use serde::{Deserialize, Serialize};
use serde_yaml::Value;
use strum_macros;
#[derive(Debug, Deserialize, Clone)]
pub struct AuditRule {
pub id: String,
pub description: String,
pub criteria: CriteriaExpr,
pub severity: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub os: Option<Vec<String>>,
}
#[derive(
Debug,
Clone,
Copy,
Serialize,
Deserialize,
PartialEq,
Eq,
strum_macros::EnumString,
strum_macros::AsRefStr,
strum_macros::EnumIter,
)]
#[strum(serialize_all = "snake_case")]
pub enum CriteriaOperator {
Equals,
Not,
Matches,
StartsWith,
EndsWith,
Contains,
Regex,
Wildcard,
InRange,
Lt,
Lte,
Gt,
Gte,
Cidr,
IsNull,
ApplicationExists,
ServiceExists,
}
#[derive(Debug, Serialize, Deserialize, Clone)]
#[serde(untagged)]
pub enum CriteriaExpr {
Group {
and: Vec<CriteriaExpr>,
},
OrGroup {
or: Vec<CriteriaExpr>,
},
NotGroup {
not: Box<CriteriaExpr>,
},
Condition(CriteriaCondition),
}
#[derive(Debug, Serialize, Deserialize, Clone)]
pub struct CriteriaCondition {
pub field: String,
#[serde(rename = "operator")]
pub operator_raw: String,
#[serde(default, skip_serializing_if = "Option::is_none")]
pub value: Option<Value>,
#[serde(skip)]
pub operator: Option<CriteriaOperator>,
}
impl CriteriaCondition {
pub fn parse_operator(&mut self) {
self.operator = self.operator_raw.parse::<CriteriaOperator>().ok();
}
}