pub enum PublicKey {
Ed25519(PublicKey),
Rsa(PublicKey),
Secp256k1(PublicKey),
Ecdsa(PublicKey),
}
Expand description
The public key of a node’s identity keypair.
Variants§
Ed25519(PublicKey)
PublicKey::from
and PublicKey::into_ed25519
instead.A public Ed25519 key.
Rsa(PublicKey)
PublicKey::from
and PublicKey::into_rsa
instead.A public RSA key.
Secp256k1(PublicKey)
PublicKey::from
and PublicKey::into_secp256k1
instead.A public Secp256k1 key.
Ecdsa(PublicKey)
PublicKey::from
and PublicKey::into_ecdsa
instead.A public ECDSA key.
Implementations§
§impl PublicKey
impl PublicKey
pub fn verify(&self, msg: &[u8], sig: &[u8]) -> bool
pub fn verify(&self, msg: &[u8], sig: &[u8]) -> bool
Verify a signature for a message using this public key, i.e. check that the signature has been produced by the corresponding private key (authenticity), and that the message has not been tampered with (integrity).
pub fn into_ed25519(self) -> Option<PublicKey>
PublicKey::try_into_ed25519
instead.pub fn try_into_ed25519(self) -> Result<PublicKey, OtherVariantError>
pub fn into_secp256k1(self) -> Option<PublicKey>
PublicKey::try_into_secp256k1
instead.pub fn try_into_secp256k1(self) -> Result<PublicKey, OtherVariantError>
pub fn into_rsa(self) -> Option<PublicKey>
PublicKey::try_into_rsa
instead.pub fn try_into_rsa(self) -> Result<PublicKey, OtherVariantError>
pub fn into_ecdsa(self) -> Option<PublicKey>
PublicKey::try_into_ecdsa
instead.pub fn try_into_ecdsa(self) -> Result<PublicKey, OtherVariantError>
pub fn to_protobuf_encoding(&self) -> Vec<u8, Global> ⓘ
👎Deprecated: Renamed to PublicKey::encode_protobuf
.
pub fn to_protobuf_encoding(&self) -> Vec<u8, Global> ⓘ
PublicKey::encode_protobuf
.Encode the public key into a protobuf structure for storage or exchange with other nodes.
pub fn encode_protobuf(&self) -> Vec<u8, Global> ⓘ
pub fn encode_protobuf(&self) -> Vec<u8, Global> ⓘ
Encode the public key into a protobuf structure for storage or exchange with other nodes.
pub fn from_protobuf_encoding(bytes: &[u8]) -> Result<PublicKey, DecodingError>
👎Deprecated: This method name does not follow Rust naming conventions, use PublicKey::try_decode_protobuf
instead.
pub fn from_protobuf_encoding(bytes: &[u8]) -> Result<PublicKey, DecodingError>
PublicKey::try_decode_protobuf
instead.Decode a public key from a protobuf structure, e.g. read from storage or received from another node.
pub fn try_decode_protobuf(bytes: &[u8]) -> Result<PublicKey, DecodingError>
pub fn try_decode_protobuf(bytes: &[u8]) -> Result<PublicKey, DecodingError>
Decode a public key from a protobuf structure, e.g. read from storage or received from another node.
pub fn to_peer_id(&self) -> PeerId
pub fn to_peer_id(&self) -> PeerId
Convert the PublicKey
into the corresponding PeerId
.
Trait Implementations§
§impl Ord for PublicKey
impl Ord for PublicKey
§impl PartialOrd<PublicKey> for PublicKey
impl PartialOrd<PublicKey> for PublicKey
§fn partial_cmp(&self, other: &PublicKey) -> Option<Ordering>
fn partial_cmp(&self, other: &PublicKey) -> Option<Ordering>
1.0.0 · source§fn le(&self, other: &Rhs) -> bool
fn le(&self, other: &Rhs) -> bool
self
and other
) and is used by the <=
operator. Read moreimpl Eq for PublicKey
impl StructuralEq for PublicKey
impl StructuralPartialEq for PublicKey
Auto Trait Implementations§
impl RefUnwindSafe for PublicKey
impl Send for PublicKey
impl Sync for PublicKey
impl Unpin for PublicKey
impl UnwindSafe for PublicKey
Blanket Implementations§
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere T: 'a,
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
source§impl<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.