You can add a mutator function to your config and setup a custom instance of your prefered HTTP client.
module.exports = {petstore: {output: {...override: {mutator: {path: './api/mutator/custom-instance.ts',name: 'customInstance',},},}...},};
// custom-instance.tsconst baseURL = '<BACKEND URL>'; // use your own URL here or environment variableexport const customInstance = async <T>({url,method,params,data,}: {url: string;method: 'get' | 'post' | 'put' | 'delete' | 'patch';params?: any;data?: BodyType<unknown>;responseType?: string;}): Promise<T> => {const response = await fetch(`${baseURL}${url}` + new URLSearchParams(params),{method,...(data ? { body: JSON.stringify(data) } : {}),},);return response.json();};export default customInstance;// In some case with react-query and swr you want to be able to override the return error type so you can also do it here like thisexport type ErrorType<Error> = AxiosError<Error>;// In case you want to wrap the body type (optional)// (if the custom instance is processing data before sending it, like changing the case for example)export type BodyType<BodyData> = CamelCase<BodyType>;