mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-18 16:55:16 +00:00
Add a SubstrateBlockAck message to the processor
When a Substrate block occurs, the coordinator is expected to emit SubstrateBlock. This causes the processor to begin a variety of plans. The processor now emits SubstrateBlockAck, explicitly listing all plan IDs, before starting signing. This lets the coordinator provide a SubstrateBlock transaction, and with it, recognize all plan IDs as valid. Prior, we would've had to have a spotty algorithm based upon the upcoming Preprocess messages, or if we immediately provided the SubstrateBlock transaction, then wait for the processor to inform us of the contained plans. This creates an explicitly proper async flow not reliant on waiting for data availability. Alternatively, we could've replaced Preprocess with (Block, Vec<Preprocess>). This would've been more efficient, yet also clunky due to the multiple usages of the Preprocess message.
This commit is contained in:
parent
70d866af6a
commit
a404944b90
2 changed files with 12 additions and 0 deletions
|
@ -134,6 +134,7 @@ pub mod coordinator {
|
|||
|
||||
#[derive(Clone, PartialEq, Eq, Debug, Zeroize, Serialize, Deserialize)]
|
||||
pub enum ProcessorMessage {
|
||||
SubstrateBlockAck { block: u64, plans: Vec<[u8; 32]> },
|
||||
BatchPreprocess { id: SignId, preprocess: Vec<u8> },
|
||||
BatchShare { id: SignId, share: [u8; 32] },
|
||||
}
|
||||
|
@ -151,6 +152,7 @@ pub mod substrate {
|
|||
},
|
||||
SubstrateBlock {
|
||||
context: SubstrateContext,
|
||||
block: u64,
|
||||
key: Vec<u8>,
|
||||
burns: Vec<OutInstructionWithBalance>,
|
||||
},
|
||||
|
|
|
@ -383,6 +383,7 @@ async fn handle_coordinator_msg<D: Db, C: Coin, Co: Coordinator>(
|
|||
|
||||
messages::substrate::CoordinatorMessage::SubstrateBlock {
|
||||
context,
|
||||
block,
|
||||
key: key_vec,
|
||||
burns,
|
||||
} => {
|
||||
|
@ -422,6 +423,15 @@ async fn handle_coordinator_msg<D: Db, C: Coin, Co: Coordinator>(
|
|||
.expect("key we don't have a scheduler for acknowledged a block")
|
||||
.schedule(outputs, payments);
|
||||
|
||||
coordinator
|
||||
.send(ProcessorMessage::Coordinator(
|
||||
messages::coordinator::ProcessorMessage::SubstrateBlockAck {
|
||||
block,
|
||||
plans: plans.iter().map(|plan| plan.id()).collect(),
|
||||
},
|
||||
))
|
||||
.await;
|
||||
|
||||
sign_plans(
|
||||
txn,
|
||||
coin,
|
||||
|
|
Loading…
Reference in a new issue