43 lines
1.2 KiB
TypeScript
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
|