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
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
use std::future::Future;
use std::pin::Pin;
use async_trait::async_trait;
use chrono::{DateTime, Utc};
use serde::de::DeserializeOwned;
use serde::Serialize;
use uuid::Uuid;
use crate::esrs::SequenceNumber;
#[async_trait]
pub trait EventStore<Event: Serialize + DeserializeOwned + Send + Sync, Error> {
async fn by_aggregate_id(&self, id: Uuid) -> Result<Vec<StoreEvent<Event>>, Error>;
async fn persist(
&self,
aggregate_id: Uuid,
events: Vec<Event>,
starting_sequence_number: SequenceNumber,
) -> Result<Vec<StoreEvent<Event>>, Error>;
async fn close(&self);
}
pub trait ProjectorStore<Event: Serialize + DeserializeOwned + Send + Sync, Executor, Error> {
fn project_event<'a>(
&'a self,
store_event: &'a StoreEvent<Event>,
executor: &'a mut Executor,
) -> Pin<Box<dyn Future<Output = Result<(), Error>> + Send + 'a>>
where
Self: Sync + 'a;
}
#[async_trait]
pub trait EraserStore<Event: Serialize + DeserializeOwned + Send + Sync, Error> {
async fn delete(&self, aggregate_id: Uuid) -> Result<(), Error>;
}
pub struct StoreEvent<Event: Serialize + DeserializeOwned + Send + Sync> {
pub id: Uuid,
pub aggregate_id: Uuid,
pub payload: Event,
pub occurred_on: DateTime<Utc>,
pub sequence_number: SequenceNumber,
}
impl<Event: Serialize + DeserializeOwned + Send + Sync> StoreEvent<Event> {
pub fn sequence_number(&self) -> SequenceNumber {
self.sequence_number
}
pub fn payload(&self) -> &Event {
&self.payload
}
}