From 15c55e560af0145130632e66a9f0fa0dba49d5d3 Mon Sep 17 00:00:00 2001 From: Matias Alejo Garcia Date: Wed, 23 Jul 2014 19:49:42 -0300 Subject: [PATCH] support uncompressed pub keys also --- browser/bundle.js | 18 +++++++++++++++++- lib/SIN.js | 4 ++-- test/mocha.opts | 1 - 3 files changed, 19 insertions(+), 4 deletions(-) delete mode 100644 test/mocha.opts diff --git a/browser/bundle.js b/browser/bundle.js index 4067855f3..c27d1bafa 100644 --- a/browser/bundle.js +++ b/browser/bundle.js @@ -3005,9 +3005,11 @@ module.exports = RpcClient; module.exports=require('tBM27q'); },{}],"tBM27q":[function(require,module,exports){ (function (Buffer){ +'use strict'; var VersionedData = require('../util/VersionedData'); var EncodedData = require('../util/EncodedData'); var util = require('util'); +var coinUtil = require('../util'); function SIN(type, payload) { if (typeof type != 'number') { @@ -3069,10 +3071,24 @@ SIN.prototype.validate = function() { if (this.data.length != 22) throw new Error('invalid data length'); }); }; + + +// create a SIN from a public key +SIN.fromPubKey = function(pubKey, type) { + if (!type) + type = SIN.SIN_EPHEM; + + if (!Buffer.isBuffer(pubKey) || (pubKey.length !== 33 && pubKey.length != 65)) + throw new Error('Invalid public key'); + + var hash = coinUtil.sha256ripe160(pubKey); + return new SIN(hash, type); +}; + module.exports = SIN; }).call(this,require("buffer").Buffer) -},{"../util/EncodedData":"eLfUFE","../util/VersionedData":"QLzNQg","buffer":91,"util":123}],"EyghZQ":[function(require,module,exports){ +},{"../util":181,"../util/EncodedData":"eLfUFE","../util/VersionedData":"QLzNQg","buffer":91,"util":123}],"EyghZQ":[function(require,module,exports){ var coinUtil = require('../util'); var timeUtil = require('../util/time'); var Key = require('./Key'); diff --git a/lib/SIN.js b/lib/SIN.js index 53889f0b1..a14cfe5de 100644 --- a/lib/SIN.js +++ b/lib/SIN.js @@ -71,8 +71,8 @@ SIN.fromPubKey = function(pubKey, type) { if (!type) type = SIN.SIN_EPHEM; - if (!Buffer.isBuffer(pubKey) || pubKey.length !== 33) - throw new Error('Invalid public key' + pubKey.length); + if (!Buffer.isBuffer(pubKey) || (pubKey.length !== 33 && pubKey.length != 65)) + throw new Error('Invalid public key'); var hash = coinUtil.sha256ripe160(pubKey); return new SIN(hash, type); diff --git a/test/mocha.opts b/test/mocha.opts deleted file mode 100644 index e2bfcc5ac..000000000 --- a/test/mocha.opts +++ /dev/null @@ -1 +0,0 @@ ---ui qunit