2013-07-10 17:07:14 -07:00
|
|
|
|
2014-07-10 07:46:44 -07:00
|
|
|
var VersionedData = require('../util/VersionedData');
|
2014-07-10 11:55:32 -07:00
|
|
|
var EncodedData = require('../util/EncodedData');
|
2014-07-10 07:46:44 -07:00
|
|
|
var networks = require('../networks');
|
2014-07-10 11:55:32 -07:00
|
|
|
var util = require('util');
|
2013-07-10 17:07:14 -07:00
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
//compressed is true if public key is compressed; false otherwise
|
|
|
|
function PrivateKey(version, buf, compressed) {
|
|
|
|
PrivateKey.super(this, arguments);
|
|
|
|
if (compressed !== undefined)
|
|
|
|
this.compressed(compressed);
|
|
|
|
};
|
2014-07-10 11:55:32 -07:00
|
|
|
util.inherits(PrivateKey, VersionedData);
|
|
|
|
EncodedData.applyEncodingsTo(PrivateKey);
|
2013-07-10 17:07:14 -07:00
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
PrivateKey.prototype.validate = function() {
|
|
|
|
this.doAsBinary(function() {
|
|
|
|
PrivateKey.super(this, 'validate', arguments);
|
2014-06-23 10:57:02 -07:00
|
|
|
if (this.data.length < 32 || (this.data.length > 1 + 32 && !this.compressed()) || (this.data.length == 1 + 32 + 1 && this.data[1 + 32 + 1 - 1] != 1) || this.data.length > 1 + 32 + 1)
|
2014-03-05 11:11:16 -08:00
|
|
|
throw new Error('invalid data length');
|
|
|
|
});
|
2014-03-19 15:00:45 -07:00
|
|
|
if (typeof this.network() === 'undefined') throw new Error('invalid network');
|
2014-03-05 11:11:16 -08:00
|
|
|
};
|
2013-07-10 17:07:14 -07:00
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
// get or set the payload data (as a Buffer object)
|
|
|
|
// overloaded from VersionedData
|
|
|
|
PrivateKey.prototype.payload = function(data) {
|
2014-06-23 10:57:02 -07:00
|
|
|
if (data) {
|
|
|
|
this.doAsBinary(function() {
|
|
|
|
data.copy(this.data, 1);
|
|
|
|
});
|
2014-03-05 11:11:16 -08:00
|
|
|
return data;
|
|
|
|
}
|
2014-06-23 10:57:02 -07:00
|
|
|
var buf = this.as('binary');
|
|
|
|
if (buf.length == 1 + 32 + 1)
|
|
|
|
return buf.slice(1, 1 + 32);
|
|
|
|
else if (buf.length == 1 + 32)
|
2014-03-05 11:11:16 -08:00
|
|
|
return buf.slice(1);
|
|
|
|
};
|
2013-12-30 19:15:01 -08:00
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
// get or set whether the corresponding public key is compressed
|
|
|
|
PrivateKey.prototype.compressed = function(compressed) {
|
|
|
|
if (compressed !== undefined) {
|
2014-06-23 10:57:02 -07:00
|
|
|
this.doAsBinary(function() {
|
|
|
|
var len = 1 + 32 + 1;
|
2014-03-05 11:11:16 -08:00
|
|
|
if (compressed) {
|
2014-06-23 10:57:02 -07:00
|
|
|
var data = new Buffer(len);
|
2014-03-05 11:11:16 -08:00
|
|
|
this.data.copy(data);
|
2014-06-23 10:57:02 -07:00
|
|
|
this.data = data;
|
|
|
|
this.data[len - 1] = 1;
|
2014-03-05 11:11:16 -08:00
|
|
|
} else {
|
2014-06-23 10:57:02 -07:00
|
|
|
this.data = this.data.slice(0, len - 1);
|
2014-03-05 11:11:16 -08:00
|
|
|
}
|
|
|
|
});
|
2014-06-23 10:57:02 -07:00
|
|
|
} else {
|
|
|
|
var len = 1 + 32 + 1;
|
|
|
|
var data = this.as('binary');
|
|
|
|
if (data.length == len && data[len - 1] == 1)
|
2014-03-05 11:11:16 -08:00
|
|
|
return true;
|
2014-06-23 10:57:02 -07:00
|
|
|
else if (data.length == len - 1)
|
2014-03-05 11:11:16 -08:00
|
|
|
return false;
|
|
|
|
else
|
|
|
|
throw new Error('invalid private key');
|
|
|
|
}
|
2013-07-10 17:07:14 -07:00
|
|
|
};
|
2014-03-05 11:11:16 -08:00
|
|
|
|
2014-03-15 14:49:48 -07:00
|
|
|
PrivateKey.prototype.network = function() {
|
|
|
|
var version = this.version();
|
|
|
|
|
|
|
|
var livenet = networks.livenet;
|
|
|
|
var testnet = networks.testnet;
|
|
|
|
|
|
|
|
var answer;
|
2014-04-07 14:30:49 -07:00
|
|
|
if (version === livenet.privKeyVersion)
|
2014-03-15 14:49:48 -07:00
|
|
|
answer = livenet;
|
2014-04-07 14:30:49 -07:00
|
|
|
else if (version === testnet.privKeyVersion)
|
2014-03-15 14:49:48 -07:00
|
|
|
answer = testnet;
|
|
|
|
|
|
|
|
return answer;
|
|
|
|
};
|
|
|
|
|
2014-07-10 12:08:42 -07:00
|
|
|
module.exports = (PrivateKey);
|