mirror of
https://github.com/hl-archive-node/nanoreth.git
synced 2025-12-06 10:59:55 +00:00
feat: EngineValidator (#11144)
This commit is contained in:
@ -4,6 +4,7 @@ use std::{future::Future, marker::PhantomData};
|
||||
|
||||
use reth_consensus::Consensus;
|
||||
use reth_evm::execute::BlockExecutorProvider;
|
||||
use reth_node_api::{EngineValidator, NodeTypesWithEngine};
|
||||
use reth_primitives::Header;
|
||||
use reth_transaction_pool::TransactionPool;
|
||||
|
||||
@ -15,6 +16,8 @@ use crate::{
|
||||
BuilderContext, ConfigureEvm, FullNodeTypes,
|
||||
};
|
||||
|
||||
use super::EngineValidatorBuilder;
|
||||
|
||||
/// A generic, general purpose and customizable [`NodeComponentsBuilder`] implementation.
|
||||
///
|
||||
/// This type is stateful and captures the configuration of the node's components.
|
||||
@ -35,22 +38,23 @@ use crate::{
|
||||
/// All component builders are captured in the builder state and will be consumed once the node is
|
||||
/// launched.
|
||||
#[derive(Debug)]
|
||||
pub struct ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB> {
|
||||
pub struct ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB> {
|
||||
pool_builder: PoolB,
|
||||
payload_builder: PayloadB,
|
||||
network_builder: NetworkB,
|
||||
executor_builder: ExecB,
|
||||
consensus_builder: ConsB,
|
||||
engine_validator_builder: EVB,
|
||||
_marker: PhantomData<Node>,
|
||||
}
|
||||
|
||||
impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB>
|
||||
ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB>
|
||||
{
|
||||
/// Configures the node types.
|
||||
pub fn node_types<Types>(
|
||||
self,
|
||||
) -> ComponentsBuilder<Types, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
) -> ComponentsBuilder<Types, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB>
|
||||
where
|
||||
Types: FullNodeTypes,
|
||||
{
|
||||
@ -60,6 +64,7 @@ impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
network_builder,
|
||||
executor_builder: evm_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
} = self;
|
||||
ComponentsBuilder {
|
||||
@ -68,6 +73,7 @@ impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
payload_builder,
|
||||
network_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker: Default::default(),
|
||||
}
|
||||
}
|
||||
@ -80,6 +86,7 @@ impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
network_builder: self.network_builder,
|
||||
executor_builder: self.executor_builder,
|
||||
consensus_builder: self.consensus_builder,
|
||||
engine_validator_builder: self.engine_validator_builder,
|
||||
_marker: self._marker,
|
||||
}
|
||||
}
|
||||
@ -92,6 +99,7 @@ impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
network_builder: self.network_builder,
|
||||
executor_builder: self.executor_builder,
|
||||
consensus_builder: self.consensus_builder,
|
||||
engine_validator_builder: self.engine_validator_builder,
|
||||
_marker: self._marker,
|
||||
}
|
||||
}
|
||||
@ -104,6 +112,7 @@ impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
network_builder: f(self.network_builder),
|
||||
executor_builder: self.executor_builder,
|
||||
consensus_builder: self.consensus_builder,
|
||||
engine_validator_builder: self.engine_validator_builder,
|
||||
_marker: self._marker,
|
||||
}
|
||||
}
|
||||
@ -116,6 +125,7 @@ impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
network_builder: self.network_builder,
|
||||
executor_builder: f(self.executor_builder),
|
||||
consensus_builder: self.consensus_builder,
|
||||
engine_validator_builder: self.engine_validator_builder,
|
||||
_marker: self._marker,
|
||||
}
|
||||
}
|
||||
@ -128,13 +138,14 @@ impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
network_builder: self.network_builder,
|
||||
executor_builder: self.executor_builder,
|
||||
consensus_builder: f(self.consensus_builder),
|
||||
engine_validator_builder: self.engine_validator_builder,
|
||||
_marker: self._marker,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB>
|
||||
ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB>
|
||||
where
|
||||
Node: FullNodeTypes,
|
||||
{
|
||||
@ -145,7 +156,7 @@ where
|
||||
pub fn pool<PB>(
|
||||
self,
|
||||
pool_builder: PB,
|
||||
) -> ComponentsBuilder<Node, PB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
) -> ComponentsBuilder<Node, PB, PayloadB, NetworkB, ExecB, ConsB, EVB>
|
||||
where
|
||||
PB: PoolBuilder<Node>,
|
||||
{
|
||||
@ -155,6 +166,7 @@ where
|
||||
network_builder,
|
||||
executor_builder: evm_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
} = self;
|
||||
ComponentsBuilder {
|
||||
@ -163,13 +175,14 @@ where
|
||||
network_builder,
|
||||
executor_builder: evm_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB>
|
||||
ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB>
|
||||
where
|
||||
Node: FullNodeTypes,
|
||||
PoolB: PoolBuilder<Node>,
|
||||
@ -181,7 +194,7 @@ where
|
||||
pub fn network<NB>(
|
||||
self,
|
||||
network_builder: NB,
|
||||
) -> ComponentsBuilder<Node, PoolB, PayloadB, NB, ExecB, ConsB>
|
||||
) -> ComponentsBuilder<Node, PoolB, PayloadB, NB, ExecB, ConsB, EVB>
|
||||
where
|
||||
NB: NetworkBuilder<Node, PoolB::Pool>,
|
||||
{
|
||||
@ -191,6 +204,7 @@ where
|
||||
network_builder: _,
|
||||
executor_builder: evm_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
} = self;
|
||||
ComponentsBuilder {
|
||||
@ -199,6 +213,7 @@ where
|
||||
network_builder,
|
||||
executor_builder: evm_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
}
|
||||
}
|
||||
@ -210,7 +225,7 @@ where
|
||||
pub fn payload<PB>(
|
||||
self,
|
||||
payload_builder: PB,
|
||||
) -> ComponentsBuilder<Node, PoolB, PB, NetworkB, ExecB, ConsB>
|
||||
) -> ComponentsBuilder<Node, PoolB, PB, NetworkB, ExecB, ConsB, EVB>
|
||||
where
|
||||
PB: PayloadServiceBuilder<Node, PoolB::Pool>,
|
||||
{
|
||||
@ -220,6 +235,7 @@ where
|
||||
network_builder,
|
||||
executor_builder: evm_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
} = self;
|
||||
ComponentsBuilder {
|
||||
@ -228,6 +244,7 @@ where
|
||||
network_builder,
|
||||
executor_builder: evm_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
}
|
||||
}
|
||||
@ -239,7 +256,7 @@ where
|
||||
pub fn executor<EB>(
|
||||
self,
|
||||
executor_builder: EB,
|
||||
) -> ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, EB, ConsB>
|
||||
) -> ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, EB, ConsB, EVB>
|
||||
where
|
||||
EB: ExecutorBuilder<Node>,
|
||||
{
|
||||
@ -249,6 +266,7 @@ where
|
||||
network_builder,
|
||||
executor_builder: _,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
} = self;
|
||||
ComponentsBuilder {
|
||||
@ -257,6 +275,7 @@ where
|
||||
network_builder,
|
||||
executor_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
}
|
||||
}
|
||||
@ -268,7 +287,7 @@ where
|
||||
pub fn consensus<CB>(
|
||||
self,
|
||||
consensus_builder: CB,
|
||||
) -> ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, CB>
|
||||
) -> ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, CB, EVB>
|
||||
where
|
||||
CB: ConsensusBuilder<Node>,
|
||||
{
|
||||
@ -278,6 +297,7 @@ where
|
||||
network_builder,
|
||||
executor_builder,
|
||||
consensus_builder: _,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
} = self;
|
||||
ComponentsBuilder {
|
||||
@ -286,13 +306,45 @@ where
|
||||
network_builder,
|
||||
executor_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
}
|
||||
}
|
||||
|
||||
/// Configures the consensus builder.
|
||||
///
|
||||
/// This accepts a [`ConsensusBuilder`] instance that will be used to create the node's
|
||||
/// components for consensus.
|
||||
pub fn engine_validator<EngineVB>(
|
||||
self,
|
||||
engine_validator_builder: EngineVB,
|
||||
) -> ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EngineVB>
|
||||
where
|
||||
EngineVB: EngineValidatorBuilder<Node>,
|
||||
{
|
||||
let Self {
|
||||
pool_builder,
|
||||
payload_builder,
|
||||
network_builder,
|
||||
executor_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder: _,
|
||||
_marker,
|
||||
} = self;
|
||||
ComponentsBuilder {
|
||||
pool_builder,
|
||||
payload_builder,
|
||||
network_builder,
|
||||
executor_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB> NodeComponentsBuilder<Node>
|
||||
for ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB>
|
||||
impl<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB> NodeComponentsBuilder<Node>
|
||||
for ComponentsBuilder<Node, PoolB, PayloadB, NetworkB, ExecB, ConsB, EVB>
|
||||
where
|
||||
Node: FullNodeTypes,
|
||||
PoolB: PoolBuilder<Node>,
|
||||
@ -300,8 +352,16 @@ where
|
||||
PayloadB: PayloadServiceBuilder<Node, PoolB::Pool>,
|
||||
ExecB: ExecutorBuilder<Node>,
|
||||
ConsB: ConsensusBuilder<Node>,
|
||||
EVB: EngineValidatorBuilder<Node>,
|
||||
{
|
||||
type Components = Components<Node, PoolB::Pool, ExecB::EVM, ExecB::Executor, ConsB::Consensus>;
|
||||
type Components = Components<
|
||||
Node,
|
||||
PoolB::Pool,
|
||||
ExecB::EVM,
|
||||
ExecB::Executor,
|
||||
ConsB::Consensus,
|
||||
EVB::Validator,
|
||||
>;
|
||||
|
||||
async fn build_components(
|
||||
self,
|
||||
@ -313,6 +373,7 @@ where
|
||||
network_builder,
|
||||
executor_builder: evm_builder,
|
||||
consensus_builder,
|
||||
engine_validator_builder,
|
||||
_marker,
|
||||
} = self;
|
||||
|
||||
@ -321,6 +382,7 @@ where
|
||||
let network = network_builder.build_network(context, pool.clone()).await?;
|
||||
let payload_builder = payload_builder.spawn_payload_service(context, pool.clone()).await?;
|
||||
let consensus = consensus_builder.build_consensus(context).await?;
|
||||
let engine_validator = engine_validator_builder.build_validator(context).await?;
|
||||
|
||||
Ok(Components {
|
||||
transaction_pool: pool,
|
||||
@ -329,11 +391,12 @@ where
|
||||
payload_builder,
|
||||
executor,
|
||||
consensus,
|
||||
engine_validator,
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
impl Default for ComponentsBuilder<(), (), (), (), (), ()> {
|
||||
impl Default for ComponentsBuilder<(), (), (), (), (), (), ()> {
|
||||
fn default() -> Self {
|
||||
Self {
|
||||
pool_builder: (),
|
||||
@ -341,6 +404,7 @@ impl Default for ComponentsBuilder<(), (), (), (), (), ()> {
|
||||
network_builder: (),
|
||||
executor_builder: (),
|
||||
consensus_builder: (),
|
||||
engine_validator_builder: (),
|
||||
_marker: Default::default(),
|
||||
}
|
||||
}
|
||||
@ -366,17 +430,18 @@ pub trait NodeComponentsBuilder<Node: FullNodeTypes>: Send {
|
||||
) -> impl Future<Output = eyre::Result<Self::Components>> + Send;
|
||||
}
|
||||
|
||||
impl<Node, F, Fut, Pool, EVM, Executor, Cons> NodeComponentsBuilder<Node> for F
|
||||
impl<Node, F, Fut, Pool, EVM, Executor, Cons, Val> NodeComponentsBuilder<Node> for F
|
||||
where
|
||||
Node: FullNodeTypes,
|
||||
F: FnOnce(&BuilderContext<Node>) -> Fut + Send,
|
||||
Fut: Future<Output = eyre::Result<Components<Node, Pool, EVM, Executor, Cons>>> + Send,
|
||||
Fut: Future<Output = eyre::Result<Components<Node, Pool, EVM, Executor, Cons, Val>>> + Send,
|
||||
Pool: TransactionPool + Unpin + 'static,
|
||||
EVM: ConfigureEvm<Header = Header>,
|
||||
Executor: BlockExecutorProvider,
|
||||
Cons: Consensus + Clone + Unpin + 'static,
|
||||
Val: EngineValidator<<Node::Types as NodeTypesWithEngine>::Engine> + Clone + Unpin + 'static,
|
||||
{
|
||||
type Components = Components<Node, Pool, EVM, Executor, Cons>;
|
||||
type Components = Components<Node, Pool, EVM, Executor, Cons, Val>;
|
||||
|
||||
fn build_components(
|
||||
self,
|
||||
|
||||
38
crates/node/builder/src/components/engine.rs
Normal file
38
crates/node/builder/src/components/engine.rs
Normal file
@ -0,0 +1,38 @@
|
||||
//! Consensus component for the node builder.
|
||||
use reth_node_api::{EngineValidator, NodeTypesWithEngine};
|
||||
|
||||
use crate::{BuilderContext, FullNodeTypes};
|
||||
use std::future::Future;
|
||||
|
||||
/// A type that knows how to build the engine validator.
|
||||
pub trait EngineValidatorBuilder<Node: FullNodeTypes>: Send {
|
||||
/// The consensus implementation to build.
|
||||
type Validator: EngineValidator<<Node::Types as NodeTypesWithEngine>::Engine>
|
||||
+ Clone
|
||||
+ Unpin
|
||||
+ 'static;
|
||||
|
||||
/// Creates the engine validator.
|
||||
fn build_validator(
|
||||
self,
|
||||
ctx: &BuilderContext<Node>,
|
||||
) -> impl Future<Output = eyre::Result<Self::Validator>> + Send;
|
||||
}
|
||||
|
||||
impl<Node, F, Fut, Validator> EngineValidatorBuilder<Node> for F
|
||||
where
|
||||
Node: FullNodeTypes,
|
||||
Validator:
|
||||
EngineValidator<<Node::Types as NodeTypesWithEngine>::Engine> + Clone + Unpin + 'static,
|
||||
F: FnOnce(&BuilderContext<Node>) -> Fut + Send,
|
||||
Fut: Future<Output = eyre::Result<Validator>> + Send,
|
||||
{
|
||||
type Validator = Validator;
|
||||
|
||||
fn build_validator(
|
||||
self,
|
||||
ctx: &BuilderContext<Node>,
|
||||
) -> impl Future<Output = eyre::Result<Self::Validator>> {
|
||||
self(ctx)
|
||||
}
|
||||
}
|
||||
@ -9,6 +9,7 @@
|
||||
|
||||
mod builder;
|
||||
mod consensus;
|
||||
mod engine;
|
||||
mod execute;
|
||||
mod network;
|
||||
mod payload;
|
||||
@ -16,6 +17,7 @@ mod pool;
|
||||
|
||||
pub use builder::*;
|
||||
pub use consensus::*;
|
||||
pub use engine::*;
|
||||
pub use execute::*;
|
||||
pub use network::*;
|
||||
pub use payload::*;
|
||||
@ -25,7 +27,7 @@ use reth_consensus::Consensus;
|
||||
use reth_evm::execute::BlockExecutorProvider;
|
||||
use reth_network::NetworkHandle;
|
||||
use reth_network_api::FullNetwork;
|
||||
use reth_node_api::NodeTypesWithEngine;
|
||||
use reth_node_api::{EngineValidator, NodeTypesWithEngine};
|
||||
use reth_payload_builder::PayloadBuilderHandle;
|
||||
use reth_primitives::Header;
|
||||
use reth_transaction_pool::TransactionPool;
|
||||
@ -53,6 +55,9 @@ pub trait NodeComponents<T: FullNodeTypes>: Clone + Unpin + Send + Sync + 'stati
|
||||
/// Network API.
|
||||
type Network: FullNetwork;
|
||||
|
||||
/// Validator for the engine API.
|
||||
type EngineValidator: EngineValidator<<T::Types as NodeTypesWithEngine>::Engine>;
|
||||
|
||||
/// Returns the transaction pool of the node.
|
||||
fn pool(&self) -> &Self::Pool;
|
||||
|
||||
@ -70,13 +75,16 @@ pub trait NodeComponents<T: FullNodeTypes>: Clone + Unpin + Send + Sync + 'stati
|
||||
|
||||
/// Returns the handle to the payload builder service.
|
||||
fn payload_builder(&self) -> &PayloadBuilderHandle<<T::Types as NodeTypesWithEngine>::Engine>;
|
||||
|
||||
/// Returns the engine validator.
|
||||
fn engine_validator(&self) -> &Self::EngineValidator;
|
||||
}
|
||||
|
||||
/// All the components of the node.
|
||||
///
|
||||
/// This provides access to all the components of the node.
|
||||
#[derive(Debug)]
|
||||
pub struct Components<Node: FullNodeTypes, Pool, EVM, Executor, Consensus> {
|
||||
pub struct Components<Node: FullNodeTypes, Pool, EVM, Executor, Consensus, Validator> {
|
||||
/// The transaction pool of the node.
|
||||
pub transaction_pool: Pool,
|
||||
/// The node's EVM configuration, defining settings for the Ethereum Virtual Machine.
|
||||
@ -89,22 +97,26 @@ pub struct Components<Node: FullNodeTypes, Pool, EVM, Executor, Consensus> {
|
||||
pub network: NetworkHandle,
|
||||
/// The handle to the payload builder service.
|
||||
pub payload_builder: PayloadBuilderHandle<<Node::Types as NodeTypesWithEngine>::Engine>,
|
||||
/// The validator for the engine API.
|
||||
pub engine_validator: Validator,
|
||||
}
|
||||
|
||||
impl<Node, Pool, EVM, Executor, Cons> NodeComponents<Node>
|
||||
for Components<Node, Pool, EVM, Executor, Cons>
|
||||
impl<Node, Pool, EVM, Executor, Cons, Val> NodeComponents<Node>
|
||||
for Components<Node, Pool, EVM, Executor, Cons, Val>
|
||||
where
|
||||
Node: FullNodeTypes,
|
||||
Pool: TransactionPool + Unpin + 'static,
|
||||
EVM: ConfigureEvm<Header = Header>,
|
||||
Executor: BlockExecutorProvider,
|
||||
Cons: Consensus + Clone + Unpin + 'static,
|
||||
Val: EngineValidator<<Node::Types as NodeTypesWithEngine>::Engine> + Clone + Unpin + 'static,
|
||||
{
|
||||
type Pool = Pool;
|
||||
type Evm = EVM;
|
||||
type Executor = Executor;
|
||||
type Consensus = Cons;
|
||||
type Network = NetworkHandle;
|
||||
type EngineValidator = Val;
|
||||
|
||||
fn pool(&self) -> &Self::Pool {
|
||||
&self.transaction_pool
|
||||
@ -131,15 +143,21 @@ where
|
||||
) -> &PayloadBuilderHandle<<Node::Types as NodeTypesWithEngine>::Engine> {
|
||||
&self.payload_builder
|
||||
}
|
||||
|
||||
fn engine_validator(&self) -> &Self::EngineValidator {
|
||||
&self.engine_validator
|
||||
}
|
||||
}
|
||||
|
||||
impl<Node, Pool, EVM, Executor, Cons> Clone for Components<Node, Pool, EVM, Executor, Cons>
|
||||
impl<Node, Pool, EVM, Executor, Cons, Val> Clone
|
||||
for Components<Node, Pool, EVM, Executor, Cons, Val>
|
||||
where
|
||||
Node: FullNodeTypes,
|
||||
Pool: TransactionPool,
|
||||
EVM: ConfigureEvm<Header = Header>,
|
||||
Executor: BlockExecutorProvider,
|
||||
Cons: Consensus + Clone,
|
||||
Val: EngineValidator<<Node::Types as NodeTypesWithEngine>::Engine>,
|
||||
{
|
||||
fn clone(&self) -> Self {
|
||||
Self {
|
||||
@ -149,6 +167,7 @@ where
|
||||
consensus: self.consensus.clone(),
|
||||
network: self.network.clone(),
|
||||
payload_builder: self.payload_builder.clone(),
|
||||
engine_validator: self.engine_validator.clone(),
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@ -275,6 +275,7 @@ where
|
||||
Box::new(ctx.task_executor().clone()),
|
||||
client,
|
||||
EngineCapabilities::default(),
|
||||
ctx.components().engine_validator().clone(),
|
||||
);
|
||||
info!(target: "reth::cli", "Engine API handler initialized");
|
||||
|
||||
|
||||
@ -351,6 +351,7 @@ where
|
||||
Box::new(ctx.task_executor().clone()),
|
||||
client,
|
||||
EngineCapabilities::default(),
|
||||
ctx.components().engine_validator().clone(),
|
||||
);
|
||||
info!(target: "reth::cli", "Engine API handler initialized");
|
||||
|
||||
|
||||
@ -39,7 +39,7 @@ pub trait NodeTypes: Send + Sync + Unpin + 'static {
|
||||
/// The type that configures an Ethereum-like node with an engine for consensus.
|
||||
pub trait NodeTypesWithEngine: NodeTypes {
|
||||
/// The node's engine types, defining the interaction with the consensus engine.
|
||||
type Engine: EngineTypes<ChainSpec = Self::ChainSpec>;
|
||||
type Engine: EngineTypes;
|
||||
}
|
||||
|
||||
/// A helper trait that is downstream of the [`NodeTypesWithEngine`] trait and adds database to the
|
||||
@ -166,7 +166,7 @@ where
|
||||
impl<P, E, C> NodeTypesWithEngine for AnyNodeTypesWithEngine<P, E, C>
|
||||
where
|
||||
P: NodePrimitives + Send + Sync + Unpin + 'static,
|
||||
E: EngineTypes<ChainSpec = C> + Send + Sync + Unpin,
|
||||
E: EngineTypes + Send + Sync + Unpin,
|
||||
C: EthChainSpec,
|
||||
{
|
||||
type Engine = E;
|
||||
|
||||
Reference in New Issue
Block a user