pub struct PostgresEvtLog<I> { /* private fields */ }
Expand description

An EvtLog implementation based on PostgreSQL.

Implementations§

source§

impl<I> PostgresEvtLog<I>
where I: ToSql + Sync,

source

pub async fn new(config: Config) -> Result<Self, Error>

Trait Implementations§

source§

impl<I: Clone> Clone for PostgresEvtLog<I>

source§

fn clone(&self) -> PostgresEvtLog<I>

Returns a copy 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<I> Debug for PostgresEvtLog<I>

source§

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

Formats the value using the given formatter. Read more
source§

impl<I> EvtLog for PostgresEvtLog<I>
where I: Clone + ToSql + Send + Sync + 'static,

source§

const MAX_SEQ_NO: NonZeroU64 = _

The maximum value for sequence numbers. As PostgreSQL does not support unsigned integers, this is i64::MAX or 9_223_372_036_854_775_807.

§

type Id = I

§

type Error = Error

source§

async fn persist<E, ToBytes, ToBytesError>( &mut self, evt: &E::Evt, id: &Self::Id, last_seq_no: Option<NonZeroU64>, to_bytes: &ToBytes ) -> Result<NonZeroU64, Self::Error>
where E: EventSourced, ToBytes: Fn(&E::Evt) -> Result<Bytes, ToBytesError> + Sync, ToBytesError: StdError + Send + Sync + 'static,

Persist the given event and optional tag for the given entity ID and return the sequence number for the persisted event. The given last sequence number is used for optimistic locking, i.e. it must match the current last sequence number of the event log.
source§

async fn last_seq_no<E>( &self, id: &Self::Id ) -> Result<Option<NonZeroU64>, Self::Error>
where E: EventSourced,

Get the last sequence number for the given entity ID.
source§

async fn evts_by_id<E, FromBytes, FromBytesError>( &self, id: &Self::Id, seq_no: NonZeroU64, from_bytes: FromBytes ) -> Result<impl Stream<Item = Result<(NonZeroU64, E::Evt), Self::Error>> + Send, Self::Error>
where E: EventSourced, FromBytes: Fn(Bytes) -> Result<E::Evt, FromBytesError> + Copy + Send + Sync + 'static, FromBytesError: StdError + Send + Sync + 'static,

Get the events for the given entity ID starting at the given sequence number.
source§

async fn evts_by_type<E, FromBytes, FromBytesError>( &self, seq_no: NonZeroU64, from_bytes: FromBytes ) -> Result<impl Stream<Item = Result<(NonZeroU64, E::Evt), Self::Error>> + Send, Self::Error>
where E: EventSourced, FromBytes: Fn(Bytes) -> Result<E::Evt, FromBytesError> + Copy + Send + Sync + 'static, FromBytesError: StdError + Send + Sync + 'static,

Get the events for the given entity type starting at the given sequence number.

Auto Trait Implementations§

§

impl<I> !RefUnwindSafe for PostgresEvtLog<I>

§

impl<I> Send for PostgresEvtLog<I>
where I: Send,

§

impl<I> Sync for PostgresEvtLog<I>
where I: Sync,

§

impl<I> Unpin for PostgresEvtLog<I>
where I: Unpin,

§

impl<I> !UnwindSafe for PostgresEvtLog<I>

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> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> Same for T

§

type Output = T

Should always be Self
source§

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

§

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>,

§

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>,

§

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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more