Browse Source

Merge pull request #182 from isocolsky/scanning

save wallet inside lock
activeAddress
Matias Alejo Garcia 10 years ago
parent
commit
28969564bc
  1. 2
      lib/model/wallet.js
  2. 25
      lib/server.js
  3. 4
      test/integration/server.js

2
lib/model/wallet.js

@ -25,7 +25,6 @@ Wallet.create = function(opts) {
x.m = opts.m; x.m = opts.m;
x.n = opts.n; x.n = opts.n;
x.status = 'pending'; x.status = 'pending';
x.scanning = false;
x.publicKeyRing = []; x.publicKeyRing = [];
x.addressIndex = 0; x.addressIndex = 0;
x.copayers = []; x.copayers = [];
@ -46,7 +45,6 @@ Wallet.fromObj = function(obj) {
x.m = obj.m; x.m = obj.m;
x.n = obj.n; x.n = obj.n;
x.status = obj.status; x.status = obj.status;
x.scanning = obj.scanning;
x.publicKeyRing = obj.publicKeyRing; x.publicKeyRing = obj.publicKeyRing;
x.copayers = _.map(obj.copayers, function(copayer) { x.copayers = _.map(obj.copayers, function(copayer) {
return Copayer.fromObj(copayer); return Copayer.fromObj(copayer);

25
lib/server.js

@ -1202,6 +1202,10 @@ WalletService.prototype.scan = function(opts, cb) {
if (err) return cb(err); if (err) return cb(err);
if (!wallet.isComplete()) return cb(new ClientError('Wallet is not complete')); if (!wallet.isComplete()) return cb(new ClientError('Wallet is not complete'));
wallet.scanStatus = 'running';
self.storage.storeWallet(wallet, function(err) {
if (err) return cb(err);
var derivators = []; var derivators = [];
_.each([false, true], function(isChange) { _.each([false, true], function(isChange) {
derivators.push(_.bind(wallet.createAddress, wallet, isChange)); derivators.push(_.bind(wallet.createAddress, wallet, isChange));
@ -1217,7 +1221,13 @@ WalletService.prototype.scan = function(opts, cb) {
if (err) return next(err); if (err) return next(err);
self.storage.storeAddressAndWallet(wallet, addresses, next); self.storage.storeAddressAndWallet(wallet, addresses, next);
}); });
}, cb); }, function(err) {
wallet.scanStatus = err ? 'error' : 'success';
self.storage.storeWallet(wallet, function() {
return cb(err);
});
});
});
}); });
}); });
}; };
@ -1232,26 +1242,16 @@ WalletService.prototype.startScan = function(opts, cb) {
var self = this; var self = this;
function scanFinished(err) { function scanFinished(err) {
var result = err ? 'error' : 'success';
var data = { var data = {
result: result, result: err ? 'error' : 'success',
}; };
if (err) data.error = err; if (err) data.error = err;
self.getWallet({}, function(err, wallet) {
wallet.scanStatus = result;
self.storage.storeWallet(wallet, function() {
self._notify('ScanFinished', data, true); self._notify('ScanFinished', data, true);
});
});
}; };
self.getWallet({}, function(err, wallet) { self.getWallet({}, function(err, wallet) {
if (err) return cb(err); if (err) return cb(err);
if (!wallet.isComplete()) return cb(new ClientError('Wallet is not complete')); if (!wallet.isComplete()) return cb(new ClientError('Wallet is not complete'));
wallet.scanStatus = 'running';
self.storage.storeWallet(wallet, function(err) {
if (err) return cb(err);
setTimeout(function() { setTimeout(function() {
self.scan(opts, scanFinished); self.scan(opts, scanFinished);
@ -1261,7 +1261,6 @@ WalletService.prototype.startScan = function(opts, cb) {
started: true started: true
}); });
}); });
});
}; };

4
test/integration/server.js

@ -2689,10 +2689,6 @@ describe('Wallet service', function() {
}); });
server.startScan({}, function(err) { server.startScan({}, function(err) {
should.not.exist(err); should.not.exist(err);
server.getWallet({}, function(err, wallet) {
should.exist(wallet.scanStatus);
wallet.scanStatus.should.equal('running');
});
}); });
}); });
it('should set scan status error when unable to reach blockchain', function(done) { it('should set scan status error when unable to reach blockchain', function(done) {

Loading…
Cancel
Save