From 4c7f8d3a53f739abdfc354177986f024a11f2bb4 Mon Sep 17 00:00:00 2001 From: Ivan Socolsky Date: Tue, 17 Feb 2015 20:58:04 -0300 Subject: [PATCH] refactor Wallet object creation --- lib/model/wallet.js | 76 +++++++++++++++++++++++++-------------------- lib/server.js | 2 +- 2 files changed, 43 insertions(+), 35 deletions(-) diff --git a/lib/model/wallet.js b/lib/model/wallet.js index 84c9cfa..634312a 100644 --- a/lib/model/wallet.js +++ b/lib/model/wallet.js @@ -12,22 +12,50 @@ var WalletUtils = require('../walletutils'); var VERSION = '1.0.0'; -function Wallet(opts) { - opts = opts || {}; +function Wallet() { this.version = VERSION; - this.createdOn = Math.floor(Date.now() / 1000); - this.id = Uuid.v4(); - this.name = opts.name; - this.m = opts.m; - this.n = opts.n; - this.status = 'pending'; - this.publicKeyRing = []; - this.addressIndex = 0; - this.copayers = []; - this.pubKey = opts.pubKey; - this.network = opts.network; - this.addressManager = new AddressManager(); +}; + +Wallet.create = function(opts) { + opts = opts || {}; + + var x = new Wallet(); + + x.createdOn = Math.floor(Date.now() / 1000); + x.id = Uuid.v4(); + x.name = opts.name; + x.m = opts.m; + x.n = opts.n; + x.status = 'pending'; + x.publicKeyRing = []; + x.addressIndex = 0; + x.copayers = []; + x.pubKey = opts.pubKey; + x.network = opts.network; + x.addressManager = new AddressManager(); + + return x; +}; + +Wallet.fromObj = function(obj) { + var x = new Wallet(); + + x.createdOn = obj.createdOn; + x.id = obj.id; + x.name = obj.name; + x.m = obj.m; + x.n = obj.n; + x.status = obj.status; + x.publicKeyRing = obj.publicKeyRing; + x.copayers = _.map(obj.copayers, function(copayer) { + return Copayer.fromObj(copayer); + }); + x.pubKey = obj.pubKey; + x.network = obj.network; + x.addressManager = AddressManager.fromObj(obj.addressManager); + + return x; }; /* For compressed keys, m*73 + n*34 <= 496 */ @@ -60,26 +88,6 @@ Wallet.verifyCopayerLimits = function(m, n) { return (n >= 1 && n <= 12) && (m >= 1 && m <= Wallet.COPAYER_PAIR_LIMITS[n]); }; -Wallet.fromObj = function(obj) { - var x = new Wallet(); - - x.createdOn = obj.createdOn; - x.id = obj.id; - x.name = obj.name; - x.m = obj.m; - x.n = obj.n; - x.status = obj.status; - x.publicKeyRing = obj.publicKeyRing; - x.copayers = _.map(obj.copayers, function(copayer) { - return Copayer.fromObj(copayer); - }); - x.pubKey = obj.pubKey; - x.network = obj.network; - x.addressManager = AddressManager.fromObj(obj.addressManager); - - return x; -}; - Wallet.prototype.isShared = function() { return this.n > 1; }; diff --git a/lib/server.js b/lib/server.js index 38d4a23..18d61f1 100644 --- a/lib/server.js +++ b/lib/server.js @@ -114,7 +114,7 @@ CopayServer.prototype.createWallet = function(opts, cb) { return cb(e.toString()); }; - var wallet = new Wallet({ + var wallet = Wallet.create({ name: opts.name, m: opts.m, n: opts.n,