Struct FileSystemEventLog

Source
pub struct FileSystemEventLog<T, E>
where T: Default + Encodable + Decodable + Send + Sync, E: Error + Debug + From<Error> + From<Error> + From<Error> + Send + Sync + 'static,
{ /* private fields */ }
Expand description

Filesystem event log.

Appends events to an append-only writer and reads events via a reader whilst managing an in-memory merkle tree of event hashes.

Implementations§

Source§

impl<T, E> FileSystemEventLog<T, E>
where T: Default + Encodable + Decodable + Send + Sync + 'static, E: Error + Debug + From<Error> + From<Error> + From<Error> + Send + Sync + 'static,

Source

pub fn file_path(&self) -> &PathBuf

Path to the event log file.

Source

pub async fn iter( &self, reverse: bool, ) -> StdResult<Box<dyn FormatStreamIterator<EventLogRecord> + Send + Sync>, E>

Iterate the event records.

Source§

impl<E> FileSystemEventLog<WriteEvent, E>
where E: Error + Debug + From<Error> + From<Error> + From<Error> + Send + Sync + 'static,

Source

pub async fn new_folder<P: AsRef<Path>>(path: P) -> StdResult<Self, E>

Create a new folder event log file.

Source§

impl<E> FileSystemEventLog<AccountEvent, E>
where E: Error + Debug + From<Error> + From<Error> + From<Error> + Send + Sync + 'static,

Source

pub async fn new_account<P: AsRef<Path>>(path: P) -> StdResult<Self, E>

Create a new account event log file.

Source§

impl<E> FileSystemEventLog<DeviceEvent, E>
where E: Error + Debug + From<Error> + From<Error> + From<Error> + Send + Sync + 'static,

Source

pub async fn new_device(path: impl AsRef<Path>) -> StdResult<Self, E>

Create a new device event log file.

Trait Implementations§

Source§

impl<T, E> EventLog<T> for FileSystemEventLog<T, E>
where T: Default + Encodable + Decodable + Send + Sync + 'static, E: Error + Debug + From<Error> + From<Error> + From<Error> + Send + Sync + 'static,

Source§

type Error = E

Error type.
Source§

fn record_stream<'life0, 'async_trait>( &'life0 self, reverse: bool, ) -> Pin<Box<dyn Future<Output = BoxStream<'async_trait, StdResult<EventRecord, Self::Error>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Stream of event records. Read more
Source§

fn event_stream<'life0, 'async_trait>( &'life0 self, reverse: bool, ) -> Pin<Box<dyn Future<Output = BoxStream<'async_trait, StdResult<(EventRecord, T), Self::Error>>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Stream of event records and decoded events. Read more
Source§

fn diff_checked<'life0, 'async_trait>( &'life0 self, commit: Option<CommitHash>, checkpoint: CommitProof, ) -> Pin<Box<dyn Future<Output = StdResult<Diff<T>, Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Create a checked diff from a commit. Read more
Source§

fn diff_unchecked<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = StdResult<Diff<T>, Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Create an unchecked diff of all events. Read more
Source§

fn diff_events<'life0, 'life1, 'async_trait>( &'life0 self, commit: Option<&'life1 CommitHash>, ) -> Pin<Box<dyn Future<Output = StdResult<Patch<T>, Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Diff of events until a specific commit; does not include the target commit. Read more
Source§

fn tree(&self) -> &CommitTree

Commit tree contains the in-memory merkle tree.
Source§

fn rewind<'life0, 'life1, 'async_trait>( &'life0 mut self, commit: &'life1 CommitHash, ) -> Pin<Box<dyn Future<Output = StdResult<Vec<EventRecord>, Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Rewind this event log discarding commits after the specific commit. Read more
Source§

fn load_tree<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = StdResult<(), Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Load data from storage to build a commit tree in memory.
Source§

fn clear<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = StdResult<(), Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Delete all events from the log file on disc and in-memory.
Source§

fn apply<'life0, 'life1, 'async_trait>( &'life0 mut self, events: &'life1 [T], ) -> Pin<Box<dyn Future<Output = StdResult<(), Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Append a collection of events and commit the tree hashes only if all the events were successfully written.
Source§

fn apply_records<'life0, 'async_trait>( &'life0 mut self, records: Vec<EventRecord>, ) -> Pin<Box<dyn Future<Output = StdResult<(), Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Append raw event records to the event log. Read more
Source§

fn patch_checked<'life0, 'life1, 'life2, 'async_trait>( &'life0 mut self, commit_proof: &'life1 CommitProof, patch: &'life2 Patch<T>, ) -> Pin<Box<dyn Future<Output = StdResult<CheckedPatch, Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,

Append a patch to this event log only if the head of the tree matches the given proof.
Source§

fn replace_all_events<'life0, 'life1, 'async_trait>( &'life0 mut self, diff: &'life1 Diff<T>, ) -> Pin<Box<dyn Future<Output = StdResult<(), Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Replace all events in this event log with the events in the diff. Read more
Source§

fn patch_unchecked<'life0, 'life1, 'async_trait>( &'life0 mut self, patch: &'life1 Patch<T>, ) -> Pin<Box<dyn Future<Output = StdResult<(), Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Append a patch to this event log.
Source§

fn diff_records<'life0, 'life1, 'async_trait>( &'life0 self, commit: Option<&'life1 CommitHash>, ) -> Pin<Box<dyn Future<Output = StdResult<Vec<EventRecord>, Self::Error>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait,

Diff of event records until a specific commit. Read more
Source§

fn version(&self) -> u16

Encoding version.

Auto Trait Implementations§

§

impl<T, E> Freeze for FileSystemEventLog<T, E>

§

impl<T, E> RefUnwindSafe for FileSystemEventLog<T, E>

§

impl<T, E> Send for FileSystemEventLog<T, E>

§

impl<T, E> Sync for FileSystemEventLog<T, E>

§

impl<T, E> Unpin for FileSystemEventLog<T, E>
where T: Unpin, E: Unpin,

§

impl<T, E> UnwindSafe for FileSystemEventLog<T, E>
where T: UnwindSafe, E: UnwindSafe,

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

Source§

type Output = T

Should always be Self
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.
Source§

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

Source§

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

impl<T> ErasedDestructor for T
where T: 'static,

Source§

impl<T> MaybeSendSync for T