adding additional tab for calculating Vanity Addresses.

This is needed when a user wants a pool to generate the
address but then needs to combine the 2 private keys to
create the final key to import into their wallet.
This commit is contained in:
Robin Owens 2012-10-07 10:13:15 +01:00
parent 31433898c7
commit 4be1a70588

View file

@ -3927,6 +3927,10 @@
.keyarea .output { display: block; }
.keyarea .qrcode_public { display: inline-block; float: left; }
.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 li { padding: 3px 0; }
@ -3978,7 +3982,11 @@
#detailarea #detailqrcodepubliccomp { position: relative; float: right; margin: 0 0 0 10px; }
#detailarea #detailqrcodeprivate { position: relative; float: left; margin: 0 10px 0 0; }
#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; }
.bulkquestion { padding: 10px 15px; text-align: left; cursor: pointer; }
.bulkquestion:hover { color: #77777A; }
@ -4018,6 +4026,11 @@
#brainpassphraseconfirm { width: 280px; }
#detailcommands { display: none; }
#detailcommands span { padding: 0 10px; }
#vanitykeycommands { display: none; }
#vanitykeycommands span { padding: 0 10px; }
#detailprivkey { width: 250px; }
.paper .commands { border-bottom: 2px solid green; padding: 10px 0; margin-bottom: 0; }
#bulkstartindex, #paperlimit, #paperlimitperpage { width: 35px; }
@ -4062,6 +4075,7 @@
<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="detailwallet" onclick="ninja.tabSwitch(this);">Wallet Details</div>
<div class="tab" id="vanitykey" onclick="ninja.tabSwitch(this);">Vanity Private Key</div>
</div>
<div id="commands" class="commands">
@ -4101,6 +4115,11 @@
<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>
</div>
<div id="vanitykeycommands">
<span><input type="button" id="newkey" value="Generate New Public/Private Key pair" onclick="ninja.generateKeyPair();" /></span>
</div>
</div>
<div id="wallets" class="wallets">
@ -4207,6 +4226,45 @@
<span class="output" id="detailprivmini"></span>
</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 id="faqs">
@ -4280,6 +4338,36 @@
<script type="text/javascript">
var ninja = {
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: {
// determine which type number is big enough for the input text length
getTypeNumber: function (text) {
@ -4432,7 +4520,7 @@
ninja.seed();
}
},
// generate bitcoin address and private key and update information in the HTML
generateNewAddressAndKey: function () {
try {
@ -4926,9 +5014,52 @@
document.getElementById("detailqrcodeprivate").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("vanityadditionalarea").style.display = "block";
document.getElementById("vanitykeycommands").style.display = "block";
//document.getElementById("vanityadditionalarea").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","vanitykey":"vanitykey" },
getQueryString: function () {
var result = {}, queryString = location.search.substring(1), re = /([^&=]+)=([^&]*)/g, m;
while (m = re.exec(queryString)) {
@ -4951,4 +5082,4 @@
setTimeout(ninja.wallets.singlewallet.forceGenerate, ninja.seedLimit * 20);
</script>
</body>
</html>
</html>