diff options
author | Dan Finlay <542863+danfinlay@users.noreply.github.com> | 2018-08-18 01:43:15 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-08-18 01:43:15 +0800 |
commit | 755369e4e48e71b04b4dbb9cb702353c09b66e28 (patch) | |
tree | e699c4305c1ec807e584bd4290f2c445027f843b /app/scripts/metamask-controller.js | |
parent | 59ba2d2785b1742a7b1b4d6455a4662d9cd685c7 (diff) | |
parent | df799d7fd6c49888e3eb659adbfca18030b85975 (diff) | |
download | tangerine-wallet-browser-755369e4e48e71b04b4dbb9cb702353c09b66e28.tar tangerine-wallet-browser-755369e4e48e71b04b4dbb9cb702353c09b66e28.tar.gz tangerine-wallet-browser-755369e4e48e71b04b4dbb9cb702353c09b66e28.tar.bz2 tangerine-wallet-browser-755369e4e48e71b04b4dbb9cb702353c09b66e28.tar.lz tangerine-wallet-browser-755369e4e48e71b04b4dbb9cb702353c09b66e28.tar.xz tangerine-wallet-browser-755369e4e48e71b04b4dbb9cb702353c09b66e28.tar.zst tangerine-wallet-browser-755369e4e48e71b04b4dbb9cb702353c09b66e28.zip |
Merge pull request #4898 from dmvt/multi-account-restore
Restore multiple consecutive accounts with balances.
Diffstat (limited to 'app/scripts/metamask-controller.js')
-rw-r--r-- | app/scripts/metamask-controller.js | 49 |
1 files changed, 47 insertions, 2 deletions
diff --git a/app/scripts/metamask-controller.js b/app/scripts/metamask-controller.js index 81bb080ab..166be720f 100644 --- a/app/scripts/metamask-controller.js +++ b/app/scripts/metamask-controller.js @@ -48,6 +48,7 @@ const percentile = require('percentile') const seedPhraseVerifier = require('./lib/seed-phrase-verifier') const log = require('loglevel') const TrezorKeyring = require('eth-trezor-keyring') +const EthQuery = require('eth-query') module.exports = class MetamaskController extends EventEmitter { @@ -475,12 +476,32 @@ module.exports = class MetamaskController extends EventEmitter { async createNewVaultAndRestore (password, seed) { const releaseLock = await this.createVaultMutex.acquire() try { + let accounts, lastBalance + + const keyringController = this.keyringController + // clear known identities this.preferencesController.setAddresses([]) // create new vault - const vault = await this.keyringController.createNewVaultAndRestore(password, seed) + const vault = await keyringController.createNewVaultAndRestore(password, seed) + + const ethQuery = new EthQuery(this.provider) + accounts = await keyringController.getAccounts() + lastBalance = await this.getBalance(accounts[accounts.length - 1], ethQuery) + + const primaryKeyring = keyringController.getKeyringsByType('HD Key Tree')[0] + if (!primaryKeyring) { + throw new Error('MetamaskController - No HD Key Tree found') + } + + // seek out the first zero balance + while (lastBalance !== '0x0') { + await keyringController.addNewAccount(primaryKeyring) + accounts = await keyringController.getAccounts() + lastBalance = await this.getBalance(accounts[accounts.length - 1], ethQuery) + } + // set new identities - const accounts = await this.keyringController.getAccounts() this.preferencesController.setAddresses(accounts) this.selectFirstIdentity() releaseLock() @@ -491,6 +512,30 @@ module.exports = class MetamaskController extends EventEmitter { } } + /** + * Get an account balance from the AccountTracker or request it directly from the network. + * @param {string} address - The account address + * @param {EthQuery} ethQuery - The EthQuery instance to use when asking the network + */ + getBalance (address, ethQuery) { + return new Promise((resolve, reject) => { + const cached = this.accountTracker.store.getState().accounts[address] + + if (cached && cached.balance) { + resolve(cached.balance) + } else { + ethQuery.getBalance(address, (error, balance) => { + if (error) { + reject(error) + log.error(error) + } else { + resolve(balance || '0x0') + } + }) + } + }) + } + /* * Submits the user's password and attempts to unlock the vault. * Also synchronizes the preferencesController, to ensure its schema |