From 98cfd646e7a96adcbd8b0fb0bad26aac240087d1 Mon Sep 17 00:00:00 2001 From: Yemel Jardi Date: Fri, 2 Jan 2015 18:01:21 -0300 Subject: [PATCH] Allow creating a new random testnet HDPrivate key --- lib/hdprivatekey.js | 34 ++++++++++++++++------------------ test/hdprivatekey.js | 6 ++++++ 2 files changed, 22 insertions(+), 18 deletions(-) diff --git a/lib/hdprivatekey.js b/lib/hdprivatekey.js index ad53e1c..c3f85a5 100644 --- a/lib/hdprivatekey.js +++ b/lib/hdprivatekey.js @@ -41,24 +41,24 @@ function HDPrivateKey(arg) { if (!(this instanceof HDPrivateKey)) { return new HDPrivateKey(arg); } - if (arg) { - if (_.isString(arg) || BufferUtil.isBuffer(arg)) { - if (HDPrivateKey.isValidSerialized(arg)) { - this._buildFromSerialized(arg); - } else if (JSUtil.isValidJSON(arg)) { - this._buildFromJSON(arg); - } else { - throw HDPrivateKey.getSerializedError(arg); - } + if (!arg) { + return this._generateRandomly(); + } + + if (Network.get(arg)) { + return this._generateRandomly(arg); + } else if (_.isString(arg) || BufferUtil.isBuffer(arg)) { + if (HDPrivateKey.isValidSerialized(arg)) { + this._buildFromSerialized(arg); + } else if (JSUtil.isValidJSON(arg)) { + this._buildFromJSON(arg); } else { - if (_.isObject(arg)) { - this._buildFromObject(arg); - } else { - throw new hdErrors.UnrecognizedArgument(arg); - } + throw HDPrivateKey.getSerializedError(arg); } + } else if (_.isObject(arg)) { + this._buildFromObject(arg); } else { - return this._generateRandomly(); + throw new hdErrors.UnrecognizedArgument(arg); } } @@ -266,7 +266,6 @@ HDPrivateKey.prototype._generateRandomly = function(network) { */ HDPrivateKey.fromSeed = function(hexa, network) { /* jshint maxcomplexity: 8 */ - if (JSUtil.isHexaString(hexa)) { hexa = BufferUtil.hexToBuffer(hexa); } @@ -282,7 +281,7 @@ HDPrivateKey.fromSeed = function(hexa, network) { var hash = Hash.sha512hmac(hexa, new buffer.Buffer('Bitcoin seed')); return new HDPrivateKey({ - network: Network.get(network) || Network.livenet, + network: Network.get(network) || Network.defaultNetwork, depth: 0, parentFingerPrint: 0, childIndex: 0, @@ -441,7 +440,6 @@ HDPrivateKey.prototype.toJSON = function toJSON() { HDPrivateKey.DefaultDepth = 0; HDPrivateKey.DefaultFingerprint = 0; HDPrivateKey.DefaultChildIndex = 0; -HDPrivateKey.DefaultNetwork = Network.livenet; HDPrivateKey.Hardened = 0x80000000; HDPrivateKey.RootElementAlias = ['m', 'M', 'm\'', 'M\'']; diff --git a/test/hdprivatekey.js b/test/hdprivatekey.js index 6ba3b4d..d8779c7 100644 --- a/test/hdprivatekey.js +++ b/test/hdprivatekey.js @@ -50,6 +50,12 @@ describe('HDPrivate key interface', function() { should.exist(new HDPrivateKey().xprivkey); }); + it('should make a new private key from random for testnet', function() { + var key = new HDPrivateKey('testnet'); + should.exist(key.xprivkey); + key.network.name.should.equal('testnet'); + }); + it('should not be able to change read-only properties', function() { var hdkey = new HDPrivateKey(); expect(function() {