Trait sc_consensus_slots::SimpleSlotWorker
source · pub trait SimpleSlotWorker<B: BlockT> {
type BlockImport: BlockImport<B, Transaction = <Self::Proposer as Proposer<B>>::Transaction> + Send + 'static;
type SyncOracle: SyncOracle;
type JustificationSyncLink: JustificationSyncLink<B>;
type CreateProposer: Future<Output = Result<Self::Proposer, Error>> + Send + Unpin + 'static;
type Proposer: Proposer<B> + Send;
type Claim: Send + Sync + 'static;
type EpochData: Send + Sync + 'static;
Show 17 methods
fn logging_target(&self) -> &'static str;
fn block_import(&mut self) -> &mut Self::BlockImport;
fn epoch_data(
&self,
header: &B::Header,
slot: Slot
) -> Result<Self::EpochData, Error>;
fn authorities_len(&self, epoch_data: &Self::EpochData) -> Option<usize>;
fn claim_slot<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
header: &'life1 B::Header,
slot: Slot,
epoch_data: &'life2 Self::EpochData
) -> Pin<Box<dyn Future<Output = Option<Self::Claim>> + Send + 'async_trait>>
where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait;
fn pre_digest_data(&self, slot: Slot, claim: &Self::Claim) -> Vec<DigestItem> ⓘ;
fn block_import_params<'life0, 'life1, 'async_trait>(
&'life0 self,
header: B::Header,
header_hash: &'life1 B::Hash,
body: Vec<B::Extrinsic>,
storage_changes: StorageChanges<<Self::BlockImport as BlockImport<B>>::Transaction, B>,
public: Self::Claim,
epoch: Self::EpochData
) -> Pin<Box<dyn Future<Output = Result<BlockImportParams<B, <Self::BlockImport as BlockImport<B>>::Transaction>, Error>> + Send + 'async_trait>>
where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait;
fn force_authoring(&self) -> bool;
fn sync_oracle(&mut self) -> &mut Self::SyncOracle;
fn justification_sync_link(&mut self) -> &mut Self::JustificationSyncLink;
fn proposer(&mut self, block: &B::Header) -> Self::CreateProposer;
fn telemetry(&self) -> Option<TelemetryHandle>;
fn proposing_remaining_duration(&self, slot_info: &SlotInfo<B>) -> Duration;
fn notify_slot(
&self,
_header: &B::Header,
_slot: Slot,
_epoch_data: &Self::EpochData
) { ... }
fn should_backoff(&self, _slot: Slot, _chain_head: &B::Header) -> bool { ... }
fn propose<'life0, 'life1, 'async_trait>(
&'life0 mut self,
proposer: Self::Proposer,
claim: &'life1 Self::Claim,
slot_info: SlotInfo<B>,
proposing_remaining: Delay
) -> Pin<Box<dyn Future<Output = Option<Proposal<B, <Self::Proposer as Proposer<B>>::Transaction, <Self::Proposer as Proposer<B>>::Proof>>> + Send + 'async_trait>>
where
Self: Send + 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
{ ... }
fn on_slot<'life0, 'async_trait>(
&'life0 mut self,
slot_info: SlotInfo<B>
) -> Pin<Box<dyn Future<Output = Option<SlotResult<B, <Self::Proposer as Proposer<B>>::Proof>>> + Send + 'async_trait>>
where
Self: Sync + Send + 'async_trait,
'life0: 'async_trait,
{ ... }
}
Expand description
A skeleton implementation for SlotWorker
which tries to claim a slot at
its beginning and tries to produce a block if successfully claimed, timing
out if block production takes too long.
Required Associated Types§
sourcetype BlockImport: BlockImport<B, Transaction = <Self::Proposer as Proposer<B>>::Transaction> + Send + 'static
type BlockImport: BlockImport<B, Transaction = <Self::Proposer as Proposer<B>>::Transaction> + Send + 'static
A handle to a BlockImport
.
sourcetype SyncOracle: SyncOracle
type SyncOracle: SyncOracle
A handle to a SyncOracle
.
sourcetype JustificationSyncLink: JustificationSyncLink<B>
type JustificationSyncLink: JustificationSyncLink<B>
A handle to a JustificationSyncLink
, allows hooking into the sync module to control the
justification sync process.
Required Methods§
sourcefn logging_target(&self) -> &'static str
fn logging_target(&self) -> &'static str
The logging target to use when logging messages.
sourcefn block_import(&mut self) -> &mut Self::BlockImport
fn block_import(&mut self) -> &mut Self::BlockImport
A handle to a BlockImport
.
sourcefn epoch_data(
&self,
header: &B::Header,
slot: Slot
) -> Result<Self::EpochData, Error>
fn epoch_data(
&self,
header: &B::Header,
slot: Slot
) -> Result<Self::EpochData, Error>
Returns the epoch data necessary for authoring. For time-dependent epochs, use the provided slot number as a canonical source of time.
Returns the number of authorities given the epoch data. None indicate that the authorities information is incomplete.
sourcefn claim_slot<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
header: &'life1 B::Header,
slot: Slot,
epoch_data: &'life2 Self::EpochData
) -> Pin<Box<dyn Future<Output = Option<Self::Claim>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn claim_slot<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
header: &'life1 B::Header,
slot: Slot,
epoch_data: &'life2 Self::EpochData
) -> Pin<Box<dyn Future<Output = Option<Self::Claim>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
Tries to claim the given slot, returning an object with claim data if successful.
sourcefn pre_digest_data(&self, slot: Slot, claim: &Self::Claim) -> Vec<DigestItem> ⓘ
fn pre_digest_data(&self, slot: Slot, claim: &Self::Claim) -> Vec<DigestItem> ⓘ
Return the pre digest data to include in a block authored with the given claim.
sourcefn block_import_params<'life0, 'life1, 'async_trait>(
&'life0 self,
header: B::Header,
header_hash: &'life1 B::Hash,
body: Vec<B::Extrinsic>,
storage_changes: StorageChanges<<Self::BlockImport as BlockImport<B>>::Transaction, B>,
public: Self::Claim,
epoch: Self::EpochData
) -> Pin<Box<dyn Future<Output = Result<BlockImportParams<B, <Self::BlockImport as BlockImport<B>>::Transaction>, Error>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn block_import_params<'life0, 'life1, 'async_trait>(
&'life0 self,
header: B::Header,
header_hash: &'life1 B::Hash,
body: Vec<B::Extrinsic>,
storage_changes: StorageChanges<<Self::BlockImport as BlockImport<B>>::Transaction, B>,
public: Self::Claim,
epoch: Self::EpochData
) -> Pin<Box<dyn Future<Output = Result<BlockImportParams<B, <Self::BlockImport as BlockImport<B>>::Transaction>, Error>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Returns a function which produces a BlockImportParams
.
Whether to force authoring if offline.
sourcefn sync_oracle(&mut self) -> &mut Self::SyncOracle
fn sync_oracle(&mut self) -> &mut Self::SyncOracle
Returns a handle to a SyncOracle
.
sourcefn justification_sync_link(&mut self) -> &mut Self::JustificationSyncLink
fn justification_sync_link(&mut self) -> &mut Self::JustificationSyncLink
Returns a handle to a JustificationSyncLink
.
sourcefn proposer(&mut self, block: &B::Header) -> Self::CreateProposer
fn proposer(&mut self, block: &B::Header) -> Self::CreateProposer
Returns a Proposer
to author on top of the given block.
sourcefn telemetry(&self) -> Option<TelemetryHandle>
fn telemetry(&self) -> Option<TelemetryHandle>
Returns a TelemetryHandle
if any.
sourcefn proposing_remaining_duration(&self, slot_info: &SlotInfo<B>) -> Duration
fn proposing_remaining_duration(&self, slot_info: &SlotInfo<B>) -> Duration
Remaining duration for proposing.
Provided Methods§
sourcefn notify_slot(
&self,
_header: &B::Header,
_slot: Slot,
_epoch_data: &Self::EpochData
)
fn notify_slot(
&self,
_header: &B::Header,
_slot: Slot,
_epoch_data: &Self::EpochData
)
Notifies the given slot. Similar to claim_slot
, but will be called no matter whether we
need to author blocks or not.
sourcefn should_backoff(&self, _slot: Slot, _chain_head: &B::Header) -> bool
fn should_backoff(&self, _slot: Slot, _chain_head: &B::Header) -> bool
Returns whether the block production should back off.
By default this function always returns false
.
An example strategy that back offs if the finalized head is lagging too much behind the tip
is implemented by BackoffAuthoringOnFinalizedHeadLagging
.
sourcefn propose<'life0, 'life1, 'async_trait>(
&'life0 mut self,
proposer: Self::Proposer,
claim: &'life1 Self::Claim,
slot_info: SlotInfo<B>,
proposing_remaining: Delay
) -> Pin<Box<dyn Future<Output = Option<Proposal<B, <Self::Proposer as Proposer<B>>::Transaction, <Self::Proposer as Proposer<B>>::Proof>>> + Send + 'async_trait>>where
Self: Send + 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
fn propose<'life0, 'life1, 'async_trait>(
&'life0 mut self,
proposer: Self::Proposer,
claim: &'life1 Self::Claim,
slot_info: SlotInfo<B>,
proposing_remaining: Delay
) -> Pin<Box<dyn Future<Output = Option<Proposal<B, <Self::Proposer as Proposer<B>>::Transaction, <Self::Proposer as Proposer<B>>::Proof>>> + Send + 'async_trait>>where
Self: Send + 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
Propose a block by Proposer
.