#ifndef LIGHTNING_BITCOIN_TX_H #define LIGHTNING_BITCOIN_TX_H #include "config.h" #include "shadouble.h" #include "signature.h" #include "varint.h" #include #include #include struct bitcoin_txid { struct sha256_double shad; }; /* Define bitcoin_txid_eq */ STRUCTEQ_DEF(bitcoin_txid, 0, shad.sha.u); struct bitcoin_tx { u32 version; struct bitcoin_tx_input *input; struct bitcoin_tx_output *output; u32 lock_time; }; struct bitcoin_tx_output { u64 amount; u8 *script; }; struct bitcoin_tx_input { struct bitcoin_txid txid; u32 index; /* output number referred to by above */ u8 *script; u32 sequence_number; /* Value of the output we're spending (NULL if unknown). */ u64 *amount; /* Only if BIP141 used. */ u8 **witness; }; /* SHA256^2 the tx: simpler than sha256_tx */ void bitcoin_txid(const struct bitcoin_tx *tx, struct bitcoin_txid *txid); /* Useful for signature code. Only supports SIGHASH_ALL and * (for segwit) SIGHASH_SINGLE|SIGHASH_ANYONECANPAY. */ void sha256_tx_for_sig(struct sha256_double *h, const struct bitcoin_tx *tx, unsigned int input_num, const u8 *script, const u8 *witness_script, enum sighash_type sighash_type); /* Linear bytes of tx. */ u8 *linearize_tx(const tal_t *ctx, const struct bitcoin_tx *tx); /* Get weight of tx in Sipa. */ size_t measure_tx_weight(const struct bitcoin_tx *tx); /* Allocate a tx: you just need to fill in inputs and outputs (they're * zeroed with inputs' sequence_number set to FFFFFFFF) */ struct bitcoin_tx *bitcoin_tx(const tal_t *ctx, varint_t input_count, varint_t output_count); /* This takes a raw bitcoin tx in hex. */ struct bitcoin_tx *bitcoin_tx_from_hex(const tal_t *ctx, const char *hex, size_t hexlen); /* Parse hex string to get txid (reversed, a-la bitcoind). */ bool bitcoin_txid_from_hex(const char *hexstr, size_t hexstr_len, struct bitcoin_txid *txid); /* Get hex string of txid (reversed, a-la bitcoind). */ bool bitcoin_txid_to_hex(const struct bitcoin_txid *txid, char *hexstr, size_t hexstr_len); /* Internal de-linearization functions. */ struct bitcoin_tx *pull_bitcoin_tx(const tal_t *ctx, const u8 **cursor, size_t *max); #endif /* LIGHTNING_BITCOIN_TX_H */