use crate::models;
use serde::{Deserialize, Serialize};
#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
pub struct MaterializedPartition {
#[serde(rename = "asset_kind")]
pub asset_kind: models::AssetKind,
#[serde(rename = "asset_path")]
pub asset_path: String,
#[serde(rename = "partition")]
pub partition: String,
#[serde(rename = "status")]
pub status: Status,
#[serde(rename = "snapshot_id", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub snapshot_id: Option<Option<i64>>,
#[serde(rename = "row_count", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub row_count: Option<Option<i64>>,
#[serde(rename = "job_id", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub job_id: Option<Option<uuid::Uuid>>,
#[serde(rename = "materialized_at")]
pub materialized_at: String,
#[serde(rename = "error", default, with = "::serde_with::rust::double_option", skip_serializing_if = "Option::is_none")]
pub error: Option<Option<String>>,
}
impl MaterializedPartition {
pub fn new(asset_kind: models::AssetKind, asset_path: String, partition: String, status: Status, materialized_at: String) -> MaterializedPartition {
MaterializedPartition {
asset_kind,
asset_path,
partition,
status,
snapshot_id: None,
row_count: None,
job_id: None,
materialized_at,
error: None,
}
}
}
#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
pub enum Status {
#[serde(rename = "running")]
Running,
#[serde(rename = "materialized")]
Materialized,
#[serde(rename = "failed")]
Failed,
}
impl Default for Status {
fn default() -> Status {
Self::Running
}
}