-
Notifications
You must be signed in to change notification settings - Fork 12
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
chore(code): Example app cleanup (#690)
* chore(code): Doc comments and module renaming * Renaming * Cleanup * Remove BlockMetadata
- Loading branch information
Showing
16 changed files
with
251 additions
and
257 deletions.
There are no files selected for viewing
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,181 @@ | ||
use std::time::Duration; | ||
|
||
use bytes::Bytes; | ||
use derive_where::derive_where; | ||
use tokio::sync::mpsc; | ||
use tokio::sync::oneshot; | ||
|
||
use malachite_engine::consensus::Msg as ConsensusActorMsg; | ||
use malachite_engine::network::Msg as NetworkActorMsg; | ||
|
||
use crate::app::types::core::{CommitCertificate, Context, Round, ValueId}; | ||
use crate::app::types::streaming::StreamMessage; | ||
use crate::app::types::sync::DecidedValue; | ||
use crate::app::types::{LocallyProposedValue, PeerId, ProposedValue}; | ||
|
||
pub type Reply<T> = oneshot::Sender<T>; | ||
|
||
/// Channels created for application consumption | ||
pub struct Channels<Ctx: Context> { | ||
/// Channel for receiving messages from consensus | ||
pub consensus: mpsc::Receiver<AppMsg<Ctx>>, | ||
/// Channel for sending messages to the networking layer | ||
pub network: mpsc::Sender<NetworkMsg<Ctx>>, | ||
} | ||
|
||
/// Messages sent from consensus to the application. | ||
#[derive_where(Debug)] | ||
pub enum AppMsg<Ctx: Context> { | ||
/// Notifies the application that consensus is ready. | ||
/// | ||
/// The application MAY reply with a message to instruct | ||
/// consensus to start at a given height. | ||
ConsensusReady { | ||
/// Channel for sending a [`ConsensusMsg::StartHeight`] message back to consensus | ||
reply: Reply<ConsensusMsg<Ctx>>, | ||
}, | ||
|
||
/// Notifies the application that a new consensus round has begun. | ||
StartedRound { | ||
/// Current consensus height | ||
height: Ctx::Height, | ||
/// Round that was just started | ||
round: Round, | ||
/// Proposer for that round | ||
proposer: Ctx::Address, | ||
}, | ||
|
||
/// Requests the application to build a value for consensus to run on. | ||
/// | ||
/// The application MUST reply to this message with the requested value | ||
/// within the specified timeout duration. | ||
GetValue { | ||
/// Height which consensus is at | ||
height: Ctx::Height, | ||
/// Round which consensus is at | ||
round: Round, | ||
/// Maximum time allowed for the application to respond | ||
timeout: Duration, | ||
/// Channel for sending back the value just built to consensus | ||
reply: Reply<LocallyProposedValue<Ctx>>, | ||
}, | ||
|
||
/// Requests the application to re-stream a proposal that it has already seen. | ||
/// | ||
/// The application MUST re-publish again all the proposal parts pertaining | ||
/// to that value by sending [`NetworkMsg::PublishProposalPart`] messages through | ||
/// the [`Channels::network`] channel. | ||
RestreamProposal { | ||
/// Height of the proposal | ||
height: Ctx::Height, | ||
/// Round of the proposal | ||
round: Round, | ||
/// Rround at which the proposal was locked on | ||
valid_round: Round, | ||
/// Address of the original proposer | ||
address: Ctx::Address, | ||
/// Unique identifier of the proposed value | ||
value_id: ValueId<Ctx>, | ||
}, | ||
|
||
/// Requests the earliest height available in the history maintained by the application. | ||
/// | ||
/// The application MUST respond with its earliest available height. | ||
GetHistoryMinHeight { reply: Reply<Ctx::Height> }, | ||
|
||
/// Notifies the application that consensus has received a proposal part over the network. | ||
/// | ||
/// If this part completes the full proposal, the application MUST respond | ||
/// with the complete proposed value. Otherwise, it MUST respond with `None`. | ||
ReceivedProposalPart { | ||
/// Peer whom the proposal part was received from | ||
from: PeerId, | ||
/// Received proposal part, together with its stream metadata | ||
part: StreamMessage<Ctx::ProposalPart>, | ||
/// Channel for returning the complete value if proposal is now complete | ||
reply: Reply<ProposedValue<Ctx>>, | ||
}, | ||
|
||
/// Requests the validator set for a specific height | ||
GetValidatorSet { | ||
/// Height of the validator set to retrieve | ||
height: Ctx::Height, | ||
/// Channel for sending back the validator set | ||
reply: Reply<Ctx::ValidatorSet>, | ||
}, | ||
|
||
/// Notifies the application that consensus has decided on a value. | ||
/// | ||
/// This message includes a commit certificate containing the ID of | ||
/// the value that was decided on, the height and round at which it was decided, | ||
/// and the aggregated signatures of the validators that committed to it. | ||
/// | ||
/// In response to this message, the application MAY send a [`ConsensusMsg::StartHeight`] | ||
/// message back to consensus, instructing it to start the next height. | ||
Decided { | ||
/// The certificate for the decided value | ||
certificate: CommitCertificate<Ctx>, | ||
/// Channel for instructing consensus to start the next height, if desired | ||
reply: Reply<ConsensusMsg<Ctx>>, | ||
}, | ||
|
||
/// Requests a previously decided value from the application's storage. | ||
/// | ||
/// The application MUST respond with that value if available, or `None` otherwise. | ||
GetDecidedValue { | ||
/// Height of the decided value to retrieve | ||
height: Ctx::Height, | ||
/// Channel for sending back the decided value | ||
reply: Reply<Option<DecidedValue<Ctx>>>, | ||
}, | ||
|
||
/// Notifies the application that a value has been synced from the network. | ||
/// This may happen when the node is catching up with the network. | ||
/// | ||
/// If a value can be decoded from the bytes provided, then the application MUST reply | ||
/// to this message with the decoded value. | ||
ProcessSyncedValue { | ||
/// Height of the synced value | ||
height: Ctx::Height, | ||
/// Round of the synced value | ||
round: Round, | ||
/// Address of the original proposer | ||
proposer: Ctx::Address, | ||
/// Raw encoded value data | ||
value_bytes: Bytes, | ||
/// Channel for sending back the proposed value, if successfully decoded | ||
reply: Reply<ProposedValue<Ctx>>, | ||
}, | ||
} | ||
|
||
/// Messages sent from the application to consensus. | ||
#[derive_where(Debug)] | ||
pub enum ConsensusMsg<Ctx: Context> { | ||
/// Instructs consensus to start a new height with the given validator set. | ||
StartHeight(Ctx::Height, Ctx::ValidatorSet), | ||
} | ||
|
||
impl<Ctx: Context> From<ConsensusMsg<Ctx>> for ConsensusActorMsg<Ctx> { | ||
fn from(msg: ConsensusMsg<Ctx>) -> ConsensusActorMsg<Ctx> { | ||
match msg { | ||
ConsensusMsg::StartHeight(height, validator_set) => { | ||
ConsensusActorMsg::StartHeight(height, validator_set) | ||
} | ||
} | ||
} | ||
} | ||
|
||
/// Messages sent from the application to the networking layer. | ||
#[derive_where(Debug)] | ||
pub enum NetworkMsg<Ctx: Context> { | ||
/// Publish a proposal part to the network, within a stream. | ||
PublishProposalPart(StreamMessage<Ctx::ProposalPart>), | ||
} | ||
|
||
impl<Ctx: Context> From<NetworkMsg<Ctx>> for NetworkActorMsg<Ctx> { | ||
fn from(msg: NetworkMsg<Ctx>) -> NetworkActorMsg<Ctx> { | ||
match msg { | ||
NetworkMsg::PublishProposalPart(part) => NetworkActorMsg::PublishProposalPart(part), | ||
} | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.