mirror of
https://github.com/apache/cloudstack.git
synced 2025-10-26 08:42:29 +01:00
* Feature: Forgot password * Address comments * fixups * Make forgot password disabled by default * Apply suggestions from code review * Address comments
209 lines
6.5 KiB
JavaScript
209 lines
6.5 KiB
JavaScript
// Licensed to the Apache Software Foundation (ASF) under one
|
|
// or more contributor license agreements. See the NOTICE file
|
|
// distributed with this work for additional information
|
|
// regarding copyright ownership. The ASF licenses this file
|
|
// to you under the Apache License, Version 2.0 (the
|
|
// "License"); you may not use this file except in compliance
|
|
// with the License. You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing,
|
|
// software distributed under the License is distributed on an
|
|
// "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
|
// KIND, either express or implied. See the License for the
|
|
// specific language governing permissions and limitations
|
|
// under the License.
|
|
|
|
import axios from 'axios'
|
|
|
|
import { vueProps } from '@/vue-app'
|
|
import router from '@/router'
|
|
import { VueAxios } from './axios'
|
|
import notification from 'ant-design-vue/es/notification'
|
|
import { CURRENT_PROJECT } from '@/store/mutation-types'
|
|
import { i18n } from '@/locales'
|
|
import store from '@/store'
|
|
|
|
let source
|
|
const service = axios.create({
|
|
timeout: 600000
|
|
})
|
|
|
|
const err = (error) => {
|
|
const response = error.response
|
|
let countNotify = store.getters.countNotify
|
|
if (response) {
|
|
console.log(response)
|
|
if (response.status === 403) {
|
|
const data = response.data
|
|
countNotify++
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
notification.error({
|
|
top: '65px',
|
|
message: i18n.global.t('label.forbidden'),
|
|
description: data.message,
|
|
onClose: () => {
|
|
let countNotify = store.getters.countNotify
|
|
countNotify > 0 ? countNotify-- : countNotify = 0
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
}
|
|
})
|
|
}
|
|
if (response.status === 401) {
|
|
if (response.config && response.config.params && ['forgotPassword', 'listIdps', 'cloudianIsEnabled'].includes(response.config.params.command)) {
|
|
return
|
|
}
|
|
const originalPath = router.currentRoute.value.fullPath
|
|
for (const key in response.data) {
|
|
if (key.includes('response')) {
|
|
if (response.data[key].errortext.includes('not available for user')) {
|
|
countNotify++
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
notification.error({
|
|
top: '65px',
|
|
message: 'Error',
|
|
description: response.data[key].errortext + ' ' + i18n.global.t('error.unable.to.proceed'),
|
|
duration: 0,
|
|
onClose: () => {
|
|
let countNotify = store.getters.countNotify
|
|
countNotify > 0 ? countNotify-- : countNotify = 0
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
}
|
|
})
|
|
return
|
|
}
|
|
}
|
|
}
|
|
countNotify++
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
if (originalPath === '/verify2FA' || originalPath === '/setup2FA') {
|
|
notification.error({
|
|
top: '65px',
|
|
message: i18n.global.t('label.2FA'),
|
|
description: i18n.global.t('message.error.verifying.2fa'),
|
|
key: 'http-401',
|
|
duration: 0,
|
|
onClose: () => {
|
|
let countNotify = store.getters.countNotify
|
|
countNotify > 0 ? countNotify-- : countNotify = 0
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
}
|
|
})
|
|
} else {
|
|
notification.error({
|
|
top: '65px',
|
|
message: i18n.global.t('label.unauthorized'),
|
|
description: i18n.global.t('message.authorization.failed'),
|
|
key: 'http-401',
|
|
duration: 0,
|
|
onClose: () => {
|
|
let countNotify = store.getters.countNotify
|
|
countNotify > 0 ? countNotify-- : countNotify = 0
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
}
|
|
})
|
|
}
|
|
|
|
store.dispatch('Logout').then(() => {
|
|
if (originalPath !== '/user/login') {
|
|
router.push({ path: '/user/login', query: { redirect: originalPath } })
|
|
}
|
|
})
|
|
}
|
|
if (response.status === 404) {
|
|
countNotify++
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
notification.error({
|
|
top: '65px',
|
|
message: i18n.global.t('label.not.found'),
|
|
description: i18n.global.t('message.resource.not.found'),
|
|
onClose: () => {
|
|
let countNotify = store.getters.countNotify
|
|
countNotify > 0 ? countNotify-- : countNotify = 0
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
}
|
|
})
|
|
router.push({ path: '/exception/404' })
|
|
}
|
|
}
|
|
if (error.isAxiosError && !error.response) {
|
|
countNotify++
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
notification.warn({
|
|
top: '65px',
|
|
message: error.message || i18n.global.t('message.network.error'),
|
|
description: i18n.global.t('message.network.error.description'),
|
|
key: 'network-error',
|
|
onClose: () => {
|
|
let countNotify = store.getters.countNotify
|
|
countNotify > 0 ? countNotify-- : countNotify = 0
|
|
store.commit('SET_COUNT_NOTIFY', countNotify)
|
|
}
|
|
})
|
|
}
|
|
return Promise.reject(error)
|
|
}
|
|
|
|
// request interceptor
|
|
service.interceptors.request.use(config => {
|
|
source = sourceToken.getSource()
|
|
config.cancelToken = source.token
|
|
if (config && config.params) {
|
|
config.params.response = 'json'
|
|
const project = vueProps.$localStorage.get(CURRENT_PROJECT)
|
|
if (!config.params.projectid && !config.params.ignoreproject && project && project.id) {
|
|
if (config.params.command === 'listTags') {
|
|
config.params.projectid = '-1'
|
|
} else if (config.params.command !== 'assignVirtualMachine') {
|
|
config.params.projectid = project.id
|
|
}
|
|
}
|
|
if (config.params.ignoreproject !== undefined) {
|
|
config.params.ignoreproject = null
|
|
}
|
|
}
|
|
return config
|
|
}, err)
|
|
|
|
// response interceptor
|
|
service.interceptors.response.use((response) => {
|
|
return response.data
|
|
}, err)
|
|
|
|
const installer = {
|
|
vm: {},
|
|
install (app) {
|
|
app.use(VueAxios, service)
|
|
}
|
|
}
|
|
|
|
const sourceToken = {
|
|
init: () => { source = axios.CancelToken.source() },
|
|
isCancel: (e) => {
|
|
return axios.isCancel(e)
|
|
},
|
|
checkExistSource: () => {
|
|
return source
|
|
},
|
|
getSource: () => {
|
|
if (!source) sourceToken.init()
|
|
return source
|
|
},
|
|
cancel: () => {
|
|
if (!source) sourceToken.init()
|
|
if (source) {
|
|
source.cancel()
|
|
source = null
|
|
} else {
|
|
console.log('Source token failed to be cancelled')
|
|
}
|
|
}
|
|
}
|
|
|
|
export {
|
|
installer as VueAxios,
|
|
service as axios,
|
|
sourceToken
|
|
}
|