Expand description
Transports, upgrades, multiplexing and node handling of libp2p.
The main concepts of libp2p-core are:
- A
PeerIdis a unique global identifier for a node on the network. Each node must have a differentPeerId. Normally, aPeerIdis the hash of the public key used to negotiate encryption on the communication channel, thereby guaranteeing that they cannot be spoofed. - The
Transporttrait defines how to reach a remote node or listen for incoming remote connections. See thetransportmodule. - The [
StreamMuxer] trait is implemented on structs that hold a connection to a remote and can subdivide this connection into multiple substreams. See themuxingmodule. - The [
UpgradeInfo] and [Upgrader] traits define how to upgrade each individual substream to use a protocol. See theupgrademodule.
Re-exports§
pub use identity::PublicKey;pub use transport::Transport;pub use upgrade::ProtocolId;pub use util::ReadEx;pub use util::WriteEx;pub use libp2prs_multiaddr as multiaddr;pub use multihash;
Modules§
- either
- identity
- A node’s network identity keys.
- keys_
proto - multistream
- Multistream-select Protocol Negotiation
- muxing
- Muxing is the process of splitting a connection into multiple substreams.
- peerstore
- routing
- Routing provides the capability of finding a peer with the given peer Id.
- secure_
io - translation
- transport
- Connection-oriented communication channels.
- upgrade
- Contains everything related to upgrading a connection to use a protocol.
- util