mirror of
https://github.com/ElementsProject/lightning.git
synced 2025-01-09 23:27:17 +01:00
dba756ef38
Signed-off-by: Rusty Russell <rusty@rustcorp.com.au>
71 lines
2.3 KiB
C
71 lines
2.3 KiB
C
#include <common/key_derive.h>
|
|
#include <common/keyset.h>
|
|
|
|
bool derive_keyset(const struct pubkey *per_commitment_point,
|
|
const struct pubkey *self_payment_basepoint,
|
|
const struct pubkey *other_payment_basepoint,
|
|
const struct pubkey *self_htlc_basepoint,
|
|
const struct pubkey *other_htlc_basepoint,
|
|
const struct pubkey *self_delayed_basepoint,
|
|
const struct pubkey *other_revocation_basepoint,
|
|
struct keyset *keyset)
|
|
{
|
|
/* BOLT #3:
|
|
*
|
|
* ### `localpubkey`, `remotepubkey`, `local_htlcpubkey`,
|
|
* `remote_htlcpubkey`, `local_delayedpubkey`, and
|
|
* `remote_delayedpubkey` Derivation
|
|
*
|
|
* These pubkeys are simply generated by addition from their base points:
|
|
*
|
|
* pubkey = basepoint + SHA256(per_commitment_point || basepoint) * G
|
|
*
|
|
* The `localpubkey` uses the local node's `payment_basepoint`; the
|
|
* `remotepubkey` uses the remote node's `payment_basepoint`; the
|
|
* `local_delayedpubkey` uses the local node's
|
|
* `delayed_payment_basepoint`; the `local_htlcpubkey` uses the local
|
|
* node's `htlc_basepoint`; and the `remote_delayedpubkey` uses the
|
|
* remote node's `delayed_payment_basepoint`.
|
|
*/
|
|
if (!derive_simple_key(self_payment_basepoint,
|
|
per_commitment_point,
|
|
&keyset->self_payment_key))
|
|
return false;
|
|
|
|
if (!derive_simple_key(other_payment_basepoint,
|
|
per_commitment_point,
|
|
&keyset->other_payment_key))
|
|
return false;
|
|
|
|
if (!derive_simple_key(self_htlc_basepoint,
|
|
per_commitment_point,
|
|
&keyset->self_htlc_key))
|
|
return false;
|
|
|
|
if (!derive_simple_key(other_htlc_basepoint,
|
|
per_commitment_point,
|
|
&keyset->other_htlc_key))
|
|
return false;
|
|
|
|
if (!derive_simple_key(self_delayed_basepoint,
|
|
per_commitment_point,
|
|
&keyset->self_delayed_payment_key))
|
|
return false;
|
|
|
|
/* BOLT #3:
|
|
*
|
|
* ### `revocationpubkey` Derivation
|
|
*
|
|
* The `revocationpubkey` is a blinded key: when the local node wishes
|
|
* to create a new commitment for the remote node, it uses its own
|
|
* `revocation_basepoint` and the remote node's `per_commitment_point`
|
|
* to derive a new `revocationpubkey` for the commitment.
|
|
*/
|
|
if (!derive_revocation_key(other_revocation_basepoint,
|
|
per_commitment_point,
|
|
&keyset->self_revocation_key))
|
|
return false;
|
|
|
|
return true;
|
|
}
|