mirror of
https://gitlab.com/pulsechaincom/lighthouse-pulse.git
synced 2025-01-16 00:48:20 +00:00
b23f19272d
* Minor log bumps * Initial building of extended RPC methods * Wire in extended RPC methods * Merge initial peer management template * Add a PeerDB and give the peer manager some basic functions * Initial connection of peer manager * Add peer manager to lighthouse * Connect peer manager with new RPC methods * Correct tests and metadata RPC Co-authored-by: Diva <divma@protonmail.com>
63 lines
2.1 KiB
Rust
63 lines
2.1 KiB
Rust
extern crate slog;
|
|
|
|
pub mod config;
|
|
mod metrics;
|
|
mod notifier;
|
|
|
|
pub mod builder;
|
|
pub mod error;
|
|
|
|
use beacon_chain::BeaconChain;
|
|
use eth2_libp2p::{Enr, Multiaddr, NetworkGlobals};
|
|
use std::net::SocketAddr;
|
|
use std::sync::Arc;
|
|
|
|
pub use beacon_chain::{BeaconChainTypes, Eth1ChainBackend};
|
|
pub use builder::ClientBuilder;
|
|
pub use config::{ClientGenesis, Config as ClientConfig};
|
|
pub use eth2_config::Eth2Config;
|
|
|
|
/// The core "beacon node" client.
|
|
///
|
|
/// Holds references to running services, cleanly shutting them down when dropped.
|
|
pub struct Client<T: BeaconChainTypes> {
|
|
beacon_chain: Option<Arc<BeaconChain<T>>>,
|
|
network_globals: Option<Arc<NetworkGlobals<T::EthSpec>>>,
|
|
http_listen_addr: Option<SocketAddr>,
|
|
websocket_listen_addr: Option<SocketAddr>,
|
|
/// Exit channels will complete/error when dropped, causing each service to exit gracefully.
|
|
_exit_channels: Vec<tokio::sync::oneshot::Sender<()>>,
|
|
}
|
|
|
|
impl<T: BeaconChainTypes> Client<T> {
|
|
/// Returns an `Arc` reference to the client's `BeaconChain`, if it was started.
|
|
pub fn beacon_chain(&self) -> Option<Arc<BeaconChain<T>>> {
|
|
self.beacon_chain.clone()
|
|
}
|
|
|
|
/// Returns the address of the client's HTTP API server, if it was started.
|
|
pub fn http_listen_addr(&self) -> Option<SocketAddr> {
|
|
self.http_listen_addr
|
|
}
|
|
|
|
/// Returns the address of the client's WebSocket API server, if it was started.
|
|
pub fn websocket_listen_addr(&self) -> Option<SocketAddr> {
|
|
self.websocket_listen_addr
|
|
}
|
|
|
|
/// Returns the port of the client's libp2p stack, if it was started.
|
|
pub fn libp2p_listen_port(&self) -> Option<u16> {
|
|
self.network_globals.as_ref().map(|n| n.listen_port_tcp())
|
|
}
|
|
|
|
/// Returns the list of libp2p addresses the client is listening to.
|
|
pub fn libp2p_listen_addresses(&self) -> Option<Vec<Multiaddr>> {
|
|
self.network_globals.as_ref().map(|n| n.listen_multiaddrs())
|
|
}
|
|
|
|
/// Returns the local libp2p ENR of this node, for network discovery.
|
|
pub fn enr(&self) -> Option<Enr> {
|
|
self.network_globals.as_ref().map(|n| n.local_enr())
|
|
}
|
|
}
|