[−][src]Struct libp2p_core::PeerId
Identifier of a peer of the network.
The data is a multihash of the public key of the peer.
Methods
impl PeerId[src]
pub fn from_public_key(key: PublicKey) -> PeerId[src]
Builds a PeerId from a public key.
pub fn from_bytes(data: Vec<u8>) -> Result<PeerId, Vec<u8>>[src]
Checks whether data is a valid PeerId. If so, returns the PeerId. If not, returns
back the data as an error.
pub fn from_multihash(data: Multihash) -> Result<PeerId, Multihash>[src]
Turns a Multihash into a PeerId. If the multihash doesn't use the correct algorithm,
returns back the data as an error.
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 into_bytes(self) -> Vec<u8>[src]
Returns a raw bytes representation of this PeerId.
Note that this is not the same as the public key of the peer.
pub fn as_bytes(&self) -> &[u8][src]
Returns a raw bytes representation of this PeerId.
Note that this is not the same as the public key of the peer.
pub fn to_base58(&self) -> String[src]
Returns a base-58 encoded string of this PeerId.
pub fn digest(&self) -> &[u8][src]
Returns the raw bytes of the hash 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 ConnectionInfo for PeerId[src]
impl AsRef<Multihash> for PeerId[src]
impl AsRef<[u8]> for PeerId[src]
impl Clone for PeerId[src]
fn clone(&self) -> PeerId[src]
fn clone_from(&mut self, source: &Self)1.0.0[src]
Performs copy-assignment from source. Read more
impl From<PublicKey> for PeerId[src]
impl Eq for PeerId[src]
impl Into<Multihash> for PeerId[src]
impl PartialEq<PeerId> for PeerId[src]
impl PartialEq<Multihash> for PeerId[src]
fn eq(&self, other: &Multihash) -> bool[src]
#[must_use]
fn ne(&self, other: &Rhs) -> bool1.0.0[src]
This method tests for !=.
impl PartialEq<PeerId> for Multihash[src]
fn eq(&self, other: &PeerId) -> bool[src]
#[must_use]
fn ne(&self, other: &Rhs) -> bool1.0.0[src]
This method tests for !=.
impl Debug for PeerId[src]
impl Display for PeerId[src]
impl FromStr for PeerId[src]
type Err = ParseError
The associated error which can be returned from parsing.
fn from_str(s: &str) -> Result<Self, Self::Err>[src]
impl TryFrom<Vec<u8>> for PeerId[src]
type Error = Vec<u8>
The type returned in the event of a conversion error.
fn try_from(value: Vec<u8>) -> Result<Self, Self::Error>[src]
impl TryFrom<Multihash> for PeerId[src]
type Error = Multihash
The type returned in the event of a conversion error.
fn try_from(value: Multihash) -> Result<Self, Self::Error>[src]
impl Hash for PeerId[src]
Auto Trait Implementations
Blanket Implementations
impl<T> ProtocolName for T where
T: AsRef<[u8]>, [src]
T: AsRef<[u8]>,
impl<T> ToString for T where
T: Display + ?Sized, [src]
T: Display + ?Sized,
impl<T> From<T> for T[src]
impl<T, U> Into<U> for T where
U: From<T>, [src]
U: From<T>,
impl<T> ToOwned for T where
T: Clone, [src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T[src]
fn clone_into(&self, target: &mut T)[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>, [src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>, [src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>[src]
impl<T> BorrowMut<T> for T where
T: ?Sized, [src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T[src]
impl<T> Borrow<T> for T where
T: ?Sized, [src]
T: ?Sized,
impl<T> Any for T where
T: 'static + ?Sized, [src]
T: 'static + ?Sized,
impl<T> Same<T> for T
type Output = T
Should always be Self