Chekov
A CQRS/ES
framework for building application in Rust
[](https://github.com/Freyskeyd/chekov/actions) [](https://coveralls.io/github/Freyskeyd/chekov?branch=master) [](https://deps.rs/repo/github/freyskeyd/chekov) [](https://crates.io/crates/chekov) [](https://docs.rs/chekov) [](https://freyskeyd.github.io/chekov/chekov/)
Table of Contents
Features
Postgres
EventStore backend
- Dispatch
Command
to Aggregate
- Generate
Event
from Aggregate
- Store and notify
Event
with subscriptions
- Dispatch
Event
to EventHandler
Getting started
Choosing an EventStore backend
Chekov works only with Postgres
backend for now. The choice is easy to make!
But some more backends need to be implemented, see the related issue.
Defining Aggregates
An Aggregate is a struct that hold a domain state. Here's an example of a UserAggregate:
```rust
[derive(Default, Aggregate)]
[aggregate(identity = "user")]
struct User {
userid: Option,
accountid: Option,
}
/// Define an Executor for the CreateUser
command
/// The result is a list of events in case of success
impl CommandExecutor for User {
fn execute(cmd: CreateUser, state: &Self) -> Result, CommandExecutorError> {
Ok(vec![UserCreated {
userid: cmd.userid,
accountid: cmd.account_id,
}])
}
}
/// Define an Applier for the UserCreated
event
/// Applier is a mutation action on the aggregate
[chekov::applier]
impl EventApplier for User {
fn apply(&mut self, event: &UserCreated) -> Result<(), ApplyError> {
self.userid = Some(event.userid);
self.accountid = Some(event.accountid);
Ok(())
}
}
```
Defining Commands
You need to create a struct per command, any type of struct can implement Command
but we advise to use struct for a better readability.
A command can only produce (or not) one type of events and it targets a single Aggregate.
A command must have a single and unique identifier
that is used to route the command to the right target.
```rust
[derive(Debug, Command)]
[command(event = "UserCreated", aggregate = "User")]
struct CreateUser {
#[command(identifier)]
userid: Uuid,
accountid: Uuid,
}
```
Defining Events
An Event
can be a struct
or an enum
.
```rust
[derive(Event, Deserialize, Serialize)]
struct UserCreated {
userid: Uuid,
accountid: Uuid,
}
```
Defining Saga
Not implemented yet