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:
Robin Owens 2012-09-27 16:00:36 +01:00
parent 4dc7cc64ac
commit 30e00a6984

View file

@ -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>