From 216791a4bfada703693e3a829c5e39219aefcf6e Mon Sep 17 00:00:00 2001 From: Kyle Huey Date: Wed, 20 Dec 2017 09:07:25 -0800 Subject: [PATCH 1/2] Update compose_yml. --- src/plugins/transform/secrets_config.in.rs | 4 ++-- src/plugins/transform/vault.rs | 6 +++--- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/plugins/transform/secrets_config.in.rs b/src/plugins/transform/secrets_config.in.rs index 43a66ec0..84bf2b5d 100644 --- a/src/plugins/transform/secrets_config.in.rs +++ b/src/plugins/transform/secrets_config.in.rs @@ -9,11 +9,11 @@ struct ServiceSecrets { } impl ServiceSecrets { - fn to_compose_env(&self) -> BTreeMap> { + fn to_compose_env(&self) -> BTreeMap>> { let mut env = BTreeMap::new(); for (var, val) in &self.secrets { let val = dc::escape(val).expect("escape string should never fail"); - env.insert(var.to_owned(), val); + env.insert(var.to_owned(), Some(val)); } env } diff --git a/src/plugins/transform/vault.rs b/src/plugins/transform/vault.rs index 76658049..395172fb 100644 --- a/src/plugins/transform/vault.rs +++ b/src/plugins/transform/vault.rs @@ -313,7 +313,7 @@ impl PluginTransform for Plugin { // Insert our VAULT_ADDR value into the generated files. service .environment - .insert("VAULT_ADDR".to_owned(), dc::escape(generator.addr())?); + .insert("VAULT_ADDR".to_owned(), Some(dc::escape(generator.addr())?)); // Get a list of policy "patterns" that apply to this service. let mut raw_policies = config.default_policies.clone(); @@ -351,13 +351,13 @@ impl PluginTransform for Plugin { .chain_err(|| format!("could not generate token for '{}'", name))?; service .environment - .insert("VAULT_TOKEN".to_owned(), dc::escape(token)?); + .insert("VAULT_TOKEN".to_owned(), Some(dc::escape(token)?)); // Add in any extra environment variables. for (var, val) in &config.extra_environment { service .environment - .insert(var.to_owned(), dc::escape(interpolated(val)?)?); + .insert(var.to_owned(), Some(dc::escape(interpolated(val)?)?)); } } Ok(()) From c290f05efc7db901f6fcfca1eb7441ec1859e3d9 Mon Sep 17 00:00:00 2001 From: Kyle Huey Date: Thu, 21 Dec 2017 11:03:41 -0800 Subject: [PATCH 2/2] Update compose_yml some more. This is not just mechanical. Things of note: If the `io.fdy.cage.srcdir` is set but null, we will use the default srcdir. Similarly `io.fdy.cage.shell` will use the default shell. A null `io.fdy.cage.test` value is treated as if it were unset. Missing values for `io.fdy.cage.lib.*` labels cause errors. --- Cargo.lock | 4 +--- Cargo.toml | 2 +- src/ext/service.rs | 22 +++++++++++++++------- src/plugins/transform/labels.rs | 4 ++-- 4 files changed, 19 insertions(+), 13 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 7296cc8a..9da2c112 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -93,7 +93,7 @@ dependencies = [ "cli_test_dir 0.1.4 (registry+https://github.com/rust-lang/crates.io-index)", "clippy 0.0.176 (registry+https://github.com/rust-lang/crates.io-index)", "colored 1.6.0 (registry+https://github.com/rust-lang/crates.io-index)", - "compose_yml 0.0.52 (registry+https://github.com/rust-lang/crates.io-index)", + "compose_yml 0.0.52", "copy_dir 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)", "env_logger 0.4.3 (registry+https://github.com/rust-lang/crates.io-index)", "error-chain 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -220,7 +220,6 @@ dependencies = [ [[package]] name = "compose_yml" version = "0.0.52" -source = "registry+https://github.com/rust-lang/crates.io-index" dependencies = [ "error-chain 0.5.0 (registry+https://github.com/rust-lang/crates.io-index)", "lazy_static 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", @@ -1240,7 +1239,6 @@ dependencies = [ "checksum clippy_lints 0.0.176 (registry+https://github.com/rust-lang/crates.io-index)" = "41a8d1856b660dae1e2f15ec3a6321f5548eae902b9fc4c8b12596ac9f769162" "checksum coco 0.1.1 (registry+https://github.com/rust-lang/crates.io-index)" = "c06169f5beb7e31c7c67ebf5540b8b472d23e3eade3b2ec7d1f5b504a85f91bd" "checksum colored 1.6.0 (registry+https://github.com/rust-lang/crates.io-index)" = "b0aa3473e85a3161b59845d6096b289bb577874cafeaf75ea1b1beaa6572c7fc" -"checksum compose_yml 0.0.52 (registry+https://github.com/rust-lang/crates.io-index)" = "c22fec933335fa3c2cb16ddcf813c762900967cf117fa27f8d02ced9272a4078" "checksum cookie 0.2.5 (registry+https://github.com/rust-lang/crates.io-index)" = "0e3d6405328b6edb412158b3b7710e2634e23f3614b9bb1c412df7952489a626" "checksum copy_dir 0.1.2 (registry+https://github.com/rust-lang/crates.io-index)" = "6e4281031634644843bd2f5aa9c48cf98fc48d6b083bd90bb11becf10deaf8b0" "checksum dbghelp-sys 0.2.0 (registry+https://github.com/rust-lang/crates.io-index)" = "97590ba53bcb8ac28279161ca943a924d1fd4a8fb3fa63302591647c4fc5b850" diff --git a/Cargo.toml b/Cargo.toml index 0a136877..77ae7e69 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -45,7 +45,7 @@ boondock = { version = "0.0.49", default-features = false } clap = { version = "2.14", features = ["yaml"] } clippy = { version = "0.0.*", optional = true } colored = "1.3" -compose_yml = "0.0.52" +compose_yml = { path = "../compose_yml" } env_logger = "0.4" error-chain = "0.5" glob = "0.2" diff --git a/src/ext/service.rs b/src/ext/service.rs index 71933a1f..8e3be342 100644 --- a/src/ext/service.rs +++ b/src/ext/service.rs @@ -56,9 +56,11 @@ impl ServiceExt for dc::Service { fn source_mount_dir(&self) -> Result { let default = dc::escape("/app")?; - let srcdir = self.labels - .get("io.fdy.cage.srcdir") - .unwrap_or_else(|| &default); + let srcdir = match self.labels + .get("io.fdy.cage.srcdir") { + Some(&Some(ref v)) => v, + _ => &default, + }; Ok(srcdir.value()?.to_owned()) } @@ -76,14 +78,16 @@ impl ServiceExt for dc::Service { fn shell(&self) -> Result { let default = dc::escape("sh")?; - let shell = self.labels - .get("io.fdy.cage.shell") - .unwrap_or_else(|| &default); + let shell = match self.labels + .get("io.fdy.cage.shell") { + Some(&Some(ref v)) => v, + _ => &default, + }; Ok(shell.value()?.to_owned()) } fn test_command(&self) -> Result> { - let raw = self.labels.get("io.fdy.cage.test").ok_or_else(|| { + let raw = self.labels.get("io.fdy.cage.test").and_then(|v| v.clone()).ok_or_else(|| { err("specify a value for the label io.fdy.cage.test to run tests") })?; let mut lexer = shlex::Shlex::new(raw.value()?); @@ -128,6 +132,10 @@ impl ServiceExt for dc::Service { || -> Error { ErrorKind::UnknownLibKey(lib_name).into() }, )?; + let mount_as = mount_as.as_ref().ok_or_else(|| { + err!("specify a value for {}", prefix) + })?; + libs.push(SourceMount { container_path: mount_as.value()?.to_owned(), source, diff --git a/src/plugins/transform/labels.rs b/src/plugins/transform/labels.rs index 9aa93f7a..6e27ae51 100644 --- a/src/plugins/transform/labels.rs +++ b/src/plugins/transform/labels.rs @@ -48,10 +48,10 @@ impl PluginTransform for Plugin { let target = ctx.project.current_target().name(); service .labels - .insert("io.fdy.cage.target".into(), dc::value(target.into())); + .insert("io.fdy.cage.target".into(), Some(dc::value(target.into()))); service .labels - .insert("io.fdy.cage.pod".into(), dc::value(ctx.pod.name().into())); + .insert("io.fdy.cage.pod".into(), Some(dc::value(ctx.pod.name().into()))); // TODO LOW: Remove metadata-only `io.fdy.cage.` labels? }