2016-11-29 20:51:50 +01:00
|
|
|
#include "../towire.c"
|
|
|
|
#include "../fromwire.c"
|
2017-05-19 14:28:39 +02:00
|
|
|
#include "../peer_wire.c"
|
2020-05-16 03:29:05 +02:00
|
|
|
#include "bitcoin/pubkey.c"
|
2020-05-15 12:32:02 +02:00
|
|
|
#include "common/amount.c"
|
2020-05-15 12:30:25 +02:00
|
|
|
#include "common/channel_id.c"
|
2020-05-16 03:29:05 +02:00
|
|
|
#include "common/node_id.c"
|
2017-01-04 04:39:20 +01:00
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
#include <stdio.h>
|
2019-11-28 15:11:07 +01:00
|
|
|
|
2021-09-09 04:50:52 +02:00
|
|
|
#include <common/channel_type.h>
|
2020-12-02 01:10:04 +01:00
|
|
|
#include <common/setup.h>
|
2017-08-28 18:05:01 +02:00
|
|
|
#include <common/sphinx.h>
|
2020-12-03 10:34:03 +01:00
|
|
|
#include <wire/tlvstream.c>
|
2016-11-29 20:51:50 +01:00
|
|
|
|
2020-01-31 21:59:00 +01:00
|
|
|
extern secp256k1_context *secp256k1_ctx;
|
2016-11-29 20:51:50 +01:00
|
|
|
|
2019-02-20 12:31:48 +01:00
|
|
|
/* AUTOGENERATED MOCKS START */
|
2021-09-09 04:50:52 +02:00
|
|
|
/* Generated stub for fromwire_channel_type */
|
|
|
|
struct channel_type *fromwire_channel_type(const tal_t *ctx UNNEEDED, const u8 **cursor UNNEEDED, size_t *plen UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_channel_type called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_channel_type */
|
|
|
|
void towire_channel_type(u8 **p UNNEEDED, const struct channel_type *channel_type UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_channel_type called!\n"); abort(); }
|
2019-02-20 12:31:48 +01:00
|
|
|
/* AUTOGENERATED MOCKS END */
|
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
/* memsetting pubkeys doesn't work */
|
|
|
|
static void set_pubkey(struct pubkey *key)
|
|
|
|
{
|
pubkey: rename PUBKEY_DER_LEN to PUBKEY_CMPR_LEN.
Pubkeys are not not actually DER encoding, but Pieter Wuille corrected
me: it's SEC 1 documented encoding.
Results from 5 runs, min-max(mean +/- stddev):
store_load_msec,vsz_kb,store_rewrite_sec,listnodes_sec,listchannels_sec,routing_sec,peer_write_all_sec
38922-39297(39180.6+/-1.3e+02),2880728,41.040000-41.160000(41.106+/-0.05),2.270000-2.530000(2.338+/-0.097),44.570000-53.980000(49.696+/-3),32.840000-33.080000(32.95+/-0.095),43.060000-44.950000(43.696+/-0.72)
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
2019-04-08 08:34:05 +02:00
|
|
|
u8 der[PUBKEY_CMPR_LEN];
|
2016-11-29 20:51:50 +01:00
|
|
|
memset(der, 2, sizeof(der));
|
2016-12-02 08:42:58 +01:00
|
|
|
assert(pubkey_from_der(der, sizeof(der), key));
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
2019-04-08 11:58:44 +02:00
|
|
|
static void set_node_id(struct node_id *id)
|
|
|
|
{
|
|
|
|
memset(id->k, 2, sizeof(id->k));
|
|
|
|
}
|
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
/* Size up to field. */
|
|
|
|
#define upto_field(p, field) \
|
|
|
|
((char *)&(p)->field - (char *)(p))
|
|
|
|
|
|
|
|
/* Size including field. */
|
|
|
|
#define with_field(p, field) \
|
|
|
|
(upto_field((p), field) + sizeof((p)->field))
|
|
|
|
|
2018-01-27 23:21:14 +01:00
|
|
|
/* Equal up to this field */
|
2016-11-29 20:51:50 +01:00
|
|
|
#define eq_upto(p1, p2, field) \
|
|
|
|
(memcmp((p1), (p2), upto_field(p1, field)) == 0)
|
|
|
|
|
2018-01-27 23:21:14 +01:00
|
|
|
/* Equal up to and including this field */
|
2016-11-29 20:51:50 +01:00
|
|
|
#define eq_with(p1, p2, field) \
|
|
|
|
(memcmp((p1), (p2), with_field(p1, field)) == 0)
|
|
|
|
|
|
|
|
/* Equal from fields first to last inclusive. */
|
|
|
|
#define eq_between(p1, p2, first, last) \
|
|
|
|
(memcmp((char *)(p1) + upto_field((p1), first), \
|
|
|
|
(char *)(p2) + upto_field((p1), first), \
|
|
|
|
with_field(p1, last) - upto_field(p1, first)) == 0)
|
|
|
|
|
|
|
|
/* Equal in one field. */
|
|
|
|
#define eq_field(p1, p2, field) \
|
|
|
|
(memcmp((char *)(p1) + upto_field((p1), field), \
|
|
|
|
(char *)(p2) + upto_field((p1), field), \
|
|
|
|
sizeof((p1)->field)) == 0)
|
|
|
|
|
2017-01-10 05:49:25 +01:00
|
|
|
#define eq_var(p1, p2, field) \
|
2018-01-02 14:25:43 +01:00
|
|
|
(tal_count((p1)->field) == tal_count((p2)->field) \
|
2018-07-28 08:00:16 +02:00
|
|
|
&& (tal_count((p1)->field) == 0 || memcmp((p1)->field, (p2)->field, tal_bytelen((p1)->field)) == 0))
|
2016-11-29 20:51:50 +01:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
/* Convenience structs for everyone! */
|
|
|
|
struct msg_error {
|
|
|
|
struct channel_id channel_id;
|
|
|
|
u8 *data;
|
|
|
|
};
|
|
|
|
struct msg_closing_signed {
|
|
|
|
struct channel_id channel_id;
|
2019-02-21 04:45:55 +01:00
|
|
|
struct amount_sat fee_satoshis;
|
2017-01-25 00:33:42 +01:00
|
|
|
secp256k1_ecdsa_signature signature;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_funding_created {
|
|
|
|
struct channel_id temporary_channel_id;
|
2017-12-18 07:41:52 +01:00
|
|
|
struct bitcoin_txid txid;
|
2017-03-02 13:21:49 +01:00
|
|
|
u16 output_index;
|
2017-01-25 00:33:42 +01:00
|
|
|
secp256k1_ecdsa_signature signature;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_accept_channel {
|
|
|
|
struct channel_id temporary_channel_id;
|
2019-02-21 04:45:55 +01:00
|
|
|
struct amount_sat dust_limit_satoshis;
|
|
|
|
struct amount_msat max_htlc_value_in_flight_msat;
|
|
|
|
struct amount_sat channel_reserve_satoshis;
|
|
|
|
struct amount_msat htlc_minimum_msat;
|
2017-01-04 04:39:20 +01:00
|
|
|
u32 minimum_depth;
|
|
|
|
u16 to_self_delay;
|
|
|
|
u16 max_accepted_htlcs;
|
|
|
|
struct pubkey funding_pubkey;
|
|
|
|
struct pubkey revocation_basepoint;
|
|
|
|
struct pubkey payment_basepoint;
|
|
|
|
struct pubkey delayed_payment_basepoint;
|
2017-11-15 10:25:19 +01:00
|
|
|
struct pubkey htlc_basepoint;
|
2017-01-04 04:39:20 +01:00
|
|
|
struct pubkey first_per_commitment_point;
|
2020-06-22 07:06:03 +02:00
|
|
|
struct tlv_accept_channel_tlvs *tlvs;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_update_fulfill_htlc {
|
|
|
|
struct channel_id channel_id;
|
|
|
|
u64 id;
|
2017-03-29 12:56:15 +02:00
|
|
|
struct preimage payment_preimage;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_shutdown {
|
|
|
|
struct channel_id channel_id;
|
|
|
|
u8 *scriptpubkey;
|
|
|
|
};
|
|
|
|
struct msg_funding_signed {
|
|
|
|
struct channel_id temporary_channel_id;
|
2017-01-25 00:33:42 +01:00
|
|
|
secp256k1_ecdsa_signature signature;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_revoke_and_ack {
|
|
|
|
struct channel_id channel_id;
|
2018-07-09 13:17:58 +02:00
|
|
|
struct secret per_commitment_secret;
|
2017-01-04 04:39:20 +01:00
|
|
|
struct pubkey next_per_commitment_point;
|
|
|
|
};
|
|
|
|
struct msg_channel_update {
|
2017-01-25 00:33:42 +01:00
|
|
|
secp256k1_ecdsa_signature signature;
|
2017-01-04 04:39:20 +01:00
|
|
|
u32 timestamp;
|
2018-09-20 02:59:46 +02:00
|
|
|
u8 message_flags;
|
|
|
|
u8 channel_flags;
|
2017-01-04 04:39:20 +01:00
|
|
|
u16 expiry;
|
2019-02-21 04:45:55 +01:00
|
|
|
struct amount_msat htlc_minimum_msat;
|
2017-01-04 04:39:20 +01:00
|
|
|
u32 fee_base_msat;
|
|
|
|
u32 fee_proportional_millionths;
|
2017-12-18 07:44:10 +01:00
|
|
|
struct bitcoin_blkid chain_hash;
|
2017-05-19 14:28:39 +02:00
|
|
|
struct short_channel_id short_channel_id;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
2018-10-04 22:34:53 +02:00
|
|
|
struct msg_channel_update_opt_htlc_max {
|
|
|
|
secp256k1_ecdsa_signature signature;
|
|
|
|
u32 timestamp;
|
|
|
|
u8 message_flags;
|
|
|
|
u8 channel_flags;
|
|
|
|
u16 expiry;
|
2019-02-21 04:45:55 +01:00
|
|
|
struct amount_msat htlc_minimum_msat;
|
2018-10-04 22:34:53 +02:00
|
|
|
u32 fee_base_msat;
|
|
|
|
u32 fee_proportional_millionths;
|
2019-02-21 04:45:55 +01:00
|
|
|
struct amount_msat htlc_maximum_msat;
|
2018-10-04 22:34:53 +02:00
|
|
|
struct bitcoin_blkid chain_hash;
|
|
|
|
struct short_channel_id short_channel_id;
|
|
|
|
};
|
2017-01-04 04:39:20 +01:00
|
|
|
struct msg_funding_locked {
|
2017-02-07 02:44:14 +01:00
|
|
|
struct channel_id channel_id;
|
|
|
|
struct pubkey next_per_commitment_point;
|
|
|
|
};
|
|
|
|
struct msg_announcement_signatures {
|
2017-01-04 04:39:20 +01:00
|
|
|
struct channel_id channel_id;
|
2017-01-25 00:33:42 +01:00
|
|
|
secp256k1_ecdsa_signature announcement_node_signature;
|
|
|
|
secp256k1_ecdsa_signature announcement_bitcoin_signature;
|
2017-05-19 14:28:39 +02:00
|
|
|
struct short_channel_id short_channel_id;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
2017-03-29 12:53:15 +02:00
|
|
|
struct msg_commitment_signed {
|
2017-01-04 04:39:20 +01:00
|
|
|
struct channel_id channel_id;
|
2017-01-25 00:33:42 +01:00
|
|
|
secp256k1_ecdsa_signature signature;
|
|
|
|
secp256k1_ecdsa_signature *htlc_signature;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_node_announcement {
|
2017-01-25 00:33:42 +01:00
|
|
|
secp256k1_ecdsa_signature signature;
|
2017-01-04 04:39:20 +01:00
|
|
|
u32 timestamp;
|
2019-04-08 11:58:44 +02:00
|
|
|
struct node_id node_id;
|
2017-01-04 04:39:20 +01:00
|
|
|
u8 rgb_color[3];
|
|
|
|
u8 alias[32];
|
2017-01-04 04:39:21 +01:00
|
|
|
u8 *features;
|
2017-01-04 04:39:21 +01:00
|
|
|
u8 *addresses;
|
2021-06-10 19:54:08 +02:00
|
|
|
struct tlv_node_ann_tlvs *tlvs;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_open_channel {
|
2017-12-18 07:44:10 +01:00
|
|
|
struct bitcoin_blkid chain_hash;
|
2017-01-04 04:39:20 +01:00
|
|
|
struct channel_id temporary_channel_id;
|
2019-02-21 04:45:55 +01:00
|
|
|
struct amount_sat funding_satoshis;
|
|
|
|
struct amount_msat push_msat;
|
|
|
|
struct amount_sat dust_limit_satoshis;
|
|
|
|
struct amount_msat max_htlc_value_in_flight_msat;
|
|
|
|
struct amount_sat channel_reserve_satoshis;
|
|
|
|
struct amount_msat htlc_minimum_msat;
|
2017-01-04 04:39:20 +01:00
|
|
|
u32 feerate_per_kw;
|
|
|
|
u16 to_self_delay;
|
|
|
|
u16 max_accepted_htlcs;
|
|
|
|
struct pubkey funding_pubkey;
|
|
|
|
struct pubkey revocation_basepoint;
|
|
|
|
struct pubkey payment_basepoint;
|
|
|
|
struct pubkey delayed_payment_basepoint;
|
2017-11-15 10:25:19 +01:00
|
|
|
struct pubkey htlc_basepoint;
|
2017-01-04 04:39:20 +01:00
|
|
|
struct pubkey first_per_commitment_point;
|
2017-06-27 04:55:01 +02:00
|
|
|
u8 channel_flags;
|
2020-06-22 07:06:03 +02:00
|
|
|
struct tlv_open_channel_tlvs *tlvs;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_update_fail_htlc {
|
|
|
|
struct channel_id channel_id;
|
|
|
|
u64 id;
|
2017-01-06 04:28:39 +01:00
|
|
|
u8 *reason;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_channel_announcement {
|
2017-01-25 00:33:42 +01:00
|
|
|
secp256k1_ecdsa_signature node_signature_1;
|
|
|
|
secp256k1_ecdsa_signature node_signature_2;
|
|
|
|
secp256k1_ecdsa_signature bitcoin_signature_1;
|
|
|
|
secp256k1_ecdsa_signature bitcoin_signature_2;
|
2017-08-03 03:45:04 +02:00
|
|
|
u8 *features;
|
2017-12-18 07:44:10 +01:00
|
|
|
struct bitcoin_blkid chain_hash;
|
2017-08-03 03:45:04 +02:00
|
|
|
struct short_channel_id short_channel_id;
|
2019-04-08 11:58:44 +02:00
|
|
|
struct node_id node_id_1;
|
|
|
|
struct node_id node_id_2;
|
2017-01-04 04:39:20 +01:00
|
|
|
struct pubkey bitcoin_key_1;
|
|
|
|
struct pubkey bitcoin_key_2;
|
|
|
|
};
|
|
|
|
struct msg_init {
|
|
|
|
u8 *globalfeatures;
|
|
|
|
u8 *localfeatures;
|
2019-11-28 15:11:07 +01:00
|
|
|
struct tlv_init_tlvs *tlvs;
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_update_add_htlc {
|
|
|
|
struct channel_id channel_id;
|
|
|
|
u64 id;
|
2019-02-21 04:45:55 +01:00
|
|
|
struct amount_msat amount_msat;
|
2017-01-04 04:39:20 +01:00
|
|
|
u32 expiry;
|
|
|
|
struct sha256 payment_hash;
|
2020-12-08 07:48:53 +01:00
|
|
|
u8 onion_routing_packet[TOTAL_PACKET_SIZE(ROUTING_INFO_SIZE)];
|
2017-01-04 04:39:20 +01:00
|
|
|
};
|
|
|
|
struct msg_update_fee {
|
|
|
|
struct channel_id channel_id;
|
|
|
|
u32 feerate_per_kw;
|
|
|
|
};
|
|
|
|
|
|
|
|
static void *towire_struct_channel_announcement(const tal_t *ctx,
|
|
|
|
const struct msg_channel_announcement *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_channel_announcement(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->node_signature_1,
|
|
|
|
&s->node_signature_2,
|
|
|
|
&s->bitcoin_signature_1,
|
|
|
|
&s->bitcoin_signature_2,
|
2017-08-03 03:45:04 +02:00
|
|
|
s->features,
|
2017-08-22 07:25:01 +02:00
|
|
|
&s->chain_hash,
|
2017-03-02 13:21:49 +01:00
|
|
|
&s->short_channel_id,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->node_id_1,
|
|
|
|
&s->node_id_2,
|
|
|
|
&s->bitcoin_key_1,
|
2017-08-03 03:45:04 +02:00
|
|
|
&s->bitcoin_key_2);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_channel_announcement *fromwire_struct_channel_announcement(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_channel_announcement *s = tal(ctx, struct msg_channel_announcement);
|
2018-02-20 21:59:09 +01:00
|
|
|
if (!fromwire_channel_announcement(s, p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->node_signature_1,
|
|
|
|
&s->node_signature_2,
|
|
|
|
&s->bitcoin_signature_1,
|
|
|
|
&s->bitcoin_signature_2,
|
2017-08-03 03:45:04 +02:00
|
|
|
&s->features,
|
2017-08-22 07:25:01 +02:00
|
|
|
&s->chain_hash,
|
2017-03-02 13:21:49 +01:00
|
|
|
&s->short_channel_id,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->node_id_1,
|
|
|
|
&s->node_id_2,
|
|
|
|
&s->bitcoin_key_1,
|
2017-08-03 03:45:04 +02:00
|
|
|
&s->bitcoin_key_2))
|
2017-01-04 04:39:20 +01:00
|
|
|
return tal_free(s);
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_open_channel(const tal_t *ctx,
|
|
|
|
const struct msg_open_channel *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_open_channel(ctx,
|
2017-03-29 12:54:15 +02:00
|
|
|
&s->chain_hash,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->temporary_channel_id,
|
|
|
|
s->funding_satoshis,
|
|
|
|
s->push_msat,
|
|
|
|
s->dust_limit_satoshis,
|
|
|
|
s->max_htlc_value_in_flight_msat,
|
|
|
|
s->channel_reserve_satoshis,
|
|
|
|
s->htlc_minimum_msat,
|
|
|
|
s->feerate_per_kw,
|
|
|
|
s->to_self_delay,
|
|
|
|
s->max_accepted_htlcs,
|
|
|
|
&s->funding_pubkey,
|
|
|
|
&s->revocation_basepoint,
|
|
|
|
&s->payment_basepoint,
|
|
|
|
&s->delayed_payment_basepoint,
|
2017-11-15 10:25:19 +01:00
|
|
|
&s->htlc_basepoint,
|
2017-06-27 04:55:01 +02:00
|
|
|
&s->first_per_commitment_point,
|
2020-06-22 07:06:03 +02:00
|
|
|
s->channel_flags,
|
|
|
|
NULL);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_open_channel *fromwire_struct_open_channel(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_open_channel *s = tal(ctx, struct msg_open_channel);
|
2020-06-22 07:06:03 +02:00
|
|
|
s->tlvs = tlv_open_channel_tlvs_new(s);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_open_channel(p,
|
2017-03-29 12:54:15 +02:00
|
|
|
&s->chain_hash,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->temporary_channel_id,
|
|
|
|
&s->funding_satoshis,
|
|
|
|
&s->push_msat,
|
|
|
|
&s->dust_limit_satoshis,
|
|
|
|
&s->max_htlc_value_in_flight_msat,
|
|
|
|
&s->channel_reserve_satoshis,
|
|
|
|
&s->htlc_minimum_msat,
|
|
|
|
&s->feerate_per_kw,
|
|
|
|
&s->to_self_delay,
|
|
|
|
&s->max_accepted_htlcs,
|
|
|
|
&s->funding_pubkey,
|
|
|
|
&s->revocation_basepoint,
|
|
|
|
&s->payment_basepoint,
|
|
|
|
&s->delayed_payment_basepoint,
|
2017-11-15 10:25:19 +01:00
|
|
|
&s->htlc_basepoint,
|
2017-06-27 04:55:01 +02:00
|
|
|
&s->first_per_commitment_point,
|
2020-06-22 07:06:03 +02:00
|
|
|
&s->channel_flags,
|
|
|
|
s->tlvs))
|
2017-01-04 04:39:20 +01:00
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_accept_channel(const tal_t *ctx,
|
|
|
|
const struct msg_accept_channel *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_accept_channel(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->temporary_channel_id,
|
|
|
|
s->dust_limit_satoshis,
|
|
|
|
s->max_htlc_value_in_flight_msat,
|
|
|
|
s->channel_reserve_satoshis,
|
|
|
|
s->htlc_minimum_msat,
|
2017-06-06 01:49:10 +02:00
|
|
|
s->minimum_depth,
|
2017-01-04 04:39:20 +01:00
|
|
|
s->to_self_delay,
|
|
|
|
s->max_accepted_htlcs,
|
|
|
|
&s->funding_pubkey,
|
|
|
|
&s->revocation_basepoint,
|
|
|
|
&s->payment_basepoint,
|
2017-11-15 10:25:19 +01:00
|
|
|
&s->htlc_basepoint,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->delayed_payment_basepoint,
|
2020-06-22 07:06:03 +02:00
|
|
|
&s->first_per_commitment_point,
|
|
|
|
s->tlvs);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_accept_channel *fromwire_struct_accept_channel(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_accept_channel *s = tal(ctx, struct msg_accept_channel);
|
2020-06-22 07:06:03 +02:00
|
|
|
s->tlvs = tlv_accept_channel_tlvs_new(s);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_accept_channel(p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->temporary_channel_id,
|
|
|
|
&s->dust_limit_satoshis,
|
|
|
|
&s->max_htlc_value_in_flight_msat,
|
|
|
|
&s->channel_reserve_satoshis,
|
|
|
|
&s->htlc_minimum_msat,
|
2017-06-06 01:49:10 +02:00
|
|
|
&s->minimum_depth,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->to_self_delay,
|
|
|
|
&s->max_accepted_htlcs,
|
|
|
|
&s->funding_pubkey,
|
|
|
|
&s->revocation_basepoint,
|
|
|
|
&s->payment_basepoint,
|
2017-11-15 10:25:19 +01:00
|
|
|
&s->htlc_basepoint,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->delayed_payment_basepoint,
|
2020-06-22 07:06:03 +02:00
|
|
|
&s->first_per_commitment_point,
|
|
|
|
s->tlvs))
|
2017-01-04 04:39:20 +01:00
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_node_announcement(const tal_t *ctx,
|
|
|
|
const struct msg_node_announcement *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_node_announcement(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->signature,
|
2017-08-03 03:45:04 +02:00
|
|
|
s->features,
|
2017-01-04 04:39:20 +01:00
|
|
|
s->timestamp,
|
|
|
|
&s->node_id,
|
|
|
|
s->rgb_color,
|
2017-01-04 04:39:21 +01:00
|
|
|
s->alias,
|
2021-06-10 19:54:08 +02:00
|
|
|
s->addresses,
|
|
|
|
s->tlvs);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_node_announcement *fromwire_struct_node_announcement(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_node_announcement *s = tal(ctx, struct msg_node_announcement);
|
2021-06-10 19:54:08 +02:00
|
|
|
s->tlvs = tlv_node_ann_tlvs_new(s);
|
2018-02-20 21:59:09 +01:00
|
|
|
if (!fromwire_node_announcement(s, p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->signature,
|
2017-08-03 03:45:04 +02:00
|
|
|
&s->features,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->timestamp,
|
|
|
|
&s->node_id,
|
|
|
|
s->rgb_color,
|
2017-01-04 04:39:21 +01:00
|
|
|
s->alias,
|
2021-06-10 19:54:08 +02:00
|
|
|
&s->addresses,
|
|
|
|
s->tlvs))
|
2017-01-04 04:39:20 +01:00
|
|
|
return tal_free(s);
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_channel_update(const tal_t *ctx,
|
|
|
|
const struct msg_channel_update *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_channel_update(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->signature,
|
2017-08-22 07:25:01 +02:00
|
|
|
&s->chain_hash,
|
2017-03-02 13:21:49 +01:00
|
|
|
&s->short_channel_id,
|
2017-01-04 04:39:20 +01:00
|
|
|
s->timestamp,
|
2018-09-20 02:59:46 +02:00
|
|
|
s->message_flags,
|
|
|
|
s->channel_flags,
|
2017-01-04 04:39:20 +01:00
|
|
|
s->expiry,
|
|
|
|
s->htlc_minimum_msat,
|
|
|
|
s->fee_base_msat,
|
|
|
|
s->fee_proportional_millionths);
|
|
|
|
}
|
|
|
|
|
2018-10-04 22:34:53 +02:00
|
|
|
static void *towire_struct_channel_update_opt_htlc_max(const tal_t *ctx,
|
|
|
|
const struct msg_channel_update_opt_htlc_max *s)
|
|
|
|
{
|
|
|
|
return towire_channel_update_option_channel_htlc_max(ctx,
|
|
|
|
&s->signature,
|
|
|
|
&s->chain_hash,
|
|
|
|
&s->short_channel_id,
|
|
|
|
s->timestamp,
|
|
|
|
s->message_flags,
|
|
|
|
s->channel_flags,
|
|
|
|
s->expiry,
|
|
|
|
s->htlc_minimum_msat,
|
|
|
|
s->fee_base_msat,
|
|
|
|
s->fee_proportional_millionths,
|
|
|
|
s->htlc_maximum_msat);
|
|
|
|
}
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_channel_update *fromwire_struct_channel_update(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_channel_update *s = tal(ctx, struct msg_channel_update);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_channel_update(p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->signature,
|
2017-08-22 07:25:01 +02:00
|
|
|
&s->chain_hash,
|
2017-03-02 13:21:49 +01:00
|
|
|
&s->short_channel_id,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->timestamp,
|
2018-09-20 02:59:46 +02:00
|
|
|
&s->message_flags,
|
|
|
|
&s->channel_flags,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->expiry,
|
|
|
|
&s->htlc_minimum_msat,
|
|
|
|
&s->fee_base_msat,
|
|
|
|
&s->fee_proportional_millionths))
|
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
2018-10-04 22:34:53 +02:00
|
|
|
static struct msg_channel_update_opt_htlc_max
|
|
|
|
*fromwire_struct_channel_update_opt_htlc_max(const tal_t *ctx, const void *p)
|
|
|
|
{
|
|
|
|
struct msg_channel_update_opt_htlc_max *s = tal(ctx, struct msg_channel_update_opt_htlc_max);
|
|
|
|
|
|
|
|
if (fromwire_channel_update_option_channel_htlc_max(p,
|
|
|
|
&s->signature,
|
|
|
|
&s->chain_hash,
|
|
|
|
&s->short_channel_id,
|
|
|
|
&s->timestamp,
|
|
|
|
&s->message_flags,
|
|
|
|
&s->channel_flags,
|
|
|
|
&s->expiry,
|
|
|
|
&s->htlc_minimum_msat,
|
|
|
|
&s->fee_base_msat,
|
|
|
|
&s->fee_proportional_millionths,
|
|
|
|
&s->htlc_maximum_msat))
|
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
static void *towire_struct_funding_locked(const tal_t *ctx,
|
|
|
|
const struct msg_funding_locked *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_funding_locked(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->next_per_commitment_point);
|
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_funding_locked *fromwire_struct_funding_locked(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_funding_locked *s = tal(ctx, struct msg_funding_locked);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_funding_locked(p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->next_per_commitment_point))
|
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
2017-02-07 02:44:14 +01:00
|
|
|
static void *towire_struct_announcement_signatures(const tal_t *ctx,
|
|
|
|
const struct msg_announcement_signatures *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_announcement_signatures(ctx,
|
2017-02-07 02:44:14 +01:00
|
|
|
&s->channel_id,
|
2017-03-02 13:21:49 +01:00
|
|
|
&s->short_channel_id,
|
2017-02-07 02:44:14 +01:00
|
|
|
&s->announcement_node_signature,
|
|
|
|
&s->announcement_bitcoin_signature);
|
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_announcement_signatures *fromwire_struct_announcement_signatures(const tal_t *ctx, const void *p)
|
2017-02-07 02:44:14 +01:00
|
|
|
{
|
|
|
|
struct msg_announcement_signatures *s = tal(ctx, struct msg_announcement_signatures);
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_announcement_signatures(p,
|
2017-02-07 02:44:14 +01:00
|
|
|
&s->channel_id,
|
2017-03-02 13:21:49 +01:00
|
|
|
&s->short_channel_id,
|
2017-02-07 02:44:14 +01:00
|
|
|
&s->announcement_node_signature,
|
|
|
|
&s->announcement_bitcoin_signature))
|
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
static void *towire_struct_update_fail_htlc(const tal_t *ctx,
|
|
|
|
const struct msg_update_fail_htlc *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_update_fail_htlc(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
s->id,
|
|
|
|
s->reason);
|
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_update_fail_htlc *fromwire_struct_update_fail_htlc(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_update_fail_htlc *s = tal(ctx, struct msg_update_fail_htlc);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (!fromwire_update_fail_htlc(ctx, p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->id,
|
2017-01-06 04:28:39 +01:00
|
|
|
&s->reason))
|
|
|
|
return tal_free(s);
|
|
|
|
return s;
|
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_update_fulfill_htlc(const tal_t *ctx,
|
|
|
|
const struct msg_update_fulfill_htlc *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_update_fulfill_htlc(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
s->id,
|
|
|
|
&s->payment_preimage);
|
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_update_fulfill_htlc *fromwire_struct_update_fulfill_htlc(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_update_fulfill_htlc *s = tal(ctx, struct msg_update_fulfill_htlc);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_update_fulfill_htlc(p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->id,
|
|
|
|
&s->payment_preimage))
|
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
2017-03-29 12:53:15 +02:00
|
|
|
static void *towire_struct_commitment_signed(const tal_t *ctx,
|
|
|
|
const struct msg_commitment_signed *s)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_commitment_signed(ctx,
|
2017-03-29 12:53:15 +02:00
|
|
|
&s->channel_id,
|
|
|
|
&s->signature,
|
|
|
|
s->htlc_signature);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_commitment_signed *fromwire_struct_commitment_signed(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
2017-03-29 12:53:15 +02:00
|
|
|
struct msg_commitment_signed *s = tal(ctx, struct msg_commitment_signed);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (!fromwire_commitment_signed(s, p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->signature,
|
|
|
|
&s->htlc_signature))
|
|
|
|
return tal_free(s);
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_revoke_and_ack(const tal_t *ctx,
|
|
|
|
const struct msg_revoke_and_ack *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_revoke_and_ack(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->per_commitment_secret,
|
2017-03-29 12:52:15 +02:00
|
|
|
&s->next_per_commitment_point);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_revoke_and_ack *fromwire_struct_revoke_and_ack(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_revoke_and_ack *s = tal(ctx, struct msg_revoke_and_ack);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (!fromwire_revoke_and_ack(p,
|
2017-03-29 12:52:15 +02:00
|
|
|
&s->channel_id,
|
|
|
|
&s->per_commitment_secret,
|
|
|
|
&s->next_per_commitment_point))
|
2017-01-04 04:39:20 +01:00
|
|
|
return tal_free(s);
|
|
|
|
return s;
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_funding_signed(const tal_t *ctx,
|
|
|
|
const struct msg_funding_signed *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_funding_signed(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->temporary_channel_id,
|
|
|
|
&s->signature);
|
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_funding_signed *fromwire_struct_funding_signed(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_funding_signed *s = tal(ctx, struct msg_funding_signed);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_funding_signed(p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->temporary_channel_id,
|
|
|
|
&s->signature))
|
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_closing_signed(const tal_t *ctx,
|
|
|
|
const struct msg_closing_signed *s)
|
|
|
|
{
|
2021-09-08 02:09:14 +02:00
|
|
|
struct tlv_closing_signed_tlvs *close_tlvs;
|
|
|
|
|
|
|
|
close_tlvs = tlv_closing_signed_tlvs_new(ctx);
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_closing_signed(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
s->fee_satoshis,
|
2021-09-08 02:09:14 +02:00
|
|
|
&s->signature,
|
|
|
|
close_tlvs);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_closing_signed *fromwire_struct_closing_signed(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_closing_signed *s = tal(ctx, struct msg_closing_signed);
|
2021-09-08 02:09:14 +02:00
|
|
|
struct tlv_closing_signed_tlvs *close_tlvs;
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2021-09-08 02:09:14 +02:00
|
|
|
close_tlvs = tlv_closing_signed_tlvs_new(ctx);
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_closing_signed(p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->fee_satoshis,
|
2021-09-08 02:09:14 +02:00
|
|
|
&s->signature,
|
|
|
|
close_tlvs))
|
2017-01-04 04:39:20 +01:00
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_shutdown(const tal_t *ctx,
|
|
|
|
const struct msg_shutdown *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_shutdown(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
2021-03-15 04:40:44 +01:00
|
|
|
s->scriptpubkey,
|
|
|
|
NULL);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_shutdown *fromwire_struct_shutdown(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_shutdown *s = tal(ctx, struct msg_shutdown);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (!fromwire_shutdown(s, p,
|
2021-03-15 04:40:44 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->scriptpubkey,
|
|
|
|
NULL))
|
2017-01-04 04:39:20 +01:00
|
|
|
return tal_free(s);
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_funding_created(const tal_t *ctx,
|
|
|
|
const struct msg_funding_created *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_funding_created(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->temporary_channel_id,
|
|
|
|
&s->txid,
|
|
|
|
s->output_index,
|
|
|
|
&s->signature);
|
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_funding_created *fromwire_struct_funding_created(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_funding_created *s = tal(ctx, struct msg_funding_created);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_funding_created(p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->temporary_channel_id,
|
|
|
|
&s->txid,
|
|
|
|
&s->output_index,
|
|
|
|
&s->signature))
|
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_error(const tal_t *ctx,
|
|
|
|
const struct msg_error *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_error(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
s->data);
|
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_error *fromwire_struct_error(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_error *s = tal(ctx, struct msg_error);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (!fromwire_error(s, p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->data))
|
|
|
|
return tal_free(s);
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_update_add_htlc(const tal_t *ctx,
|
|
|
|
const struct msg_update_add_htlc *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_update_add_htlc(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
s->id,
|
|
|
|
s->amount_msat,
|
|
|
|
&s->payment_hash,
|
2017-06-06 01:49:10 +02:00
|
|
|
s->expiry,
|
2020-04-11 04:49:51 +02:00
|
|
|
s->onion_routing_packet
|
|
|
|
#if EXPERIMENTAL_FEATURES
|
|
|
|
,NULL
|
|
|
|
#endif
|
|
|
|
);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_update_add_htlc *fromwire_struct_update_add_htlc(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_update_add_htlc *s = tal(ctx, struct msg_update_add_htlc);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_update_add_htlc(p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->id,
|
|
|
|
&s->amount_msat,
|
|
|
|
&s->payment_hash,
|
2017-06-06 01:49:10 +02:00
|
|
|
&s->expiry,
|
2020-04-11 04:49:51 +02:00
|
|
|
s->onion_routing_packet
|
|
|
|
#if EXPERIMENTAL_FEATURES
|
|
|
|
,NULL
|
|
|
|
#endif
|
|
|
|
))
|
2017-01-04 04:39:20 +01:00
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static void *towire_struct_update_fee(const tal_t *ctx,
|
|
|
|
const struct msg_update_fee *s)
|
|
|
|
{
|
2017-08-28 18:12:01 +02:00
|
|
|
return towire_update_fee(ctx,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
s->feerate_per_kw);
|
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_update_fee *fromwire_struct_update_fee(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_update_fee *s = tal(ctx, struct msg_update_fee);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (fromwire_update_fee(p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->channel_id,
|
|
|
|
&s->feerate_per_kw))
|
|
|
|
return s;
|
|
|
|
return tal_free(s);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void *towire_struct_init(const tal_t *ctx,
|
|
|
|
const struct msg_init *s)
|
|
|
|
{
|
|
|
|
return towire_init(ctx,
|
|
|
|
s->globalfeatures,
|
2019-11-28 15:11:07 +01:00
|
|
|
s->localfeatures,
|
|
|
|
s->tlvs);
|
2017-01-04 04:39:20 +01:00
|
|
|
}
|
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
static struct msg_init *fromwire_struct_init(const tal_t *ctx, const void *p)
|
2017-01-04 04:39:20 +01:00
|
|
|
{
|
|
|
|
struct msg_init *s = tal(ctx, struct msg_init);
|
2019-11-28 15:11:07 +01:00
|
|
|
s->tlvs = tlv_init_tlvs_new(s);
|
2017-01-04 04:39:21 +01:00
|
|
|
|
2018-02-20 21:59:09 +01:00
|
|
|
if (!fromwire_init(s, p,
|
2017-01-04 04:39:20 +01:00
|
|
|
&s->globalfeatures,
|
2019-11-28 15:11:07 +01:00
|
|
|
&s->localfeatures,
|
|
|
|
s->tlvs))
|
2017-01-04 04:39:20 +01:00
|
|
|
return tal_free(s);
|
|
|
|
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
static bool channel_announcement_eq(const struct msg_channel_announcement *a,
|
|
|
|
const struct msg_channel_announcement *b)
|
|
|
|
{
|
2017-08-03 03:45:04 +02:00
|
|
|
return eq_upto(a, b, features)
|
|
|
|
&& eq_var(a, b, features)
|
2017-08-22 07:25:01 +02:00
|
|
|
&& eq_field(a, b, chain_hash)
|
2018-07-04 07:30:02 +02:00
|
|
|
&& short_channel_id_eq(&a->short_channel_id,
|
|
|
|
&b->short_channel_id)
|
2019-04-08 11:58:44 +02:00
|
|
|
&& eq_field(a, b, node_id_1)
|
|
|
|
&& eq_field(a, b, node_id_2)
|
|
|
|
&& eq_between(a, b, bitcoin_key_1, bitcoin_key_2);
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool funding_locked_eq(const struct msg_funding_locked *a,
|
|
|
|
const struct msg_funding_locked *b)
|
|
|
|
{
|
2018-07-04 07:30:02 +02:00
|
|
|
return memcmp(a, b, sizeof(*a)) == 0;
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
2017-02-07 02:44:14 +01:00
|
|
|
static bool announcement_signatures_eq(const struct msg_announcement_signatures *a,
|
|
|
|
const struct msg_announcement_signatures *b)
|
|
|
|
{
|
2017-05-19 14:28:39 +02:00
|
|
|
return eq_upto(a, b, short_channel_id) &&
|
2018-07-04 07:30:02 +02:00
|
|
|
short_channel_id_eq(&a->short_channel_id, &b->short_channel_id);
|
2017-02-07 02:44:14 +01:00
|
|
|
}
|
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
static bool update_fail_htlc_eq(const struct msg_update_fail_htlc *a,
|
|
|
|
const struct msg_update_fail_htlc *b)
|
|
|
|
{
|
2017-01-06 04:28:39 +01:00
|
|
|
return eq_with(a, b, id)
|
2017-01-10 05:49:25 +01:00
|
|
|
&& eq_var(a, b, reason);
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
2017-03-29 12:53:15 +02:00
|
|
|
static bool commitment_signed_eq(const struct msg_commitment_signed *a,
|
|
|
|
const struct msg_commitment_signed *b)
|
2016-11-29 20:51:50 +01:00
|
|
|
{
|
2017-01-10 05:49:25 +01:00
|
|
|
return eq_upto(a, b, htlc_signature)
|
|
|
|
&& eq_var(a, b, htlc_signature);
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool funding_signed_eq(const struct msg_funding_signed *a,
|
|
|
|
const struct msg_funding_signed *b)
|
|
|
|
{
|
2018-07-04 07:30:02 +02:00
|
|
|
return memcmp(a, b, sizeof(*a)) == 0;
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool closing_signed_eq(const struct msg_closing_signed *a,
|
|
|
|
const struct msg_closing_signed *b)
|
|
|
|
{
|
2018-07-04 07:30:02 +02:00
|
|
|
return memcmp(a, b, sizeof(*a)) == 0;
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool update_fulfill_htlc_eq(const struct msg_update_fulfill_htlc *a,
|
|
|
|
const struct msg_update_fulfill_htlc *b)
|
|
|
|
{
|
2018-07-04 07:30:02 +02:00
|
|
|
return memcmp(a, b, sizeof(*a)) == 0;
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool error_eq(const struct msg_error *a,
|
|
|
|
const struct msg_error *b)
|
|
|
|
{
|
2017-01-10 05:49:25 +01:00
|
|
|
return eq_upto(a, b, data)
|
|
|
|
&& eq_var(a, b, data);
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool init_eq(const struct msg_init *a,
|
|
|
|
const struct msg_init *b)
|
|
|
|
{
|
2019-12-13 06:04:16 +01:00
|
|
|
if (!eq_var(a, b, globalfeatures) || !eq_var(a, b, localfeatures))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
/* Both or neither */
|
|
|
|
if (!a->tlvs != !b->tlvs)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if (!a->tlvs)
|
|
|
|
return true;
|
|
|
|
|
|
|
|
/* Both or neither */
|
|
|
|
if (!a->tlvs->networks != !b->tlvs->networks)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if (!a->tlvs->networks)
|
|
|
|
return true;
|
|
|
|
|
2020-05-06 12:41:54 +02:00
|
|
|
if (tal_count(a->tlvs->networks)
|
|
|
|
!= tal_count(b->tlvs->networks))
|
2019-12-13 06:04:16 +01:00
|
|
|
return false;
|
2020-05-06 12:41:54 +02:00
|
|
|
for (size_t i = 0; i < tal_count(a->tlvs->networks); i++)
|
|
|
|
if (!bitcoin_blkid_eq(&a->tlvs->networks[i],
|
|
|
|
&b->tlvs->networks[i]))
|
2019-12-13 06:04:16 +01:00
|
|
|
return false;
|
|
|
|
return true;
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool update_fee_eq(const struct msg_update_fee *a,
|
|
|
|
const struct msg_update_fee *b)
|
|
|
|
{
|
2018-07-04 07:30:02 +02:00
|
|
|
return memcmp(a, b, sizeof(*a)) == 0;
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool shutdown_eq(const struct msg_shutdown *a,
|
|
|
|
const struct msg_shutdown *b)
|
|
|
|
{
|
2017-01-10 05:49:25 +01:00
|
|
|
return eq_upto(a, b, scriptpubkey)
|
|
|
|
&& eq_var(a, b, scriptpubkey);
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool funding_created_eq(const struct msg_funding_created *a,
|
|
|
|
const struct msg_funding_created *b)
|
|
|
|
{
|
|
|
|
return eq_with(a, b, output_index)
|
|
|
|
&& eq_field(a, b, signature);
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool revoke_and_ack_eq(const struct msg_revoke_and_ack *a,
|
|
|
|
const struct msg_revoke_and_ack *b)
|
|
|
|
{
|
2018-07-04 07:30:02 +02:00
|
|
|
return memcmp(a, b, sizeof(*a)) == 0;
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool open_channel_eq(const struct msg_open_channel *a,
|
|
|
|
const struct msg_open_channel *b)
|
|
|
|
{
|
2017-10-11 06:31:57 +02:00
|
|
|
return eq_with(a, b, max_accepted_htlcs)
|
2017-06-27 04:55:01 +02:00
|
|
|
&& eq_between(a, b, funding_pubkey, channel_flags);
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
static bool channel_update_eq(const struct msg_channel_update *a,
|
|
|
|
const struct msg_channel_update *b)
|
|
|
|
{
|
2017-05-19 14:28:39 +02:00
|
|
|
return eq_upto(a, b, short_channel_id) &&
|
2018-07-04 07:30:02 +02:00
|
|
|
short_channel_id_eq(&a->short_channel_id, &b->short_channel_id);
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
2018-10-04 22:34:53 +02:00
|
|
|
static bool channel_update_opt_htlc_max_eq(const struct msg_channel_update_opt_htlc_max *a,
|
|
|
|
const struct msg_channel_update_opt_htlc_max *b)
|
|
|
|
{
|
|
|
|
return eq_upto(a, b, short_channel_id) &&
|
|
|
|
short_channel_id_eq(&a->short_channel_id, &b->short_channel_id);
|
|
|
|
}
|
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
static bool accept_channel_eq(const struct msg_accept_channel *a,
|
|
|
|
const struct msg_accept_channel *b)
|
|
|
|
{
|
2017-10-11 06:31:57 +02:00
|
|
|
return eq_with(a, b, max_accepted_htlcs)
|
2016-11-29 20:51:50 +01:00
|
|
|
&& eq_between(a, b, funding_pubkey, first_per_commitment_point);
|
|
|
|
}
|
|
|
|
|
|
|
|
static bool update_add_htlc_eq(const struct msg_update_add_htlc *a,
|
|
|
|
const struct msg_update_add_htlc *b)
|
|
|
|
{
|
|
|
|
return eq_with(a, b, onion_routing_packet);
|
|
|
|
}
|
|
|
|
|
2021-06-10 19:54:08 +02:00
|
|
|
static bool
|
|
|
|
lease_rates_eq(const struct lease_rates *a,
|
|
|
|
const struct lease_rates *b)
|
|
|
|
{
|
|
|
|
return eq_field(a, b, channel_fee_max_base_msat)
|
|
|
|
&& eq_field(a, b, channel_fee_max_proportional_thousandths)
|
|
|
|
&& eq_field(a, b, funding_weight)
|
|
|
|
&& eq_field(a, b, lease_fee_base_sat)
|
|
|
|
&& eq_field(a, b, lease_fee_basis);
|
|
|
|
}
|
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
static bool node_announcement_eq(const struct msg_node_announcement *a,
|
|
|
|
const struct msg_node_announcement *b)
|
|
|
|
{
|
2021-06-10 19:54:08 +02:00
|
|
|
/* Both or neither */
|
|
|
|
if (!a->tlvs != !b->tlvs)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if (!a->tlvs)
|
|
|
|
goto body_check;
|
|
|
|
|
|
|
|
/* Both or neither */
|
|
|
|
if (!a->tlvs->option_will_fund != !b->tlvs->option_will_fund)
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if (a->tlvs->option_will_fund
|
|
|
|
&& !lease_rates_eq(a->tlvs->option_will_fund,
|
|
|
|
b->tlvs->option_will_fund))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
body_check:
|
2019-04-08 11:58:44 +02:00
|
|
|
return eq_with(a, b, node_id)
|
|
|
|
&& eq_field(a, b, rgb_color)
|
|
|
|
&& eq_field(a, b, alias)
|
2017-01-10 05:49:25 +01:00
|
|
|
&& eq_var(a, b, features)
|
|
|
|
&& eq_var(a, b, addresses);
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/* Try flipping each bit, try running short. */
|
2019-12-13 06:04:16 +01:00
|
|
|
#define test_bitflip_and_short(a, b, type, short_decodefail) \
|
2016-11-29 20:51:50 +01:00
|
|
|
for (i = 0; i < tal_count(msg) * 8; i++) { \
|
|
|
|
msg[i / 8] ^= (1 << (i%8)); \
|
2019-12-13 06:04:16 +01:00
|
|
|
b = fromwire_struct_##type(ctx, msg); \
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(!b || !type##_eq(a, b)); \
|
|
|
|
msg[i / 8] ^= (1 << (i%8)); \
|
|
|
|
} \
|
|
|
|
for (i = 0; i < tal_count(msg); i++) { \
|
2018-02-20 21:59:09 +01:00
|
|
|
u8 *trunc = tal_dup_arr(ctx, u8, msg, i, 0); \
|
|
|
|
b = fromwire_struct_##type(ctx, trunc); \
|
2019-12-13 06:04:16 +01:00
|
|
|
if (short_decodefail) \
|
|
|
|
assert(!b); \
|
|
|
|
else \
|
|
|
|
assert(!b || !type##_eq(a, b)); \
|
2016-11-29 20:51:50 +01:00
|
|
|
}
|
|
|
|
|
2019-12-13 06:04:16 +01:00
|
|
|
#define test_corruption(a, b, type) \
|
|
|
|
test_bitflip_and_short(a, b, type, true)
|
|
|
|
|
|
|
|
/* If it has a tlv at the end, truncated may still parse! */
|
|
|
|
#define test_corruption_tlv(a, b, type) \
|
|
|
|
test_bitflip_and_short(a, b, type, false)
|
|
|
|
|
2020-12-02 01:10:04 +01:00
|
|
|
int main(int argc, char *argv[])
|
2016-11-29 20:51:50 +01:00
|
|
|
{
|
|
|
|
struct msg_channel_announcement ca, *ca2;
|
|
|
|
struct msg_funding_locked fl, *fl2;
|
2017-02-07 02:44:14 +01:00
|
|
|
struct msg_announcement_signatures as, *as2;
|
2016-11-29 20:51:50 +01:00
|
|
|
struct msg_update_fail_htlc ufh, *ufh2;
|
2017-03-29 12:53:15 +02:00
|
|
|
struct msg_commitment_signed cs, *cs2;
|
2016-11-29 20:51:50 +01:00
|
|
|
struct msg_funding_signed fs, *fs2;
|
|
|
|
struct msg_closing_signed cls, *cls2;
|
|
|
|
struct msg_update_fulfill_htlc uflh, *uflh2;
|
|
|
|
struct msg_error e, *e2;
|
|
|
|
struct msg_init init, *init2;
|
|
|
|
struct msg_update_fee uf, *uf2;
|
|
|
|
struct msg_shutdown shutdown, *shutdown2;
|
|
|
|
struct msg_funding_created fc, *fc2;
|
|
|
|
struct msg_revoke_and_ack raa, *raa2;
|
|
|
|
struct msg_open_channel oc, *oc2;
|
|
|
|
struct msg_channel_update cu, *cu2;
|
2018-10-04 22:34:53 +02:00
|
|
|
struct msg_channel_update_opt_htlc_max cu_opt_htlc_max, *cu_opt_htlc_max2;
|
2016-11-29 20:51:50 +01:00
|
|
|
struct msg_accept_channel ac, *ac2;
|
|
|
|
struct msg_update_add_htlc uah, *uah2;
|
|
|
|
struct msg_node_announcement na, *na2;
|
|
|
|
void *ctx = tal(NULL, char);
|
2018-02-20 21:59:09 +01:00
|
|
|
size_t i;
|
2016-11-29 20:51:50 +01:00
|
|
|
u8 *msg;
|
2019-11-28 15:11:07 +01:00
|
|
|
const struct chainparams **chains;
|
2016-11-29 20:51:50 +01:00
|
|
|
|
2020-12-02 01:10:04 +01:00
|
|
|
common_setup(argv[0]);
|
2016-11-29 20:51:50 +01:00
|
|
|
|
|
|
|
memset(&ca, 2, sizeof(ca));
|
2019-04-08 11:58:44 +02:00
|
|
|
set_node_id(&ca.node_id_1);
|
|
|
|
set_node_id(&ca.node_id_2);
|
2016-11-29 20:51:50 +01:00
|
|
|
set_pubkey(&ca.bitcoin_key_1);
|
|
|
|
set_pubkey(&ca.bitcoin_key_2);
|
2017-01-04 04:39:21 +01:00
|
|
|
ca.features = tal_arr(ctx, u8, 2);
|
|
|
|
memset(ca.features, 2, 2);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_channel_announcement(ctx, &ca);
|
2018-02-20 21:59:09 +01:00
|
|
|
ca2 = fromwire_struct_channel_announcement(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(channel_announcement_eq(&ca, ca2));
|
|
|
|
test_corruption(&ca, ca2, channel_announcement);
|
|
|
|
|
|
|
|
memset(&fl, 2, sizeof(fl));
|
|
|
|
set_pubkey(&fl.next_per_commitment_point);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_funding_locked(ctx, &fl);
|
2018-02-20 21:59:09 +01:00
|
|
|
fl2 = fromwire_struct_funding_locked(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(funding_locked_eq(&fl, fl2));
|
|
|
|
test_corruption(&fl, fl2, funding_locked);
|
2017-02-07 02:44:14 +01:00
|
|
|
|
|
|
|
memset(&as, 2, sizeof(as));
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-02-07 02:44:14 +01:00
|
|
|
msg = towire_struct_announcement_signatures(ctx, &as);
|
2018-02-20 21:59:09 +01:00
|
|
|
as2 = fromwire_struct_announcement_signatures(ctx, msg);
|
2017-02-07 02:44:14 +01:00
|
|
|
assert(announcement_signatures_eq(&as, as2));
|
|
|
|
test_corruption(&as, as2, announcement_signatures);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
memset(&ufh, 2, sizeof(ufh));
|
2017-01-06 04:28:39 +01:00
|
|
|
ufh.reason = tal_arr(ctx, u8, 2);
|
|
|
|
memset(ufh.reason, 2, 2);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_update_fail_htlc(ctx, &ufh);
|
2018-02-20 21:59:09 +01:00
|
|
|
ufh2 = fromwire_struct_update_fail_htlc(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(update_fail_htlc_eq(&ufh, ufh2));
|
|
|
|
test_corruption(&ufh, ufh2, update_fail_htlc);
|
|
|
|
|
|
|
|
memset(&cs, 2, sizeof(cs));
|
2017-01-25 00:33:42 +01:00
|
|
|
cs.htlc_signature = tal_arr(ctx, secp256k1_ecdsa_signature, 2);
|
|
|
|
memset(cs.htlc_signature, 2, sizeof(secp256k1_ecdsa_signature)*2);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-03-29 12:53:15 +02:00
|
|
|
msg = towire_struct_commitment_signed(ctx, &cs);
|
2018-02-20 21:59:09 +01:00
|
|
|
cs2 = fromwire_struct_commitment_signed(ctx, msg);
|
2017-03-29 12:53:15 +02:00
|
|
|
assert(commitment_signed_eq(&cs, cs2));
|
|
|
|
test_corruption(&cs, cs2, commitment_signed);
|
2016-11-29 20:51:50 +01:00
|
|
|
|
|
|
|
memset(&fs, 2, sizeof(fs));
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_funding_signed(ctx, &fs);
|
2018-02-20 21:59:09 +01:00
|
|
|
fs2 = fromwire_struct_funding_signed(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(funding_signed_eq(&fs, fs2));
|
|
|
|
test_corruption(&fs, fs2, funding_signed);
|
|
|
|
|
|
|
|
memset(&cls, 2, sizeof(cls));
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_closing_signed(ctx, &cls);
|
2018-02-20 21:59:09 +01:00
|
|
|
cls2 = fromwire_struct_closing_signed(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(closing_signed_eq(&cls, cls2));
|
|
|
|
test_corruption(&cls, cls2, closing_signed);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
memset(&uflh, 2, sizeof(uflh));
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_update_fulfill_htlc(ctx, &uflh);
|
2018-02-20 21:59:09 +01:00
|
|
|
uflh2 = fromwire_struct_update_fulfill_htlc(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(update_fulfill_htlc_eq(&uflh, uflh2));
|
|
|
|
test_corruption(&uflh, uflh2, update_fulfill_htlc);
|
|
|
|
|
|
|
|
memset(&e, 2, sizeof(e));
|
|
|
|
e.data = tal_arr(ctx, u8, 2);
|
|
|
|
memset(e.data, 2, 2);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_error(ctx, &e);
|
2018-02-20 21:59:09 +01:00
|
|
|
e2 = fromwire_struct_error(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(error_eq(&e, e2));
|
|
|
|
test_corruption(&e, e2, error);
|
|
|
|
|
2019-11-28 15:11:07 +01:00
|
|
|
chains = chainparams_for_networks(ctx);
|
|
|
|
for (i = 0; i < tal_count(chains); i++) {
|
|
|
|
memset(&init, 2, sizeof(init));
|
|
|
|
init.globalfeatures = tal_arr(ctx, u8, 2);
|
|
|
|
memset(init.globalfeatures, 2, 2);
|
|
|
|
init.localfeatures = tal_arr(ctx, u8, 2);
|
|
|
|
memset(init.localfeatures, 2, 2);
|
|
|
|
init.tlvs = tlv_init_tlvs_new(ctx);
|
2020-05-06 12:41:54 +02:00
|
|
|
init.tlvs->networks = tal_arr(init.tlvs, struct bitcoin_blkid, 1);
|
|
|
|
init.tlvs->networks[0] = chains[i]->genesis_blockhash;
|
2019-11-28 15:11:07 +01:00
|
|
|
msg = towire_struct_init(ctx, &init);
|
|
|
|
init2 = fromwire_struct_init(ctx, msg);
|
|
|
|
assert(init_eq(&init, init2));
|
2019-12-13 06:04:16 +01:00
|
|
|
test_corruption_tlv(&init, init2, init);
|
2019-11-28 15:11:07 +01:00
|
|
|
}
|
2016-11-29 20:51:50 +01:00
|
|
|
|
|
|
|
memset(&uf, 2, sizeof(uf));
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_update_fee(ctx, &uf);
|
2018-02-20 21:59:09 +01:00
|
|
|
uf2 = fromwire_struct_update_fee(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(update_fee_eq(&uf, uf2));
|
|
|
|
test_corruption(&uf, uf2, update_fee);
|
|
|
|
|
|
|
|
memset(&shutdown, 2, sizeof(shutdown));
|
|
|
|
shutdown.scriptpubkey = tal_arr(ctx, u8, 2);
|
|
|
|
memset(shutdown.scriptpubkey, 2, 2);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_shutdown(ctx, &shutdown);
|
2018-02-20 21:59:09 +01:00
|
|
|
shutdown2 = fromwire_struct_shutdown(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(shutdown_eq(&shutdown, shutdown2));
|
|
|
|
test_corruption(&shutdown, shutdown2, shutdown);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
memset(&fc, 2, sizeof(fc));
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_funding_created(ctx, &fc);
|
2018-02-20 21:59:09 +01:00
|
|
|
fc2 = fromwire_struct_funding_created(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(funding_created_eq(&fc, fc2));
|
|
|
|
test_corruption(&fc, fc2, funding_created);
|
|
|
|
|
|
|
|
memset(&raa, 2, sizeof(raa));
|
|
|
|
set_pubkey(&raa.next_per_commitment_point);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_revoke_and_ack(ctx, &raa);
|
2018-02-20 21:59:09 +01:00
|
|
|
raa2 = fromwire_struct_revoke_and_ack(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(revoke_and_ack_eq(&raa, raa2));
|
|
|
|
test_corruption(&raa, raa2, revoke_and_ack);
|
|
|
|
|
|
|
|
memset(&oc, 2, sizeof(oc));
|
|
|
|
set_pubkey(&oc.funding_pubkey);
|
|
|
|
set_pubkey(&oc.revocation_basepoint);
|
|
|
|
set_pubkey(&oc.payment_basepoint);
|
|
|
|
set_pubkey(&oc.delayed_payment_basepoint);
|
2017-11-15 10:25:19 +01:00
|
|
|
set_pubkey(&oc.htlc_basepoint);
|
2016-11-29 20:51:50 +01:00
|
|
|
set_pubkey(&oc.first_per_commitment_point);
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_open_channel(ctx, &oc);
|
2018-02-20 21:59:09 +01:00
|
|
|
oc2 = fromwire_struct_open_channel(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(open_channel_eq(&oc, oc2));
|
|
|
|
test_corruption(&oc, oc2, open_channel);
|
|
|
|
|
|
|
|
memset(&cu, 2, sizeof(cu));
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_channel_update(ctx, &cu);
|
2018-02-20 21:59:09 +01:00
|
|
|
cu2 = fromwire_struct_channel_update(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(channel_update_eq(&cu, cu2));
|
|
|
|
test_corruption(&cu, cu2, channel_update);
|
|
|
|
|
2018-10-04 22:34:53 +02:00
|
|
|
memset(&cu_opt_htlc_max, 2, sizeof(cu_opt_htlc_max));
|
|
|
|
|
|
|
|
msg = towire_struct_channel_update_opt_htlc_max(ctx, &cu_opt_htlc_max);
|
|
|
|
cu_opt_htlc_max2 = fromwire_struct_channel_update_opt_htlc_max(ctx, msg);
|
|
|
|
assert(channel_update_opt_htlc_max_eq(&cu_opt_htlc_max, cu_opt_htlc_max2));
|
|
|
|
test_corruption(&cu_opt_htlc_max, cu_opt_htlc_max2, channel_update_opt_htlc_max);
|
|
|
|
|
2016-11-29 20:51:50 +01:00
|
|
|
memset(&ac, 2, sizeof(ac));
|
|
|
|
set_pubkey(&ac.funding_pubkey);
|
|
|
|
set_pubkey(&ac.revocation_basepoint);
|
|
|
|
set_pubkey(&ac.payment_basepoint);
|
|
|
|
set_pubkey(&ac.delayed_payment_basepoint);
|
2017-11-15 10:25:19 +01:00
|
|
|
set_pubkey(&ac.htlc_basepoint);
|
2016-11-29 20:51:50 +01:00
|
|
|
set_pubkey(&ac.first_per_commitment_point);
|
2020-06-22 07:06:03 +02:00
|
|
|
ac.tlvs = NULL;
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_accept_channel(ctx, &ac);
|
2018-02-20 21:59:09 +01:00
|
|
|
ac2 = fromwire_struct_accept_channel(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(accept_channel_eq(&ac, ac2));
|
|
|
|
test_corruption(&ac, ac2, accept_channel);
|
|
|
|
|
|
|
|
memset(&uah, 2, sizeof(uah));
|
2017-08-28 18:12:01 +02:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_update_add_htlc(ctx, &uah);
|
2018-02-20 21:59:09 +01:00
|
|
|
uah2 = fromwire_struct_update_add_htlc(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(update_add_htlc_eq(&uah, uah2));
|
|
|
|
test_corruption(&uah, uah2, update_add_htlc);
|
|
|
|
|
|
|
|
memset(&na, 2, sizeof(na));
|
2019-04-08 11:58:44 +02:00
|
|
|
set_node_id(&na.node_id);
|
2017-01-04 04:39:21 +01:00
|
|
|
na.features = tal_arr(ctx, u8, 2);
|
|
|
|
memset(na.features, 2, 2);
|
2017-01-04 04:39:21 +01:00
|
|
|
na.addresses = tal_arr(ctx, u8, 2);
|
|
|
|
memset(na.addresses, 2, 2);
|
2021-06-10 19:54:08 +02:00
|
|
|
na.tlvs= tlv_node_ann_tlvs_new(ctx);
|
|
|
|
na.tlvs->option_will_fund = tal(ctx, struct lease_rates);
|
|
|
|
memset(na.tlvs->option_will_fund, 2,
|
|
|
|
sizeof(*na.tlvs->option_will_fund));
|
2016-11-29 20:51:50 +01:00
|
|
|
|
2017-01-04 04:39:20 +01:00
|
|
|
msg = towire_struct_node_announcement(ctx, &na);
|
2018-02-20 21:59:09 +01:00
|
|
|
na2 = fromwire_struct_node_announcement(ctx, msg);
|
2016-11-29 20:51:50 +01:00
|
|
|
assert(node_announcement_eq(&na, na2));
|
2021-06-10 19:54:08 +02:00
|
|
|
test_corruption_tlv(&na, na2, node_announcement);
|
2016-11-29 20:51:50 +01:00
|
|
|
|
|
|
|
tal_free(ctx);
|
2020-12-02 01:10:04 +01:00
|
|
|
common_shutdown();
|
2016-11-29 20:51:50 +01:00
|
|
|
return 0;
|
|
|
|
}
|