mirror of
https://github.com/paradigmxyz/reth.git
synced 2026-02-04 20:15:03 -05:00
80 lines
2.7 KiB
Rust
80 lines
2.7 KiB
Rust
use alloc::vec::Vec;
|
|
use alloy_eips::BlockHashOrNumber;
|
|
use alloy_primitives::{BlockHash, BlockNumber, U256};
|
|
use core::ops::RangeBounds;
|
|
use reth_primitives_traits::{BlockHeader, SealedHeader};
|
|
use reth_storage_errors::provider::ProviderResult;
|
|
|
|
/// A helper type alias to access [`HeaderProvider::Header`].
|
|
pub type ProviderHeader<P> = <P as HeaderProvider>::Header;
|
|
|
|
/// Client trait for fetching `Header` related data.
|
|
#[auto_impl::auto_impl(&, Arc)]
|
|
pub trait HeaderProvider: Send + Sync {
|
|
/// The header type this provider supports.
|
|
type Header: BlockHeader;
|
|
|
|
/// Check if block is known
|
|
fn is_known(&self, block_hash: &BlockHash) -> ProviderResult<bool> {
|
|
self.header(block_hash).map(|header| header.is_some())
|
|
}
|
|
|
|
/// Get header by block hash
|
|
fn header(&self, block_hash: &BlockHash) -> ProviderResult<Option<Self::Header>>;
|
|
|
|
/// Retrieves the header sealed by the given block hash.
|
|
fn sealed_header_by_hash(
|
|
&self,
|
|
block_hash: BlockHash,
|
|
) -> ProviderResult<Option<SealedHeader<Self::Header>>> {
|
|
Ok(self.header(&block_hash)?.map(|header| SealedHeader::new(header, block_hash)))
|
|
}
|
|
|
|
/// Get header by block number
|
|
fn header_by_number(&self, num: u64) -> ProviderResult<Option<Self::Header>>;
|
|
|
|
/// Get header by block number or hash
|
|
fn header_by_hash_or_number(
|
|
&self,
|
|
hash_or_num: BlockHashOrNumber,
|
|
) -> ProviderResult<Option<Self::Header>> {
|
|
match hash_or_num {
|
|
BlockHashOrNumber::Hash(hash) => self.header(&hash),
|
|
BlockHashOrNumber::Number(num) => self.header_by_number(num),
|
|
}
|
|
}
|
|
|
|
/// Get total difficulty by block hash.
|
|
fn header_td(&self, hash: &BlockHash) -> ProviderResult<Option<U256>>;
|
|
|
|
/// Get total difficulty by block number.
|
|
fn header_td_by_number(&self, number: BlockNumber) -> ProviderResult<Option<U256>>;
|
|
|
|
/// Get headers in range of block numbers
|
|
fn headers_range(
|
|
&self,
|
|
range: impl RangeBounds<BlockNumber>,
|
|
) -> ProviderResult<Vec<Self::Header>>;
|
|
|
|
/// Get a single sealed header by block number.
|
|
fn sealed_header(
|
|
&self,
|
|
number: BlockNumber,
|
|
) -> ProviderResult<Option<SealedHeader<Self::Header>>>;
|
|
|
|
/// Get headers in range of block numbers.
|
|
fn sealed_headers_range(
|
|
&self,
|
|
range: impl RangeBounds<BlockNumber>,
|
|
) -> ProviderResult<Vec<SealedHeader<Self::Header>>> {
|
|
self.sealed_headers_while(range, |_| true)
|
|
}
|
|
|
|
/// Get sealed headers while `predicate` returns `true` or the range is exhausted.
|
|
fn sealed_headers_while(
|
|
&self,
|
|
range: impl RangeBounds<BlockNumber>,
|
|
predicate: impl FnMut(&SealedHeader<Self::Header>) -> bool,
|
|
) -> ProviderResult<Vec<SealedHeader<Self::Header>>>;
|
|
}
|