You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

37 lines
973 B

4 weeks ago
import axios from 'axios';
import { getToken, setToken } from './token';
4 weeks ago
export const api = axios.create({
baseURL: process.env.NEXT_PUBLIC_API_BASE_URL,
});
api.interceptors.request.use((config) => {
const t = getToken();
if (t) {
config.headers = config.headers ?? {};
config.headers.Authorization = `Bearer ${t}`;
4 weeks ago
return config;
}
4 weeks ago
if (config.headers && 'Authorization' in config.headers) {
4 weeks ago
delete config.headers.Authorization;
4 weeks ago
}
return config;
});
api.interceptors.response.use(
(res) => res,
(error) => {
4 weeks ago
const url: string | undefined = error?.config?.url;
4 weeks ago
const isAuthRoute = url?.includes('/auth/login') || url?.includes('/auth/signup');
if (error?.response?.status === 401 && typeof window !== 'undefined' && !isAuthRoute) {
4 weeks ago
setToken(null); // 토큰 파기
4 weeks ago
window.location.href = '/login'; // 전역 리다이렉트
4 weeks ago
}
return Promise.reject(error);
4 weeks ago
},
4 weeks ago
);