|
|
@ -12,15 +12,45 @@ const service = axios.create({
|
|
|
|
withCredentials: true
|
|
|
|
withCredentials: true
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
function setTokenToHeader(config) {
|
|
|
|
|
|
|
|
// set token
|
|
|
|
|
|
|
|
const token = store.getters.token
|
|
|
|
|
|
|
|
Vue.$log.debug('Got token from store', token)
|
|
|
|
|
|
|
|
if (token && token.access_token) {
|
|
|
|
|
|
|
|
config.headers['Admin-Authorization'] = token.access_token
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async function reRequest(error) {
|
|
|
|
|
|
|
|
const config = error.response.config
|
|
|
|
|
|
|
|
setTokenToHeader(config)
|
|
|
|
|
|
|
|
const res = await axios.request(config)
|
|
|
|
|
|
|
|
return res
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
let refreshTask = null
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
async function refreshToken(error) {
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
if (refreshTask === null) {
|
|
|
|
|
|
|
|
refreshTask = store.dispatch('refreshToken', store.getters.token.refresh_token)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
await refreshTask
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
refreshTask = null
|
|
|
|
|
|
|
|
} catch (err) {
|
|
|
|
|
|
|
|
Vue.$log.error('Failed to refresh token', err)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
// Rerequest the request
|
|
|
|
|
|
|
|
return reRequest(error)
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
service.interceptors.request.use(
|
|
|
|
service.interceptors.request.use(
|
|
|
|
config => {
|
|
|
|
config => {
|
|
|
|
NProgress.start()
|
|
|
|
NProgress.start()
|
|
|
|
// TODO set token
|
|
|
|
// TODO set token
|
|
|
|
const token = store.getters.token
|
|
|
|
setTokenToHeader(config)
|
|
|
|
Vue.$log.debug('Got token from store', token)
|
|
|
|
|
|
|
|
if (token && token.access_token) {
|
|
|
|
|
|
|
|
config.headers['Admin-Authorization'] = token.access_token
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
return config
|
|
|
|
return config
|
|
|
|
},
|
|
|
|
},
|
|
|
|
error => {
|
|
|
|
error => {
|
|
|
@ -57,11 +87,10 @@ service.interceptors.response.use(
|
|
|
|
} else if (data.status === 401) {
|
|
|
|
} else if (data.status === 401) {
|
|
|
|
// TODO handle 401 status error
|
|
|
|
// TODO handle 401 status error
|
|
|
|
if (store.getters.token && store.getters.token.access_token === data.data) {
|
|
|
|
if (store.getters.token && store.getters.token.access_token === data.data) {
|
|
|
|
// Token expired
|
|
|
|
const res = refreshToken(error)
|
|
|
|
// TODO Refresh token
|
|
|
|
if (res !== error) {
|
|
|
|
store.dispatch('refreshToken', store.getters.token.refresh_token).then(response => {
|
|
|
|
return res
|
|
|
|
Vue.$log.debug('Refresh token successfully')
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
// Login
|
|
|
|
// Login
|
|
|
|
router.push({ name: 'Login' })
|
|
|
|
router.push({ name: 'Login' })
|
|
|
|