import { BACKEND_ERROR_CODE, createFlatRequest } from '@sa/axios'; import { useAuthStore } from '@/store/modules/auth'; import { localStg } from '@/utils/storage'; import { getServiceBaseURL } from '@/utils/service'; import { $t } from '@/locales'; import { clearAuthStorage } from '@/store/modules/auth/shared'; const isHttpProxy = import.meta.env.DEV && import.meta.env.VITE_HTTP_PROXY === 'Y'; const { baseURL } = getServiceBaseURL(import.meta.env, isHttpProxy); interface InstanceState { /** whether the request is refreshing token */ isRefreshingToken: boolean; } export const request = createFlatRequest( { baseURL, 'axios-retry': { retries: 0 } }, { async onRequest(config) { const { headers } = config; // set token const token = localStg.get('token'); const Authorization = token ? `Bearer ${token}` : null; // set language const ContentLanguage = localStg.get('lang') || 'zh-CN'; Object.assign(headers, { Authorization, "Content-Language": ContentLanguage }); return config; }, isBackendSuccess(response) { // when the backend response code is "0000"(default), it means the request is success // to change this logic by yourself, you can modify the `VITE_SERVICE_SUCCESS_CODE` in `.env` file return String(response.data.code) === import.meta.env.VITE_SERVICE_SUCCESS_CODE; }, async onBackendFail(response, _instance) { const authStore = useAuthStore(); function handleLogout() { authStore.resetStore(); } function logoutAndCleanup() { handleLogout(); window.removeEventListener('beforeunload', handleLogout); } // when the backend response code is in `logoutCodes`, it means the user will be logged out and redirected to login page const logoutCodes = import.meta.env.VITE_SERVICE_LOGOUT_CODES?.split(',') || []; if (logoutCodes.includes(String(response.data.code))) { handleLogout(); return null; } // when the backend response code is in `modalLogoutCodes`, it means the user will be logged out by displaying a modal const modalLogoutCodes = import.meta.env.VITE_SERVICE_MODAL_LOGOUT_CODES?.split(',') || []; if (modalLogoutCodes.includes(String(response.data.code))) { // prevent the user from refreshing the page window.addEventListener('beforeunload', handleLogout); $modal?.error({ title: 'Error', content: response.data.msg, okText: $t('common.confirm'), maskClosable: false, onOk() { logoutAndCleanup(); }, onCancel() { logoutAndCleanup(); } }); return null; } // when the backend response code is in `expiredTokenCodes`, it means the token is expired, and refresh token // the api `refreshToken` can not return error code in `expiredTokenCodes`, otherwise it will be a dead loop, should return `logoutCodes` or `modalLogoutCodes` // eslint-disable-next-line no-warning-comments // TODO: fix when back code is 403 the page redirect to login // const expiredTokenCodes = import.meta.env.VITE_SERVICE_EXPIRED_TOKEN_CODES?.split(',') || []; // if (expiredTokenCodes.includes(String(response.data.code)) && !request.state.isRefreshingToken) { // request.state.isRefreshingToken = true; // const refreshConfig = await handleRefreshToken(response.config); // request.state.isRefreshingToken = false; // if (refreshConfig) { // return instance.request(refreshConfig) as Promise; // } // } return null; }, transformBackendResponse(response) { return response.data.data; }, onError(error) { // when the request is fail, you can show error message let message = error.message; let backendErrorCode = ''; // get backend error message and code if (error.code === BACKEND_ERROR_CODE) { message = error.response?.data?.msg || message; backendErrorCode = error.response?.data?.code || ''; } // the error message is displayed in the modal const modalLogoutCodes = import.meta.env.VITE_SERVICE_MODAL_LOGOUT_CODES?.split(',') || []; if (modalLogoutCodes.includes(backendErrorCode)) { return; } // when the token is expired, refresh token and retry request, so no need to show error message const expiredTokenCodes = import.meta.env.VITE_SERVICE_EXPIRED_TOKEN_CODES?.split(',') || []; if (expiredTokenCodes.includes(backendErrorCode)) { return; } if (backendErrorCode === import.meta.env.VITE_SERVICE_SERVER_ERROR_CODE) { clearAuthStorage(); return; } $message?.error?.(message); } } );