Browse Source

"hashbuf" indicates type is a buffer

patch-2
Ryan X. Charles 11 years ago
parent
commit
3e82c57e19
  1. 26
      lib/ecdsa.js

26
lib/ecdsa.js

@ -6,10 +6,10 @@ var Privkey = require('./privkey');
var Pubkey = require('./pubkey'); var Pubkey = require('./pubkey');
var Random = require('./random'); var Random = require('./random');
var ECDSA = function ECDSA(hash, key, sig, k) { var ECDSA = function ECDSA(hashbuf, key, sig, k) {
if (!(this instanceof ECDSA)) if (!(this instanceof ECDSA))
return new ECDSA(hash, key, sig, k); return new ECDSA(hashbuf, key, sig, k);
this.hash = hash; this.hashbuf = hashbuf;
this.key = key; this.key = key;
this.sig = sig; this.sig = sig;
this.k = k; this.k = k;
@ -36,8 +36,8 @@ ECDSA.prototype.calci = function() {
ECDSA.prototype.fromString = function(str) { ECDSA.prototype.fromString = function(str) {
var obj = JSON.parse(str); var obj = JSON.parse(str);
if (obj.hash) if (obj.hashbuf)
this.hash = new Buffer(obj.hash, 'hex'); this.hashbuf = new Buffer(obj.hashbuf, 'hex');
if (obj.key) if (obj.key)
this.key = Key().fromString(obj.key); this.key = Key().fromString(obj.key);
if (obj.sig) if (obj.sig)
@ -62,7 +62,7 @@ ECDSA.prototype.sig2pubkey = function() {
if (!(i === 0 || i === 1 || i === 2 || i === 3)) if (!(i === 0 || i === 1 || i === 2 || i === 3))
throw new Error('signature: i must be equal to 0, 1, 2, or 3'); throw new Error('signature: i must be equal to 0, 1, 2, or 3');
var e = BN().fromBuffer(this.hash); var e = BN().fromBuffer(this.hashbuf);
var r = this.sig.r; var r = this.sig.r;
var s = this.sig.s; var s = this.sig.s;
@ -103,7 +103,7 @@ ECDSA.prototype.sig2pubkey = function() {
}; };
ECDSA.prototype.sigError = function() { ECDSA.prototype.sigError = function() {
if (!Buffer.isBuffer(this.hash) || this.hash.length !== 32) if (!Buffer.isBuffer(this.hashbuf) || this.hashbuf.length !== 32)
return 'Invalid hash'; return 'Invalid hash';
try { try {
@ -118,7 +118,7 @@ ECDSA.prototype.sigError = function() {
|| !(s.gt(0) && s.lt(Point.getN()))) || !(s.gt(0) && s.lt(Point.getN())))
return 'r and s not in range'; return 'r and s not in range';
var e = BN().fromBuffer(this.hash); var e = BN().fromBuffer(this.hashbuf);
var n = Point.getN(); var n = Point.getN();
var sinv = s.invm(n); var sinv = s.invm(n);
var u1 = sinv.mul(e).mod(n); var u1 = sinv.mul(e).mod(n);
@ -135,17 +135,17 @@ ECDSA.prototype.sigError = function() {
}; };
ECDSA.prototype.sign = function() { ECDSA.prototype.sign = function() {
var hash = this.hash; var hashbuf = this.hashbuf;
var privkey = this.key.privkey; var privkey = this.key.privkey;
var k = this.k; var k = this.k;
var d = privkey.bn; var d = privkey.bn;
if (!hash || !privkey || !k || !d) if (!hashbuf || !privkey || !k || !d)
throw new Error('ecdsa: invalid parameters'); throw new Error('ecdsa: invalid parameters');
var N = Point.getN(); var N = Point.getN();
var G = Point.getG(); var G = Point.getG();
var e = BN().fromBuffer(hash); var e = BN().fromBuffer(hashbuf);
do { do {
var Q = G.mul(k); var Q = G.mul(k);
@ -164,8 +164,8 @@ ECDSA.prototype.signRandomK = function() {
ECDSA.prototype.toString = function() { ECDSA.prototype.toString = function() {
var obj = {}; var obj = {};
if (this.hash) if (this.hashbuf)
obj.hash = this.hash.toString('hex'); obj.hashbuf = this.hashbuf.toString('hex');
if (this.key) if (this.key)
obj.key = this.key.toString(); obj.key = this.key.toString();
if (this.sig) if (this.sig)

Loading…
Cancel
Save