diff options
author | kumavis <kumavis@users.noreply.github.com> | 2017-08-29 02:29:47 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-08-29 02:29:47 +0800 |
commit | 76de053b0b0a40f98fa88de950fdaae33dbbf666 (patch) | |
tree | f6e00b78db4f9c7ba0e5968c6df1637825d3db5e /app/scripts/lib/pending-tx-tracker.js | |
parent | 6bff55ba2ae36a1d005b052940d91e6e43262359 (diff) | |
parent | 34b327caf07cd395229806cedecdeb770c034562 (diff) | |
download | tangerine-wallet-browser-76de053b0b0a40f98fa88de950fdaae33dbbf666.tar tangerine-wallet-browser-76de053b0b0a40f98fa88de950fdaae33dbbf666.tar.gz tangerine-wallet-browser-76de053b0b0a40f98fa88de950fdaae33dbbf666.tar.bz2 tangerine-wallet-browser-76de053b0b0a40f98fa88de950fdaae33dbbf666.tar.lz tangerine-wallet-browser-76de053b0b0a40f98fa88de950fdaae33dbbf666.tar.xz tangerine-wallet-browser-76de053b0b0a40f98fa88de950fdaae33dbbf666.tar.zst tangerine-wallet-browser-76de053b0b0a40f98fa88de950fdaae33dbbf666.zip |
Merge branch 'master' into inpage-provider-fixes
Diffstat (limited to 'app/scripts/lib/pending-tx-tracker.js')
-rw-r--r-- | app/scripts/lib/pending-tx-tracker.js | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/app/scripts/lib/pending-tx-tracker.js b/app/scripts/lib/pending-tx-tracker.js index 19720db3f..b90851b58 100644 --- a/app/scripts/lib/pending-tx-tracker.js +++ b/app/scripts/lib/pending-tx-tracker.js @@ -1,6 +1,7 @@ const EventEmitter = require('events') const EthQuery = require('ethjs-query') const sufficientBalance = require('./util').sufficientBalance +const RETRY_LIMIT = 3500 // Retry 3500 blocks, or about 1 day. /* Utility class for tracking the transactions as they @@ -28,6 +29,7 @@ module.exports = class PendingTransactionTracker extends EventEmitter { this.getBalance = config.getBalance this.getPendingTransactions = config.getPendingTransactions this.publishTransaction = config.publishTransaction + this.giveUpOnTransaction = config.giveUpOnTransaction } // checks if a signed tx is in a block and @@ -100,6 +102,10 @@ module.exports = class PendingTransactionTracker extends EventEmitter { if (balance === undefined) return if (!('retryCount' in txMeta)) txMeta.retryCount = 0 + if (txMeta.retryCount > RETRY_LIMIT) { + return this.giveUpOnTransaction(txMeta.id) + } + // if the value of the transaction is greater then the balance, fail. if (!sufficientBalance(txMeta.txParams, balance)) { const insufficientFundsError = new Error('Insufficient balance during rebroadcast.') @@ -160,4 +166,4 @@ module.exports = class PendingTransactionTracker extends EventEmitter { } nonceGlobalLock.releaseLock() } -}
\ No newline at end of file +} |