mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-09 15:18:09 +01:00
4220362692
We want to use it in peer_control to generate the transaction, but we really only need the funding_pubkey. Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
57 lines
1.8 KiB
C
57 lines
1.8 KiB
C
#ifndef LIGHTNING_LIGHTNINGD_DERIVE_BASEPOINTS_H
|
|
#define LIGHTNING_LIGHTNINGD_DERIVE_BASEPOINTS_H
|
|
#include "config.h"
|
|
#include <bitcoin/privkey.h>
|
|
#include <bitcoin/pubkey.h>
|
|
|
|
struct sha256;
|
|
|
|
struct basepoints {
|
|
struct pubkey revocation;
|
|
struct pubkey payment;
|
|
struct pubkey delayed_payment;
|
|
};
|
|
|
|
struct secrets {
|
|
struct privkey funding_privkey;
|
|
struct secret revocation_basepoint_secret;
|
|
struct secret payment_basepoint_secret;
|
|
struct secret delayed_payment_basepoint_secret;
|
|
};
|
|
|
|
/**
|
|
* derive_basepoints - given a (per-peer) seed, get the basepoints
|
|
* @seed: (in) seed (derived by master daemon from counter and main seed)
|
|
* @funding_pubkey: (out) pubkey for funding tx output (if non-NULL)
|
|
* @basepoints: (out) basepoints for channel (if non-NULL)
|
|
* @secrets: (out) basepoints for channel (if non-NULL)
|
|
* @shaseed: (out) seed for shachain (if non-NULL)
|
|
* @per_commit_point: (out) per-commit-point for @per_commit_index (if non-NULL)
|
|
* @per_commit_index: (in) which @per_commit_point to set.
|
|
*/
|
|
bool derive_basepoints(const struct privkey *seed,
|
|
struct pubkey *funding_pubkey,
|
|
struct basepoints *basepoints,
|
|
struct secrets *secrets,
|
|
struct sha256 *shaseed,
|
|
struct pubkey *per_commit_point,
|
|
u64 per_commit_index);
|
|
|
|
/* Give up secret for index-1, and generate per-commitment point for N+1. */
|
|
bool next_per_commit_point(const struct sha256 *shaseed,
|
|
struct sha256 *old_commit_secret,
|
|
struct pubkey *per_commit_point,
|
|
u64 per_commit_index);
|
|
|
|
/* BOLT #3:
|
|
*
|
|
* the first secret used MUST be index 281474976710655, and then the index
|
|
* decremented.
|
|
*/
|
|
static inline u64 shachain_index(u64 per_commit_index)
|
|
{
|
|
assert(per_commit_index < (1ULL << 48));
|
|
return 281474976710655ULL - per_commit_index;
|
|
}
|
|
#endif /* LIGHTNING_LIGHTNINGD_DERIVE_BASEPOINTS_H */
|