2019-06-13 06:16:55 +10:00
|
|
|
import mfaApi from '../../services/new_api/mfa.js'
|
|
|
|
import { mapState, mapGetters, mapActions, mapMutations } from 'vuex'
|
2020-10-21 05:18:23 +11:00
|
|
|
import { library } from '@fortawesome/fontawesome-svg-core'
|
|
|
|
import {
|
|
|
|
faTimes
|
|
|
|
} from '@fortawesome/free-solid-svg-icons'
|
|
|
|
|
|
|
|
library.add(
|
|
|
|
faTimes
|
|
|
|
)
|
2019-06-13 06:16:55 +10:00
|
|
|
|
|
|
|
export default {
|
|
|
|
data: () => ({
|
|
|
|
code: null,
|
|
|
|
error: false
|
|
|
|
}),
|
|
|
|
computed: {
|
|
|
|
...mapGetters({
|
|
|
|
authSettings: 'authFlow/settings'
|
|
|
|
}),
|
2019-12-12 16:42:21 +11:00
|
|
|
...mapState({
|
|
|
|
instance: 'instance',
|
|
|
|
oauth: 'oauth'
|
|
|
|
})
|
2019-06-13 06:16:55 +10:00
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
...mapMutations('authFlow', ['requireTOTP', 'abortMFA']),
|
|
|
|
...mapActions({ login: 'authFlow/login' }),
|
|
|
|
clearError () { this.error = false },
|
|
|
|
submit () {
|
2019-12-12 16:42:21 +11:00
|
|
|
const { clientId, clientSecret } = this.oauth
|
|
|
|
|
2019-06-13 06:16:55 +10:00
|
|
|
const data = {
|
2019-12-12 16:42:21 +11:00
|
|
|
clientId,
|
|
|
|
clientSecret,
|
2019-06-13 06:16:55 +10:00
|
|
|
instance: this.instance.server,
|
|
|
|
mfaToken: this.authSettings.mfa_token,
|
|
|
|
code: this.code
|
|
|
|
}
|
|
|
|
|
|
|
|
mfaApi.verifyRecoveryCode(data).then((result) => {
|
|
|
|
if (result.error) {
|
|
|
|
this.error = result.error
|
|
|
|
this.code = null
|
|
|
|
return
|
|
|
|
}
|
|
|
|
|
|
|
|
this.login(result).then(() => {
|
2019-07-05 17:02:14 +10:00
|
|
|
this.$router.push({ name: 'friends' })
|
2019-06-13 06:16:55 +10:00
|
|
|
})
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|