assemblyline-models 0.8.1

Data models for the Assemblyline malware analysis platform.
Documentation
//! Messages about configuration changes internal to assemblyline.

use serde::{Deserialize, Serialize};

use crate::types::ServiceName;

#[derive(Debug, strum::FromRepr, strum::EnumIs, PartialEq, Eq, Clone, Copy)]
#[repr(u8)]
pub enum Operation {
    Added = 1,
    Removed = 2,
    Modified = 3,
    Incompatible = 4
}

impl Serialize for Operation {
    fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
    where
        S: serde::Serializer {
        (*self as u8).serialize(serializer)
    }
}

impl<'de> Deserialize<'de> for Operation {
    fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
    where
        D: serde::Deserializer<'de> {
        let value = u8::deserialize(deserializer)?;
        Self::from_repr(value).ok_or(serde::de::Error::custom("could not read service change operation"))
    }
}

#[derive(Debug, Serialize, Deserialize)]
pub struct ServiceChange {
    pub name: ServiceName,
    pub operation: Operation,
    #[serde(default)]
    pub reason: Option<String>,
}

#[derive(Debug, Serialize, Deserialize)]
pub struct HeuristicChange {
    pub service_name: ServiceName,
    pub operation: Operation,
}


// @dataclass
// class SignatureChange:
//     signature_id: str
//     signature_type: str
//     source: str
//     operation: Operation

//     @staticmethod
//     def serialize(obj: SignatureChange) -> str:
//         return json.dumps(asdict(obj))

//     @staticmethod
//     def deserialize(data: str) -> SignatureChange:
//         return SignatureChange(**json.loads(data))