integrationos-domain 8.0.0

Shared library for IntegrationOS
Documentation
use super::{extractor_context::ExtractorContext, root_context::RootContext, Transaction};
use crate::{
    id::Id,
    prelude::{PipelineExt, PipelineStatus},
};
use async_trait::async_trait;
use chrono::{DateTime, Utc};
use serde::{Deserialize, Serialize};
use serde_json::Value;
use std::{collections::HashMap, fmt::Display, sync::Arc};

#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
#[serde(rename_all = "camelCase")]
pub struct PipelineContext {
    pub pipeline_key: String,
    pub event_key: Id,
    pub status: PipelineStatus,
    pub stage: PipelineStage,
    #[serde(with = "chrono::serde::ts_milliseconds")]
    pub timestamp: DateTime<Utc>,
    r#type: Arc<str>,

    #[serde(flatten)]
    pub transaction: Option<Transaction>,
}

impl PipelineContext {
    pub fn new(pipeline_key: String, context: &RootContext) -> Self {
        Self {
            pipeline_key,
            event_key: context.event_key,
            status: PipelineStatus::Succeeded,
            stage: PipelineStage::New,
            timestamp: Utc::now(),
            r#type: "pipeline".into(),
            transaction: None,
        }
    }

    pub fn is_dropped(&self) -> bool {
        matches!(self.status, PipelineStatus::Dropped { .. })
    }

    pub fn is_finished(&self) -> bool {
        matches!(self.stage, PipelineStage::FinishedPipeline)
    }
}

#[async_trait]
impl PipelineExt for PipelineContext {
    fn is_complete(&self) -> bool {
        self.is_dropped() || self.is_finished()
    }

    fn context_key(&self) -> &Id {
        &self.event_key
    }
}

#[derive(Debug, Clone, PartialEq, Eq, Serialize, Deserialize)]
pub enum PipelineStage {
    New,
    ExecutingExtractors(HashMap<String, ExtractorContext>),
    ExecutedExtractors(HashMap<String, Value>),
    ExecutedTransformer(Option<Value>),
    FinishedPipeline,
}

impl Display for PipelineStage {
    fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
        match self {
            Self::New => write!(f, "New"),
            Self::ExecutingExtractors(e) => {
                write!(f, "ExecutingExtractors(")?;
                for (s, e) in e.iter() {
                    write!(f, "{{{s} => {}: {}}}", e.stage, e.status)?;
                }
                write!(f, ")")
            }
            Self::ExecutedExtractors(m) => {
                write!(f, "ExecutedExtractors(")?;
                for (s, v) in m.iter() {
                    write!(f, "{{{s} => {v}}}")?;
                }
                write!(f, ")")
            }
            Self::ExecutedTransformer(Some(v)) => {
                write!(f, "ExecutedTransformer({v})")
            }
            Self::ExecutedTransformer(None) => {
                write!(f, "ExecutedTransformer()")
            }
            Self::FinishedPipeline => write!(f, "FinishedPipeline"),
        }
    }
}