Struct EventBus

Source
pub struct EventBus { /* private fields */ }
Expand description

Event bus for publishing and subscribing to node events

The EventBus is the central coordination point for the event system. It allows components to publish events and provides two mechanisms for subscribing to events:

  1. Callback-based: Register an EventSubscriber to receive events via callbacks
  2. Channel-based: Get a broadcast::Receiver<NodeEvent> for async event processing

§Thread Safety

The EventBus is designed to be thread-safe, with all mutable state protected by appropriate synchronization primitives. It can be safely shared across threads using Arc<EventBus>.

§Example Usage

use std::sync::Arc;
use tap_node::event::{EventBus, NodeEvent};

async fn example() {
    // Create a new event bus
    let event_bus = Arc::new(EventBus::new());

    // Subscribe to events using a channel
    let mut receiver = event_bus.subscribe_channel();

    // Publish an event using public methods
    let did = "did:example:123".to_string();
    event_bus.publish_agent_registered(did).await;

    // Process events from the channel
    tokio::spawn(async move {
        while let Ok(event) = receiver.recv().await {
            println!("Received event: {:?}", event);
        }
    });
}

Implementations§

Source§

impl EventBus

Source

pub fn new() -> Self

Create a new event bus

Source

pub async fn subscribe(&self, subscriber: Arc<dyn EventSubscriber>)

Subscribe to node events

Source

pub fn subscribe_channel(&self) -> Receiver<NodeEvent>

Get a receiver for node events

Source

pub async fn unsubscribe(&self, subscriber: &Arc<dyn EventSubscriber>)

Remove a subscriber from the event bus

Source

pub async fn publish_message_received(&self, message: Message)

Publish a message received event

Source

pub async fn publish_message_sent( &self, message: Message, from: String, to: String, )

Publish a message sent event

Source

pub async fn publish_agent_registered(&self, did: String)

Publish an agent registered event

Source

pub async fn publish_agent_unregistered(&self, did: String)

Publish an agent unregistered event

Source

pub async fn publish_agent_message(&self, did: String, message: Vec<u8>)

Publish an agent message event

Source

pub async fn publish_did_resolved(&self, did: String, success: bool)

Publish a DID resolved event

Trait Implementations§

Source§

impl Clone for EventBus

Source§

fn clone(&self) -> Self

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 Default for EventBus

Source§

fn default() -> Self

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

Auto Trait Implementations§

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> AsAny for T
where T: 'static,

Source§

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

Return a reference to self as Any
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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. 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> ToOwned for T
where T: Clone,

Source§

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

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,