Browse Source

hsmtool: add a 'testnet' option to 'dumponchaindescriptors'

Actually, it's more complex to translate the xpub descriptor to
testnet because of the descriptor checksum.

Signed-off-by: Antoine Poinsot <darosior@protonmail.com>
ppa-prep
Antoine Poinsot 4 years ago
committed by neil saitug
parent
commit
09fb34c6f3
  1. 27
      tools/hsmtool.c

27
tools/hsmtool.c

@ -41,7 +41,8 @@ static void show_usage(const char *progname)
printf(" - guesstoremote <P2WPKH address> <node id> <tries> " printf(" - guesstoremote <P2WPKH address> <node id> <tries> "
"<path/to/hsm_secret> [hsm_secret password]\n"); "<path/to/hsm_secret> [hsm_secret password]\n");
printf(" - generatehsm <path/to/new//hsm_secret>\n"); printf(" - generatehsm <path/to/new//hsm_secret>\n");
printf(" - dumponchaindescriptors <path/to/hsm_secret> <password>\n"); printf(" - dumponchaindescriptors <path/to/hsm_secret> [password] "
"[network]\n");
exit(0); exit(0);
} }
@ -516,11 +517,14 @@ static int generate_hsm(const char *hsm_secret_path)
return 0; return 0;
} }
static int dumponchaindescriptors(const char *hsm_secret_path, const char *passwd) static int dumponchaindescriptors(const char *hsm_secret_path, const char *passwd,
const bool is_testnet)
{ {
struct secret hsm_secret; struct secret hsm_secret;
u8 bip32_seed[BIP32_ENTROPY_LEN_256]; u8 bip32_seed[BIP32_ENTROPY_LEN_256];
u32 salt = 0; u32 salt = 0;
u32 version = is_testnet ?
BIP32_VER_TEST_PRIVATE : BIP32_VER_MAIN_PRIVATE;
struct ext_key master_extkey; struct ext_key master_extkey;
char *enc_xpub, *descriptor; char *enc_xpub, *descriptor;
struct descriptor_checksum checksum; struct descriptor_checksum checksum;
@ -541,9 +545,7 @@ static int dumponchaindescriptors(const char *hsm_secret_path, const char *passw
salt++; salt++;
/* ..Which is used to derive m/ */ /* ..Which is used to derive m/ */
} while (bip32_key_from_seed(bip32_seed, sizeof(bip32_seed), } while (bip32_key_from_seed(bip32_seed, sizeof(bip32_seed),
/* An xpub can easily be converted to a tpub */ version, 0, &master_extkey) != WALLY_OK);
BIP32_VER_MAIN_PRIVATE,
0, &master_extkey) != WALLY_OK);
if (bip32_key_to_base58(&master_extkey, BIP32_FLAG_KEY_PUBLIC, &enc_xpub) != WALLY_OK) if (bip32_key_to_base58(&master_extkey, BIP32_FLAG_KEY_PUBLIC, &enc_xpub) != WALLY_OK)
errx(ERROR_LIBWALLY, "Can't encode xpub"); errx(ERROR_LIBWALLY, "Can't encode xpub");
@ -629,10 +631,23 @@ int main(int argc, char *argv[])
} }
if (streq(method, "dumponchaindescriptors")) { if (streq(method, "dumponchaindescriptors")) {
bool is_testnet;
if (argc < 3) if (argc < 3)
show_usage(argv[0]); show_usage(argv[0]);
return dumponchaindescriptors(argv[2], argc > 3 ? argv[3] : NULL); if (argc > 4) {
is_testnet = streq(argv[4], "testnet");
if (!is_testnet && !streq(argv[4], "bitcoin"))
errx(ERROR_USAGE, "Network '%s' not supported."
" Supported networks: bitcoin (default),"
" testnet",
argv[4]);
} else
is_testnet = false;
return dumponchaindescriptors(argv[2],
argc > 3 && !streq(argv[3], "") ? argv[3] : NULL,
is_testnet);
} }
show_usage(argv[0]); show_usage(argv[0]);

Loading…
Cancel
Save