pub enum Msg<Ctx: Context> {
StartHeight(Ctx::Height, HeightParams<Ctx>),
NetworkEvent(NetworkEvent<Ctx>),
TimeoutElapsed(TimeoutElapsed<Timeout>),
ProposeValue(LocallyProposedValue<Ctx>),
ReceivedProposedValue(ProposedValue<Ctx>, ValueOrigin),
ProcessSyncResponse(ValueResponse<Ctx>),
RestartHeight(Ctx::Height, HeightParams<Ctx>),
DumpState(RpcReplyPort<Option<StateDump<Ctx>>>),
}Variants§
StartHeight(Ctx::Height, HeightParams<Ctx>)
Start consensus for the given height and provided parameters.
NetworkEvent(NetworkEvent<Ctx>)
Received an event from the gossip layer
TimeoutElapsed(TimeoutElapsed<Timeout>)
A timeout has elapsed
ProposeValue(LocallyProposedValue<Ctx>)
The proposal builder has built a value and can be used in a new proposal consensus message
ReceivedProposedValue(ProposedValue<Ctx>, ValueOrigin)
Received and assembled the full value proposed by a validator
ProcessSyncResponse(ValueResponse<Ctx>)
Process a sync response
RestartHeight(Ctx::Height, HeightParams<Ctx>)
Instructs consensus to restart at a given height with the provided parameters.
On this input consensus resets the Write-Ahead Log.
§Warning
This operation should be used with extreme caution as it can lead to safety violations:
- The application must clean all state associated with the height for which commit has failed
- Since consensus resets its write-ahead log, the node may equivocate on proposals and votes for the restarted height, potentially violating protocol safety
DumpState(RpcReplyPort<Option<StateDump<Ctx>>>)
Request to dump the current consensus state
Trait Implementations§
Source§impl<Ctx: Context> From<NetworkEvent<Ctx>> for Msg<Ctx>
impl<Ctx: Context> From<NetworkEvent<Ctx>> for Msg<Ctx>
Source§fn from(event: NetworkEvent<Ctx>) -> Self
fn from(event: NetworkEvent<Ctx>) -> Self
Converts to this type from the input type.
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>::Height: Unpin,
<Ctx as Context>::ValidatorSet: Unpin,
<Ctx as Context>::Timeouts: Unpin,
<Ctx as Context>::Value: Unpin,
<Ctx as Context>::Address: 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,
impl<Ctx> UnsafeUnpin for Msg<Ctx>where
<Ctx as Context>::Height: UnsafeUnpin,
<Ctx as Context>::ValidatorSet: UnsafeUnpin,
<Ctx as Context>::Timeouts: UnsafeUnpin,
<Ctx as Context>::Value: UnsafeUnpin,
<Ctx as Context>::Address: 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