|
@ -1,6 +1,5 @@ |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (process.versions) { |
|
|
if (process.versions) { |
|
|
// c++ native version
|
|
|
// c++ native version
|
|
|
module.exports = require('bindings')('KeyModule'); |
|
|
module.exports = require('bindings')('KeyModule'); |
|
@ -8,6 +7,18 @@ if (process.versions) { |
|
|
// pure js version
|
|
|
// pure js version
|
|
|
var ECKey = require('./browser/bitcoinjs-lib.js').ECKey; |
|
|
var ECKey = require('./browser/bitcoinjs-lib.js').ECKey; |
|
|
var buffertools = require('buffertools'); |
|
|
var buffertools = require('buffertools'); |
|
|
|
|
|
|
|
|
|
|
|
var bufferToArray = function(buffer) { |
|
|
|
|
|
var ret = []; |
|
|
|
|
|
|
|
|
|
|
|
var l = buffer.length; |
|
|
|
|
|
for(var i =0; i<l; i++) { |
|
|
|
|
|
ret.push(buffer.readUInt8(i)); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return ret; |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
var kSpec = function(compressed, public, private) { |
|
|
var kSpec = function(compressed, public, private) { |
|
|
this.compressed = compressed; |
|
|
this.compressed = compressed; |
|
|
this.public = public; |
|
|
this.public = public; |
|
@ -18,19 +29,54 @@ if (process.versions) { |
|
|
var eck = new ECKey(); |
|
|
var eck = new ECKey(); |
|
|
eck.setCompressed(true); |
|
|
eck.setCompressed(true); |
|
|
var pub = eck.getPub(); |
|
|
var pub = eck.getPub(); |
|
|
|
|
|
var ret = new kSpec(true, new Buffer(pub), new Buffer(eck.priv.toByteArrayUnsigned())); |
|
|
var ret = new this(true, new Buffer(pub), new Buffer(eck.priv.toByteArrayUnsigned())); |
|
|
|
|
|
ret.eck = eck; |
|
|
ret.eck = eck; |
|
|
return ret; |
|
|
return ret; |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
kSpec.prototype.regenerateSync = function() { |
|
|
kSpec.prototype.regenerateSync = function() { |
|
|
this.eck = new ECKey(buffertools.toHex(this.private)); |
|
|
var eck = new ECKey(buffertools.toHex(this.private)); |
|
|
this.eck.setCompressed(true); |
|
|
eck.setCompressed(this.compressed); |
|
|
this.public = new Buffer(this.eck.getPub()); |
|
|
this.public = new Buffer(eck.getPub()); |
|
|
return this; |
|
|
return this; |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
kSpec.prototype.signSync = function(hash) { |
|
|
|
|
|
if (!this.private) { |
|
|
|
|
|
throw new Error('Key does not have a private key set'); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
if (!Buffer.isBuffer(hash) || hash.length !== 32) { |
|
|
|
|
|
throw new Error('Arg should be a 32 bytes hash'); |
|
|
|
|
|
} |
|
|
|
|
|
var eck = new ECKey(buffertools.toHex(this.private)); |
|
|
|
|
|
eck.setCompressed(this.compressed); |
|
|
|
|
|
var signature = eck.sign(hash); |
|
|
|
|
|
// return it as a buffer to keep c++ compatibility
|
|
|
|
|
|
return new Buffer(signature); |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
kSpec.prototype.verifySignatureSync = function(hash, sig) { |
|
|
|
|
|
var self = this; |
|
|
|
|
|
|
|
|
|
|
|
if (!Buffer.isBuffer(hash) || hash.length !== 32) { |
|
|
|
|
|
throw new Error('Arg 1 should be a 32 bytes hash buffer'); |
|
|
|
|
|
} |
|
|
|
|
|
if (!Buffer.isBuffer(sig)) { |
|
|
|
|
|
throw new Error('Arg 2 should be a buffer'); |
|
|
|
|
|
} |
|
|
|
|
|
if (!self.public) { |
|
|
|
|
|
throw new Error('Key does not have a public key set'); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
var eck = new ECKey(); |
|
|
|
|
|
eck.setPub( bufferToArray(self.public)); |
|
|
|
|
|
eck.setCompressed(self.compressed); |
|
|
|
|
|
var sigA = bufferToArray(sig); |
|
|
|
|
|
return eck.verify(hash,sigA); |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
module.exports = { |
|
|
module.exports = { |
|
|
Key: kSpec |
|
|
Key: kSpec |
|
|
}; |
|
|
}; |
|
|