import axios from 'axios' import { CURRENT_CONFIG } from './config' import { message } from 'ant-design-vue' import router from '/@/router' import { ELocalStorageKey, ERouterName, EUserType } from '/@/types/enums' export * from './type' const REQUEST_ID = 'X-Request-Id' export const getHeaders = () => { const headers: { 'x-auth-token'?: string, } = {}; const token = localStorage.getItem(ELocalStorageKey.Token) if (token) { headers['x-auth-token'] = token; } return headers; }; const instance = axios.create({ headers: { 'Content-Type': 'application/json', }, }) instance.interceptors.request.use( config => { config.headers = getHeaders(); config.baseURL = '/api'; return config }, error => { return Promise.reject(error) }, ) instance.interceptors.response.use( response => { if (response.data.code && response.data.code !== 0) { message.error(response.data.message) } return response }, err => { const requestId = err?.config?.headers && err?.config?.headers[REQUEST_ID] if (requestId) { console.info(REQUEST_ID, ':', requestId) } let description = '-' if (err.response?.data && err.response.data.message) { description = err.response.data.message } if (err.response?.data && err.response.data.result) { description = err.response.data.result.message } // @See: https://github.com/axios/axios/issues/383 if (!err.response || !err.response.status) { message.error('服务异常') return } if (err.response?.status !== 200) { message.error(`ERROR_CODE: ${err.response?.status}`) } // if (err.response?.status === 403) { // // window.location.href = '/' // } if (err.response?.status === 401) { console.error(err.response) const flag: number = Number(localStorage.getItem(ELocalStorageKey.Flag)) switch (flag) { case EUserType.Web: router.push(ERouterName.PROJECT) break case EUserType.Pilot: router.push(ERouterName.PILOT) break } } return Promise.reject(err) }, ) export default instance