1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/app/keychains/hd/restore-vault.js

182 lines
4.9 KiB
JavaScript
Raw Normal View History

const inherits = require('util').inherits
const PropTypes = require('prop-types')
const PersistentForm = require('../../../lib/persistent-form')
const connect = require('react-redux').connect
const h = require('react-hyperscript')
const actions = require('../../actions')
const log = require('loglevel')
RestoreVaultScreen.contextTypes = {
t: PropTypes.func,
}
module.exports = connect(mapStateToProps)(RestoreVaultScreen)
2016-08-25 21:18:04 +02:00
inherits(RestoreVaultScreen, PersistentForm)
2016-06-21 22:18:32 +02:00
function RestoreVaultScreen () {
2016-08-25 21:18:04 +02:00
PersistentForm.call(this)
}
2016-06-21 22:18:32 +02:00
function mapStateToProps (state) {
return {
warning: state.appState.warning,
forgottenPassword: state.appState.forgottenPassword,
}
}
2016-06-21 22:18:32 +02:00
RestoreVaultScreen.prototype.render = function () {
var state = this.props
2016-08-25 21:18:04 +02:00
this.persistentFormParentId = 'restore-vault-form'
return (
h('.initialize-screen.flex-column.flex-center.flex-grow', [
h('h3.flex-center.text-transform-uppercase', {
style: {
background: '#EBEBEB',
color: '#AEAEAE',
marginBottom: 24,
width: '100%',
fontSize: '20px',
padding: 6,
},
}, [
this.context.t('restoreVault'),
]),
// wallet seed entry
h('h3', this.context.t('walletSeed')),
h('textarea.twelve-word-phrase.letter-spacey', {
dataset: {
2016-08-25 21:18:04 +02:00
persistentFormId: 'wallet-seed',
},
placeholder: this.context.t('secretPhrase'),
}),
// password
h('input.large-input.letter-spacey', {
type: 'password',
id: 'password-box',
placeholder: this.context.t('newPassword8Chars'),
dataset: {
2016-08-25 21:18:04 +02:00
persistentFormId: 'password',
},
style: {
width: 260,
marginTop: 12,
},
}),
// confirm password
h('input.large-input.letter-spacey', {
type: 'password',
id: 'password-box-confirm',
placeholder: this.context.t('confirmPassword'),
2016-11-01 19:51:51 +01:00
onKeyPress: this.createOnEnter.bind(this),
dataset: {
2016-08-25 21:18:04 +02:00
persistentFormId: 'password-confirmation',
},
style: {
width: 260,
marginTop: 16,
},
}),
(state.warning) && (
h('span.error.in-progress-notification', state.warning)
),
// submit
h('.flex-row.flex-space-between', {
style: {
marginTop: 30,
width: '50%',
},
}, [
// cancel
h('button.primary', {
onClick: this.showInitializeMenu.bind(this),
2018-03-19 19:43:22 +01:00
style: {
textTransform: 'uppercase',
},
}, this.context.t('cancel')),
// submit
h('button.primary', {
onClick: this.createNewVaultAndRestore.bind(this),
2018-03-19 19:43:22 +01:00
style: {
textTransform: 'uppercase',
},
}, this.context.t('ok')),
]),
])
)
}
2016-06-21 22:18:32 +02:00
RestoreVaultScreen.prototype.showInitializeMenu = function () {
const { dispatch, forgottenPassword } = this.props
dispatch(actions.unMarkPasswordForgotten())
.then(() => {
if (forgottenPassword) {
dispatch(actions.backToUnlockView())
} else {
dispatch(actions.showInitializeMenu())
}
})
}
2016-11-01 19:51:51 +01:00
RestoreVaultScreen.prototype.createOnEnter = function (event) {
if (event.key === 'Enter') {
2016-11-01 19:51:51 +01:00
this.createNewVaultAndRestore()
}
}
RestoreVaultScreen.prototype.createNewVaultAndRestore = function () {
// check password
var passwordBox = document.getElementById('password-box')
var password = passwordBox.value
var passwordConfirmBox = document.getElementById('password-box-confirm')
var passwordConfirm = passwordConfirmBox.value
if (password.length < 8) {
this.warning = this.context.t('passwordNotLongEnough')
this.props.dispatch(actions.displayWarning(this.warning))
return
}
if (password !== passwordConfirm) {
this.warning = this.context.t('passwordsDontMatch')
this.props.dispatch(actions.displayWarning(this.warning))
return
}
// check seed
var seedBox = document.querySelector('textarea.twelve-word-phrase')
var seed = seedBox.value.trim()
// true if the string has more than a space between words.
if (seed.split(' ').length > 1) {
this.warning = this.context.t('spaceBetween')
this.props.dispatch(actions.displayWarning(this.warning))
return
}
// true if seed contains a character that is not between a-z or a space
2018-03-13 22:41:54 +01:00
if (!seed.match(/^[a-z ]+$/)) {
this.warning = this.context.t('loweCaseWords')
2018-03-19 19:43:22 +01:00
this.props.dispatch(actions.displayWarning(this.warning))
return
}
if (seed.split(' ').length !== 12) {
this.warning = this.context.t('seedPhraseReq')
this.props.dispatch(actions.displayWarning(this.warning))
return
}
// submit
this.warning = null
this.props.dispatch(actions.displayWarning(this.warning))
this.props.dispatch(actions.createNewVaultAndRestore(password, seed))
.catch(err => log.error(err.message))
}