|
|
|
#ifndef LIGHTNING_DAEMON_PEER_H
|
|
|
|
#define LIGHTNING_DAEMON_PEER_H
|
|
|
|
#include "config.h"
|
|
|
|
#include "bitcoin/locktime.h"
|
|
|
|
#include "bitcoin/pubkey.h"
|
|
|
|
#include "bitcoin/script.h"
|
|
|
|
#include "bitcoin/shadouble.h"
|
|
|
|
#include "funding.h"
|
|
|
|
#include "lightning.pb-c.h"
|
|
|
|
#include "netaddr.h"
|
|
|
|
#include "state.h"
|
|
|
|
#include <ccan/crypto/sha256/sha256.h>
|
|
|
|
#include <ccan/list/list.h>
|
|
|
|
#include <ccan/time/time.h>
|
|
|
|
|
|
|
|
enum htlc_stage_type {
|
|
|
|
HTLC_ADD,
|
|
|
|
HTLC_FULFILL,
|
|
|
|
HTLC_FAIL
|
|
|
|
};
|
|
|
|
|
|
|
|
struct htlc_add {
|
|
|
|
enum htlc_stage_type add;
|
|
|
|
struct channel_htlc htlc;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct htlc_fulfill {
|
|
|
|
enum htlc_stage_type fulfill;
|
|
|
|
size_t index;
|
|
|
|
struct sha256 r;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct htlc_fail {
|
|
|
|
enum htlc_stage_type fail;
|
|
|
|
size_t index;
|
|
|
|
};
|
|
|
|
|
|
|
|
union htlc_staging {
|
|
|
|
enum htlc_stage_type type;
|
|
|
|
struct htlc_add add;
|
|
|
|
struct htlc_fulfill fulfill;
|
|
|
|
struct htlc_fail fail;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct peer_visible_state {
|
|
|
|
/* CMD_OPEN_WITH_ANCHOR or CMD_OPEN_WITHOUT_ANCHOR */
|
|
|
|
enum state_input offer_anchor;
|
|
|
|
/* Key for commitment tx inputs, then key for commitment tx outputs */
|
|
|
|
struct pubkey commitkey, finalkey;
|
|
|
|
/* How long to they want the other's outputs locked (seconds) */
|
|
|
|
struct rel_locktime locktime;
|
|
|
|
/* Minimum depth of anchor before channel usable. */
|
|
|
|
unsigned int mindepth;
|
|
|
|
/* Commitment fee they're offering (satoshi). */
|
|
|
|
u64 commit_fee_rate;
|
|
|
|
/* Revocation hash for latest commit tx. */
|
|
|
|
struct sha256 revocation_hash;
|
|
|
|
/* Revocation hash for next commit tx. */
|
|
|
|
struct sha256 next_revocation_hash;
|
|
|
|
/* Current commit tx. */
|
|
|
|
struct bitcoin_tx *commit;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct htlc_progress {
|
|
|
|
/* The HTLC we're working on. */
|
|
|
|
union htlc_staging stage;
|
|
|
|
|
|
|
|
/* Our next state. */
|
|
|
|
/* Channel funding state, after we've completed htlc. */
|
|
|
|
struct channel_state *cstate;
|
|
|
|
struct sha256 our_revocation_hash, their_revocation_hash;
|
|
|
|
struct bitcoin_tx *our_commit, *their_commit;
|
|
|
|
struct bitcoin_signature their_sig;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct out_pkt {
|
|
|
|
Pkt *pkt;
|
|
|
|
void (*ack_cb)(struct peer *peer, void *arg);
|
|
|
|
void *ack_arg;
|
|
|
|
};
|
|
|
|
|
|
|
|
struct peer {
|
|
|
|
/* dstate->peers list */
|
|
|
|
struct list_node list;
|
|
|
|
|
|
|
|
/* State in state machine. */
|
|
|
|
enum state state;
|
|
|
|
|
|
|
|
/* Condition of communications */
|
|
|
|
enum state_peercond cond;
|
|
|
|
|
|
|
|
/* Network connection. */
|
|
|
|
struct io_conn *conn;
|
|
|
|
|
|
|
|
/* Current command (or INPUT_NONE) */
|
|
|
|
struct {
|
|
|
|
enum state_input cmd;
|
|
|
|
union input cmddata;
|
|
|
|
struct command *jsoncmd;
|
|
|
|
} curr_cmd;
|
|
|
|
|
|
|
|
/* Pending commands. */
|
|
|
|
struct list_head pending_cmd;
|
|
|
|
|
|
|
|
/* Global state. */
|
|
|
|
struct lightningd_state *dstate;
|
|
|
|
|
|
|
|
/* Funding status for current commit tx (from our PoV). */
|
|
|
|
struct channel_state *cstate;
|
|
|
|
|
|
|
|
/* The other end's address. */
|
|
|
|
struct netaddr addr;
|
|
|
|
|
|
|
|
/* Their ID. */
|
|
|
|
struct pubkey id;
|
|
|
|
|
|
|
|
/* Current received packet. */
|
|
|
|
Pkt *inpkt;
|
|
|
|
|
|
|
|
/* Queue of output packets. */
|
|
|
|
struct out_pkt *outpkt;
|
|
|
|
|
|
|
|
/* Anchor tx output */
|
|
|
|
struct {
|
|
|
|
struct sha256_double txid;
|
|
|
|
unsigned int index;
|
|
|
|
u64 satoshis;
|
|
|
|
u8 *redeemscript;
|
|
|
|
/* If we created it, we keep entire tx. */
|
|
|
|
const struct bitcoin_tx *tx;
|
|
|
|
struct anchor_watch *watches;
|
|
|
|
} anchor;
|
|
|
|
|
|
|
|
struct {
|
|
|
|
/* Their signature for our current commit sig. */
|
|
|
|
struct bitcoin_signature theirsig;
|
|
|
|
/* When it entered a block (mediantime). */
|
|
|
|
u32 start_time;
|
|
|
|
/* Which block it entered. */
|
|
|
|
struct sha256_double blockid;
|
|
|
|
/* The watch we have on a live commit tx. */
|
|
|
|
struct txwatch *watch;
|
|
|
|
} cur_commit;
|
|
|
|
|
|
|
|
/* Current HTLC, if any. */
|
|
|
|
struct htlc_progress *current_htlc;
|
|
|
|
/* Number of HTLC updates (== number of previous commit txs) */
|
|
|
|
u64 commit_tx_counter;
|
|
|
|
|
|
|
|
struct {
|
|
|
|
/* Our last suggested closing fee. */
|
|
|
|
u64 our_fee;
|
|
|
|
/* If they've offered a signature, these are set: */
|
|
|
|
struct bitcoin_signature *their_sig;
|
|
|
|
/* If their_sig is non-NULL, this is the fee. */
|
|
|
|
u64 their_fee;
|
|
|
|
} closing;
|
|
|
|
|
|
|
|
/* If not INPUT_NONE, send this when we have no more HTLCs. */
|
|
|
|
enum state_input cleared;
|
|
|
|
|
|
|
|
/* Current ongoing packetflow */
|
|
|
|
struct io_data *io_data;
|
|
|
|
|
|
|
|
/* What happened. */
|
|
|
|
struct log *log;
|
|
|
|
|
|
|
|
/* Things we're watching for (see watches.c) */
|
|
|
|
struct list_head watches;
|
|
|
|
|
|
|
|
/* Timeout for close_watch. */
|
|
|
|
struct oneshot *close_watch_timeout;
|
|
|
|
|
|
|
|
/* Private keys for dealing with this peer. */
|
|
|
|
struct peer_secrets *secrets;
|
|
|
|
|
|
|
|
/* Stuff we have in common. */
|
|
|
|
struct peer_visible_state us, them;
|
|
|
|
};
|
|
|
|
|
|
|
|
void setup_listeners(struct lightningd_state *dstate, unsigned int portnum);
|
|
|
|
|
|
|
|
void make_commit_txs(const tal_t *ctx,
|
|
|
|
const struct peer *peer,
|
|
|
|
const struct sha256 *our_revocation_hash,
|
|
|
|
const struct sha256 *their_revocation_hash,
|
|
|
|
const struct channel_state *cstate,
|
|
|
|
struct bitcoin_tx **ours, struct bitcoin_tx **theirs);
|
|
|
|
|
|
|
|
void peer_add_htlc_expiry(struct peer *peer,
|
|
|
|
const struct abs_locktime *expiry);
|
|
|
|
|
|
|
|
struct bitcoin_tx *peer_create_close_tx(struct peer *peer, u64 fee);
|
|
|
|
|
|
|
|
uint64_t commit_tx_fee(const struct bitcoin_tx *commit,
|
|
|
|
uint64_t anchor_satoshis);
|
|
|
|
#endif /* LIGHTNING_DAEMON_PEER_H */
|