Struct libp2p_core::PeerId [−][src]
pub struct PeerId { /* fields omitted */ }Identifier of a peer of the network.
The data is a multihash of the public key of the peer.
Implementations
impl PeerId[src]
impl PeerId[src]pub fn from_public_key(key: PublicKey) -> PeerId[src]
Builds a PeerId from a public key.
pub fn from_bytes(data: &[u8]) -> Result<PeerId, Error>[src]
Parses a PeerId from bytes.
pub fn from_multihash(multihash: Multihash) -> Result<PeerId, Multihash>[src]
Tries to turn a Multihash into a PeerId.
If the multihash does not use a valid hashing algorithm for peer IDs,
or the hash value does not satisfy the constraints for a hashed
peer ID, it is returned as an Err.
pub fn random() -> PeerId[src]
Generates a random peer ID from a cryptographically secure PRNG.
This is useful for randomly walking on a DHT, or for testing purposes.
pub fn to_bytes(&self) -> Vec<u8>[src]
Returns a raw bytes representation of this PeerId.
pub fn to_base58(&self) -> String[src]
Returns a base-58 encoded string of this PeerId.
pub fn is_public_key(&self, public_key: &PublicKey) -> Option<bool>[src]
Checks whether the public key passed as parameter matches the public key of this PeerId.
Returns None if this PeerIds hash algorithm is not supported when encoding the
given public key, otherwise Some boolean as the result of an equality check.
Trait Implementations
impl AsRef<Multihash<UInt<UInt<UInt<UInt<UInt<UInt<UInt<UTerm, B1>, B0>, B0>, B0>, B0>, B0>, B0>>> for PeerId[src]
impl AsRef<Multihash<UInt<UInt<UInt<UInt<UInt<UInt<UInt<UTerm, B1>, B0>, B0>, B0>, B0>, B0>, B0>>> for PeerId[src]impl PartialOrd<PeerId> for PeerId[src]
impl PartialOrd<PeerId> for PeerId[src]impl TryFrom<Multihash<UInt<UInt<UInt<UInt<UInt<UInt<UInt<UTerm, B1>, B0>, B0>, B0>, B0>, B0>, B0>>> for PeerId[src]
impl TryFrom<Multihash<UInt<UInt<UInt<UInt<UInt<UInt<UInt<UTerm, B1>, B0>, B0>, B0>, B0>, B0>, B0>>> for PeerId[src]