[WIP] Encryption for secure values (#183)

This commit is contained in:
Gregory Schier
2025-04-15 07:18:26 -07:00
committed by GitHub
parent e114a85c39
commit 2e55a1bd6d
208 changed files with 4063 additions and 28698 deletions

View File

@@ -13,6 +13,8 @@ pub trait TemplateCallback {
fn_name: &str,
args: HashMap<String, String>,
) -> impl Future<Output = Result<String>> + Send;
fn transform_arg(&self, fn_name: &str, arg_name: &str, arg_value: &str) -> Result<String>;
}
pub async fn render_json_value_raw<T: TemplateCallback>(
@@ -104,16 +106,16 @@ async fn render_value<T: TemplateCallback>(
}
None => return Err(VariableNotFound(name)),
},
Val::Bool { value } => value.to_string(),
Val::Fn { name, args } => {
// let empty = "".to_string();
let mut resolved_args: HashMap<String, String> = HashMap::new();
for a in args {
let v = Box::pin(render_value(a.value, vars, cb, depth)).await?;
resolved_args.insert(a.name, v);
}
cb.run(name.as_str(), resolved_args.clone()).await?
let result = cb.run(name.as_str(), resolved_args.clone()).await?;
Box::pin(parse_and_render_at_depth(&result, vars, cb, depth)).await?
}
Val::Bool { value } => value.to_string(),
Val::Null => "".into(),
};
@@ -134,6 +136,15 @@ mod parse_and_render_tests {
async fn run(&self, _fn_name: &str, _args: HashMap<String, String>) -> Result<String> {
todo!()
}
fn transform_arg(
&self,
_fn_name: &str,
_arg_name: &str,
arg_value: &str,
) -> Result<String> {
Ok(arg_value.to_string())
}
}
#[tokio::test]
@@ -228,6 +239,15 @@ mod parse_and_render_tests {
async fn run(&self, fn_name: &str, args: HashMap<String, String>) -> Result<String> {
Ok(format!("{fn_name}: {}, {:?} {:?}", args.len(), args.get("a"), args.get("b")))
}
fn transform_arg(
&self,
_fn_name: &str,
_arg_name: &str,
arg_value: &str,
) -> Result<String> {
Ok(arg_value.to_string())
}
}
assert_eq!(parse_and_render(template, &vars, &CB {}).await?, result);
Ok(())
@@ -247,6 +267,15 @@ mod parse_and_render_tests {
_ => "".to_string(),
})
}
fn transform_arg(
&self,
_fn_name: &str,
_arg_name: &str,
_arg_value: &str,
) -> Result<String> {
todo!()
}
}
assert_eq!(parse_and_render(template, &vars, &CB {}).await?, result.to_string());
@@ -267,6 +296,15 @@ mod parse_and_render_tests {
_ => "".to_string(),
})
}
fn transform_arg(
&self,
_fn_name: &str,
_arg_name: &str,
_arg_value: &str,
) -> Result<String> {
todo!()
}
}
assert_eq!(parse_and_render(template, &vars, &CB {}).await?, result.to_string());
@@ -288,6 +326,44 @@ mod parse_and_render_tests {
_ => "".to_string(),
})
}
fn transform_arg(
&self,
_fn_name: &str,
_arg_name: &str,
_arg_value: &str,
) -> Result<String> {
todo!()
}
}
assert_eq!(parse_and_render(template, &vars, &CB {}).await?, result.to_string());
Ok(())
}
#[tokio::test]
async fn render_fn_return_template() -> Result<()> {
let mut vars = HashMap::new();
vars.insert("foo".to_string(), "bar".to_string());
let template = r#"${[ no_op(inner='${[ foo ]}') ]}"#;
let result = r#"bar"#;
struct CB {}
impl TemplateCallback for CB {
async fn run(&self, fn_name: &str, args: HashMap<String, String>) -> Result<String> {
Ok(match fn_name {
"no_op" => args["inner"].to_string(),
_ => "".to_string(),
})
}
fn transform_arg(
&self,
_fn_name: &str,
_arg_name: &str,
_arg_value: &str,
) -> Result<String> {
todo!()
}
}
assert_eq!(parse_and_render(template, &vars, &CB {}).await?, result.to_string());
@@ -308,6 +384,15 @@ mod parse_and_render_tests {
_ => "".to_string(),
})
}
fn transform_arg(
&self,
_fn_name: &str,
_arg_name: &str,
arg_value: &str,
) -> Result<String> {
Ok(arg_value.to_string())
}
}
assert_eq!(parse_and_render(template, &vars, &CB {}).await?, result.to_string());
@@ -324,6 +409,15 @@ mod parse_and_render_tests {
async fn run(&self, _fn_name: &str, _args: HashMap<String, String>) -> Result<String> {
Err(RenderError("Failed to do it!".to_string()))
}
fn transform_arg(
&self,
_fn_name: &str,
_arg_name: &str,
arg_value: &str,
) -> Result<String> {
Ok(arg_value.to_string())
}
}
assert_eq!(
@@ -337,7 +431,7 @@ mod parse_and_render_tests {
#[cfg(test)]
mod render_json_value_raw_tests {
use crate::error::Result;
use crate::{render_json_value_raw, TemplateCallback};
use crate::{TemplateCallback, render_json_value_raw};
use serde_json::json;
use std::collections::HashMap;
@@ -347,6 +441,15 @@ mod render_json_value_raw_tests {
async fn run(&self, _fn_name: &str, _args: HashMap<String, String>) -> Result<String> {
todo!()
}
fn transform_arg(
&self,
_fn_name: &str,
_arg_name: &str,
arg_value: &str,
) -> Result<String> {
Ok(arg_value.to_string())
}
}
#[tokio::test]