Enum schnorrkel::errors::SignatureError [−][src]
Errors which may occur while processing signatures and keypairs.
All these errors represent a failed signature when they occur in the context of verifying a sitgnature, including in deserializaing for verification. We expose the distinction among them primarily for debugging purposes.
This error may arise due to:
-
Being given bytes with a length different to what was expected.
-
A problem decompressing
r
, a curve point, in theSignature
, or the curve point for aPublicKey
. -
A problem with the format of
s
, a scalar, in theSignature
. This is only raised if the high-bit of the scalar was set. (Scalars must only be constructed from 255-bit integers.) -
Multi-signature protocol errors
Variants
A signature verification equation failed.
We emphasise that all variants represent a failed signature, not only this one.
Invalid point provided, usually to verify
methods.
Invalid scalar provided, usually to Signature::from_bytes
.
An error in the length of bytes handed to a constructor.
To use this, pass a string specifying the name
of the type
which is returning the error, and the length
in bytes which
its constructor expects.
Fields of BytesLengthError
Signature not marked as schnorrkel, maybe try ed25519 instead.
There is no record of the preceeding multi-signautre protocol stage for the specified public key.
Fields of MuSigAbsent
musig_stage: MultiSignatureStage
Identifies the multi-signature protocol stage during which the error occured.
For this public key, there are either conflicting records for the preceeding multi-signautre protocol stage or else duplicate duplicate records for the current stage.
Fields of MuSigInconsistent
musig_stage: MultiSignatureStage
Identifies the multi-signature protocol stage during which the error occured.
duplicate: bool
Set true if the stage was reached correctly once but this duplicate disagrees.
Trait Implementations
impl Clone for SignatureError
[src]
fn clone(&self) -> SignatureError
[src]
pub fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl Copy for SignatureError
[src]
impl Debug for SignatureError
[src]
impl Display for SignatureError
[src]
impl Eq for SignatureError
[src]
impl Hash for SignatureError
[src]
fn hash<__H: Hasher>(&self, state: &mut __H)
[src]
pub fn hash_slice<H>(data: &[Self], state: &mut H) where
H: Hasher,
1.3.0[src]
H: Hasher,
impl PartialEq<SignatureError> for SignatureError
[src]
fn eq(&self, other: &SignatureError) -> bool
[src]
fn ne(&self, other: &SignatureError) -> bool
[src]
impl StructuralEq for SignatureError
[src]
impl StructuralPartialEq for SignatureError
[src]
Auto Trait Implementations
impl RefUnwindSafe for SignatureError
impl Send for SignatureError
impl Sync for SignatureError
impl Unpin for SignatureError
impl UnwindSafe for SignatureError
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> From<T> for T
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> Same<T> for T
[src]
type Output = T
Should always be Self
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
pub fn to_owned(&self) -> T
[src]
pub fn clone_into(&self, target: &mut T)
[src]
impl<T> ToString for T where
T: Display + ?Sized,
[src]
T: Display + ?Sized,
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
pub fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
pub fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
[src]
V: MultiLane<T>,