2015-07-29 08:44:28 +02:00
|
|
|
#ifndef LIGHTNING_FUNDING_H
|
|
|
|
#define LIGHTNING_FUNDING_H
|
2016-01-21 21:08:08 +01:00
|
|
|
#include "config.h"
|
2016-01-21 21:11:47 +01:00
|
|
|
#include "bitcoin/locktime.h"
|
|
|
|
#include <ccan/crypto/sha256/sha256.h>
|
2015-08-07 05:15:30 +02:00
|
|
|
#include <ccan/tal/tal.h>
|
2015-07-29 08:44:28 +02:00
|
|
|
#include <stdbool.h>
|
|
|
|
|
2016-01-21 21:11:47 +01:00
|
|
|
struct channel_htlc {
|
2016-03-30 08:25:03 +02:00
|
|
|
u64 id;
|
2016-01-21 21:11:47 +01:00
|
|
|
u64 msatoshis;
|
|
|
|
struct abs_locktime expiry;
|
|
|
|
struct sha256 rhash;
|
|
|
|
};
|
|
|
|
|
2015-08-07 05:15:30 +02:00
|
|
|
struct channel_oneside {
|
2015-09-24 07:30:47 +02:00
|
|
|
/* Payment and fee is in millisatoshi. */
|
|
|
|
uint32_t pay_msat, fee_msat;
|
2015-08-07 05:15:30 +02:00
|
|
|
/* Use tal_count to get the number */
|
2016-01-21 21:11:47 +01:00
|
|
|
struct channel_htlc *htlcs;
|
2015-08-07 05:15:30 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
struct channel_state {
|
2016-03-24 02:42:43 +01:00
|
|
|
/* Satoshis paid by anchor. */
|
|
|
|
uint64_t anchor;
|
|
|
|
/* Satoshis per 1000 bytes. */
|
|
|
|
uint32_t fee_rate;
|
2016-03-31 08:42:20 +02:00
|
|
|
/* Generation counter (incremented on every change) */
|
|
|
|
uint32_t changes;
|
2015-08-07 05:15:30 +02:00
|
|
|
struct channel_oneside a, b;
|
|
|
|
};
|
|
|
|
|
2015-07-29 08:44:28 +02:00
|
|
|
/**
|
|
|
|
* initial_funding: Given A, B, and anchor, what is initial state?
|
2015-08-07 05:15:30 +02:00
|
|
|
* @ctx: tal context to allocate return value from.
|
2016-01-21 21:11:47 +01:00
|
|
|
* @am_funder: am I paying for the anchor?
|
|
|
|
* @anchor_satoshis: The anchor amount.
|
2016-03-24 02:42:43 +01:00
|
|
|
* @fee_rate: amount to pay in fees per kb (in satoshi).
|
2015-08-07 05:15:30 +02:00
|
|
|
*
|
|
|
|
* Returns state, or NULL if malformed.
|
2015-07-29 08:44:28 +02:00
|
|
|
*/
|
2015-08-07 05:15:30 +02:00
|
|
|
struct channel_state *initial_funding(const tal_t *ctx,
|
2016-01-21 21:11:47 +01:00
|
|
|
bool am_funder,
|
|
|
|
uint64_t anchor_satoshis,
|
2016-03-24 02:42:43 +01:00
|
|
|
uint32_t fee_rate);
|
2015-07-29 08:44:28 +02:00
|
|
|
|
2016-01-21 21:11:47 +01:00
|
|
|
/**
|
|
|
|
* copy_funding: Make a deep copy of channel_state
|
|
|
|
* @ctx: tal context to allocate return value from.
|
|
|
|
* @cstate: state to copy.
|
|
|
|
*/
|
|
|
|
struct channel_state *copy_funding(const tal_t *ctx,
|
|
|
|
const struct channel_state *cstate);
|
|
|
|
|
2015-07-29 08:44:28 +02:00
|
|
|
/**
|
2016-03-24 02:42:43 +01:00
|
|
|
* funding_a_add_htlc: append an HTLC to A's side of cstate if it can afford it
|
|
|
|
* @cstate: The channel state
|
|
|
|
* @msatoshis: Millisatoshi A is putting into a HTLC
|
|
|
|
* @expiry: time it expires
|
|
|
|
* @rhash: hash of redeem secret
|
2016-03-30 08:25:03 +02:00
|
|
|
* @id: 64-bit ID for htlc
|
2016-03-24 02:42:43 +01:00
|
|
|
*
|
|
|
|
* If A can't afford the HTLC (or still owes its half of the fees),
|
|
|
|
* this will return false and leave @cstate unchanged. Otherwise
|
|
|
|
* cstate->a.htlcs will have the HTLC appended, and pay_msat and
|
|
|
|
* fee_msat are adjusted accordingly.
|
2015-07-29 08:44:28 +02:00
|
|
|
*/
|
2016-03-24 02:42:43 +01:00
|
|
|
bool funding_a_add_htlc(struct channel_state *cstate,
|
|
|
|
u32 msatoshis, const struct abs_locktime *expiry,
|
2016-03-30 08:25:03 +02:00
|
|
|
const struct sha256 *rhash, uint64_t id);
|
2016-03-24 02:42:43 +01:00
|
|
|
|
|
|
|
bool funding_b_add_htlc(struct channel_state *cstate,
|
|
|
|
u32 msatoshis, const struct abs_locktime *expiry,
|
2016-03-30 08:25:03 +02:00
|
|
|
const struct sha256 *rhash, uint64_t id);
|
2015-07-29 08:44:28 +02:00
|
|
|
|
2016-01-21 21:11:47 +01:00
|
|
|
/**
|
2016-03-24 02:42:43 +01:00
|
|
|
* funding_a_fail_htlc: remove an HTLC from A's side of cstate, funds to A
|
|
|
|
* @cstate: The channel state
|
|
|
|
* @index: the index into cstate->a.htlcs[].
|
|
|
|
*
|
|
|
|
* This will remove the @index'th entry in cstate->a.htlcs[], and credit
|
|
|
|
* the value of the HTLC (back) to A.
|
2016-01-21 21:11:47 +01:00
|
|
|
*/
|
2016-03-24 02:42:43 +01:00
|
|
|
void funding_a_fail_htlc(struct channel_state *cstate, size_t index);
|
|
|
|
void funding_b_fail_htlc(struct channel_state *cstate, size_t index);
|
2016-01-21 21:11:47 +01:00
|
|
|
|
2015-07-29 08:46:24 +02:00
|
|
|
/**
|
2016-03-24 02:42:43 +01:00
|
|
|
* funding_a_fulfill_htlc: remove an HTLC from A's side of cstate, funds to B
|
|
|
|
* @cstate: The channel state
|
|
|
|
* @index: the index into cstate->a.htlcs[].
|
|
|
|
*
|
|
|
|
* This will remove the @index'th entry in cstate->a.htlcs[], and credit
|
|
|
|
* the value of the HTLC to B.
|
2015-07-29 08:46:24 +02:00
|
|
|
*/
|
2016-03-24 02:42:43 +01:00
|
|
|
void funding_a_fulfill_htlc(struct channel_state *cstate, size_t index);
|
|
|
|
void funding_b_fulfill_htlc(struct channel_state *cstate, size_t index);
|
2015-08-07 05:15:30 +02:00
|
|
|
|
|
|
|
/**
|
2016-03-24 02:42:43 +01:00
|
|
|
* adjust_fee: Change fee rate.
|
|
|
|
* @cstate: The channel state
|
|
|
|
* @fee_rate: fee in satoshi per 1000 bytes.
|
2015-08-07 05:15:30 +02:00
|
|
|
*/
|
2016-03-24 02:42:43 +01:00
|
|
|
void adjust_fee(struct channel_state *cstate, uint32_t fee_rate);
|
2015-08-07 05:15:30 +02:00
|
|
|
|
2016-01-21 21:11:47 +01:00
|
|
|
/**
|
2016-03-24 02:42:43 +01:00
|
|
|
* force_fee: Change fee to a specific value.
|
|
|
|
* @cstate: 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).
|
2016-01-21 21:11:47 +01:00
|
|
|
*/
|
2016-03-24 02:42:43 +01:00
|
|
|
bool force_fee(struct channel_state *cstate, uint64_t fee);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* invert_cstate: Get the other side's state.
|
|
|
|
* @cstate: the state to invert.
|
|
|
|
*/
|
|
|
|
void invert_cstate(struct channel_state *cstate);
|
2016-01-21 21:11:47 +01:00
|
|
|
|
2016-01-21 21:11:47 +01:00
|
|
|
/**
|
|
|
|
* funding_find_htlc: find an HTLC on this side of the channel.
|
|
|
|
* @creator: channel_state->a or channel_state->b, whichever originated htlc
|
|
|
|
* @rhash: hash of redeem secret
|
|
|
|
*
|
|
|
|
* Returns a number < tal_count(creator->htlcs), or == tal_count(creator->htlcs)
|
|
|
|
* on fail.
|
|
|
|
*/
|
|
|
|
size_t funding_find_htlc(struct channel_oneside *creator,
|
|
|
|
const struct sha256 *rhash);
|
|
|
|
|
2016-03-30 08:25:03 +02:00
|
|
|
/**
|
|
|
|
* funding_htlc_by_id: find an HTLC on this side of the channel by ID.
|
|
|
|
* @creator: channel_state->a or channel_state->b, whichever originated htlc
|
|
|
|
* @id: id for HTLC.
|
|
|
|
*
|
|
|
|
* Returns a number < tal_count(creator->htlcs), or == tal_count(creator->htlcs)
|
|
|
|
* on fail.
|
|
|
|
*/
|
|
|
|
size_t funding_htlc_by_id(struct channel_oneside *creator, uint64_t id);
|
|
|
|
|
2016-01-21 21:11:47 +01:00
|
|
|
/**
|
2016-03-24 02:42:43 +01:00
|
|
|
* fee_for_feerate: calculate the fee (in satoshi) for a given fee_rate.
|
|
|
|
* @txsize: transaction size in bytes.
|
|
|
|
* @fee_rate: satoshi per 1000 bytes.
|
|
|
|
*/
|
|
|
|
uint64_t fee_by_feerate(size_t txsize, uint32_t fee_rate);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* is_dust_amount: is an output of this value considered dust?
|
|
|
|
* @satoshis: number of satoshis.
|
|
|
|
*
|
|
|
|
* Transactions with dust outputs will not be relayed by the bitcoin
|
|
|
|
* network. It's not an exact definition, unfortunately.
|
2016-01-21 21:11:47 +01:00
|
|
|
*/
|
2016-03-24 02:42:43 +01:00
|
|
|
bool is_dust_amount(uint64_t satoshis);
|
2016-01-21 21:11:47 +01:00
|
|
|
|
2015-07-29 08:44:28 +02:00
|
|
|
#endif /* LIGHTNING_FUNDING_H */
|