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.
33 lines
747 B
33 lines
747 B
var Bn = require('./bn');
|
|
var Privkey = require('./privkey');
|
|
var Point = require('./point');
|
|
var Pubkey = require('./pubkey');
|
|
var Key = require('./key');
|
|
var Hash = require('./hash');
|
|
|
|
function KDF() {
|
|
};
|
|
|
|
KDF.buf2key = function(buf) {
|
|
return KDF.sha256hmac2key(buf);
|
|
};
|
|
|
|
KDF.sha256hmac2key = function(buf) {
|
|
var privkey = KDF.sha256hmac2privkey(buf);
|
|
var key = new Key({privkey: privkey});
|
|
key.privkey2pubkey();
|
|
return key;
|
|
};
|
|
|
|
KDF.sha256hmac2privkey = function(buf) {
|
|
var bn;
|
|
var concat = new Buffer([]);
|
|
do {
|
|
var hash = Hash.sha256hmac(buf, concat);
|
|
var bn = Bn.fromBuffer(hash);
|
|
concat = Buffer.concat([concat, new Buffer(0)]);
|
|
} while(!bn.lt(Point.getN()));
|
|
return new Privkey(bn);
|
|
};
|
|
|
|
module.exports = KDF;
|
|
|