Files
SIG-CM/frontend/counter-panel/src/services/api.ts

40 lines
1.1 KiB
TypeScript
Raw Normal View History

2025-12-18 13:32:50 -03:00
import axios from 'axios';
const api = axios.create({
2025-12-23 15:12:57 -03:00
// Asegúrate de usar la variable de entorno o la URL correcta
baseURL: import.meta.env.VITE_API_URL || 'http://localhost:5176/api',
2025-12-18 13:32:50 -03:00
});
2025-12-23 15:12:57 -03:00
// 1. Interceptor de REQUEST: Pega el token
2025-12-18 13:32:50 -03:00
api.interceptors.request.use((config) => {
const token = localStorage.getItem('token');
if (token) {
config.headers.Authorization = `Bearer ${token}`;
}
return config;
});
2025-12-23 15:12:57 -03:00
// 2. Interceptor de RESPONSE: Maneja errores globales (como 401)
api.interceptors.response.use(
(response) => {
return response;
},
(error) => {
// Si el error es 401 (Token vencido o inválido)
if (error.response && error.response.status === 401) {
console.warn("Sesión de caja expirada. Redirigiendo...");
// Limpiar almacenamiento
localStorage.removeItem('token');
localStorage.removeItem('user');
// Redirigir al Login (forzado fuera de React Router para limpiar estado)
if (window.location.pathname !== '/login') {
window.location.href = '/login';
}
}
return Promise.reject(error);
}
);
2025-12-18 13:32:50 -03:00
export default api;