2017-08-28 18:02:01 +02:00
|
|
|
/* Commit tx without HTLC support; needed for openingd. */
|
|
|
|
#ifndef LIGHTNING_COMMON_INITIAL_COMMIT_TX_H
|
|
|
|
#define LIGHTNING_COMMON_INITIAL_COMMIT_TX_H
|
|
|
|
#include "config.h"
|
|
|
|
#include <bitcoin/pubkey.h>
|
2017-08-28 18:04:01 +02:00
|
|
|
#include <common/htlc.h>
|
2017-08-28 18:02:01 +02:00
|
|
|
|
|
|
|
struct keyset;
|
|
|
|
struct sha256_double;
|
|
|
|
|
|
|
|
/* BOLT #3:
|
|
|
|
*
|
|
|
|
* This obscures the number of commitments made on the channel in the
|
|
|
|
* case of unilateral close, yet still provides a useful index for
|
|
|
|
* both nodes (who know the `payment_basepoint`s) to quickly find a
|
|
|
|
* revoked commitment transaction.
|
|
|
|
*/
|
|
|
|
u64 commit_number_obscurer(const struct pubkey *opener_payment_basepoint,
|
|
|
|
const struct pubkey *accepter_payment_basepoint);
|
|
|
|
|
|
|
|
/* Helper to calculate the base fee if we have this many htlc outputs */
|
|
|
|
static inline u64 commit_tx_base_fee(u64 feerate_per_kw,
|
|
|
|
size_t num_untrimmed_htlcs)
|
|
|
|
{
|
|
|
|
u64 weight;
|
|
|
|
|
|
|
|
/* BOLT #3:
|
|
|
|
*
|
|
|
|
* The base fee for a commitment transaction MUST BE
|
|
|
|
* calculated to match:
|
|
|
|
*
|
|
|
|
* 1. Start with `weight` = 724.
|
|
|
|
*/
|
|
|
|
weight = 724;
|
|
|
|
|
|
|
|
/* BOLT #3:
|
|
|
|
*
|
|
|
|
* 2. For each committed HTLC, if that output is not trimmed
|
|
|
|
* as specified in [Trimmed Outputs](#trimmed-outputs), add
|
|
|
|
* 172 to `weight`.
|
|
|
|
*/
|
|
|
|
weight += 172 * num_untrimmed_htlcs;
|
|
|
|
|
|
|
|
/* BOLT #3:
|
|
|
|
*
|
|
|
|
* 3. Multiply `feerate_per_kw` by `weight`, divide by 1000
|
|
|
|
* (rounding down).
|
|
|
|
*/
|
|
|
|
return feerate_per_kw * weight / 1000;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* initial_commit_tx: create (unsigned) commitment tx to spend the funding tx output
|
|
|
|
* @ctx: context to allocate transaction and @htlc_map from.
|
|
|
|
* @funding_txid, @funding_out, @funding_satoshis: funding outpoint.
|
|
|
|
* @funder: is the LOCAL or REMOTE paying the fee?
|
|
|
|
* @keyset: keys derived for this commit tx.
|
|
|
|
* @feerate_per_kw: feerate to use
|
|
|
|
* @dust_limit_satoshis: dust limit below which to trim outputs.
|
|
|
|
* @self_pay_msat: amount to pay directly to self
|
|
|
|
* @other_pay_msat: amount to pay directly to the other side
|
|
|
|
* @obscured_commitment_number: number to encode in commitment transaction
|
|
|
|
* @side: side to generate commitment transaction for.
|
|
|
|
*
|
|
|
|
* We need to be able to generate the remote side's tx to create signatures,
|
|
|
|
* but the BOLT is expressed in terms of generating our local commitment
|
|
|
|
* transaction, so we carefully use the terms "self" and "other" here.
|
|
|
|
*/
|
|
|
|
struct bitcoin_tx *initial_commit_tx(const tal_t *ctx,
|
|
|
|
const struct sha256_double *funding_txid,
|
|
|
|
unsigned int funding_txout,
|
|
|
|
u64 funding_satoshis,
|
|
|
|
enum side funder,
|
|
|
|
u16 to_self_delay,
|
|
|
|
const struct keyset *keyset,
|
|
|
|
u64 feerate_per_kw,
|
|
|
|
u64 dust_limit_satoshis,
|
|
|
|
u64 self_pay_msat,
|
|
|
|
u64 other_pay_msat,
|
|
|
|
u64 obscured_commitment_number,
|
|
|
|
enum side side);
|
|
|
|
|
|
|
|
/* try_subtract_fee - take away this fee from the funder, or all if insufficient. */
|
|
|
|
void try_subtract_fee(enum side funder, enum side side,
|
|
|
|
u64 base_fee_msat, u64 *self_msat, u64 *other_msat);
|
|
|
|
|
|
|
|
/* Generate the witness script for the to-self output:
|
|
|
|
* scriptpubkey_p2wsh(ctx, wscript) gives the scriptpubkey */
|
|
|
|
u8 *to_self_wscript(const tal_t *ctx,
|
|
|
|
u16 to_self_delay,
|
|
|
|
const struct keyset *keyset);
|
|
|
|
|
|
|
|
/* To-other is simply: scriptpubkey_p2wpkh(tx, keyset->other_payment_key) */
|
|
|
|
|
|
|
|
#endif /* LIGHTNING_COMMON_INITIAL_COMMIT_TX_H */
|