47 lines
1.1 KiB
TypeScript
47 lines
1.1 KiB
TypeScript
import axios from 'axios';
|
||
|
||
// API Base URL
|
||
export const API_BASE_URL = import.meta.env.VITE_API_URL;
|
||
|
||
// Axios instance
|
||
export const apiClient = axios.create({
|
||
baseURL: API_BASE_URL,
|
||
headers: {
|
||
'Content-Type': 'application/json',
|
||
},
|
||
});
|
||
|
||
// Request interceptor - Add auth token and tenant header
|
||
apiClient.interceptors.request.use(
|
||
(config) => {
|
||
const token = localStorage.getItem('access_token');
|
||
if (token) {
|
||
config.headers.Authorization = `Bearer ${token}`;
|
||
}
|
||
|
||
// UI uygulaması gibi tenant header'ı ekle
|
||
const tenantId = localStorage.getItem('tenant_id');
|
||
if (tenantId) {
|
||
config.headers['__tenant'] = tenantId;
|
||
}
|
||
|
||
return config;
|
||
},
|
||
(error) => {
|
||
return Promise.reject(error);
|
||
}
|
||
);
|
||
|
||
// Response interceptor - Handle errors
|
||
apiClient.interceptors.response.use(
|
||
(response) => response,
|
||
async (error) => {
|
||
if (error.response?.status === 401) {
|
||
// Token expired or invalid
|
||
localStorage.removeItem('access_token');
|
||
localStorage.removeItem('current_user');
|
||
window.location.href = '/login';
|
||
}
|
||
return Promise.reject(error);
|
||
}
|
||
);
|