EventStore

Struct EventStore 

Source
pub struct EventStore<A: Aggregate<E>, E> { /* private fields */ }
Expand description

The event store used to persisting events. Besides from using the store, to well, store events, it can also be used to fetch them, and to stream updates synced between different instances

Implementations§

Source§

impl<A: Aggregate<E> + Send + Sync + Clone, E: Send> EventStore<A, E>

Source

pub fn builder() -> EventStoreBuilder<A, E, (), ()>

Source

pub async fn aggregate( &self, aggregate_id: Uuid, ) -> Result<Option<A>, AdapterError>

Fetches a single aggregate

Source

pub async fn aggregate_without_snapshot( &self, aggregate_id: Uuid, ) -> Result<Option<A>, AdapterError>

Fetches a single aggregate

Source

pub async fn ids(&self) -> Result<BoxStream<'_, Uuid>, AdapterError>

Returns all ids in the store

Source

pub async fn all( &self, ) -> Result<BoxStream<'_, Result<A, AdapterError>>, AdapterError>

Returns all aggregates in the store

Source

pub async fn create<T: IntoEventList<E>>( &self, events: T, ) -> Result<A, CreateError>

Creates a new aggregate

Source

pub async fn create_with_external_ids( &self, events: Vec<Event<E>>, external_ids: Vec<String>, ) -> Result<A, CreateError>

Creates a new aggregate

Source

pub async fn store<T: IntoEventList<E>, F: Fn(&A) -> T + Send + Sync>( &self, aggregate_id: Uuid, callback: F, ) -> Result<A, StoreError>

Stores events to an existing aggregate

Source

pub async fn try_store<T: IntoEventList<E>, F: Fn(&A) -> Result<T, I> + Send + Sync, I: Send + Sync>( &self, aggregate_id: Uuid, callback: F, ) -> Result<Result<A, I>, StoreError>

Stores events to an existing aggregate with the option to throw a validation error

Source

pub async fn stream_realtime( &self, ) -> Result<BoxStream<'_, Result<RealtimeStreamData<A, E>, AdapterError>>, AdapterError>

Source

pub async fn remove(&self, aggregate_id: Uuid) -> Result<(), AdapterError>

Removes the aggregate permanently

Trait Implementations§

Source§

impl<A: Clone + Aggregate<E>, E: Clone> Clone for EventStore<A, E>

Source§

fn clone(&self) -> EventStore<A, E>

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl<A: Debug + Aggregate<E>, E: Debug> Debug for EventStore<A, E>

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<A, E> Freeze for EventStore<A, E>

§

impl<A, E> !RefUnwindSafe for EventStore<A, E>

§

impl<A, E> Send for EventStore<A, E>
where A: Send,

§

impl<A, E> Sync for EventStore<A, E>
where A: Sync,

§

impl<A, E> Unpin for EventStore<A, E>
where A: Unpin,

§

impl<A, E> !UnwindSafe for EventStore<A, E>

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.