1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00

Remove seedWords completely from metamask state (#6920)

`seedWords` used to be stored on the metamask state temporarily at
certain points. This hasn't been the case since #5994, but references
to this state remained. All of the logic remained for correctly updating
these `seedWords`, handling them during navigation, and scrubbing them
from the state.

However the state was never updated in practice. The `seedWords` are
still returned by `verifySeedPhrase`, and they're still stored in
component state in a few places. But they aren't ever set in the Redux
metadata state or the Preferences controller.

All references to this state have been removed, along with any logic
for interacting with this state. A few unused actions were removed as
well.
This commit is contained in:
Mark Stacey 2019-07-26 10:35:21 -03:00 committed by GitHub
parent 58965ed164
commit 1112277cd6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
16 changed files with 8 additions and 539 deletions

View File

@ -116,7 +116,6 @@ setupMetamaskMeshMetrics()
* @property {boolean} useBlockie - Indicates preferred user identicon format. True for blockie, false for Jazzicon. * @property {boolean} useBlockie - Indicates preferred user identicon format. True for blockie, false for Jazzicon.
* @property {Object} featureFlags - An object for optional feature flags. * @property {Object} featureFlags - An object for optional feature flags.
* @property {string} networkEndpointType - TODO: Document * @property {string} networkEndpointType - TODO: Document
* @property {boolean} isRevealingSeedWords - True if seed words are currently being recovered, and should be shown to user.
* @property {boolean} welcomeScreen - True if welcome screen should be shown. * @property {boolean} welcomeScreen - True if welcome screen should be shown.
* @property {string} currentLocale - A locale string matching the user's preferred display language. * @property {string} currentLocale - A locale string matching the user's preferred display language.
* @property {Object} provider - The current selected network provider. * @property {Object} provider - The current selected network provider.

View File

@ -49,7 +49,6 @@ class PreferencesController {
currentLocale: opts.initLangCode, currentLocale: opts.initLangCode,
identities: {}, identities: {},
lostIdentities: {}, lostIdentities: {},
seedWords: null,
forgottenPassword: false, forgottenPassword: false,
preferences: { preferences: {
useNativeCurrencyAsPrimaryCurrency: true, useNativeCurrencyAsPrimaryCurrency: true,
@ -79,14 +78,6 @@ class PreferencesController {
this.store.updateState({ forgottenPassword }) this.store.updateState({ forgottenPassword })
} }
/**
* Sets the {@code seedWords} seed words
* @param {string|null} seedWords the seed words
*/
setSeedWords (seedWords) {
this.store.updateState({ seedWords })
}
/** /**
* Setter for the `useBlockie` property * Setter for the `useBlockie` property
* *

View File

@ -420,9 +420,7 @@ module.exports = class MetamaskController extends EventEmitter {
// primary HD keyring management // primary HD keyring management
addNewAccount: nodeify(this.addNewAccount, this), addNewAccount: nodeify(this.addNewAccount, this),
placeSeedWords: this.placeSeedWords.bind(this),
verifySeedPhrase: nodeify(this.verifySeedPhrase, this), verifySeedPhrase: nodeify(this.verifySeedPhrase, this),
clearSeedWordCache: this.clearSeedWordCache.bind(this),
resetAccount: nodeify(this.resetAccount, this), resetAccount: nodeify(this.resetAccount, this),
removeAccount: nodeify(this.removeAccount, this), removeAccount: nodeify(this.removeAccount, this),
importAccountWithStrategy: nodeify(this.importAccountWithStrategy, this), importAccountWithStrategy: nodeify(this.importAccountWithStrategy, this),
@ -844,26 +842,6 @@ module.exports = class MetamaskController extends EventEmitter {
return {...keyState, identities} return {...keyState, identities}
} }
/**
* Adds the current vault's seed words to the UI's state tree.
*
* Used when creating a first vault, to allow confirmation.
* Also used when revealing the seed words in the confirmation view.
*
* @param {Function} cb - A callback called on completion.
*/
placeSeedWords (cb) {
this.verifySeedPhrase()
.then((seedWords) => {
this.preferencesController.setSeedWords(seedWords)
return cb(null, seedWords)
})
.catch((err) => {
return cb(err)
})
}
/** /**
* Verifies the validity of the current vault's seed phrase. * Verifies the validity of the current vault's seed phrase.
* *
@ -897,18 +875,6 @@ module.exports = class MetamaskController extends EventEmitter {
} }
} }
/**
* Remove the primary account seed phrase from the UI's state tree.
*
* The seed phrase remains available in the background process.
*
* @param {function} cb Callback function called with the current address.
*/
clearSeedWordCache (cb) {
this.preferencesController.setSeedWords(null)
cb(null, this.preferencesController.getSelectedAddress())
}
/** /**
* Clears the transaction history, to allow users to force-reset their nonces. * Clears the transaction history, to allow users to force-reset their nonces.
* Mostly used in development environments, when networks are restarted with * Mostly used in development environments, when networks are restarted with

View File

@ -35,7 +35,6 @@ describe('tx confirmation screen', function () {
actions._setBackgroundConnection({ actions._setBackgroundConnection({
approveTransaction (_, cb) { cb('An error!') }, approveTransaction (_, cb) { cb('An error!') },
cancelTransaction (_, cb) { cb() }, cancelTransaction (_, cb) { cb() },
clearSeedWordCache (cb) { cb() },
getState (cb) { cb() }, getState (cb) { cb() },
}) })
done() done()

View File

@ -497,8 +497,6 @@ describe('MetaMaskController', function () {
}) })
describe('#verifyseedPhrase', function () { describe('#verifyseedPhrase', function () {
let seedPhrase, getConfigSeed
it('errors when no keying is provided', async function () { it('errors when no keying is provided', async function () {
try { try {
await metamaskController.verifySeedPhrase() await metamaskController.verifySeedPhrase()
@ -509,21 +507,6 @@ describe('MetaMaskController', function () {
beforeEach(async function () { beforeEach(async function () {
await metamaskController.createNewVaultAndKeychain('password') await metamaskController.createNewVaultAndKeychain('password')
seedPhrase = await metamaskController.verifySeedPhrase()
})
it('#placeSeedWords should match the initially created vault seed', function () {
metamaskController.placeSeedWords((err, result) => {
if (err) {
console.log(err)
} else {
getConfigSeed = metamaskController.configManager.getSeedWords()
assert.equal(result, seedPhrase)
assert.equal(result, getConfigSeed)
}
})
assert.equal(getConfigSeed, undefined)
}) })
it('#addNewAccount', async function () { it('#addNewAccount', async function () {
@ -589,21 +572,6 @@ describe('MetaMaskController', function () {
}) })
}) })
describe('#clearSeedWordCache', function () {
it('should set seed words to null', function (done) {
sandbox.stub(metamaskController.preferencesController, 'setSeedWords')
metamaskController.clearSeedWordCache((err) => {
if (err) {
done(err)
}
assert.ok(metamaskController.preferencesController.setSeedWords.calledOnce)
assert.deepEqual(metamaskController.preferencesController.setSeedWords.args, [[null]])
done()
})
})
})
describe('#setCurrentLocale', function () { describe('#setCurrentLocale', function () {
it('checks the default currentLocale', function () { it('checks the default currentLocale', function () {

View File

@ -496,21 +496,6 @@ describe('preferences controller', function () {
}) })
}) })
describe('setSeedWords', function () {
it('should default to null', function () {
const state = preferencesController.store.getState()
assert.equal(state.seedWords, null)
})
it('should set the seedWords property in state', function () {
assert.equal(preferencesController.store.getState().seedWords, null)
preferencesController.setSeedWords('foo bar baz')
assert.equal(preferencesController.store.getState().seedWords, 'foo bar baz')
})
})
describe('#updateRpc', function () { describe('#updateRpc', function () {
it('should update the rpcDetails properly', () => { it('should update the rpcDetails properly', () => {
preferencesController.store.updateState({frequentRpcListDetail: [{}, { rpcUrl: 'test' }, {}]}) preferencesController.store.updateState({frequentRpcListDetail: [{}, { rpcUrl: 'test' }, {}]})

View File

@ -134,95 +134,25 @@ describe('Actions', () => {
}) })
}) })
describe('#confirmSeedWords', () => {
let clearSeedWordCacheSpy
afterEach(() => {
clearSeedWordCacheSpy.restore()
})
it('shows account page after clearing seed word cache', () => {
const store = mockStore({})
const expectedActions = [
{ type: 'SHOW_LOADING_INDICATION', value: undefined },
{ type: 'HIDE_LOADING_INDICATION' },
{ type: 'SHOW_ACCOUNTS_PAGE' },
]
clearSeedWordCacheSpy = sinon.spy(background, 'clearSeedWordCache')
return store.dispatch(actions.confirmSeedWords())
.then(() => {
assert.equal(clearSeedWordCacheSpy.callCount, 1)
assert.deepEqual(store.getActions(), expectedActions)
})
})
it('errors in callback will display warning', () => {
const store = mockStore({})
const expectedActions = [
{ type: 'SHOW_LOADING_INDICATION', value: undefined },
{ type: 'HIDE_LOADING_INDICATION' },
{ type: 'DISPLAY_WARNING', value: 'error' },
]
clearSeedWordCacheSpy = sinon.stub(background, 'clearSeedWordCache')
clearSeedWordCacheSpy.callsFake((callback) => {
callback(new Error('error'))
})
return store.dispatch(actions.confirmSeedWords())
.catch(() => {
assert.deepEqual(store.getActions(), expectedActions)
})
})
})
describe('#createNewVaultAndRestore', () => { describe('#createNewVaultAndRestore', () => {
let createNewVaultAndRestoreSpy, clearSeedWordCacheSpy let createNewVaultAndRestoreSpy
afterEach(() => { afterEach(() => {
createNewVaultAndRestoreSpy.restore() createNewVaultAndRestoreSpy.restore()
}) })
it('clears seed words and restores new vault', () => { it('restores new vault', () => {
const store = mockStore({}) const store = mockStore({})
createNewVaultAndRestoreSpy = sinon.spy(background, 'createNewVaultAndRestore') createNewVaultAndRestoreSpy = sinon.spy(background, 'createNewVaultAndRestore')
clearSeedWordCacheSpy = sinon.spy(background, 'clearSeedWordCache')
return store.dispatch(actions.createNewVaultAndRestore()) return store.dispatch(actions.createNewVaultAndRestore())
.catch(() => { .catch(() => {
assert(clearSeedWordCacheSpy.calledOnce)
assert(createNewVaultAndRestoreSpy.calledOnce) assert(createNewVaultAndRestoreSpy.calledOnce)
}) })
}) })
it('errors when callback in clearSeedWordCache throws', () => {
const store = mockStore()
const expectedActions = [
{ type: 'SHOW_LOADING_INDICATION', value: undefined },
{ type: 'DISPLAY_WARNING', value: 'error' },
{ type: 'HIDE_LOADING_INDICATION' },
]
clearSeedWordCacheSpy = sinon.stub(background, 'clearSeedWordCache')
clearSeedWordCacheSpy.callsFake((callback) => {
callback(new Error('error'))
})
return store.dispatch(actions.createNewVaultAndRestore())
.catch(() => {
assert.deepEqual(store.getActions(), expectedActions)
})
})
it('errors when callback in createNewVaultAndRestore throws', () => { it('errors when callback in createNewVaultAndRestore throws', () => {
const store = mockStore({}) const store = mockStore({})
@ -246,113 +176,6 @@ describe('Actions', () => {
}) })
}) })
describe('#createNewVaultAndKeychain', () => {
let createNewVaultAndKeychainSpy, placeSeedWordsSpy
afterEach(() => {
createNewVaultAndKeychainSpy.restore()
placeSeedWordsSpy.restore()
})
it('calls createNewVaultAndKeychain and placeSeedWords in background', () => {
const store = mockStore()
createNewVaultAndKeychainSpy = sinon.spy(background, 'createNewVaultAndKeychain')
placeSeedWordsSpy = sinon.spy(background, 'placeSeedWords')
return store.dispatch(actions.createNewVaultAndKeychain())
.then(() => {
assert(createNewVaultAndKeychainSpy.calledOnce)
assert(placeSeedWordsSpy.calledOnce)
})
})
it('displays error and value when callback errors', () => {
const store = mockStore()
const expectedActions = [
{ type: 'SHOW_LOADING_INDICATION', value: undefined },
{ type: 'DISPLAY_WARNING', value: 'error' },
{ type: 'HIDE_LOADING_INDICATION' },
]
createNewVaultAndKeychainSpy = sinon.stub(background, 'createNewVaultAndKeychain')
createNewVaultAndKeychainSpy.callsFake((_, callback) => {
callback(new Error('error'))
})
return store.dispatch(actions.createNewVaultAndKeychain())
.then(() => {
assert.deepEqual(store.getActions(), expectedActions)
})
})
it('errors when placeSeedWords throws', () => {
const store = mockStore()
const expectedActions = [
{ type: 'SHOW_LOADING_INDICATION', value: undefined },
{ type: 'DISPLAY_WARNING', value: 'error' },
{ type: 'HIDE_LOADING_INDICATION' },
]
placeSeedWordsSpy = sinon.stub(background, 'placeSeedWords')
placeSeedWordsSpy.callsFake((callback) => {
callback(new Error('error'))
})
return store.dispatch(actions.createNewVaultAndKeychain())
.then(() => {
assert.deepEqual(store.getActions(), expectedActions)
})
})
})
describe('#requestRevealSeed', () => {
let submitPasswordSpy, placeSeedWordsSpy
afterEach(() => {
submitPasswordSpy.restore()
})
it('calls submitPassword and placeSeedWords from background', () => {
const store = mockStore()
submitPasswordSpy = sinon.spy(background, 'submitPassword')
placeSeedWordsSpy = sinon.spy(background, 'placeSeedWords')
return store.dispatch(actions.requestRevealSeed())
.then(() => {
assert(submitPasswordSpy.calledOnce)
assert(placeSeedWordsSpy.calledOnce)
})
})
it('displays warning error with value when callback errors', () => {
const store = mockStore()
const expectedActions = [
{ type: 'SHOW_LOADING_INDICATION', value: undefined },
{ type: 'DISPLAY_WARNING', value: 'error' },
]
submitPasswordSpy = sinon.stub(background, 'submitPassword')
submitPasswordSpy.callsFake((_, callback) => {
callback(new Error('error'))
})
return store.dispatch(actions.requestRevealSeed())
.catch(() => {
assert.deepEqual(store.getActions(), expectedActions)
})
})
})
describe('#requestRevealSeedWords', () => { describe('#requestRevealSeedWords', () => {
let submitPasswordSpy let submitPasswordSpy
@ -389,68 +212,6 @@ describe('Actions', () => {
}) })
}) })
describe('#requestRevealSeed', () => {
let submitPasswordSpy, placeSeedWordsSpy
afterEach(() => {
submitPasswordSpy.restore()
placeSeedWordsSpy.restore()
})
it('calls submitPassword and placeSeedWords in background', () => {
const store = mockStore()
submitPasswordSpy = sinon.spy(background, 'submitPassword')
placeSeedWordsSpy = sinon.spy(background, 'placeSeedWords')
return store.dispatch(actions.requestRevealSeed())
.then(() => {
assert(submitPasswordSpy.calledOnce)
assert(placeSeedWordsSpy.calledOnce)
})
})
it('displays warning error message when submitPassword in background errors', () => {
submitPasswordSpy = sinon.stub(background, 'submitPassword')
submitPasswordSpy.callsFake((_, callback) => {
callback(new Error('error'))
})
const store = mockStore()
const expectedActions = [
{ type: 'SHOW_LOADING_INDICATION', value: undefined },
{ type: 'DISPLAY_WARNING', value: 'error' },
]
return store.dispatch(actions.requestRevealSeed())
.catch(() => {
assert.deepEqual(store.getActions(), expectedActions)
})
})
it('errors when placeSeedWords throw', () => {
placeSeedWordsSpy = sinon.stub(background, 'placeSeedWords')
placeSeedWordsSpy.callsFake((callback) => {
callback(new Error('error'))
})
const store = mockStore()
const expectedActions = [
{ type: 'SHOW_LOADING_INDICATION', value: undefined },
{ type: 'DISPLAY_WARNING', value: 'error' },
]
return store.dispatch(actions.requestRevealSeed())
.catch(() => {
assert.deepEqual(store.getActions(), expectedActions)
})
})
})
describe('#removeAccount', () => { describe('#removeAccount', () => {
let removeAccountSpy let removeAccountSpy

View File

@ -270,18 +270,6 @@ describe('App State', () => {
assert.equal(state.isLoading, true) assert.equal(state.isLoading, true)
}) })
it('shows new vault seed', () => {
const state = reduceApp(metamaskState, {
type: actions.SHOW_NEW_VAULT_SEED,
value: 'test seed words',
})
assert.equal(state.currentView.name, 'createVaultComplete')
assert.equal(state.currentView.seedWords, 'test seed words')
assert.equal(state.transForward, true)
assert.equal(state.isLoading, false)
})
it('shows new account screen', () => { it('shows new account screen', () => {
const state = reduceApp(metamaskState, { const state = reduceApp(metamaskState, {
type: actions.NEW_ACCOUNT_SCREEN, type: actions.NEW_ACCOUNT_SCREEN,
@ -437,7 +425,6 @@ describe('App State', () => {
}) })
assert.equal(state.currentView.name, 'accounts') assert.equal(state.currentView.name, 'accounts')
assert.equal(state.currentView.seedWords, undefined)
assert.equal(state.transForward, true) assert.equal(state.transForward, true)
assert.equal(state.isLoading, false) assert.equal(state.isLoading, false)
assert.equal(state.warning, null) assert.equal(state.warning, null)

View File

@ -9,32 +9,6 @@ describe('MetaMask Reducers', () => {
assert(initState) assert(initState)
}) })
it('sets revealing seed to true and adds seed words to new state', () => {
const seedWordsState = reduceMetamask({}, {
type: actions.SHOW_NEW_VAULT_SEED,
value: 'test seed words',
})
assert.equal(seedWordsState.seedWords, 'test seed words')
assert.equal(seedWordsState.isRevealingSeedWords, true)
})
it('shows account page', () => {
const seedWordsState = {
metamask: {
seedwords: 'test seed words',
isRevealing: true,
},
}
const state = reduceMetamask(seedWordsState, {
type: actions.SHOW_ACCOUNTS_PAGE,
})
assert.equal(state.seedWords, undefined)
assert.equal(state.isRevealingSeedWords, false)
})
it('unlocks MetaMask', () => { it('unlocks MetaMask', () => {
const state = reduceMetamask({}, { const state = reduceMetamask({}, {
type: actions.UNLOCK_METAMASK, type: actions.UNLOCK_METAMASK,
@ -152,16 +126,6 @@ describe('MetaMask Reducers', () => {
}) })
}) })
it('shows new vault seed words and sets isRevealingSeedWords to true', () => {
const showNewVaultSeedState = reduceMetamask({}, {
type: actions.SHOW_NEW_VAULT_SEED,
value: 'test seed words',
})
assert.equal(showNewVaultSeedState.isRevealingSeedWords, true)
assert.equal(showNewVaultSeedState.seedWords, 'test seed words')
})
it('shows account detail', () => { it('shows account detail', () => {
const state = reduceMetamask({}, { const state = reduceMetamask({}, {

View File

@ -27,13 +27,6 @@ function reduceApp (state, action) {
context: selectedAddress, context: selectedAddress,
} }
// confirm seed words
var seedWords = state.metamask.seedWords
var seedConfView = {
name: 'createVaultComplete',
seedWords,
}
// default state // default state
var appState = extend({ var appState = extend({
shouldClose: false, shouldClose: false,
@ -58,7 +51,7 @@ function reduceApp (state, action) {
alertMessage: null, alertMessage: null,
qrCodeData: null, qrCodeData: null,
networkDropdownOpen: false, networkDropdownOpen: false,
currentView: seedWords ? seedConfView : defaultView, currentView: defaultView,
accountDetail: { accountDetail: {
subview: 'transactions', subview: 'transactions',
}, },
@ -279,16 +272,6 @@ function reduceApp (state, action) {
isLoading: true, isLoading: true,
}) })
case actions.SHOW_NEW_VAULT_SEED:
return extend(appState, {
currentView: {
name: 'createVaultComplete',
seedWords: action.value,
},
transForward: true,
isLoading: false,
})
case actions.NEW_ACCOUNT_SCREEN: case actions.NEW_ACCOUNT_SCREEN:
return extend(appState, { return extend(appState, {
currentView: { currentView: {
@ -428,8 +411,7 @@ function reduceApp (state, action) {
case actions.SHOW_ACCOUNTS_PAGE: case actions.SHOW_ACCOUNTS_PAGE:
return extend(appState, { return extend(appState, {
currentView: { currentView: {
name: seedWords ? 'createVaultComplete' : 'accounts', name: 'accounts',
seedWords,
}, },
transForward: true, transForward: true,
isLoading: false, isLoading: false,

View File

@ -61,9 +61,6 @@ window.getCleanAppState = function () {
// append additional information // append additional information
state.version = global.platform.getVersion() state.version = global.platform.getVersion()
state.browser = window.navigator.userAgent state.browser = window.navigator.userAgent
// ensure seedWords are not included
if (state.metamask) delete state.metamask.seedWords
if (state.appState.currentView) delete state.appState.currentView.seedWords
return state return state
} }
@ -72,7 +69,7 @@ window.logStateString = function (cb) {
global.platform.getPlatformInfo((err, platform) => { global.platform.getPlatformInfo((err, platform) => {
if (err) return cb(err) if (err) return cb(err)
state.platform = platform state.platform = platform
const stateString = JSON.stringify(state, removeSeedWords, 2) const stateString = JSON.stringify(state, null, 2)
cb(null, stateString) cb(null, stateString)
}) })
} }
@ -89,7 +86,3 @@ window.logState = function (toClipboard) {
} }
}) })
} }
function removeSeedWords (key, value) {
return key === 'seedWords' ? undefined : value
}

View File

@ -44,7 +44,6 @@ function reduceMetamask (state, action) {
useBlockie: false, useBlockie: false,
featureFlags: {}, featureFlags: {},
networkEndpointType: OLD_UI_NETWORK_TYPE, networkEndpointType: OLD_UI_NETWORK_TYPE,
isRevealingSeedWords: false,
welcomeScreenSeen: false, welcomeScreenSeen: false,
currentLocale: '', currentLocale: '',
preferences: { preferences: {
@ -60,13 +59,6 @@ function reduceMetamask (state, action) {
switch (action.type) { switch (action.type) {
case actions.SHOW_ACCOUNTS_PAGE:
newState = extend(metamaskState, {
isRevealingSeedWords: false,
})
delete newState.seedWords
return newState
case actions.UPDATE_METAMASK_STATE: case actions.UPDATE_METAMASK_STATE:
return extend(metamaskState, action.value) return extend(metamaskState, action.value)
@ -128,20 +120,12 @@ function reduceMetamask (state, action) {
}, },
}) })
case actions.SHOW_NEW_VAULT_SEED:
return extend(metamaskState, {
isRevealingSeedWords: true,
seedWords: action.value,
})
case actions.CLEAR_SEED_WORD_CACHE: case actions.CLEAR_SEED_WORD_CACHE:
newState = extend(metamaskState, { newState = extend(metamaskState, {
isUnlocked: true, isUnlocked: true,
isInitialized: true, isInitialized: true,
selectedAddress: action.value, selectedAddress: action.value,
}) })
delete newState.seedWords
return newState return newState
case actions.SHOW_ACCOUNT_DETAIL: case actions.SHOW_ACCOUNT_DETAIL:
@ -150,7 +134,6 @@ function reduceMetamask (state, action) {
isInitialized: true, isInitialized: true,
selectedAddress: action.value, selectedAddress: action.value,
}) })
delete newState.seedWords
return newState return newState
case actions.SET_SELECTED_TOKEN: case actions.SET_SELECTED_TOKEN:

View File

@ -7,7 +7,6 @@ import TransactionView from '../../components/app/transaction-view'
import ProviderApproval from '../provider-approval' import ProviderApproval from '../provider-approval'
import { import {
INITIALIZE_SEED_PHRASE_ROUTE,
RESTORE_VAULT_ROUTE, RESTORE_VAULT_ROUTE,
CONFIRM_TRANSACTION_ROUTE, CONFIRM_TRANSACTION_ROUTE,
CONFIRM_ADD_SUGGESTED_TOKEN_ROUTE, CONFIRM_ADD_SUGGESTED_TOKEN_ROUTE,
@ -17,7 +16,6 @@ export default class Home extends PureComponent {
static propTypes = { static propTypes = {
history: PropTypes.object, history: PropTypes.object,
forgottenPassword: PropTypes.bool, forgottenPassword: PropTypes.bool,
seedWords: PropTypes.string,
suggestedTokens: PropTypes.object, suggestedTokens: PropTypes.object,
unconfirmedTransactionsCount: PropTypes.number, unconfirmedTransactionsCount: PropTypes.number,
providerRequests: PropTypes.array, providerRequests: PropTypes.array,
@ -49,16 +47,10 @@ export default class Home extends PureComponent {
render () { render () {
const { const {
forgottenPassword, forgottenPassword,
seedWords,
providerRequests, providerRequests,
history, history,
} = this.props } = this.props
// seed words
if (seedWords) {
return <Redirect to={{ pathname: INITIALIZE_SEED_PHRASE_ROUTE }}/>
}
if (forgottenPassword) { if (forgottenPassword) {
return <Redirect to={{ pathname: RESTORE_VAULT_ROUTE }} /> return <Redirect to={{ pathname: RESTORE_VAULT_ROUTE }} />
} }

View File

@ -8,7 +8,6 @@ const mapStateToProps = state => {
const { metamask, appState } = state const { metamask, appState } = state
const { const {
lostAccounts, lostAccounts,
seedWords,
suggestedTokens, suggestedTokens,
providerRequests, providerRequests,
} = metamask } = metamask
@ -17,7 +16,6 @@ const mapStateToProps = state => {
return { return {
lostAccounts, lostAccounts,
forgottenPassword, forgottenPassword,
seedWords,
suggestedTokens, suggestedTokens,
unconfirmedTransactionsCount: unconfirmedTransactionsCountSelector(state), unconfirmedTransactionsCount: unconfirmedTransactionsCountSelector(state),
providerRequests, providerRequests,

View File

@ -346,7 +346,6 @@ Routes.propTypes = {
forgottenPassword: PropTypes.bool, forgottenPassword: PropTypes.bool,
activeAddress: PropTypes.string, activeAddress: PropTypes.string,
unapprovedTxs: PropTypes.object, unapprovedTxs: PropTypes.object,
seedWords: PropTypes.string,
submittedPendingTransactions: PropTypes.array, submittedPendingTransactions: PropTypes.array,
unapprovedMsgCount: PropTypes.number, unapprovedMsgCount: PropTypes.number,
unapprovedPersonalMsgCount: PropTypes.number, unapprovedPersonalMsgCount: PropTypes.number,
@ -380,7 +379,6 @@ function mapStateToProps (state) {
address, address,
keyrings, keyrings,
isInitialized, isInitialized,
seedWords,
unapprovedTxs, unapprovedTxs,
lostAccounts, lostAccounts,
unapprovedMsgCount, unapprovedMsgCount,
@ -404,9 +402,8 @@ function mapStateToProps (state) {
currentView: state.appState.currentView, currentView: state.appState.currentView,
activeAddress: state.appState.activeAddress, activeAddress: state.appState.activeAddress,
transForward: state.appState.transForward, transForward: state.appState.transForward,
isOnboarding: Boolean(seedWords || !isInitialized), isOnboarding: Boolean(!isInitialized),
isPopup: state.metamask.isPopup, isPopup: state.metamask.isPopup,
seedWords: state.metamask.seedWords,
submittedPendingTransactions: submittedPendingTransactionsSelector(state), submittedPendingTransactions: submittedPendingTransactionsSelector(state),
unapprovedTxs, unapprovedTxs,
unapprovedMsgs: state.metamask.unapprovedMsgs, unapprovedMsgs: state.metamask.unapprovedMsgs,
@ -421,7 +418,6 @@ function mapStateToProps (state) {
frequentRpcListDetail: state.metamask.frequentRpcListDetail || [], frequentRpcListDetail: state.metamask.frequentRpcListDetail || [],
currentCurrency: state.metamask.currentCurrency, currentCurrency: state.metamask.currentCurrency,
isMouseUser: state.appState.isMouseUser, isMouseUser: state.appState.isMouseUser,
isRevealingSeedWords: state.metamask.isRevealingSeedWords,
Qr: state.appState.Qr, Qr: state.appState.Qr,
welcomeScreenSeen: state.metamask.welcomeScreenSeen, welcomeScreenSeen: state.metamask.welcomeScreenSeen,
providerId: getNetworkIdentifier(state), providerId: getNetworkIdentifier(state),

View File

@ -67,7 +67,6 @@ var actions = {
markPasswordForgotten, markPasswordForgotten,
unMarkPasswordForgotten, unMarkPasswordForgotten,
SHOW_INIT_MENU: 'SHOW_INIT_MENU', SHOW_INIT_MENU: 'SHOW_INIT_MENU',
SHOW_NEW_VAULT_SEED: 'SHOW_NEW_VAULT_SEED',
SHOW_INFO_PAGE: 'SHOW_INFO_PAGE', SHOW_INFO_PAGE: 'SHOW_INFO_PAGE',
SHOW_IMPORT_PAGE: 'SHOW_IMPORT_PAGE', SHOW_IMPORT_PAGE: 'SHOW_IMPORT_PAGE',
SHOW_NEW_ACCOUNT_PAGE: 'SHOW_NEW_ACCOUNT_PAGE', SHOW_NEW_ACCOUNT_PAGE: 'SHOW_NEW_ACCOUNT_PAGE',
@ -81,7 +80,6 @@ var actions = {
showImportPage, showImportPage,
showNewAccountPage, showNewAccountPage,
setNewAccountForm, setNewAccountForm,
createNewVaultAndKeychain: createNewVaultAndKeychain,
createNewVaultAndRestore: createNewVaultAndRestore, createNewVaultAndRestore: createNewVaultAndRestore,
createNewVaultInProgress: createNewVaultInProgress, createNewVaultInProgress: createNewVaultInProgress,
createNewVaultAndGetSeedPhrase, createNewVaultAndGetSeedPhrase,
@ -97,14 +95,12 @@ var actions = {
navigateToNewAccountScreen, navigateToNewAccountScreen,
resetAccount, resetAccount,
removeAccount, removeAccount,
showNewVaultSeed: showNewVaultSeed,
showInfoPage: showInfoPage, showInfoPage: showInfoPage,
CLOSE_WELCOME_SCREEN: 'CLOSE_WELCOME_SCREEN', CLOSE_WELCOME_SCREEN: 'CLOSE_WELCOME_SCREEN',
closeWelcomeScreen, closeWelcomeScreen,
// seed recovery actions // seed recovery actions
REVEAL_SEED_CONFIRMATION: 'REVEAL_SEED_CONFIRMATION', REVEAL_SEED_CONFIRMATION: 'REVEAL_SEED_CONFIRMATION',
revealSeedConfirmation: revealSeedConfirmation, revealSeedConfirmation: revealSeedConfirmation,
requestRevealSeed: requestRevealSeed,
requestRevealSeedWords, requestRevealSeedWords,
// unlock screen // unlock screen
UNLOCK_IN_PROGRESS: 'UNLOCK_IN_PROGRESS', UNLOCK_IN_PROGRESS: 'UNLOCK_IN_PROGRESS',
@ -217,7 +213,6 @@ var actions = {
gasLoadingStarted, gasLoadingStarted,
gasLoadingFinished, gasLoadingFinished,
// app messages // app messages
confirmSeedWords: confirmSeedWords,
showAccountDetail: showAccountDetail, showAccountDetail: showAccountDetail,
BACK_TO_ACCOUNT_DETAIL: 'BACK_TO_ACCOUNT_DETAIL', BACK_TO_ACCOUNT_DETAIL: 'BACK_TO_ACCOUNT_DETAIL',
backToAccountDetail: backToAccountDetail, backToAccountDetail: backToAccountDetail,
@ -444,37 +439,12 @@ function transitionBackward () {
} }
} }
function confirmSeedWords () {
return dispatch => {
dispatch(actions.showLoadingIndication())
log.debug(`background.clearSeedWordCache`)
return new Promise((resolve, reject) => {
background.clearSeedWordCache((err, account) => {
dispatch(actions.hideLoadingIndication())
if (err) {
dispatch(actions.displayWarning(err.message))
return reject(err)
}
log.info('Seed word cache cleared. ' + account)
dispatch(actions.showAccountsPage())
resolve(account)
})
})
}
}
function createNewVaultAndRestore (password, seed) { function createNewVaultAndRestore (password, seed) {
return (dispatch) => { return (dispatch) => {
dispatch(actions.showLoadingIndication()) dispatch(actions.showLoadingIndication())
log.debug(`background.createNewVaultAndRestore`) log.debug(`background.createNewVaultAndRestore`)
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
background.clearSeedWordCache((err) => {
if (err) {
return reject(err)
}
background.createNewVaultAndRestore(password, seed, (err) => { background.createNewVaultAndRestore(password, seed, (err) => {
if (err) { if (err) {
return reject(err) return reject(err)
@ -483,7 +453,6 @@ function createNewVaultAndRestore (password, seed) {
resolve() resolve()
}) })
}) })
})
.then(() => dispatch(actions.unMarkPasswordForgotten())) .then(() => dispatch(actions.unMarkPasswordForgotten()))
.then(() => { .then(() => {
dispatch(actions.showAccountsPage()) dispatch(actions.showAccountsPage())
@ -497,36 +466,6 @@ function createNewVaultAndRestore (password, seed) {
} }
} }
function createNewVaultAndKeychain (password) {
return dispatch => {
dispatch(actions.showLoadingIndication())
log.debug(`background.createNewVaultAndKeychain`)
return new Promise((resolve, reject) => {
background.createNewVaultAndKeychain(password, err => {
if (err) {
dispatch(actions.displayWarning(err.message))
return reject(err)
}
log.debug(`background.placeSeedWords`)
background.placeSeedWords((err) => {
if (err) {
dispatch(actions.displayWarning(err.message))
return reject(err)
}
resolve()
})
})
})
.then(() => forceUpdateMetamaskState(dispatch))
.then(() => dispatch(actions.hideLoadingIndication()))
.catch(() => dispatch(actions.hideLoadingIndication()))
}
}
function createNewVaultAndGetSeedPhrase (password) { function createNewVaultAndGetSeedPhrase (password) {
return async dispatch => { return async dispatch => {
dispatch(actions.showLoadingIndication()) dispatch(actions.showLoadingIndication())
@ -616,33 +555,6 @@ function verifySeedPhrase () {
}) })
} }
function requestRevealSeed (password) {
return dispatch => {
dispatch(actions.showLoadingIndication())
log.debug(`background.submitPassword`)
return new Promise((resolve, reject) => {
background.submitPassword(password, err => {
if (err) {
dispatch(actions.displayWarning(err.message))
return reject(err)
}
log.debug(`background.placeSeedWords`)
background.placeSeedWords((err, result) => {
if (err) {
dispatch(actions.displayWarning(err.message))
return reject(err)
}
dispatch(actions.showNewVaultSeed(result))
dispatch(actions.hideLoadingIndication())
resolve()
})
})
})
}
}
function requestRevealSeedWords (password) { function requestRevealSeedWords (password) {
return async dispatch => { return async dispatch => {
dispatch(actions.showLoadingIndication()) dispatch(actions.showLoadingIndication())
@ -1531,13 +1443,6 @@ function createNewVaultInProgress () {
} }
} }
function showNewVaultSeed (seed) {
return {
type: actions.SHOW_NEW_VAULT_SEED,
value: seed,
}
}
function closeWelcomeScreen () { function closeWelcomeScreen () {
return { return {
type: actions.CLOSE_WELCOME_SCREEN, type: actions.CLOSE_WELCOME_SCREEN,