pub struct SchnorrSigner<'a> { /* private fields */ }
Available on crate feature
schnorr
only.Expand description
Create a signer for Taproot BIP-340 Schnorr signatures.
Implementations§
Source§impl<'a> SchnorrSigner<'a>
impl<'a> SchnorrSigner<'a>
Sourcepub fn new(signing_key: Cow<'a, SigningKey>) -> Self
pub fn new(signing_key: Cow<'a, SigningKey>) -> Self
Create a new signer.
Sourcepub fn from_slice(signing_key: &[u8]) -> Result<SigningKey>
pub fn from_slice(signing_key: &[u8]) -> Result<SigningKey>
Initialize a signing key from a byte slice.
Sourcepub fn random() -> SigningKey
pub fn random() -> SigningKey
Generate a random private signing key.
Sourcepub fn sign_prehash(&self, prehash: &[u8]) -> Result<Signature>
pub fn sign_prehash(&self, prehash: &[u8]) -> Result<Signature>
Attempt to sign the given message digest, returning a digital signature on success, or an error if something went wrong.
Sourcepub fn sign_raw(
&self,
msg_digest: &[u8],
aux_rand: &[u8; 32],
) -> Result<Signature>
pub fn sign_raw( &self, msg_digest: &[u8], aux_rand: &[u8; 32], ) -> Result<Signature>
Compute Schnorr signature.
§⚠️ Warning
This is a low-level interface intended only for unusual use cases involving signing pre-hashed messages.
Sourcepub fn verifying_key(&self) -> &VerifyingKey
pub fn verifying_key(&self) -> &VerifyingKey
Verifying key for this signer.
Sourcepub fn verify(&self, message: &[u8], signature: &Signature) -> Result<()>
pub fn verify(&self, message: &[u8], signature: &Signature) -> Result<()>
Verify a Schnorr signaature.
Sourcepub fn verify_raw(&self, message: &[u8], signature: &Signature) -> Result<()>
pub fn verify_raw(&self, message: &[u8], signature: &Signature) -> Result<()>
Verify a Schnorr signaature.
§⚠️ Warning
This is a low-level interface intended only for unusual use cases involving verifying pre-hashed messages, or “raw” messages where the message is not hashed at all prior to being used to generate the Schnorr signature.
Auto Trait Implementations§
impl<'a> Freeze for SchnorrSigner<'a>
impl<'a> RefUnwindSafe for SchnorrSigner<'a>
impl<'a> Send for SchnorrSigner<'a>
impl<'a> Sync for SchnorrSigner<'a>
impl<'a> Unpin for SchnorrSigner<'a>
impl<'a> UnwindSafe for SchnorrSigner<'a>
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