Browse Source

avoid badFoo flags, avoid _.each() bug, use for-loop to check each output

activeAddress
Gregg Zigler 10 years ago
parent
commit
fa2170a5f3
  1. 27
      lib/server.js

27
lib/server.js

@ -878,32 +878,23 @@ WalletService.prototype.createTx = function(opts, cb) {
var outputs = (opts.type == Model.TxProposal.Types.MULTIPLEOUTPUTS) var outputs = (opts.type == Model.TxProposal.Types.MULTIPLEOUTPUTS)
? opts.outputs ? opts.outputs
: [ { toAddress: opts.toAddress, amount: opts.amount } ]; : [ { toAddress: opts.toAddress, amount: opts.amount } ];
var badAddress = false, // _.each(outputs) fails here, causes multiple callbacks to be executed
badNetwork = false, // use for-loop instead
badAmount = false, for (var i = 0; i < outputs.length; i++) {
badDust = false; var output = outputs[i];
_.each(outputs, function(output) { var toAddress = {};
var toAddress;
try { try {
toAddress = new Bitcore.Address(output.toAddress); toAddress = new Bitcore.Address(output.toAddress);
} catch (ex) { } catch (ex) {
badAddress = true; return cb(new ClientError('INVALIDADDRESS', 'Invalid address'));
} }
if (toAddress.network != wallet.getNetworkName()) if (toAddress.network != wallet.getNetworkName())
badNetwork = true;
if (output.amount <= 0)
badAmount = true;
if (output.amount < Bitcore.Transaction.DUST_AMOUNT)
badDust = true;
});
if (badAddress)
return cb(new ClientError('INVALIDADDRESS', 'Invalid address'));
if (badNetwork)
return cb(new ClientError('INVALIDADDRESS', 'Incorrect address network')); return cb(new ClientError('INVALIDADDRESS', 'Incorrect address network'));
if (badAmount) if (output.amount <= 0)
return cb(new ClientError('Invalid amount')); return cb(new ClientError('Invalid amount'));
if (badDust) if (output.amount < Bitcore.Transaction.DUST_AMOUNT)
return cb(new ClientError('DUSTAMOUNT', 'Amount below dust threshold')); return cb(new ClientError('DUSTAMOUNT', 'Amount below dust threshold'));
}
var changeAddress = wallet.createAddress(true); var changeAddress = wallet.createAddress(true);

Loading…
Cancel
Save