From: iancoleman Date: Sun, 19 Feb 2017 00:23:41 +0000 (+1100) Subject: Merge pull request #55 from galeksandrp/patch-1 X-Git-Url: https://git.immae.eu/?a=commitdiff_plain;h=5de5781ad732f71ba62d8a1640eb946e853e3c8a;hp=-c;p=perso%2FImmae%2FProjets%2FCryptomonnaies%2FBIP39.git Merge pull request #55 from galeksandrp/patch-1 Add client select --- 5de5781ad732f71ba62d8a1640eb946e853e3c8a diff --combined src/index.html index 9003f89,1c2ffcf..7dc53a7 --- a/src/index.html +++ b/src/index.html @@@ -182,9 -182,9 +182,9 @@@
+
+ +
+ +
+
@@@ -393,7 -401,7 +401,7 @@@
- +

Use path m/44'/0'/0'. @@@ -403,6 -411,13 +411,13 @@@ Can be used with: blockchain.info

+

+ Use path m/0'/0. +

+

+ Can be used with: + MultiBit HD +

@@@ -651,14 -666,12 +666,14 @@@ + + diff --combined src/js/index.js index 4c947a4,f593b3a..8c54cab --- a/src/js/index.js +++ b/src/js/index.js @@@ -23,7 -23,9 +23,9 @@@ var DOM = {}; DOM.network = $(".network"); + DOM.client = $(".client"); DOM.phraseNetwork = $("#network-phrase"); + DOM.phraseClient = $("#client-phrase"); DOM.useEntropy = $(".use-entropy"); DOM.entropyContainer = $(".entropy-container"); DOM.entropy = $(".entropy"); @@@ -77,6 -79,7 +79,7 @@@ function init() { // Events DOM.network.on("change", networkChanged); + DOM.client.on("change", clientChanged); DOM.useEntropy.on("change", setEntropyVisibility); DOM.entropy.on("input", delayedEntropyChanged); DOM.entropyMnemonicLength.on("change", entropyChanged); @@@ -102,6 -105,7 +105,7 @@@ hidePending(); hideValidationError(); populateNetworkSelect(); + populateClientSelect(); } // Event handlers @@@ -116,6 -120,17 +120,17 @@@ rootKeyChanged(); } } + + function clientChanged(e) { + var clientIndex = e.target.value; + clients[clientIndex].onSelect(); + if (seed != null) { + phraseChanged(); + } + else { + rootKeyChanged(); + } + } function setEntropyVisibility() { if (isUsingOwnEntropy()) { @@@ -564,15 -579,6 +579,15 @@@ if (useHardenedAddresses) { indexText = indexText + "'"; } + // Ethereum values are different + if (networks[DOM.network.val()].name == "Ethereum") { + var privKeyBuffer = key.privKey.d.toBuffer(); + privkey = privKeyBuffer.toString('hex'); + var addressBuffer = ethUtil.privateToAddress(privKeyBuffer); + var hexAddress = addressBuffer.toString('hex'); + var checksumAddress = ethUtil.toChecksumAddress(hexAddress); + address = ethUtil.addHexPrefix(checksumAddress); + } addAddressToList(indexText, address, pubkey, privkey); }, 50) } @@@ -710,6 -716,16 +725,16 @@@ DOM.phraseNetwork.append(option); } } + + function populateClientSelect() { + for (var i=0; i"); + option.attr("value", i); + option.text(client.name); + DOM.phraseClient.append(option); + } + } function getLanguage() { var defaultLanguage = "english"; @@@ -1132,14 -1148,31 +1157,38 @@@ DOM.bip44coin.val(6); }, }, + { + name: "Ethereum", + onSelect: function() { + network = bitcoin.networks.bitcoin; + DOM.bip44coin.val(60); + }, + }, ] + + var clients = [ + { + name: "Bitcoin Core", + onSelect: function() { + DOM.bip32path.val("m/0'/0'"); + DOM.hardenedAddresses.prop('checked', true); + }, + }, + { + name: "blockchain.info", + onSelect: function() { + DOM.bip32path.val("m/44'/0'/0'"); + DOM.hardenedAddresses.prop('checked', false); + }, + }, + { + name: "MultiBit HD", + onSelect: function() { + DOM.bip32path.val("m/0'/0"); + DOM.hardenedAddresses.prop('checked', false); + }, + } + ] init();