-
Notifications
You must be signed in to change notification settings - Fork 1k
BIP32 private derivation produces invalid results in certain cases #94
Comments
Related to #47 |
The private key is stored using a wrapper over bn.js here: https://github.com/bitpay/bitcore-lib/blob/master/lib/hdprivatekey.js#L193 And the said wrapper's serialisation method (https://github.com/bitpay/bitcore-lib/blob/master/lib/crypto/bn.js#L71) must have this issue. I'm wondering though why this wrapper isn't kept up to date since July 2015. |
Indeed, the |
@braydonf actually I would suggest using |
@axic Thanks for reporting. BIP032 states serialization to be 32 bytes as input, and with leading zero for 33 bytes: https://github.com/bitcoin/bips/blob/master/bip-0032.mediawiki#child-key-derivation-ckd-functions |
I've created a 1.0.0 development branch for collaboration on changes that change the API: |
There's a leading zero prepended in every case during private key derivation, however the bug here is that if the private key has a leading zero, that is omitted. The format is: e.g. |
Okay, I have a PR with a patch: #97 It could be useful to have this test case be a part of the BIP itself, and to cross reference with other tests with other libraries. |
Is this issue still open? |
@braydonf Is this not someone "critical" and should be fixed asap? Or am I mistaken on the severity? |
This still isn't fixed? I had to stop using my TREZOR because they use this library. EDIT: and anyone creating a key now won't work after it's fixed. |
@levino, yes it's critical in the sense that any new implementations should be using correct derivation. There are other libraries that can be used for new implementations, such as https://github.com/bcoin-org/bcoin, https://github.com/bitcoinjs/bitcoinjs-lib and https://github.com/cryptocoinjs/hdkey (FWIW both hdkeys and bcoin use libsecp256k1 bindings and are much faster for hd derivation). Existing implementations will need to have a strategy for detecting and recovering any affected keys, and why #97 includes @rickw Trezor doesn't use bitcore-lib for keys, this is handled by their hardware. From what I remember, they use Insight/bitcore-node as their source of the block chain, and is not affected. |
@braydonf when I couldn't regenerate my wallet from the seed phrase they told me this was the problem. And when I checked my private key separately it has this bug in it. (Leading Zero) TREZOR told me when this is fixed then I can regenerate my wallet. |
@rickw You can regenerate your TREZOR seed using any non-bitcore-lib app. Mycelium is one of them, so is Electrum. The problem is that Copay and bitcore-lib based wallets derive different wallets in 1 / 256 cases. You were unlucky, but it has nothing to do with Trezor. Your Trezor will work fine (the private key generation is all embedded in the Trezor device) the only thing that won't work is if you try to restore your Trezor seed in Copay or any bitcore-lib based wallet / recovery app. If you need to restore your wallet right now for some reason you can use Electrum, however, just as if you inserted the phrase into Copay, inserting the phrase into ANY app will defeat the purpose of Trezor (keeping your seed untouched by any online machine or malware) |
@dabura667 thanks, most of that I know and when I was trying to restore the wallet they were using the bitcore-lib, so they told me. I have everything handled. I had originally looked at a patch but those months ago I thought I read in one of the threads that it was handled. Since I stopped using TREZOR and bitcore personally I was ok. I was just surprised when I got the email today that his wasn't fixed. My apologies for sounding harsh. |
It seems that it happens when the previous steps' private key ended up with a leading zero, because that is dropped when crafting the input for the HMAC.
The affected line: https://github.com/bitpay/bitcore-lib/blob/master/lib/hdprivatekey.js#L183
For a detailed discussion see: MetaMask/metamask-extension#640
The text was updated successfully, but these errors were encountered: