Create autorun script capabilities
This commit is contained in:
parent
a28f0af02c
commit
2cd8878490
2 changed files with 38 additions and 1 deletions
35
src/lib.rs
35
src/lib.rs
|
|
@ -1,6 +1,6 @@
|
||||||
use std::{
|
use std::{
|
||||||
collections::HashMap,
|
collections::HashMap,
|
||||||
fs::{self, read_to_string},
|
fs::{self, read_dir, read_to_string},
|
||||||
path::PathBuf,
|
path::PathBuf,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
@ -57,6 +57,38 @@ fn print_containerfile() -> impl Function {
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn print_autorun_scripts() -> impl Function {
|
||||||
|
Box::new(
|
||||||
|
|args: &HashMap<String, tera::Value>| -> tera::Result<tera::Value> {
|
||||||
|
match args.get("mode") {
|
||||||
|
Some(v) => match from_value::<String>(v.clone()) {
|
||||||
|
Ok(mode) if mode == "pre" || mode == "post" => {
|
||||||
|
Ok(read_dir(format!("scripts/{mode}"))?
|
||||||
|
.fold(String::from(""), |mut acc: String, script| match script {
|
||||||
|
Ok(entry) => {
|
||||||
|
let file_name = entry.file_name();
|
||||||
|
if let Some(file_name) = file_name.to_str() {
|
||||||
|
if file_name.ends_with(".sh") {
|
||||||
|
acc += format!(
|
||||||
|
"RUN /tmp/scripts/{mode}/{file_name} {mode}\n"
|
||||||
|
)
|
||||||
|
.as_str();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
acc
|
||||||
|
}
|
||||||
|
Err(_) => acc,
|
||||||
|
})
|
||||||
|
.into())
|
||||||
|
}
|
||||||
|
_ => Err("Mode must be pre/post".into()),
|
||||||
|
},
|
||||||
|
None => Err("Need arg 'mode' set with 'pre' or 'post'".into()),
|
||||||
|
}
|
||||||
|
},
|
||||||
|
)
|
||||||
|
}
|
||||||
|
|
||||||
pub fn setup_tera(recipe: String) -> Result<(Tera, Context)> {
|
pub fn setup_tera(recipe: String) -> Result<(Tera, Context)> {
|
||||||
let recipe_de =
|
let recipe_de =
|
||||||
serde_yaml::from_str::<Recipe>(fs::read_to_string(PathBuf::from(&recipe))?.as_str())?
|
serde_yaml::from_str::<Recipe>(fs::read_to_string(PathBuf::from(&recipe))?.as_str())?
|
||||||
|
|
@ -68,6 +100,7 @@ pub fn setup_tera(recipe: String) -> Result<(Tera, Context)> {
|
||||||
let mut tera = Tera::default();
|
let mut tera = Tera::default();
|
||||||
tera.add_raw_template("Containerfile", DEFAULT_CONTAINERFILE)?;
|
tera.add_raw_template("Containerfile", DEFAULT_CONTAINERFILE)?;
|
||||||
tera.register_function("print_containerfile", print_containerfile());
|
tera.register_function("print_containerfile", print_containerfile());
|
||||||
|
tera.register_function("print_autorun_scripts", print_autorun_scripts());
|
||||||
|
|
||||||
Ok((tera, context))
|
Ok((tera, context))
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -32,6 +32,8 @@ RUN find /tmp/scripts -type f -exec chmod +x {} \;
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
|
{{ print_autorun_scripts(mode = "pre") }}
|
||||||
|
|
||||||
{% for script in scripts.pre %}
|
{% for script in scripts.pre %}
|
||||||
RUN /bin/bash -c '/tmp/scripts/{{ script }} pre'
|
RUN /bin/bash -c '/tmp/scripts/{{ script }} pre'
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
|
@ -66,6 +68,8 @@ RUN echo "-- firstboot: Removing all \"firstboot\" components --"; \
|
||||||
|
|
||||||
RUN rpm-ostree install {% for app in rpm.install %}{{ app }} {% endfor %}
|
RUN rpm-ostree install {% for app in rpm.install %}{{ app }} {% endfor %}
|
||||||
|
|
||||||
|
{{ print_autorun_scripts(mode = "post") }}
|
||||||
|
|
||||||
{% for script in scripts.post -%}
|
{% for script in scripts.post -%}
|
||||||
RUN /bin/bash -c '/tmp/scripts/{{ script }} post'
|
RUN /bin/bash -c '/tmp/scripts/{{ script }} post'
|
||||||
{% endfor -%}
|
{% endfor -%}
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue