Struct bitcoin::util::schnorr::PublicKey[][src]

pub struct PublicKey(_);

A Schnorr public key, used for verification of Schnorr signatures

Implementations

impl PublicKey[src]

pub fn as_ptr(&self) -> *const XOnlyPublicKey[src]

Obtains a raw const pointer suitable for use with FFI functions

pub fn as_mut_ptr(&mut self) -> *mut XOnlyPublicKey[src]

Obtains a raw mutable pointer suitable for use with FFI functions

pub fn from_keypair<C>(secp: &Secp256k1<C>, keypair: &KeyPair) -> PublicKey where
    C: Signing
[src]

Creates a new Schnorr public key from a Schnorr key pair

pub fn from_slice(data: &[u8]) -> Result<PublicKey, Error>[src]

Creates a Schnorr public key directly from a slice

pub fn serialize(&self) -> [u8; 32][src]

Serialize the key as a byte-encoded pair of values. In compressed form the y-coordinate is represented by only a single bit, as x determines it up to one bit.

pub fn tweak_add_assign<V>(
    &mut self,
    secp: &Secp256k1<V>,
    tweak: &[u8]
) -> Result<bool, Error> where
    V: Verification
[src]

Tweak an x-only PublicKey by adding the generator multiplied with the given tweak to it.

Returns a boolean representing the parity of the tweaked key, which can be provided to tweak_add_check which can be used to verify a tweak more efficiently than regenerating it and checking equality. Will return an error if the resulting key would be invalid or if the tweak was not a 32-byte length slice.

pub fn tweak_add_check<V>(
    &self,
    secp: &Secp256k1<V>,
    tweaked_key: &PublicKey,
    tweaked_parity: bool,
    tweak: [u8; 32]
) -> bool where
    V: Verification
[src]

Verify that a tweak produced by tweak_add_assign was computed correctly

Should be called on the original untweaked key. Takes the tweaked key and output parity from tweak_add_assign as input.

Currently this is not much more efficient than just recomputing the tweak and checking equality. However, in future this API will support batch verification, which is significantly faster, so it is wise to design protocols with this in mind.

Trait Implementations

impl CPtr for PublicKey[src]

impl Clone for PublicKey[src]

impl Debug for PublicKey[src]

impl<'de> Deserialize<'de> for PublicKey[src]

impl Display for PublicKey[src]

impl From<PublicKey> for PublicKey[src]

impl From<XOnlyPublicKey> for PublicKey[src]

Creates a new Schnorr public key from a FFI x-only public key

impl FromStr for PublicKey[src]

type Err = Error

The associated error which can be returned from parsing.

impl Hash for PublicKey[src]

impl LowerHex for PublicKey[src]

impl Ord for PublicKey[src]

impl PartialEq<PublicKey> for PublicKey[src]

impl PartialOrd<PublicKey> for PublicKey[src]

impl Serialize for PublicKey[src]

impl Copy for PublicKey[src]

impl Eq for PublicKey[src]

impl StructuralEq for PublicKey[src]

impl StructuralPartialEq for PublicKey[src]

Auto Trait Implementations

impl RefUnwindSafe for PublicKey

impl Send for PublicKey

impl Sync for PublicKey

impl Unpin for PublicKey

impl UnwindSafe for PublicKey

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> ToHex for T where
    T: LowerHex
[src]

pub fn to_hex(&self) -> String[src]

Outputs the hash in hexadecimal form

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T> ToString for T where
    T: Display + ?Sized
[src]

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.

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