Skip to content

Commit 6ee2c7c

Browse files
laanwjknst
authored andcommitted
Merge bitcoin#21277: wallet: listdescriptors uses normalized descriptor form
a69c3b3 wallet: listdescriptors uses normalized descriptor form (Ivan Metlushko) Pull request description: Rationale: show importable descriptors with `listdescriptors` RPC It uses bitcoin#19136 to derive xpub at the last hardened step. **Before**: ``` [ { "desc": "wpkh(tpubD6NzVbkrYhZ4YUQRJL49TWw1VR5v3QKUNYaGGMUfJUm19x5ZqQ2hEiPiYbAQvD2nHoPGQGPg3snLPM8sjmYpvx7XQhkmyfk8xhsUwKbXzyh/84'/1'/0'/0/*)#p4cn3erf", "timestamp": 1613982591, "active": true, "internal": false, "range": [ 0, 999 ], "next": 0 }, ... ] ``` **After**: ``` [ { "desc": "wpkh([d4ade89c/84'/1'/0']tpubDDUEYcVXy6Vh5meHvcXN3sAr4k3fWwLZGpAHbkAHL8EnkDxp4d99CjNhJHfM2fUJicANvAKnCZS6XaVAgwAeKYc1KesGCN5qbQ25qQHrRxM/0/*)#8wq8rcft", "timestamp": 1613982591, "active": true, "internal": false, "range": [ 0, 999 ], "next": 0 }, ... ] ``` ACKs for top commit: achow101: ACK a69c3b3 Tree-SHA512: 4f92e726cb8245aa0b520729cfd272945f0c66830f0555544e0618883aca516318543fa6ab1862058c64b4e4ed54ad1da953e032f4846eef7454122031c1b005
1 parent 8bacdbf commit 6ee2c7c

File tree

2 files changed

+23
-1
lines changed

2 files changed

+23
-1
lines changed

src/wallet/rpcdump.cpp

Lines changed: 7 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1971,6 +1971,8 @@ RPCHelpMan listdescriptors()
19711971
throw JSONRPCError(RPC_WALLET_ERROR, "listdescriptors is not available for non-descriptor wallets");
19721972
}
19731973

1974+
EnsureWalletIsUnlocked(wallet.get());
1975+
19741976
LOCK(wallet->cs_wallet);
19751977

19761978
UniValue response(UniValue::VARR);
@@ -1983,7 +1985,11 @@ RPCHelpMan listdescriptors()
19831985
UniValue spk(UniValue::VOBJ);
19841986
LOCK(desc_spk_man->cs_desc_man);
19851987
const auto& wallet_descriptor = desc_spk_man->GetWalletDescriptor();
1986-
spk.pushKV("desc", wallet_descriptor.descriptor->ToString());
1988+
std::string descriptor;
1989+
if (!desc_spk_man->GetDescriptorString(descriptor, false)) {
1990+
throw JSONRPCError(RPC_WALLET_ERROR, "Can't get normalized descriptor string.");
1991+
}
1992+
spk.pushKV("desc", descriptor);
19871993
spk.pushKV("timestamp", wallet_descriptor.creation_time);
19881994
const bool active = active_spk_mans.count(desc_spk_man) != 0;
19891995
spk.pushKV("active", active);

test/functional/wallet_listdescriptors.py

Lines changed: 16 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -51,6 +51,22 @@ def run_test(self):
5151
assert item['range'] == [0, 0]
5252
assert item['timestamp'] is not None
5353

54+
self.log.info('Test descriptors with hardened derivations are listed in importable form.')
55+
xprv = 'tprv8ZgxMBicQKsPeuVhWwi6wuMQGfPKi9Li5GtX35jVNknACgqe3CY4g5xgkfDDJcmtF7o1QnxWDRYw4H5P26PXq7sbcUkEqeR4fg3Kxp2tigg'
56+
xpub_acc = 'tpubDCMVLhErorrAGfApiJSJzEKwqeaf2z3NrkVMxgYQjZLzMjXMBeRw2muGNYbvaekAE8rUFLftyEar4LdrG2wXyyTJQZ26zptmeTEjPTaATts'
57+
hardened_path = '/84\'/1\'/0\''
58+
wallet = node.get_wallet_rpc('w2')
59+
wallet.importdescriptors([{
60+
'desc': descsum_create('pkh(' + xprv + hardened_path + '/0/*)'),
61+
'timestamp': 1296688602,
62+
}])
63+
expected = {'desc': descsum_create('pkh([80002067' + hardened_path + ']' + xpub_acc + '/0/*)'),
64+
'timestamp': 1296688602,
65+
'active': False,
66+
'range': [0, 0],
67+
'next': 0}
68+
assert_equal([expected], wallet.listdescriptors())
69+
5470
self.log.info('Test non-active non-range combo descriptor')
5571
node.createwallet(wallet_name='w4', blank=True, descriptors=True)
5672
wallet = node.get_wallet_rpc('w4')

0 commit comments

Comments
 (0)