feat: v1.5.3, environment support vec string
This commit is contained in:
@@ -36,12 +36,19 @@ use crate::spec::TinyEncryptEnvelopType;
|
||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||
#[serde(rename_all = "camelCase")]
|
||||
pub struct TinyEncryptConfig {
|
||||
pub environment: Option<HashMap<String, String>>,
|
||||
pub environment: Option<HashMap<String, StringOrVecString>>,
|
||||
pub namespaces: Option<HashMap<String, String>>,
|
||||
pub envelops: Vec<TinyEncryptConfigEnvelop>,
|
||||
pub profiles: HashMap<String, Vec<String>>,
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||
#[serde(untagged)]
|
||||
pub enum StringOrVecString {
|
||||
String(String),
|
||||
Vec(Vec<String>),
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, Serialize, Deserialize)]
|
||||
#[serde(rename_all = "camelCase")]
|
||||
pub struct TinyEncryptConfigEnvelop {
|
||||
@@ -81,6 +88,10 @@ impl TinyEncryptConfig {
|
||||
|
||||
if let Some(environment) = &config.environment {
|
||||
for (k, v) in environment {
|
||||
let v = match v {
|
||||
StringOrVecString::String(s) => { s.to_string() }
|
||||
StringOrVecString::Vec(vs) => { vs.join(",") }
|
||||
};
|
||||
debugging!("Set env: {}={}", k, v);
|
||||
env::set_var(k, v);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user