From 1d4cf86a560c3e711f8f631c3ca2bffca4050a2d Mon Sep 17 00:00:00 2001 From: Ivan Socolsky Date: Wed, 12 Apr 2017 10:49:28 -0300 Subject: [PATCH] detect low fee txs in tx history --- lib/server.js | 29 ++++++++++++++++++++++++++--- test/integration/server.js | 15 ++++++++++++++- 2 files changed, 40 insertions(+), 4 deletions(-) diff --git a/lib/server.js b/lib/server.js index c11acea..7a0d471 100644 --- a/lib/server.js +++ b/lib/server.js @@ -2590,6 +2590,7 @@ WalletService.prototype._normalizeTxHistory = function(txs) { confirmations: tx.confirmations, blockheight: tx.blockheight, fees: parseInt((tx.fees * 1e8).toFixed(0)), + size: tx.size, time: t, inputs: inputs, outputs: outputs, @@ -2736,6 +2737,10 @@ WalletService.prototype.getTxHistory = function(opts, cb) { confirmations: tx.confirmations, }; + if (_.isNumber(tx.size) && tx.size > 0) { + newTx.feePerKb = +(tx.fees * 1000 / tx.size).toFixed(); + } + if (opts.includeExtendedInfo) { newTx.inputs = _.map(inputs, function(input) { return _.pick(input, 'address', 'amount', 'isMine'); @@ -2907,10 +2912,28 @@ WalletService.prototype.getTxHistory = function(opts, cb) { var finalTxs = decorate(wallet, res.txs.items, addresses, res.txps, res.notes); - if (res.txs.fromCache) - log.debug("History from cache for:", self.walletId, from, to); + self.getFeeLevels({ + network: wallet.network + }, function(err, levels) { + if (err) { + log.warn('Could not fetch fee levels', err); + } else { + var level = _.find(levels, { + level: 'superEconomy' + }); + if (level) { + var minFeePerKb = level.feePerKb; + _.each(finalTxs, function(tx) { + tx.lowFees = tx.feePerKb < minFeePerKb; + }); + } + } - return cb(null, finalTxs, !!res.txs.fromCache); + if (res.txs.fromCache) + log.debug("History from cache for:", self.walletId, from, to); + + return cb(null, finalTxs, !!res.txs.fromCache); + }); }); }); }); diff --git a/test/integration/server.js b/test/integration/server.js index 0d824bc..c372f5c 100644 --- a/test/integration/server.js +++ b/test/integration/server.js @@ -4139,6 +4139,9 @@ describe('Wallet service', function() { }], }]; helpers.stubHistory(txs); + helpers.stubFeeLevels({ + 24: 10000, + }); server.editTxNote({ txid: '123', body: 'just some note' @@ -4341,6 +4344,9 @@ describe('Wallet service', function() { }], }]; helpers.stubHistory(txs); + helpers.stubFeeLevels({ + 24: 10000, + }); server.getTxHistory({}, function(err, txs) { should.not.exist(err); should.exist(txs); @@ -5984,6 +5990,9 @@ describe('Wallet service', function() { helpers.createAddresses(server, wallet, 1, 1, function(main, change) { mainAddresses = main; changeAddresses = change; + helpers.stubFeeLevels({ + 24: 10000, + }); done(); }); }); @@ -6003,7 +6012,6 @@ describe('Wallet service', function() { done(); }); }); - it('should get tx history for incoming txs', function(done) { server._normalizeTxHistory = sinon.stub().returnsArg(0); var txs = [{ @@ -6019,6 +6027,7 @@ describe('Wallet service', function() { address: mainAddresses[0].address, amount: 200, }], + size: 500, }]; helpers.stubHistory(txs); server.getTxHistory({}, function(err, txs) { @@ -6030,6 +6039,7 @@ describe('Wallet service', function() { tx.amount.should.equal(200); tx.fees.should.equal(100); tx.time.should.equal(20); + tx.lowFees.should.be.true; done(); }); }); @@ -6310,6 +6320,9 @@ describe('Wallet service', function() { helpers.createAddresses(server, wallet, 1, 1, function(main, change) { mainAddresses = main; changeAddresses = change; + helpers.stubFeeLevels({ + 24: 10000, + }); done(); }); });