ed25519_dalek

Struct Signature

source
#[repr(C)]
pub struct Signature { /* private fields */ }
Expand description

Ed25519 signature.

This type represents a container for the byte serialization of an Ed25519 signature, and does not necessarily represent well-formed field or curve elements.

Signature verification libraries are expected to reject invalid field elements at the time a signature is verified.

Implementations§

source§

impl Signature

source

pub const BYTE_SIZE: usize = 64usize

Size of an encoded Ed25519 signature in bytes.

source

pub fn from_bytes(bytes: &[u8; 64]) -> Signature

Parse an Ed25519 signature from a byte slice.

source

pub fn from_components(R: [u8; 32], s: [u8; 32]) -> Signature

Parse an Ed25519 signature from its R and s components.

source

pub fn from_slice(bytes: &[u8]) -> Result<Signature, Error>

Parse an Ed25519 signature from a byte slice.

§Returns
  • Ok on success
  • Err if the input byte slice is not 64-bytes
source

pub fn r_bytes(&self) -> &[u8; 32]

Bytes for the R component of a signature.

source

pub fn s_bytes(&self) -> &[u8; 32]

Bytes for the s component of a signature.

source

pub fn to_bytes(&self) -> [u8; 64]

Return the inner byte array.

Trait Implementations§

source§

impl Clone for Signature

source§

fn clone(&self) -> Signature

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Signature

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl<D> DigestSigner<D, Signature> for Context<'_, '_, SigningKey>
where D: Digest<OutputSize = U64>,

Equivalent to SigningKey::sign_prehashed with context set to Some containing self.value().

§Note

The RFC only permits SHA-512 to be used for prehashing. This function technically works, and is probably safe to use, with any secure hash function with 512-bit digests, but anything outside of SHA-512 is NOT specification-compliant. We expose crate::Sha512 for user convenience.

source§

fn try_sign_digest(&self, msg_digest: D) -> Result<Signature, SignatureError>

Attempt to sign the given prehashed message Digest, returning a digital signature on success, or an error if something went wrong.
source§

fn sign_digest(&self, digest: D) -> S

Sign the given prehashed message Digest, returning a signature. Read more
source§

impl<D> DigestSigner<D, Signature> for SigningKey
where D: Digest<OutputSize = U64>,

Equivalent to SigningKey::sign_prehashed with context set to None.

§Note

The RFC only permits SHA-512 to be used for prehashing. This function technically works, and is probably safe to use, with any secure hash function with 512-bit digests, but anything outside of SHA-512 is NOT specification-compliant. We expose crate::Sha512 for user convenience.

source§

fn try_sign_digest(&self, msg_digest: D) -> Result<Signature, SignatureError>

Attempt to sign the given prehashed message Digest, returning a digital signature on success, or an error if something went wrong.
source§

fn sign_digest(&self, digest: D) -> S

Sign the given prehashed message Digest, returning a signature. Read more
source§

impl<MsgDigest> DigestVerifier<MsgDigest, Signature> for Context<'_, '_, VerifyingKey>
where MsgDigest: Digest<OutputSize = U64>,

Equivalent to VerifyingKey::verify_prehashed with context set to Some containing self.value().

source§

fn verify_digest( &self, msg_digest: MsgDigest, signature: &Signature, ) -> Result<(), SignatureError>

Verify the signature against the given Digest output.
source§

impl<MsgDigest> DigestVerifier<MsgDigest, Signature> for VerifyingKey
where MsgDigest: Digest<OutputSize = U64>,

Equivalent to VerifyingKey::verify_prehashed with context set to None.

source§

fn verify_digest( &self, msg_digest: MsgDigest, signature: &Signature, ) -> Result<(), SignatureError>

Verify the signature against the given Digest output.
source§

impl Display for Signature

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl From<&[u8; 64]> for Signature

source§

fn from(bytes: &[u8; 64]) -> Signature

Converts to this type from the input type.
source§

impl From<[u8; 64]> for Signature

source§

fn from(bytes: [u8; 64]) -> Signature

Converts to this type from the input type.
source§

impl FromStr for Signature

Decode a signature from hexadecimal.

Upper and lower case hexadecimal are both accepted, however mixed case is rejected.

source§

type Err = Error

The associated error which can be returned from parsing.
source§

fn from_str(hex: &str) -> Result<Signature, Error>

Parses a string s to return a value of this type. Read more
source§

impl LowerHex for Signature

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl PartialEq for Signature

source§

fn eq(&self, other: &Signature) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl SignatureEncoding for Signature

source§

type Repr = [u8; 64]

Byte representation of a signature.
source§

fn to_bytes(&self) -> [u8; 64]

Encode signature as its byte representation.
source§

fn to_vec(&self) -> Vec<u8>

Encode signature as a byte vector.
source§

fn encoded_len(&self) -> usize

Get the length of this signature when encoded.
source§

impl Signer<Signature> for SigningKey

source§

fn try_sign(&self, message: &[u8]) -> Result<Signature, SignatureError>

Sign a message with this signing key’s secret key.

source§

fn sign(&self, msg: &[u8]) -> S

Sign the given message and return a digital signature
source§

impl TryFrom<&[u8]> for Signature

source§

type Error = Error

The type returned in the event of a conversion error.
source§

fn try_from(bytes: &[u8]) -> Result<Signature, Error>

Performs the conversion.
source§

impl UpperHex for Signature

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result<(), Error>

Formats the value using the given formatter. Read more
source§

impl Verifier<Signature> for SigningKey

source§

fn verify( &self, message: &[u8], signature: &Signature, ) -> Result<(), SignatureError>

Verify a signature on a message with this signing key’s public key.

source§

impl Verifier<Signature> for VerifyingKey

source§

fn verify( &self, message: &[u8], signature: &Signature, ) -> Result<(), SignatureError>

Verify a signature on a message with this keypair’s public key.

§Return

Returns Ok(()) if the signature is valid, and Err otherwise.

source§

impl Copy for Signature

source§

impl Eq for Signature

source§

impl StructuralPartialEq for Signature

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for T
where T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> CloneToUninit for T
where T: Clone,

source§

unsafe fn clone_to_uninit(&self, dst: *mut T)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dst. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for T
where U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same for T

source§

type Output = T

Should always be Self
source§

impl<T> ToOwned for T
where T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T> ToString for T
where T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.