pub enum SimpleSignature {
Ed25519 {
signature: Ed25519Signature,
public_key: Ed25519PublicKey,
},
Secp256k1 {
signature: Secp256k1Signature,
public_key: Secp256k1PublicKey,
},
Secp256r1 {
signature: Secp256r1Signature,
public_key: Secp256r1PublicKey,
},
}Expand description
A basic signature
This enumeration defines the set of simple or basic signature schemes supported by IOTA. Most signature schemes supported by IOTA end up comprising of a at least one simple signature scheme.
§BCS
The BCS serialized form for this type is defined by the following ABNF:
simple-signature-bcs = bytes ; where the contents of the bytes are defined by <simple-signature>
simple-signature = (ed25519-flag ed25519-signature ed25519-public-key) /
(secp256k1-flag secp256k1-signature secp256k1-public-key) /
(secp256r1-flag secp256r1-signature secp256r1-public-key)Note: Due to historical reasons, signatures are serialized slightly
different from the majority of the types in IOTA. In particular if a
signature is ever embedded in another structure it generally is serialized
as bytes meaning it has a length prefix that defines the length of
the completely serialized signature.
Variants§
Implementations§
Source§impl SimpleSignature
impl SimpleSignature
pub fn is_ed25519(&self) -> bool
pub fn is_secp256k1(&self) -> bool
pub fn is_secp256r1(&self) -> bool
pub fn as_ed25519_sig_opt(&self) -> Option<&Ed25519Signature>
pub fn as_ed25519_sig(&self) -> &Ed25519Signature
pub fn as_ed25519_pub_key_opt(&self) -> Option<&Ed25519PublicKey>
pub fn as_ed25519_pub_key(&self) -> &Ed25519PublicKey
pub fn into_ed25519_opt(self) -> Option<(Ed25519Signature, Ed25519PublicKey)>
pub fn into_ed25519(self) -> (Ed25519Signature, Ed25519PublicKey)
pub fn as_secp256k1_sig_opt(&self) -> Option<&Secp256k1Signature>
pub fn as_secp256k1_sig(&self) -> &Secp256k1Signature
pub fn as_secp256k1_pub_key_opt(&self) -> Option<&Secp256k1PublicKey>
pub fn as_secp256k1_pub_key(&self) -> &Secp256k1PublicKey
pub fn into_secp256k1_opt( self, ) -> Option<(Secp256k1Signature, Secp256k1PublicKey)>
pub fn into_secp256k1(self) -> (Secp256k1Signature, Secp256k1PublicKey)
pub fn as_secp256r1_sig_opt(&self) -> Option<&Secp256r1Signature>
pub fn as_secp256r1_sig(&self) -> &Secp256r1Signature
pub fn as_secp256r1_pub_key_opt(&self) -> Option<&Secp256r1PublicKey>
pub fn as_secp256r1_pub_key(&self) -> &Secp256r1PublicKey
pub fn into_secp256r1_opt( self, ) -> Option<(Secp256r1Signature, Secp256r1PublicKey)>
pub fn into_secp256r1(self) -> (Secp256r1Signature, Secp256r1PublicKey)
Sourcepub fn scheme(&self) -> SignatureScheme
pub fn scheme(&self) -> SignatureScheme
Return the flag for this signature scheme
Trait Implementations§
Source§impl Arbitrary for SimpleSignature
impl Arbitrary for SimpleSignature
Source§type Parameters = ()
type Parameters = ()
The type of parameters that
arbitrary_with accepts for configuration
of the generated Strategy. Parameters must implement Default.Source§type Strategy = BoxedStrategy<SimpleSignature>
type Strategy = BoxedStrategy<SimpleSignature>
The type of
Strategy used to generate values of type Self.Source§fn arbitrary_with(args: <Self as Arbitrary>::Parameters) -> Self::Strategy
fn arbitrary_with(args: <Self as Arbitrary>::Parameters) -> Self::Strategy
Source§impl Clone for SimpleSignature
impl Clone for SimpleSignature
Source§fn clone(&self) -> SimpleSignature
fn clone(&self) -> SimpleSignature
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for SimpleSignature
impl Debug for SimpleSignature
Source§impl<'de> Deserialize<'de> for SimpleSignature
Available on crate feature serde only.
impl<'de> Deserialize<'de> for SimpleSignature
Available on crate feature
serde only.Source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
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 Hash for SimpleSignature
impl Hash for SimpleSignature
Source§impl JsonSchema for SimpleSignature
impl JsonSchema for SimpleSignature
Source§fn schema_name() -> String
fn schema_name() -> String
The name of the generated JSON Schema. Read more
Source§fn schema_id() -> Cow<'static, str>
fn schema_id() -> Cow<'static, str>
Returns a string that uniquely identifies the schema produced by this type. Read more
Source§fn json_schema(generator: &mut SchemaGenerator) -> Schema
fn json_schema(generator: &mut SchemaGenerator) -> Schema
Generates a JSON Schema for this type. Read more
Source§fn is_referenceable() -> bool
fn is_referenceable() -> bool
Whether JSON Schemas generated for this type should be re-used where possible using the
$ref keyword. Read moreSource§impl PartialEq for SimpleSignature
impl PartialEq for SimpleSignature
Source§impl Serialize for SimpleSignature
Available on crate feature serde only.
impl Serialize for SimpleSignature
Available on crate feature
serde only.impl Eq for SimpleSignature
impl StructuralPartialEq for SimpleSignature
Auto Trait Implementations§
impl Freeze for SimpleSignature
impl RefUnwindSafe for SimpleSignature
impl Send for SimpleSignature
impl Sync for SimpleSignature
impl Unpin for SimpleSignature
impl UnwindSafe for SimpleSignature
Blanket Implementations§
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
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more