1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-11-23 02:10:12 +01:00

recent-blocks - dont listen for block when on infura providers

This commit is contained in:
frankiebee 2019-02-08 11:24:55 -10:00
parent fbc2d5880f
commit 7e64a578a4
3 changed files with 30 additions and 4 deletions

View File

@ -158,7 +158,7 @@ module.exports = class NetworkController extends EventEmitter {
_switchNetwork (opts) { _switchNetwork (opts) {
this.setNetworkState('loading') this.setNetworkState('loading')
this._configureProvider(opts) this._configureProvider(opts)
this.emit('networkDidChange') this.emit('networkDidChange', opts.type)
} }
_configureProvider (opts) { _configureProvider (opts) {

View File

@ -3,6 +3,14 @@ const extend = require('xtend')
const EthQuery = require('eth-query') const EthQuery = require('eth-query')
const log = require('loglevel') const log = require('loglevel')
const pify = require('pify') const pify = require('pify')
const {
ROPSTEN,
RINKEBY,
KOVAN,
MAINNET,
} = require('./network/enums')
const INFURA_PROVIDER_TYPES = [ROPSTEN, RINKEBY, KOVAN, MAINNET]
class RecentBlocksController { class RecentBlocksController {
@ -24,7 +32,7 @@ class RecentBlocksController {
* *
*/ */
constructor (opts = {}) { constructor (opts = {}) {
const { blockTracker, provider } = opts const { blockTracker, provider, networkController } = opts
this.blockTracker = blockTracker this.blockTracker = blockTracker
this.ethQuery = new EthQuery(provider) this.ethQuery = new EthQuery(provider)
this.historyLength = opts.historyLength || 40 this.historyLength = opts.historyLength || 40
@ -33,13 +41,30 @@ class RecentBlocksController {
recentBlocks: [], recentBlocks: [],
}, opts.initState) }, opts.initState)
this.store = new ObservableStore(initState) this.store = new ObservableStore(initState)
const blockListner = async (newBlockNumberHex) => {
this.blockTracker.on('latest', async (newBlockNumberHex) => {
try { try {
await this.processBlock(newBlockNumberHex) await this.processBlock(newBlockNumberHex)
} catch (err) { } catch (err) {
log.error(err) log.error(err)
} }
}
let isListeng = false
const { type } = networkController.getProviderConfig()
if (!INFURA_PROVIDER_TYPES.includes(type) && type !== 'loading') {
this.blockTracker.on('latest', blockListner)
isListeng = true
}
networkController.on('networkDidChange', (newType) => {
if (INFURA_PROVIDER_TYPES.includes(newType) && isListeng) {
this.blockTracker.removeListener('latest', blockListner)
} else if (
!INFURA_PROVIDER_TYPES.includes(type) &&
type !== 'loading' &&
!isListeng
) {
this.blockTracker.on('latest', blockListner)
}
}) })
this.backfill() this.backfill()
} }

View File

@ -126,6 +126,7 @@ module.exports = class MetamaskController extends EventEmitter {
this.recentBlocksController = new RecentBlocksController({ this.recentBlocksController = new RecentBlocksController({
blockTracker: this.blockTracker, blockTracker: this.blockTracker,
provider: this.provider, provider: this.provider,
networkController: this.networkController,
}) })
// account tracker watches balances, nonces, and any code at their address. // account tracker watches balances, nonces, and any code at their address.