Skip to main content

AnySignature

Struct AnySignature 

Source
pub struct AnySignature {
    pub variant: AnyPublicKeyVariant,
    pub bytes: Vec<u8>,
}
Expand description

A signature that can be any supported signature scheme.

Fields§

§variant: AnyPublicKeyVariant

The signature scheme variant.

§bytes: Vec<u8>

The raw signature bytes.

Implementations§

Source§

impl AnySignature

Source

pub fn new(variant: AnyPublicKeyVariant, bytes: Vec<u8>) -> Self

Creates a new AnySignature.

Source

pub fn ed25519(signature: &Ed25519Signature) -> Self

Available on crate feature ed25519 only.

Creates an Ed25519 signature.

Source

pub fn secp256k1(signature: &Secp256k1Signature) -> Self

Available on crate feature secp256k1 only.

Creates a Secp256k1 signature.

Source

pub fn secp256r1(signature: &Secp256r1Signature) -> Self

Available on crate feature secp256r1 only.

Creates a Secp256r1 signature.

Source

pub fn to_bcs_bytes(&self) -> Vec<u8>

Serializes to BCS AnySignature bytes.

Most variants use variant_byte || ULEB128(len) || payload.

On Aptos, discriminant 2 is shared by bare Secp256r1Ecdsa signatures (64-byte payload) and the WebAuthn variant, which embeds a PartialAuthenticatorAssertionResponse struct without an outer ULEB128 length prefix after the enum tag. When this struct is present, the first payload byte is 0x00 (AssertionSignature::Secp256r1Ecdsa). For that shape we serialize as 0x02 || payload to match the chain and crate::account::WebAuthnAccount.

Source

pub fn from_bcs_bytes(bytes: &[u8]) -> AptosResult<Self>

Parses BCS AnySignature bytes from the wire.

For variants other than Secp256r1 (2), this expects variant || ULEB128(len) || payload.

For discriminant 2, Aptos uses two layouts:

  • Bare ECDSA: 0x02 || ULEB128(64) || 64-byte signature. The length prefix always begins with 0x40 when 64 is encoded as a single ULEB128 byte.
  • WebAuthn: 0x02 || BCS(PartialAuthenticatorAssertionResponse), which begins with 0x00 (AssertionSignature::Secp256r1Ecdsa) — no outer ULEB128 wrapping the struct.
§Errors

Returns AptosError::InvalidSignature if the slice is empty, the variant byte is unknown, the length prefix is malformed, the payload is truncated, or trailing bytes remain after the declared signature bytes.

Trait Implementations§

Source§

impl Clone for AnySignature

Source§

fn clone(&self) -> AnySignature

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 AnySignature

Source§

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

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

impl PartialEq for AnySignature

Source§

fn eq(&self, other: &AnySignature) -> 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 Eq for AnySignature

Source§

impl StructuralPartialEq for AnySignature

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<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
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, 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<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more