import axios, { AxiosResponse, Method } from "axios"; interface MakeRequestArgs { method?: Method; url: string; body?: T; /** Send access token */ useToken?: boolean; contentType?: boolean; signal?: AbortSignal; /** Send refresh token */ withCredentials?: boolean; } export const createMakeRequest = (getToken: () => string, setToken: (token: string) => void) => async ({ method = "post", url, body, useToken = true, contentType = false, signal, withCredentials, }: MakeRequestArgs): Promise => { const headers: Record = {}; if (useToken) headers["Authorization"] = `Bearer ${getToken()}`; if (contentType) headers["Content-Type"] = "application/json"; try { const response = await axios>({ url, method, headers, data: body, signal, withCredentials, }); if (response.data?.accessToken) { setToken(response.data.accessToken); } return response.data; } catch (error) { if (axios.isAxiosError(error) && error.response?.status === 401 && !withCredentials) { const refreshResponse = await refresh(getToken()); if (refreshResponse.data?.accessToken) setToken(refreshResponse.data.accessToken); headers["Authorization"] = refreshResponse.data.accessToken; const response = await axios.request>({ url, method, headers, data: body, signal, }); return response.data; } throw error; } }; function refresh(token: string) { return axios>("https://admin.pena.digital/auth/refresh", { headers: { "Authorization": token, "Content-Type": "application/json", }, }); }