var seed = null;
var bip32RootKey = null;
var bip32ExtendedKey = null;
- var network = bitcoinjs.bitcoin.networks.bitcoin;
+ var network = libs.bitcoin.networks.bitcoin;
var addressRowTemplate = $("#address-row-template");
var showIndex = true;
var showPubKey = true;
var showPrivKey = true;
var showQr = false;
- var litecoinUseLtub = false;
+ var litecoinUseLtub = true;
+ var isDefaultBip44ChangeValue = true;
+ var entropyTypeAutoDetect = true;
var entropyChangeTimeoutEvent = null;
var phraseChangeTimeoutEvent = null;
+ var seedChangedTimeoutEvent = null;
var rootKeyChangedTimeoutEvent = null;
var generationProcesses = [];
var DOM = {};
+ DOM.privacyScreenToggle = $(".privacy-screen-toggle");
DOM.network = $(".network");
DOM.bip32Client = $("#bip32-client");
DOM.phraseNetwork = $("#network-phrase");
DOM.entropy = $(".entropy");
DOM.entropyFiltered = DOM.entropyContainer.find(".filtered");
DOM.entropyType = DOM.entropyContainer.find(".type");
+ DOM.entropyTypeInputs = DOM.entropyContainer.find("input[name='entropy-type']");
DOM.entropyCrackTime = DOM.entropyContainer.find(".crack-time");
DOM.entropyEventCount = DOM.entropyContainer.find(".event-count");
DOM.entropyBits = DOM.entropyContainer.find(".bits");
DOM.entropyBitsPerEvent = DOM.entropyContainer.find(".bits-per-event");
DOM.entropyWordCount = DOM.entropyContainer.find(".word-count");
DOM.entropyBinary = DOM.entropyContainer.find(".binary");
+ DOM.entropyWordIndexes = DOM.entropyContainer.find(".word-indexes");
+ DOM.entropyChecksum = DOM.entropyContainer.find(".checksum");
DOM.entropyMnemonicLength = DOM.entropyContainer.find(".mnemonic-length");
+ DOM.entropyWeakEntropyOverrideWarning = DOM.entropyContainer.find(".weak-entropy-override-warning");
DOM.entropyFilterWarning = DOM.entropyContainer.find(".filter-warning");
DOM.phrase = $(".phrase");
+ DOM.splitMnemonic = $(".splitMnemonic");
+ DOM.showSplitMnemonic = $(".showSplitMnemonic");
+ DOM.phraseSplit = $(".phraseSplit");
+ DOM.phraseSplitWarn = $(".phraseSplitWarn");
DOM.passphrase = $(".passphrase");
DOM.generateContainer = $(".generate-container");
DOM.generate = $(".generate");
DOM.bip32tab = $("#bip32-tab");
DOM.bip44tab = $("#bip44-tab");
DOM.bip49tab = $("#bip49-tab");
+ DOM.bip84tab = $("#bip84-tab");
+ DOM.bip141tab = $("#bip141-tab");
DOM.bip32panel = $("#bip32");
DOM.bip44panel = $("#bip44");
DOM.bip49panel = $("#bip49");
DOM.bip44accountXprv = $("#bip44 .account-xprv");
DOM.bip44accountXpub = $("#bip44 .account-xpub");
DOM.bip44change = $("#bip44 .change");
+ DOM.defaultBip44ChangeValue = $("#bip44 .default-bip44-change-value");
DOM.bip49unavailable = $("#bip49 .unavailable");
DOM.bip49available = $("#bip49 .available");
DOM.bip49path = $("#bip49-path");
DOM.bip49accountXprv = $("#bip49 .account-xprv");
DOM.bip49accountXpub = $("#bip49 .account-xpub");
DOM.bip49change = $("#bip49 .change");
+ DOM.bip84unavailable = $("#bip84 .unavailable");
+ DOM.bip84available = $("#bip84 .available");
+ DOM.bip84path = $("#bip84-path");
+ DOM.bip84purpose = $("#bip84 .purpose");
+ DOM.bip84coin = $("#bip84 .coin");
+ DOM.bip84account = $("#bip84 .account");
+ DOM.bip84accountXprv = $("#bip84 .account-xprv");
+ DOM.bip84accountXpub = $("#bip84 .account-xpub");
+ DOM.bip84change = $("#bip84 .change");
+ DOM.bip85 = $('.bip85');
+ DOM.showBip85 = $('.showBip85');
+ DOM.bip85Field = $('.bip85Field');
+ DOM.bip85application = $('#bip85-application');
+ DOM.bip85mnemonicLanguage = $('#bip85-mnemonic-language');
+ DOM.bip85mnemonicLanguageInput = $('.bip85-mnemonic-language-input');
+ DOM.bip85mnemonicLength = $('#bip85-mnemonic-length');
+ DOM.bip85mnemonicLengthInput = $('.bip85-mnemonic-length-input');
+ DOM.bip85index = $('#bip85-index');
+ DOM.bip85indexInput = $('.bip85-index-input');
+ DOM.bip85bytes = $('#bip85-bytes');
+ DOM.bip85bytesInput = $('.bip85-bytes-input');
+ DOM.bip141unavailable = $("#bip141 .unavailable");
+ DOM.bip141available = $("#bip141 .available");
+ DOM.bip141path = $("#bip141-path");
+ DOM.bip141semantics = $(".bip141-semantics");
DOM.generatedStrength = $(".generate-container .strength");
+ DOM.generatedStrengthWarning = $(".generate-container .warning");
DOM.hardenedAddresses = $(".hardened-addresses");
- DOM.useP2wpkhNestedInP2sh = $(".p2wpkh-nested-in-p2sh");
- DOM.useBitpayAddressesContainer = $(".use-bitpay-addresses-container");
- DOM.useBitpayAddresses = $(".use-bitpay-addresses");
+ DOM.bitcoinCashAddressTypeContainer = $(".bch-addr-type-container");
+ DOM.bitcoinCashAddressType = $("[name=bch-addr-type]")
+ DOM.useBip38 = $(".use-bip38");
+ DOM.bip38Password = $(".bip38-password");
DOM.addresses = $(".addresses");
+ DOM.csvTab = $("#csv-tab a");
+ DOM.csv = $(".csv");
DOM.rowsToAdd = $(".rows-to-add");
DOM.more = $(".more");
+ DOM.moreRowsStartIndex = $(".more-rows-start-index");
DOM.feedback = $(".feedback");
DOM.tab = $(".derivation-type a");
DOM.indexToggle = $(".index-toggle");
function init() {
// Events
+ DOM.privacyScreenToggle.on("change", privacyScreenToggled);
+ DOM.generatedStrength.on("change", generatedStrengthChanged);
DOM.network.on("change", networkChanged);
DOM.bip32Client.on("change", bip32ClientChanged);
DOM.useEntropy.on("change", setEntropyVisibility);
DOM.entropy.on("input", delayedEntropyChanged);
DOM.entropyMnemonicLength.on("change", entropyChanged);
+ DOM.entropyTypeInputs.on("change", entropyTypeChanged);
DOM.phrase.on("input", delayedPhraseChanged);
+ DOM.showSplitMnemonic.on("change", toggleSplitMnemonic);
DOM.passphrase.on("input", delayedPhraseChanged);
DOM.generate.on("click", generateClicked);
DOM.more.on("click", showMore);
+ DOM.seed.on("input", delayedSeedChanged);
DOM.rootKey.on("input", delayedRootKeyChanged);
+ DOM.showBip85.on('change', toggleBip85);
DOM.litecoinUseLtub.on("change", litecoinUseLtubChanged);
DOM.bip32path.on("input", calcForDerivationPath);
DOM.bip44account.on("input", calcForDerivationPath);
+ DOM.bip44change.on("input", modifiedDefaultBip44ChangeValue);
DOM.bip44change.on("input", calcForDerivationPath);
+ DOM.defaultBip44ChangeValue.on("click", resetDefaultBip44ChangeValue);
DOM.bip49account.on("input", calcForDerivationPath);
DOM.bip49change.on("input", calcForDerivationPath);
+ DOM.bip84account.on("input", calcForDerivationPath);
+ DOM.bip84change.on("input", calcForDerivationPath);
+ DOM.bip85application.on('input', calcBip85);
+ DOM.bip85mnemonicLanguage.on('change', calcBip85);
+ DOM.bip85mnemonicLength.on('change', calcBip85);
+ DOM.bip85index.on('input', calcBip85);
+ DOM.bip85bytes.on('input', calcBip85);
+ DOM.bip141path.on("input", calcForDerivationPath);
+ DOM.bip141semantics.on("change", tabChanged);
DOM.tab.on("shown.bs.tab", tabChanged);
DOM.hardenedAddresses.on("change", calcForDerivationPath);
- DOM.useP2wpkhNestedInP2sh.on("change", calcForDerivationPath);
+ DOM.useBip38.on("change", calcForDerivationPath);
+ DOM.bip38Password.on("change", calcForDerivationPath);
DOM.indexToggle.on("click", toggleIndexes);
DOM.addressToggle.on("click", toggleAddresses);
DOM.publicKeyToggle.on("click", togglePublicKeys);
DOM.privateKeyToggle.on("click", togglePrivateKeys);
+ DOM.csvTab.on("click", updateCsv);
DOM.languages.on("click", languageChanged);
- DOM.useBitpayAddresses.on("change", useBitpayAddressesChange);
+ DOM.bitcoinCashAddressType.on("change", bitcoinCashAddressTypeChange);
setQrEvents(DOM.showQrEls);
disableForms();
hidePending();
// Event handlers
+ function generatedStrengthChanged() {
+ var strength = parseInt(DOM.generatedStrength.val());
+ if (strength < 12) {
+ DOM.generatedStrengthWarning.removeClass("hidden");
+ }
+ else {
+ DOM.generatedStrengthWarning.addClass("hidden");
+ }
+ }
+
function networkChanged(e) {
clearDerivedKeys();
clearAddressesList();
DOM.litecoinLtubContainer.addClass("hidden");
- DOM.useBitpayAddressesContainer.addClass("hidden");
+ DOM.bitcoinCashAddressTypeContainer.addClass("hidden");
var networkIndex = e.target.value;
var network = networks[networkIndex];
network.onSelect();
- if (network.p2wpkhNestedInP2shAvailable) {
- showP2wpkhNestedInP2shAvailable();
- }
- else {
- showP2wpkhNestedInP2shUnavailable();
- }
+ adjustNetworkForSegwit();
if (seed != null) {
phraseChanged();
}
if (phraseChangeTimeoutEvent != null) {
clearTimeout(phraseChangeTimeoutEvent);
}
- phraseChangeTimeoutEvent = setTimeout(phraseChanged, 400);
+ phraseChangeTimeoutEvent = setTimeout(function() {
+ phraseChanged();
+ var entropy = mnemonic.toRawEntropyHex(DOM.phrase.val());
+ if (entropy !== null) {
+ DOM.entropyMnemonicLength.val("raw");
+ DOM.entropy.val(entropy);
+ DOM.entropyTypeInputs.filter("[value='hexadecimal']").prop("checked", true);
+ entropyTypeAutoDetect = false;
+ }
+ }, 400);
}
function phraseChanged() {
var passphrase = DOM.passphrase.val();
calcBip32RootKeyFromSeed(phrase, passphrase);
calcForDerivationPath();
+ calcBip85();
+ // Show the word indexes
+ showWordIndexes();
+ writeSplitPhrase(phrase);
}
function tabChanged() {
showPending();
- adjustNetworkForBip49();
+ adjustNetworkForSegwit();
var phrase = DOM.phrase.val();
if (phrase != "") {
// Calculate and display for mnemonic
clearDisplay();
clearEntropyFeedback();
DOM.phrase.val("");
+ DOM.phraseSplit.val("");
showValidationError("Blank entropy");
return;
}
}
}
+ function entropyTypeChanged() {
+ entropyTypeAutoDetect = false;
+ entropyChanged();
+ }
+
+ function delayedSeedChanged() {
+ // Warn if there is an existing mnemonic or passphrase.
+ if (DOM.phrase.val().length > 0 || DOM.passphrase.val().length > 0) {
+ if (!confirm("This will clear existing mnemonic and passphrase")) {
+ DOM.seed.val(seed);
+ return
+ }
+ }
+ hideValidationError();
+ showPending();
+ // Clear existing mnemonic and passphrase
+ DOM.phrase.val("");
+ DOM.phraseSplit.val("");
+ DOM.passphrase.val("");
+ DOM.rootKey.val("");
+ clearAddressesList();
+ clearDerivedKeys();
+ seed = null;
+ if (seedChangedTimeoutEvent != null) {
+ clearTimeout(seedChangedTimeoutEvent);
+ }
+ seedChangedTimeoutEvent = setTimeout(seedChanged, 400);
+ }
+
function delayedRootKeyChanged() {
// Warn if there is an existing mnemonic or passphrase.
if (DOM.phrase.val().length > 0 || DOM.passphrase.val().length > 0) {
showPending();
// Clear existing mnemonic and passphrase
DOM.phrase.val("");
+ DOM.phraseSplit.val("");
DOM.passphrase.val("");
seed = null;
if (rootKeyChangedTimeoutEvent != null) {
rootKeyChangedTimeoutEvent = setTimeout(rootKeyChanged, 400);
}
+ function seedChanged() {
+ showPending();
+ hideValidationError();
+ seed = DOM.seed.val();
+ bip32RootKey = libs.bitcoin.HDNode.fromSeedHex(seed, network);
+ var rootKeyBase58 = bip32RootKey.toBase58();
+ DOM.rootKey.val(rootKeyBase58);
+ var errorText = validateRootKey(rootKeyBase58);
+ if (errorText) {
+ showValidationError(errorText);
+ return;
+ }
+ // Calculate and display
+ calcForDerivationPath();
+ calcBip85();
+ }
+
function rootKeyChanged() {
showPending();
hideValidationError();
// Calculate and display
calcBip32RootKeyFromBase58(rootKeyBase58);
calcForDerivationPath();
+ calcBip85();
}
function litecoinUseLtubChanged() {
litecoinUseLtub = DOM.litecoinUseLtub.prop("checked");
if (litecoinUseLtub) {
- network = bitcoinjs.bitcoin.networks.litecoinLtub;
+ network = libs.bitcoin.networks.litecoin;
}
else {
- network = bitcoinjs.bitcoin.networks.litecoin;
+ network = libs.bitcoin.networks.litecoinXprv;
}
phraseChanged();
}
+ function toggleSplitMnemonic() {
+ if (DOM.showSplitMnemonic.prop("checked")) {
+ DOM.splitMnemonic.removeClass("hidden");
+ }
+ else {
+ DOM.splitMnemonic.addClass("hidden");
+ }
+ }
+
+ function toggleBip85() {
+ if (DOM.showBip85.prop('checked')) {
+ DOM.bip85.removeClass('hidden');
+ calcBip85();
+ } else {
+ DOM.bip85.addClass('hidden');
+ }
+ }
+
+ function toggleBip85Fields() {
+ if (DOM.showBip85.prop('checked')) {
+ DOM.bip85mnemonicLanguageInput.addClass('hidden');
+ DOM.bip85mnemonicLengthInput.addClass('hidden');
+ DOM.bip85bytesInput.addClass('hidden');
+
+ var app = DOM.bip85application.val();
+ if (app === 'bip39') {
+ DOM.bip85mnemonicLanguageInput.removeClass('hidden');
+ DOM.bip85mnemonicLengthInput.removeClass('hidden');
+ } else if (app === 'hex') {
+ DOM.bip85bytesInput.removeClass('hidden');
+ }
+ }
+ }
+
+ function calcBip85() {
+ if (!DOM.showBip85.prop('checked')) {
+ return
+ }
+
+ toggleBip85Fields();
+
+ var app = DOM.bip85application.val();
+
+ var phrase = DOM.phrase.val();
+ var passphrase = DOM.passphrase.val();
+ if (!phrase) {
+ return;
+ }
+ try {
+ var master = libs.bip85.BIP85.fromMnemonic(phrase, passphrase);
+
+ var result;
+
+ const index = parseInt(DOM.bip85index.val(), 10);
+
+ if (app === 'bip39') {
+ const language = parseInt(DOM.bip85mnemonicLanguage.val(), 10);
+ const length = parseInt(DOM.bip85mnemonicLength.val(), 10);
+
+ result = master.deriveBIP39(language, length, index).toMnemonic();
+ } else if (app === 'wif') {
+ result = master.deriveWIF(index).toWIF();
+ } else if (app === 'xprv') {
+ result = master.deriveXPRV(index).toXPRV();
+ } else if (app === 'hex') {
+ const bytes = parseInt(DOM.bip85bytes.val(), 10);
+
+ result = master.deriveHex(bytes, index).toEntropy();
+ }
+
+ hideValidationError();
+ DOM.bip85Field.val(result);
+ } catch (e) {
+ showValidationError('BIP85: ' + e.message);
+ DOM.bip85Field.val('');
+ }
+ }
+
function calcForDerivationPath() {
clearDerivedKeys();
clearAddressesList();
showPending();
- // Don't show bip49 if it's selected but network doesn't support it
- if (bip49TabSelected() && !networkHasBip49()) {
+ // Don't show segwit if it's selected but network doesn't support it
+ if (segwitSelected() && !networkHasSegwit()) {
+ showSegwitUnavailable();
+ hidePending();
return;
}
+ showSegwitAvailable();
// Get the derivation path
var derivationPath = getDerivationPath();
var errorText = findDerivationPathErrors(derivationPath);
if (bip44TabSelected()) {
displayBip44Info();
}
- if (bip49TabSelected()) {
+ else if (bip49TabSelected()) {
displayBip49Info();
}
+ else if (bip84TabSelected()) {
+ displayBip84Info();
+ }
displayBip32Info();
}
}, 50);
}
- function useBitpayAddressesChange() {
- setBitcoinCashNetworkValues();
+ function bitcoinCashAddressTypeChange() {
phraseChanged();
}
$("td.privkey span").toggleClass("invisible");
}
+ function privacyScreenToggled() {
+ // private-data contains elements added to DOM at runtime
+ // so catch all by adding visual privacy class to the root of the DOM
+ if (DOM.privacyScreenToggle.prop("checked")) {
+ $("body").addClass("visual-privacy");
+ }
+ else {
+ $("body").removeClass("visual-privacy");
+ }
+ }
+
// Private methods
function generateRandomPhrase() {
showValidationError(errorText);
return;
}
+ // get the amount of entropy to use
var numWords = parseInt(DOM.generatedStrength.val());
var strength = numWords / 3 * 32;
- var words = mnemonic.generate(strength);
+ var buffer = new Uint8Array(strength / 8);
+ // create secure entropy
+ var data = crypto.getRandomValues(buffer);
+ // show the words
+ var words = mnemonic.toMnemonic(data);
DOM.phrase.val(words);
+ // show the entropy
+ var entropyHex = uint8ArrayToHex(data);
+ DOM.entropy.val(entropyHex);
+ // ensure entropy fields are consistent with what is being displayed
+ DOM.entropyMnemonicLength.val("raw");
return words;
}
function calcBip32RootKeyFromSeed(phrase, passphrase) {
seed = mnemonic.toSeed(phrase, passphrase);
- bip32RootKey = bitcoinjs.bitcoin.HDNode.fromSeedHex(seed, network);
+ bip32RootKey = libs.bitcoin.HDNode.fromSeedHex(seed, network);
+ if(isGRS())
+ bip32RootKey = libs.groestlcoinjs.HDNode.fromSeedHex(seed, network);
+
}
function calcBip32RootKeyFromBase58(rootKeyBase58) {
- bip32RootKey = bitcoinjs.bitcoin.HDNode.fromBase58(rootKeyBase58, network);
+ if(isGRS()) {
+ calcBip32RootKeyFromBase58GRS(rootKeyBase58);
+ return;
+ }
+ // try parsing with various segwit network params since this extended
+ // key may be from any one of them.
+ if (networkHasSegwit()) {
+ var n = network;
+ if ("baseNetwork" in n) {
+ n = libs.bitcoin.networks[n.baseNetwork];
+ }
+ // try parsing using base network params
+ try {
+ bip32RootKey = libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n);
+ return;
+ }
+ catch (e) {}
+ // try parsing using p2wpkh params
+ if ("p2wpkh" in n) {
+ try {
+ bip32RootKey = libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n.p2wpkh);
+ return;
+ }
+ catch (e) {}
+ }
+ // try parsing using p2wpkh-in-p2sh network params
+ if ("p2wpkhInP2sh" in n) {
+ try {
+ bip32RootKey = libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n.p2wpkhInP2sh);
+ return;
+ }
+ catch (e) {}
+ }
+ // try parsing using p2wsh network params
+ if ("p2wsh" in n) {
+ try {
+ bip32RootKey = libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n.p2wsh);
+ return;
+ }
+ catch (e) {}
+ }
+ // try parsing using p2wsh-in-p2sh network params
+ if ("p2wshInP2sh" in n) {
+ try {
+ bip32RootKey = libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n.p2wshInP2sh);
+ return;
+ }
+ catch (e) {}
+ }
+ }
+ // try the network params as currently specified
+ bip32RootKey = libs.bitcoin.HDNode.fromBase58(rootKeyBase58, network);
+ }
+
+ function calcBip32RootKeyFromBase58GRS(rootKeyBase58) {
+ // try parsing with various segwit network params since this extended
+ // key may be from any one of them.
+ if (networkHasSegwit()) {
+ var n = network;
+ if ("baseNetwork" in n) {
+ n = libs.bitcoin.networks[n.baseNetwork];
+ }
+ // try parsing using base network params
+ try {
+ bip32RootKey = libs.groestlcoinjs.HDNode.fromBase58(rootKeyBase58, n);
+ return;
+ }
+ catch (e) {}
+ // try parsing using p2wpkh params
+ if ("p2wpkh" in n) {
+ try {
+ bip32RootKey = libs.groestlcoinjs.HDNode.fromBase58(rootKeyBase58, n.p2wpkh);
+ return;
+ }
+ catch (e) {}
+ }
+ // try parsing using p2wpkh-in-p2sh network params
+ if ("p2wpkhInP2sh" in n) {
+ try {
+ bip32RootKey = libs.groestlcoinjs.HDNode.fromBase58(rootKeyBase58, n.p2wpkhInP2sh);
+ return;
+ }
+ catch (e) {}
+ }
+ }
+ // try the network params as currently specified
+ bip32RootKey = libs.groestlcoinjs.HDNode.fromBase58(rootKeyBase58, network);
}
function calcBip32ExtendedKey(path) {
extendedKey = extendedKey.derive(index);
}
}
- return extendedKey
+ return extendedKey;
}
function showValidationError(errorText) {
}
function validateRootKey(rootKeyBase58) {
+ if(isGRS())
+ return validateRootKeyGRS(rootKeyBase58);
+
+ // try various segwit network params since this extended key may be from
+ // any one of them.
+ if (networkHasSegwit()) {
+ var n = network;
+ if ("baseNetwork" in n) {
+ n = libs.bitcoin.networks[n.baseNetwork];
+ }
+ // try parsing using base network params
+ try {
+ libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n);
+ return "";
+ }
+ catch (e) {}
+ // try parsing using p2wpkh params
+ if ("p2wpkh" in n) {
+ try {
+ libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n.p2wpkh);
+ return "";
+ }
+ catch (e) {}
+ }
+ // try parsing using p2wpkh-in-p2sh network params
+ if ("p2wpkhInP2sh" in n) {
+ try {
+ libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n.p2wpkhInP2sh);
+ return "";
+ }
+ catch (e) {}
+ }
+ // try parsing using p2wsh network params
+ if ("p2wsh" in n) {
+ try {
+ libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n.p2wsh);
+ return "";
+ }
+ catch (e) {}
+ }
+ // try parsing using p2wsh-in-p2sh network params
+ if ("p2wshInP2sh" in n) {
+ try {
+ libs.bitcoin.HDNode.fromBase58(rootKeyBase58, n.p2wshInP2sh);
+ return "";
+ }
+ catch (e) {}
+ }
+ }
+ // try the network params as currently specified
+ try {
+ libs.bitcoin.HDNode.fromBase58(rootKeyBase58, network);
+ }
+ catch (e) {
+ return "Invalid root key";
+ }
+ return "";
+ }
+
+ function validateRootKeyGRS(rootKeyBase58) {
+ // try various segwit network params since this extended key may be from
+ // any one of them.
+ if (networkHasSegwit()) {
+ var n = network;
+ if ("baseNetwork" in n) {
+ n = libs.bitcoin.networks[n.baseNetwork];
+ }
+ // try parsing using base network params
+ try {
+ libs.groestlcoinjs.HDNode.fromBase58(rootKeyBase58, n);
+ return "";
+ }
+ catch (e) {}
+ // try parsing using p2wpkh params
+ if ("p2wpkh" in n) {
+ try {
+ libs.groestlcoinjs.HDNode.fromBase58(rootKeyBase58, n.p2wpkh);
+ return "";
+ }
+ catch (e) {}
+ }
+ // try parsing using p2wpkh-in-p2sh network params
+ if ("p2wpkhInP2sh" in n) {
+ try {
+ libs.groestlcoinjs.HDNode.fromBase58(rootKeyBase58, n.p2wpkhInP2sh);
+ return "";
+ }
+ catch (e) {}
+ }
+ }
+ // try the network params as currently specified
try {
- bitcoinjs.bitcoin.HDNode.fromBase58(rootKeyBase58, network);
+ libs.groestlcoinjs.HDNode.fromBase58(rootKeyBase58, network);
}
catch (e) {
return "Invalid root key";
var purpose = parseIntNoNaN(DOM.bip44purpose.val(), 44);
var coin = parseIntNoNaN(DOM.bip44coin.val(), 0);
var account = parseIntNoNaN(DOM.bip44account.val(), 0);
- var change = parseIntNoNaN(DOM.bip44change.val(), 0);
- var path = "m/";
- path += purpose + "'/";
- path += coin + "'/";
- path += account + "'/";
- path += change;
+ var change = parseIntNoNaN(DOM.bip44change.val(), "");
+ var path = "m";
+ path += "/" + purpose + "'";
+ path += "/" + coin + "'";
+ path += "/" + account + "'";
+ if (change !== "") {
+ path += "/" + change;
+ }
DOM.bip44path.val(path);
var derivationPath = DOM.bip44path.val();
console.log("Using derivation path from BIP44 tab: " + derivationPath);
return derivationPath;
}
- if (bip49TabSelected()) {
+ else if (bip49TabSelected()) {
var purpose = parseIntNoNaN(DOM.bip49purpose.val(), 49);
var coin = parseIntNoNaN(DOM.bip49coin.val(), 0);
var account = parseIntNoNaN(DOM.bip49account.val(), 0);
console.log("Using derivation path from BIP49 tab: " + derivationPath);
return derivationPath;
}
+ else if (bip84TabSelected()) {
+ var purpose = parseIntNoNaN(DOM.bip84purpose.val(), 84);
+ var coin = parseIntNoNaN(DOM.bip84coin.val(), 0);
+ var account = parseIntNoNaN(DOM.bip84account.val(), 0);
+ var change = parseIntNoNaN(DOM.bip84change.val(), 0);
+ var path = "m/";
+ path += purpose + "'/";
+ path += coin + "'/";
+ path += account + "'/";
+ path += change;
+ DOM.bip84path.val(path);
+ var derivationPath = DOM.bip84path.val();
+ console.log("Using derivation path from BIP84 tab: " + derivationPath);
+ return derivationPath;
+ }
else if (bip32TabSelected()) {
var derivationPath = DOM.bip32path.val();
console.log("Using derivation path from BIP32 tab: " + derivationPath);
return derivationPath;
}
+ else if (bip141TabSelected()) {
+ var derivationPath = DOM.bip141path.val();
+ console.log("Using derivation path from BIP141 tab: " + derivationPath);
+ return derivationPath;
+ }
else {
console.log("Unknown derivation path");
}
return false;
}
+ function isGRS() {
+ return networks[DOM.network.val()].name == "GRS - Groestlcoin" || networks[DOM.network.val()].name == "GRS - Groestlcoin Testnet";
+ }
+
+ function isELA() {
+ return networks[DOM.network.val()].name == "ELA - Elastos"
+ }
+
function displayBip44Info() {
// Get the derivation path for the account
var purpose = parseIntNoNaN(DOM.bip44purpose.val(), 44);
var accountExtendedKey = calcBip32ExtendedKey(path);
var accountXprv = accountExtendedKey.toBase58();
var accountXpub = accountExtendedKey.neutered().toBase58();
+
// Display the extended keys
DOM.bip44accountXprv.val(accountXprv);
DOM.bip44accountXpub.val(accountXpub);
+
+ if (isELA()) {
+ displayBip44InfoForELA();
+ }
}
function displayBip49Info() {
DOM.bip49accountXpub.val(accountXpub);
}
+ function displayBip84Info() {
+ // Get the derivation path for the account
+ var purpose = parseIntNoNaN(DOM.bip84purpose.val(), 84);
+ var coin = parseIntNoNaN(DOM.bip84coin.val(), 0);
+ var account = parseIntNoNaN(DOM.bip84account.val(), 0);
+ var path = "m/";
+ path += purpose + "'/";
+ path += coin + "'/";
+ path += account + "'/";
+ // Calculate the account extended keys
+ var accountExtendedKey = calcBip32ExtendedKey(path);
+ var accountXprv = accountExtendedKey.toBase58();
+ var accountXpub = accountExtendedKey.neutered().toBase58();
+ // Display the extended keys
+ DOM.bip84accountXprv.val(accountXprv);
+ DOM.bip84accountXpub.val(accountXpub);
+ }
+
function displayBip32Info() {
// Display the key
DOM.seed.val(seed);
DOM.extendedPubKey.val(extendedPubKey);
// Display the addresses and privkeys
clearAddressesList();
- displayAddresses(0, 20);
+ var initialAddressCount = parseInt(DOM.rowsToAdd.val());
+ displayAddresses(0, initialAddressCount);
+
+ if (isELA()) {
+ displayBip32InfoForELA();
+ }
}
function displayAddresses(start, total) {
})());
}
- function P2wpkhNestedInP2shSelected() {
- return bip49TabSelected() || (bip32TabSelected() && useP2wpkhNestedInP2sh());
+ function segwitSelected() {
+ return bip49TabSelected() || bip84TabSelected() || bip141TabSelected();
+ }
+
+ function p2wpkhSelected() {
+ return bip84TabSelected() ||
+ bip141TabSelected() && DOM.bip141semantics.val() == "p2wpkh";
+ }
+
+ function p2wpkhInP2shSelected() {
+ return bip49TabSelected() ||
+ (bip141TabSelected() && DOM.bip141semantics.val() == "p2wpkh-p2sh");
+ }
+
+ function p2wshSelected() {
+ return bip141TabSelected() && DOM.bip141semantics.val() == "p2wsh";
+ }
+
+ function p2wshInP2shSelected() {
+ return (bip141TabSelected() && DOM.bip141semantics.val() == "p2wsh-p2sh");
}
function TableRow(index, isLast) {
var self = this;
this.shouldGenerate = true;
var useHardenedAddresses = DOM.hardenedAddresses.prop("checked");
- var isP2wpkhNestedInP2sh = P2wpkhNestedInP2shSelected();
- var p2wpkhNestedInP2shAvailable = networkHasBip49();
+ var useBip38 = DOM.useBip38.prop("checked");
+ var bip38password = DOM.bip38Password.val();
+ var isSegwit = segwitSelected();
+ var segwitAvailable = networkHasSegwit();
+ var isP2wpkh = p2wpkhSelected();
+ var isP2wpkhInP2sh = p2wpkhInP2shSelected();
+ var isP2wsh = p2wshSelected();
+ var isP2wshInP2sh = p2wshInP2shSelected();
function init() {
calculateValues();
if (!self.shouldGenerate) {
return;
}
+ // derive HDkey for this row of the table
var key = "NA";
if (useHardenedAddresses) {
key = bip32ExtendedKey.deriveHardened(index);
else {
key = bip32ExtendedKey.derive(index);
}
- var address = key.getAddress().toString();
+ // bip38 requires uncompressed keys
+ // see https://github.com/iancoleman/bip39/issues/140#issuecomment-352164035
+ var keyPair = key.keyPair;
+ var useUncompressed = useBip38;
+ if (useUncompressed) {
+ keyPair = new libs.bitcoin.ECPair(keyPair.d, null, { network: network, compressed: false });
+ if(isGRS())
+ keyPair = new libs.groestlcoinjs.ECPair(keyPair.d, null, { network: network, compressed: false });
+
+ }
+ // get address
+ var address = keyPair.getAddress().toString();
+ // get privkey
+ var hasPrivkey = !key.isNeutered();
var privkey = "NA";
- if (!key.isNeutered()) {
- privkey = key.keyPair.toWIF(network);
+ if (hasPrivkey) {
+ privkey = keyPair.toWIF();
+ // BIP38 encode private key if required
+ if (useBip38) {
+ if(isGRS())
+ privkey = libs.groestlcoinjsBip38.encrypt(keyPair.d.toBuffer(), false, bip38password, function(p) {
+ console.log("Progressed " + p.percent.toFixed(1) + "% for index " + index);
+ }, null, networks[DOM.network.val()].name.includes("Testnet"));
+ else
+ privkey = libs.bip38.encrypt(keyPair.d.toBuffer(), false, bip38password, function(p) {
+ console.log("Progressed " + p.percent.toFixed(1) + "% for index " + index);
+ });
+ }
}
- var pubkey = key.getPublicKeyBuffer().toString('hex');
+ // get pubkey
+ var pubkey = keyPair.getPublicKeyBuffer().toString('hex');
var indexText = getDerivationPath() + "/" + index;
if (useHardenedAddresses) {
indexText = indexText + "'";
}
// Ethereum values are different
- if (networks[DOM.network.val()].name == "ETH - Ethereum") {
- var privKeyBuffer = key.keyPair.d.toBuffer();
- privkey = privKeyBuffer.toString('hex');
- var addressBuffer = ethUtil.privateToAddress(privKeyBuffer);
+ if (networkIsEthereum()) {
+ var pubkeyBuffer = keyPair.getPublicKeyBuffer();
+ var ethPubkey = libs.ethUtil.importPublic(pubkeyBuffer);
+ var addressBuffer = libs.ethUtil.publicToAddress(ethPubkey);
var hexAddress = addressBuffer.toString('hex');
- var checksumAddress = ethUtil.toChecksumAddress(hexAddress);
- address = ethUtil.addHexPrefix(checksumAddress);
- privkey = ethUtil.addHexPrefix(privkey);
- pubkey = ethUtil.addHexPrefix(pubkey);
+ var checksumAddress = libs.ethUtil.toChecksumAddress(hexAddress);
+ address = libs.ethUtil.addHexPrefix(checksumAddress);
+ pubkey = libs.ethUtil.addHexPrefix(pubkey);
+ if (hasPrivkey) {
+ privkey = libs.ethUtil.bufferToHex(keyPair.d.toBuffer(32));
+ }
+ }
+ //TRX is different
+ if (networks[DOM.network.val()].name == "TRX - Tron") {
+ keyPair = new libs.bitcoin.ECPair(keyPair.d, null, { network: network, compressed: false });
+ var pubkeyBuffer = keyPair.getPublicKeyBuffer();
+ var ethPubkey = libs.ethUtil.importPublic(pubkeyBuffer);
+ var addressBuffer = libs.ethUtil.publicToAddress(ethPubkey);
+ address = libs.bitcoin.address.toBase58Check(addressBuffer, 0x41);
+ if (hasPrivkey) {
+ privkey = keyPair.d.toBuffer().toString('hex');
+ }
+ }
+
+ // RSK values are different
+ if (networkIsRsk()) {
+ var pubkeyBuffer = keyPair.getPublicKeyBuffer();
+ var ethPubkey = libs.ethUtil.importPublic(pubkeyBuffer);
+ var addressBuffer = libs.ethUtil.publicToAddress(ethPubkey);
+ var hexAddress = addressBuffer.toString('hex');
+ // Use chainId based on selected network
+ // Ref: https://developers.rsk.co/rsk/architecture/account-based/#chainid
+ var chainId;
+ var rskNetworkName = networks[DOM.network.val()].name;
+ switch (rskNetworkName) {
+ case "R-BTC - RSK":
+ chainId = 30;
+ break;
+ case "tR-BTC - RSK Testnet":
+ chainId = 31;
+ break;
+ default:
+ chainId = null;
+ }
+ var checksumAddress = toChecksumAddressForRsk(hexAddress, chainId);
+ address = libs.ethUtil.addHexPrefix(checksumAddress);
+ pubkey = libs.ethUtil.addHexPrefix(pubkey);
+ if (hasPrivkey) {
+ privkey = libs.ethUtil.bufferToHex(keyPair.d.toBuffer());
+ }
+ }
+
+ // Handshake values are different
+ if (networks[DOM.network.val()].name == "HNS - Handshake") {
+ var ring = libs.handshake.KeyRing.fromPublic(keyPair.getPublicKeyBuffer())
+ address = ring.getAddress().toString();
+ }
+
+ // Stellar is different
+ if (networks[DOM.network.val()].name == "XLM - Stellar") {
+ var purpose = parseIntNoNaN(DOM.bip44purpose.val(), 44);
+ var coin = parseIntNoNaN(DOM.bip44coin.val(), 0);
+ var path = "m/";
+ path += purpose + "'/";
+ path += coin + "'/" + index + "'";
+ var keypair = libs.stellarUtil.getKeypair(path, seed);
+ indexText = path;
+ privkey = keypair.secret();
+ pubkey = address = keypair.publicKey();
+ }
+
+ // Nano currency
+ if (networks[DOM.network.val()].name == "NANO - Nano") {
+ var nanoKeypair = libs.nanoUtil.getKeypair(index, seed);
+ privkey = nanoKeypair.privKey;
+ pubkey = nanoKeypair.pubKey;
+ address = nanoKeypair.address;
+ }
+
+ if ((networks[DOM.network.val()].name == "NAS - Nebulas")) {
+ var privKeyBuffer = keyPair.d.toBuffer(32);
+ var nebulasAccount = libs.nebulas.Account.NewAccount();
+ nebulasAccount.setPrivateKey(privKeyBuffer);
+ address = nebulasAccount.getAddressString();
+ privkey = nebulasAccount.getPrivateKeyString();
+ pubkey = nebulasAccount.getPublicKeyString();
}
// Ripple values are different
if (networks[DOM.network.val()].name == "XRP - Ripple") {
privkey = convertRipplePriv(privkey);
address = convertRippleAdrr(address);
}
- // BIP49 addresses are different
- if (isP2wpkhNestedInP2sh) {
- if (!p2wpkhNestedInP2shAvailable) {
+ // Jingtum values are different
+ if (networks[DOM.network.val()].name == "SWTC - Jingtum") {
+ privkey = convertJingtumPriv(privkey);
+ address = convertJingtumAdrr(address);
+ }
+ // CasinoCoin values are different
+ if (networks[DOM.network.val()].name == "CSC - CasinoCoin") {
+ privkey = convertCasinoCoinPriv(privkey);
+ address = convertCasinoCoinAdrr(address);
+ }
+ // Bitcoin Cash address format may vary
+ if (networks[DOM.network.val()].name == "BCH - Bitcoin Cash") {
+ var bchAddrType = DOM.bitcoinCashAddressType.filter(":checked").val();
+ if (bchAddrType == "cashaddr") {
+ address = libs.bchaddr.toCashAddress(address);
+ }
+ else if (bchAddrType == "bitpay") {
+ address = libs.bchaddr.toBitpayAddress(address);
+ }
+ }
+ // Bitcoin Cash address format may vary
+ if (networks[DOM.network.val()].name == "SLP - Simple Ledger Protocol") {
+ var bchAddrType = DOM.bitcoinCashAddressType.filter(":checked").val();
+ if (bchAddrType == "cashaddr") {
+ address = libs.bchaddrSlp.toSlpAddress(address);
+ }
+ }
+
+ // ZooBC address format may vary
+ if (networks[DOM.network.val()].name == "ZBC - ZooBlockchain") {
+
+ var purpose = parseIntNoNaN(DOM.bip44purpose.val(), 44);
+ var coin = parseIntNoNaN(DOM.bip44coin.val(), 0);
+ var path = "m/";
+ path += purpose + "'/";
+ path += coin + "'/" + index + "'";
+ var result = libs.zoobcUtil.getKeypair(path, seed);
+
+ let publicKey = result.pubKey.slice(1, 33);
+ let privateKey = result.key;
+
+ privkey = privateKey.toString('hex');
+ pubkey = publicKey.toString('hex');
+
+ indexText = path;
+ address = libs.zoobcUtil.getZBCAddress(publicKey, 'ZBC');
+ }
+
+ // Segwit addresses are different
+ if (isSegwit) {
+ if (!segwitAvailable) {
return;
}
- var keyhash = bitcoinjs.bitcoin.crypto.hash160(key.getPublicKeyBuffer());
- var scriptsig = bitcoinjs.bitcoin.script.witnessPubKeyHash.output.encode(keyhash);
- var addressbytes = bitcoinjs.bitcoin.crypto.hash160(scriptsig);
- var scriptpubkey = bitcoinjs.bitcoin.script.scriptHash.output.encode(addressbytes);
- address = bitcoinjs.bitcoin.address.fromOutputScript(scriptpubkey, network)
+ if (isP2wpkh) {
+ var keyhash = libs.bitcoin.crypto.hash160(key.getPublicKeyBuffer());
+ var scriptpubkey = libs.bitcoin.script.witnessPubKeyHash.output.encode(keyhash);
+ address = libs.bitcoin.address.fromOutputScript(scriptpubkey, network)
+ }
+ else if (isP2wpkhInP2sh) {
+ var keyhash = libs.bitcoin.crypto.hash160(key.getPublicKeyBuffer());
+ var scriptsig = libs.bitcoin.script.witnessPubKeyHash.output.encode(keyhash);
+ var addressbytes = libs.bitcoin.crypto.hash160(scriptsig);
+ var scriptpubkey = libs.bitcoin.script.scriptHash.output.encode(addressbytes);
+ address = libs.bitcoin.address.fromOutputScript(scriptpubkey, network)
+ }
+ else if (isP2wsh) {
+ // https://github.com/libs.bitcoinjs-lib/blob/v3.3.2/test/integration/addresses.js#L71
+ // This is a 1-of-1
+ var witnessScript = libs.bitcoin.script.multisig.output.encode(1, [key.getPublicKeyBuffer()]);
+ var scriptPubKey = libs.bitcoin.script.witnessScriptHash.output.encode(libs.bitcoin.crypto.sha256(witnessScript));
+ address = libs.bitcoin.address.fromOutputScript(scriptPubKey, network);
+ }
+ else if (isP2wshInP2sh) {
+ // https://github.com/libs.bitcoinjs-lib/blob/v3.3.2/test/integration/transactions.js#L183
+ // This is a 1-of-1
+ var witnessScript = libs.bitcoin.script.multisig.output.encode(1, [key.getPublicKeyBuffer()]);
+ var redeemScript = libs.bitcoin.script.witnessScriptHash.output.encode(libs.bitcoin.crypto.sha256(witnessScript));
+ var scriptPubKey = libs.bitcoin.script.scriptHash.output.encode(libs.bitcoin.crypto.hash160(redeemScript));
+ address = libs.bitcoin.address.fromOutputScript(scriptPubKey, network)
+ }
+ }
+
+ if ((networks[DOM.network.val()].name == "CRW - Crown")) {
+ address = libs.bitcoin.networks.crown.toNewAddress(address);
+ }
+
+ if (networks[DOM.network.val()].name == "EOS - EOSIO") {
+ address = ""
+ pubkey = EOSbufferToPublic(keyPair.getPublicKeyBuffer());
+ privkey = EOSbufferToPrivate(keyPair.d.toBuffer(32));
+ }
+
+ if (networks[DOM.network.val()].name == "FIO - Foundation for Interwallet Operability") {
+ address = ""
+ pubkey = FIObufferToPublic(keyPair.getPublicKeyBuffer());
+ privkey = FIObufferToPrivate(keyPair.d.toBuffer(32));
+ }
+
+ if (networks[DOM.network.val()].name == "ATOM - Cosmos Hub") {
+ address = CosmosBufferToAddress(keyPair.getPublicKeyBuffer());
+ pubkey = CosmosBufferToPublic(keyPair.getPublicKeyBuffer());
+ privkey = keyPair.d.toBuffer().toString("base64");
+ }
+
+ //Groestlcoin Addresses are different
+ if(isGRS()) {
+
+ if (isSegwit) {
+ if (!segwitAvailable) {
+ return;
+ }
+ if (isP2wpkh) {
+ address = libs.groestlcoinjs.address.fromOutputScript(scriptpubkey, network)
+ }
+ else if (isP2wpkhInP2sh) {
+ address = libs.groestlcoinjs.address.fromOutputScript(scriptpubkey, network)
+ }
+ }
+ //non-segwit addresses are handled by using groestlcoinjs for bip32RootKey
+ }
+
+ if (isELA()) {
+ let elaAddress = calcAddressForELA(
+ seed,
+ parseIntNoNaN(DOM.bip44coin.val(), 0),
+ parseIntNoNaN(DOM.bip44account.val(), 0),
+ parseIntNoNaN(DOM.bip44change.val(), 0),
+ index
+ );
+ address = elaAddress.address;
+ privkey = elaAddress.privateKey;
+ pubkey = elaAddress.publicKey;
}
+
addAddressToList(indexText, address, pubkey, privkey);
if (isLast) {
hidePending();
+ updateCsv();
}
}, 50)
}
}
function showMore() {
- var start = DOM.addresses.children().length;
var rowsToAdd = parseInt(DOM.rowsToAdd.val());
if (isNaN(rowsToAdd)) {
rowsToAdd = 20;
DOM.rowsToAdd.val("20");
}
+ var start = parseInt(DOM.moreRowsStartIndex.val())
+ if (isNaN(start)) {
+ start = lastIndexInTable() + 1;
+ }
+ else {
+ var newStart = start + rowsToAdd;
+ DOM.moreRowsStartIndex.val(newStart);
+ }
if (rowsToAdd > 200) {
var msg = "Generating " + rowsToAdd + " rows could take a while. ";
msg += "Do you want to continue?";
function clearAddressesList() {
DOM.addresses.empty();
+ DOM.csv.val("");
stopGenerating();
}
if (comparedTo.indexOf(word) == 0) {
return comparedTo;
}
- var distance = Levenshtein.get(word, comparedTo);
+ var distance = libs.levenshtein.get(word, comparedTo);
if (distance < minDistance) {
closestWord = comparedTo;
minDistance = distance;
return phrase;
}
+ function writeSplitPhrase(phrase) {
+ var wordCount = phrase.split(/\s/g).length;
+ var left=[];
+ for (var i=0;i<wordCount;i++) left.push(i);
+ var group=[[],[],[]],
+ groupI=-1;
+ var seed = Math.abs(sjcl.hash.sha256.hash(phrase)[0])% 2147483647;
+ while (left.length>0) {
+ groupI=(groupI+1)%3;
+ seed = seed * 16807 % 2147483647;
+ var selected=Math.floor(left.length*(seed - 1) / 2147483646);
+ group[groupI].push(left[selected]);
+ left.splice(selected,1);
+ }
+ var cards=[phrase.split(/\s/g),phrase.split(/\s/g),phrase.split(/\s/g)];
+ for (var i=0;i<3;i++) {
+ for (var ii=0;ii<wordCount/3;ii++) cards[i][group[i][ii]]='XXXX';
+ cards[i]='Card '+(i+1)+': '+wordArrayToPhrase(cards[i]);
+ }
+ DOM.phraseSplit.val(cards.join("\r\n"));
+ var triesPerSecond=10000000000;
+ var hackTime=Math.pow(2,wordCount*10/3)/triesPerSecond;
+ var displayRedText = false;
+ if (hackTime<1) {
+ hackTime="<1 second";
+ displayRedText = true;
+ } else if (hackTime<86400) {
+ hackTime=Math.floor(hackTime)+" seconds";
+ displayRedText = true;
+ } else if(hackTime<31557600) {
+ hackTime=Math.floor(hackTime/86400)+" days";
+ displayRedText = true;
+ } else {
+ hackTime=Math.floor(hackTime/31557600)+" years";
+ }
+ DOM.phraseSplitWarn.html("Time to hack with only one card: "+hackTime);
+ if (displayRedText) {
+ DOM.phraseSplitWarn.addClass("text-danger");
+ } else {
+ DOM.phraseSplitWarn.removeClass("text-danger");
+ }
+ }
+
function isUsingOwnEntropy() {
return DOM.useEntropy.prop("checked");
}
// Get entropy value
var entropyStr = DOM.entropy.val();
// Work out minimum base for entropy
- var entropy = Entropy.fromString(entropyStr);
+ var entropy = null;
+ if (entropyTypeAutoDetect) {
+ entropy = Entropy.fromString(entropyStr);
+ }
+ else {
+ let base = DOM.entropyTypeInputs.filter(":checked").val();
+ entropy = Entropy.fromString(entropyStr, base);
+ }
if (entropy.binaryStr.length == 0) {
return;
}
// Get bits by hashing entropy with SHA256
var hash = sjcl.hash.sha256.hash(entropy.cleanStr);
var hex = sjcl.codec.hex.fromBits(hash);
- bits = BigInteger.parse(hex, 16).toString(2);
+ bits = libs.BigInteger.BigInteger.parse(hex, 16).toString(2);
while (bits.length % 256 != 0) {
bits = "0" + bits;
}
mnemonicLength = parseInt(mnemonicLength);
var numberOfBits = 32 * mnemonicLength / 3;
bits = bits.substring(0, numberOfBits);
+ // show warning for weak entropy override
+ if (mnemonicLength / 3 * 32 > entropy.binaryStr.length) {
+ DOM.entropyWeakEntropyOverrideWarning.removeClass("hidden");
+ }
+ else {
+ DOM.entropyWeakEntropyOverrideWarning.addClass("hidden");
+ }
+ }
+ else {
+ // hide warning for weak entropy override
+ DOM.entropyWeakEntropyOverrideWarning.addClass("hidden");
}
// Discard trailing entropy
var bitsToUse = Math.floor(bits.length / 32) * 32;
var phrase = mnemonic.toMnemonic(entropyArr);
// Set the mnemonic in the UI
DOM.phrase.val(phrase);
+ writeSplitPhrase(phrase);
+ // Show the word indexes
+ showWordIndexes();
+ // Show the checksum
+ showChecksum();
}
function clearEntropyFeedback() {
var numberOfBits = entropy.binaryStr.length;
var timeToCrack = "unknown";
try {
- var z = zxcvbn(entropy.base.parts.join(""));
+ var z = libs.zxcvbn(entropy.base.events.join(""));
timeToCrack = z.crack_times_display.offline_fast_hashing_1e10_per_second;
if (z.feedback.warning != "") {
timeToCrack = timeToCrack + " - " + z.feedback.warning;
console.log(e);
}
var entropyTypeStr = getEntropyTypeStr(entropy);
+ DOM.entropyTypeInputs.attr("checked", false);
+ DOM.entropyTypeInputs.filter("[value='" + entropyTypeStr + "']").attr("checked", true);
var wordCount = Math.floor(numberOfBits / 32) * 3;
var bitsPerEvent = entropy.bitsPerEvent.toFixed(2);
+ var spacedBinaryStr = addSpacesEveryElevenBits(entropy.binaryStr);
DOM.entropyFiltered.html(entropy.cleanHtml);
DOM.entropyType.text(entropyTypeStr);
DOM.entropyCrackTime.text(timeToCrack);
- DOM.entropyEventCount.text(entropy.base.ints.length);
+ DOM.entropyEventCount.text(entropy.base.events.length);
DOM.entropyBits.text(numberOfBits);
DOM.entropyWordCount.text(wordCount);
- DOM.entropyBinary.text(entropy.binaryStr);
+ DOM.entropyBinary.text(spacedBinaryStr);
DOM.entropyBitsPerEvent.text(bitsPerEvent);
// detect and warn of filtering
var rawNoSpaces = DOM.entropy.val().replace(/\s/g, "");
// Detect duplicates
var dupes = [];
var dupeTracker = {};
- for (var i=0; i<entropy.base.parts.length; i++) {
- var card = entropy.base.parts[i];
+ for (var i=0; i<entropy.base.events.length; i++) {
+ var card = entropy.base.events[i];
var cardUpper = card.toUpperCase();
if (cardUpper in dupeTracker) {
dupes.push(card);
function createQr(e) {
var content = e.target.textContent || e.target.value;
if (content) {
- var size = 130;
- DOM.qrImage.qrcode({width: size, height: size, text: content});
+ var qrEl = libs.kjua({
+ text: content,
+ render: "canvas",
+ size: 310,
+ ecLevel: 'H',
+ });
+ DOM.qrImage.append(qrEl);
if (!showQr) {
DOM.qrHider.addClass("hidden");
}
return DOM.bip32tab.hasClass("active");
}
- function useP2wpkhNestedInP2sh() {
- return DOM.useP2wpkhNestedInP2sh.prop("checked");
+ function networkIsEthereum() {
+ var name = networks[DOM.network.val()].name;
+ return (name == "ETH - Ethereum")
+ || (name == "ETC - Ethereum Classic")
+ || (name == "EWT - EnergyWeb")
+ || (name == "PIRL - Pirl")
+ || (name == "MIX - MIX")
+ || (name == "MOAC - MOAC")
+ || (name == "MUSIC - Musicoin")
+ || (name == "POA - Poa")
+ || (name == "EXP - Expanse")
+ || (name == "CLO - Callisto")
+ || (name == "DXN - DEXON")
+ || (name == "ELLA - Ellaism")
+ || (name == "ESN - Ethersocial Network")
+ || (name == "VET - VeChain")
+ || (name == "ERE - EtherCore")
+ || (name == "BSC - Binance Smart Chain")
+ }
+
+ function networkIsRsk() {
+ var name = networks[DOM.network.val()].name;
+ return (name == "R-BTC - RSK")
+ || (name == "tR-BTC - RSK Testnet");
}
- function networkHasBip49() {
- return networks[DOM.network.val()].p2wpkhNestedInP2shAvailable;
+ function networkHasSegwit() {
+ var n = network;
+ if ("baseNetwork" in network) {
+ n = libs.bitcoin.networks[network.baseNetwork];
+ }
+ // check if only p2wpkh params are required
+ if (p2wpkhSelected()) {
+ return "p2wpkh" in n;
+ }
+ // check if only p2wpkh-in-p2sh params are required
+ else if (p2wpkhInP2shSelected()) {
+ return "p2wpkhInP2sh" in n;
+ }
+ // require both if it's unclear which params are required
+ return "p2wpkh" in n && "p2wpkhInP2sh" in n;
}
function bip49TabSelected() {
return DOM.bip49tab.hasClass("active");
}
+ function bip84TabSelected() {
+ return DOM.bip84tab.hasClass("active");
+ }
+
+ function bip141TabSelected() {
+ return DOM.bip141tab.hasClass("active");
+ }
+
+ function setBip44ChangeValue() {
+ if (isDefaultBip44ChangeValue) {
+ if (networkIsEthereum()) {
+ DOM.bip44change.val("");
+ } else {
+ DOM.bip44change.val(0);
+ }
+ }
+ }
+
+ function modifiedDefaultBip44ChangeValue() {
+ isDefaultBip44ChangeValue = false;
+ }
+
+ function resetDefaultBip44ChangeValue() {
+ isDefaultBip44ChangeValue = true;
+ setBip44ChangeValue();
+ }
+
function setHdCoin(coinValue) {
DOM.bip44coin.val(coinValue);
DOM.bip49coin.val(coinValue);
+ DOM.bip84coin.val(coinValue);
+ setBip44ChangeValue();
}
- function showP2wpkhNestedInP2shAvailable() {
+ function showSegwitAvailable() {
DOM.bip49unavailable.addClass("hidden");
DOM.bip49available.removeClass("hidden");
- DOM.useP2wpkhNestedInP2sh.prop("disabled", false);
+ DOM.bip84unavailable.addClass("hidden");
+ DOM.bip84available.removeClass("hidden");
+ DOM.bip141unavailable.addClass("hidden");
+ DOM.bip141available.removeClass("hidden");
}
- function showP2wpkhNestedInP2shUnavailable() {
+ function showSegwitUnavailable() {
DOM.bip49available.addClass("hidden");
DOM.bip49unavailable.removeClass("hidden");
- DOM.useP2wpkhNestedInP2sh.prop("disabled", true);
- DOM.useP2wpkhNestedInP2sh.prop("checked", false);
+ DOM.bip84available.addClass("hidden");
+ DOM.bip84unavailable.removeClass("hidden");
+ DOM.bip141available.addClass("hidden");
+ DOM.bip141unavailable.removeClass("hidden");
}
- 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
+ function adjustNetworkForSegwit() {
+ // If segwit 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;
+ var segwitNetworks = null;
+ // if a segwit network is alread selected, need to use base network to
+ // look up new parameters
+ if ("baseNetwork" in network) {
+ network = libs.bitcoin.networks[network.baseNetwork];
+ }
+ // choose the right segwit params
+ if (p2wpkhSelected() && "p2wpkh" in network) {
+ network = network.p2wpkh;
+ }
+ else if (p2wpkhInP2shSelected() && "p2wpkhInP2sh" in network) {
+ network = network.p2wpkhInP2sh;
+ }
+ else if (p2wshSelected() && "p2wsh" in network) {
+ network = network.p2wsh;
+ }
+ else if (p2wshInP2shSelected() && "p2wshInP2sh" in network) {
+ network = network.p2wshInP2sh;
+ }
+ }
+
+ function lastIndexInTable() {
+ var pathText = DOM.addresses.find(".index").last().text();
+ var pathBits = pathText.split("/");
+ var lastBit = pathBits[pathBits.length-1];
+ var lastBitClean = lastBit.replace("'", "");
+ return parseInt(lastBitClean);
+ }
+
+ function uint8ArrayToHex(a) {
+ var s = ""
+ for (var i=0; i<a.length; i++) {
+ var h = a[i].toString(16);
+ while (h.length < 2) {
+ h = "0" + h;
}
+ s = s + h;
}
- else {
- if (network == bitcoinjs.bitcoin.networks.bitcoinBip49) {
- network = bitcoinjs.bitcoin.networks.bitcoin;
+ return s;
+ }
+
+ function showWordIndexes() {
+ var phrase = DOM.phrase.val();
+ var words = phraseToWordArray(phrase);
+ var wordIndexes = [];
+ var language = getLanguage();
+ for (var i=0; i<words.length; i++) {
+ var word = words[i];
+ var wordIndex = WORDLISTS[language].indexOf(word);
+ wordIndexes.push(wordIndex);
+ }
+ var wordIndexesStr = wordIndexes.join(", ");
+ DOM.entropyWordIndexes.text(wordIndexesStr);
+ }
+
+ function showChecksum() {
+ var phrase = DOM.phrase.val();
+ var words = phraseToWordArray(phrase);
+ var checksumBitlength = words.length / 3;
+ var checksum = "";
+ var binaryStr = "";
+ var language = getLanguage();
+ for (var i=words.length-1; i>=0; i--) {
+ var word = words[i];
+ var wordIndex = WORDLISTS[language].indexOf(word);
+ var wordBinary = wordIndex.toString(2);
+ while (wordBinary.length < 11) {
+ wordBinary = "0" + wordBinary;
}
- else if (network == bitcoinjs.bitcoin.networks.testnetBip49) {
- network = bitcoinjs.bitcoin.networks.testnet;
+ var binaryStr = wordBinary + binaryStr;
+ if (binaryStr.length >= checksumBitlength) {
+ var start = binaryStr.length - checksumBitlength;
+ var end = binaryStr.length;
+ checksum = binaryStr.substring(start, end);
+ // add spaces so the last group is 11 bits, not the first
+ checksum = checksum.split("").reverse().join("")
+ checksum = addSpacesEveryElevenBits(checksum);
+ checksum = checksum.split("").reverse().join("")
+ break;
}
- else if (network == bitcoinjs.bitcoin.networks.litecoinBip49) {
- network = bitcoinjs.bitcoin.networks.litecoin;
+ }
+ DOM.entropyChecksum.text(checksum);
+ }
+
+ function updateCsv() {
+ var tableCsv = "path,address,public key,private key\n";
+ var rows = DOM.addresses.find("tr");
+ for (var i=0; i<rows.length; i++) {
+ var row = $(rows[i]);
+ var cells = row.find("td");
+ for (var j=0; j<cells.length; j++) {
+ var cell = $(cells[j]);
+ if (!cell.children().hasClass("invisible")) {
+ tableCsv = tableCsv + cell.text();
+ }
+ if (j != cells.length - 1) {
+ tableCsv = tableCsv + ",";
+ }
}
+ tableCsv = tableCsv + "\n";
}
+ DOM.csv.val(tableCsv);
+ }
+
+ function addSpacesEveryElevenBits(binaryStr) {
+ return binaryStr.match(/.{1,11}/g).join(" ");
}
var networks = [
{
- name: "BCH - Bitcoin Cash",
- p2wpkhNestedInP2shAvailable: false,
+ name: "AC - Asiacoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.asiacoin;
+ setHdCoin(51);
+ },
+ },
+ {
+ name: "ACC - Adcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.adcoin;
+ setHdCoin(161);
+ },
+ },
+ {
+ name: "AGM - Argoneum",
+ onSelect: function() {
+ network = libs.bitcoin.networks.argoneum;
+ setHdCoin(421);
+ },
+ },
+ {
+ name: "ARYA - Aryacoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.aryacoin;
+ setHdCoin(357);
+ },
+ },
+ {
+ name: "ATOM - Cosmos Hub",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(118);
+ },
+ },
+ {
+ name: "AUR - Auroracoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.auroracoin;
+ setHdCoin(85);
+ },
+ },
+ {
+ name: "AXE - Axe",
+ onSelect: function() {
+ network = libs.bitcoin.networks.axe;
+ setHdCoin(4242);
+ },
+ },
+ {
+ name: "ANON - ANON",
+ onSelect: function() {
+ network = libs.bitcoin.networks.anon;
+ setHdCoin(220);
+ },
+ },
+ {
+ name: "BOLI - Bolivarcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bolivarcoin;
+ setHdCoin(278);
+ },
+ },
+ {
+ name: "BCA - Bitcoin Atom",
+ onSelect: function() {
+ network = libs.bitcoin.networks.atom;
+ setHdCoin(185);
+ },
+ },
+ {
+ name: "BCH - Bitcoin Cash",
+ onSelect: function() {
+ DOM.bitcoinCashAddressTypeContainer.removeClass("hidden");
+ setHdCoin(145);
+ },
+ },
+ {
+ name: "BEET - Beetlecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.beetlecoin;
+ setHdCoin(800);
+ },
+ },
+ {
+ name: "BELA - Belacoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.belacoin;
+ setHdCoin(73);
+ },
+ },
+ {
+ name: "BLK - BlackCoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.blackcoin;
+ setHdCoin(10);
+ },
+ },
+ {
+ name: "BND - Blocknode",
+ onSelect: function() {
+ network = libs.bitcoin.networks.blocknode;
+ setHdCoin(2941);
+ },
+ },
+ {
+ name: "tBND - Blocknode Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.blocknode_testnet;
+ setHdCoin(1);
+ },
+ },
+ {
+ name: "BRIT - Britcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.britcoin;
+ setHdCoin(70);
+ },
+ },
+ {
+ name: "BSD - Bitsend",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitsend;
+ setHdCoin(91);
+ },
+ },
+ {
+ name: "BST - BlockStamp",
+ onSelect: function() {
+ network = libs.bitcoin.networks.blockstamp;
+ setHdCoin(254);
+ },
+ },
+ {
+ name: "BTA - Bata",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bata;
+ setHdCoin(89);
+ },
+ },
+ {
+ name: "BTC - Bitcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(0);
+ },
+ },
+ {
+ name: "BTC - Bitcoin RegTest",
+ onSelect: function() {
+ network = libs.bitcoin.networks.regtest;
+ // Using hd coin value 1 based on bip44_coin_type
+ // https://github.com/chaintope/bitcoinrb/blob/f1014406f6b8f9b4edcecedc18df70c80df06f11/lib/bitcoin/chainparams/regtest.yml
+ setHdCoin(1);
+ },
+ },
+ {
+ name: "BTC - Bitcoin Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.testnet;
+ setHdCoin(1);
+ },
+ },
+ {
+ name: "BITG - Bitcoin Green",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoingreen;
+ setHdCoin(222);
+ },
+ },
+ {
+ name: "BTCP - Bitcoin Private",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoinprivate;
+ setHdCoin(183);
+ },
+ },
+ {
+ name: "BSC - Binance Smart Chain",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(60);
+ },
+ },
+ {
+ name: "BSV - BitcoinSV",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoinsv;
+ setHdCoin(236);
+ },
+ },
+ {
+ name: "BTCZ - Bitcoinz",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoinz;
+ setHdCoin(177);
+ },
+ },
+ {
+ name: "BTDX - BitCloud",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcloud;
+ setHdCoin(218);
+ },
+ },
+ {
+ name: "BTG - Bitcoin Gold",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bgold;
+ setHdCoin(156);
+ },
+ },
+ {
+ name: "BTX - Bitcore",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcore;
+ setHdCoin(160);
+ },
+ },
+ {
+ name: "CCN - Cannacoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.cannacoin;
+ setHdCoin(19);
+ },
+ },
+ {
+ name: "CESC - Cryptoescudo",
+ onSelect: function() {
+ network = libs.bitcoin.networks.cannacoin;
+ setHdCoin(111);
+ },
+ },
+ {
+ name: "CDN - Canadaecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.canadaecoin;
+ setHdCoin(34);
+ },
+ },
+ {
+ name: "CLAM - Clams",
+ onSelect: function() {
+ network = libs.bitcoin.networks.clam;
+ setHdCoin(23);
+ },
+ },
+ {
+ name: "CLO - Callisto",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(820);
+ },
+ },
+ {
+ name: "CLUB - Clubcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.clubcoin;
+ setHdCoin(79);
+ },
+ },
+ {
+ name: "CMP - Compcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.compcoin;
+ setHdCoin(71);
+ },
+ },
+ {
+ name: "CPU - CPUchain",
+ onSelect: function() {
+ network = libs.bitcoin.networks.cpuchain;
+ setHdCoin(363);
+ },
+ },
+ {
+ name: "CRAVE - Crave",
+ onSelect: function() {
+ network = libs.bitcoin.networks.crave;
+ setHdCoin(186);
+ },
+ },
+ {
+ name: "CRP - CranePay",
+ onSelect: function() {
+ network = libs.bitcoin.networks.cranepay;
+ setHdCoin(2304);
+ },
+ },
+
+ {
+ name: "CRW - Crown (Legacy)",
+ onSelect: function() {
+ network = libs.bitcoin.networks.crown;
+ setHdCoin(72);
+ },
+ },
+ {
+ name: "CRW - Crown",
+ onSelect: function() {
+ network = libs.bitcoin.networks.crown;
+ setHdCoin(72);
+ },
+ },
+ {
+ name: "CSC - CasinoCoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(359);
+ },
+ },
+ {
+ name: "DASH - Dash",
+ onSelect: function() {
+ network = libs.bitcoin.networks.dash;
+ setHdCoin(5);
+ },
+ },
+ {
+ name: "DASH - Dash Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.dashtn;
+ setHdCoin(1);
+ },
+ },
+ {
+ name: "DFC - Defcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.defcoin;
+ setHdCoin(1337);
+ },
+ },
+ {
+ name: "DGB - Digibyte",
+ onSelect: function() {
+ network = libs.bitcoin.networks.digibyte;
+ setHdCoin(20);
+ },
+ },
+ {
+ name: "DGC - Digitalcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.digitalcoin;
+ setHdCoin(18);
+ },
+ },
+ {
+ name: "DMD - Diamond",
+ onSelect: function() {
+ network = libs.bitcoin.networks.diamond;
+ setHdCoin(152);
+ },
+ },
+ {
+ name: "DNR - Denarius",
+ onSelect: function() {
+ network = libs.bitcoin.networks.denarius;
+ setHdCoin(116);
+ },
+ },
+ {
+ name: "DOGE - Dogecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.dogecoin;
+ setHdCoin(3);
+ },
+ },
+ {
+ name: "DOGEt - Dogecoin Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.dogecointestnet;
+ setHdCoin(1);
+ },
+ },
+ {
+ name: "DXN - DEXON",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(237);
+ },
+ },
+ {
+ name: "ECN - Ecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.ecoin;
+ setHdCoin(115);
+ },
+ },
+ {
+ name: "EDRC - Edrcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.edrcoin;
+ setHdCoin(56);
+ },
+ },
+ {
+ name: "EFL - Egulden",
+ onSelect: function() {
+ network = libs.bitcoin.networks.egulden;
+ setHdCoin(78);
+ },
+ },
+ {
+ name: "ELA - Elastos",
+ onSelect: function () {
+ network = libs.bitcoin.networks.elastos;
+ setHdCoin(2305);
+ },
+ },
+ {
+ name: "ELLA - Ellaism",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(163);
+ },
+ },
+ {
+ name: "EMC2 - Einsteinium",
+ onSelect: function() {
+ network = libs.bitcoin.networks.einsteinium;
+ setHdCoin(41);
+ },
+ },
+ {
+ name: "ERC - Europecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.europecoin;
+ setHdCoin(151);
+ },
+ },
+ {
+ name: "EOS - EOSIO",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(194);
+ },
+ },
+ {
+ name: "ERE - EtherCore",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(466);
+ },
+ },
+ {
+ name: "ESN - Ethersocial Network",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(31102);
+ },
+ },
+ {
+ name: "ETC - Ethereum Classic",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(61);
+ },
+ },
+ {
+ name: "ETH - Ethereum",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(60);
+ },
+ },
+ {
+ name: "EWT - EnergyWeb",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(246);
+ },
+ },
+ {
+ name: "EXCL - Exclusivecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.exclusivecoin;
+ setHdCoin(190);
+ },
+ },
+ {
+ name: "EXCC - ExchangeCoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.exchangecoin;
+ setHdCoin(0);
+ },
+ },
+ {
+ name: "EXP - Expanse",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(40);
+ },
+ },
+ {
+ name: "FIO - Foundation for Interwallet Operability",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(235);
+ },
+ },
+ {
+ name: "FIRO - Firo (Zcoin rebrand)",
+ onSelect: function() {
+ network = libs.bitcoin.networks.firo;
+ setHdCoin(136);
+ },
+ },
+ {
+ name: "FIX - FIX",
+ onSelect: function() {
+ network = libs.bitcoin.networks.fix;
+ setHdCoin(336);
+ },
+ },
+ {
+ name: "FIX - FIX Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.fixtestnet;
+ setHdCoin(1);
+ },
+ },
+ {
+ name: "FJC - Fujicoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.fujicoin;
+ setHdCoin(75);
+ },
+ },
+ {
+ name: "FLASH - Flashcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.flashcoin;
+ setHdCoin(120);
+ },
+ },
+ {
+ name: "FRST - Firstcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.firstcoin;
+ setHdCoin(167);
+ },
+ },
+ {
+ name: "FTC - Feathercoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.feathercoin;
+ setHdCoin(8);
+ },
+ },
+ {
+ name: "GAME - GameCredits",
+ onSelect: function() {
+ network = libs.bitcoin.networks.game;
+ setHdCoin(101);
+ },
+ },
+ {
+ name: "GBX - Gobyte",
+ onSelect: function() {
+ network = libs.bitcoin.networks.gobyte;
+ setHdCoin(176);
+ },
+ },
+ {
+ name: "GCR - GCRCoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.gcr;
+ setHdCoin(79);
+ },
+ },
+ {
+ name: "GRC - Gridcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.gridcoin;
+ setHdCoin(84);
+ },
+ },
+ {
+ name: "GRS - Groestlcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.groestlcoin;
+ setHdCoin(17);
+ },
+ },
+ {
+ name: "GRS - Groestlcoin Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.groestlcointestnet;
+ setHdCoin(1);
+ },
+ },
+ {
+ name: "HNS - Handshake",
+ onSelect: function() {
+ setHdCoin(5353);
+ },
+ },
+ {
+ name: "HNC - Helleniccoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.helleniccoin;
+ setHdCoin(168);
+ },
+ },
+ {
+ name: "HUSH - Hush (Legacy)",
+ onSelect: function() {
+ network = libs.bitcoin.networks.hush;
+ setHdCoin(197);
+ },
+ },
+ {
+ name: "HUSH - Hush3",
+ onSelect: function() {
+ network = libs.bitcoin.networks.hush3;
+ setHdCoin(197);
+ },
+ },
+ {
+ name: "INSN - Insane",
+ onSelect: function() {
+ network = libs.bitcoin.networks.insane;
+ setHdCoin(68);
+ },
+ },
+ {
+ name: "IOP - Iop",
+ onSelect: function() {
+ network = libs.bitcoin.networks.iop;
+ setHdCoin(66);
+ },
+ },
+ {
+ name: "IXC - Ixcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.ixcoin;
+ setHdCoin(86);
+ },
+ },
+ {
+ name: "JBS - Jumbucks",
+ onSelect: function() {
+ network = libs.bitcoin.networks.jumbucks;
+ setHdCoin(26);
+ },
+ },
+ {
+ name: "KMD - Komodo",
+ bip49available: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.komodo;
+ setHdCoin(141);
+ },
+ },
+ {
+ name: "KOBO - Kobocoin",
+ bip49available: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.kobocoin;
+ setHdCoin(196);
+ },
+ },
+ {
+ name: "LBC - Library Credits",
+ onSelect: function() {
+ network = libs.bitcoin.networks.lbry;
+ setHdCoin(140);
+ },
+ },
+ {
+ name: "LCC - Litecoincash",
+ onSelect: function() {
+ network = libs.bitcoin.networks.litecoincash;
+ setHdCoin(192);
+ },
+ },
+ {
+ name: "LDCN - Landcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.landcoin;
+ setHdCoin(63);
+ },
+ },
+ {
+ name: "LINX - Linx",
+ onSelect: function() {
+ network = libs.bitcoin.networks.linx;
+ setHdCoin(114);
+ },
+ },
+ {
+ name: "LKR - Lkrcoin",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.lkrcoin;
+ setHdCoin(557);
+ },
+ },
+ {
+ name: "LTC - Litecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.litecoin;
+ setHdCoin(2);
+ DOM.litecoinLtubContainer.removeClass("hidden");
+ },
+ },
+ {
+ name: "LTCt - Litecoin Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.litecointestnet;
+ setHdCoin(1);
+ DOM.litecoinLtubContainer.removeClass("hidden");
+ },
+ },
+ {
+ name: "LTZ - LitecoinZ",
+ onSelect: function() {
+ network = libs.bitcoin.networks.litecoinz;
+ setHdCoin(221);
+ },
+ },
+ {
+ name: "LYNX - Lynx",
+ onSelect: function() {
+ network = libs.bitcoin.networks.lynx;
+ setHdCoin(191);
+ },
+ },
+ {
+ name: "MAZA - Maza",
+ onSelect: function() {
+ network = libs.bitcoin.networks.maza;
+ setHdCoin(13);
+ },
+ },
+ {
+ name: "MEC - Megacoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.megacoin;
+ setHdCoin(217);
+ },
+ },
+ {
+ name: "MIX - MIX",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(76);
+ },
+ },
+ {
+ name: "MNX - Minexcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.minexcoin;
+ setHdCoin(182);
+ },
+ },
+ {
+ name: "MONA - Monacoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.monacoin,
+ setHdCoin(22);
+ },
+ },
+ {
+ name: "MONK - Monkey Project",
+ onSelect: function() {
+ network = libs.bitcoin.networks.monkeyproject,
+ setHdCoin(214);
+ },
+ },
+ {
+ name: "MOAC - MOAC",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(314);
+ },
+ },
+ {
+ name: "MUSIC - Musicoin",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(184);
+ },
+ },
+ {
+ name: "NANO - Nano",
+ onSelect: function() {
+ network = network = libs.nanoUtil.dummyNetwork;
+ setHdCoin(165);
+ },
+ },
+ {
+ name: "NAV - Navcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.navcoin;
+ setHdCoin(130);
+ },
+ },
+ {
+ name: "NAS - Nebulas",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(2718);
+ },
+ },
+ {
+ name: "NEBL - Neblio",
+ onSelect: function() {
+ network = libs.bitcoin.networks.neblio;
+ setHdCoin(146);
+ },
+ },
+ {
+ name: "NEOS - Neoscoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.neoscoin;
+ setHdCoin(25);
+ },
+ },
+ {
+ name: "NIX - NIX Platform",
+ onSelect: function() {
+ network = libs.bitcoin.networks.nix;
+ setHdCoin(400);
+ },
+ },
+ {
+ name: "NLG - Gulden",
+ onSelect: function() {
+ network = libs.bitcoin.networks.gulden;
+ setHdCoin(87);
+ },
+ },
+ {
+ name: "NMC - Namecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.namecoin;
+ setHdCoin(7);
+ },
+ },
+ {
+ name: "NRG - Energi",
+ onSelect: function() {
+ network = libs.bitcoin.networks.energi;
+ setHdCoin(204);
+ },
+ },
+ {
+ name: "NRO - Neurocoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.neurocoin;
+ setHdCoin(110);
+ },
+ },
+ {
+ name: "NSR - Nushares",
+ onSelect: function() {
+ network = libs.bitcoin.networks.nushares;
+ setHdCoin(11);
+ },
+ },
+ {
+ name: "NYC - Newyorkc",
+ onSelect: function() {
+ network = libs.bitcoin.networks.newyorkc;
+ setHdCoin(179);
+ },
+ },
+ {
+ name: "NVC - Novacoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.novacoin;
+ setHdCoin(50);
+ },
+ },
+ {
+ name: "OK - Okcash",
+ onSelect: function() {
+ network = libs.bitcoin.networks.okcash;
+ setHdCoin(69);
+ },
+ },
+ {
+ name: "OMNI - Omnicore",
+ onSelect: function() {
+ network = libs.bitcoin.networks.omnicore;
+ setHdCoin(200);
+ },
+ },
+ {
+ name: "ONION - DeepOnion",
+ onSelect: function() {
+ network = libs.bitcoin.networks.deeponion;
+ setHdCoin(305);
+ },
+ },
+ {
+ name: "ONX - Onixcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.onixcoin;
+ setHdCoin(174);
+ },
+ },
+ {
+ name: "PHR - Phore",
onSelect: function() {
- DOM.useBitpayAddressesContainer.removeClass("hidden");
- setBitcoinCashNetworkValues();
- setHdCoin(145);
+ network = libs.bitcoin.networks.phore;
+ setHdCoin(444);
},
},
{
- name: "BTC - Bitcoin",
- p2wpkhNestedInP2shAvailable: true,
+ name: "PINK - Pinkcoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.bitcoin;
- setHdCoin(0);
+ network = libs.bitcoin.networks.pinkcoin;
+ setHdCoin(117);
},
},
{
- name: "BTC - Bitcoin Testnet",
- p2wpkhNestedInP2shAvailable: true,
+ name: "PIRL - Pirl",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(164);
+ },
+ },
+ {
+ name: "PIVX - PIVX",
+ onSelect: function() {
+ network = libs.bitcoin.networks.pivx;
+ setHdCoin(119);
+ },
+ },
+ {
+ name: "PIVX - PIVX Testnet",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.testnet;
+ network = libs.bitcoin.networks.pivxtestnet;
setHdCoin(1);
},
},
{
- name: "CLAM - Clams",
- p2wpkhNestedInP2shAvailable: false,
+ name: "POA - Poa",
+ segwitAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.clam;
- setHdCoin(23);
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(178);
},
},
{
- name: "CRW - Crown",
- p2wpkhNestedInP2shAvailable: false,
+ name: "POSW - POSWcoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.crown;
- setHdCoin(72);
+ network = libs.bitcoin.networks.poswcoin;
+ setHdCoin(47);
},
},
{
- name: "DASH - Dash",
- p2wpkhNestedInP2shAvailable: false,
+ name: "POT - Potcoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.dash;
- setHdCoin(5);
+ network = libs.bitcoin.networks.potcoin;
+ setHdCoin(81);
},
},
{
- name: "DASH - Dash Testnet",
- p2wpkhNestedInP2shAvailable: false,
+ name: "PPC - Peercoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.dashtn;
- setHdCoin(1);
+ network = libs.bitcoin.networks.peercoin;
+ setHdCoin(6);
},
},
{
- name: "DOGE - Dogecoin",
- p2wpkhNestedInP2shAvailable: false,
+ name: "PRJ - ProjectCoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.dogecoin;
- setHdCoin(3);
+ network = libs.bitcoin.networks.projectcoin;
+ setHdCoin(533);
},
},
{
- name: "ETH - Ethereum",
- p2wpkhNestedInP2shAvailable: false,
+ name: "PSB - Pesobit",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.bitcoin;
- setHdCoin(60);
+ network = libs.bitcoin.networks.pesobit;
+ setHdCoin(62);
},
},
{
- name: "FJC - Fujicoin",
- p2wpkhNestedInP2shAvailable: false,
+ name: "PUT - Putincoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.fujicoin;
- setHdCoin(75);
+ network = libs.bitcoin.networks.putincoin;
+ setHdCoin(122);
},
},
{
- name: "GAME - GameCredits",
- p2wpkhNestedInP2shAvailable: false,
+ name: "RPD - Rapids",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.game;
- setHdCoin(101);
+ network = libs.bitcoin.networks.rapids;
+ setHdCoin(320);
},
},
{
- name: "JBS - Jumbucks",
- p2wpkhNestedInP2shAvailable: false,
+ name: "RVN - Ravencoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.jumbucks;
- setHdCoin(26);
+ network = libs.bitcoin.networks.ravencoin;
+ setHdCoin(175);
},
},
{
- name: "LTC - Litecoin",
- p2wpkhNestedInP2shAvailable: true,
+ name: "R-BTC - RSK",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.litecoin;
- setHdCoin(2);
- DOM.litecoinLtubContainer.removeClass("hidden");
+ network = libs.bitcoin.networks.rsk;
+ setHdCoin(137);
},
},
{
- name: "MAZA - Maza",
- p2wpkhNestedInP2shAvailable: false,
+ name: "tR-BTC - RSK Testnet",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.maza;
- setHdCoin(13);
+ network = libs.bitcoin.networks.rsktestnet;
+ setHdCoin(37310);
},
},
-
{
- name: "NMC - Namecoin",
- p2wpkhNestedInP2shAvailable: false,
+ name: "RBY - Rubycoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.namecoin;
- setHdCoin(7);
+ network = libs.bitcoin.networks.rubycoin;
+ setHdCoin(16);
},
},
{
- name: "PIVX - PIVX",
- p2wpkhNestedInP2shAvailable: false,
+ name: "RDD - Reddcoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.pivx;
- setHdCoin(119);
+ network = libs.bitcoin.networks.reddcoin;
+ setHdCoin(4);
},
},
{
- name: "PIVX - PIVX Testnet",
- p2wpkhNestedInP2shAvailable: false,
+ name: "RITO - Ritocoin",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.pivxtestnet;
- setHdCoin(1);
+ network = libs.bitcoin.networks.ritocoin;
+ setHdCoin(19169);
},
},
{
- name: "PPC - Peercoin",
- p2wpkhNestedInP2shAvailable: false,
+ name: "RVR - RevolutionVR",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.peercoin;
- setHdCoin(6);
+ network = libs.bitcoin.networks.revolutionvr;
+ setHdCoin(129);
+ },
+ },
+ {
+ name: "SAFE - Safecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.safecoin;
+ setHdCoin(19165);
+ },
+ },
+ {
+ name: "SCRIBE - Scribe",
+ onSelect: function() {
+ network = libs.bitcoin.networks.scribe;
+ setHdCoin(545);
+ },
+ },
+ {
+ name: "SLS - Salus",
+ onSelect: function() {
+ network = libs.bitcoin.networks.salus;
+ setHdCoin(63);
},
},
{
name: "SDC - ShadowCash",
- p2wpkhNestedInP2shAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.shadow;
+ network = libs.bitcoin.networks.shadow;
setHdCoin(35);
},
},
{
name: "SDC - ShadowCash Testnet",
- p2wpkhNestedInP2shAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.shadowtn;
+ network = libs.bitcoin.networks.shadowtn;
setHdCoin(1);
},
},
{
name: "SLM - Slimcoin",
- p2wpkhNestedInP2shAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.slimcoin;
+ network = libs.bitcoin.networks.slimcoin;
setHdCoin(63);
},
},
{
name: "SLM - Slimcoin Testnet",
- p2wpkhNestedInP2shAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.slimcointn;
+ network = libs.bitcoin.networks.slimcointn;
setHdCoin(111);
},
},
+ {
+ name: "SLP - Simple Ledger Protocol",
+ onSelect: function() {
+ DOM.bitcoinCashAddressTypeContainer.removeClass("hidden");
+ setHdCoin(245);
+ },
+ },
+ {
+ name: "SLR - Solarcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.solarcoin;
+ setHdCoin(58);
+ },
+ },
+ {
+ name: "SMLY - Smileycoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.smileycoin;
+ setHdCoin(59);
+ },
+ },
+ {
+ name: "STASH - Stash",
+ onSelect: function() {
+ network = libs.bitcoin.networks.stash;
+ setHdCoin(0xC0C0);
+ },
+ },
+ {
+ name: "STASH - Stash Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.stashtn;
+ setHdCoin(0xCAFE);
+ },
+ },
+ {
+ name: "STRAT - Stratis",
+ onSelect: function() {
+ network = libs.bitcoin.networks.stratis;
+ setHdCoin(105);
+ },
+ },
+ {
+ name: "SUGAR - Sugarchain",
+ onSelect: function() {
+ network = libs.bitcoin.networks.sugarchain;
+ setHdCoin(408);
+ },
+ },
+ {
+ name: "TUGAR - Sugarchain Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.sugarchaintestnet;
+ setHdCoin(408);
+ },
+ },
+ {
+ name: "SWTC - Jingtum",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(315);
+ },
+ },
+ {
+ name: "TSTRAT - Stratis Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.stratistest;
+ setHdCoin(105);
+ },
+ },
+ {
+ name: "SYS - Syscoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.syscoin;
+ setHdCoin(57);
+ },
+ },
+ {
+ name: "THC - Hempcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.hempcoin;
+ setHdCoin(113);
+ },
+ },
+ {
+ name: "THT - Thought",
+ onSelect: function() {
+ network = libs.bitcoin.networks.thought;
+ setHdCoin(1618);
+ },
+ },
+ {
+ name: "TOA - Toa",
+ onSelect: function() {
+ network = libs.bitcoin.networks.toa;
+ setHdCoin(159);
+ },
+ },
+ {
+ name: "TRX - Tron",
+ onSelect: function() {
+ setHdCoin(195);
+ },
+ },
+ {
+ name: "TWINS - TWINS",
+ onSelect: function() {
+ network = libs.bitcoin.networks.twins;
+ setHdCoin(970);
+ },
+ },
+ {
+ name: "TWINS - TWINS Testnet",
+ onSelect: function() {
+ network = libs.bitcoin.networks.twinstestnet;
+ setHdCoin(1);
+ },
+ },
+ {
+ name: "USC - Ultimatesecurecash",
+ onSelect: function() {
+ network = libs.bitcoin.networks.ultimatesecurecash;
+ setHdCoin(112);
+ },
+ },
{
name: "USNBT - NuBits",
- p2wpkhNestedInP2shAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.nubits;
+ network = libs.bitcoin.networks.nubits;
setHdCoin(12);
},
},
+ {
+ name: "UNO - Unobtanium",
+ onSelect: function() {
+ network = libs.bitcoin.networks.unobtanium;
+ setHdCoin(92);
+ },
+ },
+ {
+ name: "VASH - Vpncoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.vpncoin;
+ setHdCoin(33);
+ },
+ },
+ {
+ name: "VET - VeChain",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoin;
+ setHdCoin(818);
+ },
+ },
{
name: "VIA - Viacoin",
- p2wpkhNestedInP2shAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.viacoin;
+ network = libs.bitcoin.networks.viacoin;
setHdCoin(14);
},
},
{
name: "VIA - Viacoin Testnet",
- p2wpkhNestedInP2shAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.viacointestnet;
+ network = libs.bitcoin.networks.viacointestnet;
setHdCoin(1);
},
},
+ {
+ name: "VIVO - Vivo",
+ onSelect: function() {
+ network = libs.bitcoin.networks.vivo;
+ setHdCoin(166);
+ },
+ },
+ {
+ name: "VTC - Vertcoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.vertcoin;
+ setHdCoin(28);
+ },
+ },
+ {
+ name: "WGR - Wagerr",
+ onSelect: function() {
+ network = libs.bitcoin.networks.wagerr;
+ setHdCoin(7825266);
+ },
+ },
+ {
+ name: "WC - Wincoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.wincoin;
+ setHdCoin(181);
+ },
+ },
+ {
+ name: "XAX - Artax",
+ onSelect: function() {
+ network = libs.bitcoin.networks.artax;
+ setHdCoin(219);
+ },
+ },
+ {
+ name: "XBC - Bitcoinplus",
+ onSelect: function() {
+ network = libs.bitcoin.networks.bitcoinplus;
+ setHdCoin(65);
+ },
+ },
+ {
+ name: "XLM - Stellar",
+ onSelect: function() {
+ network = libs.stellarUtil.dummyNetwork;
+ setHdCoin(148);
+ },
+ },
{
name: "XMY - Myriadcoin",
- p2wpkhNestedInP2shAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.myriadcoin;
+ network = libs.bitcoin.networks.myriadcoin;
setHdCoin(90);
},
},
{
name: "XRP - Ripple",
- p2wpkhNestedInP2shAvailable: false,
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.bitcoin;
+ network = libs.bitcoin.networks.bitcoin;
setHdCoin(144);
},
},
{
- name: "MONA - Monacoin",
- p2wpkhNestedInP2shAvailable: true,
+ name: "XVC - Vcash",
onSelect: function() {
- network = bitcoinjs.bitcoin.networks.monacoin,
- setHdCoin(22);
+ network = libs.bitcoin.networks.vcash;
+ setHdCoin(127);
},
- }
+ },
+ {
+ name: "XVG - Verge",
+ onSelect: function() {
+ network = libs.bitcoin.networks.verge;
+ setHdCoin(77);
+ },
+ },
+ {
+ name: "XUEZ - Xuez",
+ segwitAvailable: false,
+ onSelect: function() {
+ network = libs.bitcoin.networks.xuez;
+ setHdCoin(225);
+ },
+ },
+ {
+ name: "XWC - Whitecoin",
+ onSelect: function() {
+ network = libs.bitcoin.networks.whitecoin;
+ setHdCoin(155);
+ },
+ },
+ {
+ name: "XZC - Zcoin (rebranded to Firo)",
+ onSelect: function() {
+ network = libs.bitcoin.networks.zcoin;
+ setHdCoin(136);
+ },
+ },
+ {
+ name: "ZBC - ZooBlockchain",
+ onSelect: function () {
+ network = libs.bitcoin.networks.zoobc;
+ setHdCoin(883);
+ },
+ },
+ {
+ name: "ZCL - Zclassic",
+ onSelect: function() {
+ network = libs.bitcoin.networks.zclassic;
+ setHdCoin(147);
+ },
+ },
+ {
+ name: "ZEC - Zcash",
+ onSelect: function() {
+ network = libs.bitcoin.networks.zcash;
+ setHdCoin(133);
+ },
+ },
+ {
+ name: "ZEN - Horizen",
+ onSelect: function() {
+ network = libs.bitcoin.networks.zencash;
+ setHdCoin(121);
+ },
+ },
]
var clients = [
DOM.bip32path.val("m/0'/0");
DOM.hardenedAddresses.prop('checked', false);
},
+ },
+ {
+ name: "Coinomi, Ledger",
+ onSelect: function() {
+ DOM.bip32path.val("m/44'/"+DOM.bip44coin.val()+"'/0'");
+ DOM.hardenedAddresses.prop('checked', false);
+ },
}
]
+ // RSK - RSK functions - begin
+ function stripHexPrefix(address) {
+ if (typeof address !== "string") {
+ throw new Error("address parameter should be a string.");
+ }
+
+ var hasPrefix = (address.substring(0, 2) === "0x" ||
+ address.substring(0, 2) === "0X");
+
+ return hasPrefix ? address.slice(2) : address;
+ };
+
+ function toChecksumAddressForRsk(address, chainId = null) {
+ if (typeof address !== "string") {
+ throw new Error("address parameter should be a string.");
+ }
+
+ if (!/^(0x)?[0-9a-f]{40}$/i.test(address)) {
+ throw new Error("Given address is not a valid RSK address: " + address);
+ }
+
+ var stripAddress = stripHexPrefix(address).toLowerCase();
+ var prefix = chainId != null ? chainId.toString() + "0x" : "";
+ var keccakHash = libs.ethUtil.keccak256(prefix + stripAddress)
+ .toString("hex")
+ .replace(/^0x/i, "");
+ var checksumAddress = "0x";
+
+ for (var i = 0; i < stripAddress.length; i++) {
+ checksumAddress +=
+ parseInt(keccakHash[i], 16) >= 8 ?
+ stripAddress[i].toUpperCase() :
+ stripAddress[i];
+ }
+
+ return checksumAddress;
+ }
+
+ // RSK - RSK functions - end
+
+ // ELA - Elastos functions - begin
+ function displayBip44InfoForELA() {
+ if (!isELA()) {
+ return;
+ }
+
+ var coin = parseIntNoNaN(DOM.bip44coin.val(), 0);
+ var account = parseIntNoNaN(DOM.bip44account.val(), 0);
+
+ // Calculate the account extended keys
+ var accountXprv = libs.elastosjs.getAccountExtendedPrivateKey(seed, coin, account);
+ var accountXpub = libs.elastosjs.getAccountExtendedPublicKey(seed, coin, account);
+
+ // Display the extended keys
+ DOM.bip44accountXprv.val(accountXprv);
+ DOM.bip44accountXpub.val(accountXpub);
+ }
+
+ function displayBip32InfoForELA() {
+ if (!isELA()) {
+ return;
+ }
+
+ var coin = parseIntNoNaN(DOM.bip44coin.val(), 0);
+ var account = parseIntNoNaN(DOM.bip44account.val(), 0);
+ var change = parseIntNoNaN(DOM.bip44change.val(), 0);
+
+ DOM.extendedPrivKey.val(libs.elastosjs.getBip32ExtendedPrivateKey(seed, coin, account, change));
+ DOM.extendedPubKey.val(libs.elastosjs.getBip32ExtendedPublicKey(seed, coin, account, change));
+
+ // Display the addresses and privkeys
+ clearAddressesList();
+ var initialAddressCount = parseInt(DOM.rowsToAdd.val());
+ displayAddresses(0, initialAddressCount);
+ }
+
+ function calcAddressForELA(seed, coin, account, change, index) {
+ if (!isELA()) {
+ return;
+ }
+
+ var publicKey = libs.elastosjs.getDerivedPublicKey(libs.elastosjs.getMasterPublicKey(seed), change, index);
+ return {
+ privateKey: libs.elastosjs.getDerivedPrivateKey(seed, coin, account, change, index),
+ publicKey: publicKey,
+ address: libs.elastosjs.getAddress(publicKey.toString('hex'))
+ };
+ }
+ // ELA - Elastos functions - end
+
init();
})();