mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-05 21:44:42 +01:00
b356dda0ba
Elements requires us to have an explicit fee output instead of bitcoin's implied fee. We add the fee output mostly after sorting the other outputs since that matches the behavior in elements itself. Signed-off-by: Christian Decker <decker.christian@gmail.com>
46 lines
1.2 KiB
C
46 lines
1.2 KiB
C
#include "withdraw_tx.h"
|
|
#include <assert.h>
|
|
#include <bitcoin/pubkey.h>
|
|
#include <bitcoin/script.h>
|
|
#include <ccan/ptrint/ptrint.h>
|
|
#include <common/permute_tx.h>
|
|
#include <common/utils.h>
|
|
#include <common/utxo.h>
|
|
#include <string.h>
|
|
#include <wally_bip32.h>
|
|
|
|
struct bitcoin_tx *withdraw_tx(const tal_t *ctx,
|
|
const struct chainparams *chainparams,
|
|
const struct utxo **utxos,
|
|
struct bitcoin_tx_output **outputs,
|
|
const struct pubkey *changekey,
|
|
struct amount_sat change,
|
|
const struct ext_key *bip32_base,
|
|
int *change_outnum)
|
|
{
|
|
struct bitcoin_tx *tx;
|
|
|
|
tx = tx_spending_utxos(ctx, chainparams, utxos, bip32_base,
|
|
!amount_sat_eq(change, AMOUNT_SAT(0)),
|
|
tal_count(outputs));
|
|
|
|
bitcoin_tx_add_multi_outputs(tx, outputs);
|
|
|
|
if (!amount_sat_eq(change, AMOUNT_SAT(0))) {
|
|
const void *map[2];
|
|
map[0] = int2ptr(0);
|
|
map[1] = int2ptr(1);
|
|
bitcoin_tx_add_output(tx, scriptpubkey_p2wpkh(tmpctx, changekey),
|
|
change);
|
|
permute_outputs(tx, NULL, map);
|
|
if (change_outnum)
|
|
*change_outnum = ptr2int(map[1]);
|
|
} else if (change_outnum)
|
|
*change_outnum = -1;
|
|
permute_inputs(tx, (const void **)utxos);
|
|
bitcoin_tx_add_fee_output(tx);
|
|
assert(bitcoin_tx_check(tx));
|
|
return tx;
|
|
}
|
|
|