|
|
|
#define SUPERVERBOSE
|
|
|
|
|
|
|
|
#include <assert.h>
|
|
|
|
#include <ccan/str/hex/hex.h>
|
|
|
|
#include <common/amount.h>
|
|
|
|
#include <common/utils.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <wire/wire.h>
|
|
|
|
#include "../type_to_string.c"
|
|
|
|
#include "../key_derive.c"
|
|
|
|
|
|
|
|
/* AUTOGENERATED MOCKS START */
|
|
|
|
/* Generated stub for amount_asset_extract_value */
|
|
|
|
u8 *amount_asset_extract_value(const tal_t *ctx UNNEEDED, struct amount_asset *asset UNNEEDED)
|
|
|
|
{ fprintf(stderr, "amount_asset_extract_value called!\n"); abort(); }
|
|
|
|
/* Generated stub for amount_asset_is_main */
|
|
|
|
bool amount_asset_is_main(struct amount_asset *asset UNNEEDED)
|
|
|
|
{ fprintf(stderr, "amount_asset_is_main called!\n"); abort(); }
|
|
|
|
/* Generated stub for amount_asset_to_sat */
|
|
|
|
struct amount_sat amount_asset_to_sat(struct amount_asset *asset UNNEEDED)
|
|
|
|
{ fprintf(stderr, "amount_asset_to_sat called!\n"); abort(); }
|
|
|
|
/* Generated stub for amount_sat_add */
|
|
|
|
bool amount_sat_add(struct amount_sat *val UNNEEDED,
|
|
|
|
struct amount_sat a UNNEEDED,
|
|
|
|
struct amount_sat b UNNEEDED)
|
|
|
|
{ fprintf(stderr, "amount_sat_add called!\n"); abort(); }
|
|
|
|
/* Generated stub for amount_sat_eq */
|
|
|
|
bool amount_sat_eq(struct amount_sat a UNNEEDED, struct amount_sat b UNNEEDED)
|
|
|
|
{ fprintf(stderr, "amount_sat_eq called!\n"); abort(); }
|
|
|
|
/* Generated stub for amount_sat_greater_eq */
|
|
|
|
bool amount_sat_greater_eq(struct amount_sat a UNNEEDED, struct amount_sat b UNNEEDED)
|
|
|
|
{ fprintf(stderr, "amount_sat_greater_eq called!\n"); abort(); }
|
|
|
|
/* Generated stub for amount_sat_sub */
|
|
|
|
bool amount_sat_sub(struct amount_sat *val UNNEEDED,
|
|
|
|
struct amount_sat a UNNEEDED,
|
|
|
|
struct amount_sat b UNNEEDED)
|
|
|
|
{ fprintf(stderr, "amount_sat_sub called!\n"); abort(); }
|
|
|
|
/* Generated stub for amount_sat_to_asset */
|
|
|
|
struct amount_asset amount_sat_to_asset(struct amount_sat *sat UNNEEDED, const u8 *asset UNNEEDED)
|
|
|
|
{ fprintf(stderr, "amount_sat_to_asset called!\n"); abort(); }
|
|
|
|
/* Generated stub for amount_tx_fee */
|
|
|
|
struct amount_sat amount_tx_fee(u32 fee_per_kw UNNEEDED, size_t weight UNNEEDED)
|
|
|
|
{ fprintf(stderr, "amount_tx_fee called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire */
|
|
|
|
const u8 *fromwire(const u8 **cursor UNNEEDED, size_t *max UNNEEDED, void *copy UNNEEDED, size_t n UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_amount_sat */
|
|
|
|
struct amount_sat fromwire_amount_sat(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_amount_sat called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_bool */
|
|
|
|
bool fromwire_bool(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_bool called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_fail */
|
|
|
|
void *fromwire_fail(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_fail called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_secp256k1_ecdsa_signature */
|
|
|
|
void fromwire_secp256k1_ecdsa_signature(const u8 **cursor UNNEEDED, size_t *max UNNEEDED,
|
|
|
|
secp256k1_ecdsa_signature *signature UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_secp256k1_ecdsa_signature called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_sha256 */
|
|
|
|
void fromwire_sha256(const u8 **cursor UNNEEDED, size_t *max UNNEEDED, struct sha256 *sha256 UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_sha256 called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_tal_arrn */
|
|
|
|
u8 *fromwire_tal_arrn(const tal_t *ctx UNNEEDED,
|
|
|
|
const u8 **cursor UNNEEDED, size_t *max UNNEEDED, size_t num UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_tal_arrn called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_u16 */
|
|
|
|
u16 fromwire_u16(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_u16 called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_u32 */
|
|
|
|
u32 fromwire_u32(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_u32 called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_u64 */
|
|
|
|
u64 fromwire_u64(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_u64 called!\n"); abort(); }
|
|
|
|
/* Generated stub for fromwire_u8 */
|
|
|
|
u8 fromwire_u8(const u8 **cursor UNNEEDED, size_t *max UNNEEDED)
|
|
|
|
{ fprintf(stderr, "fromwire_u8 called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire */
|
|
|
|
void towire(u8 **pptr UNNEEDED, const void *data UNNEEDED, size_t len UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_amount_sat */
|
|
|
|
void towire_amount_sat(u8 **pptr UNNEEDED, const struct amount_sat sat UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_amount_sat called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_bool */
|
|
|
|
void towire_bool(u8 **pptr UNNEEDED, bool v UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_bool called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_secp256k1_ecdsa_signature */
|
|
|
|
void towire_secp256k1_ecdsa_signature(u8 **pptr UNNEEDED,
|
|
|
|
const secp256k1_ecdsa_signature *signature UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_secp256k1_ecdsa_signature called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_sha256 */
|
|
|
|
void towire_sha256(u8 **pptr UNNEEDED, const struct sha256 *sha256 UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_sha256 called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_u16 */
|
|
|
|
void towire_u16(u8 **pptr UNNEEDED, u16 v UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_u16 called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_u32 */
|
|
|
|
void towire_u32(u8 **pptr UNNEEDED, u32 v UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_u32 called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_u64 */
|
|
|
|
void towire_u64(u8 **pptr UNNEEDED, u64 v UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_u64 called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_u8 */
|
|
|
|
void towire_u8(u8 **pptr UNNEEDED, u8 v UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_u8 called!\n"); abort(); }
|
|
|
|
/* Generated stub for towire_u8_array */
|
|
|
|
void towire_u8_array(u8 **pptr UNNEEDED, const u8 *arr UNNEEDED, size_t num UNNEEDED)
|
|
|
|
{ fprintf(stderr, "towire_u8_array called!\n"); abort(); }
|
|
|
|
/* AUTOGENERATED MOCKS END */
|
|
|
|
|
|
|
|
static struct secret secret_from_hex(const char *hex)
|
|
|
|
{
|
|
|
|
struct secret s;
|
|
|
|
hex += 2;
|
|
|
|
if (!hex_decode(hex, strlen(hex), &s, sizeof(s)))
|
|
|
|
abort();
|
|
|
|
return s;
|
|
|
|
}
|
|
|
|
|
|
|
|
int main(void)
|
|
|
|
{
|
|
|
|
setup_locale();
|
|
|
|
|
|
|
|
struct privkey privkey;
|
|
|
|
struct secret base_secret, per_commitment_secret;
|
|
|
|
struct pubkey base_point, per_commitment_point, pubkey, pubkey2;
|
|
|
|
|
|
|
|
setup_tmpctx();
|
|
|
|
secp256k1_ctx = secp256k1_context_create(SECP256K1_CONTEXT_VERIFY
|
|
|
|
| SECP256K1_CONTEXT_SIGN);
|
|
|
|
|
|
|
|
base_secret = secret_from_hex("0x000102030405060708090a0b0c0d0e0f101112131415161718191a1b1c1d1e1f");
|
|
|
|
per_commitment_secret = secret_from_hex("0x1f1e1d1c1b1a191817161514131211100f0e0d0c0b0a09080706050403020100");
|
|
|
|
|
|
|
|
printf("base_secret: 0x%s\n",
|
|
|
|
tal_hexstr(tmpctx, &base_secret, sizeof(base_secret)));
|
|
|
|
printf("per_commitment_secret: 0x%s\n",
|
|
|
|
tal_hexstr(tmpctx, &per_commitment_secret,
|
|
|
|
sizeof(per_commitment_secret)));
|
|
|
|
if (!secp256k1_ec_pubkey_create(secp256k1_ctx,
|
|
|
|
&per_commitment_point.pubkey,
|
|
|
|
per_commitment_secret.data))
|
|
|
|
abort();
|
|
|
|
if (!secp256k1_ec_pubkey_create(secp256k1_ctx,
|
|
|
|
&base_point.pubkey,
|
|
|
|
base_secret.data))
|
|
|
|
abort();
|
|
|
|
printf("base_point: 0x%s\n",
|
|
|
|
type_to_string(tmpctx, struct pubkey, &base_point));
|
|
|
|
printf("per_commitment_point: 0x%s\n",
|
|
|
|
type_to_string(tmpctx, struct pubkey, &per_commitment_point));
|
|
|
|
|
|
|
|
/* FIXME: Annotate internal steps. */
|
|
|
|
if (!derive_simple_key(&base_point, &per_commitment_point, &pubkey))
|
|
|
|
abort();
|
|
|
|
printf("localkey: 0x%s\n",
|
|
|
|
type_to_string(tmpctx, struct pubkey, &pubkey));
|
|
|
|
if (!derive_simple_privkey(&base_secret, &base_point,
|
|
|
|
&per_commitment_point, &privkey))
|
|
|
|
abort();
|
|
|
|
printf("localprivkey: 0x%s\n",
|
|
|
|
tal_hexstr(tmpctx, &privkey, sizeof(privkey)));
|
|
|
|
pubkey_from_privkey(&privkey, &pubkey2);
|
|
|
|
assert(pubkey_eq(&pubkey, &pubkey2));
|
|
|
|
|
|
|
|
/* FIXME: Annotate internal steps. */
|
|
|
|
if (!derive_revocation_key(&base_point, &per_commitment_point, &pubkey))
|
|
|
|
abort();
|
|
|
|
printf("revocationkey: 0x%s\n",
|
|
|
|
type_to_string(tmpctx, struct pubkey, &pubkey));
|
|
|
|
if (!derive_revocation_privkey(&base_secret, &per_commitment_secret,
|
|
|
|
&base_point, &per_commitment_point,
|
|
|
|
&privkey))
|
|
|
|
abort();
|
|
|
|
printf("revocationprivkey: 0x%s\n",
|
|
|
|
tal_hexstr(tmpctx, &privkey, sizeof(privkey)));
|
|
|
|
pubkey_from_privkey(&privkey, &pubkey2);
|
|
|
|
assert(pubkey_eq(&pubkey, &pubkey2));
|
|
|
|
|
|
|
|
/* No memory leaks please */
|
|
|
|
secp256k1_context_destroy(secp256k1_ctx);
|
|
|
|
tal_free(tmpctx);
|
|
|
|
return 0;
|
|
|
|
}
|