Browse Source

store after each branch derivation to save progress

activeAddress
Ivan Socolsky 10 years ago
parent
commit
2874f6745b
  1. 17
      lib/server.js

17
lib/server.js

@ -1143,8 +1143,6 @@ WalletService.prototype.scan = function(opts, cb) {
opts = opts || {}; opts = opts || {};
var allAddresses = [];
function deriveAddresses(size, derivator, cb) { function deriveAddresses(size, derivator, cb) {
async.mapSeries(_.range(size), function(i, next) { async.mapSeries(_.range(size), function(i, next) {
setTimeout(function() { setTimeout(function() {
@ -1160,6 +1158,7 @@ WalletService.prototype.scan = function(opts, cb) {
function scanBranch(derivator, cb) { function scanBranch(derivator, cb) {
var activity = true; var activity = true;
var allAddresses = [];
async.whilst(function() { async.whilst(function() {
return activity; return activity;
}, function(next) { }, function(next) {
@ -1172,7 +1171,9 @@ WalletService.prototype.scan = function(opts, cb) {
next(); next();
}); });
}); });
}, cb); }, function(err) {
return cb(err, _.flatten(allAddresses));
});
}; };
@ -1193,13 +1194,11 @@ WalletService.prototype.scan = function(opts, cb) {
}); });
async.eachSeries(derivators, function(derivator, next) { async.eachSeries(derivators, function(derivator, next) {
scanBranch(derivator, next); scanBranch(derivator, function(err, addresses) {
}, function(err) { if (err) return next(err);
if (err) return cb(err); self.storage.storeAddressAndWallet(wallet, addresses, next);
self.storage.storeAddressAndWallet(wallet, _.flatten(allAddresses), function(err) {
return cb(err);
}); });
}); }, cb);
}); });
}); });

Loading…
Cancel
Save