risingwave_meta_model/
pending_sink_state.rs1use sea_orm::entity::prelude::*;
16use serde::{Deserialize, Serialize};
17
18use crate::{Epoch, SinkId};
19
20#[derive(Clone, Debug, PartialEq, Eq, EnumIter, DeriveActiveEnum, Serialize, Deserialize)]
21#[sea_orm(rs_type = "String", db_type = "string(None)")]
22pub enum SinkState {
23 #[sea_orm(string_value = "PENDING")]
24 Pending,
25 #[sea_orm(string_value = "COMMITTED")]
26 Committed,
27 #[sea_orm(string_value = "ABORTED")]
28 Aborted,
29}
30
31#[derive(Clone, Debug, PartialEq, DeriveEntityModel, Eq, Serialize, Deserialize)]
32#[sea_orm(table_name = "pending_sink_state")]
33pub struct Model {
34 #[sea_orm(primary_key, auto_increment = false)]
35 pub sink_id: SinkId,
36 #[sea_orm(primary_key, auto_increment = false)]
37 pub epoch: Epoch,
38 pub sink_state: SinkState,
39 pub metadata: Vec<u8>,
40}
41
42impl ActiveModelBehavior for ActiveModel {}
43
44#[derive(Copy, Clone, Debug, EnumIter, DeriveRelation)]
45pub enum Relation {
46 #[sea_orm(
47 belongs_to = "super::sink::Entity",
48 from = "Column::SinkId",
49 to = "super::sink::Column::SinkId",
50 on_update = "NoAction",
51 on_delete = "Cascade"
52 )]
53 Sink,
54 #[sea_orm(
55 belongs_to = "super::object::Entity",
56 from = "Column::SinkId",
57 to = "super::object::Column::Oid",
58 on_update = "NoAction",
59 on_delete = "Cascade"
60 )]
61 Object,
62}