2020-05-10 03:46:06 +00:00
|
|
|
import ProgressButton from 'src/components/progress_button/progress_button.vue'
|
|
|
|
import Checkbox from 'src/components/checkbox/checkbox.vue'
|
|
|
|
import Mfa from './mfa.vue'
|
2020-12-02 21:17:55 +00:00
|
|
|
import localeService from 'src/services/locale/locale.service.js'
|
2020-05-03 14:36:12 +00:00
|
|
|
|
2020-05-10 03:46:06 +00:00
|
|
|
const SecurityTab = {
|
2020-05-03 14:36:12 +00:00
|
|
|
data () {
|
|
|
|
return {
|
|
|
|
newEmail: '',
|
|
|
|
changeEmailError: false,
|
|
|
|
changeEmailPassword: '',
|
|
|
|
changedEmail: false,
|
|
|
|
deletingAccount: false,
|
|
|
|
deleteAccountConfirmPasswordInput: '',
|
|
|
|
deleteAccountError: false,
|
|
|
|
changePasswordInputs: [ '', '', '' ],
|
|
|
|
changedPassword: false,
|
2021-09-12 17:50:16 +00:00
|
|
|
changePasswordError: false,
|
|
|
|
moveAccountTarget: '',
|
|
|
|
moveAccountPassword: '',
|
|
|
|
movedAccount: false,
|
|
|
|
moveAccountError: false,
|
|
|
|
aliases: [],
|
2022-03-24 20:55:39 +00:00
|
|
|
listAliasesError: false,
|
2021-09-12 17:50:16 +00:00
|
|
|
addAliasTarget: '',
|
|
|
|
addedAlias: false,
|
|
|
|
addAliasError: false
|
2020-05-03 14:36:12 +00:00
|
|
|
}
|
|
|
|
},
|
|
|
|
created () {
|
|
|
|
this.$store.dispatch('fetchTokens')
|
2021-09-12 17:50:16 +00:00
|
|
|
this.fetchAliases()
|
2020-05-03 14:36:12 +00:00
|
|
|
},
|
|
|
|
components: {
|
|
|
|
ProgressButton,
|
|
|
|
Mfa,
|
|
|
|
Checkbox
|
|
|
|
},
|
|
|
|
computed: {
|
|
|
|
user () {
|
|
|
|
return this.$store.state.users.currentUser
|
|
|
|
},
|
|
|
|
pleromaBackend () {
|
|
|
|
return this.$store.state.instance.pleromaBackend
|
|
|
|
},
|
|
|
|
oauthTokens () {
|
|
|
|
return this.$store.state.oauthTokens.tokens.map(oauthToken => {
|
|
|
|
return {
|
|
|
|
id: oauthToken.id,
|
|
|
|
appName: oauthToken.app_name,
|
2020-12-02 21:17:55 +00:00
|
|
|
validUntil: new Date(oauthToken.valid_until).toLocaleDateString(localeService.internalToBrowserLocale(this.$i18n.locale))
|
2020-05-03 14:36:12 +00:00
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
confirmDelete () {
|
|
|
|
this.deletingAccount = true
|
|
|
|
},
|
|
|
|
deleteAccount () {
|
|
|
|
this.$store.state.api.backendInteractor.deleteAccount({ password: this.deleteAccountConfirmPasswordInput })
|
|
|
|
.then((res) => {
|
|
|
|
if (res.status === 'success') {
|
|
|
|
this.$store.dispatch('logout')
|
|
|
|
this.$router.push({ name: 'root' })
|
|
|
|
} else {
|
|
|
|
this.deleteAccountError = res.error
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
changePassword () {
|
|
|
|
const params = {
|
|
|
|
password: this.changePasswordInputs[0],
|
|
|
|
newPassword: this.changePasswordInputs[1],
|
|
|
|
newPasswordConfirmation: this.changePasswordInputs[2]
|
|
|
|
}
|
|
|
|
this.$store.state.api.backendInteractor.changePassword(params)
|
|
|
|
.then((res) => {
|
|
|
|
if (res.status === 'success') {
|
|
|
|
this.changedPassword = true
|
|
|
|
this.changePasswordError = false
|
|
|
|
this.logout()
|
|
|
|
} else {
|
|
|
|
this.changedPassword = false
|
|
|
|
this.changePasswordError = res.error
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
changeEmail () {
|
|
|
|
const params = {
|
|
|
|
email: this.newEmail,
|
|
|
|
password: this.changeEmailPassword
|
|
|
|
}
|
|
|
|
this.$store.state.api.backendInteractor.changeEmail(params)
|
|
|
|
.then((res) => {
|
|
|
|
if (res.status === 'success') {
|
|
|
|
this.changedEmail = true
|
|
|
|
this.changeEmailError = false
|
|
|
|
} else {
|
|
|
|
this.changedEmail = false
|
|
|
|
this.changeEmailError = res.error
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
2021-09-12 17:50:16 +00:00
|
|
|
moveAccount () {
|
|
|
|
const params = {
|
|
|
|
targetAccount: this.moveAccountTarget,
|
|
|
|
password: this.moveAccountPassword
|
|
|
|
}
|
|
|
|
this.$store.state.api.backendInteractor.moveAccount(params)
|
|
|
|
.then((res) => {
|
|
|
|
if (res.status === 'success') {
|
|
|
|
this.movedAccount = true
|
|
|
|
this.moveAccountError = false
|
|
|
|
} else {
|
|
|
|
this.movedAccount = false
|
|
|
|
this.moveAccountError = res.error
|
|
|
|
}
|
|
|
|
})
|
|
|
|
},
|
|
|
|
removeAlias (alias) {
|
|
|
|
this.$store.state.api.backendInteractor.deleteAlias({ alias })
|
|
|
|
.then(() => this.fetchAliases())
|
|
|
|
},
|
|
|
|
addAlias () {
|
|
|
|
this.$store.state.api.backendInteractor.addAlias({ alias: this.addAliasTarget })
|
|
|
|
.then((res) => {
|
|
|
|
this.addedAlias = true
|
|
|
|
this.addAliasError = false
|
|
|
|
this.addAliasTarget = ''
|
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
this.addedAlias = false
|
|
|
|
this.addAliasError = error
|
|
|
|
})
|
|
|
|
.then(() => this.fetchAliases())
|
|
|
|
},
|
|
|
|
fetchAliases () {
|
|
|
|
this.$store.state.api.backendInteractor.listAliases()
|
|
|
|
.then((res) => {
|
|
|
|
this.aliases = res.aliases
|
2022-03-24 20:55:39 +00:00
|
|
|
this.listAliasesError = false
|
|
|
|
})
|
|
|
|
.catch((error) => {
|
|
|
|
this.listAliasesError = error.error
|
2021-09-12 17:50:16 +00:00
|
|
|
})
|
|
|
|
},
|
2020-05-03 14:36:12 +00:00
|
|
|
logout () {
|
|
|
|
this.$store.dispatch('logout')
|
|
|
|
this.$router.replace('/')
|
|
|
|
},
|
|
|
|
revokeToken (id) {
|
|
|
|
if (window.confirm(`${this.$i18n.t('settings.revoke_token')}?`)) {
|
|
|
|
this.$store.dispatch('revokeToken', id)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-10 03:46:06 +00:00
|
|
|
export default SecurityTab
|