pub enum Msg<Ctx: Context> {
Subscribe(Box<dyn Subscriber<NetworkEvent<Ctx>>>),
PublishConsensusMsg(SignedConsensusMsg<Ctx>),
PublishLivenessMsg(LivenessMsg<Ctx>),
PublishProposalPart(StreamMessage<Ctx::ProposalPart>),
BroadcastStatus(Status<Ctx>),
OutgoingRequest(PeerId, Request<Ctx>, RpcReplyPort<OutboundRequestId>),
OutgoingResponse(InboundRequestId, Response<Ctx>),
DumpState(RpcReplyPort<Option<NetworkStateDump>>),
UpdatePersistentPeers(PersistentPeersOp, RpcReplyPort<Result<(), PersistentPeerError>>),
UpdateValidatorSet(Ctx::ValidatorSet),
// some variants omitted
}Variants§
Subscribe(Box<dyn Subscriber<NetworkEvent<Ctx>>>)
Subscribe this actor to receive gossip events
PublishConsensusMsg(SignedConsensusMsg<Ctx>)
Publish a signed consensus message
PublishLivenessMsg(LivenessMsg<Ctx>)
Publish a liveness message
PublishProposalPart(StreamMessage<Ctx::ProposalPart>)
Publish a proposal part
BroadcastStatus(Status<Ctx>)
Broadcast status to all direct peers
OutgoingRequest(PeerId, Request<Ctx>, RpcReplyPort<OutboundRequestId>)
Send a request to a peer, returning the outbound request ID
OutgoingResponse(InboundRequestId, Response<Ctx>)
Send a response for a request to a peer
DumpState(RpcReplyPort<Option<NetworkStateDump>>)
Request to dump the current network state
UpdatePersistentPeers(PersistentPeersOp, RpcReplyPort<Result<(), PersistentPeerError>>)
Add or remove a persistent peer at runtime
UpdateValidatorSet(Ctx::ValidatorSet)
Update the validator set for the current height
Auto Trait Implementations§
impl<Ctx> !Freeze for Msg<Ctx>
impl<Ctx> !RefUnwindSafe for Msg<Ctx>
impl<Ctx> Send for Msg<Ctx>
impl<Ctx> !Sync for Msg<Ctx>
impl<Ctx> Unpin for Msg<Ctx>where
<Ctx as Context>::ValidatorSet: Unpin,
<Ctx as Context>::Height: Unpin,
<Ctx as Context>::Vote: Unpin,
<<Ctx as Context>::SigningScheme as SigningScheme>::Signature: Unpin,
<Ctx as Context>::Proposal: Unpin,
<<Ctx as Context>::Value as Value>::Id: Unpin,
<Ctx as Context>::ProposalPart: Unpin,
<Ctx as Context>::Address: Unpin,
impl<Ctx> UnsafeUnpin for Msg<Ctx>where
<Ctx as Context>::ValidatorSet: UnsafeUnpin,
<Ctx as Context>::Height: UnsafeUnpin,
<Ctx as Context>::Vote: UnsafeUnpin,
<<Ctx as Context>::SigningScheme as SigningScheme>::Signature: UnsafeUnpin,
<Ctx as Context>::Proposal: UnsafeUnpin,
<<Ctx as Context>::Value as Value>::Id: UnsafeUnpin,
<Ctx as Context>::ProposalPart: UnsafeUnpin,
impl<Ctx> !UnwindSafe for Msg<Ctx>
Blanket Implementations§
Source§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
Source§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
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> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> Message for T
impl<T> Message for T
Source§fn from_boxed(m: BoxedMessage) -> Result<Self, BoxedDowncastErr>
fn from_boxed(m: BoxedMessage) -> Result<Self, BoxedDowncastErr>
Convert a BoxedMessage to this concrete type
Source§fn box_message(self, pid: &ActorId) -> Result<BoxedMessage, BoxedDowncastErr>
fn box_message(self, pid: &ActorId) -> Result<BoxedMessage, BoxedDowncastErr>
Convert this message to a BoxedMessage