1pub use reth_node_api::{FullNodeTypes, NodeTypes};
3use reth_payload_builder::PayloadBuilderHandle;
4
5use reth_node_api::{EngineTypes, FullNodeComponents, PayloadTypes};
6use reth_node_core::{
7 dirs::{ChainPath, DataDirPath},
8 node_config::NodeConfig,
9};
10use reth_provider::ChainSpecProvider;
11use reth_rpc_api::EngineApiClient;
12use reth_rpc_builder::{auth::AuthServerHandle, RpcServerHandle};
13use reth_tasks::TaskExecutor;
14use std::{
15 fmt::Debug,
16 marker::PhantomData,
17 ops::{Deref, DerefMut},
18 sync::Arc,
19};
20
21use crate::{components::NodeComponentsBuilder, rpc::RethRpcAddOns, NodeAdapter, NodeAddOns};
22
23pub trait Node<N: FullNodeTypes>: NodeTypes + Clone {
27 type ComponentsBuilder: NodeComponentsBuilder<N>;
29
30 type AddOns: NodeAddOns<
32 NodeAdapter<N, <Self::ComponentsBuilder as NodeComponentsBuilder<N>>::Components>,
33 >;
34
35 fn components_builder(&self) -> Self::ComponentsBuilder;
37
38 fn add_ons(&self) -> Self::AddOns;
40}
41
42#[derive(Clone, Default, Debug)]
44pub struct AnyNode<N = (), C = (), AO = ()>(PhantomData<N>, C, AO);
45
46impl<N, C, AO> AnyNode<N, C, AO> {
47 pub fn types<T>(self) -> AnyNode<T, C, AO> {
49 AnyNode(PhantomData, self.1, self.2)
50 }
51
52 pub fn components_builder<T>(self, value: T) -> AnyNode<N, T, AO> {
54 AnyNode(PhantomData, value, self.2)
55 }
56
57 pub fn add_ons<T>(self, value: T) -> AnyNode<N, C, T> {
59 AnyNode(PhantomData, self.1, value)
60 }
61}
62
63impl<N, C, AO> NodeTypes for AnyNode<N, C, AO>
64where
65 N: FullNodeTypes,
66 C: Clone + Debug + Send + Sync + Unpin + 'static,
67 AO: Clone + Debug + Send + Sync + Unpin + 'static,
68{
69 type Primitives = <N::Types as NodeTypes>::Primitives;
70
71 type ChainSpec = <N::Types as NodeTypes>::ChainSpec;
72
73 type StateCommitment = <N::Types as NodeTypes>::StateCommitment;
74
75 type Storage = <N::Types as NodeTypes>::Storage;
76
77 type Payload = <N::Types as NodeTypes>::Payload;
78}
79
80impl<N, C, AO> Node<N> for AnyNode<N, C, AO>
81where
82 N: FullNodeTypes + Clone,
83 C: NodeComponentsBuilder<N> + Clone + Debug + Sync + Unpin + 'static,
84 AO: NodeAddOns<NodeAdapter<N, C::Components>> + Clone + Debug + Sync + Unpin + 'static,
85{
86 type ComponentsBuilder = C;
87 type AddOns = AO;
88
89 fn components_builder(&self) -> Self::ComponentsBuilder {
90 self.1.clone()
91 }
92
93 fn add_ons(&self) -> Self::AddOns {
94 self.2.clone()
95 }
96}
97
98#[derive(Debug)]
102pub struct FullNode<Node: FullNodeComponents, AddOns: NodeAddOns<Node>> {
103 pub evm_config: Node::Evm,
105 pub block_executor: Node::Executor,
107 pub pool: Node::Pool,
109 pub network: Node::Network,
111 pub provider: Node::Provider,
113 pub payload_builder_handle: PayloadBuilderHandle<<Node::Types as NodeTypes>::Payload>,
115 pub task_executor: TaskExecutor,
117 pub config: NodeConfig<<Node::Types as NodeTypes>::ChainSpec>,
119 pub data_dir: ChainPath<DataDirPath>,
121 pub add_ons_handle: AddOns::Handle,
123}
124
125impl<Node: FullNodeComponents, AddOns: NodeAddOns<Node>> Clone for FullNode<Node, AddOns> {
126 fn clone(&self) -> Self {
127 Self {
128 evm_config: self.evm_config.clone(),
129 block_executor: self.block_executor.clone(),
130 pool: self.pool.clone(),
131 network: self.network.clone(),
132 provider: self.provider.clone(),
133 payload_builder_handle: self.payload_builder_handle.clone(),
134 task_executor: self.task_executor.clone(),
135 config: self.config.clone(),
136 data_dir: self.data_dir.clone(),
137 add_ons_handle: self.add_ons_handle.clone(),
138 }
139 }
140}
141
142impl<Payload, Node, AddOns> FullNode<Node, AddOns>
143where
144 Payload: PayloadTypes,
145 Node: FullNodeComponents<Types: NodeTypes<Payload = Payload>>,
146 AddOns: NodeAddOns<Node>,
147{
148 pub fn chain_spec(&self) -> Arc<<Node::Types as NodeTypes>::ChainSpec> {
150 self.provider.chain_spec()
151 }
152}
153
154impl<Payload, Node, AddOns> FullNode<Node, AddOns>
155where
156 Payload: PayloadTypes,
157 Node: FullNodeComponents<Types: NodeTypes<Payload = Payload>>,
158 AddOns: RethRpcAddOns<Node>,
159{
160 pub const fn rpc_server_handle(&self) -> &RpcServerHandle {
162 &self.add_ons_handle.rpc_server_handles.rpc
163 }
164
165 pub const fn auth_server_handle(&self) -> &AuthServerHandle {
167 &self.add_ons_handle.rpc_server_handles.auth
168 }
169}
170
171impl<Engine, Node, AddOns> FullNode<Node, AddOns>
172where
173 Engine: EngineTypes,
174 Node: FullNodeComponents<Types: NodeTypes<Payload = Engine>>,
175 AddOns: RethRpcAddOns<Node>,
176{
177 pub fn engine_http_client(&self) -> impl EngineApiClient<Engine> {
181 self.auth_server_handle().http_client()
182 }
183
184 pub async fn engine_ws_client(&self) -> impl EngineApiClient<Engine> {
188 self.auth_server_handle().ws_client().await
189 }
190
191 #[cfg(unix)]
195 pub async fn engine_ipc_client(&self) -> Option<impl EngineApiClient<Engine>> {
196 self.auth_server_handle().ipc_client().await
197 }
198}
199
200impl<Node: FullNodeComponents, AddOns: NodeAddOns<Node>> Deref for FullNode<Node, AddOns> {
201 type Target = AddOns::Handle;
202
203 fn deref(&self) -> &Self::Target {
204 &self.add_ons_handle
205 }
206}
207
208impl<Node: FullNodeComponents, AddOns: NodeAddOns<Node>> DerefMut for FullNode<Node, AddOns> {
209 fn deref_mut(&mut self) -> &mut Self::Target {
210 &mut self.add_ons_handle
211 }
212}