moloch_net/lib.rs
1//! Networking layer for Moloch audit chain.
2//!
3//! This crate provides peer-to-peer communication for the Moloch chain:
4//! - Transport layer with TLS 1.3
5//! - Protocol messages for gossip and sync
6//! - Peer discovery and management
7//! - Chain synchronization protocols
8//!
9//! # Architecture
10//!
11//! The networking layer is organized into four main components:
12//!
13//! 1. **Transport** (`transport.rs`) - TCP connections with TLS, connection pooling
14//! 2. **Protocol** (`protocol.rs`) - Message types and serialization
15//! 3. **Discovery** (`discovery.rs`) - Peer discovery and scoring
16//! 4. **Sync** (`sync.rs`) - Chain synchronization protocols
17//!
18//! # Example
19//!
20//! ```ignore
21//! use moloch_net::{NetworkConfig, NetworkNode};
22//!
23//! // Create node configuration
24//! let config = NetworkConfig::builder()
25//! .listen_addr("0.0.0.0:9000")
26//! .chain_id("moloch-testnet")
27//! .build();
28//!
29//! // Start the network node
30//! let node = NetworkNode::new(config, storage).await?;
31//! node.connect_to_peers(&["peer1:9000", "peer2:9000"]).await?;
32//! ```
33
34pub mod discovery;
35pub mod protocol;
36pub mod sync;
37pub mod transport;
38
39pub use discovery::{PeerDiscovery, PeerInfo, PeerScore, PeerState};
40pub use protocol::{Message, MessageCodec, PeerId, ProtocolVersion};
41pub use sync::{SyncManager, SyncMode, SyncStatus};
42pub use transport::{
43 Connection, ConnectionPool, NetworkConfig, TlsConfig, Transport, TransportError,
44};