mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-07 14:29:33 +01:00
1c4fdce514
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
45 lines
1.3 KiB
C
45 lines
1.3 KiB
C
#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 "lightning.pb-c.h"
|
|
#include <ccan/endian/endian.h>
|
|
#include <ccan/short_types/short_types.h>
|
|
#include <ccan/tal/tal.h>
|
|
|
|
/* A packet, ready to be de-protobuf'ed. */
|
|
struct pkt {
|
|
le32 len;
|
|
u8 data[];
|
|
};
|
|
|
|
struct sha256;
|
|
|
|
/**
|
|
* tal_openchannel - create an openchannel message
|
|
* @ctx: tal context to allocate off.
|
|
* @seed: psuedo-random seed to shuffle inputs.
|
|
* @revocation_hash: first hash value generated from seed.
|
|
* @script_len, @script: the script which pays to us.
|
|
* @commitment_fee: the fee to use for commitment tx.
|
|
* @rel_locktime_seconds: relative seconds for commitment locktime.
|
|
* @anchor: the anchor transaction details.
|
|
*/
|
|
struct pkt *openchannel_pkt(const tal_t *ctx,
|
|
u64 seed,
|
|
const struct sha256 *revocation_hash,
|
|
size_t script_len,
|
|
const void *script,
|
|
u64 commitment_fee,
|
|
u32 rel_locktime_seconds,
|
|
Anchor *anchor);
|
|
|
|
|
|
/* Useful helper for allocating & populating a protobuf Sha256Hash */
|
|
Sha256Hash *proto_sha256_hash(const tal_t *ctx, const struct sha256 *hash);
|
|
|
|
#endif /* LIGHTNING_PKT_H */
|