pub struct InMemoryEventStreamer { /* private fields */ }Expand description
In-memory event streamer implementation for development and testing.
InMemoryEventStreamer provides a simple, fast event streaming implementation that runs entirely in memory. It’s perfect for:
- Development and testing
- Single-process applications
- Prototyping event-driven architectures
For production use with multiple processes, consider a distributed streaming solution like Redis Streams or Apache Kafka.
§Example
use eventuali_core::{InMemoryEventStreamer, SubscriptionBuilder};
let streamer = InMemoryEventStreamer::new();
let subscription = SubscriptionBuilder::new().build();
let mut receiver = streamer.subscribe(subscription).await?;Implementations§
Trait Implementations§
Source§impl EventStreamer for InMemoryEventStreamer
impl EventStreamer for InMemoryEventStreamer
fn subscribe<'life0, 'async_trait>(
&'life0 self,
subscription: Subscription,
) -> Pin<Box<dyn Future<Output = Result<EventStreamReceiver>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn unsubscribe<'life0, 'life1, 'async_trait>(
&'life0 self,
subscription_id: &'life1 str,
) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn publish_event<'life0, 'async_trait>(
&'life0 self,
event: Event,
stream_position: u64,
global_position: u64,
) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
fn get_stream_position<'life0, 'life1, 'async_trait>(
&'life0 self,
stream_id: &'life1 str,
) -> Pin<Box<dyn Future<Output = Result<Option<u64>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn get_global_position<'life0, 'async_trait>(
&'life0 self,
) -> Pin<Box<dyn Future<Output = Result<u64>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
Auto Trait Implementations§
impl Freeze for InMemoryEventStreamer
impl !RefUnwindSafe for InMemoryEventStreamer
impl Send for InMemoryEventStreamer
impl Sync for InMemoryEventStreamer
impl Unpin for InMemoryEventStreamer
impl !UnwindSafe for InMemoryEventStreamer
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more