mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-04-29 14:59:39 -04:00
Merge bitcoin/bitcoin#26413: [22.1] Backports
403de22119
rpc: add non-regression test about deriveaddresses crash when index is 2147483647 (muxator)db20d278e2
rpc: fix crash in deriveaddresses when derivation index is 2147483647 (muxator)d174db0f3d
Adjust `.tx/config` for new Transifex CLI (Hennadii Stepanov) Pull request description: Currently backports: * https://github.com/bitcoin/bitcoin/pull/26275 * https://github.com/bitcoin/bitcoin/pull/26321 Will leave open to collect backports for 22.1, ACKs for top commit: MarcoFalke: cherry-pick ACK403de22119
🏔 Tree-SHA512: f9095a5cad52ecb9580fcaf173a05148dce382ac773a6116e2aed47009402bdfa6cbce62e488fe96120f7a0a81a623eb3e0e4539fa88670adb8c14cf5e334fa5
This commit is contained in:
commit
4ff9be5c33
3 changed files with 9 additions and 2 deletions
|
@ -1,7 +1,7 @@
|
||||||
[main]
|
[main]
|
||||||
host = https://www.transifex.com
|
host = https://www.transifex.com
|
||||||
|
|
||||||
[bitcoin.qt-translation-022x]
|
[o:bitcoin:p:bitcoin:r:qt-translation-022x]
|
||||||
file_filter = src/qt/locale/bitcoin_<lang>.xlf
|
file_filter = src/qt/locale/bitcoin_<lang>.xlf
|
||||||
source_file = src/qt/locale/bitcoin_en.xlf
|
source_file = src/qt/locale/bitcoin_en.xlf
|
||||||
source_lang = en
|
source_lang = en
|
||||||
|
|
|
@ -252,7 +252,7 @@ static RPCHelpMan deriveaddresses()
|
||||||
|
|
||||||
UniValue addresses(UniValue::VARR);
|
UniValue addresses(UniValue::VARR);
|
||||||
|
|
||||||
for (int i = range_begin; i <= range_end; ++i) {
|
for (int64_t i = range_begin; i <= range_end; ++i) {
|
||||||
FlatSigningProvider provider;
|
FlatSigningProvider provider;
|
||||||
std::vector<CScript> scripts;
|
std::vector<CScript> scripts;
|
||||||
if (!desc->Expand(i, key_provider, scripts, provider)) {
|
if (!desc->Expand(i, key_provider, scripts, provider)) {
|
||||||
|
|
|
@ -44,6 +44,13 @@ class DeriveaddressesTest(BitcoinTestFramework):
|
||||||
combo_descriptor = descsum_create("combo(tprv8ZgxMBicQKsPd7Uf69XL1XwhmjHopUGep8GuEiJDZmbQz6o58LninorQAfcKZWARbtRtfnLcJ5MQ2AtHcQJCCRUcMRvmDUjyEmNUWwx8UbK/1/1/0)")
|
combo_descriptor = descsum_create("combo(tprv8ZgxMBicQKsPd7Uf69XL1XwhmjHopUGep8GuEiJDZmbQz6o58LninorQAfcKZWARbtRtfnLcJ5MQ2AtHcQJCCRUcMRvmDUjyEmNUWwx8UbK/1/1/0)")
|
||||||
assert_equal(self.nodes[0].deriveaddresses(combo_descriptor), ["mtfUoUax9L4tzXARpw1oTGxWyoogp52KhJ", "mtfUoUax9L4tzXARpw1oTGxWyoogp52KhJ", address, "2NDvEwGfpEqJWfybzpKPHF2XH3jwoQV3D7x"])
|
assert_equal(self.nodes[0].deriveaddresses(combo_descriptor), ["mtfUoUax9L4tzXARpw1oTGxWyoogp52KhJ", "mtfUoUax9L4tzXARpw1oTGxWyoogp52KhJ", address, "2NDvEwGfpEqJWfybzpKPHF2XH3jwoQV3D7x"])
|
||||||
|
|
||||||
|
# Before #26275, bitcoind would crash when deriveaddresses was
|
||||||
|
# called with derivation index 2147483647, which is the maximum
|
||||||
|
# positive value of a signed int32, and - currently - the
|
||||||
|
# maximum value that the deriveaddresses bitcoin RPC call
|
||||||
|
# accepts as derivation index.
|
||||||
|
assert_equal(self.nodes[0].deriveaddresses(descsum_create("wpkh(tprv8ZgxMBicQKsPd7Uf69XL1XwhmjHopUGep8GuEiJDZmbQz6o58LninorQAfcKZWARbtRtfnLcJ5MQ2AtHcQJCCRUcMRvmDUjyEmNUWwx8UbK/1/1/*)"), [2147483647, 2147483647]), ["bcrt1qtzs23vgzpreks5gtygwxf8tv5rldxvvsyfpdkg"])
|
||||||
|
|
||||||
hardened_without_privkey_descriptor = descsum_create("wpkh(tpubD6NzVbkrYhZ4WaWSyoBvQwbpLkojyoTZPRsgXELWz3Popb3qkjcJyJUGLnL4qHHoQvao8ESaAstxYSnhyswJ76uZPStJRJCTKvosUCJZL5B/1'/1/0)")
|
hardened_without_privkey_descriptor = descsum_create("wpkh(tpubD6NzVbkrYhZ4WaWSyoBvQwbpLkojyoTZPRsgXELWz3Popb3qkjcJyJUGLnL4qHHoQvao8ESaAstxYSnhyswJ76uZPStJRJCTKvosUCJZL5B/1'/1/0)")
|
||||||
assert_raises_rpc_error(-5, "Cannot derive script without private keys", self.nodes[0].deriveaddresses, hardened_without_privkey_descriptor)
|
assert_raises_rpc_error(-5, "Cannot derive script without private keys", self.nodes[0].deriveaddresses, hardened_without_privkey_descriptor)
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue