From e6a6fc4c2e188c71b6dc67e67549cf38d0bb1d46 Mon Sep 17 00:00:00 2001 From: Matthias Seitz Date: Tue, 12 Nov 2024 16:37:21 +0100 Subject: [PATCH] chore: only fetch deposit info for deposit tx (#12474) --- crates/optimism/rpc/src/eth/transaction.rs | 24 ++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/crates/optimism/rpc/src/eth/transaction.rs b/crates/optimism/rpc/src/eth/transaction.rs index 3ff7cb10df10..20aa379a0c1c 100644 --- a/crates/optimism/rpc/src/eth/transaction.rs +++ b/crates/optimism/rpc/src/eth/transaction.rs @@ -85,6 +85,7 @@ where ) -> Result { let from = tx.signer(); let TransactionSigned { transaction, signature, hash } = tx.into_signed(); + let mut deposit_receipt_version = None; let inner = match transaction { reth_primitives::Transaction::Legacy(tx) => { @@ -100,16 +101,23 @@ where reth_primitives::Transaction::Eip7702(tx) => { Signed::new_unchecked(tx, signature, hash).into() } - reth_primitives::Transaction::Deposit(tx) => OpTxEnvelope::Deposit(tx), + reth_primitives::Transaction::Deposit(tx) => { + let deposit_info = self + .inner + .provider() + .receipt_by_hash(hash) + .map_err(Self::Error::from_eth_err)? + .and_then(|receipt| receipt.deposit_receipt_version.zip(receipt.deposit_nonce)); + + if let Some((version, _)) = deposit_info { + deposit_receipt_version = Some(version); + // TODO: set nonce + } + + OpTxEnvelope::Deposit(tx) + } }; - let deposit_receipt_version = self - .inner - .provider() - .receipt_by_hash(hash) - .map_err(Self::Error::from_eth_err)? - .and_then(|receipt| receipt.deposit_receipt_version); - let TransactionInfo { block_hash, block_number, index: transaction_index, base_fee, .. } = tx_info;