#ifndef LIGHTNING_LIGHTNINGD_CHAINTOPOLOGY_H #define LIGHTNING_LIGHTNINGD_CHAINTOPOLOGY_H #include "config.h" #include #include #include #include #include #include #include #include #include struct bitcoin_tx; struct bitcoind; struct command; struct lightningd; struct peer; struct txwatch; enum feerate { FEERATE_IMMEDIATE, /* Aka: aim for next block. */ FEERATE_NORMAL, /* Aka: next 4 blocks or so. */ FEERATE_SLOW, /* Aka: next 100 blocks or so. */ }; #define NUM_FEERATES (FEERATE_SLOW+1) /* Off topology->outgoing_txs */ struct outgoing_tx { struct list_node list; struct channel *channel; const char *hextx; struct bitcoin_txid txid; void (*failed)(struct channel *channel, int exitstatus, const char *err); }; struct block { u32 height; /* Actual header. */ struct bitcoin_block_hdr hdr; /* Previous block (if any). */ struct block *prev; /* Next block (if any). */ struct block *next; /* Key for hash table */ struct bitcoin_blkid blkid; /* And their associated index in the block */ u32 *txnums; /* Full copy of txs (trimmed to txs list in connect_block) */ struct bitcoin_tx **full_txs; }; /* Hash blocks by sha */ static inline const struct bitcoin_blkid *keyof_block_map(const struct block *b) { return &b->blkid; } static inline size_t hash_sha(const struct bitcoin_blkid *key) { size_t ret; memcpy(&ret, key, sizeof(ret)); return ret; } static inline bool block_eq(const struct block *b, const struct bitcoin_blkid *key) { return bitcoin_blkid_eq(&b->blkid, key); } HTABLE_DEFINE_TYPE(struct block, keyof_block_map, hash_sha, block_eq, block_map); struct chain_topology { struct block *root; struct block *prev_tip, *tip; struct block_map block_map; u32 feerate[NUM_FEERATES]; bool startup; /* Where to store blockchain info. */ struct wallet *wallet; /* Where to log things. */ struct log *log; /* What range of blocks do we have in our database? */ u32 min_blockheight, max_blockheight; /* How often to poll. */ u32 poll_seconds; /* The bitcoind. */ struct bitcoind *bitcoind; /* Our timer list. */ struct timers *timers; /* Bitcoin transactions we're broadcasting */ struct list_head outgoing_txs; /* What fee we use if estimatefee fails (satoshis/kw) */ u32 default_fee_rate; /* Transactions/txos we are watching. */ struct txwatch_hash txwatches; struct txowatch_hash txowatches; #if DEVELOPER /* Force a particular fee rate regardless of estimatefee (satoshis/kw) */ u32 *dev_override_fee_rate; #endif }; /* Information relevant to locating a TX in a blockchain. */ struct txlocator { /* The height of the block that includes this transaction */ u32 blkheight; /* Position of the transaction in the transactions list */ u32 index; }; /* This is the number of blocks which would have to be mined to invalidate * the tx */ size_t get_tx_depth(const struct chain_topology *topo, const struct bitcoin_txid *txid); /* Get highest block number. */ u32 get_block_height(const struct chain_topology *topo); /* Get fee rate in satoshi per kiloweight. */ u32 get_feerate(const struct chain_topology *topo, enum feerate feerate); /* Broadcast a single tx, and rebroadcast as reqd (copies tx). * If failed is non-NULL, call that and don't rebroadcast. */ void broadcast_tx(struct chain_topology *topo, struct channel *channel, const struct bitcoin_tx *tx, void (*failed)(struct channel *channel, int exitstatus, const char *err)); struct chain_topology *new_topology(struct lightningd *ld, struct log *log); void setup_topology(struct chain_topology *topology, struct timers *timers, u32 min_blockheight, u32 max_blockheight); void begin_topology(struct chain_topology *topo); struct txlocator *locate_tx(const void *ctx, const struct chain_topology *topo, const struct bitcoin_txid *txid); void notify_feerate_change(struct lightningd *ld); #if DEVELOPER void chaintopology_mark_pointers_used(struct htable *memtable, const struct chain_topology *topo); #endif #endif /* LIGHTNING_LIGHTNINGD_CHAINTOPOLOGY_H */