mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-01 03:24:41 +01:00
00a0d09340
This is best-practice (to ensure prototypes match up), but there were a few places we didn't (at least, directly). Make it a requirement, either of form "foo.h" or <dir/foo.h>. The noise is the change to our print templates. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
1335 lines
43 KiB
C
Generated
1335 lines
43 KiB
C
Generated
/* This file was generated by generate-wire.py */
|
|
/* Do not modify this file! Modify the .csv file it was generated from. */
|
|
/* Original template can be found at tools/gen/impl_template */
|
|
|
|
#include <hsmd/hsmd_wiregen.h>
|
|
#include <assert.h>
|
|
#include <ccan/array_size/array_size.h>
|
|
#include <ccan/mem/mem.h>
|
|
#include <ccan/tal/str/str.h>
|
|
#include <common/utils.h>
|
|
#include <stdio.h>
|
|
|
|
#ifndef SUPERVERBOSE
|
|
#define SUPERVERBOSE(...)
|
|
#endif
|
|
|
|
/* Return signature for a funding tx. */
|
|
|
|
const char *hsmd_wire_name(int e)
|
|
{
|
|
static char invalidbuf[sizeof("INVALID ") + STR_MAX_CHARS(e)];
|
|
|
|
switch ((enum hsmd_wire)e) {
|
|
case WIRE_HSMSTATUS_CLIENT_BAD_REQUEST: return "WIRE_HSMSTATUS_CLIENT_BAD_REQUEST";
|
|
case WIRE_HSMD_INIT: return "WIRE_HSMD_INIT";
|
|
case WIRE_HSMD_INIT_REPLY: return "WIRE_HSMD_INIT_REPLY";
|
|
case WIRE_HSMD_CLIENT_HSMFD: return "WIRE_HSMD_CLIENT_HSMFD";
|
|
case WIRE_HSMD_CLIENT_HSMFD_REPLY: return "WIRE_HSMD_CLIENT_HSMFD_REPLY";
|
|
case WIRE_HSMD_GET_CHANNEL_BASEPOINTS: return "WIRE_HSMD_GET_CHANNEL_BASEPOINTS";
|
|
case WIRE_HSMD_GET_CHANNEL_BASEPOINTS_REPLY: return "WIRE_HSMD_GET_CHANNEL_BASEPOINTS_REPLY";
|
|
case WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REQ: return "WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REQ";
|
|
case WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REPLY: return "WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REPLY";
|
|
case WIRE_HSMD_SIGN_WITHDRAWAL: return "WIRE_HSMD_SIGN_WITHDRAWAL";
|
|
case WIRE_HSMD_SIGN_WITHDRAWAL_REPLY: return "WIRE_HSMD_SIGN_WITHDRAWAL_REPLY";
|
|
case WIRE_HSMD_SIGN_INVOICE: return "WIRE_HSMD_SIGN_INVOICE";
|
|
case WIRE_HSMD_SIGN_INVOICE_REPLY: return "WIRE_HSMD_SIGN_INVOICE_REPLY";
|
|
case WIRE_HSMD_ECDH_REQ: return "WIRE_HSMD_ECDH_REQ";
|
|
case WIRE_HSMD_ECDH_RESP: return "WIRE_HSMD_ECDH_RESP";
|
|
case WIRE_HSMD_CANNOUNCEMENT_SIG_REQ: return "WIRE_HSMD_CANNOUNCEMENT_SIG_REQ";
|
|
case WIRE_HSMD_CANNOUNCEMENT_SIG_REPLY: return "WIRE_HSMD_CANNOUNCEMENT_SIG_REPLY";
|
|
case WIRE_HSMD_CUPDATE_SIG_REQ: return "WIRE_HSMD_CUPDATE_SIG_REQ";
|
|
case WIRE_HSMD_CUPDATE_SIG_REPLY: return "WIRE_HSMD_CUPDATE_SIG_REPLY";
|
|
case WIRE_HSMD_SIGN_COMMITMENT_TX: return "WIRE_HSMD_SIGN_COMMITMENT_TX";
|
|
case WIRE_HSMD_SIGN_COMMITMENT_TX_REPLY: return "WIRE_HSMD_SIGN_COMMITMENT_TX_REPLY";
|
|
case WIRE_HSMD_SIGN_DELAYED_PAYMENT_TO_US: return "WIRE_HSMD_SIGN_DELAYED_PAYMENT_TO_US";
|
|
case WIRE_HSMD_SIGN_REMOTE_HTLC_TO_US: return "WIRE_HSMD_SIGN_REMOTE_HTLC_TO_US";
|
|
case WIRE_HSMD_SIGN_PENALTY_TO_US: return "WIRE_HSMD_SIGN_PENALTY_TO_US";
|
|
case WIRE_HSMD_SIGN_LOCAL_HTLC_TX: return "WIRE_HSMD_SIGN_LOCAL_HTLC_TX";
|
|
case WIRE_HSMD_SIGN_REMOTE_COMMITMENT_TX: return "WIRE_HSMD_SIGN_REMOTE_COMMITMENT_TX";
|
|
case WIRE_HSMD_SIGN_REMOTE_HTLC_TX: return "WIRE_HSMD_SIGN_REMOTE_HTLC_TX";
|
|
case WIRE_HSMD_SIGN_MUTUAL_CLOSE_TX: return "WIRE_HSMD_SIGN_MUTUAL_CLOSE_TX";
|
|
case WIRE_HSMD_SIGN_TX_REPLY: return "WIRE_HSMD_SIGN_TX_REPLY";
|
|
case WIRE_HSMD_GET_PER_COMMITMENT_POINT: return "WIRE_HSMD_GET_PER_COMMITMENT_POINT";
|
|
case WIRE_HSMD_GET_PER_COMMITMENT_POINT_REPLY: return "WIRE_HSMD_GET_PER_COMMITMENT_POINT_REPLY";
|
|
case WIRE_HSMD_DEV_MEMLEAK: return "WIRE_HSMD_DEV_MEMLEAK";
|
|
case WIRE_HSMD_DEV_MEMLEAK_REPLY: return "WIRE_HSMD_DEV_MEMLEAK_REPLY";
|
|
case WIRE_HSMD_CHECK_FUTURE_SECRET: return "WIRE_HSMD_CHECK_FUTURE_SECRET";
|
|
case WIRE_HSMD_CHECK_FUTURE_SECRET_REPLY: return "WIRE_HSMD_CHECK_FUTURE_SECRET_REPLY";
|
|
case WIRE_HSMD_SIGN_MESSAGE: return "WIRE_HSMD_SIGN_MESSAGE";
|
|
case WIRE_HSMD_SIGN_MESSAGE_REPLY: return "WIRE_HSMD_SIGN_MESSAGE_REPLY";
|
|
case WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY: return "WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY";
|
|
case WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY_REPLY: return "WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY_REPLY";
|
|
case WIRE_HSMD_SIGN_BOLT12: return "WIRE_HSMD_SIGN_BOLT12";
|
|
case WIRE_HSMD_SIGN_BOLT12_REPLY: return "WIRE_HSMD_SIGN_BOLT12_REPLY";
|
|
case WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER: return "WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER";
|
|
case WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER_REPLY: return "WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER_REPLY";
|
|
}
|
|
|
|
snprintf(invalidbuf, sizeof(invalidbuf), "INVALID %i", e);
|
|
return invalidbuf;
|
|
}
|
|
|
|
bool hsmd_wire_is_defined(u16 type)
|
|
{
|
|
switch ((enum hsmd_wire)type) {
|
|
case WIRE_HSMSTATUS_CLIENT_BAD_REQUEST:;
|
|
case WIRE_HSMD_INIT:;
|
|
case WIRE_HSMD_INIT_REPLY:;
|
|
case WIRE_HSMD_CLIENT_HSMFD:;
|
|
case WIRE_HSMD_CLIENT_HSMFD_REPLY:;
|
|
case WIRE_HSMD_GET_CHANNEL_BASEPOINTS:;
|
|
case WIRE_HSMD_GET_CHANNEL_BASEPOINTS_REPLY:;
|
|
case WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REQ:;
|
|
case WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REPLY:;
|
|
case WIRE_HSMD_SIGN_WITHDRAWAL:;
|
|
case WIRE_HSMD_SIGN_WITHDRAWAL_REPLY:;
|
|
case WIRE_HSMD_SIGN_INVOICE:;
|
|
case WIRE_HSMD_SIGN_INVOICE_REPLY:;
|
|
case WIRE_HSMD_ECDH_REQ:;
|
|
case WIRE_HSMD_ECDH_RESP:;
|
|
case WIRE_HSMD_CANNOUNCEMENT_SIG_REQ:;
|
|
case WIRE_HSMD_CANNOUNCEMENT_SIG_REPLY:;
|
|
case WIRE_HSMD_CUPDATE_SIG_REQ:;
|
|
case WIRE_HSMD_CUPDATE_SIG_REPLY:;
|
|
case WIRE_HSMD_SIGN_COMMITMENT_TX:;
|
|
case WIRE_HSMD_SIGN_COMMITMENT_TX_REPLY:;
|
|
case WIRE_HSMD_SIGN_DELAYED_PAYMENT_TO_US:;
|
|
case WIRE_HSMD_SIGN_REMOTE_HTLC_TO_US:;
|
|
case WIRE_HSMD_SIGN_PENALTY_TO_US:;
|
|
case WIRE_HSMD_SIGN_LOCAL_HTLC_TX:;
|
|
case WIRE_HSMD_SIGN_REMOTE_COMMITMENT_TX:;
|
|
case WIRE_HSMD_SIGN_REMOTE_HTLC_TX:;
|
|
case WIRE_HSMD_SIGN_MUTUAL_CLOSE_TX:;
|
|
case WIRE_HSMD_SIGN_TX_REPLY:;
|
|
case WIRE_HSMD_GET_PER_COMMITMENT_POINT:;
|
|
case WIRE_HSMD_GET_PER_COMMITMENT_POINT_REPLY:;
|
|
case WIRE_HSMD_DEV_MEMLEAK:;
|
|
case WIRE_HSMD_DEV_MEMLEAK_REPLY:;
|
|
case WIRE_HSMD_CHECK_FUTURE_SECRET:;
|
|
case WIRE_HSMD_CHECK_FUTURE_SECRET_REPLY:;
|
|
case WIRE_HSMD_SIGN_MESSAGE:;
|
|
case WIRE_HSMD_SIGN_MESSAGE_REPLY:;
|
|
case WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY:;
|
|
case WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY_REPLY:;
|
|
case WIRE_HSMD_SIGN_BOLT12:;
|
|
case WIRE_HSMD_SIGN_BOLT12_REPLY:;
|
|
case WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER:;
|
|
case WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER_REPLY:;
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/* WIRE: HSMSTATUS_CLIENT_BAD_REQUEST */
|
|
/* Clients should not give a bad request but not the HSM's decision to crash. */
|
|
u8 *towire_hsmstatus_client_bad_request(const tal_t *ctx, const struct node_id *id, const wirestring *description, const u8 *msg)
|
|
{
|
|
u16 len = tal_count(msg);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMSTATUS_CLIENT_BAD_REQUEST);
|
|
towire_node_id(&p, id);
|
|
towire_wirestring(&p, description);
|
|
towire_u16(&p, len);
|
|
towire_u8_array(&p, msg, len);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmstatus_client_bad_request(const tal_t *ctx, const void *p, struct node_id *id, wirestring **description, u8 **msg)
|
|
{
|
|
u16 len;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMSTATUS_CLIENT_BAD_REQUEST)
|
|
return false;
|
|
fromwire_node_id(&cursor, &plen, id);
|
|
*description = fromwire_wirestring(ctx, &cursor, &plen);
|
|
len = fromwire_u16(&cursor, &plen);
|
|
// 2nd case msg
|
|
*msg = len ? tal_arr(ctx, u8, len) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *msg, len);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_INIT */
|
|
/* Start the HSM. */
|
|
u8 *towire_hsmd_init(const tal_t *ctx, const struct bip32_key_version *bip32_key_version, const struct chainparams *chainparams, const struct secret *hsm_encryption_key, const struct privkey *dev_force_privkey, const struct secret *dev_force_bip32_seed, const struct secrets *dev_force_channel_secrets, const struct sha256 *dev_force_channel_secrets_shaseed)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_INIT);
|
|
towire_bip32_key_version(&p, bip32_key_version);
|
|
towire_chainparams(&p, chainparams);
|
|
if (!hsm_encryption_key)
|
|
towire_bool(&p, false);
|
|
else {
|
|
towire_bool(&p, true);
|
|
towire_secret(&p, hsm_encryption_key);
|
|
}
|
|
if (!dev_force_privkey)
|
|
towire_bool(&p, false);
|
|
else {
|
|
towire_bool(&p, true);
|
|
towire_privkey(&p, dev_force_privkey);
|
|
}
|
|
if (!dev_force_bip32_seed)
|
|
towire_bool(&p, false);
|
|
else {
|
|
towire_bool(&p, true);
|
|
towire_secret(&p, dev_force_bip32_seed);
|
|
}
|
|
if (!dev_force_channel_secrets)
|
|
towire_bool(&p, false);
|
|
else {
|
|
towire_bool(&p, true);
|
|
towire_secrets(&p, dev_force_channel_secrets);
|
|
}
|
|
if (!dev_force_channel_secrets_shaseed)
|
|
towire_bool(&p, false);
|
|
else {
|
|
towire_bool(&p, true);
|
|
towire_sha256(&p, dev_force_channel_secrets_shaseed);
|
|
}
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_init(const tal_t *ctx, const void *p, struct bip32_key_version *bip32_key_version, const struct chainparams **chainparams, struct secret **hsm_encryption_key, struct privkey **dev_force_privkey, struct secret **dev_force_bip32_seed, struct secrets **dev_force_channel_secrets, struct sha256 **dev_force_channel_secrets_shaseed)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_INIT)
|
|
return false;
|
|
fromwire_bip32_key_version(&cursor, &plen, bip32_key_version);
|
|
fromwire_chainparams(&cursor, &plen, chainparams);
|
|
if (!fromwire_bool(&cursor, &plen))
|
|
*hsm_encryption_key = NULL;
|
|
else {
|
|
*hsm_encryption_key = tal(ctx, struct secret);
|
|
fromwire_secret(&cursor, &plen, *hsm_encryption_key);
|
|
}
|
|
if (!fromwire_bool(&cursor, &plen))
|
|
*dev_force_privkey = NULL;
|
|
else {
|
|
*dev_force_privkey = tal(ctx, struct privkey);
|
|
fromwire_privkey(&cursor, &plen, *dev_force_privkey);
|
|
}
|
|
if (!fromwire_bool(&cursor, &plen))
|
|
*dev_force_bip32_seed = NULL;
|
|
else {
|
|
*dev_force_bip32_seed = tal(ctx, struct secret);
|
|
fromwire_secret(&cursor, &plen, *dev_force_bip32_seed);
|
|
}
|
|
if (!fromwire_bool(&cursor, &plen))
|
|
*dev_force_channel_secrets = NULL;
|
|
else {
|
|
*dev_force_channel_secrets = tal(ctx, struct secrets);
|
|
fromwire_secrets(&cursor, &plen, *dev_force_channel_secrets);
|
|
}
|
|
if (!fromwire_bool(&cursor, &plen))
|
|
*dev_force_channel_secrets_shaseed = NULL;
|
|
else {
|
|
*dev_force_channel_secrets_shaseed = tal(ctx, struct sha256);
|
|
fromwire_sha256(&cursor, &plen, *dev_force_channel_secrets_shaseed);
|
|
}
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_INIT_REPLY */
|
|
u8 *towire_hsmd_init_reply(const tal_t *ctx, const struct node_id *node_id, const struct ext_key *bip32, const struct pubkey32 *bolt12)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_INIT_REPLY);
|
|
towire_node_id(&p, node_id);
|
|
towire_ext_key(&p, bip32);
|
|
towire_pubkey32(&p, bolt12);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_init_reply(const void *p, struct node_id *node_id, struct ext_key *bip32, struct pubkey32 *bolt12)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_INIT_REPLY)
|
|
return false;
|
|
fromwire_node_id(&cursor, &plen, node_id);
|
|
fromwire_ext_key(&cursor, &plen, bip32);
|
|
fromwire_pubkey32(&cursor, &plen, bolt12);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_CLIENT_HSMFD */
|
|
/* Get a new HSM FD */
|
|
u8 *towire_hsmd_client_hsmfd(const tal_t *ctx, const struct node_id *id, u64 dbid, u64 capabilities)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_CLIENT_HSMFD);
|
|
/* Which identity to use for requests */
|
|
towire_node_id(&p, id);
|
|
/* Database id for this client */
|
|
towire_u64(&p, dbid);
|
|
towire_u64(&p, capabilities);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_client_hsmfd(const void *p, struct node_id *id, u64 *dbid, u64 *capabilities)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_CLIENT_HSMFD)
|
|
return false;
|
|
/* Which identity to use for requests */
|
|
fromwire_node_id(&cursor, &plen, id);
|
|
/* Database id for this client */
|
|
*dbid = fromwire_u64(&cursor, &plen);
|
|
*capabilities = fromwire_u64(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_CLIENT_HSMFD_REPLY */
|
|
/* No content */
|
|
u8 *towire_hsmd_client_hsmfd_reply(const tal_t *ctx)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_CLIENT_HSMFD_REPLY);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_client_hsmfd_reply(const void *p)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_CLIENT_HSMFD_REPLY)
|
|
return false;
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_GET_CHANNEL_BASEPOINTS */
|
|
/* Get the basepoints and funding key for this specific channel. */
|
|
u8 *towire_hsmd_get_channel_basepoints(const tal_t *ctx, const struct node_id *peerid, u64 dbid)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_GET_CHANNEL_BASEPOINTS);
|
|
towire_node_id(&p, peerid);
|
|
towire_u64(&p, dbid);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_get_channel_basepoints(const void *p, struct node_id *peerid, u64 *dbid)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_GET_CHANNEL_BASEPOINTS)
|
|
return false;
|
|
fromwire_node_id(&cursor, &plen, peerid);
|
|
*dbid = fromwire_u64(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_GET_CHANNEL_BASEPOINTS_REPLY */
|
|
u8 *towire_hsmd_get_channel_basepoints_reply(const tal_t *ctx, const struct basepoints *basepoints, const struct pubkey *funding_pubkey)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_GET_CHANNEL_BASEPOINTS_REPLY);
|
|
towire_basepoints(&p, basepoints);
|
|
towire_pubkey(&p, funding_pubkey);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_get_channel_basepoints_reply(const void *p, struct basepoints *basepoints, struct pubkey *funding_pubkey)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_GET_CHANNEL_BASEPOINTS_REPLY)
|
|
return false;
|
|
fromwire_basepoints(&cursor, &plen, basepoints);
|
|
fromwire_pubkey(&cursor, &plen, funding_pubkey);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_NODE_ANNOUNCEMENT_SIG_REQ */
|
|
/* Master asks the HSM to sign a node_announcement */
|
|
u8 *towire_hsmd_node_announcement_sig_req(const tal_t *ctx, const u8 *announcement)
|
|
{
|
|
u16 annlen = tal_count(announcement);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REQ);
|
|
towire_u16(&p, annlen);
|
|
towire_u8_array(&p, announcement, annlen);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_node_announcement_sig_req(const tal_t *ctx, const void *p, u8 **announcement)
|
|
{
|
|
u16 annlen;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REQ)
|
|
return false;
|
|
annlen = fromwire_u16(&cursor, &plen);
|
|
// 2nd case announcement
|
|
*announcement = annlen ? tal_arr(ctx, u8, annlen) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *announcement, annlen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_NODE_ANNOUNCEMENT_SIG_REPLY */
|
|
u8 *towire_hsmd_node_announcement_sig_reply(const tal_t *ctx, const secp256k1_ecdsa_signature *signature)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REPLY);
|
|
towire_secp256k1_ecdsa_signature(&p, signature);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_node_announcement_sig_reply(const void *p, secp256k1_ecdsa_signature *signature)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_NODE_ANNOUNCEMENT_SIG_REPLY)
|
|
return false;
|
|
fromwire_secp256k1_ecdsa_signature(&cursor, &plen, signature);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_WITHDRAWAL */
|
|
/* Sign a withdrawal request */
|
|
u8 *towire_hsmd_sign_withdrawal(const tal_t *ctx, const struct utxo **inputs, const struct wally_psbt *psbt)
|
|
{
|
|
u16 num_inputs = tal_count(inputs);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_WITHDRAWAL);
|
|
towire_u16(&p, num_inputs);
|
|
for (size_t i = 0; i < num_inputs; i++)
|
|
towire_utxo(&p, inputs[i]);
|
|
towire_wally_psbt(&p, psbt);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_withdrawal(const tal_t *ctx, const void *p, struct utxo ***inputs, struct wally_psbt **psbt)
|
|
{
|
|
u16 num_inputs;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_WITHDRAWAL)
|
|
return false;
|
|
num_inputs = fromwire_u16(&cursor, &plen);
|
|
// 2nd case inputs
|
|
*inputs = num_inputs ? tal_arr(ctx, struct utxo *, num_inputs) : NULL;
|
|
for (size_t i = 0; i < num_inputs; i++)
|
|
(*inputs)[i] = fromwire_utxo(*inputs, &cursor, &plen);
|
|
*psbt = fromwire_wally_psbt(ctx, &cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_WITHDRAWAL_REPLY */
|
|
u8 *towire_hsmd_sign_withdrawal_reply(const tal_t *ctx, const struct wally_psbt *psbt)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_WITHDRAWAL_REPLY);
|
|
towire_wally_psbt(&p, psbt);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_withdrawal_reply(const tal_t *ctx, const void *p, struct wally_psbt **psbt)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_WITHDRAWAL_REPLY)
|
|
return false;
|
|
*psbt = fromwire_wally_psbt(ctx, &cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_INVOICE */
|
|
/* Sign an invoice */
|
|
u8 *towire_hsmd_sign_invoice(const tal_t *ctx, const u8 *u5bytes, const u8 *hrp)
|
|
{
|
|
u16 len = tal_count(u5bytes);
|
|
u16 hrplen = tal_count(hrp);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_INVOICE);
|
|
towire_u16(&p, len);
|
|
towire_u8_array(&p, u5bytes, len);
|
|
towire_u16(&p, hrplen);
|
|
towire_u8_array(&p, hrp, hrplen);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_invoice(const tal_t *ctx, const void *p, u8 **u5bytes, u8 **hrp)
|
|
{
|
|
u16 len;
|
|
u16 hrplen;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_INVOICE)
|
|
return false;
|
|
len = fromwire_u16(&cursor, &plen);
|
|
// 2nd case u5bytes
|
|
*u5bytes = len ? tal_arr(ctx, u8, len) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *u5bytes, len);
|
|
hrplen = fromwire_u16(&cursor, &plen);
|
|
// 2nd case hrp
|
|
*hrp = hrplen ? tal_arr(ctx, u8, hrplen) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *hrp, hrplen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_INVOICE_REPLY */
|
|
u8 *towire_hsmd_sign_invoice_reply(const tal_t *ctx, const secp256k1_ecdsa_recoverable_signature *sig)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_INVOICE_REPLY);
|
|
towire_secp256k1_ecdsa_recoverable_signature(&p, sig);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_invoice_reply(const void *p, secp256k1_ecdsa_recoverable_signature *sig)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_INVOICE_REPLY)
|
|
return false;
|
|
fromwire_secp256k1_ecdsa_recoverable_signature(&cursor, &plen, sig);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_ECDH_REQ */
|
|
/* Give me ECDH(node-id-secret */
|
|
u8 *towire_hsmd_ecdh_req(const tal_t *ctx, const struct pubkey *point)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_ECDH_REQ);
|
|
towire_pubkey(&p, point);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_ecdh_req(const void *p, struct pubkey *point)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_ECDH_REQ)
|
|
return false;
|
|
fromwire_pubkey(&cursor, &plen, point);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_ECDH_RESP */
|
|
u8 *towire_hsmd_ecdh_resp(const tal_t *ctx, const struct secret *ss)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_ECDH_RESP);
|
|
towire_secret(&p, ss);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_ecdh_resp(const void *p, struct secret *ss)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_ECDH_RESP)
|
|
return false;
|
|
fromwire_secret(&cursor, &plen, ss);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_CANNOUNCEMENT_SIG_REQ */
|
|
u8 *towire_hsmd_cannouncement_sig_req(const tal_t *ctx, const u8 *ca)
|
|
{
|
|
u16 calen = tal_count(ca);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_CANNOUNCEMENT_SIG_REQ);
|
|
towire_u16(&p, calen);
|
|
towire_u8_array(&p, ca, calen);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_cannouncement_sig_req(const tal_t *ctx, const void *p, u8 **ca)
|
|
{
|
|
u16 calen;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_CANNOUNCEMENT_SIG_REQ)
|
|
return false;
|
|
calen = fromwire_u16(&cursor, &plen);
|
|
// 2nd case ca
|
|
*ca = calen ? tal_arr(ctx, u8, calen) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *ca, calen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_CANNOUNCEMENT_SIG_REPLY */
|
|
u8 *towire_hsmd_cannouncement_sig_reply(const tal_t *ctx, const secp256k1_ecdsa_signature *node_signature, const secp256k1_ecdsa_signature *bitcoin_signature)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_CANNOUNCEMENT_SIG_REPLY);
|
|
towire_secp256k1_ecdsa_signature(&p, node_signature);
|
|
towire_secp256k1_ecdsa_signature(&p, bitcoin_signature);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_cannouncement_sig_reply(const void *p, secp256k1_ecdsa_signature *node_signature, secp256k1_ecdsa_signature *bitcoin_signature)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_CANNOUNCEMENT_SIG_REPLY)
|
|
return false;
|
|
fromwire_secp256k1_ecdsa_signature(&cursor, &plen, node_signature);
|
|
fromwire_secp256k1_ecdsa_signature(&cursor, &plen, bitcoin_signature);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_CUPDATE_SIG_REQ */
|
|
u8 *towire_hsmd_cupdate_sig_req(const tal_t *ctx, const u8 *cu)
|
|
{
|
|
u16 culen = tal_count(cu);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_CUPDATE_SIG_REQ);
|
|
towire_u16(&p, culen);
|
|
towire_u8_array(&p, cu, culen);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_cupdate_sig_req(const tal_t *ctx, const void *p, u8 **cu)
|
|
{
|
|
u16 culen;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_CUPDATE_SIG_REQ)
|
|
return false;
|
|
culen = fromwire_u16(&cursor, &plen);
|
|
// 2nd case cu
|
|
*cu = culen ? tal_arr(ctx, u8, culen) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *cu, culen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_CUPDATE_SIG_REPLY */
|
|
u8 *towire_hsmd_cupdate_sig_reply(const tal_t *ctx, const u8 *cu)
|
|
{
|
|
u16 culen = tal_count(cu);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_CUPDATE_SIG_REPLY);
|
|
towire_u16(&p, culen);
|
|
towire_u8_array(&p, cu, culen);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_cupdate_sig_reply(const tal_t *ctx, const void *p, u8 **cu)
|
|
{
|
|
u16 culen;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_CUPDATE_SIG_REPLY)
|
|
return false;
|
|
culen = fromwire_u16(&cursor, &plen);
|
|
// 2nd case cu
|
|
*cu = culen ? tal_arr(ctx, u8, culen) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *cu, culen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_COMMITMENT_TX */
|
|
/* Master asks HSM to sign a commitment transaction. */
|
|
u8 *towire_hsmd_sign_commitment_tx(const tal_t *ctx, const struct node_id *peer_id, u64 channel_dbid, const struct bitcoin_tx *tx, const struct pubkey *remote_funding_key)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_COMMITMENT_TX);
|
|
towire_node_id(&p, peer_id);
|
|
towire_u64(&p, channel_dbid);
|
|
towire_bitcoin_tx(&p, tx);
|
|
towire_pubkey(&p, remote_funding_key);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_commitment_tx(const tal_t *ctx, const void *p, struct node_id *peer_id, u64 *channel_dbid, struct bitcoin_tx **tx, struct pubkey *remote_funding_key)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_COMMITMENT_TX)
|
|
return false;
|
|
fromwire_node_id(&cursor, &plen, peer_id);
|
|
*channel_dbid = fromwire_u64(&cursor, &plen);
|
|
*tx = fromwire_bitcoin_tx(ctx, &cursor, &plen);
|
|
fromwire_pubkey(&cursor, &plen, remote_funding_key);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_COMMITMENT_TX_REPLY */
|
|
u8 *towire_hsmd_sign_commitment_tx_reply(const tal_t *ctx, const struct bitcoin_signature *sig)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_COMMITMENT_TX_REPLY);
|
|
towire_bitcoin_signature(&p, sig);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_commitment_tx_reply(const void *p, struct bitcoin_signature *sig)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_COMMITMENT_TX_REPLY)
|
|
return false;
|
|
fromwire_bitcoin_signature(&cursor, &plen, sig);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_DELAYED_PAYMENT_TO_US */
|
|
/* Onchaind asks HSM to sign a spend to-us. Four variants */
|
|
/* of keys is derived differently... */
|
|
/* FIXME: Have master tell hsmd the keyindex */
|
|
u8 *towire_hsmd_sign_delayed_payment_to_us(const tal_t *ctx, u64 commit_num, const struct bitcoin_tx *tx, const u8 *wscript)
|
|
{
|
|
u16 wscript_len = tal_count(wscript);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_DELAYED_PAYMENT_TO_US);
|
|
towire_u64(&p, commit_num);
|
|
towire_bitcoin_tx(&p, tx);
|
|
towire_u16(&p, wscript_len);
|
|
towire_u8_array(&p, wscript, wscript_len);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_delayed_payment_to_us(const tal_t *ctx, const void *p, u64 *commit_num, struct bitcoin_tx **tx, u8 **wscript)
|
|
{
|
|
u16 wscript_len;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_DELAYED_PAYMENT_TO_US)
|
|
return false;
|
|
*commit_num = fromwire_u64(&cursor, &plen);
|
|
*tx = fromwire_bitcoin_tx(ctx, &cursor, &plen);
|
|
wscript_len = fromwire_u16(&cursor, &plen);
|
|
// 2nd case wscript
|
|
*wscript = wscript_len ? tal_arr(ctx, u8, wscript_len) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *wscript, wscript_len);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_REMOTE_HTLC_TO_US */
|
|
u8 *towire_hsmd_sign_remote_htlc_to_us(const tal_t *ctx, const struct pubkey *remote_per_commitment_point, const struct bitcoin_tx *tx, const u8 *wscript, bool option_anchor_outputs)
|
|
{
|
|
u16 wscript_len = tal_count(wscript);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_REMOTE_HTLC_TO_US);
|
|
towire_pubkey(&p, remote_per_commitment_point);
|
|
towire_bitcoin_tx(&p, tx);
|
|
towire_u16(&p, wscript_len);
|
|
towire_u8_array(&p, wscript, wscript_len);
|
|
towire_bool(&p, option_anchor_outputs);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_remote_htlc_to_us(const tal_t *ctx, const void *p, struct pubkey *remote_per_commitment_point, struct bitcoin_tx **tx, u8 **wscript, bool *option_anchor_outputs)
|
|
{
|
|
u16 wscript_len;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_REMOTE_HTLC_TO_US)
|
|
return false;
|
|
fromwire_pubkey(&cursor, &plen, remote_per_commitment_point);
|
|
*tx = fromwire_bitcoin_tx(ctx, &cursor, &plen);
|
|
wscript_len = fromwire_u16(&cursor, &plen);
|
|
// 2nd case wscript
|
|
*wscript = wscript_len ? tal_arr(ctx, u8, wscript_len) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *wscript, wscript_len);
|
|
*option_anchor_outputs = fromwire_bool(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_PENALTY_TO_US */
|
|
u8 *towire_hsmd_sign_penalty_to_us(const tal_t *ctx, const struct secret *revocation_secret, const struct bitcoin_tx *tx, const u8 *wscript)
|
|
{
|
|
u16 wscript_len = tal_count(wscript);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_PENALTY_TO_US);
|
|
towire_secret(&p, revocation_secret);
|
|
towire_bitcoin_tx(&p, tx);
|
|
towire_u16(&p, wscript_len);
|
|
towire_u8_array(&p, wscript, wscript_len);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_penalty_to_us(const tal_t *ctx, const void *p, struct secret *revocation_secret, struct bitcoin_tx **tx, u8 **wscript)
|
|
{
|
|
u16 wscript_len;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_PENALTY_TO_US)
|
|
return false;
|
|
fromwire_secret(&cursor, &plen, revocation_secret);
|
|
*tx = fromwire_bitcoin_tx(ctx, &cursor, &plen);
|
|
wscript_len = fromwire_u16(&cursor, &plen);
|
|
// 2nd case wscript
|
|
*wscript = wscript_len ? tal_arr(ctx, u8, wscript_len) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *wscript, wscript_len);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_LOCAL_HTLC_TX */
|
|
/* Onchaind asks HSM to sign a local HTLC success or HTLC timeout tx. */
|
|
u8 *towire_hsmd_sign_local_htlc_tx(const tal_t *ctx, u64 commit_num, const struct bitcoin_tx *tx, const u8 *wscript, bool option_anchor_outputs)
|
|
{
|
|
u16 wscript_len = tal_count(wscript);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_LOCAL_HTLC_TX);
|
|
towire_u64(&p, commit_num);
|
|
towire_bitcoin_tx(&p, tx);
|
|
towire_u16(&p, wscript_len);
|
|
towire_u8_array(&p, wscript, wscript_len);
|
|
towire_bool(&p, option_anchor_outputs);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_local_htlc_tx(const tal_t *ctx, const void *p, u64 *commit_num, struct bitcoin_tx **tx, u8 **wscript, bool *option_anchor_outputs)
|
|
{
|
|
u16 wscript_len;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_LOCAL_HTLC_TX)
|
|
return false;
|
|
*commit_num = fromwire_u64(&cursor, &plen);
|
|
*tx = fromwire_bitcoin_tx(ctx, &cursor, &plen);
|
|
wscript_len = fromwire_u16(&cursor, &plen);
|
|
// 2nd case wscript
|
|
*wscript = wscript_len ? tal_arr(ctx, u8, wscript_len) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *wscript, wscript_len);
|
|
*option_anchor_outputs = fromwire_bool(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_REMOTE_COMMITMENT_TX */
|
|
/* Openingd/channeld asks HSM to sign the other sides' commitment tx. */
|
|
u8 *towire_hsmd_sign_remote_commitment_tx(const tal_t *ctx, const struct bitcoin_tx *tx, const struct pubkey *remote_funding_key, const struct pubkey *remote_per_commit, bool option_static_remotekey)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_REMOTE_COMMITMENT_TX);
|
|
towire_bitcoin_tx(&p, tx);
|
|
towire_pubkey(&p, remote_funding_key);
|
|
towire_pubkey(&p, remote_per_commit);
|
|
towire_bool(&p, option_static_remotekey);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_remote_commitment_tx(const tal_t *ctx, const void *p, struct bitcoin_tx **tx, struct pubkey *remote_funding_key, struct pubkey *remote_per_commit, bool *option_static_remotekey)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_REMOTE_COMMITMENT_TX)
|
|
return false;
|
|
*tx = fromwire_bitcoin_tx(ctx, &cursor, &plen);
|
|
fromwire_pubkey(&cursor, &plen, remote_funding_key);
|
|
fromwire_pubkey(&cursor, &plen, remote_per_commit);
|
|
*option_static_remotekey = fromwire_bool(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_REMOTE_HTLC_TX */
|
|
/* channeld asks HSM to sign remote HTLC tx. */
|
|
u8 *towire_hsmd_sign_remote_htlc_tx(const tal_t *ctx, const struct bitcoin_tx *tx, const u8 *wscript, const struct pubkey *remote_per_commit_point, bool option_anchor_outputs)
|
|
{
|
|
u16 len = tal_count(wscript);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_REMOTE_HTLC_TX);
|
|
towire_bitcoin_tx(&p, tx);
|
|
towire_u16(&p, len);
|
|
towire_u8_array(&p, wscript, len);
|
|
towire_pubkey(&p, remote_per_commit_point);
|
|
towire_bool(&p, option_anchor_outputs);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_remote_htlc_tx(const tal_t *ctx, const void *p, struct bitcoin_tx **tx, u8 **wscript, struct pubkey *remote_per_commit_point, bool *option_anchor_outputs)
|
|
{
|
|
u16 len;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_REMOTE_HTLC_TX)
|
|
return false;
|
|
*tx = fromwire_bitcoin_tx(ctx, &cursor, &plen);
|
|
len = fromwire_u16(&cursor, &plen);
|
|
// 2nd case wscript
|
|
*wscript = len ? tal_arr(ctx, u8, len) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *wscript, len);
|
|
fromwire_pubkey(&cursor, &plen, remote_per_commit_point);
|
|
*option_anchor_outputs = fromwire_bool(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_MUTUAL_CLOSE_TX */
|
|
/* closingd asks HSM to sign mutual close tx. */
|
|
u8 *towire_hsmd_sign_mutual_close_tx(const tal_t *ctx, const struct bitcoin_tx *tx, const struct pubkey *remote_funding_key)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_MUTUAL_CLOSE_TX);
|
|
towire_bitcoin_tx(&p, tx);
|
|
towire_pubkey(&p, remote_funding_key);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_mutual_close_tx(const tal_t *ctx, const void *p, struct bitcoin_tx **tx, struct pubkey *remote_funding_key)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_MUTUAL_CLOSE_TX)
|
|
return false;
|
|
*tx = fromwire_bitcoin_tx(ctx, &cursor, &plen);
|
|
fromwire_pubkey(&cursor, &plen, remote_funding_key);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_TX_REPLY */
|
|
/* Reply for all the above requests. */
|
|
u8 *towire_hsmd_sign_tx_reply(const tal_t *ctx, const struct bitcoin_signature *sig)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_TX_REPLY);
|
|
towire_bitcoin_signature(&p, sig);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_tx_reply(const void *p, struct bitcoin_signature *sig)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_TX_REPLY)
|
|
return false;
|
|
fromwire_bitcoin_signature(&cursor, &plen, sig);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_GET_PER_COMMITMENT_POINT */
|
|
/* Openingd/channeld/onchaind asks for Nth per_commitment_point */
|
|
u8 *towire_hsmd_get_per_commitment_point(const tal_t *ctx, u64 n)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_GET_PER_COMMITMENT_POINT);
|
|
towire_u64(&p, n);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_get_per_commitment_point(const void *p, u64 *n)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_GET_PER_COMMITMENT_POINT)
|
|
return false;
|
|
*n = fromwire_u64(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_GET_PER_COMMITMENT_POINT_REPLY */
|
|
u8 *towire_hsmd_get_per_commitment_point_reply(const tal_t *ctx, const struct pubkey *per_commitment_point, const struct secret *old_commitment_secret)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_GET_PER_COMMITMENT_POINT_REPLY);
|
|
towire_pubkey(&p, per_commitment_point);
|
|
if (!old_commitment_secret)
|
|
towire_bool(&p, false);
|
|
else {
|
|
towire_bool(&p, true);
|
|
towire_secret(&p, old_commitment_secret);
|
|
}
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_get_per_commitment_point_reply(const tal_t *ctx, const void *p, struct pubkey *per_commitment_point, struct secret **old_commitment_secret)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_GET_PER_COMMITMENT_POINT_REPLY)
|
|
return false;
|
|
fromwire_pubkey(&cursor, &plen, per_commitment_point);
|
|
if (!fromwire_bool(&cursor, &plen))
|
|
*old_commitment_secret = NULL;
|
|
else {
|
|
*old_commitment_secret = tal(ctx, struct secret);
|
|
fromwire_secret(&cursor, &plen, *old_commitment_secret);
|
|
}
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_DEV_MEMLEAK */
|
|
/* master -> hsmd: do you have a memleak? */
|
|
u8 *towire_hsmd_dev_memleak(const tal_t *ctx)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_DEV_MEMLEAK);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_dev_memleak(const void *p)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_DEV_MEMLEAK)
|
|
return false;
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_DEV_MEMLEAK_REPLY */
|
|
u8 *towire_hsmd_dev_memleak_reply(const tal_t *ctx, bool leak)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_DEV_MEMLEAK_REPLY);
|
|
towire_bool(&p, leak);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_dev_memleak_reply(const void *p, bool *leak)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_DEV_MEMLEAK_REPLY)
|
|
return false;
|
|
*leak = fromwire_bool(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_CHECK_FUTURE_SECRET */
|
|
/* channeld asks to check if claimed future commitment_secret is correct. */
|
|
u8 *towire_hsmd_check_future_secret(const tal_t *ctx, u64 n, const struct secret *commitment_secret)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_CHECK_FUTURE_SECRET);
|
|
towire_u64(&p, n);
|
|
towire_secret(&p, commitment_secret);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_check_future_secret(const void *p, u64 *n, struct secret *commitment_secret)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_CHECK_FUTURE_SECRET)
|
|
return false;
|
|
*n = fromwire_u64(&cursor, &plen);
|
|
fromwire_secret(&cursor, &plen, commitment_secret);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_CHECK_FUTURE_SECRET_REPLY */
|
|
u8 *towire_hsmd_check_future_secret_reply(const tal_t *ctx, bool correct)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_CHECK_FUTURE_SECRET_REPLY);
|
|
towire_bool(&p, correct);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_check_future_secret_reply(const void *p, bool *correct)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_CHECK_FUTURE_SECRET_REPLY)
|
|
return false;
|
|
*correct = fromwire_bool(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_MESSAGE */
|
|
/* lightningd asks us to sign a string. */
|
|
u8 *towire_hsmd_sign_message(const tal_t *ctx, const u8 *msg)
|
|
{
|
|
u16 len = tal_count(msg);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_MESSAGE);
|
|
towire_u16(&p, len);
|
|
towire_u8_array(&p, msg, len);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_message(const tal_t *ctx, const void *p, u8 **msg)
|
|
{
|
|
u16 len;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_MESSAGE)
|
|
return false;
|
|
len = fromwire_u16(&cursor, &plen);
|
|
// 2nd case msg
|
|
*msg = len ? tal_arr(ctx, u8, len) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *msg, len);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_MESSAGE_REPLY */
|
|
u8 *towire_hsmd_sign_message_reply(const tal_t *ctx, const secp256k1_ecdsa_recoverable_signature *sig)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_MESSAGE_REPLY);
|
|
towire_secp256k1_ecdsa_recoverable_signature(&p, sig);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_message_reply(const void *p, secp256k1_ecdsa_recoverable_signature *sig)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_MESSAGE_REPLY)
|
|
return false;
|
|
fromwire_secp256k1_ecdsa_recoverable_signature(&cursor, &plen, sig);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_GET_OUTPUT_SCRIPTPUBKEY */
|
|
/* lightningd needs to get a scriptPubkey for a utxo with closeinfo */
|
|
u8 *towire_hsmd_get_output_scriptpubkey(const tal_t *ctx, u64 channel_id, const struct node_id *peer_id, const struct pubkey *commitment_point)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY);
|
|
towire_u64(&p, channel_id);
|
|
towire_node_id(&p, peer_id);
|
|
if (!commitment_point)
|
|
towire_bool(&p, false);
|
|
else {
|
|
towire_bool(&p, true);
|
|
towire_pubkey(&p, commitment_point);
|
|
}
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_get_output_scriptpubkey(const tal_t *ctx, const void *p, u64 *channel_id, struct node_id *peer_id, struct pubkey **commitment_point)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY)
|
|
return false;
|
|
*channel_id = fromwire_u64(&cursor, &plen);
|
|
fromwire_node_id(&cursor, &plen, peer_id);
|
|
if (!fromwire_bool(&cursor, &plen))
|
|
*commitment_point = NULL;
|
|
else {
|
|
*commitment_point = tal(ctx, struct pubkey);
|
|
fromwire_pubkey(&cursor, &plen, *commitment_point);
|
|
}
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_GET_OUTPUT_SCRIPTPUBKEY_REPLY */
|
|
u8 *towire_hsmd_get_output_scriptpubkey_reply(const tal_t *ctx, const u8 *script)
|
|
{
|
|
u16 script_len = tal_count(script);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY_REPLY);
|
|
towire_u16(&p, script_len);
|
|
towire_u8_array(&p, script, script_len);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_get_output_scriptpubkey_reply(const tal_t *ctx, const void *p, u8 **script)
|
|
{
|
|
u16 script_len;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_GET_OUTPUT_SCRIPTPUBKEY_REPLY)
|
|
return false;
|
|
script_len = fromwire_u16(&cursor, &plen);
|
|
// 2nd case script
|
|
*script = script_len ? tal_arr(ctx, u8, script_len) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *script, script_len);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_BOLT12 */
|
|
/* Sign a bolt12-style merkle hash */
|
|
u8 *towire_hsmd_sign_bolt12(const tal_t *ctx, const wirestring *messagename, const wirestring *fieldname, const struct sha256 *merkleroot, const u8 *publictweak)
|
|
{
|
|
u16 publictweaklen = tal_count(publictweak);
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_BOLT12);
|
|
towire_wirestring(&p, messagename);
|
|
towire_wirestring(&p, fieldname);
|
|
towire_sha256(&p, merkleroot);
|
|
/* This is for invreq payer_id (temporary keys) */
|
|
towire_u16(&p, publictweaklen);
|
|
towire_u8_array(&p, publictweak, publictweaklen);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_bolt12(const tal_t *ctx, const void *p, wirestring **messagename, wirestring **fieldname, struct sha256 *merkleroot, u8 **publictweak)
|
|
{
|
|
u16 publictweaklen;
|
|
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_BOLT12)
|
|
return false;
|
|
*messagename = fromwire_wirestring(ctx, &cursor, &plen);
|
|
*fieldname = fromwire_wirestring(ctx, &cursor, &plen);
|
|
fromwire_sha256(&cursor, &plen, merkleroot);
|
|
/* This is for invreq payer_id (temporary keys) */
|
|
publictweaklen = fromwire_u16(&cursor, &plen);
|
|
// 2nd case publictweak
|
|
*publictweak = publictweaklen ? tal_arr(ctx, u8, publictweaklen) : NULL;
|
|
fromwire_u8_array(&cursor, &plen, *publictweak, publictweaklen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_BOLT12_REPLY */
|
|
u8 *towire_hsmd_sign_bolt12_reply(const tal_t *ctx, const struct bip340sig *sig)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_BOLT12_REPLY);
|
|
towire_bip340sig(&p, sig);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_bolt12_reply(const void *p, struct bip340sig *sig)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_BOLT12_REPLY)
|
|
return false;
|
|
fromwire_bip340sig(&cursor, &plen, sig);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_OPTION_WILL_FUND_OFFER */
|
|
/* Sign an option_will_fund offer hash */
|
|
u8 *towire_hsmd_sign_option_will_fund_offer(const tal_t *ctx, const struct pubkey *funding_pubkey, u32 blockheight, u32 channel_fee_base_max_msat, u16 channel_fee_proportional_basis_max)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER);
|
|
towire_pubkey(&p, funding_pubkey);
|
|
towire_u32(&p, blockheight);
|
|
towire_u32(&p, channel_fee_base_max_msat);
|
|
towire_u16(&p, channel_fee_proportional_basis_max);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_option_will_fund_offer(const void *p, struct pubkey *funding_pubkey, u32 *blockheight, u32 *channel_fee_base_max_msat, u16 *channel_fee_proportional_basis_max)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER)
|
|
return false;
|
|
fromwire_pubkey(&cursor, &plen, funding_pubkey);
|
|
*blockheight = fromwire_u32(&cursor, &plen);
|
|
*channel_fee_base_max_msat = fromwire_u32(&cursor, &plen);
|
|
*channel_fee_proportional_basis_max = fromwire_u16(&cursor, &plen);
|
|
return cursor != NULL;
|
|
}
|
|
|
|
/* WIRE: HSMD_SIGN_OPTION_WILL_FUND_OFFER_REPLY */
|
|
u8 *towire_hsmd_sign_option_will_fund_offer_reply(const tal_t *ctx, const secp256k1_ecdsa_signature *rsig)
|
|
{
|
|
u8 *p = tal_arr(ctx, u8, 0);
|
|
|
|
towire_u16(&p, WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER_REPLY);
|
|
towire_secp256k1_ecdsa_signature(&p, rsig);
|
|
|
|
return memcheck(p, tal_count(p));
|
|
}
|
|
bool fromwire_hsmd_sign_option_will_fund_offer_reply(const void *p, secp256k1_ecdsa_signature *rsig)
|
|
{
|
|
const u8 *cursor = p;
|
|
size_t plen = tal_count(p);
|
|
|
|
if (fromwire_u16(&cursor, &plen) != WIRE_HSMD_SIGN_OPTION_WILL_FUND_OFFER_REPLY)
|
|
return false;
|
|
fromwire_secp256k1_ecdsa_signature(&cursor, &plen, rsig);
|
|
return cursor != NULL;
|
|
}
|
|
// SHA256STAMP:739903bb8c5fedb86d1d35fea7b926f35b117d9cfdb5e3e8e1f62ddca731f54b
|