2015-05-26 06:38:12 +02:00
|
|
|
#ifndef LIGHTNING_PKT_H
|
|
|
|
#define LIGHTNING_PKT_H
|
|
|
|
/* Simple (non-threadsafe!) wrapper for protobufs.
|
|
|
|
*
|
|
|
|
* This could be a simple set of macros, if the protobuf-c people hadn't
|
|
|
|
* insisted on "prettifing" the names they generate into CamelCase.
|
|
|
|
*/
|
|
|
|
#include <ccan/endian/endian.h>
|
|
|
|
#include <ccan/short_types/short_types.h>
|
|
|
|
#include <ccan/tal/tal.h>
|
2015-06-12 04:56:59 +02:00
|
|
|
#include "lightning.pb-c.h"
|
2015-05-26 06:38:12 +02:00
|
|
|
|
|
|
|
/* A packet, ready to be de-protobuf'ed. */
|
|
|
|
struct pkt {
|
|
|
|
le32 len;
|
|
|
|
u8 data[];
|
|
|
|
};
|
|
|
|
|
2015-05-28 23:38:27 +02:00
|
|
|
/* Utility helper: dies if there's a problem. */
|
|
|
|
Pkt *pkt_from_file(const char *filename, Pkt__PktCase expect);
|
2015-06-09 06:07:30 +02:00
|
|
|
Pkt *any_pkt_from_file(const char *filename);
|
2015-05-28 23:38:27 +02:00
|
|
|
|
2015-06-12 05:31:50 +02:00
|
|
|
/* Total length of packet, including header. */
|
|
|
|
size_t pkt_totlen(const struct pkt *pkt);
|
|
|
|
|
2015-05-26 06:38:12 +02:00
|
|
|
struct sha256;
|
2015-07-24 08:30:10 +02:00
|
|
|
struct sha256_double;
|
2015-05-28 23:38:27 +02:00
|
|
|
struct bitcoin_compressed_pubkey;
|
2015-06-01 04:26:09 +02:00
|
|
|
struct signature;
|
2015-06-05 04:07:27 +02:00
|
|
|
struct pubkey;
|
2015-05-26 06:38:12 +02:00
|
|
|
|
|
|
|
/**
|
2015-05-28 23:38:27 +02:00
|
|
|
* openchannel_pkt - create an openchannel message
|
2015-05-26 06:38:12 +02:00
|
|
|
* @ctx: tal context to allocate off.
|
|
|
|
* @revocation_hash: first hash value generated from seed.
|
2015-07-24 08:30:10 +02:00
|
|
|
* @commit: the pubkey for commit transactions.
|
|
|
|
* @final: the pubkey for the commit transactions' output and escape input.
|
2015-05-26 06:38:12 +02:00
|
|
|
* @commitment_fee: the fee to use for commitment tx.
|
|
|
|
* @rel_locktime_seconds: relative seconds for commitment locktime.
|
2015-07-24 08:30:10 +02:00
|
|
|
* @anchor_txid: the anchor transaction ID.
|
|
|
|
* @anchor_amount: the anchor amount.
|
|
|
|
* @escape_hash: the hash whose preimage will revoke our escape txs.
|
|
|
|
* @min_confirms: how many confirms we want on anchor.
|
2015-05-26 06:38:12 +02:00
|
|
|
*/
|
|
|
|
struct pkt *openchannel_pkt(const tal_t *ctx,
|
|
|
|
const struct sha256 *revocation_hash,
|
2015-07-24 08:30:10 +02:00
|
|
|
const struct pubkey *commit,
|
|
|
|
const struct pubkey *final,
|
2015-05-26 06:38:12 +02:00
|
|
|
u64 commitment_fee,
|
|
|
|
u32 rel_locktime_seconds,
|
2015-07-24 08:30:10 +02:00
|
|
|
u64 anchor_amount,
|
|
|
|
const struct sha256 *escape_hash,
|
|
|
|
u32 min_confirms);
|
2015-05-26 06:38:12 +02:00
|
|
|
|
2015-05-28 23:38:27 +02:00
|
|
|
/**
|
2015-07-24 08:30:10 +02:00
|
|
|
* open_anchor_pkt - create an open_anchor_sig message
|
2015-05-28 23:38:27 +02:00
|
|
|
* @ctx: tal context to allocate off.
|
2015-07-24 08:30:10 +02:00
|
|
|
* @txid: the anchor's txid
|
|
|
|
* @index: the anchor's output to spend.
|
2015-05-28 23:38:27 +02:00
|
|
|
*/
|
2015-07-24 08:30:10 +02:00
|
|
|
struct pkt *open_anchor_pkt(const tal_t *ctx,
|
|
|
|
const struct sha256_double *txid, u32 index);
|
2015-05-26 06:38:12 +02:00
|
|
|
|
2015-05-30 12:41:10 +02:00
|
|
|
/**
|
|
|
|
* open_commit_sig_pkt - create an open_commit_sig message
|
|
|
|
* @ctx: tal context to allocate off.
|
2015-07-24 08:30:10 +02:00
|
|
|
* @sigs: two signatures for the commit transaction inputs
|
2015-05-30 12:41:10 +02:00
|
|
|
*/
|
2015-07-24 08:30:10 +02:00
|
|
|
struct pkt *open_commit_sig_pkt(const tal_t *ctx,
|
|
|
|
const struct signature *sigs);
|
2015-05-30 12:41:10 +02:00
|
|
|
|
2015-07-24 08:30:10 +02:00
|
|
|
/**
|
|
|
|
* open_complete_pkt - create an open_complete message
|
|
|
|
* @ctx: tal context to allocate off.
|
|
|
|
* @escape_preimage: preimage to revoke escape transactions.
|
|
|
|
*/
|
|
|
|
struct pkt *open_complete_pkt(const tal_t *ctx,
|
|
|
|
const struct sha256 *escape_preimage);
|
|
|
|
|
2015-06-08 07:14:47 +02:00
|
|
|
/**
|
|
|
|
* close_channel_pkt - create an close_channel message
|
|
|
|
* @ctx: tal context to allocate off.
|
2015-07-24 08:30:10 +02:00
|
|
|
* @sigs: two signatures for the close transaction inputs
|
2015-06-08 07:14:47 +02:00
|
|
|
*/
|
2015-07-24 08:30:10 +02:00
|
|
|
struct pkt *close_channel_pkt(const tal_t *ctx,
|
|
|
|
const struct signature *sigs);
|
2015-06-08 07:14:47 +02:00
|
|
|
|
2015-06-08 07:21:29 +02:00
|
|
|
/**
|
|
|
|
* close_channel_complete_pkt - create an close_channel_complete message
|
|
|
|
* @ctx: tal context to allocate off.
|
2015-07-24 08:30:10 +02:00
|
|
|
* @sigs: two signatures for the close transaction inputs
|
2015-06-08 07:21:29 +02:00
|
|
|
*/
|
|
|
|
struct pkt *close_channel_complete_pkt(const tal_t *ctx,
|
2015-07-24 08:30:10 +02:00
|
|
|
const struct signature *sigs);
|
|
|
|
|
2015-06-08 07:21:29 +02:00
|
|
|
|
2015-06-08 08:44:52 +02:00
|
|
|
/**
|
|
|
|
* update_pkt - create an update message
|
|
|
|
* @ctx: tal context to allocate off.
|
|
|
|
* @revocation_hash: the revocation hash for the next tx.
|
|
|
|
* @delta: the change in satoshis (to me).
|
|
|
|
*/
|
|
|
|
struct pkt *update_pkt(const tal_t *ctx,
|
|
|
|
const struct sha256 *revocation_hash,
|
2015-06-10 13:02:43 +02:00
|
|
|
s64 delta);
|
2015-06-08 08:44:52 +02:00
|
|
|
|
2015-06-08 22:29:06 +02:00
|
|
|
/**
|
|
|
|
* update_accept_pkt - create an update_accept message
|
|
|
|
* @ctx: tal context to allocate off.
|
2015-07-24 08:30:10 +02:00
|
|
|
* @sigs: two signatures for the commit transaction inputs
|
2015-06-08 22:29:06 +02:00
|
|
|
* @revocation_hash: hash to revoke the next tx.
|
|
|
|
*/
|
|
|
|
struct pkt *update_accept_pkt(const tal_t *ctx,
|
2015-07-24 08:30:10 +02:00
|
|
|
const struct signature *sigs,
|
2015-06-10 13:02:43 +02:00
|
|
|
const struct sha256 *revocation_hash);
|
2015-06-08 22:29:06 +02:00
|
|
|
|
2015-06-10 13:02:43 +02:00
|
|
|
/**
|
|
|
|
* update_signature_pkt - create an update_signature message
|
|
|
|
* @ctx: tal context to allocate off.
|
2015-07-24 08:30:10 +02:00
|
|
|
* @sigs: two signatures for the commit transaction inputs
|
2015-06-10 13:02:43 +02:00
|
|
|
* @revocation_preimage: preimage to revoke existing (now-obsolete) tx.
|
|
|
|
*/
|
|
|
|
struct pkt *update_signature_pkt(const tal_t *ctx,
|
2015-07-24 08:30:10 +02:00
|
|
|
const struct signature *sigs,
|
2015-06-10 13:02:43 +02:00
|
|
|
const struct sha256 *revocation_preimage);
|
2015-06-09 06:07:30 +02:00
|
|
|
/**
|
|
|
|
* update_complete_pkt - create an update_accept message
|
|
|
|
* @ctx: tal context to allocate off.
|
|
|
|
* @revocation_preimage: preimage to revoke existing (now-obsolete) tx.
|
|
|
|
*/
|
|
|
|
struct pkt *update_complete_pkt(const tal_t *ctx,
|
|
|
|
const struct sha256 *revocation_preimage);
|
|
|
|
|
2015-05-26 06:38:12 +02:00
|
|
|
#endif /* LIGHTNING_PKT_H */
|