Skip to content

Commit

Permalink
bitcoin/psbt: psbt_finalize needs a tal ctx.
Browse files Browse the repository at this point in the history
Since it returns a wally_tx.

Signed-off-by: Rusty Russell <[email protected]>
  • Loading branch information
rustyrussell committed Sep 23, 2020
1 parent 607075a commit 77b62d9
Show file tree
Hide file tree
Showing 5 changed files with 8 additions and 5 deletions.
4 changes: 3 additions & 1 deletion bitcoin/psbt.c
Original file line number Diff line number Diff line change
Expand Up @@ -524,7 +524,8 @@ static void wally_tx_destroy(struct wally_tx *wtx)
wally_tx_free(wtx);
}

struct wally_tx *psbt_finalize(struct wally_psbt *psbt, bool finalize_in_place)
struct wally_tx *psbt_finalize(const tal_t *ctx,
struct wally_psbt *psbt, bool finalize_in_place)
{
struct wally_psbt *tmppsbt;
struct wally_tx *wtx;
Expand Down Expand Up @@ -585,6 +586,7 @@ struct wally_tx *psbt_finalize(struct wally_psbt *psbt, bool finalize_in_place)

if (psbt_is_finalized(tmppsbt)
&& wally_psbt_extract(tmppsbt, &wtx) == WALLY_OK) {
tal_steal(ctx, wtx);
tal_add_destructor(wtx, wally_tx_destroy);
if (!finalize_in_place)
wally_psbt_free(tmppsbt);
Expand Down
3 changes: 2 additions & 1 deletion bitcoin/psbt.h
Original file line number Diff line number Diff line change
Expand Up @@ -79,7 +79,8 @@ void psbt_txid(const tal_t *ctx,
*/
void psbt_elements_normalize_fees(struct wally_psbt *psbt);

struct wally_tx *psbt_finalize(struct wally_psbt *psbt, bool finalize_in_place);
struct wally_tx *psbt_finalize(const tal_t *ctx,
struct wally_psbt *psbt, bool finalize_in_place);

/* psbt_make_key - Create a new, proprietary c-lightning key
*
Expand Down
2 changes: 1 addition & 1 deletion bitcoin/tx.c
Original file line number Diff line number Diff line change
Expand Up @@ -502,7 +502,7 @@ struct bitcoin_tx *bitcoin_tx_with_psbt(const tal_t *ctx, struct wally_psbt *psb
psbt->tx->num_outputs,
psbt->tx->locktime);
wally_tx_free(tx->wtx);
tx->wtx = psbt_finalize(psbt, false);
tx->wtx = psbt_finalize(tx, psbt, false);
if (!tx->wtx && wally_tx_clone_alloc(psbt->tx, 0, &tx->wtx) != WALLY_OK)
return NULL;

Expand Down
2 changes: 1 addition & 1 deletion lightningd/dual_open_control.c
Original file line number Diff line number Diff line change
Expand Up @@ -590,7 +590,7 @@ openchannel2_sign_hook_cb(struct openchannel2_psbt_payload *payload STEALS)
tal_steal(tmpctx, payload);

/* Finalize it, if not already. It shouldn't work entirely */
psbt_finalize(payload->psbt, true);
psbt_finalize(tmpctx, payload->psbt, true);

if (!psbt_side_finalized(payload->ld->log, payload->psbt, REMOTE))
fatal("Plugin must return a 'psbt' with signatures for their inputs"
Expand Down
2 changes: 1 addition & 1 deletion wallet/walletrpc.c
Original file line number Diff line number Diff line change
Expand Up @@ -812,7 +812,7 @@ static struct command_result *json_sendpsbt(struct command *cmd,

sending = tal(cmd, struct sending_psbt);
sending->cmd = cmd;
sending->wtx = tal_steal(sending, psbt_finalize(psbt, true));
sending->wtx = psbt_finalize(sending, psbt, true);
if (!sending->wtx)
return command_fail(cmd, LIGHTNINGD,
"PSBT not finalizeable %s",
Expand Down

0 comments on commit 77b62d9

Please sign in to comment.