You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
80 lines
2.3 KiB
80 lines
2.3 KiB
var bn = require('./bn');
|
|
var point = require('./point');
|
|
var constants = require('./constants');
|
|
var base58check = require('./base58check');
|
|
|
|
var Privkey = function(n, network, compressed) {
|
|
if (typeof n !== 'undefined')
|
|
this.setNumber(n);
|
|
if (typeof network !== 'undefined')
|
|
this.setNetwork(network);
|
|
if (typeof compressed !== 'undefined')
|
|
this.setCompressed(compressed);
|
|
};
|
|
|
|
Privkey.prototype.setNumber = function(n) {
|
|
if (!n.lt(point.getN()))
|
|
throw new Error('privkey: Number must be less than N');
|
|
this.n = n;
|
|
};
|
|
|
|
Privkey.prototype.setNetwork = function(network) {
|
|
if (typeof constants[network] === undefined)
|
|
throw new Error('privkey: Must specify the network ("mainnet" or "testnet")');
|
|
this.network = network;
|
|
};
|
|
|
|
Privkey.prototype.setCompressed = function(compressed) {
|
|
if (typeof compressed !== 'boolean')
|
|
throw new Error('privkey: Must specify whether the corresponding public key is compressed or not (true or false)');
|
|
this.compressed = compressed;
|
|
};
|
|
|
|
Privkey.prototype.toWIF = function() {
|
|
var network = this.network;
|
|
var compressed = this.compressed;
|
|
|
|
if (typeof this.network === 'undefined')
|
|
network = 'mainnet';
|
|
if (typeof this.compressed === 'undefined')
|
|
compressed = true;
|
|
|
|
var privbuf = this.n.toBuffer({size: 32});
|
|
var buf;
|
|
if (compressed)
|
|
buf = Buffer.concat([new Buffer([constants[network].privkey]), this.n.toBuffer({size: 32}), new Buffer([0x01])]);
|
|
else
|
|
buf = Buffer.concat([new Buffer([constants[network].privkey]), this.n.toBuffer({size: 32})]);
|
|
|
|
return base58check.encode(buf);
|
|
};
|
|
|
|
Privkey.prototype.fromWIF = function(str) {
|
|
var buf = base58check.decode(str);
|
|
|
|
if (buf.length === 1 + 32 + 1 && buf[1 + 32 + 1 - 1] == 1)
|
|
this.compressed = true;
|
|
else if (buf.length === 1 + 32)
|
|
this.compressed = false;
|
|
else
|
|
throw new Error('privkey: Length of buffer must be 33 (uncompressed) or 34 (compressed)');
|
|
|
|
if (buf[0] === constants.mainnet.privkey)
|
|
this.network = 'mainnet';
|
|
else if (buf[0] === constants.testnet.privkey)
|
|
this.network = 'testnet';
|
|
else
|
|
throw new Error('privkey: Invalid network');
|
|
|
|
this.n = bn.fromBuffer(buf.slice(1, 32 + 1));
|
|
};
|
|
|
|
Privkey.prototype.toString = function() {
|
|
return this.toWIF();
|
|
};
|
|
|
|
Privkey.prototype.fromString = function(str) {
|
|
this.fromWIF(str);
|
|
};
|
|
|
|
module.exports = Privkey;
|
|
|