diff options
author | frankiebee <frankie.diamond@gmail.com> | 2017-09-27 02:52:57 +0800 |
---|---|---|
committer | frankiebee <frankie.diamond@gmail.com> | 2017-09-27 04:38:27 +0800 |
commit | b654eb9b1f37cd3757e4614bb048884ab89d2986 (patch) | |
tree | feef7673d9fc25863471a75e0598e3bc5fe548ec /app/scripts/controllers | |
parent | 87fc44c45a5bb511fe60b2c3fe7e7c78f5f6584f (diff) | |
download | tangerine-wallet-browser-b654eb9b1f37cd3757e4614bb048884ab89d2986.tar tangerine-wallet-browser-b654eb9b1f37cd3757e4614bb048884ab89d2986.tar.gz tangerine-wallet-browser-b654eb9b1f37cd3757e4614bb048884ab89d2986.tar.bz2 tangerine-wallet-browser-b654eb9b1f37cd3757e4614bb048884ab89d2986.tar.lz tangerine-wallet-browser-b654eb9b1f37cd3757e4614bb048884ab89d2986.tar.xz tangerine-wallet-browser-b654eb9b1f37cd3757e4614bb048884ab89d2986.tar.zst tangerine-wallet-browser-b654eb9b1f37cd3757e4614bb048884ab89d2986.zip |
wrap block tracker in events proxy
Diffstat (limited to 'app/scripts/controllers')
-rw-r--r-- | app/scripts/controllers/network.js | 22 |
1 files changed, 8 insertions, 14 deletions
diff --git a/app/scripts/controllers/network.js b/app/scripts/controllers/network.js index 0a3e5e26b..6daedbb67 100644 --- a/app/scripts/controllers/network.js +++ b/app/scripts/controllers/network.js @@ -4,6 +4,7 @@ const ObservableStore = require('obs-store') const ComposedStore = require('obs-store/lib/composed') const extend = require('xtend') const EthQuery = require('eth-query') +const createEventEmitterProxy = require('../lib/events-proxy.js') const RPC_ADDRESS_LIST = require('../config.js').network const DEFAULT_RPC = RPC_ADDRESS_LIST['rinkeby'] @@ -31,16 +32,8 @@ module.exports = class NetworkController extends EventEmitter { initializeProvider (opts, providerContructor = MetaMaskProvider) { this.providerInit = opts this._provider = providerContructor(opts) - this._proxy = new Proxy(this._provider, { - get: (obj, name) => { - if (name === 'on') return this._on.bind(this) - return this._provider[name] - }, - set: (obj, name, value) => { - this._provider[name] = value - return value - }, - }) + this._proxy = createEventEmitterProxy(this._provider) + this.provider._blockTracker = createEventEmitterProxy(this._provider._blockTracker) this.provider.on('block', this._logBlock.bind(this)) this.provider.on('error', this.verifyNetwork.bind(this)) this.ethQuery = new EthQuery(this.provider) @@ -55,11 +48,12 @@ module.exports = class NetworkController extends EventEmitter { this._provider.removeAllListeners() this._provider.stop() - this.provider = MetaMaskProvider(newInit) + this._provider = MetaMaskProvider(newInit) // apply the listners created by other controllers - Object.keys(this._providerListeners).forEach((key) => { - this._providerListeners[key].forEach((handler) => this._provider.addListener(key, handler)) - }) + const blockTrackerHandlers = this.provider._blockTracker.proxyEventHandlers + this.provider.setTarget(this._provider) + + this.provider._blockTracker = createEventEmitterProxy(this._provider._blockTracker, blockTrackerHandlers) this.emit('networkDidChange') } |