Browse Source

include i in sig obj + cosmetic improvements

patch-2
Ryan X. Charles 11 years ago
parent
commit
65c3545cb6
  1. 24
      lib/signature.js

24
lib/signature.js

@ -1,26 +1,31 @@
var bn = require('./bn'); var BN = require('./bn');
var Point = require('./point');
var Pubkey = require('./pubkey');
var Signature = function Signature(r, s) { var Signature = function Signature(r, s, i) {
if (!(this instanceof Signature)) if (!(this instanceof Signature))
return new Signature(r, s); return new Signature(r, s, i);
this.r = r; this.r = r;
this.s = s; this.s = s;
this.i = i; //public key recovery parameter in range [0, 3]
}; };
Signature.prototype.fromCompressed = function(buf) { Signature.prototype.fromCompressed = function(buf) {
var b1 = buf.slice(0, 1)[0]; var i = buf.slice(0, 1)[0];
var b2 = buf.slice(1, 33); var b2 = buf.slice(1, 33);
var b3 = buf.slice(33, 65); var b3 = buf.slice(33, 65);
if (!(b1 === 0 || b1 === 1 || b1 === 2 || b1 === 3)) if (!(i === 0 || i === 1 || i === 2 || i === 3))
throw new Error('signature: i must be 0, 1, 2, or 3'); throw new Error('signature: i must be 0, 1, 2, or 3');
if (b2.length !== 32) if (b2.length !== 32)
throw new Error('signature: r must be 32 bytes'); throw new Error('signature: r must be 32 bytes');
if (b3.length !== 32) if (b3.length !== 32)
throw new Error('signature: s must be 32 bytes'); throw new Error('signature: s must be 32 bytes');
this.r = bn.fromBuffer(b2); this.i = i;
this.s = bn.fromBuffer(b3); this.r = BN().fromBuffer(b2);
this.s = BN().fromBuffer(b3);
}; };
Signature.prototype.fromDER = function(buf) { Signature.prototype.fromDER = function(buf) {
@ -53,7 +58,7 @@ Signature.parseDER = function(buf) {
var rlength = buf[2 + 1]; var rlength = buf[2 + 1];
var rbuf = buf.slice(2 + 2, 2 + 2 + rlength); var rbuf = buf.slice(2 + 2, 2 + 2 + rlength);
var r = bn.fromBuffer(rbuf); var r = BN().fromBuffer(rbuf);
var rneg = buf[2 + 1 + 1] === 0x00 ? true : false; var rneg = buf[2 + 1 + 1] === 0x00 ? true : false;
if (rlength !== rbuf.length) if (rlength !== rbuf.length)
throw new Error('signature: Length of r incorrect'); throw new Error('signature: Length of r incorrect');
@ -64,7 +69,7 @@ Signature.parseDER = function(buf) {
var slength = buf[2 + 2 + rlength + 1]; var slength = buf[2 + 2 + rlength + 1];
var sbuf = buf.slice(2 + 2 + rlength + 2, 2 + 2 + rlength + 2 + slength); var sbuf = buf.slice(2 + 2 + rlength + 2, 2 + 2 + rlength + 2 + slength);
var s = bn.fromBuffer(sbuf); var s = BN().fromBuffer(sbuf);
var sneg = buf[2 + 2 + rlength + 2 + 2] === 0x00 ? true : false; var sneg = buf[2 + 2 + rlength + 2 + 2] === 0x00 ? true : false;
if (slength !== sbuf.length) if (slength !== sbuf.length)
throw new Error('signature: Length of s incorrect'); throw new Error('signature: Length of s incorrect');
@ -92,6 +97,7 @@ Signature.parseDER = function(buf) {
}; };
Signature.prototype.toCompressed = function(i) { Signature.prototype.toCompressed = function(i) {
i = typeof i === 'number' ? i : this.i;
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');

Loading…
Cancel
Save