pub struct CommandHandlerRouter<S, H>where
H: CommandHandlerDomainHandler<State = S>,{ /* private fields */ }Expand description
Router for command handler components (commands → events, single domain).
Domain is set at construction time. No .domain() method exists,
enforcing single-domain constraint at compile time.
§Factory Pattern (per-request handlers)
ⓘ
let db_pool = Arc::new(DbPool::new());
let router = CommandHandlerRouter::with_factory(
"agg-player",
"player",
move || PlayerHandler::new(db_pool.clone())
);Implementations§
Source§impl<S: Default + Send + Sync + 'static, H: CommandHandlerDomainHandler<State = S> + Clone> CommandHandlerRouter<S, H>
impl<S: Default + Send + Sync + 'static, H: CommandHandlerDomainHandler<State = S> + Clone> CommandHandlerRouter<S, H>
Sourcepub fn new(
name: impl Into<String>,
domain: impl Into<String>,
handler: H,
) -> Self
pub fn new( name: impl Into<String>, domain: impl Into<String>, handler: H, ) -> Self
Create a new command handler router with a static handler.
Command handlers accept commands and emit events. Single domain enforced at construction. The handler is shared across all requests.
Sourcepub fn with_factory<F>(
name: impl Into<String>,
domain: impl Into<String>,
factory: F,
) -> Self
pub fn with_factory<F>( name: impl Into<String>, domain: impl Into<String>, factory: F, ) -> Self
Create a new command handler router with a factory.
The factory is called per-request to create fresh handler instances. Use this for dependency injection.
§Example
ⓘ
let db_pool = Arc::new(DbPool::new());
let router = CommandHandlerRouter::with_factory(
"agg-player",
"player",
move || PlayerHandler::new(db_pool.clone())
);Sourcepub fn command_types(&self) -> Vec<String>
pub fn command_types(&self) -> Vec<String>
Get command types from the handler.
Sourcepub fn subscriptions(&self) -> Vec<(String, Vec<String>)>
pub fn subscriptions(&self) -> Vec<(String, Vec<String>)>
Get subscriptions for this command handler.
Sourcepub fn rebuild_state(&self, events: &EventBook) -> S
pub fn rebuild_state(&self, events: &EventBook) -> S
Rebuild state from events using the handler’s state router.
Sourcepub fn dispatch(
&self,
cmd: &ContextualCommand,
) -> Result<BusinessResponse, Status>
pub fn dispatch( &self, cmd: &ContextualCommand, ) -> Result<BusinessResponse, Status>
Dispatch a contextual command to the handler.
Auto Trait Implementations§
impl<S, H> Freeze for CommandHandlerRouter<S, H>where
H: Freeze,
impl<S, H> !RefUnwindSafe for CommandHandlerRouter<S, H>
impl<S, H> Send for CommandHandlerRouter<S, H>where
S: Send,
impl<S, H> Sync for CommandHandlerRouter<S, H>where
S: Sync,
impl<S, H> Unpin for CommandHandlerRouter<S, H>
impl<S, H> UnsafeUnpin for CommandHandlerRouter<S, H>where
H: UnsafeUnpin,
impl<S, H> !UnwindSafe for CommandHandlerRouter<S, H>
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> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request