AnyHeader

Struct AnyHeader 

Source
pub struct AnyHeader {
Show 21 fields pub parent_hash: FixedBytes<32>, pub ommers_hash: FixedBytes<32>, pub beneficiary: Address, pub state_root: FixedBytes<32>, pub transactions_root: FixedBytes<32>, pub receipts_root: FixedBytes<32>, pub logs_bloom: Bloom, pub difficulty: Uint<256, 4>, pub number: u64, pub gas_limit: u64, pub gas_used: u64, pub timestamp: u64, pub extra_data: Bytes, pub mix_hash: Option<FixedBytes<32>>, pub nonce: Option<FixedBytes<8>>, pub base_fee_per_gas: Option<u64>, pub withdrawals_root: Option<FixedBytes<32>>, pub blob_gas_used: Option<u64>, pub excess_blob_gas: Option<u64>, pub parent_beacon_block_root: Option<FixedBytes<32>>, pub requests_hash: Option<FixedBytes<32>>,
}
Expand description

Block header representation with certain fields made optional to account for possible differences in network implementations.

Fields§

§parent_hash: FixedBytes<32>

Hash of the parent

§ommers_hash: FixedBytes<32>

Hash of the uncles

§beneficiary: Address

Alias of author

§state_root: FixedBytes<32>

State root hash

§transactions_root: FixedBytes<32>

Transactions root hash

§receipts_root: FixedBytes<32>

Transactions receipts root hash

§logs_bloom: Bloom

Logs bloom

§difficulty: Uint<256, 4>

Difficulty

§number: u64

Block number

§gas_limit: u64

Gas Limit

§gas_used: u64

Gas Used

§timestamp: u64

Timestamp

§extra_data: Bytes

Extra data

§mix_hash: Option<FixedBytes<32>>

Mix Hash

Before the merge this proves, combined with the nonce, that a sufficient amount of computation has been carried out on this block: the Proof-of-Work (PoW).

After the merge this is prevRandao: Randomness value for the generated payload.

This is an Option because it is not always set by non-ethereum networks.

See also https://eips.ethereum.org/EIPS/eip-4399 And https://github.com/ethereum/execution-apis/issues/328

§nonce: Option<FixedBytes<8>>

Nonce

§base_fee_per_gas: Option<u64>

Base fee per unit of gas (if past London)

§withdrawals_root: Option<FixedBytes<32>>

Withdrawals root hash added by EIP-4895 and is ignored in legacy headers.

§blob_gas_used: Option<u64>

Blob gas used

§excess_blob_gas: Option<u64>

Excess blob gas

§parent_beacon_block_root: Option<FixedBytes<32>>

EIP-4788 parent beacon block root

§requests_hash: Option<FixedBytes<32>>

EIP-7685 requests hash.

Implementations§

Source§

impl AnyHeader

Source

pub const fn seal(self, hash: FixedBytes<32>) -> Sealed<AnyHeader>

Seal the header with a known hash.

WARNING: This method does not perform validation whether the hash is correct.

Source

pub fn try_into_header(self) -> Result<Header, ValueError<AnyHeader>>

Attempts to convert this header into a Header.

This can fail if the header is missing required fields:

  • nonce
  • mix_hash

If the conversion fails, the original AnyHeader is returned.

Source

pub fn into_header_with_defaults(self) -> Header

Converts this header into a Header with default values for missing mandatory fields:

  • mix_hash
  • nonce

Trait Implementations§

Source§

impl BlockHeader for AnyHeader

Source§

fn parent_hash(&self) -> FixedBytes<32>

Retrieves the parent hash of the block
Source§

fn ommers_hash(&self) -> FixedBytes<32>

Retrieves the ommers hash of the block
Source§

fn beneficiary(&self) -> Address

Retrieves the beneficiary (miner) of the block
Source§

fn state_root(&self) -> FixedBytes<32>

Retrieves the state root hash of the block
Source§

fn transactions_root(&self) -> FixedBytes<32>

Retrieves the transactions root hash of the block
Source§

fn receipts_root(&self) -> FixedBytes<32>

Retrieves the receipts root hash of the block
Source§

fn withdrawals_root(&self) -> Option<FixedBytes<32>>

Retrieves the withdrawals root hash of the block, if available
Source§

fn logs_bloom(&self) -> Bloom

Retrieves the logs bloom filter of the block
Source§

fn difficulty(&self) -> Uint<256, 4>

Retrieves the difficulty of the block
Source§

fn number(&self) -> u64

Retrieves the block number
Source§

fn gas_limit(&self) -> u64

Retrieves the gas limit of the block
Source§

fn gas_used(&self) -> u64

Retrieves the gas used by the block
Source§

fn timestamp(&self) -> u64

Retrieves the timestamp of the block
Source§

fn mix_hash(&self) -> Option<FixedBytes<32>>

Retrieves the mix hash of the block, if available
Source§

fn nonce(&self) -> Option<FixedBytes<8>>

Retrieves the nonce of the block, if available
Source§

fn base_fee_per_gas(&self) -> Option<u64>

Retrieves the base fee per gas of the block, if available
Source§

fn blob_gas_used(&self) -> Option<u64>

Retrieves the blob gas used by the block, if available
Source§

fn excess_blob_gas(&self) -> Option<u64>

Retrieves the excess blob gas of the block, if available
Source§

fn parent_beacon_block_root(&self) -> Option<FixedBytes<32>>

Retrieves the parent beacon block root of the block, if available
Source§

fn requests_hash(&self) -> Option<FixedBytes<32>>

Retrieves the requests hash of the block, if available
Source§

fn extra_data(&self) -> &Bytes

Retrieves the block’s extra data field
Source§

fn header_info(&self) -> HeaderInfo

Extracts essential information into one container type.
Source§

fn blob_fee(&self, blob_params: BlobParams) -> Option<u128>

Returns the blob fee for this block according to the EIP-4844 spec. Read more
Source§

fn next_block_excess_blob_gas(&self, blob_params: BlobParams) -> Option<u64>

Calculate excess blob gas for the next block according to the EIP-4844 spec. Read more
Source§

fn maybe_next_block_excess_blob_gas( &self, blob_params: Option<BlobParams>, ) -> Option<u64>

Convenience function for Self::next_block_excess_blob_gas with an optional BlobParams argument. Read more
Source§

fn next_block_blob_fee(&self, blob_params: BlobParams) -> Option<u128>

Returns the blob fee for the next block according to the EIP-4844 spec. Read more
Source§

fn maybe_next_block_blob_fee( &self, blob_params: Option<BlobParams>, ) -> Option<u128>

Convenience function for Self::next_block_blob_fee with an optional BlobParams argument. Read more
Source§

fn next_block_base_fee(&self, base_fee_params: BaseFeeParams) -> Option<u64>

Calculate base fee for next block according to the EIP-1559 spec. Read more
Source§

fn parent_num_hash(&self) -> NumHash

Returns the parent block’s number and hash Read more
Source§

fn is_empty(&self) -> bool

Checks if the header is considered empty - has no transactions, no ommers or withdrawals
Source§

fn is_zero_difficulty(&self) -> bool

Checks if the block’s difficulty is set to zero, indicating a Proof-of-Stake header. Read more
Source§

fn exceeds_allowed_future_timestamp(&self, present_timestamp: u64) -> bool

Checks if the block’s timestamp is in the future based on the present timestamp. Read more
Source§

fn is_nonce_zero(&self) -> bool

Checks if the nonce exists, and if it exists, if it’s zero. Read more
Source§

impl Clone for AnyHeader

Source§

fn clone(&self) -> AnyHeader

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for AnyHeader

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
Source§

impl Default for AnyHeader

Source§

fn default() -> AnyHeader

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for AnyHeader

Source§

fn deserialize<__D>( __deserializer: __D, ) -> Result<AnyHeader, <__D as Deserializer<'de>>::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl From<Header> for AnyHeader

Source§

fn from(value: Header) -> AnyHeader

Converts to this type from the input type.
Source§

impl Hash for AnyHeader

Source§

fn hash<__H>(&self, state: &mut __H)
where __H: Hasher,

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl PartialEq for AnyHeader

Source§

fn eq(&self, other: &AnyHeader) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for AnyHeader

Source§

fn serialize<__S>( &self, __serializer: __S, ) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for AnyHeader

Source§

impl StructuralPartialEq for AnyHeader

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<'de, T> BorrowedRpcObject<'de> for T
where T: RpcBorrow<'de> + RpcSend,

Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<'de, T> RpcBorrow<'de> for T
where T: Deserialize<'de> + Debug + Send + Sync + Unpin,

Source§

impl<T> RpcObject for T
where T: RpcSend + RpcRecv,

Source§

impl<T> RpcRecv for T
where T: DeserializeOwned + Debug + Send + Sync + Unpin + 'static,

Source§

impl<T> RpcSend for T
where T: Serialize + Clone + Debug + Send + Sync + Unpin,

Layout§

Note: Most layout information is completely unstable and may even differ between compilations. The only exception is types with certain repr(...) attributes. Please see the Rust Reference's “Type Layout” chapter for details on type layout guarantees.

Size: 728 bytes