1#![doc(
10 html_logo_url = "https://raw.githubusercontent.com/paradigmxyz/reth/main/assets/reth-docs.png",
11 html_favicon_url = "https://avatars0.githubusercontent.com/u/97369466?s=256",
12 issue_tracker_base_url = "https://github.com/paradigmxyz/reth/issues/"
13)]
14#![cfg_attr(docsrs, feature(doc_cfg))]
15
16pub mod custody;
18pub mod downloaders;
19pub mod error;
21pub mod events;
22pub mod noop;
24
25pub mod test_utils;
26use test_utils::PeersHandleProvider;
27
28pub use alloy_rpc_types_admin::EthProtocolInfo;
29pub use reth_network_p2p::{BlockClient, HeadersClient};
30pub use reth_network_types::{PeerKind, Reputation, ReputationChangeKind};
31
32pub use custody::CellCustody;
33pub use downloaders::BlockDownloaderProvider;
34pub use error::NetworkError;
35pub use events::{
36 DiscoveredEvent, DiscoveryEvent, NetworkEvent, NetworkEventListenerProvider, PeerRequest,
37 PeerRequestSender,
38};
39
40use reth_eth_wire_types::{
41 capability::Capabilities, Capability, DisconnectReason, EthVersion, NetworkPrimitives,
42 UnifiedStatus,
43};
44use reth_network_p2p::sync::NetworkSyncUpdater;
45use reth_network_peers::NodeRecord;
46use std::{future::Future, net::SocketAddr, sync::Arc, time::Instant};
47
48pub type PeerId = alloy_primitives::B512;
50
51pub trait FullNetwork:
53 BlockDownloaderProvider<
54 Client: BlockClient<Block = <Self::Primitives as NetworkPrimitives>::Block>,
55 > + NetworkSyncUpdater
56 + NetworkInfo
57 + NetworkEventListenerProvider
58 + Peers
59 + PeersHandleProvider
60 + Clone
61 + Unpin
62 + 'static
63{
64}
65
66impl<T> FullNetwork for T where
67 T: BlockDownloaderProvider<
68 Client: BlockClient<Block = <Self::Primitives as NetworkPrimitives>::Block>,
69 > + NetworkSyncUpdater
70 + NetworkInfo
71 + NetworkEventListenerProvider
72 + Peers
73 + PeersHandleProvider
74 + Clone
75 + Unpin
76 + 'static
77{
78}
79
80#[auto_impl::auto_impl(&, Arc)]
82pub trait NetworkInfo: Send + Sync {
83 fn local_addr(&self) -> SocketAddr;
85
86 fn network_status(&self) -> impl Future<Output = Result<NetworkStatus, NetworkError>> + Send;
88
89 fn chain_id(&self) -> u64;
91
92 fn cell_custody(&self) -> &CellCustody;
99
100 fn is_syncing(&self) -> bool;
102
103 fn is_initially_syncing(&self) -> bool;
105}
106
107#[auto_impl::auto_impl(&, Arc)]
109pub trait PeersInfo: Send + Sync {
110 fn num_connected_peers(&self) -> usize;
114
115 fn local_node_record(&self) -> NodeRecord;
117
118 fn local_enr(&self) -> enr::Enr<enr::secp256k1::SecretKey>;
120}
121
122#[auto_impl::auto_impl(&, Arc)]
124pub trait Peers: PeersInfo {
125 fn add_peer(&self, peer: PeerId, tcp_addr: SocketAddr) {
129 self.add_peer_kind(peer, Some(PeerKind::Static), tcp_addr, None);
130 }
131
132 fn add_peer_with_udp(&self, peer: PeerId, tcp_addr: SocketAddr, udp_addr: SocketAddr) {
136 self.add_peer_kind(peer, Some(PeerKind::Static), tcp_addr, Some(udp_addr));
137 }
138
139 fn add_trusted_peer_id(&self, peer: PeerId);
143
144 fn add_trusted_peer(&self, peer: PeerId, tcp_addr: SocketAddr) {
146 self.add_peer_kind(peer, Some(PeerKind::Trusted), tcp_addr, None);
147 }
148
149 fn add_trusted_peer_with_udp(&self, peer: PeerId, tcp_addr: SocketAddr, udp_addr: SocketAddr) {
151 self.add_peer_kind(peer, Some(PeerKind::Trusted), tcp_addr, Some(udp_addr));
152 }
153
154 fn add_trusted_peer_node(&self, _peer: reth_network_peers::TrustedPeer) {}
160
161 fn add_peer_kind(
165 &self,
166 peer: PeerId,
167 kind: Option<PeerKind>,
168 tcp_addr: SocketAddr,
169 udp_addr: Option<SocketAddr>,
170 );
171
172 fn get_trusted_peers(
174 &self,
175 ) -> impl Future<Output = Result<Vec<PeerInfo>, NetworkError>> + Send {
176 self.get_peers_by_kind(PeerKind::Trusted)
177 }
178
179 fn get_basic_peers(&self) -> impl Future<Output = Result<Vec<PeerInfo>, NetworkError>> + Send {
181 self.get_peers_by_kind(PeerKind::Basic)
182 }
183
184 fn get_peers_by_kind(
186 &self,
187 kind: PeerKind,
188 ) -> impl Future<Output = Result<Vec<PeerInfo>, NetworkError>> + Send;
189
190 fn get_all_peers(&self) -> impl Future<Output = Result<Vec<PeerInfo>, NetworkError>> + Send;
192
193 fn get_peer_by_id(
197 &self,
198 peer_id: PeerId,
199 ) -> impl Future<Output = Result<Option<PeerInfo>, NetworkError>> + Send;
200
201 fn get_peers_by_id(
206 &self,
207 peer_ids: Vec<PeerId>,
208 ) -> impl Future<Output = Result<Vec<PeerInfo>, NetworkError>> + Send;
209
210 fn remove_peer(&self, peer: PeerId, kind: PeerKind);
212
213 fn disconnect_peer(&self, peer: PeerId);
215
216 fn disconnect_peer_with_reason(&self, peer: PeerId, reason: DisconnectReason);
218
219 fn connect_peer(&self, peer: PeerId, tcp_addr: SocketAddr) {
222 self.connect_peer_kind(peer, PeerKind::Static, tcp_addr, None)
223 }
224
225 fn connect_peer_kind(
227 &self,
228 peer: PeerId,
229 kind: PeerKind,
230 tcp_addr: SocketAddr,
231 udp_addr: Option<SocketAddr>,
232 );
233
234 fn reputation_change(&self, peer_id: PeerId, kind: ReputationChangeKind);
236
237 fn reputation_by_id(
239 &self,
240 peer_id: PeerId,
241 ) -> impl Future<Output = Result<Option<Reputation>, NetworkError>> + Send;
242}
243
244#[derive(Debug, Clone)]
246pub struct PeerInfo {
247 pub capabilities: Arc<Capabilities>,
249 pub remote_id: PeerId,
251 pub client_version: Arc<str>,
253 pub enode: String,
255 pub enr: Option<String>,
257 pub remote_addr: SocketAddr,
259 pub local_addr: Option<SocketAddr>,
261 pub direction: Direction,
263 pub eth_version: EthVersion,
265 pub status: Arc<UnifiedStatus>,
267 pub session_established: Instant,
269 pub kind: PeerKind,
271}
272
273#[derive(Debug, Copy, Clone, PartialEq, Eq)]
275pub enum Direction {
276 Incoming,
278 Outgoing(PeerId),
280}
281
282impl Direction {
283 pub const fn is_incoming(&self) -> bool {
285 matches!(self, Self::Incoming)
286 }
287
288 pub const fn is_outgoing(&self) -> bool {
290 matches!(self, Self::Outgoing(_))
291 }
292}
293
294impl std::fmt::Display for Direction {
295 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
296 match self {
297 Self::Incoming => write!(f, "incoming"),
298 Self::Outgoing(_) => write!(f, "outgoing"),
299 }
300 }
301}
302
303#[derive(Clone, Debug)]
305#[cfg_attr(feature = "serde", derive(serde::Serialize, serde::Deserialize))]
306pub struct NetworkStatus {
307 pub client_version: String,
309 pub protocol_version: u64,
311 pub eth_protocol_info: EthProtocolInfo,
313 pub capabilities: Vec<Capability>,
315}