#ifndef LIGHTNING_LIGHTNINGD_LIGHTNINGD_H #define LIGHTNING_LIGHTNINGD_LIGHTNINGD_H #include "config.h" #include #include #include #include #include struct amount_msat; /* Various adjustable things. */ struct config { /* How long do we want them to lock up their funds? (blocks) */ u32 locktime_blocks; /* How long do we let them lock up our funds? (blocks) */ u32 locktime_max; /* How many confirms until we consider an anchor "settled". */ u32 anchor_confirms; /* Minimum CLTV to subtract from incoming HTLCs to outgoing */ u32 cltv_expiry_delta; /* Minimum CLTV if we're the final hop.*/ u32 cltv_final; /* Fee rates. */ u32 fee_base; u32 fee_per_satoshi; /* htlcs per channel */ u32 max_concurrent_htlcs; /* Max amount of dust allowed per channel */ struct amount_msat max_dust_htlc_exposure_msat; /* How long between changing commit and sending COMMIT message. */ u32 commit_time_ms; /* Do we let the opener set any fee rate they want */ bool ignore_fee_limits; /* Number of blocks to rescan from the current head, or absolute * blockheight if rescan >= 500'000 */ s32 rescan; /* ipv6 bind disable */ bool no_ipv6_bind; /* Are we allowed to use DNS lookup for peers. */ bool use_dns; /* Minimal amount of effective funding_satoshis for accepting channels */ u64 min_capacity_sat; /* Allow to define the default behavior of tor services calls*/ bool use_v3_autotor; /* This is the key we use to encrypt `hsm_secret`. */ struct secret *keypass; /* How long before we give up waiting for INIT msg */ u32 connection_timeout_secs; /* EXPERIMENTAL: offers support */ bool exp_offers; }; typedef STRMAP(const char *) alt_subdaemon_map; enum lightningd_state { LD_STATE_RUNNING, LD_STATE_SHUTDOWN, }; struct lightningd { /* The directory to find all the subdaemons. */ const char *daemon_dir; /* If we told to run in the background, this is our parent fd, otherwise * -1. */ int daemon_parent_fd; /* Our config basedir, network directory, and rpc file */ char *config_basedir, *config_netdir; /* Location of the RPC socket. */ char *rpc_filename; /* Mode of the RPC filename. */ mode_t rpc_filemode; /* The root of the jsonrpc interface. Can be shut down * separately from the rest of the daemon to allow a clean * shutdown, which frees all pending cmds in a DB * transaction. */ struct jsonrpc *jsonrpc; /* Configuration file name */ char *config_filename; /* Configuration settings. */ struct config config; /* This log_book is owned by all the struct logs */ struct log_book *log_book; /* Log for general stuff. */ struct log *log; const char *logfile; /* This is us. */ struct node_id id; /* The public base for our payer_id keys */ struct point32 bolt12_base; /* The secret we put in onion message paths to know it's ours. */ struct secret onion_reply_secret; /* Feature set we offer. */ struct feature_set *our_features; /* My name is... my favorite color is... */ u8 *alias; /* At least 32 bytes (zero-filled) */ u8 *rgb; /* tal_len() == 3. */ /* Any pending timers. */ struct timers *timers; /* Port we're listening on */ u16 portnum; /* Do we want to reconnect to other peers? */ bool reconnect; /* Do we want to listen for other peers? */ bool listen; /* Do we want to guess addresses to listen and announce? */ bool autolisten; /* Setup: Addresses to bind/announce to the network (tal_count()) */ struct wireaddr_internal *proposed_wireaddr; /* Setup: And the bitset for each, whether to listen, announce or both */ enum addr_listen_announce *proposed_listen_announce; /* Actual bindings and announceables from gossipd */ struct wireaddr_internal *binding; struct wireaddr *announceable; /* unverified remote_addr as reported by recent peers */ struct wireaddr *remote_addr_v4; struct wireaddr *remote_addr_v6; struct node_id remote_addr_v4_peer; struct node_id remote_addr_v6_peer; /* Bearer of all my secrets. */ int hsm_fd; struct subd *hsm; /* Daemon for routing */ struct subd *gossip; /* Daemon looking after peers during init / before channel. */ struct subd *connectd; /* All peers we're tracking. */ struct list_head peers; /* Outstanding connect commands. */ struct list_head connects; /* Our chain topology. */ struct chain_topology *topology; /* Blockheight (as acknowledged by gossipd) */ u32 blockheight; /* HTLCs in flight. */ struct htlc_in_map htlcs_in; struct htlc_out_map htlcs_out; /* Sets of HTLCs we are holding onto for MPP. */ struct htlc_set_map htlc_sets; struct wallet *wallet; /* Outstanding waitsendpay commands. */ struct list_head waitsendpay_commands; /* Outstanding sendpay commands. */ struct list_head sendpay_commands; /* Outstanding close commands. */ struct list_head close_commands; /* Outstanding ping commands. */ struct list_head ping_commands; /* Outstanding disconnect commands. */ struct list_head disconnect_commands; /* Maintained by invoices.c */ struct invoices *invoices; /* Transaction filter matching what we're interested in */ struct txfilter *owned_txfilter; /* PID file */ char *pidfile; /* RPC which asked us to shutdown, if non-NULL */ struct io_conn *stop_conn; /* RPC response to send once we've shut down. */ const char *stop_response; /* All the subdaemons. */ struct list_head subds; /* Used these feerates instead of whatever bcli returns (up to * FEERATE_PENALTY). */ u32 *force_feerates; #if DEVELOPER /* If we want to debug a subdaemon/plugin. */ const char *dev_debug_subprocess; /* If we have --dev-no-plugin-checksum */ bool dev_no_plugin_checksum; /* If we have a --dev-disconnect file */ int dev_disconnect_fd; /* If we have --dev-fail-on-subdaemon-fail */ bool dev_subdaemon_fail; /* Allow and accept localhost node_announcement addresses */ bool dev_allow_localhost; /* Timestamp to use for gossipd, iff non-zero */ u32 dev_gossip_time; /* Speedup gossip propagation, for testing. */ bool dev_fast_gossip; bool dev_fast_gossip_prune; /* This is the forced private key for the node. */ struct privkey *dev_force_privkey; /* This is the forced bip32 seed for the node. */ struct secret *dev_force_bip32_seed; /* These are the forced channel secrets for the node. */ struct secrets *dev_force_channel_secrets; struct sha256 *dev_force_channel_secrets_shaseed; struct channel_id *dev_force_tmp_channel_id; /* For slow tests (eg protocol tests) don't die if HTLC not * committed in 30 secs */ bool dev_no_htlc_timeout; bool dev_no_version_checks; /* Number of blocks we wait for a channel to get funded * if we are the fundee. */ u32 dev_max_funding_unconfirmed; /* Special switches to test onion compatibility */ bool dev_ignore_modern_onion, dev_ignore_obsolete_onion; /* Tell channeld to disable commits after this many. */ int dev_disable_commit; #endif /* DEVELOPER */ /* tor support */ struct wireaddr *proxyaddr; bool always_use_proxy; char *tor_service_password; bool pure_tor_setup; struct plugins *plugins; char *wallet_dsn; bool encrypted_hsm; mode_t initial_umask; /* Outstanding waitblockheight commands. */ struct list_head waitblockheight_commands; alt_subdaemon_map alt_subdaemons; enum lightningd_state state; /* Total number of coin moves we've seen, since * coin move tracking was cool */ s64 coin_moves_count; /* If non-NULL, contains the exit code to use. */ int *exit_code; /* The round-robin list of channels, for use when doing MPP. */ u64 rr_counter; /* Should we re-exec ourselves instead of just exiting? */ bool try_reexec; /* Array of (even) TLV types that we should allow. This is required * since we otherwise would outright reject them. */ u64 *accept_extra_tlv_types; /* EXPERIMENTAL: websocket port if non-zero */ u16 websocket_port; }; /* Turning this on allows a tal allocation to return NULL, rather than aborting. * Use only on carefully tested code! */ extern bool tal_oom_ok; /* Returns true if called with a recognized subdaemon, eg: "hsmd" */ bool is_subdaemon(const char *sdname); /* Returns the path to the subdaemon. Considers alternate subdaemon paths. */ const char *subdaemon_path(const tal_t *ctx, const struct lightningd *ld, const char *name); /* Check we can run subdaemons, and check their versions */ void test_subdaemons(const struct lightningd *ld); /* Notify lightningd about new blocks. */ void notify_new_block(struct lightningd *ld, u32 block_height); /* Signal a clean exit from lightningd. * NOTE! This function **returns**. * This just causes the main loop to exit, so you have to return * all the way to the main loop for `lightningd` to exit. */ void lightningd_exit(struct lightningd *ld, int exit_code); #endif /* LIGHTNING_LIGHTNINGD_LIGHTNINGD_H */