pub struct EventBus { /* private fields */ }Expand description
Shared event bus for broadcasting repo events to watching agents.
Uses per-repo tokio::sync::broadcast channels so subscribers
only receive events for repos they care about. A special “all”
channel receives a copy of every published event (used by the
platform bridge).
Events that are not consumed before the channel capacity (256) is exhausted are silently dropped for lagged receivers.
Implementations§
Source§impl EventBus
impl EventBus
Sourcepub fn publish(&self, event: WatchEvent)
pub fn publish(&self, event: WatchEvent)
Publish an event to a specific repo channel AND the global “all” channel.
If there are no subscribers the event is silently discarded.
Sourcepub fn subscribe(&self, repo_id: &str) -> Receiver<WatchEvent>
pub fn subscribe(&self, repo_id: &str) -> Receiver<WatchEvent>
Subscribe to events for a specific repo.
The receiver is created while the DashMap shard lock is held so that
cleanup_idle cannot race and remove the channel between creation
and subscription.
Sourcepub fn subscribe_all(&self) -> Receiver<WatchEvent>
pub fn subscribe_all(&self) -> Receiver<WatchEvent>
Subscribe to ALL events across all repos (for the platform bridge).
Sourcepub fn remove_repo(&self, repo_id: &str)
pub fn remove_repo(&self, repo_id: &str)
Remove the channel for a specific repo (e.g. when decommissioned).
Sourcepub fn cleanup_idle(&self)
pub fn cleanup_idle(&self)
Remove channels that have no active receivers, excluding the global channel. Call periodically (e.g. every few minutes) to prevent unbounded growth.
Trait Implementations§
Auto Trait Implementations§
impl Freeze for EventBus
impl !RefUnwindSafe for EventBus
impl Send for EventBus
impl Sync for EventBus
impl Unpin for EventBus
impl UnsafeUnpin for EventBus
impl !UnwindSafe for EventBus
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
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
Source§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can
then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.Source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be
further downcast into Rc<ConcreteType> where ConcreteType implements Trait.Source§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.Source§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.Source§impl<T> DowncastSync for T
impl<T> DowncastSync for T
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>
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>
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 moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::Request