aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/controllers/network
diff options
context:
space:
mode:
authorkumavis <aaron@kumavis.me>2018-06-13 02:12:32 +0800
committerkumavis <aaron@kumavis.me>2018-06-13 02:12:32 +0800
commit6a2649a90f5147b505ebc33b97a75d2e90956fca (patch)
treebd671fca8ba693010e0b54b769bea0fcffec865e /app/scripts/controllers/network
parentc86f93588965291837ae905632ba9a8855f496f2 (diff)
downloadtangerine-wallet-browser-6a2649a90f5147b505ebc33b97a75d2e90956fca.tar
tangerine-wallet-browser-6a2649a90f5147b505ebc33b97a75d2e90956fca.tar.gz
tangerine-wallet-browser-6a2649a90f5147b505ebc33b97a75d2e90956fca.tar.bz2
tangerine-wallet-browser-6a2649a90f5147b505ebc33b97a75d2e90956fca.tar.lz
tangerine-wallet-browser-6a2649a90f5147b505ebc33b97a75d2e90956fca.tar.xz
tangerine-wallet-browser-6a2649a90f5147b505ebc33b97a75d2e90956fca.tar.zst
tangerine-wallet-browser-6a2649a90f5147b505ebc33b97a75d2e90956fca.zip
network - import createBlockTrackerInspectorMiddleware and rearrange cache middleware order
Diffstat (limited to 'app/scripts/controllers/network')
-rw-r--r--app/scripts/controllers/network/createInfuraClient.js15
-rw-r--r--app/scripts/controllers/network/createJsonRpcClient.js13
-rw-r--r--app/scripts/controllers/network/createLocalhostClient.js13
3 files changed, 4 insertions, 37 deletions
diff --git a/app/scripts/controllers/network/createInfuraClient.js b/app/scripts/controllers/network/createInfuraClient.js
index 663a2595a..6976e6022 100644
--- a/app/scripts/controllers/network/createInfuraClient.js
+++ b/app/scripts/controllers/network/createInfuraClient.js
@@ -3,6 +3,7 @@ const createAsyncMiddleware = require('json-rpc-engine/src/createAsyncMiddleware
const createBlockReEmitMiddleware = require('eth-json-rpc-middleware/block-reemit')
const createBlockCacheMiddleware = require('eth-json-rpc-middleware/block-cache')
const createInflightMiddleware = require('eth-json-rpc-middleware/inflight-cache')
+const createBlockTrackerInspectorMiddleware = require('eth-json-rpc-middleware/block-tracker-inspector')
const providerFromMiddleware = require('eth-json-rpc-middleware/providerFromMiddleware')
const createInfuraMiddleware = require('eth-json-rpc-infura')
const BlockTracker = require('eth-block-tracker')
@@ -15,23 +16,11 @@ function createInfuraClient ({ network }) {
const blockTracker = new BlockTracker({ provider: blockProvider })
const networkMiddleware = mergeMiddleware([
- createBlockReEmitMiddleware({ blockTracker, provider: blockProvider }),
createBlockCacheMiddleware({ blockTracker }),
createInflightMiddleware(),
+ createBlockReEmitMiddleware({ blockTracker, provider: blockProvider }),
createBlockTrackerInspectorMiddleware({ blockTracker }),
infuraMiddleware,
])
return { networkMiddleware, blockTracker }
}
-
-// inspect if response contains a block ref higher than our latest block
-const futureBlockRefRequests = ['eth_getTransactionByHash', 'eth_getTransactionReceipt']
-function createBlockTrackerInspectorMiddleware ({ blockTracker }) {
- return createAsyncMiddleware(async (req, res, next) => {
- if (!futureBlockRefRequests.includes(req.method)) return next()
- await next()
- const blockNumber = Number.parseInt(res.result.blockNumber, 16)
- const currentBlockNumber = Number.parseInt(blockTracker.getCurrentBlock(), 16)
- if (blockNumber > currentBlockNumber) await blockTracker.checkForLatestBlock()
- })
-}
diff --git a/app/scripts/controllers/network/createJsonRpcClient.js b/app/scripts/controllers/network/createJsonRpcClient.js
index d712ed135..b9aca0bcf 100644
--- a/app/scripts/controllers/network/createJsonRpcClient.js
+++ b/app/scripts/controllers/network/createJsonRpcClient.js
@@ -4,6 +4,7 @@ const createFetchMiddleware = require('eth-json-rpc-middleware/fetch')
const createBlockRefMiddleware = require('eth-json-rpc-middleware/block-ref')
const createBlockCacheMiddleware = require('eth-json-rpc-middleware/block-cache')
const createInflightMiddleware = require('eth-json-rpc-middleware/inflight-cache')
+const createBlockTrackerInspectorMiddleware = require('eth-json-rpc-middleware/block-tracker-inspector')
const providerFromMiddleware = require('eth-json-rpc-middleware/providerFromMiddleware')
const BlockTracker = require('eth-block-tracker')
@@ -23,15 +24,3 @@ function createJsonRpcClient ({ rpcUrl }) {
])
return { networkMiddleware, blockTracker }
}
-
-// inspect if response contains a block ref higher than our latest block
-const futureBlockRefRequests = ['eth_getTransactionByHash', 'eth_getTransactionReceipt']
-function createBlockTrackerInspectorMiddleware ({ blockTracker }) {
- return createAsyncMiddleware(async (req, res, next) => {
- if (!futureBlockRefRequests.includes(req.method)) return next()
- await next()
- const blockNumber = Number.parseInt(res.result.blockNumber, 16)
- const currentBlockNumber = Number.parseInt(blockTracker.getCurrentBlock(), 16)
- if (blockNumber > currentBlockNumber) await blockTracker.checkForLatestBlock()
- })
-}
diff --git a/app/scripts/controllers/network/createLocalhostClient.js b/app/scripts/controllers/network/createLocalhostClient.js
index 990dc6a95..ae42ac48b 100644
--- a/app/scripts/controllers/network/createLocalhostClient.js
+++ b/app/scripts/controllers/network/createLocalhostClient.js
@@ -2,6 +2,7 @@ const mergeMiddleware = require('json-rpc-engine/src/mergeMiddleware')
const createAsyncMiddleware = require('json-rpc-engine/src/createAsyncMiddleware')
const createFetchMiddleware = require('eth-json-rpc-middleware/fetch')
const createBlockRefMiddleware = require('eth-json-rpc-middleware/block-ref')
+const createBlockTrackerInspectorMiddleware = require('eth-json-rpc-middleware/block-tracker-inspector')
const providerFromMiddleware = require('eth-json-rpc-middleware/providerFromMiddleware')
const BlockTracker = require('eth-block-tracker')
@@ -19,15 +20,3 @@ function createLocalhostClient () {
])
return { networkMiddleware, blockTracker }
}
-
-// inspect if response contains a block ref higher than our latest block
-const futureBlockRefRequests = ['eth_getTransactionByHash', 'eth_getTransactionReceipt']
-function createBlockTrackerInspectorMiddleware ({ blockTracker }) {
- return createAsyncMiddleware(async (req, res, next) => {
- if (!futureBlockRefRequests.includes(req.method)) return next()
- await next()
- const blockNumber = Number.parseInt(res.result.blockNumber, 16)
- const currentBlockNumber = Number.parseInt(blockTracker.getCurrentBlock(), 16)
- if (blockNumber > currentBlockNumber) await blockTracker.checkForLatestBlock()
- })
-}