Struct workflow_rpc::server::Interface
source · pub struct Interface<ServerContext, ConnectionContext, Ops>where
ServerContext: Clone + Send + Sync + 'static,
ConnectionContext: Clone + Send + Sync + 'static,
Ops: OpsT,{ /* private fields */ }
Expand description
Interface
struct carries a mapping of RPC methods
and notifications, used by protocols to dispatch calls
to their respective handlers.
Implementations§
source§impl<ServerContext, ConnectionContext, Ops> Interface<ServerContext, ConnectionContext, Ops>where
ServerContext: Clone + Send + Sync + 'static,
ConnectionContext: Clone + Send + Sync + 'static,
Ops: OpsT,
impl<ServerContext, ConnectionContext, Ops> Interface<ServerContext, ConnectionContext, Ops>where ServerContext: Clone + Send + Sync + 'static, ConnectionContext: Clone + Send + Sync + 'static, Ops: OpsT,
sourcepub fn new(
server_ctx: ServerContext
) -> Interface<ServerContext, ConnectionContext, Ops>
pub fn new( server_ctx: ServerContext ) -> Interface<ServerContext, ConnectionContext, Ops>
Create an interface that will contain user-defined
RPC message and notification handlers. This method
accepts server_ctx
argument that will be subsequently
passed to each RPC method or notification invocation.
sourcepub fn method<Req, Resp>(
&mut self,
op: Ops,
method: Method<ServerContext, ConnectionContext, Req, Resp>
)where
Ops: Debug + Clone,
Req: MsgT,
Resp: MsgT,
pub fn method<Req, Resp>( &mut self, op: Ops, method: Method<ServerContext, ConnectionContext, Req, Resp> )where Ops: Debug + Clone, Req: MsgT, Resp: MsgT,
Declare an RPC method handler. You can use a method!()
macro to declare the method as follows:
interface.method(MyOps::Method, method!(
| connection_ctx: ConnectionCtx,
server_ctx: ServerContext,
req: MyReq |
async move {
// ...
Ok(MyResp { })
}))
sourcepub fn notification<Msg>(
&mut self,
op: Ops,
method: Notification<ServerContext, ConnectionContext, Msg>
)where
Ops: Debug + Clone,
Msg: MsgT,
pub fn notification<Msg>( &mut self, op: Ops, method: Notification<ServerContext, ConnectionContext, Msg> )where Ops: Debug + Clone, Msg: MsgT,
Declare an RPC notification handler. You can use a notification!()
macro to declare the notification as follows:
interface.notification(MyOps::Notify, notification!(
| connection_ctx: ConnectionCtx,
server_ctx: ServerContext,
msg: MyMsg |
async move {
// ...
Ok(())
}))
Auto Trait Implementations§
impl<ServerContext, ConnectionContext, Ops> !RefUnwindSafe for Interface<ServerContext, ConnectionContext, Ops>
impl<ServerContext, ConnectionContext, Ops> Send for Interface<ServerContext, ConnectionContext, Ops>
impl<ServerContext, ConnectionContext, Ops> Sync for Interface<ServerContext, ConnectionContext, Ops>
impl<ServerContext, ConnectionContext, Ops> Unpin for Interface<ServerContext, ConnectionContext, Ops>where Ops: Unpin, ServerContext: Unpin,
impl<ServerContext, ConnectionContext, Ops> !UnwindSafe for Interface<ServerContext, ConnectionContext, Ops>
Blanket Implementations§
source§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere T: Any,
source§fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
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
.source§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Convert
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)
Convert
&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)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.