Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

chore(rpc): remove use of extensible transaction + receipt types #9774

Merged
merged 114 commits into from
Sep 20, 2024
Merged
Show file tree
Hide file tree
Changes from 14 commits
Commits
Show all changes
114 commits
Select commit Hold shift + click to select a range
64777ff
Add EthApiTypes with error as AT and helper traits for conversion fro…
emhane Jul 17, 2024
2f9b4d4
Make it possible to reference EthApiTypes via EthApiServer helper traits
emhane Jul 18, 2024
494b3d9
Fix rpc API impls
emhane Jul 18, 2024
e05fd6f
Merge branch 'main' into emhane/rpc-error
emhane Jul 18, 2024
916e509
Fix OpEthApi impl
emhane Jul 18, 2024
f1d02a7
Merge branch 'main' into emhane/rpc-error
emhane Jul 24, 2024
09a4192
Merge branch 'main' into emhane/rpc-error
emhane Jul 24, 2024
20fae32
Extend EthApiTypes with alloy_network::Network AT
emhane Jul 24, 2024
ade6b8f
Merge branch 'emhane/rpc-error' into emhane/ethapi-types
emhane Jul 24, 2024
8a631dc
Merge branch 'main' into emhane/ethapi-types
emhane Jul 26, 2024
83bd53b
Import OP rpc types from op-alloy-network
emhane Jul 26, 2024
ad29246
Rename EthApiTypes::Types to EthApiTypes::NetworkTypes
emhane Jul 26, 2024
6bd0f60
Remove optimism feature from reth-rpc-types-compat lib
emhane Jul 26, 2024
e248a65
Incorporate TransactionBuilder into EthTransactions
emhane Jul 26, 2024
624e938
Revert unrelated change
emhane Jul 27, 2024
91ace3a
Fix conflicts from making rpc comapt generic over network for transac…
emhane Jul 27, 2024
c506e8e
Add trait for building rpc block response
emhane Jul 27, 2024
0860e1c
Add adapter for network type builders to EthApi and OpEthApi
emhane Jul 27, 2024
f48038e
Fix conflicts, resp ty has non-unique builder
emhane Jul 29, 2024
91fe6e0
Merge branch 'main' into emhane/ethapi-types
emhane Aug 1, 2024
b052000
Add generics to EthApi trait that are compatible with jsonrpsee
emhane Aug 1, 2024
359eae7
Add temp constraint Network::TransactionResponse = reth_rpc_types::Tr…
emhane Aug 1, 2024
e12d811
Replace EthFilterApi and EthPubSubApi generics with jsonrpsee compati…
emhane Aug 1, 2024
fa58787
Fix lint
emhane Aug 1, 2024
ce48b0f
Merge branch 'main' into emhane/ethapi-types
emhane Aug 2, 2024
4e1d95f
Remove redundant trait bounds
emhane Aug 2, 2024
d859c5e
Flatten trait ResponseTypeBuilders into EthApiTypes
emhane Aug 2, 2024
b733699
Remove duplicate file
emhane Aug 2, 2024
179bd6b
Add noop impl for EthApiTypes
emhane Aug 2, 2024
626c877
Add EthApiTypes trait bounds to node builder
emhane Aug 2, 2024
f24dee5
fixup! Flatten trait ResponseTypeBuilders into EthApiTypes
emhane Aug 2, 2024
34c56e6
Fix tests
emhane Aug 2, 2024
fe0297f
Fix optimism crates
emhane Aug 2, 2024
f7c7206
Set explicit Ethereum network for reth_e2e_test_utils::TransactionTes…
emhane Aug 2, 2024
75ff7da
Fix docs
emhane Aug 2, 2024
de9f909
Merge branch 'main' into emhane/ethapi-types
emhane Aug 3, 2024
43f6808
Remove redundant autotrait impls for EthApi
emhane Aug 3, 2024
57995de
Remove redundant attribute
emhane Aug 3, 2024
b62ec37
Make generic naming unfiorm
emhane Aug 3, 2024
7e11a17
Merge branch 'main' into emhane/ethapi-types
emhane Aug 5, 2024
1cb4f44
Merge branch 'main' into emhane/ethapi-types
emhane Aug 5, 2024
a499898
Merge branch 'main' into emhane/ethapi-types
emhane Aug 8, 2024
7121475
Merge branch 'main' into emhane/ethapi-types
emhane Aug 14, 2024
474367c
Merge branch 'main' into emhane/ethapi-types
emhane Aug 15, 2024
1b8197f
Remove trait bound TransactionBuilder on EthApiTypes::TransationBuilder
emhane Aug 15, 2024
61ce9bf
Merge branch 'main' into emhane/ethapi-types
emhane Aug 20, 2024
a186867
fixup! Remove trait bound TransactionBuilder on EthApiTypes::Transati…
emhane Aug 20, 2024
a784b7a
Fix lint
emhane Aug 20, 2024
856f37e
Rename TransactionBuilder to TransactionCompat
emhane Aug 20, 2024
9d911bb
Rename BlockBuilder to BlockCompat
emhane Aug 21, 2024
2bb8a75
Delay trait bound for EthApiTypes::BlockCompat
emhane Aug 21, 2024
e5b47e8
Merge branch 'main' into emhane/ethapi-types
emhane Aug 21, 2024
b6a2cc9
Remove EthApiTypes::BlockCompat
emhane Aug 21, 2024
9705100
Fix lint
emhane Aug 21, 2024
729716e
Merge branch 'emhane/fix-lint' into emhane/ethapi-types
emhane Aug 21, 2024
a5d95bd
Fix lint
emhane Aug 21, 2024
16cc68e
Fix docs
emhane Aug 21, 2024
a0a2f35
Checkout EthApiTypes::NetworkTypes from emhane/ethapi-types
emhane Aug 21, 2024
e991d9e
Merge branch 'emhane/ethapi-networktypes' into emhane/ethapi-types
emhane Aug 21, 2024
2d6d702
Shrink scope of TransactionCompat trait
emhane Aug 21, 2024
443e9b2
Rename reth_rpc_eth_api::Transaction to RpcTransaction
emhane Aug 22, 2024
fe2bf75
Move crates/rpc/rpc-eth-api/src/helpers/types.rs up one dir
emhane Aug 22, 2024
02b38c7
Update docs
emhane Aug 22, 2024
689c67c
Merge branch 'main' into emhane/ethapi-networktypes
emhane Aug 22, 2024
46bad2e
Fix lint
emhane Aug 22, 2024
d50649e
Merge branch 'emhane/ethapi-networktypes' into emhane/ethapi-types
emhane Aug 22, 2024
64facc7
Merge branch 'main' into emhane/ethapi-types
emhane Aug 22, 2024
5e09011
Revert unrelated change
emhane Aug 22, 2024
148d4e3
Fix lint
emhane Aug 22, 2024
406848d
Merge branch 'main' into emhane/ethapi-types
emhane Aug 24, 2024
145b71d
Merge branch 'main' into emhane/ethapi-types
emhane Sep 6, 2024
07f2e9f
Fix merge conflicts
emhane Sep 6, 2024
cc4dddc
Merge branch 'main' into emhane/ethapi-types
emhane Sep 8, 2024
2dff25a
Fix merge conflicts
emhane Sep 8, 2024
963dab3
Define type reth_optimism_rpc::OpReceiptBuilder
emhane Sep 9, 2024
4ff2ab2
Merge branch 'emhane/op-receipt' into emhane/ethapi-types
emhane Sep 9, 2024
ecddc97
Move EthBlocks::block_receipts default impl to impl for EthApi
emhane Sep 9, 2024
a0b5cfd
Move LoadReceipt::build_transaction_receipt default impl to impl for …
emhane Sep 9, 2024
2d735fa
Merge branch 'emhane/mv-block-receipts' into emhane/ethapi-types
emhane Sep 9, 2024
7d53b1b
Merge branch 'emhane/mv-build-tx-receipt' into emhane/ethapi-types
emhane Sep 9, 2024
b6ad116
Merge branch 'main' into emhane/ethapi-types
emhane Sep 11, 2024
30bd98e
Fix merge conflicts
emhane Sep 11, 2024
00c5adc
Merge branch 'main' into emhane/ethapi-types
emhane Sep 11, 2024
3187093
Merge branch 'main' into emhane/ethapi-types
emhane Sep 11, 2024
79de341
Revert formatting changes
emhane Sep 11, 2024
604df14
Add helper trait FullEthApiTypes linking EthApiTypes::NetworkTypes to…
emhane Sep 11, 2024
68d5c9a
Fix merge conflicts
emhane Sep 11, 2024
3841450
Revert formatting changes
emhane Sep 11, 2024
1756510
Revert formatting changes
emhane Sep 11, 2024
3c1b2cd
Revert bad formatting changes
emhane Sep 11, 2024
472a338
Remove redundant trait bound on RPC transaction response type
emhane Sep 11, 2024
509939f
Bump deps
emhane Sep 13, 2024
fd4d588
Merge branch 'emhane/bump-deps' into emhane/ethapi-types
emhane Sep 13, 2024
dd61e57
Fix lint
emhane Sep 13, 2024
769fb0a
Merge branch 'main' into emhane/ethapi-types
emhane Sep 16, 2024
237a78a
Fix conflicts eth filter API
emhane Sep 16, 2024
461e7a7
Fix conflicts eth pubsub API
emhane Sep 16, 2024
89ba917
Fix conflicts rpc builder
emhane Sep 16, 2024
011b80b
Fix conflicts tx pool API
emhane Sep 16, 2024
87f8f51
Fix conflicts otterscan API
emhane Sep 16, 2024
15112eb
Fix conflicts optimism
emhane Sep 16, 2024
4794fd4
Fix lint
emhane Sep 16, 2024
a430d61
Fix lint
emhane Sep 16, 2024
e51f52a
Remove completed todos
emhane Sep 16, 2024
67d4ba8
Revert unrelated changes
emhane Sep 16, 2024
a3c203b
Merge branch 'main' into emhane/ethapi-types
emhane Sep 18, 2024
d24e7f5
Merge branch 'main' into emhane/ethapi-types
emhane Sep 18, 2024
9ccf619
Update docs
emhane Sep 19, 2024
dc7d4d1
Add lost code comment
emhane Sep 19, 2024
a625312
Add todo
emhane Sep 19, 2024
5555173
Merge branch 'main' into emhane/ethapi-types
emhane Sep 19, 2024
614cb7f
Fix merge conflicts
emhane Sep 19, 2024
2c6bb1d
Fix merge conflicts
emhane Sep 19, 2024
16dc6df
Merge branch 'main' into emhane/ethapi-types
emhane Sep 20, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
21 changes: 21 additions & 0 deletions Cargo.lock

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

1 change: 1 addition & 0 deletions Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -431,6 +431,7 @@ alloy-rpc-client = { version = "0.2", default-features = false }

# op
op-alloy-rpc-types = "0.1"
op-alloy-network = "0.1"

# misc
auto_impl = "1"
Expand Down
1 change: 0 additions & 1 deletion crates/optimism/cli/src/commands/import_receipts.rs
Original file line number Diff line number Diff line change
Expand Up @@ -270,7 +270,6 @@ mod test {
/// No receipts for genesis block
const EMPTY_RECEIPTS_GENESIS_BLOCK: &[u8] = &hex!("c0");

#[ignore]
emhane marked this conversation as resolved.
Show resolved Hide resolved
#[tokio::test]
async fn filter_out_genesis_block_receipts() {
let mut f: File = tempfile().unwrap().into();
Expand Down
2 changes: 1 addition & 1 deletion crates/optimism/primitives/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -9,4 +9,4 @@ repository.workspace = true
description = "OP primitive types"

[lints]
workspace = true
workspace = true
3 changes: 3 additions & 0 deletions crates/optimism/rpc/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,12 @@ reth-tasks = { workspace = true, features = ["rayon"] }
reth-transaction-pool.workspace = true
reth-rpc.workspace = true
reth-node-api.workspace = true
reth-rpc-types-compat.workspace = true

# ethereum
alloy-primitives.workspace = true
alloy-rpc-types.workspace = true
op-alloy-network.workspace = true
revm.workspace = true

# async
Expand Down
27 changes: 27 additions & 0 deletions crates/optimism/rpc/src/eth/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,8 @@ mod pending_block;
use std::{future::Future, sync::Arc};

use alloy_primitives::{Address, U64};
use alloy_rpc_types::optimism::OptimismTransactionFields;
use op_alloy_network::Optimism;
use reth_chainspec::{ChainInfo, ChainSpec};
use reth_errors::RethResult;
use reth_evm::ConfigureEvm;
Expand All @@ -25,6 +27,7 @@ use reth_rpc_eth_api::{
};
use reth_rpc_eth_types::EthStateCache;
use reth_rpc_types::SyncStatus;
use reth_rpc_types_compat::TransactionBuilder;
use reth_tasks::{pool::BlockingTaskPool, TaskSpawner};
use reth_transaction_pool::TransactionPool;
use tokio::sync::{AcquireError, OwnedSemaphorePermit};
Expand Down Expand Up @@ -58,6 +61,30 @@ where
Eth: Send + Sync,
{
type Error = OpEthApiError;
type NetworkTypes = Optimism;
}

impl TransactionBuilder for OpEthApi<Eth> {
type Transaction = <Self::NetworkTypes as Network>::TransactionResponse;

fn fill(
tx: TransactionSignedEcRecovered,
block_hash: Option<B256>,
block_number: Option<BlockNumber>,
base_fee: Option<u64>,
transaction_index: Option<usize>,
) -> Self::Transaction {
let mut resp = Eth::fill(tx, block_hash, block_number, base_fee, transaction_index);

resp.other = OptimismTransactionFields {
source_hash: signed_tx.source_hash(),
mint: signed_tx.mint(),
is_system_tx: signed_tx.is_deposit().then_some(signed_tx.is_system_transaction()),
}
.into();

resp
}
}

impl<Eth: EthApiSpec> EthApiSpec for OpEthApi<Eth> {
Expand Down
1 change: 1 addition & 0 deletions crates/rpc/rpc-eth-api/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,7 @@ reth-rpc-server-types.workspace = true

# ethereum
alloy-dyn-abi = { workspace = true, features = ["eip712"] }
alloy-network.workspace = true

# rpc
jsonrpsee = { workspace = true, features = ["server", "macros"] }
Expand Down
2 changes: 1 addition & 1 deletion crates/rpc/rpc-eth-api/src/core.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ impl<T> FullEthApiServer for T where T: EthApiServer + FullEthApi + UpdateRawTxF
/// Eth rpc interface: <https://ethereum.github.io/execution-apis/api-documentation/>
#[cfg_attr(not(feature = "client"), rpc(server, namespace = "eth"))]
#[cfg_attr(feature = "client", rpc(server, client, namespace = "eth"))]
pub trait EthApi {
pub trait EthApi: EthApiTypes {
/// Returns the protocol version encoded as a string.
#[method(name = "protocolVersion")]
async fn protocol_version(&self) -> RpcResult<U64>;
Expand Down
10 changes: 7 additions & 3 deletions crates/rpc/rpc-eth-api/src/helpers/transaction.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
use std::{fmt, ops::Deref, sync::Arc};

use alloy_dyn_abi::TypedData;
use alloy_network::Network;
use futures::Future;
use reth_primitives::{
Address, BlockId, Bytes, FromRecoveredPooledTransaction, IntoRecoveredTransaction, Receipt,
Expand All @@ -21,7 +22,7 @@ use reth_rpc_types::{
},
AnyTransactionReceipt, Transaction, TransactionRequest, TypedTransactionRequest,
};
use reth_rpc_types_compat::transaction::from_recovered_with_block_context;
use reth_rpc_types_compat::{transaction::from_recovered_with_block_context, TransactionBuilder};
use reth_transaction_pool::{TransactionOrigin, TransactionPool};

use crate::{FromEthApiError, IntoEthApiError};
Expand Down Expand Up @@ -53,7 +54,10 @@ use super::{
/// See also <https://github.com/paradigmxyz/reth/issues/6240>
///
/// This implementation follows the behaviour of Geth and disables the basefee check for tracing.
pub trait EthTransactions: LoadTransaction {
pub trait EthTransactions:
LoadTransaction
+ TransactionBuilder<Transaction = <Self::NetworkTypes as Network>::TransactionResponse>
{
/// Returns a handle for reading data from disk.
///
/// Data access in default (L1) trait method implementations.
Expand Down Expand Up @@ -197,7 +201,7 @@ pub trait EthTransactions: LoadTransaction {
&self,
block_id: BlockId,
index: usize,
) -> impl Future<Output = Result<Option<Transaction>, Self::Error>> + Send
) -> impl Future<Output = Result<Option<Self::Transaction>, Self::Error>> + Send
where
Self: LoadBlock,
{
Expand Down
4 changes: 4 additions & 0 deletions crates/rpc/rpc-eth-api/src/helpers/types.rs
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,8 @@

use std::error::Error;

use alloy_network::Network;

use crate::{AsEthApiError, FromEthApiError, FromEvmError};

/// Network specific `eth` API types.
Expand All @@ -14,4 +16,6 @@ pub trait EthApiTypes: Send + Sync {
+ Error
+ Send
+ Sync;
/// Blockchain data types, specific to network, e.g. block and transaction.
type NetworkTypes: Network;
}
4 changes: 4 additions & 0 deletions crates/rpc/rpc-types-compat/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,8 +15,12 @@ workspace = true
reth-primitives.workspace = true
reth-rpc-types.workspace = true
reth-trie-common.workspace = true

# ethereum
alloy-network.workspace = true
alloy-rlp.workspace = true
alloy-rpc-types.workspace = true
op-alloy-network.workspace = true

[dev-dependencies]
serde_json.workspace = true
Expand Down
2 changes: 2 additions & 0 deletions crates/rpc/rpc-types-compat/src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,5 @@ pub mod block;
pub mod engine;
pub mod proof;
pub mod transaction;

pub use transaction::TransactionBuilder;
Loading
Loading