Adding in additional tab for Vanity Address calculations.
When calc a vanity address there is a need for the user to multiply 2 private addresses together. This needs to be done offline.
This commit is contained in:
parent
4dc7cc64ac
commit
30e00a6984
1 changed files with 122 additions and 4 deletions
|
@ -3932,6 +3932,9 @@
|
||||||
.keyarea .output { display: block; }
|
.keyarea .output { display: block; }
|
||||||
.keyarea .qrcode_public { display: inline-block; float: left; }
|
.keyarea .qrcode_public { display: inline-block; float: left; }
|
||||||
.keyarea .qrcode_private { display: inline-block; position: relative; top: 28px; float: right; }
|
.keyarea .qrcode_private { display: inline-block; position: relative; top: 28px; float: right; }
|
||||||
|
.vankeyarea { font-family: Courier New; text-align: left; position: relative; padding: 5px; }
|
||||||
|
.vankeyarea .label { text-decoration: underline; }
|
||||||
|
.vankeyarea .output { display: block; }
|
||||||
#faqs ol { padding: 0 0 0 25px; }
|
#faqs ol { padding: 0 0 0 25px; }
|
||||||
#faqs li { padding: 3px 0; }
|
#faqs li { padding: 3px 0; }
|
||||||
|
|
||||||
|
@ -3956,7 +3959,10 @@
|
||||||
#detailarea #detailqrcodepubliccomp { position: relative; float: right; margin: 0 0 0 10px; }
|
#detailarea #detailqrcodepubliccomp { position: relative; float: right; margin: 0 0 0 10px; }
|
||||||
#detailarea #detailqrcodeprivate { position: relative; float: left; margin: 0 10px 0 0; }
|
#detailarea #detailqrcodeprivate { position: relative; float: left; margin: 0 10px 0 0; }
|
||||||
#detailarea #detailqrcodeprivatecomp { position: relative; float: right; margin: 0 0 0 10px; }
|
#detailarea #detailqrcodeprivatecomp { position: relative; float: right; margin: 0 0 0 10px; }
|
||||||
|
#vanityarea { display: none; border: 2px solid green; min-height: 250px;}
|
||||||
|
#vanityarea .keyarea {display: none; }
|
||||||
|
#vanityaddareaoutput .keyarea {display: none; }
|
||||||
|
#vanityarea .notes { text-align: left; font-size: 80%; padding: 0 0 20px 0; }
|
||||||
#bulkfaqs { display: none; }
|
#bulkfaqs { display: none; }
|
||||||
.bulkquestion { padding: 10px 15px; text-align: left; cursor: pointer; }
|
.bulkquestion { padding: 10px 15px; text-align: left; cursor: pointer; }
|
||||||
.bulkquestion:hover { color: #77777A; }
|
.bulkquestion:hover { color: #77777A; }
|
||||||
|
@ -3992,6 +3998,8 @@
|
||||||
#brainpassphrase { width: 280px; }
|
#brainpassphrase { width: 280px; }
|
||||||
#detailcommands { display: none; }
|
#detailcommands { display: none; }
|
||||||
#detailcommands span { padding: 0 10px; }
|
#detailcommands span { padding: 0 10px; }
|
||||||
|
#vanitykeycommands { display: none; }
|
||||||
|
#vanitykeycommands span { padding: 0 10px; }
|
||||||
#detailprivkey { width: 250px; }
|
#detailprivkey { width: 250px; }
|
||||||
.paper .commands { border-bottom: 2px solid green; padding: 10px 0; margin-bottom: 0; }
|
.paper .commands { border-bottom: 2px solid green; padding: 10px 0; margin-bottom: 0; }
|
||||||
#bulkstartindex, #paperlimit, #paperlimitperpage { width: 35px; }
|
#bulkstartindex, #paperlimit, #paperlimitperpage { width: 35px; }
|
||||||
|
@ -4050,6 +4058,7 @@
|
||||||
<div class="tab" id="bulkwallet" onclick="ninja.tabSwitch(this);">Bulk Wallet</div>
|
<div class="tab" id="bulkwallet" onclick="ninja.tabSwitch(this);">Bulk Wallet</div>
|
||||||
<div class="tab" id="brainwallet" onclick="ninja.tabSwitch(this);">Brain Wallet</div>
|
<div class="tab" id="brainwallet" onclick="ninja.tabSwitch(this);">Brain Wallet</div>
|
||||||
<div class="tab" id="detailwallet" onclick="ninja.tabSwitch(this);">Wallet Details</div>
|
<div class="tab" id="detailwallet" onclick="ninja.tabSwitch(this);">Wallet Details</div>
|
||||||
|
<div class="tab" id="vanitykey" onclick="ninja.tabSwitch(this);">Vanity Private Key</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="commands" class="commands">
|
<div id="commands" class="commands">
|
||||||
|
@ -4088,6 +4097,11 @@
|
||||||
<span><input type="button" id="detailview" value="View Details" onclick="ninja.wallets.detailwallet.viewDetails();" /></span>
|
<span><input type="button" id="detailview" value="View Details" onclick="ninja.wallets.detailwallet.viewDetails();" /></span>
|
||||||
<span class="print"><input type="button" name="print" value="Print" onclick="window.print();" /></span>
|
<span class="print"><input type="button" name="print" value="Print" onclick="window.print();" /></span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div id="vanitykeycommands">
|
||||||
|
<span><input type="button" id="newkey" value="Generate New Public/Private Key pair" onclick="ninja.generateKeyPair();" /></span>
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="wallets" class="wallets">
|
<div id="wallets" class="wallets">
|
||||||
|
@ -4194,6 +4208,45 @@
|
||||||
<span class="output" id="detailprivmini"></span>
|
<span class="output" id="detailprivmini"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<div id="vanityarea">
|
||||||
|
<div id="vanitykeyarea" class="vankeyarea">
|
||||||
|
<div>
|
||||||
|
<span class="label">Public Key:</span>
|
||||||
|
<div class="output" id=vanitypubkey style="word-wrap:break-word;"></div>
|
||||||
|
<div class="notes"><br />Copy and paste the above into the Public Key field in the Vanity Pool Website.</div>
|
||||||
|
</div>
|
||||||
|
<div>
|
||||||
|
<span class="label">Private Key:</span>
|
||||||
|
<span class="output" id=vanityprivatekey></span>
|
||||||
|
<div class="notes"><br />Copy and paste the above Private Key field into a text file. Ideally save to an encrypted drive.
|
||||||
|
You will need this to retrieve the Bitcoin Private Key once the Pool has found your prefix.</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<hr />
|
||||||
|
<div id=vanityadditionarea class="vankeyarea">
|
||||||
|
<div class="label">Enter Private Key (previously saved):</div>
|
||||||
|
<div><input type="text" id="vanityprivkey" value="" maxlength=64 size=80 onfocus="this.select();" /></div>
|
||||||
|
<div class="label">Enter Private Key (from Vanity Pool):</div>
|
||||||
|
<div><input type="text" id="vanitypoolprivkey" value="" maxlength=64 size=80 onfocus="this.select();" /></div>
|
||||||
|
<div></div><input type="button" id="vanityadd" value="Calc Wallet Private Key" onclick="ninja.wallets.vanitykey.addKeys();" />
|
||||||
|
|
||||||
|
<hr/>
|
||||||
|
<div id=vanityaddareaoutput class="vankeyarea">
|
||||||
|
<div>
|
||||||
|
<span class="label">Private Key (WIF):</span>
|
||||||
|
<span class="output" id=vanityprivatekeyWIF>-</span>
|
||||||
|
<div class="notes"><br />The above is the Private Key to load into your wallet. </div>
|
||||||
|
</div>
|
||||||
|
<hr/>
|
||||||
|
<div>
|
||||||
|
<span class="label">New Address:</span>
|
||||||
|
<span class="output" id=vanityAddress>-</span>
|
||||||
|
<div class="notes"><br />The above is your new address that should include your required prefix.</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="faqs">
|
<div id="faqs">
|
||||||
|
@ -4301,6 +4354,35 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
generateKeyPair: function (idPostFix) {
|
||||||
|
idPostFix = idPostFix || "";
|
||||||
|
try {
|
||||||
|
var key = new Bitcoin.ECKey(false);
|
||||||
|
var publicKey = Crypto.util.bytesToHex(key.getPub()).toString().toUpperCase();
|
||||||
|
//var halfWayIndex = Math.floor(publicKey.length / 2);
|
||||||
|
//var pubKeyFirstHalf = publicKey.substr(0, halfWayIndex);
|
||||||
|
//var pubKeySecondHalf = publicKey.substr(halfWayIndex, publicKey.length - halfWayIndex);
|
||||||
|
//publicKey = pubKeyFirstHalf + "<br />" + pubKeySecondHalf;
|
||||||
|
var privateKey = Crypto.util.bytesToHex(key.getBitcoinPrivateKeyByteArray()).toString().toUpperCase();
|
||||||
|
}
|
||||||
|
catch (e) {
|
||||||
|
alert(e);
|
||||||
|
publicKey = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (publicKey) {
|
||||||
|
document.getElementById("vanitypubkey" + idPostFix).innerHTML = publicKey;
|
||||||
|
document.getElementById("vanityprivatekey" + idPostFix).innerHTML = privateKey;
|
||||||
|
|
||||||
|
}
|
||||||
|
// browsers that failed to generate keys
|
||||||
|
else {
|
||||||
|
document.getElementById("vanitypubkey" + idPostFix).innerHTML = "error";
|
||||||
|
document.getElementById("vanityprivatekey" + idPostFix).innerHTML = "error";
|
||||||
|
}
|
||||||
|
document.getElementById("vanitykeyarea").style.display = "block";
|
||||||
|
},
|
||||||
|
|
||||||
|
|
||||||
qrCode: {
|
qrCode: {
|
||||||
// determine which type number is big enough for the input text length
|
// determine which type number is big enough for the input text length
|
||||||
|
@ -4835,10 +4917,45 @@
|
||||||
document.getElementById("detailqrcodeprivate").innerHTML = "";
|
document.getElementById("detailqrcodeprivate").innerHTML = "";
|
||||||
document.getElementById("detailqrcodeprivatecomp").innerHTML = "";
|
document.getElementById("detailqrcodeprivatecomp").innerHTML = "";
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
|
vanitykey: {
|
||||||
|
open: function () {
|
||||||
|
for (var wType in ninja.walletType) {
|
||||||
|
ninja.wallets[wType].close();
|
||||||
|
}
|
||||||
|
document.getElementById("vanityarea").style.display = "block";
|
||||||
|
document.getElementById("vanitykeycommands").style.display = "block";
|
||||||
|
},
|
||||||
|
|
||||||
|
close: function () {
|
||||||
|
document.getElementById("vanityarea").style.display = "none";
|
||||||
|
document.getElementById("vanitykeyarea").style.display = "none";
|
||||||
|
document.getElementById("vanitykeycommands").style.display = "none";
|
||||||
|
},
|
||||||
|
addKeys: function () {
|
||||||
|
var privateKeyWif = false;
|
||||||
|
var bitcoinAddress = false;
|
||||||
|
//document.getElementById("vanityadditionalarea").style.display = "block";
|
||||||
|
try{
|
||||||
|
var privateKeyString=document.getElementById("vanityprivkey").value;
|
||||||
|
var privatePoolKeyString=document.getElementById("vanitypoolprivkey").value;
|
||||||
|
var privateKey=BigInteger.fromByteArrayUnsigned(Crypto.util.hexToBytes(privateKeyString));
|
||||||
|
var privatePoolKey=BigInteger.fromByteArrayUnsigned(Crypto.util.hexToBytes(privatePoolKeyString));
|
||||||
|
var n=EllipticCurve.getSECCurveByName("secp256k1").getN();
|
||||||
|
var newPrivateKey=new Bitcoin.ECKey(privateKey.multiply(privatePoolKey).mod(n));
|
||||||
|
bitcoinAddress = newPrivateKey.getBitcoinAddress();
|
||||||
|
privateKeyWif = newPrivateKey.getBitcoinWalletImportFormat();
|
||||||
|
} catch (e) {
|
||||||
|
alert(e);
|
||||||
|
}
|
||||||
|
document.getElementById("vanityprivatekeyWIF").innerHTML = privateKeyWif;
|
||||||
|
document.getElementById("vanityAddress").innerHTML = bitcoinAddress;
|
||||||
|
},
|
||||||
|
|
||||||
|
},
|
||||||
},
|
},
|
||||||
|
|
||||||
walletType: { "singlewallet": "singlewallet", "paperwallet": "paperwallet", "bulkwallet": "bulkwallet", "brainwallet": "brainwallet", "detailwallet": "detailwallet" },
|
walletType: { "singlewallet": "singlewallet", "paperwallet": "paperwallet", "bulkwallet": "bulkwallet", "brainwallet": "brainwallet", "detailwallet": "detailwallet","vanitykey":"vanitykey" },
|
||||||
|
|
||||||
getQueryString: function () {
|
getQueryString: function () {
|
||||||
var result = {}, queryString = location.search.substring(1), re = /([^&=]+)=([^&]*)/g, m;
|
var result = {}, queryString = location.search.substring(1), re = /([^&=]+)=([^&]*)/g, m;
|
||||||
|
@ -4864,3 +4981,4 @@
|
||||||
</script>
|
</script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue