#ifndef LIGHTNING_SIGNATURE_H #define LIGHTNING_SIGNATURE_H #include #include #include #include "lightning.pb-c.h" enum sighash_type { SIGHASH_ALL = 1, SIGHASH_NONE = 2, SIGHASH_SINGLE = 3, SIGHASH_ANYONECANPAY = 0x80 }; /* ECDSA of double SHA256. */ struct signature { u8 r[32]; u8 s[32]; }; struct sha256_double; struct bitcoin_tx; struct pubkey; struct bitcoin_tx_output; struct signature *sign_hash(const tal_t *ctx, EC_KEY *private_key, const struct sha256_double *h); /* All tx input scripts must be set to 0 len. */ struct signature *sign_tx_input(const tal_t *ctx, struct bitcoin_tx *tx, unsigned int in, const u8 *subscript, size_t subscript_len, EC_KEY *privkey); bool check_2of2_sig(struct bitcoin_tx *tx, size_t input_num, const struct bitcoin_tx_output *spending, const struct pubkey *key1, const struct pubkey *key2, const struct signature *sig1, const struct signature *sig2); /* Convert to-from protobuf to internal representation. */ Signature *signature_to_proto(const tal_t *ctx, const struct signature *sig); bool proto_to_signature(const Signature *pb, struct signature *sig); #endif /* LIGHTNING_SIGNATURE_H */