#![allow(unused_imports, dead_code, non_camel_case_types, unused_variables, clippy::all)]
use super::super::context::{LoadContext, SaveContext};
use super::validation_error::ValidationError;
#[derive(Debug, Clone, Default)]
pub struct ValidationResult {
pub valid: bool,
pub errors: Vec<ValidationError>,
}
impl ValidationResult {
pub fn new() -> Self {
Self::default()
}
pub fn from_json(json: &str, ctx: &LoadContext) -> Result<Self, serde_json::Error> {
let value: serde_json::Value = serde_json::from_str(json)?;
Ok(Self::load_from_value(&value, ctx))
}
pub fn from_yaml(yaml: &str, ctx: &LoadContext) -> Result<Self, serde_yaml::Error> {
let value: serde_json::Value = serde_yaml::from_str(yaml)?;
Ok(Self::load_from_value(&value, ctx))
}
pub fn load_from_value(value: &serde_json::Value, ctx: &LoadContext) -> Self {
let value = ctx.process_input(value.clone());
Self {
valid: value.get("valid").and_then(|v| v.as_bool()).unwrap_or(false),
errors: value.get("errors").map(|v| Self::load_errors(v, ctx)).unwrap_or_default(),
}
}
pub fn to_value(&self, ctx: &SaveContext) -> serde_json::Value {
let mut result = serde_json::Map::new();
result.insert("valid".to_string(), serde_json::Value::Bool(self.valid));
if !self.errors.is_empty() {
result.insert("errors".to_string(), Self::save_errors(&self.errors, ctx));
}
ctx.process_dict(serde_json::Value::Object(result))
}
pub fn to_json(&self, ctx: &SaveContext) -> Result<String, serde_json::Error> {
serde_json::to_string_pretty(&self.to_value(ctx))
}
pub fn to_yaml(&self, ctx: &SaveContext) -> Result<String, serde_yaml::Error> {
serde_yaml::to_string(&self.to_value(ctx))
}
fn load_errors(data: &serde_json::Value, ctx: &LoadContext) -> Vec<ValidationError> {
match data {
serde_json::Value::Array(arr) => {
arr.iter().map(|v| ValidationError::load_from_value(v, ctx)).collect()
}
_ => Vec::new(),
}
}
fn save_errors(items: &[ValidationError], ctx: &SaveContext) -> serde_json::Value {
serde_json::Value::Array(items.iter().map(|item| item.to_value(ctx)).collect::<Vec<_>>())
}
}