Broker

Struct Broker 

Source
pub struct Broker {
    inner: Mutex<BrokerInner>,
}
Expand description

The central pub/sub broker for WaveEvents.

Fields§

§inner: Mutex<BrokerInner>

Implementations§

Source§

impl Broker

Source

pub fn new() -> Self

Source

pub fn set_client(&self, client: Box<dyn WpsClient>)

Source

pub fn subscribe(&self, route_id: &str, sub: SubscriptionRequest)

Subscribe a route to an event, optionally scoped.

Replay-on-subscribe: after registering the route, immediately deliver any persisted events that match the subscription. Lets late subscribers catch up on the most recent state without waiting for the next publish — closes the race for live-log streaming where the frontend learns the tool_use_id only after the wrapper has already finished publishing.

Source

fn replay_to_route( inner: &mut BrokerInner, route_id: &str, sub: &SubscriptionRequest, )

Deliver any persisted events matching sub to route_id. Called inside subscribe so replay happens atomically under the broker lock — no live event published mid-replay can interleave.

Once-per-(route, event, scope). The frontend (frontend/app/store/wps.ts) flushes eventsub for the shared ws-main route on every listener add/remove. Replaying persisted history on each of those flushes would re-emit completed bash logs every pane mount / tab switch / sibling subscription. The replayed set tracks tuples that already received their backfill and short-circuits subsequent resubscribes. Cleared per-route in unsubscribe_all so a true reconnect (route dropped + re-registered) gets a fresh replay.

Star-scope replay is intentionally not implemented (rare, requires scanning every persist key; can add later if needed).

Source

pub fn unsubscribe(&self, route_id: &str, event_name: &str)

Unsubscribe a route from a specific event.

Source

pub fn unsubscribe_all(&self, route_id: &str)

Unsubscribe a route from all events.

Also clears the replayed tracker for this route so a future reconnect (route registers again from scratch) gets a fresh replay of persisted history. Without this, a transient WebSocket drop would silently lose all subsequent replay.

Source

fn unsubscribe_nolock(inner: &mut BrokerInner, route_id: &str, event_name: &str)

Source

pub fn publish(&self, event: WaveEvent)

Publish an event to all matching subscribers.

Source

pub fn read_event_history( &self, event_type: &str, scope: &str, max_items: usize, ) -> Vec<WaveEvent>

Read persisted event history.

Source

fn persist_event(inner: &mut BrokerInner, event: &WaveEvent)

Source

fn get_matching_routes(inner: &BrokerInner, event: &WaveEvent) -> Vec<String>

Trait Implementations§

Source§

impl Default for Broker

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl !Freeze for Broker

§

impl RefUnwindSafe for Broker

§

impl Send for Broker

§

impl Sync for Broker

§

impl Unpin for Broker

§

impl UnwindSafe for Broker

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
§

impl<T> Downcast for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

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

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

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

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

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.

§

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

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. Read more
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.
§

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

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
§

fn with_current_subscriber(self) -> WithDispatch<Self>

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

impl<A, B, T> HttpServerConnExec<A, B> for T
where B: Body,