Struct reth_node_core::primitives::SealedBlockWithSenders
source · pub struct SealedBlockWithSenders {
pub block: SealedBlock,
pub senders: Vec<Address>,
}
Expand description
Sealed block with senders recovered from transactions.
Fields§
§block: SealedBlock
Sealed block
senders: Vec<Address>
List of senders that match transactions from block.
Implementations§
source§impl SealedBlockWithSenders
impl SealedBlockWithSenders
sourcepub fn new(
block: SealedBlock,
senders: Vec<Address>,
) -> Option<SealedBlockWithSenders>
pub fn new( block: SealedBlock, senders: Vec<Address>, ) -> Option<SealedBlockWithSenders>
New sealed block with sender. Return none if len of tx and senders does not match
sourcepub fn into_components(self) -> (SealedBlock, Vec<Address>)
pub fn into_components(self) -> (SealedBlock, Vec<Address>)
Split Structure to its components
sourcepub fn unseal(self) -> BlockWithSenders
pub fn unseal(self) -> BlockWithSenders
Returns the unsealed BlockWithSenders
sourcepub fn transactions(&self) -> impl Iterator<Item = &TransactionSigned>
pub fn transactions(&self) -> impl Iterator<Item = &TransactionSigned>
Returns an iterator over all transactions in the block.
sourcepub fn transactions_with_sender(
&self,
) -> impl Iterator<Item = (&Address, &TransactionSigned)>
pub fn transactions_with_sender( &self, ) -> impl Iterator<Item = (&Address, &TransactionSigned)>
Returns an iterator over all transactions and their sender.
sourcepub fn into_transactions(self) -> Vec<TransactionSigned>
pub fn into_transactions(self) -> Vec<TransactionSigned>
Consumes the block and returns the transactions of the block.
sourcepub fn into_transactions_ecrecovered(
self,
) -> impl Iterator<Item = TransactionSignedEcRecovered>
pub fn into_transactions_ecrecovered( self, ) -> impl Iterator<Item = TransactionSignedEcRecovered>
Returns an iterator over all transactions in the chain.
Methods from Deref<Target = SealedBlock>§
sourcepub fn hash(&self) -> FixedBytes<32>
pub fn hash(&self) -> FixedBytes<32>
Header hash.
sourcepub fn blob_transactions_iter(&self) -> impl Iterator<Item = &TransactionSigned>
pub fn blob_transactions_iter(&self) -> impl Iterator<Item = &TransactionSigned>
Returns an iterator over all blob transactions of the block
sourcepub fn blob_transactions(&self) -> Vec<&TransactionSigned>
pub fn blob_transactions(&self) -> Vec<&TransactionSigned>
Returns only the blob transactions, if any, from the block body.
sourcepub fn blob_versioned_hashes_iter(
&self,
) -> impl Iterator<Item = &FixedBytes<32>>
pub fn blob_versioned_hashes_iter( &self, ) -> impl Iterator<Item = &FixedBytes<32>>
Returns an iterator over all blob versioned hashes from the block body.
sourcepub fn blob_versioned_hashes(&self) -> Vec<&FixedBytes<32>>
pub fn blob_versioned_hashes(&self) -> Vec<&FixedBytes<32>>
Returns all blob versioned hashes from the block body.
sourcepub fn senders(&self) -> Option<Vec<Address>>
pub fn senders(&self) -> Option<Vec<Address>>
Expensive operation that recovers transaction signer. See SealedBlockWithSenders
.
sourcepub fn size(&self) -> usize
pub fn size(&self) -> usize
Calculates a heuristic for the in-memory size of the SealedBlock
.
sourcepub fn blob_gas_used(&self) -> u64
pub fn blob_gas_used(&self) -> u64
Calculates the total gas used by blob transactions in the sealed block.
sourcepub fn has_blob_transactions(&self) -> bool
pub fn has_blob_transactions(&self) -> bool
Returns whether or not the block contains any blob transactions.
sourcepub fn has_eip7702_transactions(&self) -> bool
pub fn has_eip7702_transactions(&self) -> bool
Returns whether or not the block contains any eip-7702 transactions.
sourcepub fn ensure_transaction_root_valid(
&self,
) -> Result<(), GotExpected<FixedBytes<32>>>
pub fn ensure_transaction_root_valid( &self, ) -> Result<(), GotExpected<FixedBytes<32>>>
Ensures that the transaction root in the block header is valid.
The transaction root is the Keccak 256-bit hash of the root node of the trie structure populated with each transaction in the transactions list portion of the block.
§Returns
Returns Ok(())
if the calculated transaction root matches the one stored in the header,
indicating that the transactions in the block are correctly represented in the trie.
Returns Err(error)
if the transaction root validation fails, providing a GotExpected
error containing the calculated and expected roots.
sourcepub fn raw_transactions(&self) -> Vec<Bytes>
pub fn raw_transactions(&self) -> Vec<Bytes>
Returns a vector of transactions RLP encoded with TransactionSigned::encode_enveloped
.
Methods from Deref<Target = SealedHeader>§
pub fn hash(&self) -> FixedBytes<32>
pub fn hash(&self) -> FixedBytes<32>
Returns header/block hash.
pub fn num_hash(&self) -> NumHash
pub fn num_hash(&self) -> NumHash
Return the number hash tuple.
pub fn size(&self) -> usize
pub fn size(&self) -> usize
Calculates a heuristic for the in-memory size of the SealedHeader
.
pub fn set_header(&mut self, header: Header)
Available on crate feature test-utils
only.
pub fn set_header(&mut self, header: Header)
test-utils
only.Updates the block header.
pub fn set_hash(&mut self, hash: FixedBytes<32>)
Available on crate feature test-utils
only.
pub fn set_hash(&mut self, hash: FixedBytes<32>)
test-utils
only.Updates the block hash.
pub fn set_parent_hash(&mut self, hash: FixedBytes<32>)
Available on crate feature test-utils
only.
pub fn set_parent_hash(&mut self, hash: FixedBytes<32>)
test-utils
only.Updates the parent block hash.
pub fn set_block_number(&mut self, number: u64)
Available on crate feature test-utils
only.
pub fn set_block_number(&mut self, number: u64)
test-utils
only.Updates the block number.
pub fn set_state_root(&mut self, state_root: FixedBytes<32>)
Available on crate feature test-utils
only.
pub fn set_state_root(&mut self, state_root: FixedBytes<32>)
test-utils
only.Updates the block state root.
pub fn set_difficulty(&mut self, difficulty: Uint<256, 4>)
Available on crate feature test-utils
only.
pub fn set_difficulty(&mut self, difficulty: Uint<256, 4>)
test-utils
only.Updates the block difficulty.
Methods from Deref<Target = Header>§
pub fn is_zero_difficulty(&self) -> bool
pub fn is_zero_difficulty(&self) -> bool
Checks if the block’s difficulty is set to zero, indicating a Proof-of-Stake header.
This function is linked to EIP-3675, proposing the consensus upgrade to Proof-of-Stake: EIP-3675
Verifies whether, as per the EIP, the block’s difficulty is updated to zero, signifying the transition to a Proof-of-Stake mechanism.
Returns true
if the block’s difficulty matches the constant zero set by the EIP.
pub fn ensure_extradata_valid(&self) -> Result<(), HeaderError>
pub fn ensure_extradata_valid(&self) -> Result<(), HeaderError>
Performs a sanity check on the extradata field of the header.
§Errors
Returns an error if the extradata size is larger than 100 KB.
pub fn ensure_difficulty_valid(&self) -> Result<(), HeaderError>
pub fn ensure_difficulty_valid(&self) -> Result<(), HeaderError>
Performs a sanity check on the block difficulty field of the header.
§Errors
Returns an error if the block difficulty exceeds 80 bits.
pub fn ensure_well_formed(&self) -> Result<(), HeaderError>
pub fn ensure_well_formed(&self) -> Result<(), HeaderError>
Performs combined sanity checks on multiple header fields.
This method combines checks for block difficulty and extradata sizes.
§Errors
Returns an error if either the block difficulty exceeds 80 bits or if the extradata size is larger than 100 KB.
pub fn is_timestamp_in_past(&self, parent_timestamp: u64) -> bool
pub fn is_timestamp_in_past(&self, parent_timestamp: u64) -> bool
Checks if the block’s timestamp is in the past compared to the parent block’s timestamp.
Note: This check is relevant only pre-merge.
pub fn exceeds_allowed_future_timestamp(&self, present_timestamp: u64) -> bool
pub 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.
Clock can drift but this can be consensus issue.
Note: This check is relevant only pre-merge.
pub fn parent_num_hash(&self) -> NumHash
pub fn parent_num_hash(&self) -> NumHash
Returns the parent block’s number and hash
pub fn hash_slow(&self) -> FixedBytes<32>
pub fn hash_slow(&self) -> FixedBytes<32>
Heavy function that will calculate hash of data and will not save the change to metadata.
Use Header::seal
, SealedHeader
and unlock if you need hash to be persistent.
pub fn ommers_hash_is_empty(&self) -> bool
pub fn ommers_hash_is_empty(&self) -> bool
Check if the ommers hash equals to empty hash list.
pub fn transaction_root_is_empty(&self) -> bool
pub fn transaction_root_is_empty(&self) -> bool
Check if the transaction root equals to empty root.
pub fn blob_fee(&self) -> Option<u128>
pub fn blob_fee(&self) -> Option<u128>
Returns the blob fee for this block according to the EIP-4844 spec.
Returns None
if excess_blob_gas
is None
pub fn next_block_blob_fee(&self) -> Option<u128>
pub fn next_block_blob_fee(&self) -> Option<u128>
Returns the blob fee for the next block according to the EIP-4844 spec.
Returns None
if excess_blob_gas
is None.
See also Self::next_block_excess_blob_gas
pub fn next_block_base_fee(&self, base_fee_params: BaseFeeParams) -> Option<u64>
pub fn next_block_base_fee(&self, base_fee_params: BaseFeeParams) -> Option<u64>
Calculate base fee for next block according to the EIP-1559 spec.
Returns a None
if no base fee is set, no EIP-1559 support
pub fn next_block_excess_blob_gas(&self) -> Option<u64>
pub fn next_block_excess_blob_gas(&self) -> Option<u64>
Calculate excess blob gas for the next block according to the EIP-4844 spec.
Returns a None
if no excess blob gas is set, no EIP-4844 support
Trait Implementations§
source§impl Clone for SealedBlockWithSenders
impl Clone for SealedBlockWithSenders
source§fn clone(&self) -> SealedBlockWithSenders
fn clone(&self) -> SealedBlockWithSenders
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read moresource§impl Debug for SealedBlockWithSenders
impl Debug for SealedBlockWithSenders
source§impl Default for SealedBlockWithSenders
impl Default for SealedBlockWithSenders
source§fn default() -> SealedBlockWithSenders
fn default() -> SealedBlockWithSenders
source§impl Deref for SealedBlockWithSenders
impl Deref for SealedBlockWithSenders
source§type Target = SealedBlock
type Target = SealedBlock
source§impl DerefMut for SealedBlockWithSenders
impl DerefMut for SealedBlockWithSenders
source§impl<'de> Deserialize<'de> for SealedBlockWithSenders
impl<'de> Deserialize<'de> for SealedBlockWithSenders
source§fn deserialize<__D>(
__deserializer: __D,
) -> Result<SealedBlockWithSenders, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(
__deserializer: __D,
) -> Result<SealedBlockWithSenders, <__D as Deserializer<'de>>::Error>where
__D: Deserializer<'de>,
source§impl PartialEq for SealedBlockWithSenders
impl PartialEq for SealedBlockWithSenders
source§impl Serialize for SealedBlockWithSenders
impl Serialize for SealedBlockWithSenders
source§fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
fn serialize<__S>(
&self,
__serializer: __S,
) -> Result<<__S as Serializer>::Ok, <__S as Serializer>::Error>where
__S: Serializer,
impl Eq for SealedBlockWithSenders
impl StructuralPartialEq for SealedBlockWithSenders
Auto Trait Implementations§
impl !Freeze for SealedBlockWithSenders
impl RefUnwindSafe for SealedBlockWithSenders
impl Send for SealedBlockWithSenders
impl Sync for SealedBlockWithSenders
impl Unpin for SealedBlockWithSenders
impl UnwindSafe for SealedBlockWithSenders
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Conv for T
impl<T> Conv for T
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
source§fn in_current_span(self) -> Instrumented<Self> ⓘ
fn in_current_span(self) -> Instrumented<Self> ⓘ
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
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 moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
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§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.§impl<T> TryConv for T
impl<T> TryConv for T
§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
§fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
source§impl<T> WithSubscriber for T
impl<T> WithSubscriber for T
source§fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self> ⓘwhere
S: Into<Dispatch>,
source§fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
fn with_current_subscriber(self) -> WithDispatch<Self> ⓘ
impl<T> DeserializeOwned for Twhere
T: for<'de> Deserialize<'de>,
impl<T> ErasedDestructor for Twhere
T: 'static,
impl<T> MaybeDebug for Twhere
T: Debug,
impl<T> MaybeSend for Twhere
T: Send,
impl<T> MaybeSendSync for T
impl<T> NippyJarHeader for T
impl<T> RpcObject for Twhere
T: RpcParam + RpcReturn,
impl<T> RpcParam for T
impl<T> RpcReturn for T
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: 872 bytes