2017-02-21 05:45:28 +01:00
|
|
|
#ifndef LIGHTNING_LIGHTNINGD_CHANNEL_H
|
|
|
|
#define LIGHTNING_LIGHTNINGD_CHANNEL_H
|
|
|
|
#include "config.h"
|
|
|
|
#include <bitcoin/pubkey.h>
|
|
|
|
#include <bitcoin/shadouble.h>
|
|
|
|
#include <ccan/short_types/short_types.h>
|
|
|
|
#include <ccan/tal/tal.h>
|
|
|
|
#include <daemon/htlc.h>
|
|
|
|
#include <lightningd/channel_config.h>
|
2017-03-07 02:07:06 +01:00
|
|
|
#include <lightningd/derive_basepoints.h>
|
2017-04-28 16:28:53 +02:00
|
|
|
#include <lightningd/sphinx.h>
|
2017-02-21 05:45:28 +01:00
|
|
|
#include <stdbool.h>
|
|
|
|
|
|
|
|
struct signature;
|
2017-06-20 08:05:03 +02:00
|
|
|
struct added_htlc;
|
|
|
|
struct failed_htlc;
|
|
|
|
struct fulfilled_htlc;
|
2017-02-21 05:45:28 +01:00
|
|
|
|
|
|
|
/* View from each side */
|
|
|
|
struct channel_view {
|
|
|
|
/* Current feerate in satoshis per 1000 weight. */
|
|
|
|
u64 feerate_per_kw;
|
|
|
|
|
|
|
|
/* How much is owed to each side (includes pending changes) */
|
|
|
|
u64 owed_msat[NUM_SIDES];
|
|
|
|
};
|
|
|
|
|
|
|
|
struct channel {
|
|
|
|
/* Funding txid and output. */
|
|
|
|
struct sha256_double funding_txid;
|
|
|
|
unsigned int funding_txout;
|
|
|
|
|
2017-03-29 12:58:15 +02:00
|
|
|
/* Keys used to spend funding tx. */
|
|
|
|
struct pubkey funding_pubkey[NUM_SIDES];
|
|
|
|
|
2017-02-21 05:45:28 +01:00
|
|
|
/* Millisatoshis in from commitment tx */
|
|
|
|
u64 funding_msat;
|
|
|
|
|
|
|
|
/* Who is paying fees. */
|
|
|
|
enum side funder;
|
|
|
|
|
|
|
|
/* Limits and settings on this channel. */
|
|
|
|
const struct channel_config *config[NUM_SIDES];
|
|
|
|
|
|
|
|
/* Basepoints for deriving keys. */
|
2017-03-07 02:07:06 +01:00
|
|
|
struct basepoints basepoints[NUM_SIDES];
|
2017-02-21 05:45:28 +01:00
|
|
|
|
|
|
|
/* Mask for obscuring the encoding of the commitment number. */
|
|
|
|
u64 commitment_number_obscurer;
|
|
|
|
|
|
|
|
/* All live HTLCs for this channel */
|
|
|
|
struct htlc_map htlcs;
|
|
|
|
|
|
|
|
/* What it looks like to each side. */
|
|
|
|
struct channel_view view[NUM_SIDES];
|
|
|
|
};
|
|
|
|
|
|
|
|
/* Some requirements are self-specified (eg. my dust limit), others
|
|
|
|
* are force upon the other side (eg. minimum htlc you can add).
|
|
|
|
*
|
|
|
|
* These values are also universally in msatsoshi. These avoid
|
|
|
|
* confusion: use them! */
|
|
|
|
|
|
|
|
/* BOLT #2:
|
|
|
|
*
|
2017-06-06 01:48:10 +02:00
|
|
|
* `dust_limit_satoshis` is the threshold below which output should be
|
2017-02-21 05:45:28 +01:00
|
|
|
* generated for this node's commitment or HTLC transaction */
|
|
|
|
static inline u64 dust_limit_satoshis(const struct channel *channel,
|
|
|
|
enum side side)
|
|
|
|
{
|
|
|
|
return channel->config[side]->dust_limit_satoshis;
|
|
|
|
}
|
|
|
|
/* BOLT #2:
|
|
|
|
*
|
2017-06-06 01:48:10 +02:00
|
|
|
* `max_htlc_value_in_flight_msat` is a cap on total value of
|
2017-02-21 05:45:28 +01:00
|
|
|
* outstanding HTLCs, which allows a node to limit its exposure to
|
|
|
|
* HTLCs */
|
|
|
|
static inline u64 max_htlc_value_in_flight_msat(const struct channel *channel,
|
|
|
|
enum side recipient)
|
|
|
|
{
|
|
|
|
return channel->config[recipient]->max_htlc_value_in_flight_msat;
|
|
|
|
}
|
|
|
|
/* BOLT #2:
|
|
|
|
*
|
2017-06-06 01:48:10 +02:00
|
|
|
* similarly `max_accepted_htlcs` limits the number of outstanding
|
2017-02-21 05:45:28 +01:00
|
|
|
* HTLCs the other node can offer. */
|
|
|
|
static inline u16 max_accepted_htlcs(const struct channel *channel,
|
|
|
|
enum side recipient)
|
|
|
|
{
|
|
|
|
return channel->config[recipient]->max_accepted_htlcs;
|
|
|
|
}
|
|
|
|
/* BOLT #2:
|
|
|
|
*
|
2017-06-06 01:48:10 +02:00
|
|
|
* `channel_reserve_satoshis` is the minimum amount that the other
|
2017-02-21 05:45:28 +01:00
|
|
|
* node is to keep as a direct payment. */
|
|
|
|
static inline u64 channel_reserve_msat(const struct channel *channel,
|
|
|
|
enum side side)
|
|
|
|
{
|
|
|
|
return channel->config[!side]->channel_reserve_satoshis * 1000;
|
|
|
|
}
|
|
|
|
/* BOLT #2:
|
|
|
|
*
|
2017-06-06 01:48:10 +02:00
|
|
|
* `htlc_minimum_msat` indicates the smallest value HTLC this node will accept.
|
2017-02-21 05:45:28 +01:00
|
|
|
*/
|
|
|
|
static inline u32 htlc_minimum_msat(const struct channel *channel,
|
|
|
|
enum side recipient)
|
|
|
|
{
|
|
|
|
return channel->config[recipient]->htlc_minimum_msat;
|
|
|
|
}
|
|
|
|
/* BOLT #2:
|
|
|
|
*
|
2017-06-06 01:48:10 +02:00
|
|
|
* `to_self_delay` is the number of blocks that the other nodes
|
2017-02-21 05:45:28 +01:00
|
|
|
* to-self outputs must be delayed, using `OP_CHECKSEQUENCEVERIFY`
|
|
|
|
* delays */
|
|
|
|
static inline u16 to_self_delay(const struct channel *channel, enum side side)
|
|
|
|
{
|
|
|
|
return channel->config[!side]->to_self_delay;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* new_channel: Given initial fees and funding, what is initial state?
|
|
|
|
* @ctx: tal context to allocate return value from.
|
|
|
|
* @funding_txid: The commitment transaction id.
|
|
|
|
* @funding_txout: The commitment transaction output number.
|
|
|
|
* @funding_satoshis: The commitment transaction amount.
|
2017-06-20 08:01:03 +02:00
|
|
|
* @local_msatoshi: The amount for the local side (remainder goes to remote)
|
2017-06-30 13:42:00 +02:00
|
|
|
* @feerate_per_kw: feerate per kiloweight (satoshis) for the commitment
|
|
|
|
* transaction and HTLCS
|
2017-02-21 05:45:28 +01:00
|
|
|
* @local: local channel configuration
|
|
|
|
* @remote: remote channel configuration
|
2017-03-07 02:07:06 +01:00
|
|
|
* @local_basepoints: local basepoints.
|
|
|
|
* @remote_basepoints: remote basepoints.
|
2017-03-29 12:58:15 +02:00
|
|
|
* @local_fundingkey: local funding key
|
|
|
|
* @remote_fundingkey: remote funding key
|
2017-02-21 05:45:28 +01:00
|
|
|
* @funder: which side initiated it.
|
|
|
|
*
|
|
|
|
* Returns state, or NULL if malformed.
|
|
|
|
*/
|
|
|
|
struct channel *new_channel(const tal_t *ctx,
|
|
|
|
const struct sha256_double *funding_txid,
|
|
|
|
unsigned int funding_txout,
|
|
|
|
u64 funding_satoshis,
|
2017-06-20 08:01:03 +02:00
|
|
|
u64 local_msatoshi,
|
2017-02-21 05:45:28 +01:00
|
|
|
u32 feerate_per_kw,
|
|
|
|
const struct channel_config *local,
|
|
|
|
const struct channel_config *remote,
|
2017-03-07 02:07:06 +01:00
|
|
|
const struct basepoints *local_basepoints,
|
|
|
|
const struct basepoints *remote_basepoints,
|
2017-03-29 12:58:15 +02:00
|
|
|
const struct pubkey *local_funding_pubkey,
|
|
|
|
const struct pubkey *remote_funding_pubkey,
|
2017-02-21 05:45:28 +01:00
|
|
|
enum side funder);
|
2017-03-29 12:58:15 +02:00
|
|
|
|
2017-02-21 05:45:28 +01:00
|
|
|
/**
|
2017-03-29 12:58:15 +02:00
|
|
|
* channel_txs: Get the current commitment and htlc txs for the channel.
|
2017-02-21 05:45:28 +01:00
|
|
|
* @ctx: tal context to allocate return value from.
|
|
|
|
* @channel: The channel to evaluate
|
|
|
|
* @htlc_map: Pointer to htlcs for each tx output (allocated off @ctx) or NULL.
|
2017-03-29 12:58:15 +02:00
|
|
|
* @wscripts: Pointer to array of wscript for each tx returned (alloced off @ctx)
|
|
|
|
* @per_commitment_point: Per-commitment point to determine keys
|
2017-06-20 08:10:03 +02:00
|
|
|
* @commitment_number: The index of this commitment.
|
2017-02-21 05:45:28 +01:00
|
|
|
* @side: which side to get the commitment transaction for
|
|
|
|
*
|
|
|
|
* Returns the unsigned commitment transaction for the committed state
|
2017-03-29 12:58:15 +02:00
|
|
|
* for @side, followed by the htlc transactions in output order, and
|
|
|
|
* fills in @htlc_map (if not NULL), or NULL on key derivation
|
|
|
|
* failure.
|
2017-02-21 05:45:28 +01:00
|
|
|
*/
|
2017-03-29 12:58:15 +02:00
|
|
|
struct bitcoin_tx **channel_txs(const tal_t *ctx,
|
|
|
|
const struct htlc ***htlcmap,
|
|
|
|
const u8 ***wscripts,
|
|
|
|
const struct channel *channel,
|
|
|
|
const struct pubkey *per_commitment_point,
|
2017-06-20 08:10:03 +02:00
|
|
|
u64 commitment_number,
|
2017-03-29 12:58:15 +02:00
|
|
|
enum side side);
|
2017-02-21 05:45:28 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* actual_feerate: what is the actual feerate for the local side.
|
|
|
|
* @channel: The channel state
|
|
|
|
* @theirsig: The other side's signature
|
|
|
|
*
|
|
|
|
* The fee calculated on a commitment transaction is a worst-case
|
|
|
|
* approximation. It's also possible that the desired feerate is not
|
|
|
|
* met, because the initiator sets it while the other side is adding many
|
|
|
|
* htlcs.
|
|
|
|
*
|
|
|
|
* This is the fee rate we actually care about, if we're going to check
|
|
|
|
* whether it's actually too low.
|
|
|
|
*/
|
|
|
|
uint32_t actual_feerate(const struct channel *channel,
|
|
|
|
const struct signature *theirsig);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* copy_channel: Make a deep copy of channel
|
|
|
|
* @ctx: tal context to allocate return value from.
|
|
|
|
* @channel: channel to copy.
|
|
|
|
*/
|
|
|
|
struct channel *copy_channel(const tal_t *ctx, const struct channel *channel);
|
|
|
|
|
|
|
|
enum channel_add_err {
|
|
|
|
/* All OK! */
|
|
|
|
CHANNEL_ERR_ADD_OK,
|
|
|
|
/* Bad expiry value */
|
|
|
|
CHANNEL_ERR_INVALID_EXPIRY,
|
|
|
|
/* Not really a failure, if expected: it's an exact duplicate. */
|
|
|
|
CHANNEL_ERR_DUPLICATE,
|
|
|
|
/* Same ID, but otherwise different. */
|
|
|
|
CHANNEL_ERR_DUPLICATE_ID_DIFFERENT,
|
|
|
|
/* Would exceed the specified max_htlc_value_in_flight_msat */
|
|
|
|
CHANNEL_ERR_MAX_HTLC_VALUE_EXCEEDED,
|
|
|
|
/* Can't afford it */
|
|
|
|
CHANNEL_ERR_CHANNEL_CAPACITY_EXCEEDED,
|
|
|
|
/* HTLC is below htlc_minimum_msat */
|
|
|
|
CHANNEL_ERR_HTLC_BELOW_MINIMUM,
|
|
|
|
/* HTLC would push past max_accepted_htlcs */
|
|
|
|
CHANNEL_ERR_TOO_MANY_HTLCS,
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* channel_add_htlc: append an HTLC to channel if it can afford it
|
|
|
|
* @channel: The channel
|
|
|
|
* @offerer: the side offering the HTLC (to the other side).
|
|
|
|
* @id: unique HTLC id.
|
|
|
|
* @msatoshi: amount in millisatoshi.
|
2017-03-29 12:55:15 +02:00
|
|
|
* @cltv_expiry: block number when HTLC can no longer be redeemed.
|
2017-02-21 05:45:28 +01:00
|
|
|
* @payment_hash: hash whose preimage can redeem HTLC.
|
|
|
|
* @routing: routing information (copied)
|
|
|
|
*
|
|
|
|
* If this returns CHANNEL_ERR_NONE, the fee htlc was added and
|
|
|
|
* the output amounts adjusted accordingly. Otherwise nothing
|
|
|
|
* is changed.
|
|
|
|
*/
|
|
|
|
enum channel_add_err channel_add_htlc(struct channel *channel,
|
|
|
|
enum side sender,
|
|
|
|
u64 id,
|
|
|
|
u64 msatoshi,
|
2017-03-29 12:55:15 +02:00
|
|
|
u32 cltv_expiry,
|
2017-02-21 05:45:28 +01:00
|
|
|
const struct sha256 *payment_hash,
|
2017-04-28 16:28:53 +02:00
|
|
|
const u8 routing[TOTAL_PACKET_SIZE]);
|
2017-02-21 05:45:28 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* channel_get_htlc: find an HTLC
|
|
|
|
* @channel: The channel
|
|
|
|
* @offerer: the side offering the HTLC.
|
|
|
|
* @id: unique HTLC id.
|
|
|
|
*/
|
|
|
|
struct htlc *channel_get_htlc(struct channel *channel, enum side sender, u64 id);
|
|
|
|
|
|
|
|
enum channel_remove_err {
|
|
|
|
/* All OK! */
|
|
|
|
CHANNEL_ERR_REMOVE_OK,
|
|
|
|
/* No such HTLC. */
|
|
|
|
CHANNEL_ERR_NO_SUCH_ID,
|
|
|
|
/* Already have fulfilled it */
|
|
|
|
CHANNEL_ERR_ALREADY_FULFILLED,
|
|
|
|
/* Preimage doesn't hash to value. */
|
|
|
|
CHANNEL_ERR_BAD_PREIMAGE,
|
|
|
|
/* HTLC is not committed */
|
|
|
|
CHANNEL_ERR_HTLC_UNCOMMITTED,
|
|
|
|
/* HTLC is not committed and prior revoked on both sides */
|
|
|
|
CHANNEL_ERR_HTLC_NOT_IRREVOCABLE
|
|
|
|
};
|
|
|
|
|
|
|
|
/**
|
|
|
|
* channel_fail_htlc: remove an HTLC, funds to the side which offered it.
|
|
|
|
* @channel: The channel state
|
2017-04-01 13:01:11 +02:00
|
|
|
* @owner: the side who offered the HTLC (opposite to that failing it)
|
2017-02-21 05:45:28 +01:00
|
|
|
* @id: unique HTLC id.
|
|
|
|
*
|
|
|
|
* This will remove the htlc and credit the value of the HTLC (back)
|
|
|
|
* to its offerer.
|
|
|
|
*/
|
|
|
|
enum channel_remove_err channel_fail_htlc(struct channel *channel,
|
2017-04-01 13:01:11 +02:00
|
|
|
enum side owner, u64 id);
|
2017-02-21 05:45:28 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* channel_fulfill_htlc: remove an HTLC, funds to side which accepted it.
|
|
|
|
* @channel: The channel state
|
2017-04-01 13:01:11 +02:00
|
|
|
* @owner: the side who offered the HTLC (opposite to that fulfilling it)
|
2017-02-21 05:45:28 +01:00
|
|
|
* @id: unique HTLC id.
|
|
|
|
*
|
|
|
|
* If the htlc exists, is not already fulfilled, the preimage is correct and
|
|
|
|
* HTLC committed at the recipient, this will add a pending change to
|
|
|
|
* remove the htlc and give the value of the HTLC to its recipient,
|
|
|
|
* and return CHANNEL_ERR_FULFILL_OK. Otherwise, it will return another error.
|
|
|
|
*/
|
|
|
|
enum channel_remove_err channel_fulfill_htlc(struct channel *channel,
|
2017-04-01 13:01:11 +02:00
|
|
|
enum side owner,
|
2017-02-21 05:45:28 +01:00
|
|
|
u64 id,
|
|
|
|
const struct preimage *preimage);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* approx_max_feerate: what's the we (initiator) could raise fee rate to?
|
|
|
|
* @channel: The channel state
|
|
|
|
*
|
|
|
|
* This is not exact! To check if their offer is valid, use can_afford_feerate.
|
|
|
|
*/
|
|
|
|
u64 approx_max_feerate(const struct channel *channel);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* can_afford_feerate: could the initiator pay for the fee at fee_rate?
|
|
|
|
* @channel: The channel state
|
|
|
|
* @feerate_per_kw: the new fee rate proposed
|
|
|
|
*/
|
|
|
|
bool can_afford_feerate(const struct channel *channel, u64 feerate_per_kw);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* adjust_fee: Change fee rate.
|
|
|
|
* @channel: The channel state
|
|
|
|
* @feerate_per_kw: fee in satoshi per 1000 bytes.
|
|
|
|
* @side: which side to adjust.
|
|
|
|
*/
|
|
|
|
void adjust_fee(struct channel *channel, u64 feerate_per_kw, enum side side);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* force_fee: Change fees to a specific value.
|
|
|
|
* @channel: The channel state
|
|
|
|
* @fee: fee in satoshi.
|
|
|
|
*
|
|
|
|
* This is used for the close transaction, which specifies an exact fee.
|
|
|
|
* If the fee cannot be paid in full, this return false (but cstate will
|
|
|
|
* still be altered).
|
|
|
|
*/
|
|
|
|
bool force_fee(struct channel *channel, u64 fee);
|
|
|
|
|
|
|
|
/**
|
2017-04-01 12:58:23 +02:00
|
|
|
* channel_sending_commit: commit all remote outstanding changes.
|
2017-02-21 05:45:28 +01:00
|
|
|
* @channel: the channel
|
2017-06-20 07:41:03 +02:00
|
|
|
* @htlcs: initially-empty tal_arr() for htlcs which changed state.
|
2017-02-21 05:45:28 +01:00
|
|
|
*
|
|
|
|
* This is where we commit to pending changes we've added; returns true if
|
2017-04-01 12:58:23 +02:00
|
|
|
* anything changed for the remote side (if not, don't send!) */
|
2017-06-20 07:41:03 +02:00
|
|
|
bool channel_sending_commit(struct channel *channel,
|
|
|
|
const struct htlc ***htlcs);
|
2017-02-21 05:45:28 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* channel_rcvd_revoke_and_ack: accept ack on remote committed changes.
|
|
|
|
* @channel: the channel
|
2017-06-20 07:41:03 +02:00
|
|
|
* @htlcs: initially-empty tal_arr() for htlcs which changed state.
|
2017-02-21 05:45:28 +01:00
|
|
|
*
|
|
|
|
* This is where we commit to pending changes we've added; returns true if
|
2017-04-01 12:58:23 +02:00
|
|
|
* anything changed for our local commitment (ie. we have pending changes).
|
2017-04-01 12:29:39 +02:00
|
|
|
*/
|
2017-06-20 07:41:03 +02:00
|
|
|
bool channel_rcvd_revoke_and_ack(struct channel *channel,
|
|
|
|
const struct htlc ***htlcs);
|
2017-02-21 05:45:28 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* channel_rcvd_commit: commit all local outstanding changes.
|
|
|
|
* @channel: the channel
|
2017-06-20 07:41:03 +02:00
|
|
|
* @htlcs: initially-empty tal_arr() for htlcs which changed state.
|
2017-02-21 05:45:28 +01:00
|
|
|
*
|
|
|
|
* This is where we commit to pending changes we've added; returns true if
|
2017-04-01 12:58:23 +02:00
|
|
|
* anything changed for our local commitment (ie. we had pending changes).
|
2017-04-01 12:29:39 +02:00
|
|
|
*/
|
2017-06-20 07:41:03 +02:00
|
|
|
bool channel_rcvd_commit(struct channel *channel,
|
|
|
|
const struct htlc ***htlcs);
|
2017-02-21 05:45:28 +01:00
|
|
|
|
|
|
|
/**
|
2017-04-01 12:58:23 +02:00
|
|
|
* channel_sending_revoke_and_ack: sending ack on local committed changes.
|
2017-02-21 05:45:28 +01:00
|
|
|
* @channel: the channel
|
|
|
|
*
|
2017-04-01 12:58:23 +02:00
|
|
|
* This is where we commit to pending changes we've added. Returns true if
|
|
|
|
* anything changed for the remote commitment (ie. send a new commit).*/
|
|
|
|
bool channel_sending_revoke_and_ack(struct channel *channel);
|
2017-02-21 05:45:28 +01:00
|
|
|
|
2017-04-01 12:58:30 +02:00
|
|
|
/**
|
|
|
|
* channel_awaiting_revoke_and_ack: are we waiting for revoke_and_ack?
|
|
|
|
* @channel: the channel
|
|
|
|
*
|
|
|
|
* If true, we can't send a new commit message.
|
|
|
|
*/
|
|
|
|
bool channel_awaiting_revoke_and_ack(const struct channel *channel);
|
2017-06-20 07:47:03 +02:00
|
|
|
|
2017-07-04 02:47:32 +02:00
|
|
|
/**
|
|
|
|
* channel_has_htlcs: are there any HTLCs at all in channel?
|
|
|
|
* @channel: the channel
|
|
|
|
*/
|
|
|
|
bool channel_has_htlcs(const struct channel *channel);
|
|
|
|
|
2017-06-20 08:05:03 +02:00
|
|
|
/**
|
|
|
|
* channel_force_htlcs: force these htlcs into the (new) channel
|
|
|
|
* @channel: the channel
|
|
|
|
* @htlcs: the htlcs to add (tal_arr)
|
|
|
|
* @hstates: the states for the htlcs (tal_arr of same size)
|
|
|
|
* @fulfilled: htlcs of those which are fulfilled
|
|
|
|
* @fulfilled_sides: sides for ids in @fulfilled
|
|
|
|
* @failed: htlcs of those which are failed
|
|
|
|
* @failed_sides: sides for ids in @failed
|
|
|
|
*
|
|
|
|
* This is used for restoring a channel state.
|
|
|
|
*/
|
|
|
|
bool channel_force_htlcs(struct channel *channel,
|
|
|
|
const struct added_htlc *htlcs,
|
|
|
|
const enum htlc_state *hstates,
|
|
|
|
const struct fulfilled_htlc *fulfilled,
|
|
|
|
const enum side *fulfilled_sides,
|
|
|
|
const struct failed_htlc *failed,
|
|
|
|
const enum side *failed_sides);
|
|
|
|
|
2017-06-20 07:47:03 +02:00
|
|
|
/**
|
|
|
|
* dump_htlcs: debugging dump of all HTLCs
|
|
|
|
* @channel: the channel
|
|
|
|
* @prefix: the prefix to prepend to each line.
|
|
|
|
*
|
|
|
|
* Uses status_trace() on every HTLC.
|
|
|
|
*/
|
|
|
|
void dump_htlcs(const struct channel *channel, const char *prefix);
|
2017-02-21 05:45:28 +01:00
|
|
|
#endif /* LIGHTNING_DAEMON_CHANNEL_H */
|