diff options
author | Thomas Huang <tmashuang@users.noreply.github.com> | 2018-06-05 07:37:58 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-06-05 07:37:58 +0800 |
commit | e1cd3562cef92a78945056dc557d4228a72b119c (patch) | |
tree | 0d4a7cbe1c095085744ed27f59453667d5b41c88 /app/scripts/controllers/preferences.js | |
parent | 750ec8769931f8db30ebb5e8e8bcc61816368800 (diff) | |
parent | c12b02b4af75d6d706d0b8cd9aeb07f18aa3037a (diff) | |
download | tangerine-wallet-browser-e1cd3562cef92a78945056dc557d4228a72b119c.tar tangerine-wallet-browser-e1cd3562cef92a78945056dc557d4228a72b119c.tar.gz tangerine-wallet-browser-e1cd3562cef92a78945056dc557d4228a72b119c.tar.bz2 tangerine-wallet-browser-e1cd3562cef92a78945056dc557d4228a72b119c.tar.lz tangerine-wallet-browser-e1cd3562cef92a78945056dc557d4228a72b119c.tar.xz tangerine-wallet-browser-e1cd3562cef92a78945056dc557d4228a72b119c.tar.zst tangerine-wallet-browser-e1cd3562cef92a78945056dc557d4228a72b119c.zip |
Merge pull request #4490 from MetaMask/v4.7.3
Version 4.7.3
Diffstat (limited to 'app/scripts/controllers/preferences.js')
-rw-r--r-- | app/scripts/controllers/preferences.js | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/app/scripts/controllers/preferences.js b/app/scripts/controllers/preferences.js index 760868ddf..2fe009f9a 100644 --- a/app/scripts/controllers/preferences.js +++ b/app/scripts/controllers/preferences.js @@ -1,6 +1,9 @@ const ObservableStore = require('obs-store') const normalizeAddress = require('eth-sig-util').normalize const extend = require('xtend') +const notifier = require('../lib/bug-notifier') +const log = require('loglevel') +const { version } = require('../../manifest.json') class PreferencesController { @@ -28,7 +31,12 @@ class PreferencesController { featureFlags: {}, currentLocale: opts.initLangCode, identities: {}, + lostIdentities: {}, }, opts.initState) + + this.getFirstTimeInfo = opts.getFirstTimeInfo || null + this.notifier = opts.notifier || notifier + this.store = new ObservableStore(initState) } // PUBLIC METHODS @@ -98,6 +106,58 @@ class PreferencesController { this.store.updateState({ identities }) } + /* + * Synchronizes identity entries with known accounts. + * Removes any unknown identities, and returns the resulting selected address. + * + * @param {Array<string>} addresses known to the vault. + * @returns {Promise<string>} selectedAddress the selected address. + */ + syncAddresses (addresses) { + let { identities, lostIdentities } = this.store.getState() + + let newlyLost = {} + Object.keys(identities).forEach((identity) => { + if (!addresses.includes(identity)) { + newlyLost[identity] = identities[identity] + delete identities[identity] + } + }) + + // Identities are no longer present. + if (Object.keys(newlyLost).length > 0) { + + // Notify our servers: + const uri = 'https://diagnostics.metamask.io/v1/orphanedAccounts' + const firstTimeInfo = this.getFirstTimeInfo ? this.getFirstTimeInfo() : {} + this.notifier.notify(uri, { + accounts: Object.keys(newlyLost), + metadata: { + version, + firstTimeInfo, + }, + }) + .catch(log.error) + + for (let key in newlyLost) { + lostIdentities[key] = newlyLost[key] + } + } + + this.store.updateState({ identities, lostIdentities }) + this.addAddresses(addresses) + + // If the selected account is no longer valid, + // select an arbitrary other account: + let selected = this.getSelectedAddress() + if (!addresses.includes(selected)) { + selected = addresses[0] + this.setSelectedAddress(selected) + } + + return selected + } + /** * Setter for the `selectedAddress` property * |