95 lines
3.1 KiB
HTML
95 lines
3.1 KiB
HTML
|
<!DOCTYPE html>
|
||
|
<html lang="en">
|
||
|
<head>
|
||
|
<meta charset="utf-8">
|
||
|
<title>JSDoc: Source: wif.js</title>
|
||
|
|
||
|
<script src="scripts/prettify/prettify.js"> </script>
|
||
|
<script src="scripts/prettify/lang-css.js"> </script>
|
||
|
<!--[if lt IE 9]>
|
||
|
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
|
||
|
<![endif]-->
|
||
|
<link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
|
||
|
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
|
||
|
</head>
|
||
|
|
||
|
<body>
|
||
|
|
||
|
<div id="main">
|
||
|
|
||
|
<h1 class="page-title">Source: wif.js</h1>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
<section>
|
||
|
<article>
|
||
|
<pre class="prettyprint source linenums"><code>/**
|
||
|
* Implements WIF encoding/decoding.
|
||
|
* @see {@link https://en.bitcoin.it/wiki/Wallet_import_format}
|
||
|
* @module bitmessage/wif
|
||
|
*/
|
||
|
|
||
|
"use strict";
|
||
|
|
||
|
var assert = require("assert");
|
||
|
var bufferEqual = require("buffer-equal");
|
||
|
var bs58 = require("bs58");
|
||
|
var bmcrypto = require("./crypto");
|
||
|
|
||
|
// Compute the WIF checksum for the given data.
|
||
|
function getchecksum(data) {
|
||
|
return bmcrypto.sha256(bmcrypto.sha256(data)).slice(0, 4);
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Decode WIF encoded private key.
|
||
|
* @param {string} wif - Encoded key
|
||
|
* @return {Buffer} Private key.
|
||
|
*/
|
||
|
exports.decode = function(wif) {
|
||
|
var bytes = bs58.decode(wif);
|
||
|
assert(bytes[0] === 0x80, "Bad WIF");
|
||
|
var data = new Buffer(bytes.slice(0, -4));
|
||
|
var checksum = new Buffer(bytes.slice(-4));
|
||
|
assert(bufferEqual(checksum, getchecksum(data)), "Bad checkum");
|
||
|
return data.slice(1);
|
||
|
};
|
||
|
|
||
|
/**
|
||
|
* Convert private key to a WIF.
|
||
|
* @param {Buffer} privateKey - A private key to encode
|
||
|
* @return {string} Encoded private key.
|
||
|
*/
|
||
|
exports.encode = function(privateKey) {
|
||
|
var data = Buffer.concat([new Buffer([0x80]), privateKey]);
|
||
|
var checksum = getchecksum(data);
|
||
|
var bytes = Buffer.concat([data, checksum]);
|
||
|
return bs58.encode(bytes);
|
||
|
};
|
||
|
</code></pre>
|
||
|
</article>
|
||
|
</section>
|
||
|
|
||
|
|
||
|
|
||
|
|
||
|
</div>
|
||
|
|
||
|
<nav>
|
||
|
<h2><a href="index.html">Home</a></h2><h3>Modules</h3><ul><li><a href="module-bitmessage.html">bitmessage</a></li><li><a href="module-bitmessage_address.html">bitmessage/address</a></li><li><a href="module-bitmessage_crypto.html">bitmessage/crypto</a></li><li><a href="module-bitmessage_messages.html">bitmessage/messages</a></li><li><a href="module-bitmessage_objects.html">bitmessage/objects</a></li><li><a href="module-bitmessage_pow.html">bitmessage/pow</a></li><li><a href="module-bitmessage_structs.html">bitmessage/structs</a></li><li><a href="module-bitmessage_wif.html">bitmessage/wif</a></li></ul><h3>Classes</h3><ul><li><a href="module-bitmessage_address.Address.html">Address</a></li></ul><h3>Namespaces</h3><ul><li><a href="module-bitmessage_structs.var_int.html">var_int</a></li><li><a href="module-bitmessage_structs.var_int_list.html">var_int_list</a></li><li><a href="module-bitmessage_structs.var_str.html">var_str</a></li></ul>
|
||
|
</nav>
|
||
|
|
||
|
<br class="clear">
|
||
|
|
||
|
<footer>
|
||
|
Documentation generated by <a href="https://github.com/jsdoc3/jsdoc">JSDoc 3.3.0-alpha13</a> on Sat Jan 03 2015 19:33:03 GMT+0300 (MSK)
|
||
|
</footer>
|
||
|
|
||
|
<script> prettyPrint(); </script>
|
||
|
<script src="scripts/linenumber.js"> </script>
|
||
|
</body>
|
||
|
</html>
|