Skip to content

Commit

Permalink
Merge pull request #22 from b-rad15/main
Browse files Browse the repository at this point in the history
feat: sysctl quadlet option
  • Loading branch information
k9withabone authored Dec 1, 2023
2 parents bc5f5fe + 09d067d commit 3c249ed
Show file tree
Hide file tree
Showing 3 changed files with 30 additions and 24 deletions.
24 changes: 0 additions & 24 deletions src/cli/container/podman.rs
Original file line number Diff line number Diff line change
Expand Up @@ -388,12 +388,6 @@ pub struct PodmanArgs {
#[arg(long, value_name = "NAME")]
subuidname: Option<String>,

/// Configure namespaced kernel parameters at runtime
///
/// Can be specified multiple times
#[arg(long, value_name = "NAME=VALUE")]
sysctl: Vec<String>,

/// Run container in systemd mode
///
/// Default is true
Expand Down Expand Up @@ -532,7 +526,6 @@ impl Default for PodmanArgs {
stop_timeout: None,
subgidname: None,
subuidname: None,
sysctl: Vec::new(),
systemd: None,
timeout: None,
tls_verify: None,
Expand Down Expand Up @@ -623,7 +616,6 @@ impl PodmanArgs {
+ self.stop_timeout.iter().len()
+ self.subgidname.iter().len()
+ self.subuidname.iter().len()
+ self.sysctl.len()
+ self.systemd.iter().len()
+ self.timeout.iter().len()
+ self.tls_verify.iter().len()
Expand Down Expand Up @@ -874,8 +866,6 @@ impl Display for PodmanArgs {

extend_args(&mut args, "--subuidname", &self.subuidname);

extend_args(&mut args, "--sysctl", &self.sysctl);

extend_args(&mut args, "--systemd", &self.systemd);

let timeout = self.timeout.map(|timeout| timeout.to_string());
Expand Down Expand Up @@ -960,19 +950,6 @@ impl TryFrom<&mut docker_compose_types::Service> for PodmanArgs {
.map(|(key, value)| format!("{key}={value}"))
.collect();

let sysctl = match mem::take(&mut value.sysctls) {
docker_compose_types::SysCtls::List(vec) => vec,
docker_compose_types::SysCtls::Map(map) => map
.into_iter()
.map(|(key, value)| {
let value = value
.as_ref()
.map_or_else(|| String::from("null"), ToString::to_string);
format!("{key}={value}")
})
.collect(),
};

Ok(Self {
hostname: value.hostname.take(),
privileged: value.privileged,
Expand All @@ -989,7 +966,6 @@ impl TryFrom<&mut docker_compose_types::Service> for PodmanArgs {
log_opt,
add_host: mem::take(&mut value.extra_hosts),
tty: value.tty,
sysctl,
..Self::default()
})
}
Expand Down
25 changes: 25 additions & 0 deletions src/cli/container/quadlet.rs
Original file line number Diff line number Diff line change
Expand Up @@ -237,6 +237,14 @@ pub struct QuadletOptions {
#[arg(long, value_name = "SECRET[,OPT=OPT,...]")]
secret: Vec<String>,

/// Configures namespaced kernel parameters for the container.
///
/// Converts to "Sysctl=NAME=VALUE"
///
/// Can be specified multiple times
#[arg(long, value_name = "NAME=VALUE")]
sysctl: Vec<String>,

/// Create a tmpfs mount
///
/// Converts to "Tmpfs=FS" or, if FS == /tmp, "VolatileTmp=true"
Expand Down Expand Up @@ -348,6 +356,7 @@ impl From<QuadletOptions> for crate::quadlet::Container {
read_only: value.read_only,
run_init: value.init,
secret: value.secret,
sysctl: value.sysctl,
tmpfs,
timezone: value.tz,
user,
Expand All @@ -370,6 +379,7 @@ impl TryFrom<ComposeService> for QuadletOptions {
impl TryFrom<&mut ComposeService> for QuadletOptions {
type Error = color_eyre::Report;

#[allow(clippy::too_many_lines)]
fn try_from(value: &mut ComposeService) -> Result<Self, Self::Error> {
let service = &mut value.service;

Expand Down Expand Up @@ -420,6 +430,20 @@ impl TryFrom<&mut ComposeService> for QuadletOptions {
.collect(),
};

let sysctl = match mem::take(&mut service.sysctls) {
docker_compose_types::SysCtls::List(vec) => vec,
docker_compose_types::SysCtls::Map(map) => map
.into_iter()
.map(|(key, value)| {
if let Some(value) = value {
format!("{key}={value}")
} else {
key + "=null"
}
})
.collect(),
};

let mut tmpfs = service
.tmpfs
.take()
Expand Down Expand Up @@ -461,6 +485,7 @@ impl TryFrom<&mut ComposeService> for QuadletOptions {
health_retries,
health_start_period,
health_timeout,
sysctl,
tmpfs,
mount,
user: service.user.take(),
Expand Down
5 changes: 5 additions & 0 deletions src/quadlet/container.rs
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ pub struct Container {
pub security_label_level: Option<String>,
pub security_label_type: Option<String>,
pub secret: Vec<String>,
pub sysctl: Vec<String>,
pub tmpfs: Vec<String>,
pub timezone: Option<String>,
pub user: Option<String>,
Expand Down Expand Up @@ -222,6 +223,10 @@ impl Display for Container {
writeln!(f, "Secret={secret}")?;
}

if !self.sysctl.is_empty() {
writeln_escape_spaces(f, "Sysctl", &self.sysctl)?;
}

for tmpfs in &self.tmpfs {
writeln!(f, "Tmpfs={tmpfs}")?;
}
Expand Down

0 comments on commit 3c249ed

Please sign in to comment.