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

Release v943060 #980

Closed
wants to merge 113 commits into from
Closed
Changes from 1 commit
Commits
Show all changes
113 commits
Select commit Hold shift + click to select a range
9f5355d
ci: forbid eslint warnings
CertainLach Feb 17, 2023
4bcabac
ci: run clippy
CertainLach Feb 17, 2023
e1f20e1
fix: set prop for not existed token (#933)
bugrazoid Jun 14, 2023
71175e3
feat: update MarketV2 contract
Jun 16, 2023
c575769
migration(app-promo): added number(s) of unhandled blocks
PraetorP Jun 15, 2023
6f79f09
ci collator-selection for dockerhub
BuddyGlas Jun 23, 2023
65414d6
feat(app-promo): types for `Currency` trait support has been removed …
PraetorP Jun 23, 2023
e041df2
Test for market sponsoring
uandysmith Jun 26, 2023
8196877
fix: add `from` to `confirmSponsorship`
Jun 26, 2023
f661a22
test: tests for sending `value` with `evm.call`
Jun 27, 2023
a7c577e
Update market + substrate sponsoring example
uandysmith Jun 27, 2023
54a7967
Remove console.log
uandysmith Jun 27, 2023
9c3f000
fix: return TokenData with owner for old runtimes (#957)
fairax Jun 28, 2023
ef738f7
Merge pull request #958 from UniqueNetwork/ci/collator-selection
CertainLach Jun 28, 2023
1913bf6
Merge pull request #954 from UniqueNetwork/feature/update_market_v2_c…
CertainLach Jun 29, 2023
07a896e
fix: update unique-frontier dependency
Jun 30, 2023
1ecd8fc
Merge pull request #961 from UniqueNetwork/test/send_value_to_contrac…
CertainLach Jun 30, 2023
d8a735e
refactor!: decouple pallet-collator-selection from pallet-configurati…
PraetorP Jun 30, 2023
83d67e5
fix: Rust Analyzer for common mod (#966)
Jul 10, 2023
83605d4
fix: sponsoring tests
Jul 11, 2023
28d97ca
test: add bench for nesting (#963)
PraetorP Jul 11, 2023
724706b
ci: wait for try-runtime logs (#960)
BuddyGlas Jul 11, 2023
8d1c3c9
build: update polkadot to v0.9.43
CertainLach Jul 16, 2023
4de16ed
build: bump spec_version
CertainLach Jul 17, 2023
4d3b620
ci: fix launch-config
CertainLach Jul 17, 2023
55ce0a6
refactor: drop TransactionConverter support
CertainLach Jun 16, 2023
f28d992
feat: update BaseFee storage from pallet-configuration
CertainLach Jun 16, 2023
ec57cb9
refactor: ethereum RPC/tasks initialization
CertainLach Jun 16, 2023
a73db73
style: fix formatting
CertainLach Jul 17, 2023
1b4b057
ci: remove deprecated arguments
CertainLach Jul 20, 2023
ebfc6b1
ci: remove ws-port leftovers
CertainLach Jul 21, 2023
8d3362a
ci: regenerate .env
CertainLach Jul 21, 2023
471fdb4
build: update dependencies
CertainLach Jul 21, 2023
fc1ccc4
Merge pull request #968 from UniqueNetwork/feature/update-polkadot-v0…
CertainLach Aug 14, 2023
e7df43a
ci: node only update changes (#956)
BuddyGlas Aug 14, 2023
950d276
Merge pull request #888 from UniqueNetwork/ci/forbid-warnings
CertainLach Aug 15, 2023
20ac01d
feat: eth all-in-one create_collection (#971)
fairax Aug 16, 2023
1a4aa2d
feat: introduce democracy (#965)
PraetorP Aug 23, 2023
905f9b3
refactor: fix complex value type support in evm-coder
CertainLach Aug 29, 2023
0ce92f0
fix: tests cleanup
uandysmith Aug 29, 2023
e12df81
test(evm): using value with Option::None is not allowed
CertainLach Aug 30, 2023
dff02f7
fix: restore unrecognized selector error message
CertainLach Aug 30, 2023
e24c985
style: fix formatting
CertainLach Aug 30, 2023
66f7f7d
fix: createCollection flags test
uandysmith Aug 30, 2023
c466f2a
test: fix build and style
CertainLach Aug 30, 2023
369a51d
Merge pull request #974 from UniqueNetwork/fix/evm-coder-leftovers
CertainLach Aug 30, 2023
fc2ce00
ci: specify endpoints for xcm containers
CertainLach Aug 23, 2023
7fac866
ci: update .env
CertainLach Aug 23, 2023
6586b5a
ci: remove old xcm workflow
CertainLach Aug 25, 2023
37e846d
test: upgrade to yarn berry
CertainLach Aug 25, 2023
b8ffe22
ci: update env generator
CertainLach Aug 25, 2023
86762e7
ci: use baedeker for xcm workflow
CertainLach Aug 25, 2023
c1adeef
test: regenerate types
CertainLach Aug 27, 2023
12f3485
ci: use compose discovery
CertainLach Aug 30, 2023
d83685b
test: fix unique imports and eslint
uandysmith Aug 31, 2023
ca74825
ci: statemints wants para-ed keys
CertainLach Aug 31, 2023
0722057
test: make testing more resilent to random failures
CertainLach Aug 31, 2023
9acbee5
ci: do not regenerate types on every run
CertainLach Sep 1, 2023
21a0683
test: rewrite metadata fetch to js
CertainLach Sep 1, 2023
24a0f65
ci: add polkadex to xcm workflow
BuddyGlas Aug 31, 2023
3cd8b28
ci(xcm): run for all networks
CertainLach Sep 1, 2023
693c003
test: restore gov tests
CertainLach Sep 1, 2023
a17eff7
Merge pull request #972 from UniqueNetwork/ci/baedeker
CertainLach Sep 1, 2023
42448e1
fix: governance setup inconsistencies
mrshiposha Sep 1, 2023
3e9a8d1
Merge pull request #976 from UniqueNetwork/fix/governance-setup-incon…
CertainLach Sep 2, 2023
edf428e
test(gov): added neg votes
PraetorP Sep 4, 2023
c6d53cc
Merge pull request #977 from UniqueNetwork/fix/gov-council-test
CertainLach Sep 4, 2023
a797a1d
feat: add opal gov timings
mrshiposha Sep 4, 2023
0e75cd9
Merge pull request #978 from UniqueNetwork/fix/opal-governance-timings
CertainLach Sep 4, 2023
5b9d45c
enable governance workflow for develop and master branch
BuddyGlas Sep 5, 2023
98753ec
Merge pull request #981 from UniqueNetwork/ci/governance-workflow
CertainLach Sep 5, 2023
56c4087
ci: relay_chain argument for baedeker
CertainLach Sep 3, 2023
1a650ec
ci: move nodeonly to baedeker
CertainLach Sep 3, 2023
ec8104e
Merge pull request #983 from UniqueNetwork/ci/baedeker-node-only
CertainLach Sep 5, 2023
3050b51
test: add event asserts (#982)
Maksandre Sep 6, 2023
bf4df5f
fix: xcm tests
mrshiposha Sep 6, 2023
a4cc0ef
feat: baedeker helper scripts
CertainLach Sep 6, 2023
3567b2a
ci: set repoDir tla-str by default
CertainLach Sep 6, 2023
432eea3
ci: move collator selection to baedeker (#979)
BuddyGlas Sep 6, 2023
33d4989
Merge pull request #985 from UniqueNetwork/fix/xcm-release-60
CertainLach Sep 6, 2023
d3757b6
Merge pull request #984 from UniqueNetwork/dev/baedeker
CertainLach Sep 6, 2023
320ac9b
ci: update nodejs version to 18 (#987)
BuddyGlas Sep 7, 2023
911b03c
fix: wasm runtime version section
CertainLach Sep 8, 2023
8483c29
test: runtime upgrade helpers
CertainLach Sep 8, 2023
129199c
ci: ability to disable disable default actions
CertainLach Sep 8, 2023
5a3f942
ci: move forkless-nodata to baedeker
CertainLach Sep 8, 2023
f266535
ci: move forkless-data to baedeker
CertainLach Sep 8, 2023
dfae293
ci: fix bdk dev paths
CertainLach Sep 8, 2023
d892f52
ci: fix codestyle failures
CertainLach Sep 8, 2023
f4daa42
fix: collator-selection tests
mrshiposha Sep 8, 2023
13175ce
ci: forkless misc fixes
CertainLach Sep 8, 2023
a1bfaca
style: fix clippy warning
CertainLach Sep 8, 2023
cb2cc11
fix: workflow cargo build
mrshiposha Sep 8, 2023
1d7b145
ci: missing wasm_name for opal
CertainLach Sep 8, 2023
0e9500c
fix: simplify test timings features
mrshiposha Sep 8, 2023
0caf783
fix: use plain node names instead of test account names
mrshiposha Sep 8, 2023
d6fc80a
fix: workflow baedeker args
mrshiposha Sep 8, 2023
70415c3
fix: session-test-timingS
mrshiposha Sep 8, 2023
d27c764
fix: stash accounts discovery move to baedeker-library
mrshiposha Sep 8, 2023
62d7507
fix: maintenance tests - disable MM after the suite
mrshiposha Sep 8, 2023
e6eb884
Merge pull request #989 from UniqueNetwork/fix/maintenance-tests-rele…
CertainLach Sep 8, 2023
095843d
fix: increase session test timings - 5 mins
mrshiposha Sep 8, 2023
f3f56cc
Merge pull request #988 from UniqueNetwork/fix/collector-selection-te…
CertainLach Sep 8, 2023
4badfb7
ci: forkless-nodata wants new nodes in runtime
CertainLach Sep 10, 2023
950f6ba
ci: respect RELAY_CHAIN_TYPE
CertainLach Sep 11, 2023
31ef540
style: fix clippy warning
CertainLach Sep 11, 2023
af0cd94
build: baedeker reset helper script
CertainLach Sep 11, 2023
1454e80
style: fix rest of clippy warnings
CertainLach Sep 11, 2023
716e4d5
ci: fix relay spec name
CertainLach Sep 11, 2023
afa2cb8
ci: fix rewrite ordering
CertainLach Sep 11, 2023
8bfa768
feat: add .envrc-dev
mrshiposha Sep 11, 2023
348c8c0
Merge pull request #991 from UniqueNetwork/feature/envrc-dev
CertainLach Sep 11, 2023
2fcc0ad
test: forbid creating ApiPromise without set endpoint
CertainLach Sep 11, 2023
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
Prev Previous commit
Next Next commit
refactor: ethereum RPC/tasks initialization
Signed-off-by: Yaroslav Bolyukin <[email protected]>
CertainLach committed Jul 17, 2023

Verified

This commit was created on GitHub.com and signed with GitHub’s verified signature. The key has expired.
commit ec57cb9db90d55aa796c76b9810ace0427aed16c
7 changes: 6 additions & 1 deletion Cargo.lock

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

1 change: 0 additions & 1 deletion Cargo.toml
Original file line number Diff line number Diff line change
@@ -125,7 +125,6 @@ sc-chain-spec = { git = "https://github.com/paritytech/substrate", branch = "pol
sc-cli = { git = "https://github.com/paritytech/substrate", branch = "polkadot-v0.9.43" }
sc-client-api = { git = "https://github.com/paritytech/substrate", branch = "polkadot-v0.9.43" }
sc-consensus = { git = "https://github.com/paritytech/substrate", branch = "polkadot-v0.9.43" }
sc-consensus-grandpa = { git = "https://github.com/paritytech/substrate", branch = "polkadot-v0.9.43" }
sc-consensus-manual-seal = { git = "https://github.com/paritytech/substrate", branch = "polkadot-v0.9.43" }
sc-executor = { git = "https://github.com/paritytech/substrate", branch = "polkadot-v0.9.43" }
sc-network = { git = "https://github.com/paritytech/substrate", branch = "polkadot-v0.9.43" }
5 changes: 4 additions & 1 deletion node/cli/Cargo.toml
Original file line number Diff line number Diff line change
@@ -21,7 +21,7 @@ targets = ['x86_64-unknown-linux-gnu']

[dependencies]
clap = "4.1"
futures = '0.3.17'
futures = '0.3.28'
tokio = { version = "1.24", features = ["time"] }
serde_json = "1.0"

@@ -94,6 +94,9 @@ uc-rpc = { workspace = true }
unique-rpc = { workspace = true }
up-pov-estimate-rpc = { workspace = true }
up-rpc = { workspace = true }
jsonrpsee.workspace = true
fp-storage.workspace = true
sc-rpc.workspace = true

[build-dependencies]
substrate-build-script-utils = { workspace = true }
2 changes: 2 additions & 0 deletions node/cli/src/chain_spec.rs
Original file line number Diff line number Diff line change
@@ -168,6 +168,7 @@ macro_rules! testnet_genesis {
.collect(),
},
common: Default::default(),
configuration: Default::default(),
nonfungible: Default::default(),
treasury: Default::default(),
tokens: TokensConfig { balances: vec![] },
@@ -228,6 +229,7 @@ macro_rules! testnet_genesis {
.to_vec(),
},
common: Default::default(),
configuration: Default::default(),
nonfungible: Default::default(),
balances: BalancesConfig {
balances: $endowed_accounts
456 changes: 309 additions & 147 deletions node/cli/src/service.rs

Large diffs are not rendered by default.

2 changes: 1 addition & 1 deletion node/rpc/Cargo.toml
Original file line number Diff line number Diff line change
@@ -14,7 +14,6 @@ jsonrpsee = { workspace = true }
# pallet-contracts-rpc = { git = 'https://github.com/paritytech/substrate', branch = 'master' }
pallet-transaction-payment-rpc = { workspace = true }
sc-client-api = { workspace = true }
sc-consensus-grandpa = { workspace = true }
sc-network = { workspace = true }
sc-network-sync = { workspace = true }
sc-rpc = { workspace = true }
@@ -41,6 +40,7 @@ up-common = { workspace = true }
up-data-structs = { workspace = true }
up-pov-estimate-rpc = { workspace = true, default-features = true }
up-rpc = { workspace = true }
pallet-ethereum.workspace = true

[features]
default = []
226 changes: 124 additions & 102 deletions node/rpc/src/lib.rs
Original file line number Diff line number Diff line change
@@ -14,6 +14,7 @@
// You should have received a copy of the GNU General Public License
// along with Unique Network. If not, see <http://www.gnu.org/licenses/>.

use fc_mapping_sync::{EthereumBlockNotificationSinks, EthereumBlockNotification};
use sp_runtime::traits::BlakeTwo256;
use fc_rpc::{
EthBlockDataCacheTask, OverrideHandle, RuntimeApiStorageOverride, SchemaV1Override,
@@ -27,9 +28,6 @@ use sc_client_api::{
client::BlockchainEvents,
StateBackend, Backend,
};
use sc_consensus_grandpa::{
FinalityProofProvider, GrandpaJustificationStream, SharedAuthoritySet, SharedVoterState,
};
use sc_network::NetworkService;
use sc_network_sync::SyncingService;
use sc_rpc::SubscriptionTaskExecutor;
@@ -46,42 +44,16 @@ use up_common::types::opaque::*;
#[cfg(feature = "pov-estimate")]
type FullBackend = sc_service::TFullBackend<Block>;

/// Extra dependencies for GRANDPA
pub struct GrandpaDeps<B> {
/// Voting round info.
pub shared_voter_state: SharedVoterState,
/// Authority set info.
pub shared_authority_set: SharedAuthoritySet<Hash, BlockNumber>,
/// Receives notifications about justification events from Grandpa.
pub justification_stream: GrandpaJustificationStream<Block>,
/// Executor to drive the subscription manager in the Grandpa RPC handler.
pub subscription_executor: SubscriptionTaskExecutor,
/// Finality proof provider.
pub finality_provider: Arc<FinalityProofProvider<B, Block>>,
}

/// Full client dependencies.
pub struct FullDeps<C, P, SC, CA: ChainApi> {
pub struct FullDeps<C, P, SC> {
/// The client instance to use.
pub client: Arc<C>,
/// Transaction pool instance.
pub pool: Arc<P>,
/// Graph pool instance.
pub graph: Arc<Pool<CA>>,
/// The SelectChain Strategy
pub select_chain: SC,
/// The Node authority flag
pub is_authority: bool,
/// Whether to enable dev signer
pub enable_dev_signer: bool,
/// Network service
pub network: Arc<NetworkService<Block, Hash>>,
/// Syncing service
pub sync: Arc<SyncingService<Block>>,
/// Whether to deny unsafe calls
pub deny_unsafe: DenyUnsafe,
/// EthFilterApi pool.
pub filter_pool: Option<FilterPool>,

/// Runtime identification (read from the chain spec)
pub runtime_id: RuntimeId,
@@ -91,23 +63,6 @@ pub struct FullDeps<C, P, SC, CA: ChainApi> {
/// Substrate Backend.
#[cfg(feature = "pov-estimate")]
pub backend: Arc<FullBackend>,

/// Ethereum Backend.
pub eth_backend: Arc<dyn fc_db::BackendReader<Block> + Send + Sync>,
/// Maximum number of logs in a query.
pub max_past_logs: u32,
/// Maximum fee history cache size.
pub fee_history_limit: u64,
/// Fee history cache.
pub fee_history_cache: FeeHistoryCache,
/// Cache for Ethereum block data.
pub block_data_cache: Arc<EthBlockDataCacheTask<Block>>,

pub pubsub_notification_sinks: Arc<
fc_mapping_sync::EthereumBlockNotificationSinks<
fc_mapping_sync::EthereumBlockNotification<Block>,
>,
>,
}

pub fn overrides_handle<C, BE, R>(client: Arc<C>) -> Arc<OverrideHandle<Block>>
@@ -142,10 +97,10 @@ where
}

/// Instantiate all Full RPC extensions.
pub fn create_full<C, P, SC, CA, R, A, B>(
deps: FullDeps<C, P, SC, CA>,
subscription_task_executor: SubscriptionTaskExecutor,
) -> Result<RpcModule<()>, Box<dyn std::error::Error + Send + Sync>>
pub fn create_full<C, P, SC, R, A, B>(
io: &mut RpcModule<()>,
deps: FullDeps<C, P, SC>,
) -> Result<(), Box<dyn std::error::Error + Send + Sync>>
where
C: ProvideRuntimeApi<Block> + StorageProvider<Block, B> + AuxStore,
C: HeaderBackend<Block> + HeaderMetadata<Block, Error = BlockChainError> + 'static,
@@ -155,8 +110,6 @@ where
C::Api: BlockBuilder<Block>,
// C::Api: pallet_contracts_rpc::ContractsRuntimeApi<Block, AccountId, Balance, BlockNumber, Hash>,
C::Api: pallet_transaction_payment_rpc::TransactionPaymentRuntimeApi<Block, Balance>,
C::Api: fp_rpc::EthereumRuntimeRPCApi<Block>,
C::Api: fp_rpc::ConvertTransactionRuntimeApi<Block>,
C::Api: up_rpc::UniqueApi<Block, <R as RuntimeInstance>::CrossAccountId, AccountId>,
C::Api: app_promotion_rpc::AppPromotionApi<
Block,
@@ -168,7 +121,6 @@ where
B: sc_client_api::Backend<Block> + Send + Sync + 'static,
B::State: sc_client_api::backend::StateBackend<sp_runtime::traits::HashFor<Block>>,
P: TransactionPool<Block = Block> + 'static,
CA: ChainApi<Block = Block> + 'static,
R: RuntimeInstance + Send + Sync + 'static,
<R as RuntimeInstance>::CrossAccountId: serde::Serialize,
C: sp_api::CallApiAt<
@@ -179,10 +131,6 @@ where
>,
for<'de> <R as RuntimeInstance>::CrossAccountId: serde::Deserialize<'de>,
{
use fc_rpc::{
Eth, EthApiServer, EthDevSigner, EthFilter, EthFilterApiServer, EthPubSub,
EthPubSubApiServer, EthSigner, Net, NetApiServer, Web3, Web3ApiServer, TxPool, TxPoolApiServer
};
use uc_rpc::{UniqueApiServer, Unique};

use uc_rpc::{AppPromotionApiServer, AppPromotion};
@@ -194,21 +142,11 @@ where
use pallet_transaction_payment_rpc::{TransactionPayment, TransactionPaymentApiServer};
use substrate_frame_rpc_system::{System, SystemApiServer};

let mut io = RpcModule::new(());
let FullDeps {
client,
pool,
graph,
select_chain: _,
fee_history_limit,
fee_history_cache,
block_data_cache,
enable_dev_signer,
is_authority,
network,
sync,
deny_unsafe,
filter_pool,

runtime_id: _,

@@ -217,37 +155,137 @@ where

#[cfg(feature = "pov-estimate")]
backend,

eth_backend,
max_past_logs,
pubsub_notification_sinks,
} = deps;

io.merge(System::new(Arc::clone(&client), Arc::clone(&pool), deny_unsafe).into_rpc())?;
io.merge(TransactionPayment::new(Arc::clone(&client)).into_rpc())?;

// io.extend_with(ContractsApi::to_delegate(Contracts::new(client.clone())));
io.merge(Unique::new(client.clone()).into_rpc())?;

io.merge(AppPromotion::new(client.clone()).into_rpc())?;

#[cfg(feature = "pov-estimate")]
io.merge(
PovEstimate::new(
client.clone(),
backend,
deny_unsafe,
exec_params,
runtime_id,
)
.into_rpc(),
)?;

Ok(())
}

pub struct EthDeps<C, P, CA: ChainApi> {
/// The client instance to use.
pub client: Arc<C>,
/// Transaction pool instance.
pub pool: Arc<P>,
/// Graph pool instance.
pub graph: Arc<Pool<CA>>,
/// Syncing service
pub sync: Arc<SyncingService<Block>>,
/// The Node authority flag
pub is_authority: bool,
/// Network service
pub network: Arc<NetworkService<Block, Hash>>,

/// Ethereum Backend.
pub eth_backend: Arc<dyn fc_db::BackendReader<Block> + Send + Sync>,
/// Maximum number of logs in a query.
pub max_past_logs: u32,
/// Maximum fee history cache size.
pub fee_history_limit: u64,
/// Fee history cache.
pub fee_history_cache: FeeHistoryCache,
pub eth_block_data_cache: Arc<EthBlockDataCacheTask<Block>>,
/// EthFilterApi pool.
pub eth_filter_pool: Option<FilterPool>,
pub eth_pubsub_notification_sinks: Arc<EthereumBlockNotificationSinks<EthereumBlockNotification<Block>>>,
/// Whether to enable eth dev signer
pub enable_dev_signer: bool,

pub overrides: Arc<OverrideHandle<Block>>,
}

/// This converter is never used, but we have a generic
/// Option<T>, where T should implement ConvertTransaction
///
/// TODO: remove after never-type (`!`) stabilization
enum NeverConvert {}
impl<T> fp_rpc::ConvertTransaction<T> for NeverConvert {
fn convert_transaction(&self, _transaction: pallet_ethereum::Transaction) -> T {
unreachable!()
}
}

pub fn create_eth<C, P, CA, B>(
io: &mut RpcModule<()>,
deps: EthDeps<C, P, CA>,
subscription_task_executor: SubscriptionTaskExecutor,
) -> Result<(), Box<dyn std::error::Error + Send + Sync>>
where
C: ProvideRuntimeApi<Block> + StorageProvider<Block, B> + AuxStore,
C: HeaderBackend<Block> + HeaderMetadata<Block, Error = BlockChainError> + 'static,
C: Send + Sync + 'static,
C: BlockchainEvents<Block>,
C::Api: BlockBuilder<Block>,
C::Api: fp_rpc::EthereumRuntimeRPCApi<Block>,
C::Api: fp_rpc::ConvertTransactionRuntimeApi<Block>,
P: TransactionPool<Block = Block> + 'static,
CA: ChainApi<Block = Block> + 'static,
B: sc_client_api::Backend<Block> + Send + Sync + 'static,
C: sp_api::CallApiAt<
sp_runtime::generic::Block<
sp_runtime::generic::Header<u32, BlakeTwo256>,
sp_runtime::OpaqueExtrinsic,
>,
>,
{
use fc_rpc::{
Eth, EthApiServer, EthDevSigner, EthFilter, EthFilterApiServer, EthPubSub,
EthPubSubApiServer, EthSigner, Net, NetApiServer, Web3, Web3ApiServer, TxPool, TxPoolApiServer,
};

let EthDeps {
client,
pool,
graph,
eth_backend,
max_past_logs,
fee_history_limit,
fee_history_cache,
eth_block_data_cache,
eth_filter_pool,
eth_pubsub_notification_sinks,
enable_dev_signer,
sync,
is_authority,
network,
overrides,
} = deps;

let mut signers = Vec::new();
if enable_dev_signer {
signers.push(Box::new(EthDevSigner::new()) as Box<dyn EthSigner>);
}

let overrides = overrides_handle::<_, _, R>(client.clone());

let execute_gas_limit_multiplier = 10;
io.merge(
Eth::new(
client.clone(),
pool.clone(),
graph.clone(),
Some(<R as RuntimeInstance>::get_transaction_converter()),
// We have no runtimes old enough to only accept converted transactions
None::<NeverConvert>,
sync.clone(),
signers,
overrides.clone(),
eth_backend.clone(),
is_authority,
block_data_cache.clone(),
eth_block_data_cache.clone(),
fee_history_cache,
fee_history_limit,
execute_gas_limit_multiplier,
@@ -256,24 +294,12 @@ where
.into_rpc(),
)?;

io.merge(Unique::new(client.clone()).into_rpc())?;

io.merge(AppPromotion::new(client.clone()).into_rpc())?;

#[cfg(feature = "pov-estimate")]
io.merge(
PovEstimate::new(
client.clone(),
backend,
deny_unsafe,
exec_params,
runtime_id,
)
.into_rpc(),
)?;
let tx_pool = TxPool::new(
client.clone(),
graph,
);

let tx_pool = TxPool::new(client.clone(), graph);
if let Some(filter_pool) = filter_pool {
if let Some(filter_pool) = eth_filter_pool {
io.merge(
EthFilter::new(
client.clone(),
@@ -282,12 +308,11 @@ where
filter_pool,
500_usize, // max stored filters
max_past_logs,
block_data_cache,
eth_block_data_cache,
)
.into_rpc(),
)?;
}

io.merge(
Net::new(
client.clone(),
@@ -297,22 +322,19 @@ where
)
.into_rpc(),
)?;

io.merge(Web3::new(client.clone()).into_rpc())?;

io.merge(
EthPubSub::new(
pool,
client,
sync,
subscription_task_executor,
overrides,
pubsub_notification_sinks,
eth_pubsub_notification_sinks,
)
.into_rpc(),
)?;

io.merge(tx_pool.into_rpc())?;

Ok(io)
Ok(())
}