mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-01 03:24:41 +01:00
9f8a6e2314
It handles all the cases of retransmission, and in the normal case retransmits shutdown and immediately returns for us to run closingd. This is actually far simpler and reduces code duplication. [ Includes fixup to stop warn_unused_result from Christian ] Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> Changelog-Fixed: Protocol: We could get stuck on signature exchange if we needed to retransmit the final revoke_and_ack.
1005 lines
51 KiB
C
1005 lines
51 KiB
C
#include "../invoice.c"
|
|
#include "../peer_control.c"
|
|
#include "../routehint.c"
|
|
#include <ccan/alignof/alignof.h>
|
|
#include <common/errcode.h>
|
|
#include <common/setup.h>
|
|
|
|
bool deprecated_apis = false;
|
|
|
|
/* AUTOGENERATED MOCKS START */
|
|
/* Generated stub for active_channel_by_scid */
|
|
struct channel *active_channel_by_scid(struct lightningd *ld UNNEEDED,
|
|
const struct short_channel_id *scid UNNEEDED)
|
|
{ fprintf(stderr, "active_channel_by_scid called!\n"); abort(); }
|
|
/* Generated stub for bitcoind_getutxout_ */
|
|
void bitcoind_getutxout_(struct bitcoind *bitcoind UNNEEDED,
|
|
const struct bitcoin_txid *txid UNNEEDED, const u32 outnum UNNEEDED,
|
|
void (*cb)(struct bitcoind *bitcoind UNNEEDED,
|
|
const struct bitcoin_tx_output *txout UNNEEDED,
|
|
void *arg) UNNEEDED,
|
|
void *arg UNNEEDED)
|
|
{ fprintf(stderr, "bitcoind_getutxout_ called!\n"); abort(); }
|
|
/* Generated stub for bolt11_decode */
|
|
struct bolt11 *bolt11_decode(const tal_t *ctx UNNEEDED, const char *str UNNEEDED,
|
|
const struct feature_set *our_features UNNEEDED,
|
|
const char *description UNNEEDED,
|
|
const struct chainparams *must_be_chain UNNEEDED,
|
|
char **fail UNNEEDED)
|
|
{ fprintf(stderr, "bolt11_decode called!\n"); abort(); }
|
|
/* Generated stub for bolt11_decode_nosig */
|
|
struct bolt11 *bolt11_decode_nosig(const tal_t *ctx UNNEEDED, const char *str UNNEEDED,
|
|
const struct feature_set *our_features UNNEEDED,
|
|
const char *description UNNEEDED,
|
|
const struct chainparams *must_be_chain UNNEEDED,
|
|
struct sha256 *hash UNNEEDED,
|
|
u5 **sig UNNEEDED,
|
|
bool *have_n UNNEEDED,
|
|
char **fail UNNEEDED)
|
|
{ fprintf(stderr, "bolt11_decode_nosig called!\n"); abort(); }
|
|
/* Generated stub for bolt11_encode_ */
|
|
char *bolt11_encode_(const tal_t *ctx UNNEEDED,
|
|
const struct bolt11 *b11 UNNEEDED, bool n_field UNNEEDED,
|
|
bool (*sign)(const u5 *u5bytes UNNEEDED,
|
|
const u8 *hrpu8 UNNEEDED,
|
|
secp256k1_ecdsa_recoverable_signature *rsig UNNEEDED,
|
|
void *arg) UNNEEDED,
|
|
void *arg UNNEEDED)
|
|
{ fprintf(stderr, "bolt11_encode_ called!\n"); abort(); }
|
|
/* Generated stub for broadcast_tx */
|
|
void broadcast_tx(struct chain_topology *topo UNNEEDED,
|
|
struct channel *channel UNNEEDED, const struct bitcoin_tx *tx UNNEEDED,
|
|
void (*failed)(struct channel *channel UNNEEDED,
|
|
bool success UNNEEDED,
|
|
const char *err))
|
|
{ fprintf(stderr, "broadcast_tx called!\n"); abort(); }
|
|
/* Generated stub for channel_change_state_reason_str */
|
|
const char *channel_change_state_reason_str(enum state_change reason UNNEEDED)
|
|
{ fprintf(stderr, "channel_change_state_reason_str called!\n"); abort(); }
|
|
/* Generated stub for channel_cleanup_commands */
|
|
void channel_cleanup_commands(struct channel *channel UNNEEDED, const char *why UNNEEDED)
|
|
{ fprintf(stderr, "channel_cleanup_commands called!\n"); abort(); }
|
|
/* Generated stub for channel_fail_forget */
|
|
void channel_fail_forget(struct channel *channel UNNEEDED, const char *fmt UNNEEDED, ...)
|
|
{ fprintf(stderr, "channel_fail_forget called!\n"); abort(); }
|
|
/* Generated stub for channel_fail_permanent */
|
|
void channel_fail_permanent(struct channel *channel UNNEEDED,
|
|
enum state_change reason UNNEEDED,
|
|
const char *fmt UNNEEDED,
|
|
...)
|
|
{ fprintf(stderr, "channel_fail_permanent called!\n"); abort(); }
|
|
/* Generated stub for channel_fail_reconnect */
|
|
void channel_fail_reconnect(struct channel *channel UNNEEDED,
|
|
const char *fmt UNNEEDED, ...)
|
|
{ fprintf(stderr, "channel_fail_reconnect called!\n"); abort(); }
|
|
/* Generated stub for channel_fail_reconnect_later */
|
|
void channel_fail_reconnect_later(struct channel *channel UNNEEDED,
|
|
const char *fmt UNNEEDED,...)
|
|
{ fprintf(stderr, "channel_fail_reconnect_later called!\n"); abort(); }
|
|
/* Generated stub for channel_has_htlc_in */
|
|
struct htlc_in *channel_has_htlc_in(struct channel *channel UNNEEDED)
|
|
{ fprintf(stderr, "channel_has_htlc_in called!\n"); abort(); }
|
|
/* Generated stub for channel_has_htlc_out */
|
|
struct htlc_out *channel_has_htlc_out(struct channel *channel UNNEEDED)
|
|
{ fprintf(stderr, "channel_has_htlc_out called!\n"); abort(); }
|
|
/* Generated stub for channel_inflight_find */
|
|
struct channel_inflight *channel_inflight_find(struct channel *channel UNNEEDED,
|
|
const struct bitcoin_txid *txid UNNEEDED)
|
|
{ fprintf(stderr, "channel_inflight_find called!\n"); abort(); }
|
|
/* Generated stub for channel_internal_error */
|
|
void channel_internal_error(struct channel *channel UNNEEDED, const char *fmt UNNEEDED, ...)
|
|
{ fprintf(stderr, "channel_internal_error called!\n"); abort(); }
|
|
/* Generated stub for channel_last_funding_feerate */
|
|
u32 channel_last_funding_feerate(const struct channel *channel UNNEEDED)
|
|
{ fprintf(stderr, "channel_last_funding_feerate called!\n"); abort(); }
|
|
/* Generated stub for channel_set_billboard */
|
|
void channel_set_billboard(struct channel *channel UNNEEDED, bool perm UNNEEDED,
|
|
const char *str TAKES UNNEEDED)
|
|
{ fprintf(stderr, "channel_set_billboard called!\n"); abort(); }
|
|
/* Generated stub for channel_set_last_tx */
|
|
void channel_set_last_tx(struct channel *channel UNNEEDED,
|
|
struct bitcoin_tx *tx UNNEEDED,
|
|
const struct bitcoin_signature *sig UNNEEDED,
|
|
enum wallet_tx_type type UNNEEDED)
|
|
{ fprintf(stderr, "channel_set_last_tx called!\n"); abort(); }
|
|
/* Generated stub for channel_set_state */
|
|
void channel_set_state(struct channel *channel UNNEEDED,
|
|
enum channel_state old_state UNNEEDED,
|
|
enum channel_state state UNNEEDED,
|
|
enum state_change reason UNNEEDED,
|
|
char *why UNNEEDED)
|
|
{ fprintf(stderr, "channel_set_state called!\n"); abort(); }
|
|
/* Generated stub for channel_state_name */
|
|
const char *channel_state_name(const struct channel *channel UNNEEDED)
|
|
{ fprintf(stderr, "channel_state_name called!\n"); abort(); }
|
|
/* Generated stub for channel_state_str */
|
|
const char *channel_state_str(enum channel_state state UNNEEDED)
|
|
{ fprintf(stderr, "channel_state_str called!\n"); abort(); }
|
|
/* Generated stub for channel_tell_depth */
|
|
bool channel_tell_depth(struct lightningd *ld UNNEEDED,
|
|
struct channel *channel UNNEEDED,
|
|
const struct bitcoin_txid *txid UNNEEDED,
|
|
u32 depth UNNEEDED)
|
|
{ fprintf(stderr, "channel_tell_depth called!\n"); abort(); }
|
|
/* Generated stub for channel_unsaved_close_conn */
|
|
void channel_unsaved_close_conn(struct channel *channel UNNEEDED, const char *why UNNEEDED)
|
|
{ fprintf(stderr, "channel_unsaved_close_conn called!\n"); abort(); }
|
|
/* Generated stub for channel_update_reserve */
|
|
void channel_update_reserve(struct channel *channel UNNEEDED,
|
|
struct channel_config *their_config UNNEEDED,
|
|
struct amount_sat funding_total UNNEEDED)
|
|
{ fprintf(stderr, "channel_update_reserve called!\n"); abort(); }
|
|
/* Generated stub for command_fail */
|
|
struct command_result *command_fail(struct command *cmd UNNEEDED, errcode_t code UNNEEDED,
|
|
const char *fmt UNNEEDED, ...)
|
|
|
|
{ fprintf(stderr, "command_fail called!\n"); abort(); }
|
|
/* Generated stub for command_failed */
|
|
struct command_result *command_failed(struct command *cmd UNNEEDED,
|
|
struct json_stream *result)
|
|
|
|
{ fprintf(stderr, "command_failed called!\n"); abort(); }
|
|
/* Generated stub for command_its_complicated */
|
|
struct command_result *command_its_complicated(const char *why UNNEEDED)
|
|
{ fprintf(stderr, "command_its_complicated called!\n"); abort(); }
|
|
/* Generated stub for command_param_failed */
|
|
struct command_result *command_param_failed(void)
|
|
|
|
{ fprintf(stderr, "command_param_failed called!\n"); abort(); }
|
|
/* Generated stub for command_still_pending */
|
|
struct command_result *command_still_pending(struct command *cmd)
|
|
|
|
{ fprintf(stderr, "command_still_pending called!\n"); abort(); }
|
|
/* Generated stub for command_success */
|
|
struct command_result *command_success(struct command *cmd UNNEEDED,
|
|
struct json_stream *response)
|
|
|
|
{ fprintf(stderr, "command_success called!\n"); abort(); }
|
|
/* Generated stub for connect_succeeded */
|
|
void connect_succeeded(struct lightningd *ld UNNEEDED, const struct peer *peer UNNEEDED,
|
|
bool incoming UNNEEDED,
|
|
const struct wireaddr_internal *addr UNNEEDED)
|
|
{ fprintf(stderr, "connect_succeeded called!\n"); abort(); }
|
|
/* Generated stub for db_begin_transaction_ */
|
|
void db_begin_transaction_(struct db *db UNNEEDED, const char *location UNNEEDED)
|
|
{ fprintf(stderr, "db_begin_transaction_ called!\n"); abort(); }
|
|
/* Generated stub for db_commit_transaction */
|
|
void db_commit_transaction(struct db *db UNNEEDED)
|
|
{ fprintf(stderr, "db_commit_transaction called!\n"); abort(); }
|
|
/* Generated stub for delay_then_reconnect */
|
|
void delay_then_reconnect(struct channel *channel UNNEEDED, u32 seconds_delay UNNEEDED,
|
|
const struct wireaddr_internal *addrhint TAKES UNNEEDED)
|
|
{ fprintf(stderr, "delay_then_reconnect called!\n"); abort(); }
|
|
/* Generated stub for delete_channel */
|
|
void delete_channel(struct channel *channel STEALS UNNEEDED)
|
|
{ fprintf(stderr, "delete_channel called!\n"); abort(); }
|
|
/* Generated stub for encode_scriptpubkey_to_addr */
|
|
char *encode_scriptpubkey_to_addr(const tal_t *ctx UNNEEDED,
|
|
const struct chainparams *chainparams UNNEEDED,
|
|
const u8 *scriptPubkey UNNEEDED)
|
|
{ fprintf(stderr, "encode_scriptpubkey_to_addr called!\n"); abort(); }
|
|
/* Generated stub for failmsg_incorrect_or_unknown_ */
|
|
const u8 *failmsg_incorrect_or_unknown_(const tal_t *ctx UNNEEDED,
|
|
struct lightningd *ld UNNEEDED,
|
|
const struct htlc_in *hin UNNEEDED,
|
|
const char *file UNNEEDED, int line UNNEEDED)
|
|
{ fprintf(stderr, "failmsg_incorrect_or_unknown_ called!\n"); abort(); }
|
|
/* Generated stub for fatal */
|
|
void fatal(const char *fmt UNNEEDED, ...)
|
|
{ fprintf(stderr, "fatal called!\n"); abort(); }
|
|
/* Generated stub for feature_is_set */
|
|
bool feature_is_set(const u8 *features UNNEEDED, size_t bit UNNEEDED)
|
|
{ fprintf(stderr, "feature_is_set called!\n"); abort(); }
|
|
/* Generated stub for feature_negotiated */
|
|
bool feature_negotiated(const struct feature_set *our_features UNNEEDED,
|
|
const u8 *their_features UNNEEDED, size_t f UNNEEDED)
|
|
{ fprintf(stderr, "feature_negotiated called!\n"); abort(); }
|
|
/* Generated stub for feature_offered */
|
|
bool feature_offered(const u8 *features UNNEEDED, size_t f UNNEEDED)
|
|
{ fprintf(stderr, "feature_offered called!\n"); abort(); }
|
|
/* Generated stub for find_plugin_for_command */
|
|
struct plugin *find_plugin_for_command(struct lightningd *ld UNNEEDED,
|
|
const char *cmd_name UNNEEDED)
|
|
{ fprintf(stderr, "find_plugin_for_command called!\n"); abort(); }
|
|
/* Generated stub for fixup_htlcs_out */
|
|
void fixup_htlcs_out(struct lightningd *ld UNNEEDED)
|
|
{ fprintf(stderr, "fixup_htlcs_out called!\n"); abort(); }
|
|
/* Generated stub for fromwire_bigsize */
|
|
bigsize_t fromwire_bigsize(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
|
|
{ fprintf(stderr, "fromwire_bigsize called!\n"); abort(); }
|
|
/* Generated stub for fromwire_channel_id */
|
|
void fromwire_channel_id(const u8 **cursor UNNEEDED, size_t *max UNNEEDED,
|
|
struct channel_id *channel_id UNNEEDED)
|
|
{ fprintf(stderr, "fromwire_channel_id called!\n"); abort(); }
|
|
/* Generated stub for fromwire_channeld_dev_memleak_reply */
|
|
bool fromwire_channeld_dev_memleak_reply(const void *p UNNEEDED, bool *leak UNNEEDED)
|
|
{ fprintf(stderr, "fromwire_channeld_dev_memleak_reply called!\n"); abort(); }
|
|
/* Generated stub for fromwire_connectd_peer_connected */
|
|
bool fromwire_connectd_peer_connected(const tal_t *ctx UNNEEDED, const void *p UNNEEDED, struct node_id *id UNNEEDED, struct wireaddr_internal *addr UNNEEDED, bool *incoming UNNEEDED, struct per_peer_state **pps UNNEEDED, u8 **features UNNEEDED)
|
|
{ fprintf(stderr, "fromwire_connectd_peer_connected called!\n"); abort(); }
|
|
/* Generated stub for fromwire_hsmd_sign_bolt12_reply */
|
|
bool fromwire_hsmd_sign_bolt12_reply(const void *p UNNEEDED, struct bip340sig *sig UNNEEDED)
|
|
{ fprintf(stderr, "fromwire_hsmd_sign_bolt12_reply called!\n"); abort(); }
|
|
/* Generated stub for fromwire_hsmd_sign_commitment_tx_reply */
|
|
bool fromwire_hsmd_sign_commitment_tx_reply(const void *p UNNEEDED, struct bitcoin_signature *sig UNNEEDED)
|
|
{ fprintf(stderr, "fromwire_hsmd_sign_commitment_tx_reply called!\n"); abort(); }
|
|
/* Generated stub for fromwire_hsmd_sign_invoice_reply */
|
|
bool fromwire_hsmd_sign_invoice_reply(const void *p UNNEEDED, secp256k1_ecdsa_recoverable_signature *sig UNNEEDED)
|
|
{ fprintf(stderr, "fromwire_hsmd_sign_invoice_reply called!\n"); abort(); }
|
|
/* Generated stub for fromwire_node_id */
|
|
void fromwire_node_id(const u8 **cursor UNNEEDED, size_t *max UNNEEDED, struct node_id *id UNNEEDED)
|
|
{ fprintf(stderr, "fromwire_node_id called!\n"); abort(); }
|
|
/* Generated stub for fromwire_onchaind_dev_memleak_reply */
|
|
bool fromwire_onchaind_dev_memleak_reply(const void *p UNNEEDED, bool *leak UNNEEDED)
|
|
{ fprintf(stderr, "fromwire_onchaind_dev_memleak_reply called!\n"); abort(); }
|
|
/* Generated stub for get_block_height */
|
|
u32 get_block_height(const struct chain_topology *topo UNNEEDED)
|
|
{ fprintf(stderr, "get_block_height called!\n"); abort(); }
|
|
/* Generated stub for get_feerate */
|
|
u32 get_feerate(const struct fee_states *fee_states UNNEEDED,
|
|
enum side opener UNNEEDED,
|
|
enum side side UNNEEDED)
|
|
{ fprintf(stderr, "get_feerate called!\n"); abort(); }
|
|
/* Generated stub for hash_htlc_key */
|
|
size_t hash_htlc_key(const struct htlc_key *htlc_key UNNEEDED)
|
|
{ fprintf(stderr, "hash_htlc_key called!\n"); abort(); }
|
|
/* Generated stub for htlc_is_trimmed */
|
|
bool htlc_is_trimmed(enum side htlc_owner UNNEEDED,
|
|
struct amount_msat htlc_amount UNNEEDED,
|
|
u32 feerate_per_kw UNNEEDED,
|
|
struct amount_sat dust_limit UNNEEDED,
|
|
enum side side UNNEEDED,
|
|
bool option_anchor_outputs UNNEEDED)
|
|
{ fprintf(stderr, "htlc_is_trimmed called!\n"); abort(); }
|
|
/* Generated stub for htlc_set_fail */
|
|
void htlc_set_fail(struct htlc_set *set UNNEEDED, const u8 *failmsg TAKES UNNEEDED)
|
|
{ fprintf(stderr, "htlc_set_fail called!\n"); abort(); }
|
|
/* Generated stub for htlc_set_fulfill */
|
|
void htlc_set_fulfill(struct htlc_set *set UNNEEDED, const struct preimage *preimage UNNEEDED)
|
|
{ fprintf(stderr, "htlc_set_fulfill called!\n"); abort(); }
|
|
/* Generated stub for invoice_decode */
|
|
struct tlv_invoice *invoice_decode(const tal_t *ctx UNNEEDED,
|
|
const char *b12 UNNEEDED, size_t b12len UNNEEDED,
|
|
const struct feature_set *our_features UNNEEDED,
|
|
const struct chainparams *must_be_chain UNNEEDED,
|
|
char **fail UNNEEDED)
|
|
{ fprintf(stderr, "invoice_decode called!\n"); abort(); }
|
|
/* Generated stub for invoice_decode_nosig */
|
|
struct tlv_invoice *invoice_decode_nosig(const tal_t *ctx UNNEEDED,
|
|
const char *b12 UNNEEDED, size_t b12len UNNEEDED,
|
|
const struct feature_set *our_features UNNEEDED,
|
|
const struct chainparams *must_be_chain UNNEEDED,
|
|
char **fail UNNEEDED)
|
|
{ fprintf(stderr, "invoice_decode_nosig called!\n"); abort(); }
|
|
/* Generated stub for invoice_encode */
|
|
char *invoice_encode(const tal_t *ctx UNNEEDED, const struct tlv_invoice *bolt12_tlv UNNEEDED)
|
|
{ fprintf(stderr, "invoice_encode called!\n"); abort(); }
|
|
/* Generated stub for json_add_address */
|
|
void json_add_address(struct json_stream *response UNNEEDED, const char *fieldname UNNEEDED,
|
|
const struct wireaddr *addr UNNEEDED)
|
|
{ fprintf(stderr, "json_add_address called!\n"); abort(); }
|
|
/* Generated stub for json_add_address_internal */
|
|
void json_add_address_internal(struct json_stream *response UNNEEDED,
|
|
const char *fieldname UNNEEDED,
|
|
const struct wireaddr_internal *addr UNNEEDED)
|
|
{ fprintf(stderr, "json_add_address_internal called!\n"); abort(); }
|
|
/* Generated stub for json_add_amount_msat_compat */
|
|
void json_add_amount_msat_compat(struct json_stream *result UNNEEDED,
|
|
struct amount_msat msat UNNEEDED,
|
|
const char *rawfieldname UNNEEDED,
|
|
const char *msatfieldname)
|
|
|
|
{ fprintf(stderr, "json_add_amount_msat_compat called!\n"); abort(); }
|
|
/* Generated stub for json_add_amount_msat_only */
|
|
void json_add_amount_msat_only(struct json_stream *result UNNEEDED,
|
|
const char *msatfieldname UNNEEDED,
|
|
struct amount_msat msat)
|
|
|
|
{ fprintf(stderr, "json_add_amount_msat_only called!\n"); abort(); }
|
|
/* Generated stub for json_add_amount_sat_compat */
|
|
void json_add_amount_sat_compat(struct json_stream *result UNNEEDED,
|
|
struct amount_sat sat UNNEEDED,
|
|
const char *rawfieldname UNNEEDED,
|
|
const char *msatfieldname)
|
|
|
|
{ fprintf(stderr, "json_add_amount_sat_compat called!\n"); abort(); }
|
|
/* Generated stub for json_add_amount_sat_only */
|
|
void json_add_amount_sat_only(struct json_stream *result UNNEEDED,
|
|
const char *msatfieldname UNNEEDED,
|
|
struct amount_sat sat)
|
|
|
|
{ fprintf(stderr, "json_add_amount_sat_only called!\n"); abort(); }
|
|
/* Generated stub for json_add_bolt11 */
|
|
void json_add_bolt11(struct json_stream *response UNNEEDED,
|
|
const struct bolt11 *b11 UNNEEDED)
|
|
{ fprintf(stderr, "json_add_bolt11 called!\n"); abort(); }
|
|
/* Generated stub for json_add_log */
|
|
void json_add_log(struct json_stream *result UNNEEDED,
|
|
const struct log_book *lr UNNEEDED,
|
|
const struct node_id *node_id UNNEEDED,
|
|
enum log_level minlevel UNNEEDED)
|
|
{ fprintf(stderr, "json_add_log called!\n"); abort(); }
|
|
/* Generated stub for json_add_member */
|
|
void json_add_member(struct json_stream *js UNNEEDED,
|
|
const char *fieldname UNNEEDED,
|
|
bool quote UNNEEDED,
|
|
const char *fmt UNNEEDED, ...)
|
|
{ fprintf(stderr, "json_add_member called!\n"); abort(); }
|
|
/* Generated stub for json_add_node_id */
|
|
void json_add_node_id(struct json_stream *response UNNEEDED,
|
|
const char *fieldname UNNEEDED,
|
|
const struct node_id *id UNNEEDED)
|
|
{ fprintf(stderr, "json_add_node_id called!\n"); abort(); }
|
|
/* Generated stub for json_add_preimage */
|
|
void json_add_preimage(struct json_stream *result UNNEEDED, const char *fieldname UNNEEDED,
|
|
const struct preimage *preimage UNNEEDED)
|
|
{ fprintf(stderr, "json_add_preimage called!\n"); abort(); }
|
|
/* Generated stub for json_add_sha256 */
|
|
void json_add_sha256(struct json_stream *result UNNEEDED, const char *fieldname UNNEEDED,
|
|
const struct sha256 *hash UNNEEDED)
|
|
{ fprintf(stderr, "json_add_sha256 called!\n"); abort(); }
|
|
/* Generated stub for json_add_short_channel_id */
|
|
void json_add_short_channel_id(struct json_stream *response UNNEEDED,
|
|
const char *fieldname UNNEEDED,
|
|
const struct short_channel_id *id UNNEEDED)
|
|
{ fprintf(stderr, "json_add_short_channel_id called!\n"); abort(); }
|
|
/* Generated stub for json_add_tx */
|
|
void json_add_tx(struct json_stream *result UNNEEDED,
|
|
const char *fieldname UNNEEDED,
|
|
const struct bitcoin_tx *tx UNNEEDED)
|
|
{ fprintf(stderr, "json_add_tx called!\n"); abort(); }
|
|
/* Generated stub for json_add_txid */
|
|
void json_add_txid(struct json_stream *result UNNEEDED, const char *fieldname UNNEEDED,
|
|
const struct bitcoin_txid *txid UNNEEDED)
|
|
{ fprintf(stderr, "json_add_txid called!\n"); abort(); }
|
|
/* Generated stub for json_add_uncommitted_channel */
|
|
void json_add_uncommitted_channel(struct json_stream *response UNNEEDED,
|
|
const struct uncommitted_channel *uc UNNEEDED)
|
|
{ fprintf(stderr, "json_add_uncommitted_channel called!\n"); abort(); }
|
|
/* Generated stub for json_add_unsaved_channel */
|
|
void json_add_unsaved_channel(struct json_stream *response UNNEEDED,
|
|
const struct channel *channel UNNEEDED)
|
|
{ fprintf(stderr, "json_add_unsaved_channel called!\n"); abort(); }
|
|
/* Generated stub for json_array_end */
|
|
void json_array_end(struct json_stream *js UNNEEDED)
|
|
{ fprintf(stderr, "json_array_end called!\n"); abort(); }
|
|
/* Generated stub for json_array_start */
|
|
void json_array_start(struct json_stream *js UNNEEDED, const char *fieldname UNNEEDED)
|
|
{ fprintf(stderr, "json_array_start called!\n"); abort(); }
|
|
/* Generated stub for json_member_direct */
|
|
char *json_member_direct(struct json_stream *js UNNEEDED,
|
|
const char *fieldname UNNEEDED, size_t extra UNNEEDED)
|
|
{ fprintf(stderr, "json_member_direct called!\n"); abort(); }
|
|
/* Generated stub for json_notify_fmt */
|
|
void json_notify_fmt(struct command *cmd UNNEEDED,
|
|
enum log_level level UNNEEDED,
|
|
const char *fmt UNNEEDED, ...)
|
|
|
|
{ fprintf(stderr, "json_notify_fmt called!\n"); abort(); }
|
|
/* Generated stub for json_object_end */
|
|
void json_object_end(struct json_stream *js UNNEEDED)
|
|
{ fprintf(stderr, "json_object_end called!\n"); abort(); }
|
|
/* Generated stub for json_object_start */
|
|
void json_object_start(struct json_stream *ks UNNEEDED, const char *fieldname UNNEEDED)
|
|
{ fprintf(stderr, "json_object_start called!\n"); abort(); }
|
|
/* Generated stub for json_stream_fail */
|
|
struct json_stream *json_stream_fail(struct command *cmd UNNEEDED,
|
|
errcode_t code UNNEEDED,
|
|
const char *errmsg UNNEEDED)
|
|
{ fprintf(stderr, "json_stream_fail called!\n"); abort(); }
|
|
/* Generated stub for json_stream_success */
|
|
struct json_stream *json_stream_success(struct command *cmd UNNEEDED)
|
|
{ fprintf(stderr, "json_stream_success called!\n"); abort(); }
|
|
/* Generated stub for json_to_address_scriptpubkey */
|
|
enum address_parse_result json_to_address_scriptpubkey(const tal_t *ctx UNNEEDED,
|
|
const struct chainparams *chainparams UNNEEDED,
|
|
const char *buffer UNNEEDED,
|
|
const jsmntok_t *tok UNNEEDED, const u8 **scriptpubkey UNNEEDED)
|
|
{ fprintf(stderr, "json_to_address_scriptpubkey called!\n"); abort(); }
|
|
/* Generated stub for json_to_msat */
|
|
bool json_to_msat(const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
struct amount_msat *msat UNNEEDED)
|
|
{ fprintf(stderr, "json_to_msat called!\n"); abort(); }
|
|
/* Generated stub for json_to_node_id */
|
|
bool json_to_node_id(const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
struct node_id *id UNNEEDED)
|
|
{ fprintf(stderr, "json_to_node_id called!\n"); abort(); }
|
|
/* Generated stub for json_to_outpoint */
|
|
bool json_to_outpoint(const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
struct bitcoin_outpoint *op UNNEEDED)
|
|
{ fprintf(stderr, "json_to_outpoint called!\n"); abort(); }
|
|
/* Generated stub for json_to_short_channel_id */
|
|
bool json_to_short_channel_id(const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
struct short_channel_id *scid UNNEEDED)
|
|
{ fprintf(stderr, "json_to_short_channel_id called!\n"); abort(); }
|
|
/* Generated stub for json_tok_channel_id */
|
|
bool json_tok_channel_id(const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
struct channel_id *cid UNNEEDED)
|
|
{ fprintf(stderr, "json_tok_channel_id called!\n"); abort(); }
|
|
/* Generated stub for jsonrpc_request_end */
|
|
void jsonrpc_request_end(struct jsonrpc_request *request UNNEEDED)
|
|
{ fprintf(stderr, "jsonrpc_request_end called!\n"); abort(); }
|
|
/* Generated stub for jsonrpc_request_start_ */
|
|
struct jsonrpc_request *jsonrpc_request_start_(
|
|
const tal_t *ctx UNNEEDED, const char *method UNNEEDED, struct log *log UNNEEDED,
|
|
void (*notify_cb)(const char *buffer UNNEEDED,
|
|
const jsmntok_t *idtok UNNEEDED,
|
|
const jsmntok_t *methodtok UNNEEDED,
|
|
const jsmntok_t *paramtoks UNNEEDED,
|
|
void *) UNNEEDED,
|
|
void (*response_cb)(const char *buffer UNNEEDED, const jsmntok_t *toks UNNEEDED,
|
|
const jsmntok_t *idtok UNNEEDED, void *) UNNEEDED,
|
|
void *response_cb_arg UNNEEDED)
|
|
{ fprintf(stderr, "jsonrpc_request_start_ called!\n"); abort(); }
|
|
/* Generated stub for kill_uncommitted_channel */
|
|
void kill_uncommitted_channel(struct uncommitted_channel *uc UNNEEDED,
|
|
const char *why UNNEEDED)
|
|
{ fprintf(stderr, "kill_uncommitted_channel called!\n"); abort(); }
|
|
/* Generated stub for log_ */
|
|
void log_(struct log *log UNNEEDED, enum log_level level UNNEEDED,
|
|
const struct node_id *node_id UNNEEDED,
|
|
bool call_notifier UNNEEDED,
|
|
const char *fmt UNNEEDED, ...)
|
|
|
|
{ fprintf(stderr, "log_ called!\n"); abort(); }
|
|
/* Generated stub for merkle_tlv */
|
|
void merkle_tlv(const struct tlv_field *fields UNNEEDED, struct sha256 *merkle UNNEEDED)
|
|
{ fprintf(stderr, "merkle_tlv called!\n"); abort(); }
|
|
/* Generated stub for new_bolt11 */
|
|
struct bolt11 *new_bolt11(const tal_t *ctx UNNEEDED,
|
|
const struct amount_msat *msat TAKES UNNEEDED)
|
|
{ fprintf(stderr, "new_bolt11 called!\n"); abort(); }
|
|
/* Generated stub for new_reltimer_ */
|
|
struct oneshot *new_reltimer_(struct timers *timers UNNEEDED,
|
|
const tal_t *ctx UNNEEDED,
|
|
struct timerel expire UNNEEDED,
|
|
void (*cb)(void *) UNNEEDED, void *arg UNNEEDED)
|
|
{ fprintf(stderr, "new_reltimer_ called!\n"); abort(); }
|
|
/* Generated stub for node_id_cmp */
|
|
int node_id_cmp(const struct node_id *a UNNEEDED, const struct node_id *b UNNEEDED)
|
|
{ fprintf(stderr, "node_id_cmp called!\n"); abort(); }
|
|
/* Generated stub for node_id_to_hexstr */
|
|
char *node_id_to_hexstr(const tal_t *ctx UNNEEDED, const struct node_id *id UNNEEDED)
|
|
{ fprintf(stderr, "node_id_to_hexstr called!\n"); abort(); }
|
|
/* Generated stub for notify_connect */
|
|
void notify_connect(struct lightningd *ld UNNEEDED,
|
|
const struct node_id *nodeid UNNEEDED,
|
|
bool incoming UNNEEDED,
|
|
const struct wireaddr_internal *addr UNNEEDED)
|
|
{ fprintf(stderr, "notify_connect called!\n"); abort(); }
|
|
/* Generated stub for notify_disconnect */
|
|
void notify_disconnect(struct lightningd *ld UNNEEDED, struct node_id *nodeid UNNEEDED)
|
|
{ fprintf(stderr, "notify_disconnect called!\n"); abort(); }
|
|
/* Generated stub for notify_invoice_creation */
|
|
void notify_invoice_creation(struct lightningd *ld UNNEEDED, struct amount_msat *amount UNNEEDED,
|
|
struct preimage preimage UNNEEDED, const struct json_escape *label UNNEEDED)
|
|
{ fprintf(stderr, "notify_invoice_creation called!\n"); abort(); }
|
|
/* Generated stub for notify_invoice_payment */
|
|
void notify_invoice_payment(struct lightningd *ld UNNEEDED, struct amount_msat amount UNNEEDED,
|
|
struct preimage preimage UNNEEDED, const struct json_escape *label UNNEEDED)
|
|
{ fprintf(stderr, "notify_invoice_payment called!\n"); abort(); }
|
|
/* Generated stub for onchaind_funding_spent */
|
|
enum watch_result onchaind_funding_spent(struct channel *channel UNNEEDED,
|
|
const struct bitcoin_tx *tx UNNEEDED,
|
|
u32 blockheight UNNEEDED,
|
|
bool is_replay UNNEEDED)
|
|
{ fprintf(stderr, "onchaind_funding_spent called!\n"); abort(); }
|
|
/* Generated stub for param */
|
|
bool param(struct command *cmd UNNEEDED, const char *buffer UNNEEDED,
|
|
const jsmntok_t params[] UNNEEDED, ...)
|
|
{ fprintf(stderr, "param called!\n"); abort(); }
|
|
/* Generated stub for param_array */
|
|
struct command_result *param_array(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
const jsmntok_t **arr UNNEEDED)
|
|
{ fprintf(stderr, "param_array called!\n"); abort(); }
|
|
/* Generated stub for param_bin_from_hex */
|
|
struct command_result *param_bin_from_hex(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
u8 **bin UNNEEDED)
|
|
{ fprintf(stderr, "param_bin_from_hex called!\n"); abort(); }
|
|
/* Generated stub for param_bitcoin_address */
|
|
struct command_result *param_bitcoin_address(struct command *cmd UNNEEDED,
|
|
const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED,
|
|
const jsmntok_t *tok UNNEEDED,
|
|
const u8 **scriptpubkey UNNEEDED)
|
|
{ fprintf(stderr, "param_bitcoin_address called!\n"); abort(); }
|
|
/* Generated stub for param_bool */
|
|
struct command_result *param_bool(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
bool **b UNNEEDED)
|
|
{ fprintf(stderr, "param_bool called!\n"); abort(); }
|
|
/* Generated stub for param_channel_id */
|
|
struct command_result *param_channel_id(struct command *cmd UNNEEDED,
|
|
const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED,
|
|
const jsmntok_t *tok UNNEEDED,
|
|
struct channel_id **cid UNNEEDED)
|
|
{ fprintf(stderr, "param_channel_id called!\n"); abort(); }
|
|
/* Generated stub for param_escaped_string */
|
|
struct command_result *param_escaped_string(struct command *cmd UNNEEDED,
|
|
const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED,
|
|
const jsmntok_t *tok UNNEEDED,
|
|
const char **str UNNEEDED)
|
|
{ fprintf(stderr, "param_escaped_string called!\n"); abort(); }
|
|
/* Generated stub for param_label */
|
|
struct command_result *param_label(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char * buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
struct json_escape **label UNNEEDED)
|
|
{ fprintf(stderr, "param_label called!\n"); abort(); }
|
|
/* Generated stub for param_loglevel */
|
|
struct command_result *param_loglevel(struct command *cmd UNNEEDED,
|
|
const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED,
|
|
const jsmntok_t *tok UNNEEDED,
|
|
enum log_level **level UNNEEDED)
|
|
{ fprintf(stderr, "param_loglevel called!\n"); abort(); }
|
|
/* Generated stub for param_msat */
|
|
struct command_result *param_msat(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
struct amount_msat **msat UNNEEDED)
|
|
{ fprintf(stderr, "param_msat called!\n"); abort(); }
|
|
/* Generated stub for param_node_id */
|
|
struct command_result *param_node_id(struct command *cmd UNNEEDED,
|
|
const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED,
|
|
const jsmntok_t *tok UNNEEDED,
|
|
struct node_id **id UNNEEDED)
|
|
{ fprintf(stderr, "param_node_id called!\n"); abort(); }
|
|
/* Generated stub for param_number */
|
|
struct command_result *param_number(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
unsigned int **num UNNEEDED)
|
|
{ fprintf(stderr, "param_number called!\n"); abort(); }
|
|
/* Generated stub for param_sha256 */
|
|
struct command_result *param_sha256(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
struct sha256 **hash UNNEEDED)
|
|
{ fprintf(stderr, "param_sha256 called!\n"); abort(); }
|
|
/* Generated stub for param_short_channel_id */
|
|
struct command_result *param_short_channel_id(struct command *cmd UNNEEDED,
|
|
const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED,
|
|
const jsmntok_t *tok UNNEEDED,
|
|
struct short_channel_id **scid UNNEEDED)
|
|
{ fprintf(stderr, "param_short_channel_id called!\n"); abort(); }
|
|
/* Generated stub for param_string */
|
|
struct command_result *param_string(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char * buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
const char **str UNNEEDED)
|
|
{ fprintf(stderr, "param_string called!\n"); abort(); }
|
|
/* Generated stub for param_tok */
|
|
struct command_result *param_tok(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED, const jsmntok_t * tok UNNEEDED,
|
|
const jsmntok_t **out UNNEEDED)
|
|
{ fprintf(stderr, "param_tok called!\n"); abort(); }
|
|
/* Generated stub for param_u64 */
|
|
struct command_result *param_u64(struct command *cmd UNNEEDED, const char *name UNNEEDED,
|
|
const char *buffer UNNEEDED, const jsmntok_t *tok UNNEEDED,
|
|
uint64_t **num UNNEEDED)
|
|
{ fprintf(stderr, "param_u64 called!\n"); abort(); }
|
|
/* Generated stub for peer_active_channel */
|
|
struct channel *peer_active_channel(struct peer *peer UNNEEDED)
|
|
{ fprintf(stderr, "peer_active_channel called!\n"); abort(); }
|
|
/* Generated stub for peer_get_owning_subd */
|
|
struct subd *peer_get_owning_subd(struct peer *peer UNNEEDED)
|
|
{ fprintf(stderr, "peer_get_owning_subd called!\n"); abort(); }
|
|
/* Generated stub for peer_memleak_done */
|
|
void peer_memleak_done(struct command *cmd UNNEEDED, struct subd *leaker UNNEEDED)
|
|
{ fprintf(stderr, "peer_memleak_done called!\n"); abort(); }
|
|
/* Generated stub for peer_normal_channel */
|
|
struct channel *peer_normal_channel(struct peer *peer UNNEEDED)
|
|
{ fprintf(stderr, "peer_normal_channel called!\n"); abort(); }
|
|
/* Generated stub for peer_restart_dualopend */
|
|
void peer_restart_dualopend(struct peer *peer UNNEEDED,
|
|
struct per_peer_state *pps UNNEEDED,
|
|
struct channel *channel UNNEEDED)
|
|
{ fprintf(stderr, "peer_restart_dualopend called!\n"); abort(); }
|
|
/* Generated stub for peer_start_channeld */
|
|
void peer_start_channeld(struct channel *channel UNNEEDED,
|
|
struct per_peer_state *pps UNNEEDED,
|
|
const u8 *fwd_msg UNNEEDED,
|
|
bool reconnected UNNEEDED)
|
|
{ fprintf(stderr, "peer_start_channeld called!\n"); abort(); }
|
|
/* Generated stub for peer_start_dualopend */
|
|
void peer_start_dualopend(struct peer *peer UNNEEDED, struct per_peer_state *pps UNNEEDED)
|
|
{ fprintf(stderr, "peer_start_dualopend called!\n"); abort(); }
|
|
/* Generated stub for peer_start_openingd */
|
|
void peer_start_openingd(struct peer *peer UNNEEDED,
|
|
struct per_peer_state *pps UNNEEDED)
|
|
{ fprintf(stderr, "peer_start_openingd called!\n"); abort(); }
|
|
/* Generated stub for peer_unsaved_channel */
|
|
struct channel *peer_unsaved_channel(struct peer *peer UNNEEDED)
|
|
{ fprintf(stderr, "peer_unsaved_channel called!\n"); abort(); }
|
|
/* Generated stub for per_peer_state_set_fds */
|
|
void per_peer_state_set_fds(struct per_peer_state *pps UNNEEDED,
|
|
int peer_fd UNNEEDED, int gossip_fd UNNEEDED, int gossip_store_fd UNNEEDED)
|
|
{ fprintf(stderr, "per_peer_state_set_fds called!\n"); abort(); }
|
|
/* Generated stub for plugin_hook_call_ */
|
|
bool plugin_hook_call_(struct lightningd *ld UNNEEDED, const struct plugin_hook *hook UNNEEDED,
|
|
tal_t *cb_arg STEALS UNNEEDED)
|
|
{ fprintf(stderr, "plugin_hook_call_ called!\n"); abort(); }
|
|
/* Generated stub for plugin_request_send */
|
|
void plugin_request_send(struct plugin *plugin UNNEEDED,
|
|
struct jsonrpc_request *req TAKES UNNEEDED)
|
|
{ fprintf(stderr, "plugin_request_send called!\n"); abort(); }
|
|
/* Generated stub for subd_req_ */
|
|
void subd_req_(const tal_t *ctx UNNEEDED,
|
|
struct subd *sd UNNEEDED,
|
|
const u8 *msg_out UNNEEDED,
|
|
int fd_out UNNEEDED, size_t num_fds_in UNNEEDED,
|
|
void (*replycb)(struct subd * UNNEEDED, const u8 * UNNEEDED, const int * UNNEEDED, void *) UNNEEDED,
|
|
void *replycb_data UNNEEDED)
|
|
{ fprintf(stderr, "subd_req_ called!\n"); abort(); }
|
|
/* Generated stub for subd_send_fd */
|
|
void subd_send_fd(struct subd *sd UNNEEDED, int fd UNNEEDED)
|
|
{ fprintf(stderr, "subd_send_fd called!\n"); abort(); }
|
|
/* Generated stub for subd_send_msg */
|
|
void subd_send_msg(struct subd *sd UNNEEDED, const u8 *msg_out UNNEEDED)
|
|
{ fprintf(stderr, "subd_send_msg called!\n"); abort(); }
|
|
/* Generated stub for towire_bigsize */
|
|
void towire_bigsize(u8 **pptr UNNEEDED, const bigsize_t val UNNEEDED)
|
|
{ fprintf(stderr, "towire_bigsize called!\n"); abort(); }
|
|
/* Generated stub for towire_channel_id */
|
|
void towire_channel_id(u8 **pptr UNNEEDED, const struct channel_id *channel_id UNNEEDED)
|
|
{ fprintf(stderr, "towire_channel_id called!\n"); abort(); }
|
|
/* Generated stub for towire_channeld_dev_memleak */
|
|
u8 *towire_channeld_dev_memleak(const tal_t *ctx UNNEEDED)
|
|
{ fprintf(stderr, "towire_channeld_dev_memleak called!\n"); abort(); }
|
|
/* Generated stub for towire_channeld_dev_reenable_commit */
|
|
u8 *towire_channeld_dev_reenable_commit(const tal_t *ctx UNNEEDED)
|
|
{ fprintf(stderr, "towire_channeld_dev_reenable_commit called!\n"); abort(); }
|
|
/* Generated stub for towire_channeld_send_shutdown */
|
|
u8 *towire_channeld_send_shutdown(const tal_t *ctx UNNEEDED, const u8 *shutdown_scriptpubkey UNNEEDED, const struct bitcoin_outpoint *wrong_funding UNNEEDED)
|
|
{ fprintf(stderr, "towire_channeld_send_shutdown called!\n"); abort(); }
|
|
/* Generated stub for towire_channeld_specific_feerates */
|
|
u8 *towire_channeld_specific_feerates(const tal_t *ctx UNNEEDED, u32 feerate_base UNNEEDED, u32 feerate_ppm UNNEEDED)
|
|
{ fprintf(stderr, "towire_channeld_specific_feerates called!\n"); abort(); }
|
|
/* Generated stub for towire_connectd_connect_to_peer */
|
|
u8 *towire_connectd_connect_to_peer(const tal_t *ctx UNNEEDED, const struct node_id *id UNNEEDED, u32 seconds_waited UNNEEDED, const struct wireaddr_internal *addrhint UNNEEDED)
|
|
{ fprintf(stderr, "towire_connectd_connect_to_peer called!\n"); abort(); }
|
|
/* Generated stub for towire_connectd_peer_final_msg */
|
|
u8 *towire_connectd_peer_final_msg(const tal_t *ctx UNNEEDED, const struct node_id *id UNNEEDED, const struct per_peer_state *pps UNNEEDED, const u8 *msg UNNEEDED)
|
|
{ fprintf(stderr, "towire_connectd_peer_final_msg called!\n"); abort(); }
|
|
/* Generated stub for towire_dualopend_send_shutdown */
|
|
u8 *towire_dualopend_send_shutdown(const tal_t *ctx UNNEEDED, const u8 *shutdown_scriptpubkey UNNEEDED)
|
|
{ fprintf(stderr, "towire_dualopend_send_shutdown called!\n"); abort(); }
|
|
/* Generated stub for towire_errorfmt */
|
|
u8 *towire_errorfmt(const tal_t *ctx UNNEEDED,
|
|
const struct channel_id *channel UNNEEDED,
|
|
const char *fmt UNNEEDED, ...)
|
|
{ fprintf(stderr, "towire_errorfmt called!\n"); abort(); }
|
|
/* Generated stub for towire_hsmd_sign_bolt12 */
|
|
u8 *towire_hsmd_sign_bolt12(const tal_t *ctx UNNEEDED, const wirestring *messagename UNNEEDED, const wirestring *fieldname UNNEEDED, const struct sha256 *merkleroot UNNEEDED, const u8 *publictweak UNNEEDED)
|
|
{ fprintf(stderr, "towire_hsmd_sign_bolt12 called!\n"); abort(); }
|
|
/* Generated stub for towire_hsmd_sign_commitment_tx */
|
|
u8 *towire_hsmd_sign_commitment_tx(const tal_t *ctx UNNEEDED, const struct node_id *peer_id UNNEEDED, u64 channel_dbid UNNEEDED, const struct bitcoin_tx *tx UNNEEDED, const struct pubkey *remote_funding_key UNNEEDED)
|
|
{ fprintf(stderr, "towire_hsmd_sign_commitment_tx called!\n"); abort(); }
|
|
/* Generated stub for towire_hsmd_sign_invoice */
|
|
u8 *towire_hsmd_sign_invoice(const tal_t *ctx UNNEEDED, const u8 *u5bytes UNNEEDED, const u8 *hrp UNNEEDED)
|
|
{ fprintf(stderr, "towire_hsmd_sign_invoice called!\n"); abort(); }
|
|
/* Generated stub for towire_node_id */
|
|
void towire_node_id(u8 **pptr UNNEEDED, const struct node_id *id UNNEEDED)
|
|
{ fprintf(stderr, "towire_node_id called!\n"); abort(); }
|
|
/* Generated stub for towire_onchaind_dev_memleak */
|
|
u8 *towire_onchaind_dev_memleak(const tal_t *ctx UNNEEDED)
|
|
{ fprintf(stderr, "towire_onchaind_dev_memleak called!\n"); abort(); }
|
|
/* Generated stub for towire_warningfmt */
|
|
u8 *towire_warningfmt(const tal_t *ctx UNNEEDED,
|
|
const struct channel_id *channel UNNEEDED,
|
|
const char *fmt UNNEEDED, ...)
|
|
{ fprintf(stderr, "towire_warningfmt called!\n"); abort(); }
|
|
/* Generated stub for valid_shutdown_scriptpubkey */
|
|
bool valid_shutdown_scriptpubkey(const u8 *scriptpubkey UNNEEDED,
|
|
bool anysegwit UNNEEDED)
|
|
{ fprintf(stderr, "valid_shutdown_scriptpubkey called!\n"); abort(); }
|
|
/* Generated stub for version */
|
|
const char *version(void)
|
|
{ fprintf(stderr, "version called!\n"); abort(); }
|
|
/* Generated stub for wallet_annotate_txout */
|
|
void wallet_annotate_txout(struct wallet *w UNNEEDED, const struct bitcoin_txid *txid UNNEEDED,
|
|
int outnum UNNEEDED, enum wallet_tx_type type UNNEEDED, u64 channel UNNEEDED)
|
|
{ fprintf(stderr, "wallet_annotate_txout called!\n"); abort(); }
|
|
/* Generated stub for wallet_channel_save */
|
|
void wallet_channel_save(struct wallet *w UNNEEDED, struct channel *chan UNNEEDED)
|
|
{ fprintf(stderr, "wallet_channel_save called!\n"); abort(); }
|
|
/* Generated stub for wallet_channel_stats_load */
|
|
void wallet_channel_stats_load(struct wallet *w UNNEEDED, u64 cdbid UNNEEDED, struct channel_stats *stats UNNEEDED)
|
|
{ fprintf(stderr, "wallet_channel_stats_load called!\n"); abort(); }
|
|
/* Generated stub for wallet_channeltxs_add */
|
|
void wallet_channeltxs_add(struct wallet *w UNNEEDED, struct channel *chan UNNEEDED,
|
|
const int type UNNEEDED, const struct bitcoin_txid *txid UNNEEDED,
|
|
const u32 input_num UNNEEDED, const u32 blockheight UNNEEDED)
|
|
{ fprintf(stderr, "wallet_channeltxs_add called!\n"); abort(); }
|
|
/* Generated stub for wallet_htlcs_load_in_for_channel */
|
|
bool wallet_htlcs_load_in_for_channel(struct wallet *wallet UNNEEDED,
|
|
struct channel *chan UNNEEDED,
|
|
struct htlc_in_map *htlcs_in UNNEEDED)
|
|
{ fprintf(stderr, "wallet_htlcs_load_in_for_channel called!\n"); abort(); }
|
|
/* Generated stub for wallet_htlcs_load_out_for_channel */
|
|
bool wallet_htlcs_load_out_for_channel(struct wallet *wallet UNNEEDED,
|
|
struct channel *chan UNNEEDED,
|
|
struct htlc_out_map *htlcs_out UNNEEDED,
|
|
struct htlc_in_map *remaining_htlcs_in UNNEEDED)
|
|
{ fprintf(stderr, "wallet_htlcs_load_out_for_channel called!\n"); abort(); }
|
|
/* Generated stub for wallet_init_channels */
|
|
bool wallet_init_channels(struct wallet *w UNNEEDED)
|
|
{ fprintf(stderr, "wallet_init_channels called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_create */
|
|
bool wallet_invoice_create(struct wallet *wallet UNNEEDED,
|
|
struct invoice *pinvoice UNNEEDED,
|
|
const struct amount_msat *msat TAKES UNNEEDED,
|
|
const struct json_escape *label TAKES UNNEEDED,
|
|
u64 expiry UNNEEDED,
|
|
const char *b11enc UNNEEDED,
|
|
const char *description UNNEEDED,
|
|
const u8 *features UNNEEDED,
|
|
const struct preimage *r UNNEEDED,
|
|
const struct sha256 *rhash UNNEEDED,
|
|
const struct sha256 *local_offer_id UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_create called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_delete */
|
|
bool wallet_invoice_delete(struct wallet *wallet UNNEEDED,
|
|
struct invoice invoice UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_delete called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_delete_expired */
|
|
void wallet_invoice_delete_expired(struct wallet *wallet UNNEEDED,
|
|
u64 max_expiry_time UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_delete_expired called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_details */
|
|
const struct invoice_details *wallet_invoice_details(const tal_t *ctx UNNEEDED,
|
|
struct wallet *wallet UNNEEDED,
|
|
struct invoice invoice UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_details called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_find_by_label */
|
|
bool wallet_invoice_find_by_label(struct wallet *wallet UNNEEDED,
|
|
struct invoice *pinvoice UNNEEDED,
|
|
const struct json_escape *label UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_find_by_label called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_find_by_rhash */
|
|
bool wallet_invoice_find_by_rhash(struct wallet *wallet UNNEEDED,
|
|
struct invoice *pinvoice UNNEEDED,
|
|
const struct sha256 *rhash UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_find_by_rhash called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_find_unpaid */
|
|
bool wallet_invoice_find_unpaid(struct wallet *wallet UNNEEDED,
|
|
struct invoice *pinvoice UNNEEDED,
|
|
const struct sha256 *rhash UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_find_unpaid called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_iterate */
|
|
bool wallet_invoice_iterate(struct wallet *wallet UNNEEDED,
|
|
struct invoice_iterator *it UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_iterate called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_iterator_deref */
|
|
const struct invoice_details *wallet_invoice_iterator_deref(const tal_t *ctx UNNEEDED,
|
|
struct wallet *wallet UNNEEDED,
|
|
const struct invoice_iterator *it UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_iterator_deref called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_resolve */
|
|
bool wallet_invoice_resolve(struct wallet *wallet UNNEEDED,
|
|
struct invoice invoice UNNEEDED,
|
|
struct amount_msat received UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_resolve called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_waitany */
|
|
void wallet_invoice_waitany(const tal_t *ctx UNNEEDED,
|
|
struct wallet *wallet UNNEEDED,
|
|
u64 lastpay_index UNNEEDED,
|
|
void (*cb)(const struct invoice * UNNEEDED, void*) UNNEEDED,
|
|
void *cbarg UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_waitany called!\n"); abort(); }
|
|
/* Generated stub for wallet_invoice_waitone */
|
|
void wallet_invoice_waitone(const tal_t *ctx UNNEEDED,
|
|
struct wallet *wallet UNNEEDED,
|
|
struct invoice invoice UNNEEDED,
|
|
void (*cb)(const struct invoice * UNNEEDED, void*) UNNEEDED,
|
|
void *cbarg UNNEEDED)
|
|
{ fprintf(stderr, "wallet_invoice_waitone called!\n"); abort(); }
|
|
/* Generated stub for wallet_offer_find */
|
|
char *wallet_offer_find(const tal_t *ctx UNNEEDED,
|
|
struct wallet *w UNNEEDED,
|
|
const struct sha256 *offer_id UNNEEDED,
|
|
const struct json_escape **label UNNEEDED,
|
|
enum offer_status *status)
|
|
|
|
{ fprintf(stderr, "wallet_offer_find called!\n"); abort(); }
|
|
/* Generated stub for wallet_peer_delete */
|
|
void wallet_peer_delete(struct wallet *w UNNEEDED, u64 peer_dbid UNNEEDED)
|
|
{ fprintf(stderr, "wallet_peer_delete called!\n"); abort(); }
|
|
/* Generated stub for wallet_state_change_get */
|
|
struct state_change_entry *wallet_state_change_get(struct wallet *w UNNEEDED,
|
|
const tal_t *ctx UNNEEDED,
|
|
u64 channel_id UNNEEDED)
|
|
{ fprintf(stderr, "wallet_state_change_get called!\n"); abort(); }
|
|
/* Generated stub for wallet_total_forward_fees */
|
|
struct amount_msat wallet_total_forward_fees(struct wallet *w UNNEEDED)
|
|
{ fprintf(stderr, "wallet_total_forward_fees called!\n"); abort(); }
|
|
/* Generated stub for wallet_transaction_add */
|
|
void wallet_transaction_add(struct wallet *w UNNEEDED, const struct wally_tx *tx UNNEEDED,
|
|
const u32 blockheight UNNEEDED, const u32 txindex UNNEEDED)
|
|
{ fprintf(stderr, "wallet_transaction_add called!\n"); abort(); }
|
|
/* Generated stub for wallet_transaction_annotate */
|
|
void wallet_transaction_annotate(struct wallet *w UNNEEDED,
|
|
const struct bitcoin_txid *txid UNNEEDED,
|
|
enum wallet_tx_type type UNNEEDED, u64 channel_id UNNEEDED)
|
|
{ fprintf(stderr, "wallet_transaction_annotate called!\n"); abort(); }
|
|
/* Generated stub for wallet_transaction_locate */
|
|
struct txlocator *wallet_transaction_locate(const tal_t *ctx UNNEEDED, struct wallet *w UNNEEDED,
|
|
const struct bitcoin_txid *txid UNNEEDED)
|
|
{ fprintf(stderr, "wallet_transaction_locate called!\n"); abort(); }
|
|
/* Generated stub for watch_txid */
|
|
struct txwatch *watch_txid(const tal_t *ctx UNNEEDED,
|
|
struct chain_topology *topo UNNEEDED,
|
|
struct channel *channel UNNEEDED,
|
|
const struct bitcoin_txid *txid UNNEEDED,
|
|
enum watch_result (*cb)(struct lightningd *ld UNNEEDED,
|
|
struct channel *channel UNNEEDED,
|
|
const struct bitcoin_txid * UNNEEDED,
|
|
const struct bitcoin_tx * UNNEEDED,
|
|
unsigned int depth))
|
|
{ fprintf(stderr, "watch_txid called!\n"); abort(); }
|
|
/* Generated stub for watch_txo */
|
|
struct txowatch *watch_txo(const tal_t *ctx UNNEEDED,
|
|
struct chain_topology *topo UNNEEDED,
|
|
struct channel *channel UNNEEDED,
|
|
const struct bitcoin_txid *txid UNNEEDED,
|
|
unsigned int output UNNEEDED,
|
|
enum watch_result (*cb)(struct channel *channel UNNEEDED,
|
|
const struct bitcoin_tx *tx UNNEEDED,
|
|
size_t input_num UNNEEDED,
|
|
const struct block *block))
|
|
{ fprintf(stderr, "watch_txo called!\n"); abort(); }
|
|
/* AUTOGENERATED MOCKS END */
|
|
|
|
#if DEVELOPER
|
|
/* Generated stub for dev_disconnect_permanent */
|
|
bool dev_disconnect_permanent(struct lightningd *ld UNNEEDED)
|
|
{ fprintf(stderr, "dev_disconnect_permanent called!\n"); abort(); }
|
|
#endif
|
|
|
|
static void add_candidate(struct routehint_candidate **candidates, int n,
|
|
struct channel *c)
|
|
{
|
|
struct routehint_candidate candidate;
|
|
|
|
candidate.r = tal(*candidates, struct route_info);
|
|
memset(&candidate.r->pubkey, n, sizeof(candidate.r->pubkey));
|
|
memset(&candidate.r->short_channel_id, n,
|
|
sizeof(candidate.r->short_channel_id));
|
|
candidate.r->fee_base_msat
|
|
= candidate.r->fee_proportional_millionths
|
|
= candidate.r->cltv_expiry_delta
|
|
= n;
|
|
candidate.c = c;
|
|
candidate.capacity = amount_msat(n * 1000 - 1);
|
|
tal_arr_expand(candidates, candidate);
|
|
}
|
|
|
|
static struct channel *add_peer(struct lightningd *ld, int n,
|
|
enum channel_state state,
|
|
bool connected)
|
|
{
|
|
struct peer *peer = tal(ld, struct peer);
|
|
struct channel *c = tal(peer, struct channel);
|
|
|
|
memset(&peer->id, n, sizeof(peer->id));
|
|
list_head_init(&peer->channels);
|
|
list_add_tail(&ld->peers, &peer->list);
|
|
peer->ld = ld;
|
|
|
|
c->state = state;
|
|
c->owner = connected ? (void *)peer : NULL;
|
|
c->opener = LOCAL;
|
|
c->peer = peer;
|
|
/* Channel has incoming capacity n*1000 - 1 millisatoshi */
|
|
c->funding.satoshis = n+1;
|
|
c->our_msat = AMOUNT_MSAT(1);
|
|
c->our_config.channel_reserve = AMOUNT_SAT(1);
|
|
c->our_config.htlc_minimum = AMOUNT_MSAT(0);
|
|
c->channel_info.their_config.channel_reserve = AMOUNT_SAT(0);
|
|
list_add_tail(&peer->channels, &c->list);
|
|
|
|
return c;
|
|
}
|
|
|
|
/* There *is* padding in this structure, after pubkey and after cltv_expiry_delta. */
|
|
STRUCTEQ_DEF(route_info,
|
|
ALIGNOF(struct short_channel_id) - 1 - sizeof(u16),
|
|
pubkey,
|
|
cltv_expiry_delta,
|
|
short_channel_id,
|
|
fee_base_msat,
|
|
fee_proportional_millionths);
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
struct lightningd *ld;
|
|
struct routehint_candidate *candidates;
|
|
struct route_info **ret;
|
|
size_t n;
|
|
|
|
common_setup(argv[0]);
|
|
ld = tal(tmpctx, struct lightningd);
|
|
|
|
list_head_init(&ld->peers);
|
|
htlc_in_map_init(&ld->htlcs_in);
|
|
chainparams = chainparams_for_network("regtest");
|
|
|
|
candidates = tal_arr(tmpctx, struct routehint_candidate, 0);
|
|
|
|
/* 1. Nothing to choose from -> NULL result. */
|
|
ret = select_inchan(tmpctx, ld, AMOUNT_MSAT(0), candidates);
|
|
assert(tal_count(ret) == 0);
|
|
|
|
/* 2. One peer (999 msat capacity) */
|
|
add_candidate(&candidates, 1, add_peer(ld, 1, CHANNELD_NORMAL, true));
|
|
ret = select_inchan(tmpctx, ld, AMOUNT_MSAT(1000), candidates);
|
|
assert(tal_count(ret) == 0);
|
|
|
|
ret = select_inchan(tmpctx, ld, AMOUNT_MSAT(999), candidates);
|
|
assert(tal_count(ret) == 1);
|
|
assert(tal_count(ret[0]) == 1);
|
|
assert(route_info_eq(ret[0], candidates[0].r));
|
|
|
|
/* 3. Two peers (999 msat capacity and 1999 msat) */
|
|
add_candidate(&candidates, 2, add_peer(ld, 2, CHANNELD_NORMAL, true));
|
|
|
|
ret = select_inchan(tmpctx, ld, AMOUNT_MSAT(1000), candidates);
|
|
assert(tal_count(ret) == 1);
|
|
assert(tal_count(ret[0]) == 1);
|
|
assert(route_info_eq(ret[0], candidates[1].r));
|
|
|
|
/* 7. Correct peer with just enough capacity_to_pay_us */
|
|
ret = select_inchan(tmpctx, ld, AMOUNT_MSAT(1999), candidates);
|
|
assert(tal_count(ret) == 1);
|
|
assert(tal_count(ret[0]) == 1);
|
|
assert(route_info_eq(ret[0], candidates[1].r));
|
|
|
|
/* 8. Not if we ask for too much! Our balance is 1msat. */
|
|
ret = select_inchan(tmpctx, ld, AMOUNT_MSAT(2000), candidates);
|
|
assert(tal_count(ret) == 0);
|
|
|
|
/* 9. Add another peer (2999 capacity) */
|
|
add_candidate(&candidates, 3, add_peer(ld, 3, CHANNELD_NORMAL, true));
|
|
|
|
/* Simulate selection ratios between excesses 25% and 50% of capacity*/
|
|
for (size_t i = n = 0; i < 1000; i++) {
|
|
ret = select_inchan(tmpctx, ld, AMOUNT_MSAT(1499), candidates);
|
|
assert(tal_count(ret) == 1);
|
|
assert(tal_count(ret[0]) == 1);
|
|
assert(route_info_eq(ret[0], candidates[1].r)
|
|
|| route_info_eq(ret[0], candidates[2].r));
|
|
n += route_info_eq(ret[0], candidates[1].r);
|
|
}
|
|
|
|
/* Handwave over probability of this happening! Within 20% */
|
|
printf("Number of selections with excess 25 percent of capacity: %zu\n"
|
|
"Number of selections with excess 50 percent of capacity: %zu\n",
|
|
n, 1000 - n);
|
|
assert(n > 333 - 66 && n < 333 + 66);
|
|
|
|
/* 10. Last peer's capacity goes from 3 to 2 sat */
|
|
candidates[2].c->channel_info.their_config.channel_reserve = AMOUNT_SAT(1);
|
|
|
|
for (size_t i = n = 0; i < 1000; i++) {
|
|
ret = select_inchan(tmpctx, ld, AMOUNT_MSAT(1499), candidates);
|
|
assert(tal_count(ret) == 1);
|
|
assert(tal_count(ret[0]) == 1);
|
|
assert(route_info_eq(ret[0], candidates[1].r)
|
|
|| route_info_eq(ret[0], candidates[2].r));
|
|
n += route_info_eq(ret[0], candidates[1].r);
|
|
}
|
|
|
|
/* Handwave over probability of this happening! Within 20% */
|
|
printf("Number of selections with excess 25 percent of capacity: %zu\n"
|
|
"Number of selections with excess 75 percent of capacity: %zu\n",
|
|
n, 1000 - n);
|
|
assert(n > 250 - 50 && n < 250 + 50);
|
|
|
|
common_shutdown();
|
|
|
|
/* FIXME: Do BOLT comparison! */
|
|
return 0;
|
|
}
|