1#ifndef SECP256K1_SCHNORRSIG_H 
    2#define SECP256K1_SCHNORRSIG_H 
   42    unsigned char *nonce32,
 
   43    const unsigned char *
msg,
 
   45    const unsigned char *key32,
 
   46    const unsigned char *xonly_pk32,
 
   47    const unsigned char *algo,
 
   88#define SECP256K1_SCHNORRSIG_EXTRAPARAMS_MAGIC { 0xda, 0x6f, 0xb3, 0x8c } 
   89#define SECP256K1_SCHNORRSIG_EXTRAPARAMS_INIT {\ 
   90    SECP256K1_SCHNORRSIG_EXTRAPARAMS_MAGIC,\ 
  121    unsigned char *sig64,
 
  122    const unsigned char *msg32,
 
  124    const unsigned char *aux_rand32
 
  131    unsigned char *sig64,
 
  132    const 
unsigned char *msg32,
 
  134    const 
unsigned char *aux_rand32
 
  161    unsigned char *sig64,
 
  162    const 
unsigned char *
msg,
 
  180    const 
unsigned char *sig64,
 
  181    const 
unsigned char *
msg,
 
#define SECP256K1_ARG_NONNULL(_x)
SECP256K1_API const secp256k1_context *const secp256k1_context_no_precomp SECP256K1_DEPRECATED("Use secp256k1_context_static instead")
Deprecated alias for secp256k1_context_static.
#define SECP256K1_WARN_UNUSED_RESULT
int(* secp256k1_nonce_function_hardened)(unsigned char *nonce32, const unsigned char *msg, size_t msglen, const unsigned char *key32, const unsigned char *xonly_pk32, const unsigned char *algo, size_t algolen, void *data)
This module implements a variant of Schnorr signatures compliant with Bitcoin Improvement Proposal 34...
SECP256K1_API int secp256k1_schnorrsig_sign32(const secp256k1_context *ctx, unsigned char *sig64, const unsigned char *msg32, const secp256k1_keypair *keypair, const unsigned char *aux_rand32) SECP256K1_ARG_NONNULL(1) SECP256K1_ARG_NONNULL(2) SECP256K1_ARG_NONNULL(3) SECP256K1_ARG_NONNULL(4)
Create a Schnorr signature.
struct secp256k1_schnorrsig_extraparams secp256k1_schnorrsig_extraparams
Data structure that contains additional arguments for schnorrsig_sign_custom.
SECP256K1_API int secp256k1_schnorrsig_sign(const secp256k1_context *ctx, unsigned char *sig64, const unsigned char *msg32, const secp256k1_keypair *keypair, const unsigned char *aux_rand32) SECP256K1_ARG_NONNULL(1) SECP256K1_ARG_NONNULL(2) SECP256K1_ARG_NONNULL(3) SECP256K1_ARG_NONNULL(4) SECP256K1_DEPRECATED("Use secp256k1_schnorrsig_sign32 instead")
Same as secp256k1_schnorrsig_sign32, but DEPRECATED.
SECP256K1_API const secp256k1_nonce_function_hardened secp256k1_nonce_function_bip340
An implementation of the nonce generation function as defined in Bitcoin Improvement Proposal 340 "Sc...
SECP256K1_API int secp256k1_schnorrsig_sign_custom(const secp256k1_context *ctx, unsigned char *sig64, const unsigned char *msg, size_t msglen, const secp256k1_keypair *keypair, secp256k1_schnorrsig_extraparams *extraparams) SECP256K1_ARG_NONNULL(1) SECP256K1_ARG_NONNULL(2) SECP256K1_ARG_NONNULL(5)
Create a Schnorr signature with a more flexible API.
SECP256K1_API SECP256K1_WARN_UNUSED_RESULT int secp256k1_schnorrsig_verify(const secp256k1_context *ctx, const unsigned char *sig64, const unsigned char *msg, size_t msglen, const secp256k1_xonly_pubkey *pubkey) SECP256K1_ARG_NONNULL(1) SECP256K1_ARG_NONNULL(2) SECP256K1_ARG_NONNULL(5)
Verify a Schnorr signature.
Opaque data structure that holds a keypair consisting of a secret and a public key.
Opaque data structure that holds a parsed and valid "x-only" public key.