1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
use chrono::offset::Utc;
use chrono::DateTime;
use uuid::Uuid;
use nakadi::model::{FlowId, PartitionId};
#[derive(Debug, Clone, Serialize)]
pub struct OutgoingMetadata {
pub eid: Uuid,
#[serde(skip_serializing_if = "Option::is_none")]
pub event_type: Option<String>,
pub occurred_at: DateTime<Utc>,
pub parent_eids: Vec<Uuid>,
#[serde(skip_serializing_if = "Option::is_none")]
pub partition: Option<PartitionId>,
}
#[derive(Debug, Clone, Deserialize)]
pub struct IncomingMetadata {
pub eid: Uuid,
pub event_type: String,
pub occurred_at: DateTime<Utc>,
pub received_at: DateTime<Utc>,
pub version: String,
#[serde(default)]
pub parent_eids: Vec<Uuid>,
pub partition: PartitionId,
pub flow_id: FlowId,
}