Skip to main content

Signature

Struct Signature 

Source
pub struct Signature { /* private fields */ }
Expand description

Ed448 signature.

This type represents a container for the byte serialization of an Ed448 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

Size of an encoded Ed448 signature in bytes (114-bytes).

Source

pub fn from_bytes(bytes: &SignatureBytes) -> Self

Parse an Ed448 signature from a byte slice.

Source

pub fn from_slice(bytes: &[u8]) -> Result<Self>

Parse an Ed448 signature from a byte slice.

§Errors
  • Returns Error if the input byte slice is not 114-bytes.
Source

pub fn r_bytes(&self) -> &ComponentBytes

Bytes for the R component of a signature.

Source

pub fn s_bytes(&self) -> &ComponentBytes

Bytes for the s component of a signature.

Source

pub fn to_bytes(&self) -> SignatureBytes

Return the inner byte array.

Source

pub fn from_components( r: impl Into<ComponentBytes>, s: impl Into<ComponentBytes>, ) -> Self

Create a Signature from the serialized r and s component values which comprise the signature.

Trait Implementations§

Source§

impl AssociatedAlgorithmIdentifier for Signature

Available on crate feature pkcs8 only.
Source§

const ALGORITHM_IDENTIFIER: AlgorithmIdentifierRef<'static> = pkcs8::ALGORITHM_ID

AlgorithmIdentifier for this structure.
Source§

type Params = AnyRef<'static>

Algorithm parameters.
Source§

impl Clone for Signature

Source§

fn clone(&self) -> Signature

Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · 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

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

impl<'de> Deserialize<'de> for Signature

Available on crate feature serde only.
Source§

fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl<'de> Deserialize<'de> for Signature

Available on crate features serde and serde_bytes only.
Source§

fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where D: Deserializer<'de>,

Source§

impl Display for Signature

Source§

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

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

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

Source§

fn from(bytes: &SignatureBytes) -> Self

Converts to this type from the input type.
Source§

impl From<&Signature> for SignatureBytes

Source§

fn from(sig: &Signature) -> SignatureBytes

Converts to this type from the input type.
Source§

impl From<[u8; 114]> for Signature

Source§

fn from(bytes: SignatureBytes) -> Self

Converts to this type from the input type.
Source§

impl From<Signature> for SignatureBytes

Source§

fn from(sig: Signature) -> SignatureBytes

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<Self>

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

impl Hash for Signature

Source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · Source§

fn hash_slice<H>(data: &[Self], state: &mut H)
where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
Source§

impl LowerHex for Signature

Source§

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

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 (const: unstable) · 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 Serialize for Signature

Available on crate feature serde only.
Source§

fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Serialize for Signature

Available on crate features serde and serde_bytes only.
Source§

fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where S: Serializer,

Source§

impl SignatureBitStringEncoding for Signature

Available on crate features alloc and pkcs8 only.
Source§

fn to_bitstring(&self) -> Result<BitString>

BitString encoding for this signature. Read more
Source§

impl SignatureEncoding for Signature

Source§

type Repr = [u8; 114]

Byte representation of a signature.
Source§

fn to_bytes(&self) -> SignatureBytes

Encode signature as its byte representation.
Source§

fn encoded_len(&self) -> usize

Get the length of this signature when encoded.
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<Self>

Performs the conversion.
Source§

impl UpperHex for Signature

Source§

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

Formats the value using the given formatter. Read more
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, dest: *mut u8)

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

impl<T> DynAssociatedAlgorithmIdentifier for T

Source§

fn algorithm_identifier(&self) -> Result<AlgorithmIdentifier<Any>, Error>

AlgorithmIdentifier for this structure. 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> 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§

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.
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,