X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=src%2Fjs%2Findex.js;h=f38aa3ce3bcaf537441ba5bc5dc3b1b891963505;hb=b57b721e2cec18e0df07f1e35e1e72852f51bec4;hp=6a2fea609140edb8e8b4561426f066772bd88bac;hpb=ee0981f1ecc4c6e78831f538ef77396c1e4fbe91;p=perso%2FImmae%2FProjets%2FCryptomonnaies%2FBIP39.git diff --git a/src/js/index.js b/src/js/index.js index 6a2fea6..f38aa3c 100644 --- a/src/js/index.js +++ b/src/js/index.js @@ -75,6 +75,8 @@ DOM.generatedStrength = $(".generate-container .strength"); DOM.hardenedAddresses = $(".hardened-addresses"); DOM.useP2wpkhNestedInP2sh = $(".p2wpkh-nested-in-p2sh"); + DOM.useBitpayAddressesContainer = $(".use-bitpay-addresses-container"); + DOM.useBitpayAddresses = $(".use-bitpay-addresses"); DOM.addresses = $(".addresses"); DOM.rowsToAdd = $(".rows-to-add"); DOM.more = $(".more"); @@ -109,7 +111,7 @@ DOM.bip44change.on("input", calcForDerivationPath); DOM.bip49account.on("input", calcForDerivationPath); DOM.bip49change.on("input", calcForDerivationPath); - DOM.tab.on("shown.bs.tab", calcForDerivationPath); + DOM.tab.on("shown.bs.tab", tabChanged); DOM.hardenedAddresses.on("change", calcForDerivationPath); DOM.useP2wpkhNestedInP2sh.on("change", calcForDerivationPath); DOM.indexToggle.on("click", toggleIndexes); @@ -117,6 +119,7 @@ DOM.publicKeyToggle.on("click", togglePublicKeys); DOM.privateKeyToggle.on("click", togglePrivateKeys); DOM.languages.on("click", languageChanged); + DOM.useBitpayAddresses.on("change", useBitpayAddressesChange); setQrEvents(DOM.showQrEls); disableForms(); hidePending(); @@ -131,6 +134,7 @@ clearDerivedKeys(); clearAddressesList(); DOM.litecoinLtubContainer.addClass("hidden"); + DOM.useBitpayAddressesContainer.addClass("hidden"); var networkIndex = e.target.value; var network = networks[networkIndex]; network.onSelect(); @@ -210,6 +214,35 @@ calcForDerivationPath(); } + function tabChanged() { + showPending(); + adjustNetworkForBip49(); + var phrase = DOM.phrase.val(); + if (phrase != "") { + // Calculate and display for mnemonic + var errorText = findPhraseErrors(phrase); + if (errorText) { + showValidationError(errorText); + return; + } + // Calculate and display + var passphrase = DOM.passphrase.val(); + calcBip32RootKeyFromSeed(phrase, passphrase); + } + else { + // Calculate and display for root key + var rootKeyBase58 = DOM.rootKey.val(); + var errorText = validateRootKey(rootKeyBase58); + if (errorText) { + showValidationError(errorText); + return; + } + // Calculate and display + calcBip32RootKeyFromBase58(rootKeyBase58); + } + calcForDerivationPath(); + } + function delayedEntropyChanged() { hideValidationError(); showPending(); @@ -347,6 +380,11 @@ }, 50); } + function useBitpayAddressesChange() { + setBitcoinCashNetworkValues(); + phraseChanged(); + } + function toggleIndexes() { showIndex = !showIndex; $("td.index span").toggleClass("invisible"); @@ -635,12 +673,16 @@ })()); } + function P2wpkhNestedInP2shSelected() { + return bip49TabSelected() || (bip32TabSelected() && useP2wpkhNestedInP2sh()); + } + function TableRow(index, isLast) { var self = this; this.shouldGenerate = true; var useHardenedAddresses = DOM.hardenedAddresses.prop("checked"); - var isP2wpkhNestedInP2sh = bip49TabSelected() || (bip32TabSelected() && useP2wpkhNestedInP2sh()); + var isP2wpkhNestedInP2sh = P2wpkhNestedInP2shSelected(); var p2wpkhNestedInP2shAvailable = networkHasBip49(); function init() { @@ -1207,12 +1249,55 @@ DOM.useP2wpkhNestedInP2sh.prop("checked", false); } + function useBitpayAddresses() { + return !(DOM.useBitpayAddresses.prop("checked")); + } + + function setBitcoinCashNetworkValues() { + if (useBitpayAddresses()) { + network = bitcoinjs.bitcoin.networks.bitcoin; + } + else { + network = bitcoinjs.bitcoin.networks.bitcoinCashBitbpay; + } + } + + function adjustNetworkForBip49() { + // If bip49 is selected the xpub/xprv prefixes need to be adjusted + // to avoid accidentally importing BIP49 xpub to BIP44 watch only + // wallet. + // See https://github.com/iancoleman/bip39/issues/125 + if (P2wpkhNestedInP2shSelected()) { + if (network == bitcoinjs.bitcoin.networks.bitcoin) { + network = bitcoinjs.bitcoin.networks.bitcoinBip49; + } + else if (network == bitcoinjs.bitcoin.networks.testnet) { + network = bitcoinjs.bitcoin.networks.testnetBip49; + } + else if (network == bitcoinjs.bitcoin.networks.litecoin) { + network = bitcoinjs.bitcoin.networks.litecoinBip49; + } + } + else { + if (network == bitcoinjs.bitcoin.networks.bitcoinBip49) { + network = bitcoinjs.bitcoin.networks.bitcoin; + } + else if (network == bitcoinjs.bitcoin.networks.testnetBip49) { + network = bitcoinjs.bitcoin.networks.testnet; + } + else if (network == bitcoinjs.bitcoin.networks.litecoinBip49) { + network = bitcoinjs.bitcoin.networks.litecoin; + } + } + } + var networks = [ { name: "BCH - Bitcoin Cash", p2wpkhNestedInP2shAvailable: false, onSelect: function() { - network = bitcoinjs.bitcoin.networks.bitcoin; + DOM.useBitpayAddressesContainer.removeClass("hidden"); + setBitcoinCashNetworkValues(); setHdCoin(145); }, }, @@ -1280,6 +1365,14 @@ setHdCoin(60); }, }, + { + name: "FJC - Fujicoin", + p2wpkhNestedInP2shAvailable: false, + onSelect: function() { + network = bitcoinjs.bitcoin.networks.fujicoin; + setHdCoin(75); + }, + }, { name: "GAME - GameCredits", p2wpkhNestedInP2shAvailable: false, @@ -1298,7 +1391,7 @@ }, { name: "LTC - Litecoin", - p2wpkhNestedInP2shAvailable: false, + p2wpkhNestedInP2shAvailable: true, onSelect: function() { network = bitcoinjs.bitcoin.networks.litecoin; setHdCoin(2); @@ -1378,6 +1471,14 @@ setHdCoin(111); }, }, + { + name: "USNBT - NuBits", + p2wpkhNestedInP2shAvailable: false, + onSelect: function() { + network = bitcoinjs.bitcoin.networks.nubits; + setHdCoin(12); + }, + }, { name: "VIA - Viacoin", p2wpkhNestedInP2shAvailable: false,