hrms-checkin/src/plugins/http.ts

43 lines
1.2 KiB
TypeScript

import Axios, { type AxiosRequestConfig, type AxiosResponse } from 'axios'
import { getToken } from './auth'
const http = Axios.create({
timeout: 30000, // 30 seconds - reasonable timeout for API calls
headers: {
'X-Requested-With': 'XMLHttpRequest',
},
})
http.interceptors.request.use(
async function (config: AxiosRequestConfig<any>) {
config.headers = config.headers ?? {}
const token = await getToken()
if (token) config.headers.Authorization = `Bearer ${token}`
return config
},
function (error: any) {
return Promise.reject(error)
}
)
http.interceptors.response.use(
function (response: AxiosResponse<any, any>) {
return response
},
function (error: any) {
if (typeof error !== undefined) {
// eslint-disable-next-line no-prototype-builtins
if (error.hasOwnProperty('response')) {
if (error.response.status === 401 || error.response.status === 403) {
// TODO: Implement proper logout logic on 401/403
// Store.commit("SET_ERROR_MESSAGE", error.response.data.message);
// Store.commit("REMOVE_ACCESS_TOKEN")
}
}
}
return Promise.reject(error)
}
)
export default http