| import axios from 'axios'; | |
| const api = axios.create({ | |
| baseURL: import.meta.env.VITE_API_URL || '/api/', | |
| headers: { | |
| 'Content-Type': 'application/json', | |
| }, | |
| }); | |
| api.interceptors.request.use( | |
| (config) => { | |
| const token = localStorage.getItem('access_token'); | |
| if (token) { | |
| config.headers['Authorization'] = `Bearer ${token}`; | |
| } | |
| return config; | |
| }, | |
| (error) => Promise.reject(error) | |
| ); | |
| api.interceptors.response.use( | |
| (response) => response, | |
| async (error) => { | |
| const originalRequest = error.config; | |
| if (error.response.status === 401 && !originalRequest._retry) { | |
| originalRequest._retry = true; | |
| try { | |
| const refreshToken = localStorage.getItem('refresh_token'); | |
| const response = await axios.post('/api/auth/token/refresh/', { | |
| refresh: refreshToken | |
| }); | |
| const { access } = response.data; | |
| localStorage.setItem('access_token', access); | |
| api.defaults.headers.common['Authorization'] = `Bearer ${access}`; | |
| return api(originalRequest); | |
| } catch (err) { | |
| // Logout user if refresh fails | |
| localStorage.removeItem('access_token'); | |
| localStorage.removeItem('refresh_token'); | |
| window.location.href = '/'; | |
| } | |
| } | |
| return Promise.reject(error); | |
| } | |
| ); | |
| export default api; | |