Struct rings_node::prelude::message::handlers::MessageHandler
source · pub struct MessageHandler { /* private fields */ }
Expand description
MessageHandler will manage resources.
Implementations§
source§impl MessageHandler
impl MessageHandler
sourcepub fn new(
dht: Arc<PeerRing, Global>,
callback: Option<Box<dyn MessageCallback + Sync + Send, Global>>,
validator: Option<Box<dyn MessageValidator + Sync + Send, Global>>
) -> MessageHandler
pub fn new( dht: Arc<PeerRing, Global>, callback: Option<Box<dyn MessageCallback + Sync + Send, Global>>, validator: Option<Box<dyn MessageValidator + Sync + Send, Global>> ) -> MessageHandler
Create a new MessageHandler Instance.
sourcepub fn handle_message<'life0, 'life_self, 'async_recursion>(
&'life_self self,
payload: &'life0 MessagePayload<Message>
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_recursion, Global>>where
'life0: 'async_recursion,
'life_self: 'async_recursion,
pub fn handle_message<'life0, 'life_self, 'async_recursion>( &'life_self self, payload: &'life0 MessagePayload<Message> ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_recursion, Global>>where 'life0: 'async_recursion, 'life_self: 'async_recursion,
Handle builtin message.
Trait Implementations§
source§impl Clone for MessageHandler
impl Clone for MessageHandler
source§fn clone(&self) -> MessageHandler
fn clone(&self) -> MessageHandler
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl HandleMsg<ConnectNodeReport> for MessageHandler
impl HandleMsg<ConnectNodeReport> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 ConnectNodeReport
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 ConnectNodeReport ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<ConnectNodeSend> for MessageHandler
impl HandleMsg<ConnectNodeSend> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 ConnectNodeSend
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 ConnectNodeSend ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<CustomMessage> for MessageHandler
impl HandleMsg<CustomMessage> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
_: &'life2 CustomMessage
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, _: &'life2 CustomMessage ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<FindSuccessorReport> for MessageHandler
impl HandleMsg<FindSuccessorReport> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 FindSuccessorReport
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 FindSuccessorReport ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<FindSuccessorSend> for MessageHandler
impl HandleMsg<FindSuccessorSend> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 FindSuccessorSend
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 FindSuccessorSend ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<FoundVNode> for MessageHandler
impl HandleMsg<FoundVNode> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 FoundVNode
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 FoundVNode ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<JoinDHT> for MessageHandler
impl HandleMsg<JoinDHT> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 JoinDHT
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 JoinDHT ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<LeaveDHT> for MessageHandler
impl HandleMsg<LeaveDHT> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_ctx: &'life1 MessagePayload<Message>,
msg: &'life2 LeaveDHT
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, _ctx: &'life1 MessagePayload<Message>, msg: &'life2 LeaveDHT ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<NotifyPredecessorReport> for MessageHandler
impl HandleMsg<NotifyPredecessorReport> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_ctx: &'life1 MessagePayload<Message>,
msg: &'life2 NotifyPredecessorReport
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, _ctx: &'life1 MessagePayload<Message>, msg: &'life2 NotifyPredecessorReport ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<NotifyPredecessorSend> for MessageHandler
impl HandleMsg<NotifyPredecessorSend> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 NotifyPredecessorSend
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 NotifyPredecessorSend ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<QueryForTopoInfoReport> for MessageHandler
impl HandleMsg<QueryForTopoInfoReport> for MessageHandler
Try join received node into DHT after received from TopoInfo.
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 QueryForTopoInfoReport
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 QueryForTopoInfoReport ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<QueryForTopoInfoSend> for MessageHandler
impl HandleMsg<QueryForTopoInfoSend> for MessageHandler
QueryForTopoInfoSend is direct message
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 QueryForTopoInfoSend
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 QueryForTopoInfoSend ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<SearchVNode> for MessageHandler
impl HandleMsg<SearchVNode> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 SearchVNode
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 SearchVNode ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Search VNode via successor If a VNode is storead local, it will response immediately.(See Chordstorageinterface::storage_fetch)
source§impl HandleMsg<SyncVNodeWithSuccessor> for MessageHandler
impl HandleMsg<SyncVNodeWithSuccessor> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
_ctx: &'life1 MessagePayload<Message>,
msg: &'life2 SyncVNodeWithSuccessor
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, _ctx: &'life1 MessagePayload<Message>, msg: &'life2 SyncVNodeWithSuccessor ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
source§impl HandleMsg<VNodeOperation> for MessageHandler
impl HandleMsg<VNodeOperation> for MessageHandler
source§fn handle<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 MessagePayload<Message>,
msg: &'life2 VNodeOperation
) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
MessageHandler: 'async_trait,
fn handle<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 MessagePayload<Message>, msg: &'life2 VNodeOperation ) -> Pin<Box<dyn Future<Output = Result<Vec<MessageHandlerEvent, Global>, Error>> + Send + 'async_trait, Global>>where 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, MessageHandler: 'async_trait,
Message handler.
Auto Trait Implementations§
impl !RefUnwindSafe for MessageHandler
impl Send for MessageHandler
impl Sync for MessageHandler
impl Unpin for MessageHandler
impl !UnwindSafe for MessageHandler
Blanket Implementations§
§impl<T> ArchivePointee for T
impl<T> ArchivePointee for T
§type ArchivedMetadata = ()
type ArchivedMetadata = ()
The archived version of the pointer metadata for this type.
§fn pointer_metadata(
_: &<T as ArchivePointee>::ArchivedMetadata
) -> <T as Pointee>::Metadata
fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata ) -> <T as Pointee>::Metadata
Converts some archived metadata to the pointer metadata for itself.
§impl<'a, T> AsTaggedExplicit<'a> for Twhere
T: 'a,
impl<'a, T> AsTaggedExplicit<'a> for Twhere T: 'a,
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere T: 'a,
§impl<'a, T> AsTaggedImplicit<'a> for Twhere
T: 'a,
impl<'a, T> AsTaggedImplicit<'a> for Twhere T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere T: 'a,
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
§impl<F, W, T, D> Deserialize<With<T, W>, D> for Fwhere
W: DeserializeWith<F, T, D>,
D: Fallible + ?Sized,
F: ?Sized,
impl<F, W, T, D> Deserialize<With<T, W>, D> for Fwhere W: DeserializeWith<F, T, D>, D: Fallible + ?Sized, F: ?Sized,
§fn deserialize(
&self,
deserializer: &mut D
) -> Result<With<T, W>, <D as Fallible>::Error>
fn deserialize( &self, deserializer: &mut D ) -> Result<With<T, W>, <D as Fallible>::Error>
Deserializes using the given deserializer
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
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>
§impl<T> LayoutRaw for T
impl<T> LayoutRaw for T
§fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
fn layout_raw(_: <T as Pointee>::Metadata) -> Result<Layout, LayoutError>
Gets the layout of the type.
§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> Upcastable for Twhere
T: Any + Send + Sync + 'static,
impl<T> Upcastable for Twhere T: Any + Send + Sync + 'static,
§fn upcast_any_ref(&self) -> &(dyn Any + 'static)
fn upcast_any_ref(&self) -> &(dyn Any + 'static)
upcast ref
§fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn upcast_any_mut(&mut self) -> &mut (dyn Any + 'static)
upcast mut ref