2018-12-03 00:02:11 +01:00
|
|
|
#include <bitcoin/script.h>
|
|
|
|
#include <common/key_derive.h>
|
2019-06-05 07:29:08 +02:00
|
|
|
#include <common/utils.h>
|
2017-08-28 18:05:01 +02:00
|
|
|
#include <common/utxo.h>
|
2017-02-21 05:45:29 +01:00
|
|
|
#include <wire/wire.h>
|
|
|
|
|
|
|
|
void towire_utxo(u8 **pptr, const struct utxo *utxo)
|
|
|
|
{
|
2018-01-02 14:54:32 +01:00
|
|
|
/* Is this a unilateral close output and needs the
|
|
|
|
* close_info? */
|
|
|
|
bool is_unilateral_close = utxo->close_info != NULL;
|
2017-12-18 07:41:52 +01:00
|
|
|
towire_bitcoin_txid(pptr, &utxo->txid);
|
2017-02-21 05:45:29 +01:00
|
|
|
towire_u32(pptr, utxo->outnum);
|
2019-02-21 03:39:51 +01:00
|
|
|
towire_amount_sat(pptr, utxo->amount);
|
2017-02-21 05:45:29 +01:00
|
|
|
towire_u32(pptr, utxo->keyindex);
|
|
|
|
towire_bool(pptr, utxo->is_p2sh);
|
2018-01-02 14:54:32 +01:00
|
|
|
|
|
|
|
towire_bool(pptr, is_unilateral_close);
|
|
|
|
if (is_unilateral_close) {
|
|
|
|
towire_u64(pptr, utxo->close_info->channel_id);
|
2019-04-08 11:58:32 +02:00
|
|
|
towire_node_id(pptr, &utxo->close_info->peer_id);
|
2018-01-02 14:54:32 +01:00
|
|
|
towire_pubkey(pptr, &utxo->close_info->commitment_point);
|
|
|
|
}
|
2017-02-21 05:45:29 +01:00
|
|
|
}
|
|
|
|
|
2018-02-08 02:23:46 +01:00
|
|
|
struct utxo *fromwire_utxo(const tal_t *ctx, const u8 **ptr, size_t *max)
|
2017-02-21 05:45:29 +01:00
|
|
|
{
|
2018-02-08 02:23:46 +01:00
|
|
|
struct utxo *utxo = tal(ctx, struct utxo);
|
|
|
|
|
2017-12-18 07:41:52 +01:00
|
|
|
fromwire_bitcoin_txid(ptr, max, &utxo->txid);
|
2017-02-21 05:45:29 +01:00
|
|
|
utxo->outnum = fromwire_u32(ptr, max);
|
2019-02-21 03:39:51 +01:00
|
|
|
utxo->amount = fromwire_amount_sat(ptr, max);
|
2017-02-21 05:45:29 +01:00
|
|
|
utxo->keyindex = fromwire_u32(ptr, max);
|
|
|
|
utxo->is_p2sh = fromwire_bool(ptr, max);
|
2019-02-22 15:47:30 +01:00
|
|
|
|
|
|
|
/* No need to tell hsmd about the scriptPubkey, it has all the info to
|
|
|
|
* derive it from the rest. */
|
|
|
|
utxo->scriptPubkey = NULL;
|
|
|
|
|
2018-01-02 14:54:32 +01:00
|
|
|
if (fromwire_bool(ptr, max)) {
|
2018-02-08 02:23:46 +01:00
|
|
|
utxo->close_info = tal(utxo, struct unilateral_close_info);
|
2018-01-02 14:54:32 +01:00
|
|
|
utxo->close_info->channel_id = fromwire_u64(ptr, max);
|
2019-04-08 11:58:32 +02:00
|
|
|
fromwire_node_id(ptr, max, &utxo->close_info->peer_id);
|
2018-01-02 14:54:32 +01:00
|
|
|
fromwire_pubkey(ptr, max, &utxo->close_info->commitment_point);
|
|
|
|
} else {
|
|
|
|
utxo->close_info = NULL;
|
|
|
|
}
|
2018-02-08 02:23:46 +01:00
|
|
|
return utxo;
|
2017-02-21 05:45:29 +01:00
|
|
|
}
|
2018-12-03 00:02:11 +01:00
|
|
|
|
|
|
|
struct bitcoin_tx *tx_spending_utxos(const tal_t *ctx,
|
|
|
|
const struct utxo **utxos,
|
|
|
|
const struct ext_key *bip32_base,
|
|
|
|
bool add_change_output)
|
|
|
|
{
|
2019-03-14 16:21:45 +01:00
|
|
|
struct pubkey key;
|
|
|
|
u8 *script;
|
|
|
|
size_t outcount = add_change_output ? 2 : 1;
|
|
|
|
struct bitcoin_tx *tx = bitcoin_tx(ctx, tal_count(utxos), outcount);
|
2018-12-03 00:02:11 +01:00
|
|
|
|
|
|
|
for (size_t i = 0; i < tal_count(utxos); i++) {
|
|
|
|
if (utxos[i]->is_p2sh && bip32_base) {
|
|
|
|
bip32_pubkey(bip32_base, &key, utxos[i]->keyindex);
|
2019-06-05 07:29:08 +02:00
|
|
|
script = bitcoin_scriptsig_p2sh_p2wpkh(tmpctx, &key);
|
2019-03-14 16:21:45 +01:00
|
|
|
} else {
|
|
|
|
script = NULL;
|
2018-12-03 00:02:11 +01:00
|
|
|
}
|
2019-03-14 16:21:45 +01:00
|
|
|
|
|
|
|
bitcoin_tx_add_input(tx, &utxos[i]->txid, utxos[i]->outnum,
|
|
|
|
BITCOIN_TX_DEFAULT_SEQUENCE,
|
|
|
|
&utxos[i]->amount, script);
|
2018-12-03 00:02:11 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return tx;
|
|
|
|
}
|