#ifndef LIGHTNING_LIGHTNINGD_PEER_CONTROL_H #define LIGHTNING_LIGHTNINGD_PEER_CONTROL_H #include "config.h" #include #include #include #include #include #include #include #include #define ANNOUNCE_MIN_DEPTH 6 struct crypto_state; struct peer { struct lightningd *ld; /* Unique ID (works before we know their pubkey) */ u64 unique_id; /* What's happening. */ enum peer_state state; /* Which side offered channel? */ enum side funder; /* Inside ld->peers. */ struct list_node list; /* What stage is this in? NULL during first creation. */ struct subd *owner; /* History */ struct log_book *log_book; struct log *log; /* ID of peer (NULL before initial handshake). */ struct pubkey *id; /* Our fd to the peer (-1 when we don't have it). */ int fd; /* Crypto state (NULL if it's in daemon) */ struct crypto_state *cs; /* Where we connected to, or it connected from. */ struct netaddr netaddr; /* Our channel config. */ struct channel_config our_config; /* Channel if locked. */ struct short_channel_id *scid; /* Minimum funding depth (specified by us if they fund). */ u32 minimum_depth; /* Funding txid and amounts (once known) */ struct sha256_double *funding_txid; u16 funding_outnum; u64 funding_satoshi, push_msat; /* Channel balance (LOCAL and REMOTE); if we have one. */ u64 *balance; /* Keys for channel. */ struct channel_info *channel_info; /* Secret seed (FIXME: Move to hsm!) */ struct privkey *seed; /* Gossip client fd, forwarded to the respective owner */ int gossip_client_fd; }; static inline bool peer_can_add_htlc(const struct peer *peer) { return peer->state == CHANNELD_NORMAL; } static inline bool peer_can_remove_htlc(const struct peer *peer) { return peer->state == CHANNELD_NORMAL || peer->state == SHUTDOWND_SENT || peer->state == SHUTDOWND_RCVD || peer->state == ONCHAIND_THEIR_UNILATERAL || peer->state == ONCHAIND_OUR_UNILATERAL; } static inline bool peer_on_chain(const struct peer *peer) { return peer->state == ONCHAIND_CHEATED || peer->state == ONCHAIND_THEIR_UNILATERAL || peer->state == ONCHAIND_OUR_UNILATERAL || peer->state == ONCHAIND_MUTUAL; } /* BOLT #2: * * On disconnection, the funder MUST remember the channel for * reconnection if it has broadcast the funding transaction, otherwise it * MUST NOT. * * On disconnection, the non-funding node MUST remember the channel for * reconnection if it has sent the `funding_signed` message, otherwise * it MUST NOT. */ static inline bool peer_persists(const struct peer *peer) { return peer->state >= CHANNELD_AWAITING_LOCKIN; } struct peer *peer_by_unique_id(struct lightningd *ld, u64 unique_id); struct peer *peer_by_id(struct lightningd *ld, const struct pubkey *id); struct peer *peer_from_json(struct lightningd *ld, const char *buffer, jsmntok_t *peeridtok); void peer_accept_open(struct peer *peer, const u8 *msg); void add_peer(struct lightningd *ld, u64 unique_id, int fd, const struct pubkey *id, const struct crypto_state *cs); /* Peer has failed. */ PRINTF_FMT(2,3) void peer_fail(struct peer *peer, const char *fmt, ...); const char *peer_state_name(enum peer_state state); void peer_set_condition(struct peer *peer, enum peer_state oldstate, enum peer_state state); void setup_listeners(struct lightningd *ld); #endif /* LIGHTNING_LIGHTNINGD_PEER_CONTROL_H */