reth::consensus

Trait Consensus

Source
pub trait Consensus<H = Header, B = BlockBody>: AsHeaderValidator<H> {
    // Required methods
    fn validate_body_against_header(
        &self,
        body: &B,
        header: &SealedHeader<H>,
    ) -> Result<(), ConsensusError>;
    fn validate_block_pre_execution(
        &self,
        block: &SealedBlock<H, B>,
    ) -> Result<(), ConsensusError>;
}
Expand description

Consensus is a protocol that chooses canonical chain.

Required Methods§

Source

fn validate_body_against_header( &self, body: &B, header: &SealedHeader<H>, ) -> Result<(), ConsensusError>

Ensures that body field values match the header.

Source

fn validate_block_pre_execution( &self, block: &SealedBlock<H, B>, ) -> Result<(), ConsensusError>

Validate a block disregarding world state, i.e. things that can be checked before sender recovery and execution.

See the Yellow Paper sections 4.3.2 “Holistic Validity”, 4.3.4 “Block Header Validity”, and 11.1 “Ommer Validation”.

This should not be called for the genesis block.

Note: validating blocks does not include other validations of the Consensus

Implementations on Foreign Types§

Source§

impl<'a, H, B, T> Consensus<H, B> for &'a T
where T: 'a + Consensus<H, B> + ?Sized, &'a T: AsHeaderValidator<H>,

Source§

impl<H, B, T> Consensus<H, B> for Arc<T>
where T: Consensus<H, B> + ?Sized, Arc<T>: AsHeaderValidator<H>,

Implementors§

Source§

impl<H, B> Consensus<H, B> for NoopConsensus

Source§

impl<H, B> Consensus<H, B> for TestConsensus

Source§

impl<H, B, ChainSpec> Consensus<H, B> for EthBeaconConsensus<ChainSpec>
where ChainSpec: Send + Sync + EthChainSpec + EthereumHardforks + Debug, H: BlockHeader, B: BlockBody,