mirror of
https://github.com/ElementsProject/lightning.git
synced 2024-11-19 09:54:16 +01:00
plugins/txprepare: move functions higher.
Simple moveonly change for next patch. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
This commit is contained in:
parent
3b8c0a7397
commit
8d4557938b
@ -117,6 +117,54 @@ static struct command_result *param_outputs(struct command *cmd,
|
||||
return NULL;
|
||||
}
|
||||
|
||||
/* Called after lightningd has broadcast the transaction. */
|
||||
static struct command_result *sendpsbt_done(struct command *cmd,
|
||||
const char *buf,
|
||||
const jsmntok_t *result,
|
||||
struct unreleased_tx *utx)
|
||||
{
|
||||
struct json_stream *out;
|
||||
|
||||
out = jsonrpc_stream_success(cmd);
|
||||
json_add_hex_talarr(out, "tx", linearize_wtx(tmpctx, utx->tx));
|
||||
json_add_txid(out, "txid", &utx->txid);
|
||||
return command_finished(cmd, out);
|
||||
}
|
||||
|
||||
/* Called after lightningd has signed the inputs. */
|
||||
static struct command_result *signpsbt_done(struct command *cmd,
|
||||
const char *buf,
|
||||
const jsmntok_t *result,
|
||||
struct unreleased_tx *utx)
|
||||
{
|
||||
struct out_req *req;
|
||||
const jsmntok_t *psbttok = json_get_member(buf, result, "signed_psbt");
|
||||
struct bitcoin_txid txid;
|
||||
|
||||
tal_free(utx->psbt);
|
||||
utx->psbt = json_tok_psbt(utx, buf, psbttok);
|
||||
/* Replace with signed tx. */
|
||||
tal_free(utx->tx);
|
||||
|
||||
/* The txid from the final should match our expectation. */
|
||||
psbt_txid(utx->psbt, &txid, &utx->tx);
|
||||
if (!bitcoin_txid_eq(&txid, &utx->txid)) {
|
||||
return command_fail(cmd, LIGHTNINGD,
|
||||
"Signed tx changed txid? Had '%s' now '%s'",
|
||||
tal_hex(tmpctx,
|
||||
linearize_wtx(tmpctx, utx->tx)),
|
||||
tal_hex(tmpctx,
|
||||
linearize_wtx(tmpctx,
|
||||
utx->psbt->tx)));
|
||||
}
|
||||
|
||||
req = jsonrpc_request_start(cmd->plugin, cmd, "sendpsbt",
|
||||
sendpsbt_done, forward_error,
|
||||
utx);
|
||||
json_add_psbt(req->js, "psbt", utx->psbt);
|
||||
return send_outreq(cmd->plugin, req);
|
||||
}
|
||||
|
||||
static struct command_result *finish_txprepare(struct command *cmd,
|
||||
struct txprepare *txp)
|
||||
{
|
||||
@ -360,54 +408,6 @@ static struct command_result *json_txdiscard(struct command *cmd,
|
||||
return send_outreq(cmd->plugin, req);
|
||||
}
|
||||
|
||||
/* Called after lightningd has broadcast the transaction. */
|
||||
static struct command_result *sendpsbt_done(struct command *cmd,
|
||||
const char *buf,
|
||||
const jsmntok_t *result,
|
||||
struct unreleased_tx *utx)
|
||||
{
|
||||
struct json_stream *out;
|
||||
|
||||
out = jsonrpc_stream_success(cmd);
|
||||
json_add_hex_talarr(out, "tx", linearize_wtx(tmpctx, utx->tx));
|
||||
json_add_txid(out, "txid", &utx->txid);
|
||||
return command_finished(cmd, out);
|
||||
}
|
||||
|
||||
/* Called after lightningd has signed the inputs. */
|
||||
static struct command_result *signpsbt_done(struct command *cmd,
|
||||
const char *buf,
|
||||
const jsmntok_t *result,
|
||||
struct unreleased_tx *utx)
|
||||
{
|
||||
struct out_req *req;
|
||||
const jsmntok_t *psbttok = json_get_member(buf, result, "signed_psbt");
|
||||
struct bitcoin_txid txid;
|
||||
|
||||
tal_free(utx->psbt);
|
||||
utx->psbt = json_tok_psbt(utx, buf, psbttok);
|
||||
/* Replace with signed tx. */
|
||||
tal_free(utx->tx);
|
||||
|
||||
/* The txid from the final should match our expectation. */
|
||||
psbt_txid(utx->psbt, &txid, &utx->tx);
|
||||
if (!bitcoin_txid_eq(&txid, &utx->txid)) {
|
||||
return command_fail(cmd, LIGHTNINGD,
|
||||
"Signed tx changed txid? Had '%s' now '%s'",
|
||||
tal_hex(tmpctx,
|
||||
linearize_wtx(tmpctx, utx->tx)),
|
||||
tal_hex(tmpctx,
|
||||
linearize_wtx(tmpctx,
|
||||
utx->psbt->tx)));
|
||||
}
|
||||
|
||||
req = jsonrpc_request_start(cmd->plugin, cmd, "sendpsbt",
|
||||
sendpsbt_done, forward_error,
|
||||
utx);
|
||||
json_add_psbt(req->js, "psbt", utx->psbt);
|
||||
return send_outreq(cmd->plugin, req);
|
||||
}
|
||||
|
||||
static struct command_result *json_txsend(struct command *cmd,
|
||||
const char *buffer,
|
||||
const jsmntok_t *params)
|
||||
|
Loading…
Reference in New Issue
Block a user