|
@ -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); |
|
|
|
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}; |
|
|
}; |
|
|