v1.4 updates to Wallet Details and Bulk Wallet tabs
This commit is contained in:
parent
0ba1fb6a6e
commit
eb462e526c
1 changed files with 149 additions and 16 deletions
|
@ -3896,9 +3896,20 @@
|
||||||
#bulktextarea { font-size: 90%; width: 98%; margin: 4px 0 0 0; }
|
#bulktextarea { font-size: 90%; width: 98%; margin: 4px 0 0 0; }
|
||||||
#detailarea { display: none; margin: 0; padding: 10px; border: 2px solid green; text-align: left; }
|
#detailarea { display: none; margin: 0; padding: 10px; border: 2px solid green; text-align: left; }
|
||||||
#detailarea .notes { text-align: left; font-size: 80%; padding: 0 0 20px 0; }
|
#detailarea .notes { text-align: left; font-size: 80%; padding: 0 0 20px 0; }
|
||||||
#detailarea .item { margin: 10px 0; }
|
#detailarea .item { margin: 10px 0; position: relative; }
|
||||||
#detailarea .label { display: block; text-decoration: underline; }
|
#detailarea .label { display: block; text-decoration: underline; }
|
||||||
#detailarea .output { display: block; min-height: 20px; }
|
#detailarea .output { display: block; min-height: 20px; }
|
||||||
|
#detailarea #detailqrcodepublic { position: relative; float: left; margin: 0 10px 0 0; }
|
||||||
|
#detailarea #detailqrcodeprivate { position: relative; float: right; margin: 0 0 0 10px; }
|
||||||
|
.right { text-align: right; }
|
||||||
|
|
||||||
|
#bulkfaqs { display: none; }
|
||||||
|
.bulkquestion { padding: 10px 15px; text-align: left; cursor: pointer; }
|
||||||
|
.bulkquestion:hover { color: #77777A; }
|
||||||
|
.bulkanswer { padding: 0 15px 10px 25px; text-align: left; display: none; font-size: 80%; }
|
||||||
|
.bulkfaq { border: 2px solid green; border-top: 0; width: 696px; margin: auto; position: relative; }
|
||||||
|
#faqs ol { padding: 0 0 0 25px; }
|
||||||
|
#faqs li { padding: 3px 0; }
|
||||||
|
|
||||||
.qrcode_table { border-width: 0px; border-style: none; border-color: #0000ff; border-collapse: collapse; }
|
.qrcode_table { border-width: 0px; border-style: none; border-color: #0000ff; border-collapse: collapse; }
|
||||||
.qrcode_tddark { border-width: 0px; border-style: none; border-color: #0000ff; border-collapse: collapse; padding: 0; margin: 0; width: 2px; height: 2px; background-color: #000000; }
|
.qrcode_tddark { border-width: 0px; border-style: none; border-color: #0000ff; border-collapse: collapse; padding: 0; margin: 0; width: 2px; height: 2px; background-color: #000000; }
|
||||||
|
@ -3931,6 +3942,19 @@
|
||||||
#bulklimit { width: 45px; }
|
#bulklimit { width: 45px; }
|
||||||
.pagebreak { height: 50px; }
|
.pagebreak { height: 50px; }
|
||||||
|
|
||||||
|
.more
|
||||||
|
{
|
||||||
|
background: url()
|
||||||
|
no-repeat left center;
|
||||||
|
width: 17px; height: 17px; display: inline-block; float: right;
|
||||||
|
}
|
||||||
|
.less
|
||||||
|
{
|
||||||
|
background: url()
|
||||||
|
no-repeat left center;
|
||||||
|
width: 17px; height: 17px; display: inline-block; float: right;
|
||||||
|
}
|
||||||
|
|
||||||
.footer { font-family: Arial; font-size: 90%; clear: both; width: 700px; padding: 10px 0 10px 0; margin: 50px auto auto auto; }
|
.footer { font-family: Arial; font-size: 90%; clear: both; width: 700px; padding: 10px 0 10px 0; margin: 50px auto auto auto; }
|
||||||
.footer div span { padding: 10px; }
|
.footer div span { padding: 10px; }
|
||||||
.footer .authorbtc { float: left; width: 470px; }
|
.footer .authorbtc { float: left; width: 470px; }
|
||||||
|
@ -3950,6 +3974,7 @@
|
||||||
.footer { display: none; }
|
.footer { display: none; }
|
||||||
.commands { display: none; }
|
.commands { display: none; }
|
||||||
#tagline { display: none; }
|
#tagline { display: none; }
|
||||||
|
#faqs { display: none; }
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
</head>
|
</head>
|
||||||
|
@ -3992,7 +4017,7 @@
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div id="detailcommands">
|
<div id="detailcommands">
|
||||||
<span>Enter Private Key (any format): <input type="text" id="detailprivkey" value="" onfocus="this.select();" /></span>
|
<span>Enter Private Key (any format): <input type="text" id="detailprivkey" value="" onfocus="this.select();" onkeypress="if (event.keyCode == 13) ninja.wallets.detailwallet.viewDetails();" /></span>
|
||||||
<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>
|
||||||
|
@ -4032,36 +4057,90 @@
|
||||||
<div id="detailarea">
|
<div id="detailarea">
|
||||||
<div class="notes">
|
<div class="notes">
|
||||||
Your Bitcoin Private Key is a unique secret number that only you know. It can be be encoded in a number of different formats.
|
Your Bitcoin Private Key is a unique secret number that only you know. It can be be encoded in a number of different formats.
|
||||||
Below we show the Bitcoin Address that corresponds to your Private Key as well as your Private Key in the most popular encoding formats.
|
Below we show the Bitcoin Address and Public Key that corresponds to your Private Key as well as your Private Key in the most popular encoding formats (WIF, HEX, B64, MINI).
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="item">
|
<div class="item">
|
||||||
<span class="label">Bitcoin Address (33 or 34 characters, always starts with a '1'):</span>
|
<div id="detailqrcodepublic" class="qrcode_public"></div>
|
||||||
|
<span class="label">Bitcoin Address (33 or 34 characters, starts with a '1'):</span>
|
||||||
<span class="output" id="detailaddress"></span>
|
<span class="output" id="detailaddress"></span>
|
||||||
</div>
|
</div>
|
||||||
|
<br />
|
||||||
<div class="item">
|
<div class="item">
|
||||||
<span class="label">Private Key Sipa Wallet Import Format (51 characters base58, always starts with a '5'):</span>
|
<span class="label">Public Key (130 characters [0-9A-F]):</span>
|
||||||
|
<span class="output" id="detailpubkey"></span>
|
||||||
|
</div>
|
||||||
|
<div class="item right">
|
||||||
|
<div id="detailqrcodeprivate" class="qrcode_private"></div>
|
||||||
|
<span class="label">Private Key Sipa Wallet Import Format (51 characters base58, starts with a '5'):</span>
|
||||||
<span class="output" id="detailprivwif"></span>
|
<span class="output" id="detailprivwif"></span>
|
||||||
</div>
|
</div>
|
||||||
|
<br /><br />
|
||||||
<div class="item">
|
<div class="item">
|
||||||
<span class="label">Private Key Hexadecimal Format (64 characters [0-9A-F]):</span>
|
<span class="label">Private Key Hexadecimal Format (64 characters [0-9A-F]):</span>
|
||||||
<span class="output" id="detailprivhex"></span>
|
<span class="output" id="detailprivhex"></span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="item">
|
<div class="item">
|
||||||
<span class="label">Private Key Base64 (44 characters):</span>
|
<span class="label">Private Key Base64 (44 characters):</span>
|
||||||
<span class="output" id="detailprivb64"></span>
|
<span class="output" id="detailprivb64"></span>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div class="item" style="display: none;" id="detailmini">
|
<div class="item" style="display: none;" id="detailmini">
|
||||||
<span class="label">Private Key Mini Format (22, 26 or 30 characters, always starts with an 'S'):</span>
|
<span class="label">Private Key Mini Format (22, 26 or 30 characters, starts with an 'S'):</span>
|
||||||
<span class="output" id="detailprivmini"></span>
|
<span class="output" id="detailprivmini"></span>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
|
<div id="faqs">
|
||||||
|
<div id="bulkfaqs">
|
||||||
|
<div id="bulkfaq1" class="bulkfaq">
|
||||||
|
<div id="bulkq1" class="bulkquestion" onclick="ninja.wallets.bulkwallet.openCloseFaq(1);">
|
||||||
|
<span>Why should I use a Bulk Wallet to accept Bitcoins on my website?</span>
|
||||||
|
<div id="bulke1" class="more"></div>
|
||||||
|
</div>
|
||||||
|
<div id="bulka1" class="bulkanswer">
|
||||||
|
The traditional approach to accepting bitcoins on your website requires that
|
||||||
|
you install the official bitcoin client daeman ("bitcoind"). Many website hosting packages
|
||||||
|
don't support installing the bitcoin daeman. Also, running the bitcoin daeman on your
|
||||||
|
web server means your private keys are hosted on the server and could get stolen if your web
|
||||||
|
server is hacked. When using a Bulk Wallet you can upload only the bitcoin addresses
|
||||||
|
and not the private keys to your web server. Then you don't have to worry about your
|
||||||
|
bitcoin wallet being stolen if your web server is hacked.
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
<div id="bulkfaq2" class="bulkfaq">
|
||||||
|
<div id="bulkq2" class="bulkquestion" onclick="ninja.wallets.bulkwallet.openCloseFaq(2);">
|
||||||
|
<span>How do I use a Bulk Wallet to accept Bitcoins on my website?</span>
|
||||||
|
<div id="bulke2" class="more"></div>
|
||||||
|
</div>
|
||||||
|
<div id="bulka2" class="bulkanswer">
|
||||||
|
<ol>
|
||||||
|
<li>Use the Bulk Wallet tab to pre-generate a large number of bitcoin addresses (10,000+). Copy and paste the generated
|
||||||
|
comma separated values (CSV) list to a secure text file on your computer. Backup the file you just created to a secure location.</li>
|
||||||
|
<li>Import the bitcoin addresses into a database table on your web server.
|
||||||
|
(Don't put the wallet/private keys on your web server, otherwise you risk hackers stealing your coins.
|
||||||
|
Just the bitcoin addresses as they will be shown to customers.)</li>
|
||||||
|
<li>Provide an option on your website's shopping cart for your customer to pay in Bitcoin. When the customer chooses to pay in Bitcoin you will
|
||||||
|
then display one of the addresses from your database to the customer as his "payment address" and save it with his shopping cart order.</li>
|
||||||
|
<li>You now need to be notified when the payment arrives. Google "bitcoin payment notification" and subscribe to at least
|
||||||
|
one bitcoin payment notification service. There are various services that will notify you via Web Services, API, SMS, Email, etc.
|
||||||
|
Once you receive this notification, which could be programmatically automated, you can process the customer's order.
|
||||||
|
To manually check if a payment has arrived you can use Block Explorer. Replace THEADDRESSGOESHERE with the bitcoin address
|
||||||
|
you are checking. It could take between 10 minutes to one hour for the transaction to be confirmed.
|
||||||
|
<br />
|
||||||
|
http://www.blockexplorer.com/address/THEADDRESSGOESHERE
|
||||||
|
<br /><br />
|
||||||
|
Unconfirmed transactions can be viewed at: http://blockchain.info/ <br />
|
||||||
|
You should see the transaction there within 30 seconds.
|
||||||
|
</li>
|
||||||
|
<li>Bitcoins will safely pile up on the block chain. Use the original wallet file you generated in step 1 to spend them.</li>
|
||||||
|
</ol>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
|
||||||
<div id="footer" class="footer">
|
<div id="footer" class="footer">
|
||||||
<div class="authorbtc">
|
<div class="authorbtc">
|
||||||
|
@ -4072,7 +4151,7 @@
|
||||||
</div>
|
</div>
|
||||||
<div class="authorpgp">
|
<div class="authorpgp">
|
||||||
<span><a href="ninja_bitaddress.org.txt" target="_blank">PGP Public Key</a></span>
|
<span><a href="ninja_bitaddress.org.txt" target="_blank">PGP Public Key</a></span>
|
||||||
<span><a href="pgpsignedmsg.txt" target="_blank">Signed Version History</a></span>
|
<span><a href="pgpsignedmsg.txt" target="_blank">Signed Version History (v1.4)</a></span>
|
||||||
</div>
|
</div>
|
||||||
<div class="copyright">
|
<div class="copyright">
|
||||||
<span>Copyright bitaddress.org.</span>
|
<span>Copyright bitaddress.org.</span>
|
||||||
|
@ -4272,6 +4351,7 @@
|
||||||
}
|
}
|
||||||
document.getElementById("bulkarea").style.display = "block";
|
document.getElementById("bulkarea").style.display = "block";
|
||||||
document.getElementById("bulkcommands").style.display = "block";
|
document.getElementById("bulkcommands").style.display = "block";
|
||||||
|
document.getElementById("bulkfaqs").style.display = "block";
|
||||||
|
|
||||||
// show a default CSV list if the text area is empty
|
// show a default CSV list if the text area is empty
|
||||||
if (document.getElementById("bulktextarea").value == "") {
|
if (document.getElementById("bulktextarea").value == "") {
|
||||||
|
@ -4283,6 +4363,7 @@
|
||||||
close: function () {
|
close: function () {
|
||||||
document.getElementById("bulkarea").style.display = "none";
|
document.getElementById("bulkarea").style.display = "none";
|
||||||
document.getElementById("bulkcommands").style.display = "none";
|
document.getElementById("bulkcommands").style.display = "none";
|
||||||
|
document.getElementById("bulkfaqs").style.display = "none";
|
||||||
},
|
},
|
||||||
|
|
||||||
// use this function to bulk generate addresses
|
// use this function to bulk generate addresses
|
||||||
|
@ -4325,6 +4406,19 @@
|
||||||
else if (bulkWallet.csvRowsRemaining === 0) {
|
else if (bulkWallet.csvRowsRemaining === 0) {
|
||||||
document.getElementById("bulktextarea").value = bulkWallet.csv.join("\n");
|
document.getElementById("bulktextarea").value = bulkWallet.csv.join("\n");
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
openCloseFaq: function (faqNum) {
|
||||||
|
// do close
|
||||||
|
if (document.getElementById("bulka" + faqNum).style.display == "block") {
|
||||||
|
document.getElementById("bulka" + faqNum).style.display = "none";
|
||||||
|
document.getElementById("bulke" + faqNum).setAttribute("class", "more");
|
||||||
|
}
|
||||||
|
// do open
|
||||||
|
else {
|
||||||
|
document.getElementById("bulka" + faqNum).style.display = "block";
|
||||||
|
document.getElementById("bulke" + faqNum).setAttribute("class", "less");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
|
@ -4465,7 +4559,7 @@
|
||||||
bytes.shift();
|
bytes.shift();
|
||||||
bytes = bytes.slice(0, bytes.length - 4);
|
bytes = bytes.slice(0, bytes.length - 4);
|
||||||
if (bytes.length != 32) {
|
if (bytes.length != 32) {
|
||||||
alert("Not a valid Private Key");
|
alert("The text you entered is not a valid Private Key");
|
||||||
ninja.wallets.detailwallet.clear();
|
ninja.wallets.detailwallet.clear();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -4479,7 +4573,7 @@
|
||||||
else if (keyFormat.isBase64Format(key)) {
|
else if (keyFormat.isBase64Format(key)) {
|
||||||
var bytes = Crypto.util.base64ToBytes(key);
|
var bytes = Crypto.util.base64ToBytes(key);
|
||||||
if (bytes.length != 32) {
|
if (bytes.length != 32) {
|
||||||
alert("Not a valid Private Key");
|
alert("The text you entered is not a valid Private Key");
|
||||||
ninja.wallets.detailwallet.clear();
|
ninja.wallets.detailwallet.clear();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
@ -4493,31 +4587,70 @@
|
||||||
document.getElementById("detailmini").style.display = "block";
|
document.getElementById("detailmini").style.display = "block";
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
alert("Not a valid Private Key");
|
|
||||||
|
// enforce a minimum passphrase length
|
||||||
|
if (key.length > 11) {
|
||||||
|
// Deterministic Wallet confirm box to ask if user wants to SHA256 the input to get a private key
|
||||||
|
var usePassphrase = confirm("The text you entered is not a valid Private Key!\n\n"
|
||||||
|
+ "Would you like use the entered text as a passphrase and create a Private Key using a SHA256 hash of the passphrase?\n\n"
|
||||||
|
+ "Warning: Choosing a strong passphrase is important to avoid brute force attempts to guess your passphrase and steal your bitcoins.");
|
||||||
|
|
||||||
|
if (usePassphrase) {
|
||||||
|
var bytes = Crypto.SHA256(key, { asBytes: true });
|
||||||
|
var btcKey = new Bitcoin.ECKey(bytes);
|
||||||
|
}
|
||||||
|
else {
|
||||||
ninja.wallets.detailwallet.clear();
|
ninja.wallets.detailwallet.clear();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
alert("The text you entered is not a valid Private Key");
|
||||||
|
ninja.wallets.detailwallet.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (btcKey != undefined) {
|
if (btcKey != undefined) {
|
||||||
|
var pubKey = Crypto.util.bytesToHex(btcKey.getPub()).toUpperCase();
|
||||||
|
var halfWayIndex = Math.floor(pubKey.length / 2);
|
||||||
|
var pubKeyFirstHalf = pubKey.substr(0, halfWayIndex);
|
||||||
|
var pubKeySecondHalf = pubKey.substr(halfWayIndex, pubKey.length - halfWayIndex);
|
||||||
|
document.getElementById("detailpubkey").innerHTML = pubKeyFirstHalf + "<br />" + pubKeySecondHalf;
|
||||||
document.getElementById("detailaddress").innerHTML = btcKey.getBitcoinAddress();
|
document.getElementById("detailaddress").innerHTML = btcKey.getBitcoinAddress();
|
||||||
document.getElementById("detailprivwif").innerHTML = btcKey.getBitcoinWalletImportFormat();
|
document.getElementById("detailprivwif").innerHTML = btcKey.getBitcoinWalletImportFormat();
|
||||||
document.getElementById("detailprivhex").innerHTML = btcKey.toString().toUpperCase();
|
document.getElementById("detailprivhex").innerHTML = btcKey.toString().toUpperCase();
|
||||||
document.getElementById("detailprivb64").innerHTML = btcKey.toString("base64");
|
document.getElementById("detailprivb64").innerHTML = btcKey.toString("base64");
|
||||||
|
document.getElementById("detailqrcodepublic").innerHTML = "";
|
||||||
|
document.getElementById("detailqrcodeprivate").innerHTML = "";
|
||||||
|
// show QR codes
|
||||||
|
try {
|
||||||
|
document.getElementById("detailqrcodepublic").appendChild(ninja.qrCode.createCanvas(btcKey.getBitcoinAddress()));
|
||||||
|
document.getElementById("detailqrcodeprivate").appendChild(ninja.qrCode.createCanvas(btcKey.getBitcoinWalletImportFormat()));
|
||||||
|
}
|
||||||
|
catch (e) {
|
||||||
|
// for browsers that do not support canvas (IE8)
|
||||||
|
document.getElementById("detailqrcodepublic").innerHTML = ninja.qrCode.createTableHtml(btcKey.getBitcoinAddress());
|
||||||
|
document.getElementById("detailqrcodeprivate").innerHTML = ninja.qrCode.createTableHtml(btcKey.getBitcoinWalletImportFormat());
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
clear: function () {
|
clear: function () {
|
||||||
|
document.getElementById("detailpubkey").innerHTML = "";
|
||||||
document.getElementById("detailaddress").innerHTML = "";
|
document.getElementById("detailaddress").innerHTML = "";
|
||||||
document.getElementById("detailprivwif").innerHTML = "";
|
document.getElementById("detailprivwif").innerHTML = "";
|
||||||
document.getElementById("detailprivhex").innerHTML = "";
|
document.getElementById("detailprivhex").innerHTML = "";
|
||||||
document.getElementById("detailprivb64").innerHTML = "";
|
document.getElementById("detailprivb64").innerHTML = "";
|
||||||
document.getElementById("detailprivmini").innerHTML = "";
|
document.getElementById("detailprivmini").innerHTML = "";
|
||||||
|
document.getElementById("detailqrcodepublic").innerHTML = "";
|
||||||
|
document.getElementById("detailqrcodeprivate").innerHTML = "";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
walletType: { "singlewallet": "singlewallet", "bulkwallet": "bulkwallet", "paperwallet": "paperwallet", "detailwallet": "detailwallet" },
|
walletType: { "singlewallet": "singlewallet", "bulkwallet": "bulkwallet", "paperwallet": "paperwallet", "detailwallet": "detailwallet" },
|
||||||
|
|
||||||
getQueryString: function() {
|
getQueryString: function () {
|
||||||
var result = {}, queryString = location.search.substring(1), re = /([^&=]+)=([^&]*)/g, m;
|
var result = {}, queryString = location.search.substring(1), re = /([^&=]+)=([^&]*)/g, m;
|
||||||
|
|
||||||
while (m = re.exec(queryString)) {
|
while (m = re.exec(queryString)) {
|
||||||
|
|
Loading…
Reference in a new issue