pub struct TempoTransactionPool<Client> {
protocol_pool: Pool<TransactionValidationTaskExecutor<TempoTransactionValidator<Client>>, TempoTipOrdering<TempoPooledTransaction>, InMemoryBlobStore>,
aa_2d_pool: Arc<RwLock<AA2dPool>>,
}Expand description
Tempo transaction pool that routes based on nonce_key
Fields§
§protocol_pool: Pool<TransactionValidationTaskExecutor<TempoTransactionValidator<Client>>, TempoTipOrdering<TempoPooledTransaction>, InMemoryBlobStore>Vanilla pool for all standard transactions and AA transactions with regular nonce.
aa_2d_pool: Arc<RwLock<AA2dPool>>Minimal pool for 2D nonces (nonce_key > 0)
Implementations§
Source§impl<Client> TempoTransactionPool<Client>where
Client: StateProviderFactory + ChainSpecProvider<ChainSpec = TempoChainSpec> + 'static,
impl<Client> TempoTransactionPool<Client>where
Client: StateProviderFactory + ChainSpecProvider<ChainSpec = TempoChainSpec> + 'static,
pub fn new( protocol_pool: Pool<TransactionValidationTaskExecutor<TempoTransactionValidator<Client>>, TempoTipOrdering<TempoPooledTransaction>, InMemoryBlobStore>, aa_2d_pool: AA2dPool, ) -> Self
Source§impl<Client> TempoTransactionPool<Client>where
Client: StateProviderFactory + ChainSpecProvider<ChainSpec = TempoChainSpec> + 'static,
impl<Client> TempoTransactionPool<Client>where
Client: StateProviderFactory + ChainSpecProvider<ChainSpec = TempoChainSpec> + 'static,
Sourcepub fn amm_liquidity_cache(&self) -> AmmLiquidityCache
pub fn amm_liquidity_cache(&self) -> AmmLiquidityCache
Obtains a clone of the shared AmmLiquidityCache.
Sourcepub(crate) fn notify_aa_pool_on_state_updates(
&self,
state: &AddressMap<BundleAccount>,
) -> Vec<Arc<ValidPoolTransaction<TempoPooledTransaction>>>
pub(crate) fn notify_aa_pool_on_state_updates( &self, state: &AddressMap<BundleAccount>, ) -> Vec<Arc<ValidPoolTransaction<TempoPooledTransaction>>>
Updates the 2d nonce pool with the given state changes.
Returns mined AA transactions.
Sourcepub fn evict_invalidated_transactions(
&self,
updates: &TempoPoolUpdates,
) -> Vec<Arc<ValidPoolTransaction<TempoPooledTransaction>>>
pub fn evict_invalidated_transactions( &self, updates: &TempoPoolUpdates, ) -> Vec<Arc<ValidPoolTransaction<TempoPooledTransaction>>>
Evicts transactions that are no longer valid due to on-chain events.
This performs a single scan of all pooled transactions and checks for:
- Revoked keychain keys: AA transactions signed with keys that have been revoked
- Spending limit updates: AA transactions signed with keys whose spending limit
changed for a token matching the transaction’s fee token
2b. Spending limit spends: AA transactions whose remaining spending limit (re-read
from state) is now insufficient after included keychain txs decremented it
2c. Key-authorization witness burns: AA transactions with a witness-bearing
inline key authorization whose
(account, witness)has been manually burned - Validator token changes: Transactions that would fail due to insufficient liquidity in the new (user_token, validator_token) AMM pool
- Fee payer balance changes: Transactions whose fee payer no longer has enough balance in the resolved fee token after a TIP20 transfer
All checks are combined into one scan to avoid iterating the pool multiple times per block.
Sourcepub(crate) fn evict_invalidated_transactions_from<'a>(
&self,
updates: &TempoPoolUpdates,
transactions: impl IntoIterator<Item = &'a Arc<ValidPoolTransaction<TempoPooledTransaction>>>,
) -> Vec<Arc<ValidPoolTransaction<TempoPooledTransaction>>>
pub(crate) fn evict_invalidated_transactions_from<'a>( &self, updates: &TempoPoolUpdates, transactions: impl IntoIterator<Item = &'a Arc<ValidPoolTransaction<TempoPooledTransaction>>>, ) -> Vec<Arc<ValidPoolTransaction<TempoPooledTransaction>>>
See Self::evict_invalidated_transactions; returns the removed transactions so
the caller controls when they are dropped.
Sourcefn add_validated_transaction(
&self,
origin: TransactionOrigin,
transaction: TransactionValidationOutcome<TempoPooledTransaction>,
) -> PoolResult<AddedTransactionOutcome>
fn add_validated_transaction( &self, origin: TransactionOrigin, transaction: TransactionValidationOutcome<TempoPooledTransaction>, ) -> PoolResult<AddedTransactionOutcome>
Adds a validated transaction to the subpool derived from its type and nonce key.
TempoPooledTransaction::is_aa_2d routes AA transactions with non-zero
nonce keys, including expiring nonces, to the 2D nonce pool. Everything else
stays in the protocol pool.
Trait Implementations§
Source§impl<Client> Clone for TempoTransactionPool<Client>
impl<Client> Clone for TempoTransactionPool<Client>
Source§impl<Client> Debug for TempoTransactionPool<Client>
impl<Client> Debug for TempoTransactionPool<Client>
Source§impl<Client> TransactionPool for TempoTransactionPool<Client>where
Client: StateProviderFactory + ChainSpecProvider<ChainSpec = TempoChainSpec> + Send + Sync + 'static,
TempoPooledTransaction: EthPoolTransaction,
impl<Client> TransactionPool for TempoTransactionPool<Client>where
Client: StateProviderFactory + ChainSpecProvider<ChainSpec = TempoChainSpec> + Send + Sync + 'static,
TempoPooledTransaction: EthPoolTransaction,
Source§type Transaction = TempoPooledTransaction
type Transaction = TempoPooledTransaction
Source§fn block_info(&self) -> BlockInfo
fn block_info(&self) -> BlockInfo
Source§async fn add_transaction_and_subscribe(
&self,
origin: TransactionOrigin,
transaction: Self::Transaction,
) -> PoolResult<TransactionEvents>
async fn add_transaction_and_subscribe( &self, origin: TransactionOrigin, transaction: Self::Transaction, ) -> PoolResult<TransactionEvents>
Source§async fn add_transaction(
&self,
origin: TransactionOrigin,
transaction: Self::Transaction,
) -> PoolResult<AddedTransactionOutcome>
async fn add_transaction( &self, origin: TransactionOrigin, transaction: Self::Transaction, ) -> PoolResult<AddedTransactionOutcome>
Source§async fn add_transactions(
&self,
origin: TransactionOrigin,
transactions: Vec<Self::Transaction>,
) -> Vec<PoolResult<AddedTransactionOutcome>> ⓘ
async fn add_transactions( &self, origin: TransactionOrigin, transactions: Vec<Self::Transaction>, ) -> Vec<PoolResult<AddedTransactionOutcome>> ⓘ
Source§async fn add_transactions_with_origins(
&self,
transactions: Vec<(TransactionOrigin, Self::Transaction)>,
) -> Vec<PoolResult<AddedTransactionOutcome>> ⓘ
async fn add_transactions_with_origins( &self, transactions: Vec<(TransactionOrigin, Self::Transaction)>, ) -> Vec<PoolResult<AddedTransactionOutcome>> ⓘ
Source§fn transaction_event_listener(&self, tx_hash: B256) -> Option<TransactionEvents>
fn transaction_event_listener(&self, tx_hash: B256) -> Option<TransactionEvents>
Source§fn all_transactions_event_listener(
&self,
) -> AllTransactionsEvents<Self::Transaction>
fn all_transactions_event_listener( &self, ) -> AllTransactionsEvents<Self::Transaction>
Source§fn pending_transactions_listener_for(
&self,
kind: TransactionListenerKind,
) -> Receiver<B256>
fn pending_transactions_listener_for( &self, kind: TransactionListenerKind, ) -> Receiver<B256>
TransactionListenerKind] argument.Source§fn blob_transaction_sidecars_listener(&self) -> Receiver<NewBlobSidecar>
fn blob_transaction_sidecars_listener(&self) -> Receiver<NewBlobSidecar>
Source§fn new_transactions_listener_for(
&self,
kind: TransactionListenerKind,
) -> Receiver<NewTransactionEvent<Self::Transaction>>
fn new_transactions_listener_for( &self, kind: TransactionListenerKind, ) -> Receiver<NewTransactionEvent<Self::Transaction>>
TransactionListenerKind] argument.Source§fn pooled_transaction_hashes(&self) -> Vec<B256> ⓘ
fn pooled_transaction_hashes(&self) -> Vec<B256> ⓘ
Source§fn pooled_transaction_hashes_max(&self, max: usize) -> Vec<B256> ⓘ
fn pooled_transaction_hashes_max(&self, max: usize) -> Vec<B256> ⓘ
max hashes of transactions in the pool. Read moreSource§fn pooled_transactions(
&self,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn pooled_transactions( &self, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn pooled_transactions_max(
&self,
max: usize,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn pooled_transactions_max( &self, max: usize, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
max transactions in the pool. Read moreSource§fn get_pooled_transaction_elements(
&self,
tx_hashes: Vec<B256>,
limit: GetPooledTransactionLimit,
) -> Vec<<Self::Transaction as PoolTransaction>::Pooled>
fn get_pooled_transaction_elements( &self, tx_hashes: Vec<B256>, limit: GetPooledTransactionLimit, ) -> Vec<<Self::Transaction as PoolTransaction>::Pooled>
PooledTransactionVariant] for the given transaction hashes that are
allowed to be propagated. Read moreSource§fn append_pooled_transaction_elements(
&self,
tx_hashes: &[B256],
limit: GetPooledTransactionLimit,
out: &mut Vec<<Self::Transaction as PoolTransaction>::Pooled>,
)
fn append_pooled_transaction_elements( &self, tx_hashes: &[B256], limit: GetPooledTransactionLimit, out: &mut Vec<<Self::Transaction as PoolTransaction>::Pooled>, )
Source§fn get_pooled_transaction_element(
&self,
tx_hash: B256,
) -> Option<Recovered<<Self::Transaction as PoolTransaction>::Pooled>>
fn get_pooled_transaction_element( &self, tx_hash: B256, ) -> Option<Recovered<<Self::Transaction as PoolTransaction>::Pooled>>
Source§fn best_transactions(
&self,
) -> Box<dyn BestTransactions<Item = Arc<ValidPoolTransaction<Self::Transaction>>>>
fn best_transactions( &self, ) -> Box<dyn BestTransactions<Item = Arc<ValidPoolTransaction<Self::Transaction>>>>
Source§fn best_transactions_with_attributes(
&self,
attributes: BestTransactionsAttributes,
) -> Box<dyn BestTransactions<Item = Arc<ValidPoolTransaction<Self::Transaction>>>>
fn best_transactions_with_attributes( &self, attributes: BestTransactionsAttributes, ) -> Box<dyn BestTransactions<Item = Arc<ValidPoolTransaction<Self::Transaction>>>>
Source§fn pending_transactions(
&self,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn pending_transactions( &self, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn pending_transactions_max(
&self,
max: usize,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn pending_transactions_max( &self, max: usize, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
max transactions that can be included in the next block.
See https://github.com/paradigmxyz/reth/issues/12767#issuecomment-2493223579 Read moreSource§fn queued_transactions(
&self,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn queued_transactions( &self, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn pending_and_queued_txn_count(&self) -> (usize, usize)
fn pending_and_queued_txn_count(&self) -> (usize, usize)
(pending, queued).Source§fn all_transactions(&self) -> AllPoolTransactions<Self::Transaction>
fn all_transactions(&self) -> AllPoolTransactions<Self::Transaction>
Source§fn all_transaction_hashes(&self) -> Vec<B256> ⓘ
fn all_transaction_hashes(&self) -> Vec<B256> ⓘ
Source§fn remove_transactions(
&self,
hashes: Vec<B256>,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn remove_transactions( &self, hashes: Vec<B256>, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn remove_transactions_and_descendants(
&self,
hashes: Vec<B256>,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn remove_transactions_and_descendants( &self, hashes: Vec<B256>, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn remove_transactions_by_sender(
&self,
sender: Address,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn remove_transactions_by_sender( &self, sender: Address, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn prune_transactions(
&self,
hashes: Vec<TxHash>,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn prune_transactions( &self, hashes: Vec<TxHash>, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn retain_unknown<A: HandleMempoolData>(&self, announcement: &mut A)
fn retain_unknown<A: HandleMempoolData>(&self, announcement: &mut A)
Source§fn retain_contains<A>(&self, announcement: &mut A)where
A: HandleMempoolData,
fn retain_contains<A>(&self, announcement: &mut A)where
A: HandleMempoolData,
Source§fn contains(&self, tx_hash: &B256) -> bool
fn contains(&self, tx_hash: &B256) -> bool
Source§fn get(
&self,
tx_hash: &B256,
) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get( &self, tx_hash: &B256, ) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn get_all(
&self,
txs: Vec<B256>,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_all( &self, txs: Vec<B256>, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn on_propagated(&self, txs: PropagatedTransactions)
fn on_propagated(&self, txs: PropagatedTransactions)
Source§fn get_transactions_by_sender(
&self,
sender: Address,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_transactions_by_sender( &self, sender: Address, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn get_pending_transactions_with_predicate(
&self,
predicate: impl FnMut(&ValidPoolTransaction<Self::Transaction>) -> bool,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_pending_transactions_with_predicate( &self, predicate: impl FnMut(&ValidPoolTransaction<Self::Transaction>) -> bool, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn get_pending_transactions_by_sender(
&self,
sender: Address,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_pending_transactions_by_sender( &self, sender: Address, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn get_queued_transactions_by_sender(
&self,
sender: Address,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_queued_transactions_by_sender( &self, sender: Address, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn get_highest_transaction_by_sender(
&self,
sender: Address,
) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_highest_transaction_by_sender( &self, sender: Address, ) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn get_highest_consecutive_transaction_by_sender(
&self,
sender: Address,
on_chain_nonce: u64,
) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_highest_consecutive_transaction_by_sender( &self, sender: Address, on_chain_nonce: u64, ) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn get_transaction_by_sender_and_nonce(
&self,
sender: Address,
nonce: u64,
) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_transaction_by_sender_and_nonce( &self, sender: Address, nonce: u64, ) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
Source§fn get_transactions_by_origin(
&self,
origin: TransactionOrigin,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_transactions_by_origin( &self, origin: TransactionOrigin, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
TransactionOrigin]Source§fn get_pending_transactions_by_origin(
&self,
origin: TransactionOrigin,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_pending_transactions_by_origin( &self, origin: TransactionOrigin, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
TransactionOrigin]Source§fn unique_senders(&self) -> AddressSet
fn unique_senders(&self) -> AddressSet
Source§fn get_blob(
&self,
tx_hash: B256,
) -> Result<Option<Arc<BlobTransactionSidecarVariant>>, BlobStoreError>
fn get_blob( &self, tx_hash: B256, ) -> Result<Option<Arc<BlobTransactionSidecarVariant>>, BlobStoreError>
BlobTransactionSidecarVariant] for the given transaction hash if it exists in
the blob store.Source§fn get_all_blobs(
&self,
tx_hashes: Vec<B256>,
) -> Result<Vec<(B256, Arc<BlobTransactionSidecarVariant>)>, BlobStoreError>
fn get_all_blobs( &self, tx_hashes: Vec<B256>, ) -> Result<Vec<(B256, Arc<BlobTransactionSidecarVariant>)>, BlobStoreError>
BlobTransactionSidecarVariant] for the given transaction hashes if they
exists in the blob store. Read moreSource§fn get_all_blobs_exact(
&self,
tx_hashes: Vec<B256>,
) -> Result<Vec<Arc<BlobTransactionSidecarVariant>>, BlobStoreError>
fn get_all_blobs_exact( &self, tx_hashes: Vec<B256>, ) -> Result<Vec<Arc<BlobTransactionSidecarVariant>>, BlobStoreError>
BlobTransactionSidecarVariant] for the given transaction hashes in the
order they were requested. Read moreSource§fn get_blobs_for_versioned_hashes_v1(
&self,
versioned_hashes: &[B256],
) -> Result<Vec<Option<BlobAndProofV1>>, BlobStoreError>
fn get_blobs_for_versioned_hashes_v1( &self, versioned_hashes: &[B256], ) -> Result<Vec<Option<BlobAndProofV1>>, BlobStoreError>
BlobAndProofV1]s for a list of blob versioned hashes.Source§fn get_blobs_for_versioned_hashes_v2(
&self,
versioned_hashes: &[B256],
) -> Result<Option<Vec<BlobAndProofV2>>, BlobStoreError>
fn get_blobs_for_versioned_hashes_v2( &self, versioned_hashes: &[B256], ) -> Result<Option<Vec<BlobAndProofV2>>, BlobStoreError>
BlobAndProofV2]s for a list of blob versioned hashes.
Blobs and proofs are returned only if they are present for all of the requested versioned
hashes.Source§fn get_blobs_for_versioned_hashes_v3(
&self,
versioned_hashes: &[B256],
) -> Result<Vec<Option<BlobAndProofV2>>, BlobStoreError>
fn get_blobs_for_versioned_hashes_v3( &self, versioned_hashes: &[B256], ) -> Result<Vec<Option<BlobAndProofV2>>, BlobStoreError>
BlobAndProofV2]s for a list of blob versioned hashes. Read moreSource§fn get_blobs_for_versioned_hashes_v4(
&self,
versioned_hashes: &[B256],
indices_bitarray: B128,
) -> Result<Vec<Option<BlobCellsAndProofsV1>>, BlobStoreError>
fn get_blobs_for_versioned_hashes_v4( &self, versioned_hashes: &[B256], indices_bitarray: B128, ) -> Result<Vec<Option<BlobCellsAndProofsV1>>, BlobStoreError>
BlobCellsAndProofsV1]s for a list of blob versioned hashes and requested cell
indices. Read moreSource§fn blob_store(&self) -> Box<dyn BlobStore>
fn blob_store(&self) -> Box<dyn BlobStore>
§fn add_external_transaction(
&self,
transaction: Self::Transaction,
) -> impl Future<Output = Result<AddedTransactionOutcome, PoolError>> + Send
fn add_external_transaction( &self, transaction: Self::Transaction, ) -> impl Future<Output = Result<AddedTransactionOutcome, PoolError>> + Send
§fn add_external_transactions(
&self,
transactions: Vec<Self::Transaction>,
) -> impl Future<Output = Vec<Result<AddedTransactionOutcome, PoolError>>> + Send
fn add_external_transactions( &self, transactions: Vec<Self::Transaction>, ) -> impl Future<Output = Vec<Result<AddedTransactionOutcome, PoolError>>> + Send
§fn add_consensus_transaction(
&self,
tx: Recovered<<Self::Transaction as PoolTransaction>::Consensus>,
origin: TransactionOrigin,
) -> impl Future<Output = Result<AddedTransactionOutcome, PoolError>> + Send
fn add_consensus_transaction( &self, tx: Recovered<<Self::Transaction as PoolTransaction>::Consensus>, origin: TransactionOrigin, ) -> impl Future<Output = Result<AddedTransactionOutcome, PoolError>> + Send
§fn add_consensus_transaction_and_subscribe(
&self,
tx: Recovered<<Self::Transaction as PoolTransaction>::Consensus>,
origin: TransactionOrigin,
) -> impl Future<Output = Result<TransactionEvents, PoolError>> + Send
fn add_consensus_transaction_and_subscribe( &self, tx: Recovered<<Self::Transaction as PoolTransaction>::Consensus>, origin: TransactionOrigin, ) -> impl Future<Output = Result<TransactionEvents, PoolError>> + Send
§fn pending_transactions_listener(&self) -> Receiver<FixedBytes<32>>
fn pending_transactions_listener(&self) -> Receiver<FixedBytes<32>>
§fn new_transactions_listener(
&self,
) -> Receiver<NewTransactionEvent<Self::Transaction>>
fn new_transactions_listener( &self, ) -> Receiver<NewTransactionEvent<Self::Transaction>>
§fn new_pending_pool_transactions_listener(
&self,
) -> NewSubpoolTransactionStream<Self::Transaction>
fn new_pending_pool_transactions_listener( &self, ) -> NewSubpoolTransactionStream<Self::Transaction>
§fn new_basefee_pool_transactions_listener(
&self,
) -> NewSubpoolTransactionStream<Self::Transaction>
fn new_basefee_pool_transactions_listener( &self, ) -> NewSubpoolTransactionStream<Self::Transaction>
§fn new_queued_transactions_listener(
&self,
) -> NewSubpoolTransactionStream<Self::Transaction>
fn new_queued_transactions_listener( &self, ) -> NewSubpoolTransactionStream<Self::Transaction>
§fn new_blob_pool_transactions_listener(
&self,
) -> NewSubpoolTransactionStream<Self::Transaction>
fn new_blob_pool_transactions_listener( &self, ) -> NewSubpoolTransactionStream<Self::Transaction>
§fn get_pending_transaction_by_sender_and_nonce(
&self,
sender: Address,
nonce: u64,
) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_pending_transaction_by_sender_and_nonce( &self, sender: Address, nonce: u64, ) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
§fn remove_transaction(
&self,
hash: FixedBytes<32>,
) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
fn remove_transaction( &self, hash: FixedBytes<32>, ) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
§fn prune_transaction(
&self,
hash: FixedBytes<32>,
) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
fn prune_transaction( &self, hash: FixedBytes<32>, ) -> Option<Arc<ValidPoolTransaction<Self::Transaction>>>
§fn get_local_transactions(
&self,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_local_transactions( &self, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
TransactionOrigin::Local]§fn get_private_transactions(
&self,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_private_transactions( &self, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
TransactionOrigin::Private]§fn get_external_transactions(
&self,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_external_transactions( &self, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
TransactionOrigin::External]§fn get_local_pending_transactions(
&self,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_local_pending_transactions( &self, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
TransactionOrigin::Local]§fn get_private_pending_transactions(
&self,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_private_pending_transactions( &self, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
TransactionOrigin::Private]§fn get_external_pending_transactions(
&self,
) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
fn get_external_pending_transactions( &self, ) -> Vec<Arc<ValidPoolTransaction<Self::Transaction>>>
TransactionOrigin::External]Source§impl<Client> TransactionPoolExt for TempoTransactionPool<Client>where
Client: StateProviderFactory + ChainSpecProvider<ChainSpec = TempoChainSpec> + 'static,
impl<Client> TransactionPoolExt for TempoTransactionPool<Client>where
Client: StateProviderFactory + ChainSpecProvider<ChainSpec = TempoChainSpec> + 'static,
Source§type Block = Block<TempoTxEnvelope, TempoHeader>
type Block = Block<TempoTxEnvelope, TempoHeader>
Source§fn set_block_info(&self, info: BlockInfo)
fn set_block_info(&self, info: BlockInfo)
Source§fn on_canonical_state_change(
&self,
update: CanonicalStateUpdate<'_, Self::Block>,
)
fn on_canonical_state_change( &self, update: CanonicalStateUpdate<'_, Self::Block>, )
Source§fn update_accounts(&self, accounts: Vec<ChangedAccount>)
fn update_accounts(&self, accounts: Vec<ChangedAccount>)
Source§fn delete_blob(&self, tx: B256)
fn delete_blob(&self, tx: B256)
Source§fn delete_blobs(&self, txs: Vec<B256>)
fn delete_blobs(&self, txs: Vec<B256>)
Source§fn cleanup_blobs(&self)
fn cleanup_blobs(&self)
Auto Trait Implementations§
impl<Client> !RefUnwindSafe for TempoTransactionPool<Client>
impl<Client> !UnwindSafe for TempoTransactionPool<Client>
impl<Client> Freeze for TempoTransactionPool<Client>
impl<Client> Send for TempoTransactionPool<Client>
impl<Client> Sync for TempoTransactionPool<Client>
impl<Client> Unpin for TempoTransactionPool<Client>
impl<Client> UnsafeUnpin for TempoTransactionPool<Client>
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
impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
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<T> ErasedDestructor for Twhere
T: 'static,
§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<TxEnv, T> FromRecoveredTx<&T> for TxEnvwhere
TxEnv: FromRecoveredTx<T>,
impl<TxEnv, T> FromRecoveredTx<&T> for TxEnvwhere
TxEnv: FromRecoveredTx<T>,
§fn from_recovered_tx(tx: &&T, sender: Address) -> TxEnv
fn from_recovered_tx(tx: &&T, sender: Address) -> TxEnv
TxEnv] from a transaction and a sender address.§impl<TxEnv, T> FromTxWithEncoded<&T> for TxEnvwhere
TxEnv: FromTxWithEncoded<T>,
impl<TxEnv, T> FromTxWithEncoded<&T> for TxEnvwhere
TxEnv: FromTxWithEncoded<T>,
§fn from_encoded_tx(tx: &&T, sender: Address, encoded: Bytes) -> TxEnv
fn from_encoded_tx(tx: &&T, sender: Address, encoded: Bytes) -> TxEnv
TxEnv] from a transaction, its sender, and encoded transaction bytes.§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> FutureExt for T
impl<T> FutureExt for T
§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> 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>
§impl<B> IntoBlock<B> for B
impl<B> IntoBlock<B> for B
§fn into_block(self) -> B
fn into_block(self) -> B
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> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Layered].impl<T> MaybeDebug for Twhere
T: Debug,
impl<T> MaybeSend for Twhere
T: Send,
§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> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> Read<Exclusive, BecauseExclusive> for Twhere
T: ?Sized,
§impl<T> ServiceExt for T
impl<T> ServiceExt for T
§fn propagate_header(self, header: HeaderName) -> PropagateHeader<Self>where
Self: Sized,
fn propagate_header(self, header: HeaderName) -> PropagateHeader<Self>where
Self: Sized,
propagate-header only.§fn add_extension<T>(self, value: T) -> AddExtension<Self, T>where
Self: Sized,
fn add_extension<T>(self, value: T) -> AddExtension<Self, T>where
Self: Sized,
add-extension only.§fn map_request_body<F>(self, f: F) -> MapRequestBody<Self, F>where
Self: Sized,
fn map_request_body<F>(self, f: F) -> MapRequestBody<Self, F>where
Self: Sized,
map-request-body only.§fn map_response_body<F>(self, f: F) -> MapResponseBody<Self, F>where
Self: Sized,
fn map_response_body<F>(self, f: F) -> MapResponseBody<Self, F>where
Self: Sized,
map-response-body only.§fn compression(self) -> Compression<Self>where
Self: Sized,
fn compression(self) -> Compression<Self>where
Self: Sized,
compression-br or compression-deflate or compression-gzip or compression-zstd only.§fn decompression(self) -> Decompression<Self>where
Self: Sized,
fn decompression(self) -> Decompression<Self>where
Self: Sized,
decompression-br or decompression-deflate or decompression-gzip or decompression-zstd only.§fn trace_for_http(self) -> Trace<Self, SharedClassifier<ServerErrorsAsFailures>>where
Self: Sized,
fn trace_for_http(self) -> Trace<Self, SharedClassifier<ServerErrorsAsFailures>>where
Self: Sized,
trace only.§fn trace_for_grpc(self) -> Trace<Self, SharedClassifier<GrpcErrorsAsFailures>>where
Self: Sized,
fn trace_for_grpc(self) -> Trace<Self, SharedClassifier<GrpcErrorsAsFailures>>where
Self: Sized,
trace only.§fn follow_redirects(self) -> FollowRedirect<Self>where
Self: Sized,
fn follow_redirects(self) -> FollowRedirect<Self>where
Self: Sized,
follow-redirect only.§fn sensitive_headers(
self,
headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<SetSensitiveResponseHeaders<Self>>where
Self: Sized,
fn sensitive_headers(
self,
headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<SetSensitiveResponseHeaders<Self>>where
Self: Sized,
sensitive-headers only.§fn sensitive_request_headers(
self,
headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<Self>where
Self: Sized,
fn sensitive_request_headers(
self,
headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveRequestHeaders<Self>where
Self: Sized,
sensitive-headers only.§fn sensitive_response_headers(
self,
headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveResponseHeaders<Self>where
Self: Sized,
fn sensitive_response_headers(
self,
headers: impl IntoIterator<Item = HeaderName>,
) -> SetSensitiveResponseHeaders<Self>where
Self: Sized,
sensitive-headers only.§fn override_request_header<M>(
self,
header_name: HeaderName,
make: M,
) -> SetRequestHeader<Self, M>where
Self: Sized,
fn override_request_header<M>(
self,
header_name: HeaderName,
make: M,
) -> SetRequestHeader<Self, M>where
Self: Sized,
set-header only.§fn append_request_header<M>(
self,
header_name: HeaderName,
make: M,
) -> SetRequestHeader<Self, M>where
Self: Sized,
fn append_request_header<M>(
self,
header_name: HeaderName,
make: M,
) -> SetRequestHeader<Self, M>where
Self: Sized,
set-header only.§fn insert_request_header_if_not_present<M>(
self,
header_name: HeaderName,
make: M,
) -> SetRequestHeader<Self, M>where
Self: Sized,
fn insert_request_header_if_not_present<M>(
self,
header_name: HeaderName,
make: M,
) -> SetRequestHeader<Self, M>where
Self: Sized,
set-header only.§fn override_response_header<M>(
self,
header_name: HeaderName,
make: M,
) -> SetResponseHeader<Self, M>where
Self: Sized,
fn override_response_header<M>(
self,
header_name: HeaderName,
make: M,
) -> SetResponseHeader<Self, M>where
Self: Sized,
set-header only.§fn append_response_header<M>(
self,
header_name: HeaderName,
make: M,
) -> SetResponseHeader<Self, M>where
Self: Sized,
fn append_response_header<M>(
self,
header_name: HeaderName,
make: M,
) -> SetResponseHeader<Self, M>where
Self: Sized,
set-header only.§fn insert_response_header_if_not_present<M>(
self,
header_name: HeaderName,
make: M,
) -> SetResponseHeader<Self, M>where
Self: Sized,
fn insert_response_header_if_not_present<M>(
self,
header_name: HeaderName,
make: M,
) -> SetResponseHeader<Self, M>where
Self: Sized,
set-header only.§fn set_request_id<M>(
self,
header_name: HeaderName,
make_request_id: M,
) -> SetRequestId<Self, M>where
Self: Sized,
M: MakeRequestId,
fn set_request_id<M>(
self,
header_name: HeaderName,
make_request_id: M,
) -> SetRequestId<Self, M>where
Self: Sized,
M: MakeRequestId,
request-id only.§fn set_x_request_id<M>(self, make_request_id: M) -> SetRequestId<Self, M>where
Self: Sized,
M: MakeRequestId,
fn set_x_request_id<M>(self, make_request_id: M) -> SetRequestId<Self, M>where
Self: Sized,
M: MakeRequestId,
request-id only.x-request-id as the header name. Read more§fn propagate_request_id(
self,
header_name: HeaderName,
) -> PropagateRequestId<Self>where
Self: Sized,
fn propagate_request_id(
self,
header_name: HeaderName,
) -> PropagateRequestId<Self>where
Self: Sized,
request-id only.§fn propagate_x_request_id(self) -> PropagateRequestId<Self>where
Self: Sized,
fn propagate_x_request_id(self) -> PropagateRequestId<Self>where
Self: Sized,
request-id only.x-request-id as the header name. Read more§fn catch_panic(self) -> CatchPanic<Self, DefaultResponseForPanic>where
Self: Sized,
fn catch_panic(self) -> CatchPanic<Self, DefaultResponseForPanic>where
Self: Sized,
catch-panic only.500 Internal Server responses. Read more§fn request_body_limit(self, limit: usize) -> RequestBodyLimit<Self>where
Self: Sized,
fn request_body_limit(self, limit: usize) -> RequestBodyLimit<Self>where
Self: Sized,
limit only.413 Payload Too Large responses. Read more§fn trim_trailing_slash(self) -> NormalizePath<Self>where
Self: Sized,
fn trim_trailing_slash(self) -> NormalizePath<Self>where
Self: Sized,
normalize-path only.§fn append_trailing_slash(self) -> NormalizePath<Self>where
Self: Sized,
fn append_trailing_slash(self) -> NormalizePath<Self>where
Self: Sized,
normalize-path only.§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>
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: 16 bytes