diff options
author | Kevin Serrano <kevgagser@gmail.com> | 2017-09-27 06:17:24 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-09-27 06:17:24 +0800 |
commit | 6ca519e97c4c282023ab6b7788715ff8d7ec8189 (patch) | |
tree | c1f884dcd4f7e4af7d2846bb937aa531d1352400 /app/scripts/lib | |
parent | b1daa5ae260be0aa91516bde0cbdb8820099587b (diff) | |
parent | 651098c70d21edbca98a96ef2a8800d164035638 (diff) | |
download | tangerine-wallet-browser-6ca519e97c4c282023ab6b7788715ff8d7ec8189.tar tangerine-wallet-browser-6ca519e97c4c282023ab6b7788715ff8d7ec8189.tar.gz tangerine-wallet-browser-6ca519e97c4c282023ab6b7788715ff8d7ec8189.tar.bz2 tangerine-wallet-browser-6ca519e97c4c282023ab6b7788715ff8d7ec8189.tar.lz tangerine-wallet-browser-6ca519e97c4c282023ab6b7788715ff8d7ec8189.tar.xz tangerine-wallet-browser-6ca519e97c4c282023ab6b7788715ff8d7ec8189.tar.zst tangerine-wallet-browser-6ca519e97c4c282023ab6b7788715ff8d7ec8189.zip |
Merge pull request #2183 from MetaMask/Fix2094
Fix 2094 related issues
Diffstat (limited to 'app/scripts/lib')
-rw-r--r-- | app/scripts/lib/account-tracker.js | 32 |
1 files changed, 20 insertions, 12 deletions
diff --git a/app/scripts/lib/account-tracker.js b/app/scripts/lib/account-tracker.js index bf949597b..e2892b1ce 100644 --- a/app/scripts/lib/account-tracker.js +++ b/app/scripts/lib/account-tracker.js @@ -10,15 +10,21 @@ const async = require('async') const EthQuery = require('eth-query') const ObservableStore = require('obs-store') +const EventEmitter = require('events').EventEmitter function noop () {} -class EthereumStore extends ObservableStore { +class AccountTracker extends EventEmitter { constructor (opts = {}) { - super({ + super() + + const initState = { accounts: {}, - }) + currentBlockGasLimit: '', + } + this.store = new ObservableStore(initState) + this._provider = opts.provider this._query = new EthQuery(this._provider) this._blockTracker = opts.blockTracker @@ -33,17 +39,17 @@ class EthereumStore extends ObservableStore { // addAccount (address) { - const accounts = this.getState().accounts + const accounts = this.store.getState().accounts accounts[address] = {} - this.updateState({ accounts }) + this.store.updateState({ accounts }) if (!this._currentBlockNumber) return this._updateAccount(address) } removeAccount (address) { - const accounts = this.getState().accounts + const accounts = this.store.getState().accounts delete accounts[address] - this.updateState({ accounts }) + this.store.updateState({ accounts }) } // @@ -54,29 +60,31 @@ class EthereumStore extends ObservableStore { const blockNumber = '0x' + block.number.toString('hex') this._currentBlockNumber = blockNumber + this.store.updateState({ currentBlockGasLimit: `0x${block.gasLimit.toString('hex')}` }) + async.parallel([ this._updateAccounts.bind(this), ], (err) => { if (err) return console.error(err) - this.emit('block', this.getState()) + this.emit('block', this.store.getState()) }) } _updateAccounts (cb = noop) { - const accounts = this.getState().accounts + const accounts = this.store.getState().accounts const addresses = Object.keys(accounts) async.each(addresses, this._updateAccount.bind(this), cb) } _updateAccount (address, cb = noop) { - const accounts = this.getState().accounts this._getAccount(address, (err, result) => { if (err) return cb(err) result.address = address + const accounts = this.store.getState().accounts // only populate if the entry is still present if (accounts[address]) { accounts[address] = result - this.updateState({ accounts }) + this.store.updateState({ accounts }) } cb(null, result) }) @@ -93,4 +101,4 @@ class EthereumStore extends ObservableStore { } -module.exports = EthereumStore +module.exports = AccountTracker |