Browse Source

Merge pull request #569 from isocolsky/ref/addr-creation

Move address creation check outside of locked section
activeAddress
Matias Alejo Garcia 9 years ago
committed by GitHub
parent
commit
f4c4f4a5d1
  1. 36
      lib/server.js

36
lib/server.js

@ -775,20 +775,15 @@ WalletService.prototype.createAddress = function(opts, cb) {
opts = opts || {}; opts = opts || {};
function createNewAddress(wallet, cb) { function createNewAddress(wallet, cb) {
self._canCreateAddress(opts.ignoreMaxGap, function(err, canCreate) { var address = wallet.createAddress(false);
if (err) return cb(err);
if (!canCreate) return cb(Errors.MAIN_ADDRESS_GAP_REACHED);
var address = wallet.createAddress(false);
self.storage.storeAddressAndWallet(wallet, address, function(err) { self.storage.storeAddressAndWallet(wallet, address, function(err) {
if (err) return cb(err); if (err) return cb(err);
self._notify('NewAddress', { self._notify('NewAddress', {
address: address.address, address: address.address,
}, function() { }, function() {
return cb(null, address); return cb(null, address);
});
}); });
}); });
}; };
@ -801,13 +796,18 @@ WalletService.prototype.createAddress = function(opts, cb) {
}); });
}; };
self._runLocked(cb, function(cb) { self._canCreateAddress(opts.ignoreMaxGap, function(err, canCreate) {
self.getWallet({}, function(err, wallet) { if (err) return cb(err);
if (err) return cb(err); if (!canCreate) return cb(Errors.MAIN_ADDRESS_GAP_REACHED);
if (!wallet.isComplete()) return cb(Errors.WALLET_NOT_COMPLETE);
var createFn = wallet.singleAddress ? getFirstAddress : createNewAddress; self._runLocked(cb, function(cb) {
return createFn(wallet, cb); self.getWallet({}, function(err, wallet) {
if (err) return cb(err);
if (!wallet.isComplete()) return cb(Errors.WALLET_NOT_COMPLETE);
var createFn = wallet.singleAddress ? getFirstAddress : createNewAddress;
return createFn(wallet, cb);
});
}); });
}); });
}; };

Loading…
Cancel
Save