2014-03-05 11:11:16 -08:00
|
|
|
var coinUtil = require('./util/util');
|
|
|
|
var timeUtil = require('./util/time');
|
2014-03-13 10:31:02 -07:00
|
|
|
var Key = require('./Key');
|
2014-03-05 11:11:16 -08:00
|
|
|
var SIN = require('./SIN');
|
2013-08-16 19:22:50 -07:00
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
function SINKey(cfg) {
|
|
|
|
if (typeof cfg != 'object')
|
|
|
|
cfg = {};
|
2014-01-16 01:21:35 -08:00
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
this.created = cfg.created;
|
|
|
|
this.privKey = cfg.privKey;
|
|
|
|
};
|
2014-01-16 01:21:35 -08:00
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
SINKey.prototype.generate = function() {
|
2014-03-13 10:31:02 -07:00
|
|
|
this.privKey = Key.generateSync();
|
2014-03-05 11:11:16 -08:00
|
|
|
this.created = timeUtil.curtime();
|
|
|
|
};
|
2014-01-16 01:21:35 -08:00
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
SINKey.prototype.pubkeyHash = function() {
|
|
|
|
return coinUtil.sha256ripe160(this.privKey.public);
|
|
|
|
};
|
2014-01-16 01:21:35 -08:00
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
SINKey.prototype.storeObj = function() {
|
|
|
|
var pubKey = this.privKey.public.toString('hex');
|
|
|
|
var pubKeyHash = this.pubkeyHash();
|
|
|
|
var sin = new SIN(SIN.SIN_EPHEM, pubKeyHash);
|
|
|
|
var obj = {
|
|
|
|
created: this.created,
|
|
|
|
priv: this.privKey.private.toString('hex'),
|
|
|
|
pub: pubKey,
|
|
|
|
sin: sin.toString(),
|
2014-01-16 01:21:35 -08:00
|
|
|
};
|
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
return obj;
|
2013-08-16 19:22:50 -07:00
|
|
|
};
|
|
|
|
|
2014-03-05 11:11:16 -08:00
|
|
|
module.exports = require('soop')(SINKey);
|