aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/lib/nonce-tracker.js
diff options
context:
space:
mode:
authorDan Finlay <dan@danfinlay.com>2017-07-27 06:32:19 +0800
committerDan Finlay <dan@danfinlay.com>2017-07-27 06:32:19 +0800
commitf147b928b238af3e1f0abdcc4d38b5281f67aba4 (patch)
tree758d3cb81d42af5bde01be3dbedfb24536cc1a80 /app/scripts/lib/nonce-tracker.js
parent3d8ebf2265d167923f3b913bac3b9cc4d37fa052 (diff)
parent520cda0058849778461cf6b9682980068149c120 (diff)
downloadtangerine-wallet-browser-f147b928b238af3e1f0abdcc4d38b5281f67aba4.tar.gz
tangerine-wallet-browser-f147b928b238af3e1f0abdcc4d38b5281f67aba4.tar.zst
tangerine-wallet-browser-f147b928b238af3e1f0abdcc4d38b5281f67aba4.zip
Merge branch 'master' into i1805-LiveBlacklistUpdating
Diffstat (limited to 'app/scripts/lib/nonce-tracker.js')
-rw-r--r--app/scripts/lib/nonce-tracker.js17
1 files changed, 12 insertions, 5 deletions
diff --git a/app/scripts/lib/nonce-tracker.js b/app/scripts/lib/nonce-tracker.js
index c0746bd87..8328e81ec 100644
--- a/app/scripts/lib/nonce-tracker.js
+++ b/app/scripts/lib/nonce-tracker.js
@@ -4,8 +4,8 @@ const Mutex = require('await-semaphore').Mutex
class NonceTracker {
- constructor ({ blockTracker, provider, getPendingTransactions }) {
- this.blockTracker = blockTracker
+ constructor ({ provider, getPendingTransactions }) {
+ this.provider = provider
this.ethQuery = new EthQuery(provider)
this.getPendingTransactions = getPendingTransactions
this.lockMap = {}
@@ -39,16 +39,17 @@ class NonceTracker {
assert(Number.isInteger(nextNonce), `nonce-tracker - nextNonce is not an integer - got: (${typeof nextNonce}) "${nextNonce}"`)
// collect the numbers used to calculate the nonce for debugging
const blockNumber = currentBlock.number
- const nonceDetails = { blockNumber, baseCount, pendingCount }
+ const nonceDetails = { blockNumber, baseCount, baseCountHex, pendingCount }
// return nonce and release cb
return { nextNonce, nonceDetails, releaseLock }
}
async _getCurrentBlock () {
- const currentBlock = this.blockTracker.getCurrentBlock()
+ const blockTracker = this._getBlockTracker()
+ const currentBlock = blockTracker.getCurrentBlock()
if (currentBlock) return currentBlock
return await Promise((reject, resolve) => {
- this.blockTracker.once('latest', resolve)
+ blockTracker.once('latest', resolve)
})
}
@@ -82,6 +83,12 @@ class NonceTracker {
return mutex
}
+ // this is a hotfix for the fact that the blockTracker will
+ // change when the network changes
+ _getBlockTracker () {
+ return this.provider._blockTracker
+ }
+
}
module.exports = NonceTracker