73 lines
2.0 KiB
TypeScript
73 lines
2.0 KiB
TypeScript
import axios from "axios";
|
|
import Cookies from "js-cookie";
|
|
import { getCsrfToken, login } from "../auth";
|
|
|
|
// Use environment variable for API URL, default to localhost:8080 for local development
|
|
const baseURL = process.env.NEXT_PUBLIC_API_URL || "http://localhost:8080/api/";
|
|
|
|
const refreshToken = Cookies.get("refresh_token");
|
|
|
|
const axiosInterceptorInstance = axios.create({
|
|
baseURL,
|
|
headers: {
|
|
"content-type": "application/json",
|
|
"X-Client-Key": "b1ce6602-07ad-46c2-85eb-0cd6decfefa3",
|
|
},
|
|
withCredentials: true,
|
|
});
|
|
|
|
// Request interceptor
|
|
axiosInterceptorInstance.interceptors.request.use(
|
|
(config) => {
|
|
const accessToken = Cookies.get("access_token");
|
|
if (accessToken) {
|
|
if (config.headers)
|
|
config.headers.Authorization = "Bearer " + accessToken;
|
|
}
|
|
return config;
|
|
},
|
|
(error) => {
|
|
return Promise.reject(error);
|
|
}
|
|
);
|
|
|
|
// Response interceptor
|
|
axiosInterceptorInstance.interceptors.response.use(
|
|
(response) => {
|
|
console.log("Response interceptor : ", response);
|
|
return response;
|
|
},
|
|
async function (error) {
|
|
console.log("Error interceptor : ", error.response.status);
|
|
const originalRequest = error.config;
|
|
if (error.response.status === 401 && !originalRequest._retry) {
|
|
originalRequest._retry = true;
|
|
const data = {
|
|
grantType: "refresh_token",
|
|
refreshToken: refreshToken,
|
|
clientId: "mediahub-app",
|
|
};
|
|
console.log("refresh token ", data);
|
|
const res = await login(data);
|
|
if (res?.error) {
|
|
Object.keys(Cookies.get()).forEach((cookieName) => {
|
|
Cookies.remove(cookieName);
|
|
});
|
|
} else {
|
|
const { access_token } = res?.data;
|
|
const { refresh_token } = res?.data;
|
|
if (access_token) {
|
|
Cookies.set("access_token", access_token);
|
|
Cookies.set("refresh_token", refresh_token);
|
|
}
|
|
}
|
|
|
|
return axiosInterceptorInstance(originalRequest);
|
|
}
|
|
|
|
return Promise.reject(error);
|
|
}
|
|
);
|
|
|
|
export default axiosInterceptorInstance;
|