Trait node_testing::client::sp_consensus::SelectChain [−][src]
pub trait SelectChain<Block>: Sync + Send + Clone where
Block: Block, { fn leaves<'life0, 'async_trait>(
&'life0 self
) -> Pin<Box<dyn Future<Output = Result<Vec<<Block as Block>::Hash, Global>, Error>> + Send + 'async_trait, Global>>
where
'life0: 'async_trait,
Self: 'async_trait; fn best_chain<'life0, 'async_trait>(
&'life0 self
) -> Pin<Box<dyn Future<Output = Result<<Block as Block>::Header, Error>> + Send + 'async_trait, Global>>
where
'life0: 'async_trait,
Self: 'async_trait; fn finality_target<'life0, 'async_trait>(
&'life0 self,
target_hash: <Block as Block>::Hash,
_maybe_max_number: Option<<<Block as Block>::Header as Header>::Number>
) -> Pin<Box<dyn Future<Output = Result<Option<<Block as Block>::Hash>, Error>> + Send + 'async_trait, Global>>
where
'life0: 'async_trait,
Self: 'async_trait, { ... } }
Expand description
The SelectChain trait defines the strategy upon which the head is chosen if multiple forks are present for an opaque definition of “best” in the specific chain build.
The Strategy can be customized for the two use cases of authoring new blocks
upon the best chain or which fork to finalize. Unless implemented differently
by default finalization methods fall back to use authoring, so as a minimum
_authoring
-functions must be implemented.
Any particular user must make explicit, however, whether they intend to finalize or author through the using the right function call, as these might differ in some implementations.
Non-deterministically finalizing chains may only use the _authoring
functions.
Required methods
Get all leaves of the chain, i.e. block hashes that have no children currently. Leaves that can never be finalized will not be returned.
Among those leaves
deterministically pick one chain as the generally
best chain to author new blocks upon and probably (but not necessarily)
finalize.
Provided methods
fn finality_target<'life0, 'async_trait>(
&'life0 self,
target_hash: <Block as Block>::Hash,
_maybe_max_number: Option<<<Block as Block>::Header as Header>::Number>
) -> Pin<Box<dyn Future<Output = Result<Option<<Block as Block>::Hash>, Error>> + Send + 'async_trait, Global>> where
'life0: 'async_trait,
Self: 'async_trait,
fn finality_target<'life0, 'async_trait>(
&'life0 self,
target_hash: <Block as Block>::Hash,
_maybe_max_number: Option<<<Block as Block>::Header as Header>::Number>
) -> Pin<Box<dyn Future<Output = Result<Option<<Block as Block>::Hash>, Error>> + Send + 'async_trait, Global>> where
'life0: 'async_trait,
Self: 'async_trait,
Get the best descendent of target_hash
that we should attempt to
finalize next, if any. It is valid to return the given target_hash
itself if no better descendent exists.
Implementations on Foreign Types
impl<B, Block> SelectChain<Block> for LongestChain<B, Block> where
Block: Block,
B: Backend<Block>,
impl<B, Block> SelectChain<Block> for LongestChain<B, Block> where
Block: Block,
B: Backend<Block>,
pub fn leaves<'life0, 'async_trait>(
&'life0 self
) -> Pin<Box<dyn Future<Output = Result<Vec<<Block as Block>::Hash, Global>, Error>> + Send + 'async_trait, Global>> where
'life0: 'async_trait,
LongestChain<B, Block>: 'async_trait,
pub fn best_chain<'life0, 'async_trait>(
&'life0 self
) -> Pin<Box<dyn Future<Output = Result<<Block as Block>::Header, Error>> + Send + 'async_trait, Global>> where
'life0: 'async_trait,
LongestChain<B, Block>: 'async_trait,
pub fn finality_target<'life0, 'async_trait>(
&'life0 self,
target_hash: <Block as Block>::Hash,
maybe_max_number: Option<<<Block as Block>::Header as Header>::Number>
) -> Pin<Box<dyn Future<Output = Result<Option<<Block as Block>::Hash>, Error>> + Send + 'async_trait, Global>> where
'life0: 'async_trait,
LongestChain<B, Block>: 'async_trait,