quivr/frontend/lib/hooks/useAxios.ts
Mamadou DICKO 68642afbb8
Frontend/test/chat 2 (#516)
* feat: add chat api

* refactor(MicButton): move related hook

* feat: add nock http call example

* test(useChatApi): add unit tests
2023-07-05 13:33:26 +02:00

36 lines
1010 B
TypeScript

import axios, { AxiosError, AxiosInstance } from "axios";
import { useBrainConfig } from "@/lib/context/BrainConfigProvider";
import { useSupabase } from "@/lib/context/SupabaseProvider";
import { DEFAULT_BACKEND_URL } from "../config/CONSTANTS";
const axiosInstance = axios.create({
baseURL: `${process.env.NEXT_PUBLIC_BACKEND_URL ?? DEFAULT_BACKEND_URL}`,
});
export const useAxios = (): { axiosInstance: AxiosInstance } => {
const { session } = useSupabase();
const {
config: { backendUrl, openAiKey },
} = useBrainConfig();
axiosInstance.interceptors.request.clear();
axiosInstance.interceptors.request.use(
(config) => {
config.headers["Authorization"] = `Bearer ${session?.access_token ?? ""}`;
config.headers["Openai-Api-Key"] = openAiKey;
config.baseURL = backendUrl ?? config.baseURL;
return config;
},
(error: AxiosError) => {
console.error({ error });
void Promise.reject(error);
}
);
return {
axiosInstance,
};
};