@zayne-labs/callapi 1.3.3 → 1.3.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,17 @@
1
+ type ErrorDetails<TErrorResponse> = {
2
+ defaultErrorMessage: string;
3
+ errorData: TErrorResponse;
4
+ response: Response;
5
+ };
6
+ type ErrorOptions = {
7
+ cause?: unknown;
8
+ };
9
+ declare class HTTPError<TErrorResponse = Record<string, unknown>> extends Error {
10
+ errorData: ErrorDetails<TErrorResponse>["errorData"];
11
+ isHTTPError: boolean;
12
+ name: "HTTPError";
13
+ response: ErrorDetails<TErrorResponse>["response"];
14
+ constructor(errorDetails: ErrorDetails<TErrorResponse>, errorOptions?: ErrorOptions);
15
+ }
16
+
17
+ export { HTTPError as H };
@@ -1 +1 @@
1
- "use strict";var e,r=Object.defineProperty,t=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,s=Object.prototype.hasOwnProperty,n={};((e,t)=>{for(var o in t)r(e,o,{get:t[o],enumerable:!0})})(n,{callApi:()=>H,createFetchClient:()=>A,definePlugin:()=>j}),module.exports=(e=n,((e,n,a,i)=>{if(n&&"object"==typeof n||"function"==typeof n)for(let l of o(n))s.call(e,l)||l===a||r(e,l,{get:()=>n[l],enumerable:!(i=t(n,l))||i.enumerable});return e})(r({},"__esModule",{value:!0}),e));var a=e=>Array.isArray(e),i=e=>{if(!(e=>"object"==typeof e&&null!==e)(e))return!1;const r=Object.getPrototypeOf(e);return(null==r||r===Object.prototype||null===Object.getPrototypeOf(r))&&!(Symbol.toStringTag in e)},l=e=>"function"==typeof e,u=e=>"string"==typeof e,c=e=>l(e)?e():e,p=e=>{if(void 0!==e){if(u(e)||null===e)return{Authorization:`Bearer ${e}`};switch(e.type){case"Basic":{const r=c(e.username),t=c(e.password);if(void 0===r||void 0===t)return;return{Authorization:`Basic ${globalThis.btoa(`${r}:${t}`)}`}}case"Custom":{const r=c(e.value);if(void 0===r)return;return{Authorization:`${c(e.prefix)} ${r}`}}default:{const r=c(e.bearer),t=c(e.token);return"token"in e&&void 0!==t?{Authorization:`Token ${t}`}:void 0!==r&&{Authorization:`Bearer ${r}`}}}}},d=["extend","dedupeKey"],f=["body","integrity","method","headers","signal","cache","redirect","window","credentials","keepalive","referrer","priority","mode","referrerPolicy"],y={408:"Request Timeout",409:"Conflict",425:"Too Early",429:"Too Many Requests",500:"Internal Server Error",502:"Bad Gateway",503:"Service Unavailable",504:"Gateway Timeout"},m=["GET","POST"],g=Object.keys(y).map(Number),w=(e,r)=>{const t={},o=new Set(r);for(const[r,s]of Object.entries(e))o.has(r)||(t[r]=s);return t},h=(e,r)=>{const t={},o=new Set(r);for(const[r,s]of Object.entries(e))o.has(r)&&(t[r]=s);return t},b=e=>!e||i(e)?e:Object.fromEntries(e),E=e=>{const{auth:r,baseHeaders:t,body:o,headers:s}=e;if(!Boolean(t||s||o||r))return;const n={...p(r),...b(t),...b(s)};return u(a=o)&&a.includes("=")?(n["Content-Type"]="application/x-www-form-urlencoded",n):((i(o)||u(o)&&o.startsWith("{"))&&(n["Content-Type"]="application/json",n.Accept="application/json"),n);var a},R=(...e)=>Promise.all(e),S=async(e,r,t,o)=>{const s=((e,r)=>({arrayBuffer:()=>e.arrayBuffer(),blob:()=>e.blob(),formData:()=>e.formData(),json:async()=>{if(r){const t=await e.text();return r(t)}return e.json()},stream:()=>e.body,text:()=>e.text()}))(e,t);if(!Object.hasOwn(s,r))throw new Error(`Invalid response type: ${r}`);const n=await s[r]();return o?o(n):n},O=e=>{const{defaultErrorMessage:r,error:t,message:o,resultMode:s}=e;let n={data:null,error:{errorData:t,message:o??t.message,name:t.name},response:null};if(v(t)){const{errorData:e,message:o=r,name:s,response:a}=t;n={data:null,error:{errorData:e,message:o,name:s},response:a}}return{apiDetails:n,generalErrorResult:{all:n,onlyError:n.error,onlyResponse:n.response,onlySuccess:n.data,onlySuccessWithException:n.data}[s??"all"],resolveCustomErrorInfo:({message:r})=>O({...e,message:r}).generalErrorResult}},q=class extends Error{errorData;isHTTPError=!0;name="HTTPError";response;constructor(e,r){const{defaultErrorMessage:t,errorData:o,response:s}=e;super(o?.message??t,r),this.errorData=o,this.response=s,Error.captureStackTrace(this,this.constructor)}},v=e=>e instanceof q||i(e)&&"HTTPError"===e.name&&!0===e.isHTTPError,T=e=>{if(0===e)return;const{promise:r,resolve:t}=(()=>{let e,r;return{promise:new Promise(((t,o)=>{r=t,e=o})),reject:e,resolve:r}})();return setTimeout(t,e),r},M=(e,r,t,o)=>{const s=(e=>{if(e)return e;if("undefined"!=typeof globalThis&&l(globalThis.fetch))return globalThis.fetch;throw new Error("No fetch implementation found")})(r.customFetchImpl);return o&&"defer"===r.dedupeStrategy?o.responsePromise:s(e,t)},j=e=>e,P=(e,r)=>async t=>{if("sequential"!==r){if("parallel"===r){const r=[...e];await Promise.all(r.map((e=>e?.(t))))}}else for(const r of e)await(r?.(t))},$={onError:new Set,onRequest:new Set,onRequestError:new Set,onResponse:new Set,onResponseError:new Set,onRetry:new Set,onSuccess:new Set},k=(e,r)=>{const t=e.retryCount??0;return{getDelay:()=>"exponential"===e.retryStrategy?((e,r)=>{const t=r.retryMaxDelay??1e4,o=(r.retryDelay??1e3)*2**e;return Math.min(o,t)})(t,e):(e=>e.retryDelay??1e3)(e),shouldAttemptRetry:async()=>{const o=await(e.retryCondition?.(r))??!0,s=(e.retryAttempts??0)>t&&o;if("HTTPError"!==r.error.name)return s;const n=!!r.request.method&&e.retryMethods?.includes(r.request.method);return!!r.response?.status&&e.retryStatusCodes?.includes(r.response.status)&&n&&s}}},D=(e,r)=>{if(!r)return e;const t=(o=r)?new URLSearchParams(o).toString():(console.error("toQueryString:","No query params provided!"),null);var o;return 0===t?.length?e:e.endsWith("?")?`${e}${t}`:e.includes("?")?`${e}&${t}`:`${e}?${t}`},x=(e,r,t)=>{const o=((e,r)=>{if(!r)return e;let t=e;if(a(r)){const e=t.split("/").filter((e=>e.startsWith(":")));for(const[o,s]of e.entries()){const e=r[o];t=t.replace(s,e)}return t}for(const[e,o]of Object.entries(r))t=t.replace(`:${e}`,String(o));return t})(e,r);return D(o,t)},A=(e={})=>{const[r,t]=(e=>[h(e,f),w(e,[...f,...d])])(e),{body:o,headers:s,signal:n,...c}=r,p=new Map,y=async(...e)=>{const[r,d={}]=e,[b,j]=(e=>[h(e,f),w(e,f)])(d),{body:D=o,headers:A,signal:H=n,...C}=b,U={};for(const e of Object.keys($)){const r=(L=t[e],B=j[e],a(L)?[L,B].flat():B??L);U[e]=r}var L,B;const z={baseURL:"",bodySerializer:JSON.stringify,dedupeStrategy:"cancel",defaultErrorMessage:"Failed to fetch data from server!",mergedHooksExecutionMode:"parallel",mergedHooksExecutionOrder:"mainHooksAfterPlugins",responseType:"json",resultMode:"all",retryAttempts:0,retryDelay:1e3,retryMaxDelay:1e4,retryMethods:m,retryStatusCodes:g,retryStrategy:"linear",...t,...j,...U},{resolvedHooks:N,resolvedOptions:I,resolvedRequestOptions:W,url:G}=await(async e=>{const{initURL:r,options:t,request:o}=e,s=structuredClone($),n=()=>{for(const e of Object.keys($)){const r=t[e];s[e].add(r)}},a=e=>{for(const r of Object.keys($)){const t=e[r];s[r].add(t)}};"mainHooksBeforePlugins"===t.mergedHooksExecutionOrder&&n();const c=e=>e?l(e)?e({initURL:r,options:t,request:o}):e:[],p=[...c(t.plugins),...c(t.extend?.plugins)];let d=r,f=t,y=o;const m=async e=>{if(!e)return;const s=await e({initURL:r,options:t,request:o});i(s)&&(u(s.initURL)&&(d=s.initURL),i(s.request)&&(y=s.request),i(s.options)&&(f=s.options))};for(const e of p)await m(e.init),e.hooks&&a(e.hooks);t.mergedHooksExecutionOrder&&"mainHooksAfterPlugins"!==t.mergedHooksExecutionOrder||n();const g={};for(const[e,r]of Object.entries(s)){const o=[...r].flat(),s=P(o,t.mergedHooksExecutionMode);g[e]=s}return{resolvedHooks:g,resolvedOptions:f,resolvedRequestOptions:y,url:d}})({initURL:r,options:z,request:{...c,...C}}),K=`${I.baseURL}${x(G,I.params,I.query)}`,F={...I,...N,fullURL:K,initURL:r},J={body:i(D)?F.bodySerializer(D):D,method:"GET",...W},V=new AbortController,_=null!=F.timeout?(Q=F.timeout,AbortSignal.timeout(Q)):null;var Q;const X=((...e)=>AbortSignal.any(e.filter(Boolean)))(V.signal,_,H),Y={signal:X,...J},Z=F.dedupeKey??((e,r,t)=>"cancel"===t.dedupeStrategy||"defer"===t.dedupeStrategy?`${t.fullURL}-${JSON.stringify({options:t,request:r})}`:null)(0,Y,F);null!==Z&&await T(.1);const ee=null!==Z?p:null,re=ee?.get(Z);((e,r,t)=>{if(t&&"cancel"===r.dedupeStrategy){const e=r.dedupeKey?`Duplicate request detected - Aborting previous request with key '${r.dedupeKey}' as a new request was initiated`:`Duplicate request detected - Aborting previous request to '${r.fullURL}' as a new request with identical options was initiated`,o=new DOMException(e,"AbortError");t.controller.abort(o)}})(0,F,re);try{await R(F.onRequest({options:F,request:Y})),Y.headers=E({auth:F.auth,baseHeaders:s??A,body:D,headers:Y.headers});const e=M(K,F,Y,re);ee?.set(Z,{controller:V,responsePromise:e});const r=await e,t="defer"===F.dedupeStrategy||F.cloneResponse;if(!r.ok){const e=await S(t?r.clone():r,F.responseType,F.responseParser,F.responseErrorValidator);throw new q({defaultErrorMessage:F.defaultErrorMessage,errorData:e,response:r})}const o=await S(t?r.clone():r,F.responseType,F.responseParser,F.responseValidator);return await R(F.onSuccess({data:o,options:F,request:Y,response:F.cloneResponse?r.clone():r}),F.onResponse({data:o,error:null,options:F,request:Y,response:F.cloneResponse?r.clone():r})),await(e=>{const{data:r,response:t,resultMode:o}=e,s={data:r,error:null,response:t};return o?{all:s,onlyError:s.error,onlyResponse:s.response,onlySuccess:s.data,onlySuccessWithException:s.data}[o]:s})({data:o,response:r,resultMode:F.resultMode})}catch(e){const{apiDetails:t,generalErrorResult:o,resolveCustomErrorInfo:s}=O({defaultErrorMessage:F.defaultErrorMessage,error:e,resultMode:F.resultMode}),n={error:t.error,options:F,request:Y,response:t.response},{getDelay:a,shouldAttemptRetry:i}=k(F,n);if(!X.aborted&&await i()){await R(F.onRetry(n));const e=a();await T(e);const t={...d,retryCount:(F.retryCount??0)+1};return await y(r,t)}const u=l(F.throwOnError)?F.throwOnError(n):F.throwOnError,c=()=>{if(u)throw t.error};if(v(e)){const{response:r}=e,t=o.error;return await R(F.onResponseError({error:t,options:F,request:Y,response:F.cloneResponse?r.clone():r}),F.onError({error:t,options:F,request:Y,response:F.cloneResponse?r.clone():r}),F.onResponse({data:null,error:t,options:F,request:Y,response:F.cloneResponse?r.clone():r})),c(),o}if(e instanceof DOMException&&"AbortError"===e.name){const{message:r,name:t}=e;return console.error(`${t}:`,r),c(),o}if(e instanceof DOMException&&"TimeoutError"===e.name){const r=`Request timed out after ${F.timeout}ms`;return console.error(`${e.name}:`,r),c(),s({message:r})}const p=o.error;return await R(F.onRequestError({error:p,options:F,request:Y}),F.onError({error:p,options:F,request:Y,response:null})),c(),o}finally{ee?.delete(Z)}};return y.create=A,y},H=A();//# sourceMappingURL=index.cjs.map
1
+ "use strict";var e,r=Object.defineProperty,t=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,s=Object.prototype.hasOwnProperty,n={};((e,t)=>{for(var o in t)r(e,o,{get:t[o],enumerable:!0})})(n,{HTTPError:()=>a,callApi:()=>C,createFetchClient:()=>A,definePlugin:()=>M}),module.exports=(e=n,((e,n,a,i)=>{if(n&&"object"==typeof n||"function"==typeof n)for(let l of o(n))s.call(e,l)||l===a||r(e,l,{get:()=>n[l],enumerable:!(i=t(n,l))||i.enumerable});return e})(r({},"__esModule",{value:!0}),e));var a=class extends Error{errorData;isHTTPError=!0;name="HTTPError";response;constructor(e,r){const{defaultErrorMessage:t,errorData:o,response:s}=e;super(o?.message??t,r),this.errorData=o,this.response=s,Error.captureStackTrace(this,this.constructor)}},i=e=>e instanceof a||c(e)&&"HTTPError"===e.name&&!0===e.isHTTPError,l=e=>Array.isArray(e),u=e=>"object"==typeof e&&null!==e,c=e=>{if(!u(e))return!1;const r=Object.getPrototypeOf(e);return(null==r||r===Object.prototype||null===Object.getPrototypeOf(r))&&!(Symbol.toStringTag in e)},d=e=>"function"==typeof e,p=e=>"string"==typeof e,y=e=>d(e)?e():e,f=e=>{if(void 0!==e){if(p(e)||null===e)return{Authorization:`Bearer ${e}`};switch(e.type){case"Basic":{const r=y(e.username),t=y(e.password);if(void 0===r||void 0===t)return;return{Authorization:`Basic ${globalThis.btoa(`${r}:${t}`)}`}}case"Custom":{const r=y(e.value);if(void 0===r)return;return{Authorization:`${y(e.prefix)} ${r}`}}default:{const r=y(e.bearer),t=y(e.token);return"token"in e&&void 0!==t?{Authorization:`Token ${t}`}:void 0!==r&&{Authorization:`Bearer ${r}`}}}}},m=["extend","dedupeKey"],h=["body","integrity","method","headers","signal","cache","redirect","window","credentials","keepalive","referrer","priority","mode","referrerPolicy"],g={408:"Request Timeout",409:"Conflict",425:"Too Early",429:"Too Many Requests",500:"Internal Server Error",502:"Bad Gateway",503:"Service Unavailable",504:"Gateway Timeout"},w=["GET","POST"],b=Object.keys(g).map(Number),E=(e,r)=>{const t={},o=new Set(r);for(const[r,s]of Object.entries(e))o.has(r)||(t[r]=s);return t},R=(e,r)=>{const t={},o=new Set(r);for(const[r,s]of Object.entries(e))o.has(r)&&(t[r]=s);return t},S=e=>!e||c(e)?e:Object.fromEntries(e),O=e=>{const{auth:r,baseHeaders:t,body:o,headers:s}=e;if(!Boolean(t||s||o||r))return;const n={...f(r),...S(t),...S(s)};return p(a=o)&&a.includes("=")?(n["Content-Type"]="application/x-www-form-urlencoded",n):((c(o)||p(o)&&o.startsWith("{"))&&(n["Content-Type"]="application/json",n.Accept="application/json"),n);var a},q=(...e)=>Promise.all(e),v=async(e,r,t,o)=>{const s=((e,r)=>({arrayBuffer:()=>e.arrayBuffer(),blob:()=>e.blob(),formData:()=>e.formData(),json:async()=>{if(r){const t=await e.text();return r(t)}return e.json()},stream:()=>e.body,text:()=>e.text()}))(e,t);if(!Object.hasOwn(s,r))throw new Error(`Invalid response type: ${r}`);const n=await s[r]();return o?o(n):n},T=e=>{if(0===e)return;const{promise:r,resolve:t}=(()=>{let e,r;return{promise:new Promise(((t,o)=>{r=t,e=o})),reject:e,resolve:r}})();return setTimeout(t,e),r},D=async e=>{const{$RequestInfoCache:r,newFetchController:t,options:o,request:s}=e,n=o.dedupeKey??("cancel"===o.dedupeStrategy||"defer"===o.dedupeStrategy?`${o.fullURL}-${JSON.stringify({options:o,request:s})}`:null),a=null!==n?r:null;null!==n&&await T(.1);const i=a?.get(n);return{handleRequestCancelDedupeStrategy:()=>{if(i&&"cancel"===o.dedupeStrategy){const e=o.dedupeKey?`Duplicate request detected - Aborting previous request with key '${o.dedupeKey}' as a new request was initiated`:`Duplicate request detected - Aborting previous request to '${o.fullURL}' as a new request with identical options was initiated`,r=new DOMException(e,"AbortError");i.controller.abort(r)}},handleRequestDeferDedupeStrategy:()=>{const e=(e=>{if(e)return e;if("undefined"!=typeof globalThis&&d(globalThis.fetch))return globalThis.fetch;throw new Error("No fetch implementation found")})(o.customFetchImpl),r=i&&"defer"===o.dedupeStrategy?i.responsePromise:e(o.fullURL,s);return a?.set(n,{controller:t,responsePromise:r}),r},removeDedupeKeyFromCache:()=>a?.delete(n)}},M=e=>e,$=(e,r)=>async t=>{if("sequential"!==r){if("parallel"===r){const r=[...e];await Promise.all(r.map((e=>e?.(t))))}}else for(const r of e)await(r?.(t))},P={onError:new Set,onRequest:new Set,onRequestError:new Set,onResponse:new Set,onResponseError:new Set,onRetry:new Set,onSuccess:new Set},j=(e,r)=>{const t=e["~retryCount"]??0;return{getDelay:()=>"exponential"===e.retryStrategy?((e,r)=>{const t=r.retryMaxDelay??1e4,o=(r.retryDelay??1e3)*2**e;return Math.min(o,t)})(t,e):(e=>e.retryDelay??1e3)(e),shouldAttemptRetry:async()=>{const o=await(e.retryCondition?.(r))??!0,s=(e.retryAttempts??0)>t&&o;if("HTTPError"!==r.error.name)return s;const n=!!r.request.method&&e.retryMethods?.includes(r.request.method);return!!r.response?.status&&e.retryStatusCodes?.includes(r.response.status)&&n&&s}}},k=(e,r)=>{if(!r)return e;const t=(o=r)?new URLSearchParams(o).toString():(console.error("toQueryString:","No query params provided!"),null);var o;return 0===t?.length?e:e.endsWith("?")?`${e}${t}`:e.includes("?")?`${e}&${t}`:`${e}?${t}`},x=(e,r,t)=>{const o=((e,r)=>{if(!r)return e;let t=e;if(l(r)){const e=t.split("/").filter((e=>e.startsWith(":")));for(const[o,s]of e.entries()){const e=r[o];t=t.replace(s,e)}return t}for(const[e,o]of Object.entries(r))t=t.replace(`:${e}`,String(o));return t})(e,r);return k(o,t)},A=e=>{const[r,t]=(e=>[R(e,h),E(e,[...h,...m])])(e??{}),o=new Map,s=async(...e)=>{const[n,y={}]=e,[f,m]=(e=>[R(e,h),E(e,h)])(y),g={};for(const e of Object.keys(P)){const r=(S=t[e],M=m[e],l(S)?[S,M].flat():M??S);g[e]=r}var S,M;const k={baseURL:"",bodySerializer:JSON.stringify,dedupeStrategy:"cancel",defaultErrorMessage:"Failed to fetch data from server!",mergedHooksExecutionMode:"parallel",mergedHooksExecutionOrder:"mainHooksAfterPlugins",responseType:"json",resultMode:"all",retryAttempts:0,retryDelay:1e3,retryMaxDelay:1e4,retryMethods:w,retryStatusCodes:b,retryStrategy:"linear",...t,...m,...g},A=f.body??r.body,C={body:c(A)?k.bodySerializer(A):A,method:"GET",...r,...f,headers:O({auth:k.auth,baseHeaders:r.headers,body:A,headers:f.headers}),signal:f.signal??r.signal},{resolvedHooks:H,resolvedOptions:U,resolvedRequestOptions:L,url:B}=await(async e=>{const{initURL:r,options:t,request:o}=e,s=structuredClone(P),n=()=>{for(const e of Object.keys(P)){const r=t[e];s[e].add(r)}},a=e=>{for(const r of Object.keys(P)){const t=e[r];s[r].add(t)}};"mainHooksBeforePlugins"===t.mergedHooksExecutionOrder&&n();const i=e=>e?d(e)?e({initURL:r,options:t,request:o}):e:[],l=[...i(t.plugins),...i(t.extend?.plugins)];let u=r,y=t,f=o;const m=async e=>{if(!e)return;const s=await e({initURL:r,options:t,request:o});c(s)&&(p(s.initURL)&&(u=s.initURL),c(s.request)&&(f=s.request),c(s.options)&&(y=s.options))};for(const e of l)await m(e.init),e.hooks&&a(e.hooks);t.mergedHooksExecutionOrder&&"mainHooksAfterPlugins"!==t.mergedHooksExecutionOrder||n();const h={};for(const[e,r]of Object.entries(s)){const o=[...r].flat(),s=$(o,t.mergedHooksExecutionMode);h[e]=s}return{resolvedHooks:h,resolvedOptions:y,resolvedRequestOptions:f,url:u}})({initURL:n,options:k,request:C}),z=`${U.baseURL}${x(B,U.params,U.query)}`,F={...U,...H,fullURL:z,initURL:n},K=new AbortController,N=null!=F.timeout?(I=F.timeout,AbortSignal.timeout(I)):null;var I;const W=((...e)=>AbortSignal.any(e.filter(Boolean)))(L.signal,N,K.signal),G={...L,signal:W},{handleRequestCancelDedupeStrategy:V,handleRequestDeferDedupeStrategy:J,removeDedupeKeyFromCache:_}=await D({$RequestInfoCache:o,newFetchController:K,options:F,request:G});V();try{await q(F.onRequest({options:F,request:G})),G.headers=O({auth:F.auth,baseHeaders:r.headers,body:A,headers:G.headers});const e=await J(),t="defer"===F.dedupeStrategy||F.cloneResponse;if(!e.ok){const r=await v(t?e.clone():e,F.responseType,F.responseParser,F.responseErrorValidator);throw new a({defaultErrorMessage:F.defaultErrorMessage,errorData:r,response:e})}const o={data:await v(t?e.clone():e,F.responseType,F.responseParser,F.responseValidator),options:F,request:G,response:F.cloneResponse?e.clone():e};return await q(F.onSuccess(o),F.onResponse({...o,error:null})),await(e=>{const{data:r,response:t,resultMode:o}=e,s={data:r,error:null,response:t};return o?{all:s,onlyError:s.error,onlyResponse:s.response,onlySuccess:s.data,onlySuccessWithException:s.data}[o]:s})({data:o.data,response:o.response,resultMode:F.resultMode})}catch(e){const{errorVariantDetails:r,getErrorResult:t}=(e=>{const{cloneResponse:r,defaultErrorMessage:t,error:o,message:s,resultMode:n}=e;let a={data:null,error:{errorData:o,message:s??o.message,name:o.name},response:null};if(i(o)){const{errorData:e,message:s=t,name:n,response:i}=o;a={data:null,error:{errorData:e,message:s,name:n},response:r?i.clone():i}}const l={all:a,onlyError:a.error,onlyResponse:a.response,onlySuccess:a.data,onlySuccessWithException:a.data};return{errorVariantDetails:a,getErrorResult:e=>{const r=l[n??"all"];return u(e)?{...r,...e}:r}}})({cloneResponse:F.cloneResponse,defaultErrorMessage:F.defaultErrorMessage,error:e,resultMode:F.resultMode}),o={error:r.error,options:F,request:G},a={...o,response:r.response},{getDelay:l,shouldAttemptRetry:c}=j(F,a);if(!W.aborted&&await c()){await q(F.onRetry(a));const e=l();await T(e);const r={...y,"~retryCount":(F["~retryCount"]??0)+1};return await s(n,r)}const p=d(F.throwOnError)?F.throwOnError(a):F.throwOnError,f=()=>{if(p)throw r.error};if(i(e))return await q(F.onResponseError(a),F.onError(a),F.onResponse({...a,data:null})),f(),t();if(e instanceof DOMException&&"AbortError"===e.name){const{message:r,name:o}=e;return console.error(`${o}:`,r),f(),t()}if(e instanceof DOMException&&"TimeoutError"===e.name){const r=`Request timed out after ${F.timeout}ms`;return console.error(`${e.name}:`,r),f(),t({message:r})}return await q(F.onRequestError(o),F.onError(a)),f(),t()}finally{_()}};return s.create=A,s},C=A({});//# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/index.ts","../../src/utils/type-guards.ts","../../src/auth.ts","../../src/utils/type-helpers.ts","../../src/types.ts","../../src/utils/constants.ts","../../src/utils/common.ts","../../src/dedupe.ts","../../src/plugins.ts","../../src/retry.ts","../../src/url.ts","../../src/utils/polyfills.ts","../../src/createFetchClient.ts"],"sourcesContent":["export { callApi, createFetchClient } from \"./createFetchClient\";\n\nexport { definePlugin, type CallApiPlugin, type PluginInitContext } from \"./plugins\";\n\nexport type {\n\tBaseCallApiConfig,\n\tBaseCallApiExtraOptions,\n\tCallApiConfig,\n\tCallApiExtraOptions,\n\tPossibleJavaScriptError,\n\tPossibleHTTPError,\n\tCallApiParameters,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n\tCallApiResultErrorVariant,\n\tResultModeUnion,\n\tCallApiResultSuccessVariant,\n\tCombinedCallApiExtraOptions,\n\tErrorContext,\n\tInterceptors,\n\tInterceptorsOrInterceptorArray,\n\tPossibleJavascriptErrorNames,\n\tRegister,\n\tRequestContext,\n\tRequestErrorContext,\n\tResponseContext,\n\tResponseErrorContext,\n\tSuccessContext,\n} from \"./types\";\n","import type { AnyFunction } from \"./type-helpers\";\n\nexport const isArray = <TArrayItem>(value: unknown): value is TArrayItem[] => Array.isArray(value);\n\nexport const isObject = (value: unknown) => typeof value === \"object\" && value !== null;\n\nexport const isPlainObject = <TPlainObject extends Record<string, unknown>>(\n\tvalue: unknown\n): value is TPlainObject => {\n\tif (!isObject(value)) {\n\t\treturn false;\n\t}\n\n\tconst prototype = Object.getPrototypeOf(value) as unknown;\n\n\t// Check if it's a plain object\n\treturn (\n\t\t// prettier-ignore\n\t\t(prototype == null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in value)\n\t);\n};\n\nexport const isFunction = <TFunction extends AnyFunction>(value: unknown): value is TFunction =>\n\ttypeof value === \"function\";\n\nexport const isQueryString = (value: unknown): value is string => isString(value) && value.includes(\"=\");\n\nexport const isString = (value: unknown) => typeof value === \"string\";\n\n// https://github.com/unjs/ofetch/blob/main/src/utils.ts\n// TODO Find a way to incorporate this function in checking when to apply the bodySerializer on the body and also whether to add the content type application/json\nexport const isJSONSerializable = (value: unknown) => {\n\tif (value === undefined) {\n\t\treturn false;\n\t}\n\tconst t = typeof value;\n\t// eslint-disable-next-line ts-eslint/no-unnecessary-condition -- No time to make this more type-safe\n\tif (t === \"string\" || t === \"number\" || t === \"boolean\" || t === null) {\n\t\treturn true;\n\t}\n\tif (t !== \"object\") {\n\t\treturn false;\n\t}\n\tif (isArray(value)) {\n\t\treturn true;\n\t}\n\tif ((value as Buffer | null)?.buffer) {\n\t\treturn false;\n\t}\n\n\treturn (\n\t\t// eslint-disable-next-line ts-eslint/prefer-nullish-coalescing -- Nullish coalescing makes no sense in this boolean context\n\t\t(value?.constructor && value.constructor.name === \"Object\") ||\n\t\ttypeof (value as { toJSON: () => unknown } | null)?.toJSON === \"function\"\n\t);\n};\n","/* eslint-disable perfectionist/sort-object-types -- Avoid Sorting for now */\n\nimport type { ExtraOptions } from \"./types\";\nimport { isFunction, isString } from \"./utils/type-guards\";\n\ntype ValueOrFunctionResult<TValue> = TValue | (() => TValue);\n\n/**\n * Bearer Or Token authentication\n *\n * The value of `bearer` will be added to a header as\n * `auth: Bearer some-auth-token`,\n *\n * The value of `token` will be added to a header as\n * `auth: Token some-auth-token`,\n */\nexport type BearerOrTokenAuth =\n\t| {\n\t\t\ttype?: never;\n\t\t\tbearer?: never;\n\t\t\ttoken?: ValueOrFunctionResult<string | null>;\n\t }\n\t| {\n\t\t\ttype?: never;\n\t\t\tbearer?: ValueOrFunctionResult<string | null>;\n\t\t\ttoken?: never;\n\t };\n\n/**\n * Basic auth\n */\nexport type BasicAuth = {\n\ttype: \"Basic\";\n\tusername: ValueOrFunctionResult<string | null | undefined>;\n\tpassword: ValueOrFunctionResult<string | null | undefined>;\n};\n\n/**\n * Custom auth\n *\n * @param prefix - prefix of the header\n * @param authValue - value of the header\n *\n * @example\n * ```ts\n * {\n * type: \"Custom\",\n * prefix: \"Token\",\n * authValue: \"token\"\n * }\n * ```\n */\nexport type CustomAuth = {\n\ttype: \"Custom\";\n\tprefix: ValueOrFunctionResult<string | null | undefined>;\n\tvalue: ValueOrFunctionResult<string | null | undefined>;\n};\n\n// eslint-disable-next-line perfectionist/sort-union-types -- Let the first one be first\nexport type Auth = BearerOrTokenAuth | BasicAuth | CustomAuth;\n\nconst getValue = (value: ValueOrFunctionResult<string | null | undefined>) => {\n\treturn isFunction(value) ? value() : value;\n};\n\ntype AuthorizationHeader = {\n\tAuthorization: string;\n};\n\nexport const getAuthHeader = (auth: ExtraOptions[\"auth\"]): false | AuthorizationHeader | undefined => {\n\tif (auth === undefined) return;\n\n\tif (isString(auth) || auth === null) {\n\t\treturn { Authorization: `Bearer ${auth}` };\n\t}\n\n\tswitch (auth.type) {\n\t\tcase \"Basic\": {\n\t\t\tconst username = getValue(auth.username);\n\t\t\tconst password = getValue(auth.password);\n\n\t\t\tif (username === undefined || password === undefined) return;\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `Basic ${globalThis.btoa(`${username}:${password}`)}`,\n\t\t\t};\n\t\t}\n\n\t\tcase \"Custom\": {\n\t\t\tconst value = getValue(auth.value);\n\n\t\t\tif (value === undefined) return;\n\n\t\t\tconst prefix = getValue(auth.prefix);\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `${prefix} ${value}`,\n\t\t\t};\n\t\t}\n\n\t\tdefault: {\n\t\t\tconst bearer = getValue(auth.bearer);\n\t\t\tconst token = getValue(auth.token);\n\n\t\t\tif (\"token\" in auth && token !== undefined) {\n\t\t\t\treturn { Authorization: `Token ${token}` };\n\t\t\t}\n\n\t\t\treturn bearer !== undefined && { Authorization: `Bearer ${bearer}` };\n\t\t}\n\t}\n};\n","// == These two types allows for adding arbitrary literal types, while still provided autocomplete for defaults.\n// == Usually intersection with \"{}\" or \"NonNullable<unknown>\" would make it work fine, but the placeholder with never type is added to make the AnyWhatever type appear last in a given union.\nexport type AnyString = string & { z_placeholder?: never };\nexport type AnyNumber = number & { z_placeholder?: never };\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is fine here\nexport type AnyObject = Record<string, any>;\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport type AnyFunction<TResult = any> = (...args: any[]) => TResult;\n\nexport type CallbackFn<in TParams, out TResult = void> = (...params: TParams[]) => TResult;\n\nexport type Prettify<TObject> = NonNullable<unknown> & { [Key in keyof TObject]: TObject[Key] };\n\nexport type Writeable<TObject, TType extends \"deep\" | \"shallow\" = \"shallow\"> = {\n\t-readonly [key in keyof TObject]: TType extends \"shallow\"\n\t\t? TObject[key]\n\t\t: TType extends \"deep\"\n\t\t\t? TObject[key] extends object\n\t\t\t\t? Writeable<TObject[key], TType>\n\t\t\t\t: TObject[key]\n\t\t\t: never;\n};\n\nexport const defineEnum = <const TValue>(value: TValue) => value as Prettify<Writeable<TValue, \"deep\">>;\n\n// == Using this Immediately Indexed Mapped type helper to help show computed type of anything passed to it instead of just the type name\nexport type UnmaskType<TValue> = { _: TValue }[\"_\"];\n\nexport type Awaitable<TValue> = Promise<TValue> | TValue;\n\nexport type CommonRequestHeaders =\n\t| \"Access-Control-Allow-Credentials\"\n\t| \"Access-Control-Allow-Headers\"\n\t| \"Access-Control-Allow-Methods\"\n\t| \"Access-Control-Allow-Origin\"\n\t| \"Access-Control-Expose-Headers\"\n\t| \"Access-Control-Max-Age\"\n\t| \"Age\"\n\t| \"Allow\"\n\t| \"Cache-Control\"\n\t| \"Clear-Site-Data\"\n\t| \"Content-Disposition\"\n\t| \"Content-Encoding\"\n\t| \"Content-Language\"\n\t| \"Content-Length\"\n\t| \"Content-Location\"\n\t| \"Content-Range\"\n\t| \"Content-Security-Policy-Report-Only\"\n\t| \"Content-Security-Policy\"\n\t| \"Cookie\"\n\t| \"Cross-Origin-Embedder-Policy\"\n\t| \"Cross-Origin-Opener-Policy\"\n\t| \"Cross-Origin-Resource-Policy\"\n\t| \"Date\"\n\t| \"ETag\"\n\t| \"Expires\"\n\t| \"Last-Modified\"\n\t| \"Location\"\n\t| \"Permissions-Policy\"\n\t| \"Pragma\"\n\t| \"Retry-After\"\n\t| \"Save-Data\"\n\t| \"Sec-CH-Prefers-Color-Scheme\"\n\t| \"Sec-CH-Prefers-Reduced-Motion\"\n\t| \"Sec-CH-UA-Arch\"\n\t| \"Sec-CH-UA-Bitness\"\n\t| \"Sec-CH-UA-Form-Factor\"\n\t| \"Sec-CH-UA-Full-Version-List\"\n\t| \"Sec-CH-UA-Full-Version\"\n\t| \"Sec-CH-UA-Mobile\"\n\t| \"Sec-CH-UA-Model\"\n\t| \"Sec-CH-UA-Platform-Version\"\n\t| \"Sec-CH-UA-Platform\"\n\t| \"Sec-CH-UA-WoW64\"\n\t| \"Sec-CH-UA\"\n\t| \"Sec-Fetch-Dest\"\n\t| \"Sec-Fetch-Mode\"\n\t| \"Sec-Fetch-Site\"\n\t| \"Sec-Fetch-User\"\n\t| \"Sec-GPC\"\n\t| \"Server-Timing\"\n\t| \"Server\"\n\t| \"Service-Worker-Navigation-Preload\"\n\t| \"Set-Cookie\"\n\t| \"Strict-Transport-Security\"\n\t| \"Timing-Allow-Origin\"\n\t| \"Trailer\"\n\t| \"Transfer-Encoding\"\n\t| \"Upgrade\"\n\t| \"Vary\"\n\t| \"Warning\"\n\t| \"WWW-Authenticate\"\n\t| \"X-Content-Type-Options\"\n\t| \"X-DNS-Prefetch-Control\"\n\t| \"X-Frame-Options\"\n\t| \"X-Permitted-Cross-Domain-Policies\"\n\t| \"X-Powered-By\"\n\t| \"X-Robots-Tag\"\n\t| \"X-XSS-Protection\";\n\nexport type CommonAuthorizationHeaders = `${\"Basic\" | \"Bearer\" | \"Token\"} ${string}`;\n\nexport type CommonContentTypes =\n\t| \"application/epub+zip\"\n\t| \"application/gzip\"\n\t| \"application/json\"\n\t| \"application/ld+json\"\n\t| \"application/octet-stream\"\n\t| \"application/ogg\"\n\t| \"application/pdf\"\n\t| \"application/rtf\"\n\t| \"application/vnd.ms-fontobject\"\n\t| \"application/wasm\"\n\t| \"application/xhtml+xml\"\n\t| \"application/xml\"\n\t| \"application/zip\"\n\t| \"audio/aac\"\n\t| \"audio/mpeg\"\n\t| \"audio/ogg\"\n\t| \"audio/opus\"\n\t| \"audio/webm\"\n\t| \"audio/x-midi\"\n\t| \"font/otf\"\n\t| \"font/ttf\"\n\t| \"font/woff\"\n\t| \"font/woff2\"\n\t| \"image/avif\"\n\t| \"image/bmp\"\n\t| \"image/gif\"\n\t| \"image/jpeg\"\n\t| \"image/png\"\n\t| \"image/svg+xml\"\n\t| \"image/tiff\"\n\t| \"image/webp\"\n\t| \"image/x-icon\"\n\t| \"model/gltf-binary\"\n\t| \"model/gltf+json\"\n\t| \"text/calendar\"\n\t| \"text/css\"\n\t| \"text/csv\"\n\t| \"text/html\"\n\t| \"text/javascript\"\n\t| \"text/plain\"\n\t| \"video/3gpp\"\n\t| \"video/3gpp2\"\n\t| \"video/av1\"\n\t| \"video/mp2t\"\n\t| \"video/mp4\"\n\t| \"video/mpeg\"\n\t| \"video/ogg\"\n\t| \"video/webm\"\n\t| \"video/x-msvideo\";\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\n\nimport type { Auth } from \"./auth\";\nimport type { CallApiPlugin, PluginInitContext } from \"./plugins\";\nimport type { RetryOptions } from \"./retry\";\nimport type { getResponseType } from \"./utils/common\";\nimport type { fetchSpecificKeys } from \"./utils/constants\";\nimport {\n\ttype AnyObject,\n\ttype AnyString,\n\ttype Awaitable,\n\ttype CommonAuthorizationHeaders,\n\ttype CommonContentTypes,\n\ttype CommonRequestHeaders,\n\ttype UnmaskType,\n\tdefineEnum,\n} from \"./utils/type-helpers\";\n\ntype FetchSpecificKeysUnion = Exclude<(typeof fetchSpecificKeys)[number], \"body\" | \"headers\" | \"method\">;\n\nexport interface CallApiRequestOptions extends Pick<RequestInit, FetchSpecificKeysUnion> {\n\t/**\n\t * @description Optional body of the request, can be a object or any other supported body type.\n\t */\n\tbody?: Record<string, unknown> | RequestInit[\"body\"];\n\n\t/**\n\t * @description Headers to be used in the request.\n\t */\n\theaders?:\n\t\t| Record<\"Authorization\", CommonAuthorizationHeaders>\n\t\t| Record<\"Content-Type\", CommonContentTypes>\n\t\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the first one to be first\n\t\t| Record<CommonRequestHeaders | AnyString, string>\n\t\t| RequestInit[\"headers\"];\n\n\t/**\n\t * @description HTTP method for the request.\n\t * @default \"GET\"\n\t */\n\tmethod?: \"DELETE\" | \"GET\" | \"PATCH\" | \"POST\" | \"PUT\" | AnyString;\n}\n\nexport interface CallApiRequestOptionsForHooks extends CallApiRequestOptions {\n\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the first one to be first\n\theaders?: Record<CommonRequestHeaders | AnyString, string> | Record<string, string>;\n}\n\n// eslint-disable-next-line ts-eslint/no-empty-object-type -- This needs to be empty to allow users to register their own meta\nexport interface Register {\n\t// == meta: Meta\n}\n\nexport type DefaultDataType = unknown;\n\nexport interface Interceptors<TData = DefaultDataType, TErrorData = DefaultDataType> {\n\t/**\n\t * @description Interceptor that will be called when any error occurs within the request/response lifecyle, regardless of whether the error is from the api or not.\n\t * It is basically a combination of `onRequestError` and `onResponseError` interceptors\n\t */\n\tonError?: (context: ErrorContext<TErrorData>) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called just before the request is made, allowing for modifications or additional operations.\n\t */\n\tonRequest?: (context: RequestContext) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called when an error occurs during the fetch request.\n\t */\n\tonRequestError?: (context: RequestErrorContext) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called when any response is received from the api, whether successful or not\n\t */\n\tonResponse?: (context: ResponseContext<TData, TErrorData>) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called when an error response is received from the api.\n\t */\n\tonResponseError?: (context: ResponseErrorContext<TErrorData>) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called when a request is retried.\n\t */\n\tonRetry?: (response: ErrorContext<TErrorData>) => Awaitable<unknown>;\n\t/**\n\t * @description Interceptor that will be called when a successful response is received from the api.\n\t */\n\tonSuccess?: (context: SuccessContext<TData>) => Awaitable<unknown>;\n}\n\n/* eslint-disable perfectionist/sort-union-types -- I need arrays to be last */\nexport type InterceptorsOrInterceptorArray<TData = DefaultDataType, TErrorData = DefaultDataType> = {\n\t[Key in keyof Interceptors<TData, TErrorData>]:\n\t\t| Interceptors<TData, TErrorData>[Key]\n\t\t| Array<Interceptors<TData, TErrorData>[Key]>;\n};\n/* eslint-enable perfectionist/sort-union-types -- I need arrays to be last */\n\ntype FetchImpl = UnmaskType<(input: string | Request | URL, init?: RequestInit) => Promise<Response>>;\n\ntype CallApiPluginArray<TMoreOptions extends AnyObject> = Array<CallApiPlugin<TMoreOptions>>;\n\nexport type DefaultMoreOptions = NonNullable<unknown>;\n\nexport type Meta = Register extends { meta?: infer TMeta extends Record<string, unknown> } ? TMeta : never;\n\nexport type ExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTMoreOptions extends AnyObject = DefaultMoreOptions,\n> = InterceptorsOrInterceptorArray<TData, TErrorData> &\n\tPartial<TMoreOptions> &\n\tRetryOptions<TErrorData> & {\n\t\t/**\n\t\t * @description Authorization header value.\n\t\t */\n\t\tauth?: string | Auth | null;\n\n\t\t/**\n\t\t * @description Base URL to be prepended to all request URLs\n\t\t */\n\t\tbaseURL?: string;\n\n\t\t/**\n\t\t * @description Custom function to serialize the body object into a string.\n\t\t */\n\t\tbodySerializer?: (bodyData: Record<string, unknown>) => string;\n\n\t\t/**\n\t\t * @description Whether or not to clone the response, so response.json() and the like, can be read again else where.\n\t\t * @see https://developer.mozilla.org/en-US/docs/Web/API/Response/clone\n\t\t * @default false\n\t\t */\n\t\tcloneResponse?: boolean;\n\n\t\t/**\n\t\t * @description Custom fetch implementation\n\t\t */\n\t\tcustomFetchImpl?: FetchImpl;\n\n\t\t/**\n\t\t * @description Custom request key to be used to identify a request in the fetch deduplication strategy.\n\t\t * @default the full request url + string formed from the request options\n\t\t */\n\t\tdedupeKey?: string;\n\n\t\t/**\n\t\t * @description Defines the deduplication strategy for the request, can be set to \"none\" | \"defer\" | \"cancel\".\n\t\t * - If set to \"cancel\", the previous pending request with the same request key will be cancelled and lets the new request through.\n\t\t * - If set to \"defer\", all new request with the same request key will be share the same response, until the previous one is completed.\n\t\t * - If set to \"none\", deduplication is disabled.\n\t\t * @default \"cancel\"\n\t\t */\n\t\tdedupeStrategy?: \"cancel\" | \"defer\" | \"none\";\n\n\t\t/**\n\t\t * @description Default error message to use if none is provided from a response.\n\t\t * @default \"Failed to fetch data from server!\"\n\t\t */\n\t\tdefaultErrorMessage?: string;\n\n\t\t/**\n\t\t * @description Resolved request URL\n\t\t */\n\t\treadonly fullURL?: string;\n\n\t\t/**\n\t\t * @description URL to be used in the request.\n\t\t */\n\t\treadonly initURL?: string;\n\n\t\t/**\n\t\t * @description Defines the mode in which the merged hooks are executed, can be set to \"parallel\" | \"sequential\".\n\t\t * - If set to \"parallel\", main and plugin hooks will be executed in parallel.\n\t\t * - If set to \"sequential\", the plugin hooks will be executed first, followed by the main hook.\n\t\t * @default \"parallel\"\n\t\t */\n\t\tmergedHooksExecutionMode?: \"parallel\" | \"sequential\";\n\n\t\t/**\n\t\t * @description - Controls what order in which the merged hooks execute\n\t\t * @default \"mainHooksLast\"\n\t\t */\n\t\tmergedHooksExecutionOrder?: \"mainHooksAfterPlugins\" | \"mainHooksBeforePlugins\";\n\n\t\t/**\n\t\t * @description - An optional field you can fill with additional information,\n\t\t * to associate with the request, typically used for logging or tracing.\n\t\t *\n\t\t * - A good use case for this, would be to use the info to handle specific cases in any of the shared interceptors.\n\t\t *\n\t\t * @example\n\t\t * ```ts\n\t\t * const callMainApi = callApi.create({\n\t\t * \tbaseURL: \"https://main-api.com\",\n\t\t * \tonResponseError: ({ response, options }) => {\n\t\t * \t\tif (options.meta?.userId) {\n\t\t * \t\t\tconsole.error(`User ${options.meta.userId} made an error`);\n\t\t * \t\t}\n\t\t * \t},\n\t\t * });\n\t\t *\n\t\t * const response = await callMainApi({\n\t\t * \turl: \"https://example.com/api/data\",\n\t\t * \tmeta: { userId: \"123\" },\n\t\t * });\n\t\t * ```\n\t\t */\n\t\tmeta?: Meta;\n\n\t\t/**\n\t\t * @description Params to be appended to the URL (i.e: /:id)\n\t\t */\n\t\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the Record to be first\n\t\tparams?: Record<string, boolean | number | string> | Array<boolean | number | string>;\n\n\t\t/**\n\t\t * @description An array of CallApi plugins. It allows you to extend the behavior of the library.\n\t\t */\n\t\tplugins?:\n\t\t\t| CallApiPluginArray<TMoreOptions>\n\t\t\t| ((context: PluginInitContext) => CallApiPluginArray<TMoreOptions>);\n\n\t\t/**\n\t\t * @description Query parameters to append to the URL.\n\t\t */\n\t\tquery?: Record<string, boolean | number | string>;\n\n\t\t/**\n\t\t * @description Custom function to validate the response error data, stemming from the api.\n\t\t * This only runs if the api actually sends back error status codes, else it will be ignored, in which case you should only use the `responseValidator` option.\n\t\t */\n\t\tresponseErrorValidator?: (data: unknown) => TErrorData;\n\n\t\t/**\n\t\t * @description Custom function to parse the response string into a object.\n\t\t */\n\t\tresponseParser?: (responseString: string) => Awaitable<Record<string, unknown>>;\n\n\t\t/**\n\t\t * @description Expected response type, affects how response is parsed\n\t\t * @default \"json\"\n\t\t */\n\t\tresponseType?: keyof ReturnType<typeof getResponseType>;\n\n\t\t/**\n\t\t * @description Custom function to validate the response data.\n\t\t */\n\t\tresponseValidator?: (data: unknown) => TData;\n\n\t\t/**\n\t\t * @description Mode of the result, can influence how results are handled or returned.\n\t\t * Can be set to \"all\" | \"onlySuccess\" | \"onlyError\" | \"onlyResponse\".\n\t\t * @default \"all\"\n\t\t */\n\t\tresultMode?: TErrorData extends false ? \"onlySuccessWithException\" : TResultMode | undefined;\n\n\t\t/**\n\t\t * If true or the function returns true, throws errors instead of returning them\n\t\t * The function is passed the error object and can be used to conditionally throw the error\n\t\t * @default false\n\t\t */\n\t\tthrowOnError?: boolean | ((context: ErrorContext<TErrorData>) => boolean);\n\n\t\t/**\n\t\t * @description Request timeout in milliseconds\n\t\t */\n\t\ttimeout?: number;\n\t};\n\nexport const optionsEnumToExtendFromBase = defineEnum([\"plugins\"] satisfies Array<keyof ExtraOptions>);\n\nexport type CallApiExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTMoreOptions extends AnyObject = DefaultMoreOptions,\n> = ExtraOptions<TData, TErrorData, TResultMode, TMoreOptions> & {\n\t/**\n\t * @description Options that should extend the base options.\n\t */\n\textend?: Pick<\n\t\tExtraOptions<TData, TErrorData, TResultMode, TMoreOptions>,\n\t\t(typeof optionsEnumToExtendFromBase)[number]\n\t>;\n};\n\nexport const optionsEnumToOmitFromBase = defineEnum([\"extend\", \"dedupeKey\"] satisfies Array<\n\tkeyof CallApiExtraOptions\n>);\n\nexport type BaseCallApiExtraOptions<\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTMoreOptions extends AnyObject = DefaultMoreOptions,\n> = Omit<\n\tCallApiExtraOptions<TBaseData, TBaseErrorData, TBaseResultMode, TMoreOptions>,\n\t(typeof optionsEnumToOmitFromBase)[number]\n>;\n\nexport type CombinedCallApiExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTMoreOptions extends AnyObject = DefaultMoreOptions,\n> = BaseCallApiExtraOptions<TData, TErrorData, TResultMode, TMoreOptions> &\n\tCallApiExtraOptions<TData, TErrorData, TResultMode, TMoreOptions>;\n\nexport type CallApiConfig<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTMoreOptions extends AnyObject = DefaultMoreOptions,\n> = CallApiExtraOptions<TData, TErrorData, TResultMode, TMoreOptions> & CallApiRequestOptions;\n\nexport type BaseCallApiConfig<\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBaseMoreOptions extends AnyObject = DefaultMoreOptions,\n> = BaseCallApiExtraOptions<TBaseData, TBaseErrorData, TBaseResultMode, TBaseMoreOptions> &\n\tCallApiRequestOptions;\n\nexport type CallApiParameters<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTMoreOptions extends AnyObject = DefaultMoreOptions,\n> = [initURL: string, config?: CallApiConfig<TData, TErrorData, TResultMode, TMoreOptions>];\n\nexport type RequestContext = UnmaskType<{\n\toptions: CombinedCallApiExtraOptions;\n\trequest: CallApiRequestOptionsForHooks;\n}>;\n\nexport type ResponseContext<TData, TErrorData> = UnmaskType<\n\t| {\n\t\t\tdata: TData;\n\t\t\terror: null;\n\t\t\toptions: CombinedCallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptionsForHooks;\n\t\t\tresponse: Response;\n\t }\n\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the first one to be first\n\t| {\n\t\t\tdata: null;\n\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\toptions: CombinedCallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptionsForHooks;\n\t\t\tresponse: Response;\n\t }\n>;\n\nexport type SuccessContext<TData> = UnmaskType<{\n\tdata: TData;\n\toptions: CombinedCallApiExtraOptions;\n\trequest: CallApiRequestOptionsForHooks;\n\tresponse: Response;\n}>;\n\nexport type PossibleJavascriptErrorNames =\n\t| \"AbortError\"\n\t| \"Error\"\n\t| \"SyntaxError\"\n\t| \"TimeoutError\"\n\t| \"TypeError\"\n\t| (`${string}Error` & {});\n\nexport type PossibleJavaScriptError = UnmaskType<{\n\terrorData: DOMException | Error | SyntaxError | TypeError;\n\tmessage: string;\n\tname: PossibleJavascriptErrorNames;\n}>;\n\nexport type PossibleHTTPError<TErrorData> = UnmaskType<{\n\terrorData: TErrorData;\n\tmessage: string;\n\tname: \"HTTPError\";\n}>;\n\nexport type RequestErrorContext = UnmaskType<{\n\terror: PossibleJavaScriptError;\n\toptions: CombinedCallApiExtraOptions;\n\trequest: CallApiRequestOptionsForHooks;\n}>;\n\nexport type ResponseErrorContext<TErrorData> = UnmaskType<{\n\terror: PossibleHTTPError<TErrorData>;\n\toptions: CombinedCallApiExtraOptions;\n\trequest: CallApiRequestOptionsForHooks;\n\tresponse: Response;\n}>;\n\nexport type ErrorContext<TErrorData> = UnmaskType<\n\t| {\n\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\toptions: CombinedCallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptionsForHooks;\n\t\t\tresponse: Response;\n\t }\n\t| {\n\t\t\terror: PossibleJavaScriptError;\n\t\t\toptions: CombinedCallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptionsForHooks;\n\t\t\tresponse: null;\n\t }\n>;\n\nexport type CallApiResultSuccessVariant<TData> = {\n\tdata: TData;\n\terror: null;\n\tresponse: Response;\n};\n\nexport type CallApiResultErrorVariant<TErrorData> =\n\t| {\n\t\t\tdata: null;\n\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\tresponse: Response;\n\t }\n\t| {\n\t\t\tdata: null;\n\t\t\terror: PossibleJavaScriptError;\n\t\t\tresponse: null;\n\t };\n\nexport type ResultModeMap<TData = DefaultDataType, TErrorData = DefaultDataType> = {\n\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the first one to be first\n\tall: CallApiResultSuccessVariant<TData> | CallApiResultErrorVariant<TErrorData>;\n\tonlyError: CallApiResultErrorVariant<TErrorData>[\"error\"] | CallApiResultSuccessVariant<TData>[\"error\"];\n\tonlyResponse:\n\t\t| CallApiResultErrorVariant<TErrorData>[\"response\"]\n\t\t| CallApiResultSuccessVariant<TData>[\"response\"];\n\tonlySuccess: CallApiResultErrorVariant<TErrorData>[\"data\"] | CallApiResultSuccessVariant<TData>[\"data\"];\n\tonlySuccessWithException: CallApiResultSuccessVariant<TData>[\"data\"];\n};\n\nexport type ResultModeUnion = { [Key in keyof ResultModeMap]: Key }[keyof ResultModeMap] | undefined;\n\nexport type GetCallApiResult<TData, TErrorData, TResultMode> = TErrorData extends false\n\t? ResultModeMap<TData, TErrorData>[\"onlySuccessWithException\"]\n\t: undefined extends TResultMode\n\t\t? ResultModeMap<TData, TErrorData>[\"all\"]\n\t\t: TResultMode extends NonNullable<ResultModeUnion>\n\t\t\t? ResultModeMap<TData, TErrorData>[TResultMode]\n\t\t\t: never;\n","import type { BaseCallApiConfig } from \"../types\";\nimport { defineEnum } from \"./type-helpers\";\n\nexport const fetchSpecificKeys = defineEnum([\n\t\"body\",\n\t\"integrity\",\n\t\"method\",\n\t\"headers\",\n\t\"signal\",\n\t\"cache\",\n\t\"redirect\",\n\t\"window\",\n\t\"credentials\",\n\t\"keepalive\",\n\t\"referrer\",\n\t\"priority\",\n\t\"mode\",\n\t\"referrerPolicy\",\n] satisfies Array<keyof RequestInit>);\n\nconst retryStatusCodesLookup = defineEnum({\n\t408: \"Request Timeout\",\n\t409: \"Conflict\",\n\t425: \"Too Early\",\n\t429: \"Too Many Requests\",\n\t500: \"Internal Server Error\",\n\t502: \"Bad Gateway\",\n\t503: \"Service Unavailable\",\n\t504: \"Gateway Timeout\",\n});\n\nexport const defaultRetryMethods = [\"GET\", \"POST\"] satisfies BaseCallApiConfig[\"retryMethods\"];\n\n// prettier-ignore\nexport const defaultRetryStatusCodes = Object.keys(retryStatusCodesLookup).map(Number) as Required<BaseCallApiConfig>[\"retryStatusCodes\"];\n","import { getAuthHeader } from \"@/auth\";\nimport {\n\ttype BaseCallApiExtraOptions,\n\ttype CallApiConfig,\n\ttype CallApiExtraOptions,\n\ttype CallApiRequestOptions,\n\ttype CallApiResultErrorVariant,\n\ttype PossibleHTTPError,\n\ttype PossibleJavaScriptError,\n\ttype PossibleJavascriptErrorNames,\n\ttype ResultModeMap,\n\toptionsEnumToOmitFromBase,\n} from \"../types\";\nimport { fetchSpecificKeys } from \"./constants\";\nimport { isArray, isFunction, isPlainObject, isQueryString, isString } from \"./type-guards\";\nimport type { AnyFunction, Awaitable } from \"./type-helpers\";\n\nconst omitKeys = <TObject extends Record<string, unknown>, const TOmitArray extends Array<keyof TObject>>(\n\tinitialObject: TObject,\n\tkeysToOmit: TOmitArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tconst keysToOmitSet = new Set(keysToOmit);\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (!keysToOmitSet.has(key)) {\n\t\t\tupdatedObject[key] = value;\n\t\t}\n\t}\n\n\treturn updatedObject as Omit<TObject, TOmitArray[number]>;\n};\n\nconst pickKeys = <TObject extends Record<string, unknown>, const TPickArray extends Array<keyof TObject>>(\n\tinitialObject: TObject,\n\tkeysToPick: TPickArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tconst keysToPickSet = new Set(keysToPick);\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (keysToPickSet.has(key)) {\n\t\t\tupdatedObject[key] = value;\n\t\t}\n\t}\n\n\treturn updatedObject as Pick<TObject, TPickArray[number]>;\n};\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport const splitBaseConfig = (baseConfig: Record<string, any>) =>\n\t[\n\t\tpickKeys(baseConfig, fetchSpecificKeys) as CallApiRequestOptions,\n\t\tomitKeys(baseConfig, [\n\t\t\t...fetchSpecificKeys,\n\t\t\t...optionsEnumToOmitFromBase,\n\t\t]) as BaseCallApiExtraOptions,\n\t] as const;\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport const splitConfig = (config: Record<string, any>) =>\n\t[\n\t\tpickKeys(config, fetchSpecificKeys) as CallApiRequestOptions,\n\t\tomitKeys(config, fetchSpecificKeys) as CallApiExtraOptions,\n\t] as const;\n\nexport const objectifyHeaders = (headers: RequestInit[\"headers\"]): Record<string, string> | undefined => {\n\tif (!headers || isPlainObject(headers)) {\n\t\treturn headers;\n\t}\n\n\treturn Object.fromEntries(headers);\n};\n\ntype ToQueryStringFn = {\n\t(params: CallApiConfig[\"query\"]): string | null;\n\t(params: Required<CallApiConfig>[\"query\"]): string;\n};\n\nexport const toQueryString: ToQueryStringFn = (params) => {\n\tif (!params) {\n\t\tconsole.error(\"toQueryString:\", \"No query params provided!\");\n\n\t\treturn null as never;\n\t}\n\n\treturn new URLSearchParams(params as Record<string, string>).toString();\n};\n\n// export mergeAndResolve\n\nexport const mergeAndResolveHeaders = (options: {\n\tauth: CallApiConfig[\"auth\"];\n\tbaseHeaders: CallApiConfig[\"headers\"];\n\tbody: CallApiConfig[\"body\"];\n\theaders: CallApiConfig[\"headers\"];\n}) => {\n\tconst { auth, baseHeaders, body, headers } = options;\n\n\t// eslint-disable-next-line ts-eslint/prefer-nullish-coalescing -- Nullish coalescing makes no sense in this boolean context\n\tconst shouldResolveHeaders = Boolean(baseHeaders || headers || body || auth);\n\n\t// == Return early if any of the following conditions are not met (so that native fetch would auto set the correct headers):\n\t// == - headers are provided\n\t// == - The body is an object\n\t// == - The auth option is provided\n\tif (!shouldResolveHeaders) return;\n\n\tconst headersObject: Record<string, string> = {\n\t\t...getAuthHeader(auth),\n\t\t...objectifyHeaders(baseHeaders),\n\t\t...objectifyHeaders(headers),\n\t};\n\n\tif (isQueryString(body)) {\n\t\theadersObject[\"Content-Type\"] = \"application/x-www-form-urlencoded\";\n\n\t\treturn headersObject;\n\t}\n\n\tif (isPlainObject(body) || (isString(body) && body.startsWith(\"{\"))) {\n\t\theadersObject[\"Content-Type\"] = \"application/json\";\n\t\theadersObject.Accept = \"application/json\";\n\t}\n\n\treturn headersObject;\n};\n\nexport const combineHooks = <\n\tTInterceptor extends\n\t\t| AnyFunction<Awaitable<unknown>>\n\t\t| Array<AnyFunction<Awaitable<unknown>> | undefined>,\n>(\n\tbaseInterceptor: TInterceptor | undefined,\n\tinterceptor: TInterceptor | undefined\n) => {\n\tif (isArray(baseInterceptor)) {\n\t\treturn [baseInterceptor, interceptor].flat() as TInterceptor;\n\t}\n\n\treturn interceptor ?? baseInterceptor;\n};\n\nexport const getFetchImpl = (customFetchImpl: CallApiExtraOptions[\"customFetchImpl\"]) => {\n\tif (customFetchImpl) {\n\t\treturn customFetchImpl;\n\t}\n\n\tif (typeof globalThis !== \"undefined\" && isFunction(globalThis.fetch)) {\n\t\treturn globalThis.fetch;\n\t}\n\n\tthrow new Error(\"No fetch implementation found\");\n};\n\nexport const getResponseType = <TResponse>(\n\tresponse: Response,\n\tparser?: Required<CallApiExtraOptions>[\"responseParser\"]\n) => ({\n\tarrayBuffer: () => response.arrayBuffer() as Promise<TResponse>,\n\tblob: () => response.blob() as Promise<TResponse>,\n\tformData: () => response.formData() as Promise<TResponse>,\n\tjson: async () => {\n\t\tif (parser) {\n\t\t\tconst text = await response.text();\n\t\t\treturn parser(text);\n\t\t}\n\n\t\treturn response.json() as Promise<TResponse>;\n\t},\n\tstream: () => response.body,\n\ttext: () => response.text() as Promise<TResponse>,\n});\n\nexport const executeHooks = <TInterceptor extends Awaitable<unknown>>(...interceptors: TInterceptor[]) =>\n\tPromise.all(interceptors);\n\nexport const getResponseData = async <TResponse>(\n\tresponse: Response,\n\tresponseType: keyof ReturnType<typeof getResponseType>,\n\tparser: CallApiExtraOptions[\"responseParser\"],\n\tvalidator?: CallApiExtraOptions[\"responseValidator\"]\n) => {\n\tconst RESPONSE_TYPE_LOOKUP = getResponseType<TResponse>(response, parser);\n\n\tif (!Object.hasOwn(RESPONSE_TYPE_LOOKUP, responseType)) {\n\t\tthrow new Error(`Invalid response type: ${responseType}`);\n\t}\n\n\tconst responseData = await RESPONSE_TYPE_LOOKUP[responseType]();\n\n\tconst validResponseData = validator ? validator(responseData) : responseData;\n\n\treturn validResponseData;\n};\n\ntype SuccessInfo = {\n\tdata: unknown;\n\tresponse: Response;\n\tresultMode: CallApiExtraOptions[\"resultMode\"];\n};\n\n// == The CallApiResult type is used to cast all return statements due to a design limitation in ts.\n// LINK - See https://www.zhenghao.io/posts/type-functions for more info\nexport const resolveSuccessResult = <TCallApiResult>(info: SuccessInfo): TCallApiResult => {\n\tconst { data, response, resultMode } = info;\n\n\tconst apiDetails = { data, error: null, response };\n\n\tif (!resultMode) {\n\t\treturn apiDetails as TCallApiResult;\n\t}\n\n\tconst resultModeMap: ResultModeMap = {\n\t\tall: apiDetails,\n\t\tonlyError: apiDetails.error,\n\t\tonlyResponse: apiDetails.response,\n\t\tonlySuccess: apiDetails.data,\n\t\tonlySuccessWithException: apiDetails.data,\n\t};\n\n\treturn resultModeMap[resultMode] as TCallApiResult;\n};\n\ntype ErrorInfo = {\n\tdefaultErrorMessage: Required<CallApiExtraOptions>[\"defaultErrorMessage\"];\n\terror?: unknown;\n\tmessage?: string;\n\tresultMode: CallApiExtraOptions[\"resultMode\"];\n};\n\nexport const resolveErrorResult = <TCallApiResult = never>(info: ErrorInfo) => {\n\tconst { defaultErrorMessage, error, message: customErrorMessage, resultMode } = info;\n\n\tlet apiDetails: CallApiResultErrorVariant<unknown> = {\n\t\tdata: null,\n\t\terror: {\n\t\t\terrorData: error as Error,\n\t\t\tmessage: customErrorMessage ?? (error as Error).message,\n\t\t\tname: (error as Error).name as PossibleJavascriptErrorNames,\n\t\t},\n\t\tresponse: null,\n\t};\n\n\tif (isHTTPErrorInstance(error)) {\n\t\tconst { errorData, message = defaultErrorMessage, name, response } = error;\n\n\t\tapiDetails = {\n\t\t\tdata: null,\n\t\t\terror: {\n\t\t\t\terrorData,\n\t\t\t\tmessage,\n\t\t\t\tname,\n\t\t\t},\n\t\t\tresponse,\n\t\t};\n\t}\n\n\tconst resultModeMap: ResultModeMap = {\n\t\tall: apiDetails,\n\t\tonlyError: apiDetails.error,\n\t\tonlyResponse: apiDetails.response,\n\t\tonlySuccess: apiDetails.data,\n\t\tonlySuccessWithException: apiDetails.data,\n\t};\n\n\tconst generalErrorResult = resultModeMap[resultMode ?? \"all\"] as TCallApiResult;\n\n\t// prettier-ignore\n\tconst resolveCustomErrorInfo = ({ message }: Pick<ErrorInfo, \"message\">) => {\n\t\tconst errorResult = resolveErrorResult<TCallApiResult>({ ...info, message });\n\n\t\treturn errorResult.generalErrorResult;\n\t};\n\n\treturn { apiDetails, generalErrorResult, resolveCustomErrorInfo };\n};\n\ntype ErrorObjectUnion<TErrorData = unknown> = PossibleHTTPError<TErrorData> | PossibleJavaScriptError;\n\nexport const isHTTPError = <TErrorData>(\n\terror: ErrorObjectUnion<TErrorData> | null\n): error is PossibleHTTPError<TErrorData> => {\n\treturn isPlainObject(error) && error.name === \"HTTPError\";\n};\n\ntype ErrorDetails<TErrorResponse> = {\n\tdefaultErrorMessage: string;\n\terrorData: TErrorResponse;\n\tresponse: Response;\n};\n\ntype ErrorOptions = {\n\tcause?: unknown;\n};\n\nexport class HTTPError<TErrorResponse = Record<string, unknown>> extends Error {\n\terrorData: ErrorDetails<TErrorResponse>[\"errorData\"];\n\tisHTTPError = true;\n\n\toverride name = \"HTTPError\" as const;\n\n\tresponse: ErrorDetails<TErrorResponse>[\"response\"];\n\n\tconstructor(errorDetails: ErrorDetails<TErrorResponse>, errorOptions?: ErrorOptions) {\n\t\tconst { defaultErrorMessage, errorData, response } = errorDetails;\n\n\t\tsuper((errorData as { message?: string } | undefined)?.message ?? defaultErrorMessage, errorOptions);\n\n\t\tthis.errorData = errorData;\n\t\tthis.response = response;\n\n\t\tError.captureStackTrace(this, this.constructor);\n\t}\n}\n\nexport const isHTTPErrorInstance = <TErrorResponse>(\n\terror: unknown\n): error is HTTPError<TErrorResponse> => {\n\treturn (\n\t\t// prettier-ignore\n\t\terror instanceof HTTPError|| (isPlainObject(error) && error.name === \"HTTPError\" && error.isHTTPError === true)\n\t);\n};\n\nconst PromiseWithResolvers = () => {\n\tlet reject!: (reason?: unknown) => void;\n\tlet resolve!: (value: unknown) => void;\n\n\tconst promise = new Promise((res, rej) => {\n\t\tresolve = res;\n\t\treject = rej;\n\t});\n\n\treturn { promise, reject, resolve };\n};\n\nexport const waitUntil = (delay: number) => {\n\tif (delay === 0) return;\n\n\tconst { promise, resolve } = PromiseWithResolvers();\n\n\tsetTimeout(resolve, delay);\n\n\treturn promise;\n};\n","import type { CallApiExtraOptions, CallApiRequestOptions } from \"./types\";\nimport { getFetchImpl } from \"./utils/common\";\n\nexport const generateDedupeKey = (\n\tfullURL: string,\n\trequest: CallApiRequestOptions,\n\toptions: CallApiExtraOptions\n) => {\n\tconst shouldHaveDedupeKey = options.dedupeStrategy === \"cancel\" || options.dedupeStrategy === \"defer\";\n\n\tif (!shouldHaveDedupeKey) {\n\t\treturn null;\n\t}\n\n\treturn `${options.fullURL}-${JSON.stringify({ options, request })}`;\n};\n\ntype RequestInfo = { controller: AbortController; responsePromise: Promise<Response> };\n\nexport type RequestInfoCache = Map<string | null, RequestInfo>;\n\nexport const handleRequestCancelDedupe = (\n\tfullURL: string,\n\toptions: CallApiExtraOptions,\n\tprevRequestInfo: RequestInfo | undefined\n) => {\n\tconst shouldCancelRequest = prevRequestInfo && options.dedupeStrategy === \"cancel\";\n\n\tif (shouldCancelRequest) {\n\t\tconst message = options.dedupeKey\n\t\t\t? `Duplicate request detected - Aborting previous request with key '${options.dedupeKey}' as a new request was initiated`\n\t\t\t: `Duplicate request detected - Aborting previous request to '${options.fullURL}' as a new request with identical options was initiated`;\n\n\t\tconst reason = new DOMException(message, \"AbortError\");\n\n\t\tprevRequestInfo.controller.abort(reason);\n\t}\n};\n\nexport const handleRequestDeferDedupe = (\n\tfullURL: string,\n\toptions: CallApiExtraOptions,\n\trequest: CallApiRequestOptions,\n\tprevRequestInfo: RequestInfo | undefined\n) => {\n\tconst fetchApi = getFetchImpl(options.customFetchImpl);\n\n\tconst shouldUsePromiseFromCache = prevRequestInfo && options.dedupeStrategy === \"defer\";\n\n\tconst responsePromise = shouldUsePromiseFromCache\n\t\t? prevRequestInfo.responsePromise\n\t\t: fetchApi(fullURL, request as RequestInit);\n\n\treturn responsePromise;\n};\n","import type {\n\tCallApiRequestOptionsForHooks,\n\tCombinedCallApiExtraOptions,\n\tDefaultDataType,\n\tDefaultMoreOptions,\n\tExtraOptions,\n\tInterceptors,\n\tInterceptorsOrInterceptorArray,\n\tResultModeUnion,\n} from \"./types\";\nimport { isFunction, isPlainObject, isString } from \"./utils/type-guards\";\nimport type { AnyFunction, AnyObject, Awaitable } from \"./utils/type-helpers\";\n\nexport type PluginInitContext<TMoreOptions extends AnyObject = DefaultMoreOptions> = {\n\tinitURL: string;\n\toptions: CombinedCallApiExtraOptions<DefaultDataType, DefaultDataType, ResultModeUnion, TMoreOptions>;\n\trequest: CallApiRequestOptionsForHooks;\n};\n\ntype CreateExtraOptions<TMoreOptions> = (...params: never[]) => TMoreOptions;\n\nexport type CallApiPlugin<TMoreOptions extends AnyObject = DefaultMoreOptions> = {\n\t/**\n\t * @description Defines additional options that can be passed to callApi\n\t */\n\tcreateExtraOptions?: CreateExtraOptions<TMoreOptions>;\n\n\t/**\n\t * @description A description for the plugin\n\t */\n\tdescription?: string;\n\n\t/**\n\t * Hooks / Interceptors for the plugin\n\t */\n\thooks?: InterceptorsOrInterceptorArray;\n\n\t/**\n\t * @description A unique id for the plugin\n\t */\n\tid: string;\n\n\t/**\n\t * @description A function that will be called when the plugin is\n\t * initialized. This will be called before the any\n\t * of the other internal functions.\n\t */\n\tinit?: (context: PluginInitContext) => Awaitable<Partial<PluginInitContext>> | Awaitable<void>;\n\n\t/**\n\t * @description A name for the plugin\n\t */\n\tname: string;\n\n\t/**\n\t * @description A version for the plugin\n\t */\n\tversion?: string;\n};\n\nexport const definePlugin = <\n\tTMoreOptions extends AnyObject = DefaultMoreOptions,\n\tTPlugin extends\n\t\t| AnyFunction<CallApiPlugin<TMoreOptions>>\n\t\t| CallApiPlugin<TMoreOptions> = CallApiPlugin<TMoreOptions>,\n>(\n\tplugin: TPlugin\n) => {\n\treturn plugin;\n};\n\nconst createMergedHook = (\n\thooks: Array<AnyFunction<Awaitable<unknown>> | undefined>,\n\tmergedHooksExecutionMode: CombinedCallApiExtraOptions[\"mergedHooksExecutionMode\"]\n) => {\n\treturn async (ctx: Record<string, unknown>) => {\n\t\tif (mergedHooksExecutionMode === \"sequential\") {\n\t\t\tfor (const hook of hooks) {\n\t\t\t\t// eslint-disable-next-line no-await-in-loop -- This is necessary in this case\n\t\t\t\tawait hook?.(ctx);\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (mergedHooksExecutionMode === \"parallel\") {\n\t\t\tconst hookArray = [...hooks];\n\n\t\t\tawait Promise.all(hookArray.map((uniqueHook) => uniqueHook?.(ctx)));\n\t\t}\n\t};\n};\n\n// prettier-ignore\ntype HookRegistries = {\n\t[Key in keyof Interceptors]: Set<Interceptors[Key]>;\n};\n\nexport const hooksEnum = {\n\tonError: new Set(),\n\tonRequest: new Set(),\n\tonRequestError: new Set(),\n\tonResponse: new Set(),\n\tonResponseError: new Set(),\n\tonRetry: new Set(),\n\tonSuccess: new Set(),\n} satisfies HookRegistries;\n\nexport const initializePlugins = async (context: PluginInitContext) => {\n\tconst { initURL, options, request } = context;\n\n\tconst hookRegistries = structuredClone(hooksEnum);\n\n\tconst addMainHooks = () => {\n\t\tfor (const key of Object.keys(hooksEnum)) {\n\t\t\tconst mainHook = options[key as keyof Interceptors] as never;\n\n\t\t\thookRegistries[key as keyof Interceptors].add(mainHook);\n\t\t}\n\t};\n\n\tconst addPluginHooks = (pluginHooks: InterceptorsOrInterceptorArray) => {\n\t\tfor (const key of Object.keys(hooksEnum)) {\n\t\t\tconst pluginHook = pluginHooks[key as keyof Interceptors] as never;\n\n\t\t\thookRegistries[key as keyof Interceptors].add(pluginHook);\n\t\t}\n\t};\n\n\tif (options.mergedHooksExecutionOrder === \"mainHooksBeforePlugins\") {\n\t\taddMainHooks();\n\t}\n\n\tconst getPluginArray = (plugins: ExtraOptions[\"plugins\"]) => {\n\t\tif (!plugins) {\n\t\t\treturn [];\n\t\t}\n\n\t\treturn isFunction(plugins) ? plugins({ initURL, options, request }) : plugins;\n\t};\n\n\tconst resolvedPlugins = [\n\t\t...getPluginArray(options.plugins),\n\t\t...getPluginArray(options.extend?.plugins),\n\t];\n\n\tlet resolvedUrl = initURL;\n\tlet resolvedOptions = options;\n\tlet resolvedRequestOptions = request;\n\n\tconst executePluginInit = async (pluginInit: CallApiPlugin[\"init\"]) => {\n\t\tif (!pluginInit) return;\n\n\t\tconst initResult = await pluginInit({ initURL, options, request });\n\n\t\tif (!isPlainObject(initResult)) return;\n\n\t\tif (isString(initResult.initURL)) {\n\t\t\tresolvedUrl = initResult.initURL;\n\t\t}\n\n\t\tif (isPlainObject(initResult.request)) {\n\t\t\tresolvedRequestOptions = initResult.request;\n\t\t}\n\n\t\tif (isPlainObject(initResult.options)) {\n\t\t\tresolvedOptions = initResult.options;\n\t\t}\n\t};\n\n\tfor (const plugin of resolvedPlugins) {\n\t\t// eslint-disable-next-line no-await-in-loop -- Await is necessary in this case.\n\t\tawait executePluginInit(plugin.init);\n\n\t\tif (!plugin.hooks) continue;\n\n\t\taddPluginHooks(plugin.hooks);\n\t}\n\n\tif (\n\t\t!options.mergedHooksExecutionOrder ||\n\t\toptions.mergedHooksExecutionOrder === \"mainHooksAfterPlugins\"\n\t) {\n\t\taddMainHooks();\n\t}\n\n\tconst resolvedHooks = {} as Required<Interceptors>;\n\n\tfor (const [key, hookRegistry] of Object.entries(hookRegistries)) {\n\t\tconst flattenedHookArray = [...hookRegistry].flat();\n\n\t\tconst mergedHook = createMergedHook(flattenedHookArray, options.mergedHooksExecutionMode);\n\n\t\tresolvedHooks[key as keyof Interceptors] = mergedHook;\n\t}\n\n\treturn {\n\t\tresolvedHooks,\n\t\tresolvedOptions,\n\t\tresolvedRequestOptions,\n\t\turl: resolvedUrl,\n\t};\n};\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\n\nimport type { ErrorContext } from \"./types\";\nimport type { AnyNumber, AnyString } from \"./utils/type-helpers\";\n\ntype RetryCondition<TErrorData> = (context: ErrorContext<TErrorData>) => boolean | Promise<boolean>;\n\nexport interface RetryOptions<TErrorData> {\n\t/**\n\t * @description Number of allowed retry attempts on HTTP errors\n\t * @default 0\n\t */\n\tretryAttempts?: number;\n\n\t/**\n\t * @description Callback whose return value determines if a request should be retried or not\n\t */\n\tretryCondition?: RetryCondition<TErrorData>;\n\n\t/**\n\t * @description Keeps track of the number of times the request has already been retried\n\t */\n\tretryCount?: number;\n\n\t/**\n\t * @description Delay between retries in milliseconds\n\t * @default 1000\n\t */\n\tretryDelay?: number;\n\n\t/**\n\t * @description Maximum delay in milliseconds. Only applies to exponential strategy\n\t * @default 10000\n\t */\n\tretryMaxDelay?: number;\n\n\t/**\n\t * HTTP methods that are allowed to retry\n\t * @default [\"GET\", \"POST\"]\n\t */\n\tretryMethods?: Array<\"GET\" | \"POST\" | AnyString>;\n\n\t/**\n\t * @description HTTP status codes that trigger a retry\n\t * @default [409, 425, 429, 500, 502, 503, 504]\n\t */\n\tretryStatusCodes?: Array<409 | 425 | 429 | 500 | 502 | 503 | 504 | AnyNumber>;\n\n\t/**\n\t * @description Strategy to use when retrying\n\t * @default \"linear\"\n\t */\n\tretryStrategy?: \"exponential\" | \"linear\";\n}\n\nconst getLinearDelay = <TErrorData>(options: RetryOptions<TErrorData>) => options.retryDelay ?? 1000;\n\nconst getExponentialDelay = <TErrorData>(\n\tcurrentAttemptCount: number,\n\toptions: RetryOptions<TErrorData>\n) => {\n\tconst maxDelay = options.retryMaxDelay ?? 10000;\n\n\tconst exponentialDelay = (options.retryDelay ?? 1000) * 2 ** currentAttemptCount;\n\n\treturn Math.min(exponentialDelay, maxDelay);\n};\n\nexport const createRetryStrategy = <TErrorData>(\n\toptions: RetryOptions<TErrorData>,\n\tctx: ErrorContext<TErrorData>\n) => {\n\tconst currentRetryCount = options.retryCount ?? 0;\n\n\treturn {\n\t\tgetDelay: () => {\n\t\t\tif (options.retryStrategy === \"exponential\") {\n\t\t\t\treturn getExponentialDelay(currentRetryCount, options);\n\t\t\t}\n\n\t\t\treturn getLinearDelay(options);\n\t\t},\n\n\t\tshouldAttemptRetry: async () => {\n\t\t\tconst customRetryCondition = (await options.retryCondition?.(ctx)) ?? true;\n\n\t\t\tconst maxRetryAttempts = options.retryAttempts ?? 0;\n\n\t\t\tconst baseRetryCondition = maxRetryAttempts > currentRetryCount && customRetryCondition;\n\n\t\t\tif (ctx.error.name !== \"HTTPError\") {\n\t\t\t\treturn baseRetryCondition;\n\t\t\t}\n\n\t\t\tconst includesMethod =\n\t\t\t\t// eslint-disable-next-line no-implicit-coercion -- Boolean doesn't narrow\n\t\t\t\t!!ctx.request.method && options.retryMethods?.includes(ctx.request.method);\n\n\t\t\tconst includesCodes =\n\t\t\t\t// eslint-disable-next-line no-implicit-coercion -- Boolean doesn't narrow\n\t\t\t\t!!ctx.response?.status && options.retryStatusCodes?.includes(ctx.response.status);\n\n\t\t\treturn includesCodes && includesMethod && baseRetryCondition;\n\t\t},\n\t};\n};\n","import type { CallApiConfig, CallApiExtraOptions } from \"./types\";\nimport { toQueryString } from \"./utils\";\nimport { isArray } from \"./utils/type-guards\";\n\nconst slash = \"/\";\nconst column = \":\";\nconst mergeUrlWithParams = (url: string, params: CallApiExtraOptions[\"params\"]) => {\n\tif (!params) {\n\t\treturn url;\n\t}\n\n\tlet newUrl = url;\n\n\tif (isArray(params)) {\n\t\tconst matchedParamArray = newUrl.split(slash).filter((param) => param.startsWith(column));\n\n\t\tfor (const [index, matchedParam] of matchedParamArray.entries()) {\n\t\t\tconst realParam = params[index] as string;\n\t\t\tnewUrl = newUrl.replace(matchedParam, realParam);\n\t\t}\n\n\t\treturn newUrl;\n\t}\n\n\tfor (const [key, value] of Object.entries(params)) {\n\t\tnewUrl = newUrl.replace(`${column}${key}`, String(value));\n\t}\n\n\treturn newUrl;\n};\n\nconst questionMark = \"?\";\nconst ampersand = \"&\";\nconst mergeUrlWithQuery = (url: string, query: CallApiConfig[\"query\"]): string => {\n\tif (!query) {\n\t\treturn url;\n\t}\n\n\tconst queryString = toQueryString(query);\n\n\tif (queryString?.length === 0) {\n\t\treturn url;\n\t}\n\n\tif (url.endsWith(questionMark)) {\n\t\treturn `${url}${queryString}`;\n\t}\n\n\tif (url.includes(questionMark)) {\n\t\treturn `${url}${ampersand}${queryString}`;\n\t}\n\n\treturn `${url}${questionMark}${queryString}`;\n};\n\nexport const mergeUrlWithParamsAndQuery = (\n\turl: string,\n\tparams: CallApiExtraOptions[\"params\"],\n\tquery: CallApiExtraOptions[\"query\"]\n) => {\n\tconst urlWithMergedParams = mergeUrlWithParams(url, params);\n\n\treturn mergeUrlWithQuery(urlWithMergedParams, query);\n};\n","// prettier-ignore\nexport const createCombinedSignal = (...signals: Array<AbortSignal | null | undefined>) => AbortSignal.any(signals.filter(Boolean));\n\nexport const createTimeoutSignal = (milliseconds: number) => AbortSignal.timeout(milliseconds);\n","import {\n\ttype RequestInfoCache,\n\tgenerateDedupeKey,\n\thandleRequestCancelDedupe,\n\thandleRequestDeferDedupe,\n} from \"./dedupe\";\nimport { hooksEnum, initializePlugins } from \"./plugins\";\nimport { createRetryStrategy } from \"./retry\";\nimport type {\n\tBaseCallApiConfig,\n\tCallApiConfig,\n\tCallApiParameters,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n\tCombinedCallApiExtraOptions,\n\tDefaultDataType,\n\tDefaultMoreOptions,\n\tGetCallApiResult,\n\tInterceptors,\n\tPossibleHTTPError,\n\tPossibleJavaScriptError,\n\tResultModeUnion,\n} from \"./types\";\nimport { mergeUrlWithParamsAndQuery } from \"./url\";\nimport {\n\tHTTPError,\n\tcombineHooks,\n\texecuteHooks,\n\tgetResponseData,\n\tisHTTPErrorInstance,\n\tmergeAndResolveHeaders,\n\tresolveErrorResult,\n\tresolveSuccessResult,\n\tsplitBaseConfig,\n\tsplitConfig,\n\twaitUntil,\n} from \"./utils/common\";\nimport { defaultRetryMethods, defaultRetryStatusCodes } from \"./utils/constants\";\nimport { createCombinedSignal, createTimeoutSignal } from \"./utils/polyfills\";\nimport { isFunction, isPlainObject } from \"./utils/type-guards\";\nimport type { AnyObject } from \"./utils/type-helpers\";\n\nexport const createFetchClient = <\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBaseMoreOptions extends AnyObject = DefaultMoreOptions,\n>(\n\tbaseConfig: BaseCallApiConfig<\n\t\tTBaseData,\n\t\tTBaseErrorData,\n\t\tTBaseResultMode,\n\t\tTBaseMoreOptions\n\t> = {} as never\n) => {\n\tconst [baseFetchConfig, baseExtraOptions] = splitBaseConfig(baseConfig);\n\n\tconst {\n\t\tbody: baseBody,\n\t\theaders: baseHeaders,\n\t\tsignal: baseSignal,\n\t\t...restOfBaseFetchConfig\n\t} = baseFetchConfig;\n\n\tconst $RequestInfoCache = new Map() satisfies RequestInfoCache;\n\n\tconst callApi = async <\n\t\tTData = TBaseData,\n\t\tTErrorData = TBaseErrorData,\n\t\tTResultMode extends ResultModeUnion = TBaseResultMode,\n\t\tTMoreOptions extends AnyObject = TBaseMoreOptions,\n\t>(\n\t\t...parameters: CallApiParameters<TData, TErrorData, TResultMode, TMoreOptions>\n\t): Promise<GetCallApiResult<TData, TErrorData, TResultMode>> => {\n\t\tconst [initURL, config = {}] = parameters;\n\n\t\tconst [fetchConfig, extraOptions] = splitConfig(config);\n\n\t\tconst { body = baseBody, headers, signal = baseSignal, ...restOfFetchConfig } = fetchConfig;\n\n\t\tconst initCombinedHooks = {} as Required<Interceptors>;\n\n\t\tfor (const key of Object.keys(hooksEnum)) {\n\t\t\tconst combinedHook = combineHooks(\n\t\t\t\tbaseExtraOptions[key as keyof Interceptors],\n\t\t\t\textraOptions[key as keyof Interceptors]\n\t\t\t);\n\n\t\t\tinitCombinedHooks[key as keyof Interceptors] = combinedHook as never;\n\t\t}\n\n\t\t// == Default Extra Options\n\t\tconst defaultExtraOptions = {\n\t\t\tbaseURL: \"\",\n\t\t\tbodySerializer: JSON.stringify,\n\t\t\tdedupeStrategy: \"cancel\",\n\t\t\tdefaultErrorMessage: \"Failed to fetch data from server!\",\n\t\t\tmergedHooksExecutionMode: \"parallel\",\n\t\t\tmergedHooksExecutionOrder: \"mainHooksAfterPlugins\",\n\t\t\tresponseType: \"json\",\n\t\t\tresultMode: \"all\",\n\t\t\tretryAttempts: 0,\n\t\t\tretryDelay: 1000,\n\t\t\tretryMaxDelay: 10000,\n\t\t\tretryMethods: defaultRetryMethods,\n\t\t\tretryStatusCodes: defaultRetryStatusCodes,\n\t\t\tretryStrategy: \"linear\",\n\n\t\t\t...baseExtraOptions,\n\t\t\t...extraOptions,\n\n\t\t\t...initCombinedHooks,\n\t\t} satisfies CombinedCallApiExtraOptions;\n\n\t\tconst { resolvedHooks, resolvedOptions, resolvedRequestOptions, url } = await initializePlugins({\n\t\t\tinitURL,\n\t\t\toptions: defaultExtraOptions,\n\t\t\trequest: { ...restOfBaseFetchConfig, ...restOfFetchConfig },\n\t\t});\n\n\t\tconst fullURL = `${resolvedOptions.baseURL}${mergeUrlWithParamsAndQuery(url, resolvedOptions.params, resolvedOptions.query)}`;\n\n\t\tconst options = {\n\t\t\t...resolvedOptions,\n\t\t\t...resolvedHooks,\n\t\t\tfullURL,\n\t\t\tinitURL,\n\t\t} satisfies CombinedCallApiExtraOptions as typeof defaultExtraOptions & typeof resolvedHooks;\n\n\t\t// == Default Request Options\n\t\tconst defaultRequestOptions = {\n\t\t\tbody: isPlainObject(body) ? options.bodySerializer(body) : body,\n\t\t\tmethod: \"GET\",\n\n\t\t\t...resolvedRequestOptions,\n\t\t} satisfies CallApiRequestOptions;\n\n\t\tconst newFetchController = new AbortController();\n\n\t\tconst timeoutSignal = options.timeout != null ? createTimeoutSignal(options.timeout) : null;\n\n\t\tconst combinedSignal = createCombinedSignal(newFetchController.signal, timeoutSignal, signal);\n\n\t\tconst request = {\n\t\t\tsignal: combinedSignal,\n\t\t\t...defaultRequestOptions,\n\t\t} satisfies CallApiRequestOptionsForHooks;\n\n\t\tconst dedupeKey = options.dedupeKey ?? generateDedupeKey(fullURL, request, options);\n\n\t\t// == Add a small delay to ensure proper request deduplication when multiple requests with the same key start simultaneously.\n\t\t// == This gives time for the cache to be updated with the previous request info before the next request checks it.\n\t\tdedupeKey !== null && (await waitUntil(0.1));\n\n\t\t// == This ensures cache operations only occur when key is available\n\t\tconst $RequestInfoCacheOrNull = dedupeKey !== null ? $RequestInfoCache : null;\n\n\t\tconst prevRequestInfo = $RequestInfoCacheOrNull?.get(dedupeKey);\n\n\t\thandleRequestCancelDedupe(fullURL, options, prevRequestInfo);\n\n\t\ttry {\n\t\t\tawait executeHooks(options.onRequest({ options, request }));\n\n\t\t\t// == Apply determined headers after onRequest incase they were modified\n\t\t\trequest.headers = mergeAndResolveHeaders({\n\t\t\t\tauth: options.auth,\n\t\t\t\tbaseHeaders: baseHeaders ?? headers,\n\t\t\t\tbody,\n\t\t\t\theaders: request.headers,\n\t\t\t});\n\n\t\t\tconst responsePromise = handleRequestDeferDedupe(fullURL, options, request, prevRequestInfo);\n\n\t\t\t$RequestInfoCacheOrNull?.set(dedupeKey, { controller: newFetchController, responsePromise });\n\n\t\t\tconst response = await responsePromise;\n\n\t\t\t// == Also clone response when dedupeStrategy is set to \"defer\", to avoid error thrown from reading response.(whatever) more than once\n\t\t\tconst shouldCloneResponse = options.dedupeStrategy === \"defer\" || options.cloneResponse;\n\n\t\t\tif (!response.ok) {\n\t\t\t\tconst errorData = await getResponseData<TErrorData>(\n\t\t\t\t\tshouldCloneResponse ? response.clone() : response,\n\t\t\t\t\toptions.responseType,\n\t\t\t\t\toptions.responseParser,\n\t\t\t\t\toptions.responseErrorValidator\n\t\t\t\t);\n\n\t\t\t\t// == Push all error handling responsibilities to the catch block if not retrying\n\t\t\t\tthrow new HTTPError({\n\t\t\t\t\tdefaultErrorMessage: options.defaultErrorMessage,\n\t\t\t\t\terrorData,\n\t\t\t\t\tresponse,\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconst successData = await getResponseData<TData>(\n\t\t\t\tshouldCloneResponse ? response.clone() : response,\n\t\t\t\toptions.responseType,\n\t\t\t\toptions.responseParser,\n\t\t\t\toptions.responseValidator\n\t\t\t);\n\n\t\t\tawait executeHooks(\n\t\t\t\toptions.onSuccess({\n\t\t\t\t\tdata: successData as never,\n\t\t\t\t\toptions,\n\t\t\t\t\trequest,\n\t\t\t\t\tresponse: options.cloneResponse ? response.clone() : response,\n\t\t\t\t}),\n\n\t\t\t\toptions.onResponse({\n\t\t\t\t\tdata: successData,\n\t\t\t\t\terror: null,\n\t\t\t\t\toptions,\n\t\t\t\t\trequest,\n\t\t\t\t\tresponse: options.cloneResponse ? response.clone() : response,\n\t\t\t\t})\n\t\t\t);\n\n\t\t\treturn await resolveSuccessResult({\n\t\t\t\tdata: successData,\n\t\t\t\tresponse,\n\t\t\t\tresultMode: options.resultMode,\n\t\t\t});\n\n\t\t\t// == Exhaustive Error handling\n\t\t} catch (error) {\n\t\t\tconst { apiDetails, generalErrorResult, resolveCustomErrorInfo } = resolveErrorResult({\n\t\t\t\tdefaultErrorMessage: options.defaultErrorMessage,\n\t\t\t\terror,\n\t\t\t\tresultMode: options.resultMode,\n\t\t\t});\n\n\t\t\tconst errorContext = {\n\t\t\t\terror: apiDetails.error as never,\n\t\t\t\toptions,\n\t\t\t\trequest,\n\t\t\t\tresponse: apiDetails.response,\n\t\t\t};\n\n\t\t\tconst { getDelay, shouldAttemptRetry } = createRetryStrategy(options, errorContext);\n\n\t\t\tconst shouldRetry = !combinedSignal.aborted && (await shouldAttemptRetry());\n\n\t\t\tif (shouldRetry) {\n\t\t\t\tawait executeHooks(options.onRetry(errorContext));\n\n\t\t\t\tconst delay = getDelay();\n\n\t\t\t\tawait waitUntil(delay);\n\n\t\t\t\tconst updatedOptions = {\n\t\t\t\t\t...config,\n\t\t\t\t\tretryCount: (options.retryCount ?? 0) + 1,\n\t\t\t\t} satisfies CallApiConfig<TData, TErrorData, TResultMode>;\n\n\t\t\t\treturn await callApi(initURL, updatedOptions);\n\t\t\t}\n\n\t\t\tconst shouldThrowOnError = isFunction(options.throwOnError)\n\t\t\t\t? options.throwOnError(errorContext)\n\t\t\t\t: options.throwOnError;\n\n\t\t\t// eslint-disable-next-line unicorn/consistent-function-scoping -- False alarm: this function is depends on this scope\n\t\t\tconst handleThrowOnError = () => {\n\t\t\t\tif (!shouldThrowOnError) return;\n\n\t\t\t\t// eslint-disable-next-line ts-eslint/only-throw-error -- It's fine to throw this\n\t\t\t\tthrow apiDetails.error;\n\t\t\t};\n\n\t\t\tif (isHTTPErrorInstance<TErrorData>(error)) {\n\t\t\t\tconst { response } = error;\n\n\t\t\t\tconst possibleHttpError = (generalErrorResult as { error: PossibleHTTPError<TErrorData> })\n\t\t\t\t\t.error;\n\n\t\t\t\tawait executeHooks(\n\t\t\t\t\toptions.onResponseError({\n\t\t\t\t\t\terror: possibleHttpError,\n\t\t\t\t\t\toptions,\n\t\t\t\t\t\trequest,\n\t\t\t\t\t\tresponse: options.cloneResponse ? response.clone() : response,\n\t\t\t\t\t}),\n\n\t\t\t\t\toptions.onError({\n\t\t\t\t\t\terror: possibleHttpError,\n\t\t\t\t\t\toptions,\n\t\t\t\t\t\trequest,\n\t\t\t\t\t\tresponse: options.cloneResponse ? response.clone() : response,\n\t\t\t\t\t}),\n\n\t\t\t\t\toptions.onResponse({\n\t\t\t\t\t\tdata: null,\n\t\t\t\t\t\terror: possibleHttpError,\n\t\t\t\t\t\toptions,\n\t\t\t\t\t\trequest,\n\t\t\t\t\t\tresponse: options.cloneResponse ? response.clone() : response,\n\t\t\t\t\t})\n\t\t\t\t);\n\n\t\t\t\thandleThrowOnError();\n\n\t\t\t\treturn generalErrorResult;\n\t\t\t}\n\n\t\t\tif (error instanceof DOMException && error.name === \"AbortError\") {\n\t\t\t\tconst { message, name } = error;\n\n\t\t\t\tconsole.error(`${name}:`, message);\n\n\t\t\t\thandleThrowOnError();\n\n\t\t\t\treturn generalErrorResult;\n\t\t\t}\n\n\t\t\tif (error instanceof DOMException && error.name === \"TimeoutError\") {\n\t\t\t\tconst message = `Request timed out after ${options.timeout}ms`;\n\n\t\t\t\tconsole.error(`${error.name}:`, message);\n\n\t\t\t\thandleThrowOnError();\n\n\t\t\t\treturn resolveCustomErrorInfo({ message });\n\t\t\t}\n\n\t\t\tconst possibleJavascriptError = (generalErrorResult as { error: PossibleJavaScriptError }).error;\n\n\t\t\tawait executeHooks(\n\t\t\t\t// == At this point only the request errors exist, so the request error interceptor is called\n\t\t\t\toptions.onRequestError({\n\t\t\t\t\terror: possibleJavascriptError,\n\t\t\t\t\toptions,\n\t\t\t\t\trequest,\n\t\t\t\t}),\n\n\t\t\t\t// == Also call the onError interceptor\n\t\t\t\toptions.onError({\n\t\t\t\t\terror: possibleJavascriptError,\n\t\t\t\t\toptions,\n\t\t\t\t\trequest,\n\t\t\t\t\tresponse: null,\n\t\t\t\t})\n\t\t\t);\n\n\t\t\thandleThrowOnError();\n\n\t\t\treturn generalErrorResult;\n\n\t\t\t// == Removing the now unneeded AbortController from store\n\t\t} finally {\n\t\t\t$RequestInfoCacheOrNull?.delete(dedupeKey);\n\t\t}\n\t};\n\n\tcallApi.create = createFetchClient;\n\n\treturn callApi;\n};\n\nexport const callApi = createFetchClient();\n"],"mappings":"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","names":["callApi"]}
1
+ {"version":3,"sources":["../../src/index.ts","../../src/error.ts","../../src/utils/type-guards.ts","../../src/auth.ts","../../src/utils/type-helpers.ts","../../src/types.ts","../../src/utils/constants.ts","../../src/utils/common.ts","../../src/dedupe.ts","../../src/plugins.ts","../../src/retry.ts","../../src/url.ts","../../src/utils/polyfills.ts","../../src/createFetchClient.ts"],"sourcesContent":["export { callApi, createFetchClient } from \"./createFetchClient\";\n\nexport { definePlugin, type CallApiPlugin, type PluginInitContext } from \"./plugins\";\n\nexport { HTTPError } from \"./error\";\n\nexport type {\n\tBaseCallApiConfig,\n\tBaseCallApiExtraOptions,\n\tCallApiConfig,\n\tCallApiExtraOptions,\n\tPossibleJavaScriptError,\n\tPossibleHTTPError,\n\tCallApiParameters,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n\tCallApiResultErrorVariant,\n\tResultModeUnion,\n\tCallApiResultSuccessVariant,\n\tCombinedCallApiExtraOptions,\n\tErrorContext,\n\tInterceptors,\n\tInterceptorsOrInterceptorArray,\n\tPossibleJavascriptErrorNames,\n\tRegister,\n\tRequestContext,\n\tRequestErrorContext,\n\tResponseContext,\n\tResponseErrorContext,\n\tSuccessContext,\n} from \"./types\";\n","import type {\n\tCallApiExtraOptions,\n\tCallApiResultErrorVariant,\n\tPossibleJavascriptErrorNames,\n\tResultModeMap,\n} from \"./types\";\nimport { isHTTPErrorInstance, isObject } from \"./utils/type-guards\";\n\ntype ErrorInfo = {\n\tcloneResponse: CallApiExtraOptions[\"cloneResponse\"];\n\tdefaultErrorMessage: Required<CallApiExtraOptions>[\"defaultErrorMessage\"];\n\terror?: unknown;\n\tmessage?: string;\n\tresultMode: CallApiExtraOptions[\"resultMode\"];\n};\n\nexport const resolveErrorResult = <TCallApiResult = never>(info: ErrorInfo) => {\n\tconst { cloneResponse, defaultErrorMessage, error, message: customErrorMessage, resultMode } = info;\n\n\tlet errorVariantDetails: CallApiResultErrorVariant<unknown> = {\n\t\tdata: null,\n\t\terror: {\n\t\t\terrorData: error as Error,\n\t\t\tmessage: customErrorMessage ?? (error as Error).message,\n\t\t\tname: (error as Error).name as PossibleJavascriptErrorNames,\n\t\t},\n\t\tresponse: null,\n\t};\n\n\tif (isHTTPErrorInstance(error)) {\n\t\tconst { errorData, message = defaultErrorMessage, name, response } = error;\n\n\t\terrorVariantDetails = {\n\t\t\tdata: null,\n\t\t\terror: {\n\t\t\t\terrorData,\n\t\t\t\tmessage,\n\t\t\t\tname,\n\t\t\t},\n\t\t\tresponse: cloneResponse ? response.clone() : response,\n\t\t};\n\t}\n\n\tconst resultModeMap: ResultModeMap = {\n\t\tall: errorVariantDetails,\n\t\tonlyError: errorVariantDetails.error,\n\t\tonlyResponse: errorVariantDetails.response,\n\t\tonlySuccess: errorVariantDetails.data,\n\t\tonlySuccessWithException: errorVariantDetails.data,\n\t};\n\n\tconst getErrorResult = (customInfo?: Pick<ErrorInfo, \"message\">) => {\n\t\tconst errorResult = resultModeMap[resultMode ?? \"all\"] as TCallApiResult;\n\n\t\treturn isObject(customInfo) ? { ...errorResult, ...customInfo } : errorResult;\n\t};\n\n\treturn { errorVariantDetails, getErrorResult };\n};\n\ntype ErrorDetails<TErrorResponse> = {\n\tdefaultErrorMessage: string;\n\terrorData: TErrorResponse;\n\tresponse: Response;\n};\n\ntype ErrorOptions = {\n\tcause?: unknown;\n};\n\nexport class HTTPError<TErrorResponse = Record<string, unknown>> extends Error {\n\terrorData: ErrorDetails<TErrorResponse>[\"errorData\"];\n\tisHTTPError = true;\n\n\toverride name = \"HTTPError\" as const;\n\n\tresponse: ErrorDetails<TErrorResponse>[\"response\"];\n\n\tconstructor(errorDetails: ErrorDetails<TErrorResponse>, errorOptions?: ErrorOptions) {\n\t\tconst { defaultErrorMessage, errorData, response } = errorDetails;\n\n\t\tsuper((errorData as { message?: string } | undefined)?.message ?? defaultErrorMessage, errorOptions);\n\n\t\tthis.errorData = errorData;\n\t\tthis.response = response;\n\n\t\tError.captureStackTrace(this, this.constructor);\n\t}\n}\n","import { HTTPError } from \"@/error\";\nimport type { PossibleHTTPError, PossibleJavaScriptError } from \"@/types\";\nimport type { AnyFunction } from \"./type-helpers\";\n\ntype ErrorObjectUnion<TErrorData = unknown> = PossibleHTTPError<TErrorData> | PossibleJavaScriptError;\n\nexport const isHTTPError = <TErrorData>(\n\terror: ErrorObjectUnion<TErrorData> | null\n): error is PossibleHTTPError<TErrorData> => {\n\treturn isPlainObject(error) && error.name === \"HTTPError\";\n};\n\nexport const isHTTPErrorInstance = <TErrorResponse>(\n\terror: unknown\n): error is HTTPError<TErrorResponse> => {\n\treturn (\n\t\t// prettier-ignore\n\t\terror instanceof HTTPError|| (isPlainObject(error) && error.name === \"HTTPError\" && error.isHTTPError === true)\n\t);\n};\n\nexport const isArray = <TArrayItem>(value: unknown): value is TArrayItem[] => Array.isArray(value);\n\nexport const isObject = (value: unknown) => typeof value === \"object\" && value !== null;\n\nexport const isPlainObject = <TPlainObject extends Record<string, unknown>>(\n\tvalue: unknown\n): value is TPlainObject => {\n\tif (!isObject(value)) {\n\t\treturn false;\n\t}\n\n\tconst prototype = Object.getPrototypeOf(value) as unknown;\n\n\t// Check if it's a plain object\n\treturn (\n\t\t// prettier-ignore\n\t\t(prototype == null || prototype === Object.prototype || Object.getPrototypeOf(prototype) === null) && !(Symbol.toStringTag in value)\n\t);\n};\n\nexport const isFunction = <TFunction extends AnyFunction>(value: unknown): value is TFunction =>\n\ttypeof value === \"function\";\n\nexport const isQueryString = (value: unknown): value is string => isString(value) && value.includes(\"=\");\n\nexport const isString = (value: unknown) => typeof value === \"string\";\n\n// https://github.com/unjs/ofetch/blob/main/src/utils.ts\n// TODO Find a way to incorporate this function in checking when to apply the bodySerializer on the body and also whether to add the content type application/json\nexport const isJSONSerializable = (value: unknown) => {\n\tif (value === undefined) {\n\t\treturn false;\n\t}\n\tconst t = typeof value;\n\t// eslint-disable-next-line ts-eslint/no-unnecessary-condition -- No time to make this more type-safe\n\tif (t === \"string\" || t === \"number\" || t === \"boolean\" || t === null) {\n\t\treturn true;\n\t}\n\tif (t !== \"object\") {\n\t\treturn false;\n\t}\n\tif (isArray(value)) {\n\t\treturn true;\n\t}\n\tif ((value as Buffer | null)?.buffer) {\n\t\treturn false;\n\t}\n\n\treturn (\n\t\t// eslint-disable-next-line ts-eslint/prefer-nullish-coalescing -- Nullish coalescing makes no sense in this boolean context\n\t\t(value?.constructor && value.constructor.name === \"Object\") ||\n\t\ttypeof (value as { toJSON: () => unknown } | null)?.toJSON === \"function\"\n\t);\n};\n","/* eslint-disable perfectionist/sort-object-types -- Avoid Sorting for now */\n\nimport type { ExtraOptions } from \"./types\";\nimport { isFunction, isString } from \"./utils/type-guards\";\n\ntype ValueOrFunctionResult<TValue> = TValue | (() => TValue);\n\n/**\n * Bearer Or Token authentication\n *\n * The value of `bearer` will be added to a header as\n * `auth: Bearer some-auth-token`,\n *\n * The value of `token` will be added to a header as\n * `auth: Token some-auth-token`,\n */\nexport type BearerOrTokenAuth =\n\t| {\n\t\t\ttype?: \"Bearer\";\n\t\t\tbearer?: ValueOrFunctionResult<string | null>;\n\t\t\ttoken?: never;\n\t }\n\t| {\n\t\t\ttype?: \"Token\";\n\t\t\tbearer?: never;\n\t\t\ttoken?: ValueOrFunctionResult<string | null>;\n\t };\n\n/**\n * Basic auth\n */\nexport type BasicAuth = {\n\ttype: \"Basic\";\n\tusername: ValueOrFunctionResult<string | null | undefined>;\n\tpassword: ValueOrFunctionResult<string | null | undefined>;\n};\n\n/**\n * Custom auth\n *\n * @param prefix - prefix of the header\n * @param authValue - value of the header\n *\n * @example\n * ```ts\n * {\n * type: \"Custom\",\n * prefix: \"Token\",\n * authValue: \"token\"\n * }\n * ```\n */\nexport type CustomAuth = {\n\ttype: \"Custom\";\n\tprefix: ValueOrFunctionResult<string | null | undefined>;\n\tvalue: ValueOrFunctionResult<string | null | undefined>;\n};\n\n// eslint-disable-next-line perfectionist/sort-union-types -- Let the first one be first\nexport type Auth = BearerOrTokenAuth | BasicAuth | CustomAuth;\n\nconst getValue = (value: ValueOrFunctionResult<string | null | undefined>) => {\n\treturn isFunction(value) ? value() : value;\n};\n\ntype AuthorizationHeader = {\n\tAuthorization: string;\n};\n\nexport const getAuthHeader = (auth: ExtraOptions[\"auth\"]): false | AuthorizationHeader | undefined => {\n\tif (auth === undefined) return;\n\n\tif (isString(auth) || auth === null) {\n\t\treturn { Authorization: `Bearer ${auth}` };\n\t}\n\n\tswitch (auth.type) {\n\t\tcase \"Basic\": {\n\t\t\tconst username = getValue(auth.username);\n\t\t\tconst password = getValue(auth.password);\n\n\t\t\tif (username === undefined || password === undefined) return;\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `Basic ${globalThis.btoa(`${username}:${password}`)}`,\n\t\t\t};\n\t\t}\n\n\t\tcase \"Custom\": {\n\t\t\tconst value = getValue(auth.value);\n\n\t\t\tif (value === undefined) return;\n\n\t\t\tconst prefix = getValue(auth.prefix);\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `${prefix} ${value}`,\n\t\t\t};\n\t\t}\n\n\t\tdefault: {\n\t\t\tconst bearer = getValue(auth.bearer);\n\t\t\tconst token = getValue(auth.token);\n\n\t\t\tif (\"token\" in auth && token !== undefined) {\n\t\t\t\treturn { Authorization: `Token ${token}` };\n\t\t\t}\n\n\t\t\treturn bearer !== undefined && { Authorization: `Bearer ${bearer}` };\n\t\t}\n\t}\n};\n","// == These two types allows for adding arbitrary literal types, while still provided autocomplete for defaults.\n// == Usually intersection with \"{}\" or \"NonNullable<unknown>\" would make it work fine, but the placeholder with never type is added to make the AnyWhatever type appear last in a given union.\nexport type AnyString = string & { z_placeholder?: never };\nexport type AnyNumber = number & { z_placeholder?: never };\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is fine here\nexport type AnyObject = Record<string, any>;\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport type AnyFunction<TResult = any> = (...args: any[]) => TResult;\n\nexport type CallbackFn<in TParams, out TResult = void> = (...params: TParams[]) => TResult;\n\nexport type Prettify<TObject> = NonNullable<unknown> & { [Key in keyof TObject]: TObject[Key] };\n\nexport type Writeable<TObject, TType extends \"deep\" | \"shallow\" = \"shallow\"> = {\n\t-readonly [key in keyof TObject]: TType extends \"shallow\"\n\t\t? TObject[key]\n\t\t: TType extends \"deep\"\n\t\t\t? TObject[key] extends object\n\t\t\t\t? Writeable<TObject[key], TType>\n\t\t\t\t: TObject[key]\n\t\t\t: never;\n};\n\nexport const defineEnum = <const TValue>(value: TValue) => value as Prettify<Writeable<TValue, \"deep\">>;\n\n// == Using this Immediately Indexed Mapped type helper to help show computed type of anything passed to it instead of just the type name\nexport type UnmaskType<TValue> = { _: TValue }[\"_\"];\n\nexport type Awaitable<TValue> = Promise<TValue> | TValue;\n\nexport type CommonRequestHeaders =\n\t| \"Access-Control-Allow-Credentials\"\n\t| \"Access-Control-Allow-Headers\"\n\t| \"Access-Control-Allow-Methods\"\n\t| \"Access-Control-Allow-Origin\"\n\t| \"Access-Control-Expose-Headers\"\n\t| \"Access-Control-Max-Age\"\n\t| \"Age\"\n\t| \"Allow\"\n\t| \"Cache-Control\"\n\t| \"Clear-Site-Data\"\n\t| \"Content-Disposition\"\n\t| \"Content-Encoding\"\n\t| \"Content-Language\"\n\t| \"Content-Length\"\n\t| \"Content-Location\"\n\t| \"Content-Range\"\n\t| \"Content-Security-Policy-Report-Only\"\n\t| \"Content-Security-Policy\"\n\t| \"Cookie\"\n\t| \"Cross-Origin-Embedder-Policy\"\n\t| \"Cross-Origin-Opener-Policy\"\n\t| \"Cross-Origin-Resource-Policy\"\n\t| \"Date\"\n\t| \"ETag\"\n\t| \"Expires\"\n\t| \"Last-Modified\"\n\t| \"Location\"\n\t| \"Permissions-Policy\"\n\t| \"Pragma\"\n\t| \"Retry-After\"\n\t| \"Save-Data\"\n\t| \"Sec-CH-Prefers-Color-Scheme\"\n\t| \"Sec-CH-Prefers-Reduced-Motion\"\n\t| \"Sec-CH-UA-Arch\"\n\t| \"Sec-CH-UA-Bitness\"\n\t| \"Sec-CH-UA-Form-Factor\"\n\t| \"Sec-CH-UA-Full-Version-List\"\n\t| \"Sec-CH-UA-Full-Version\"\n\t| \"Sec-CH-UA-Mobile\"\n\t| \"Sec-CH-UA-Model\"\n\t| \"Sec-CH-UA-Platform-Version\"\n\t| \"Sec-CH-UA-Platform\"\n\t| \"Sec-CH-UA-WoW64\"\n\t| \"Sec-CH-UA\"\n\t| \"Sec-Fetch-Dest\"\n\t| \"Sec-Fetch-Mode\"\n\t| \"Sec-Fetch-Site\"\n\t| \"Sec-Fetch-User\"\n\t| \"Sec-GPC\"\n\t| \"Server-Timing\"\n\t| \"Server\"\n\t| \"Service-Worker-Navigation-Preload\"\n\t| \"Set-Cookie\"\n\t| \"Strict-Transport-Security\"\n\t| \"Timing-Allow-Origin\"\n\t| \"Trailer\"\n\t| \"Transfer-Encoding\"\n\t| \"Upgrade\"\n\t| \"Vary\"\n\t| \"Warning\"\n\t| \"WWW-Authenticate\"\n\t| \"X-Content-Type-Options\"\n\t| \"X-DNS-Prefetch-Control\"\n\t| \"X-Frame-Options\"\n\t| \"X-Permitted-Cross-Domain-Policies\"\n\t| \"X-Powered-By\"\n\t| \"X-Robots-Tag\"\n\t| \"X-XSS-Protection\"\n\t| AnyString;\n\nexport type CommonAuthorizationHeaders = `${\"Basic\" | \"Bearer\" | \"Token\"} ${string}`;\n\nexport type CommonContentTypes =\n\t| \"application/epub+zip\"\n\t| \"application/gzip\"\n\t| \"application/json\"\n\t| \"application/ld+json\"\n\t| \"application/octet-stream\"\n\t| \"application/ogg\"\n\t| \"application/pdf\"\n\t| \"application/rtf\"\n\t| \"application/vnd.ms-fontobject\"\n\t| \"application/wasm\"\n\t| \"application/xhtml+xml\"\n\t| \"application/xml\"\n\t| \"application/zip\"\n\t| \"audio/aac\"\n\t| \"audio/mpeg\"\n\t| \"audio/ogg\"\n\t| \"audio/opus\"\n\t| \"audio/webm\"\n\t| \"audio/x-midi\"\n\t| \"font/otf\"\n\t| \"font/ttf\"\n\t| \"font/woff\"\n\t| \"font/woff2\"\n\t| \"image/avif\"\n\t| \"image/bmp\"\n\t| \"image/gif\"\n\t| \"image/jpeg\"\n\t| \"image/png\"\n\t| \"image/svg+xml\"\n\t| \"image/tiff\"\n\t| \"image/webp\"\n\t| \"image/x-icon\"\n\t| \"model/gltf-binary\"\n\t| \"model/gltf+json\"\n\t| \"text/calendar\"\n\t| \"text/css\"\n\t| \"text/csv\"\n\t| \"text/html\"\n\t| \"text/javascript\"\n\t| \"text/plain\"\n\t| \"video/3gpp\"\n\t| \"video/3gpp2\"\n\t| \"video/av1\"\n\t| \"video/mp2t\"\n\t| \"video/mp4\"\n\t| \"video/mpeg\"\n\t| \"video/ogg\"\n\t| \"video/webm\"\n\t| \"video/x-msvideo\"\n\t| AnyString;\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\n\nimport type { Auth } from \"./auth\";\nimport type { CallApiPlugin, InferPluginOptions, PluginInitContext } from \"./plugins\";\nimport type { RetryOptions } from \"./retry\";\nimport type { getResponseType } from \"./utils/common\";\nimport type { fetchSpecificKeys } from \"./utils/constants\";\nimport {\n\ttype AnyString,\n\ttype Awaitable,\n\ttype CommonAuthorizationHeaders,\n\ttype CommonContentTypes,\n\ttype CommonRequestHeaders,\n\ttype UnmaskType,\n\tdefineEnum,\n} from \"./utils/type-helpers\";\n\ntype FetchSpecificKeysUnion = Exclude<(typeof fetchSpecificKeys)[number], \"body\" | \"headers\" | \"method\">;\n\nexport interface CallApiRequestOptions extends Pick<RequestInit, FetchSpecificKeysUnion> {\n\t/**\n\t * @description Optional body of the request, can be a object or any other supported body type.\n\t */\n\tbody?: Record<string, unknown> | RequestInit[\"body\"];\n\n\t/**\n\t * @description Headers to be used in the request.\n\t */\n\theaders?:\n\t\t| Record<\"Authorization\", CommonAuthorizationHeaders>\n\t\t| Record<\"Content-Type\", CommonContentTypes>\n\t\t| Record<CommonRequestHeaders, string | undefined>\n\t\t| Record<string, string | undefined>\n\t\t| RequestInit[\"headers\"];\n\n\t/**\n\t * @description HTTP method for the request.\n\t * @default \"GET\"\n\t */\n\tmethod?: \"DELETE\" | \"GET\" | \"PATCH\" | \"POST\" | \"PUT\" | AnyString;\n}\n\nexport interface CallApiRequestOptionsForHooks extends Omit<CallApiRequestOptions, \"headers\"> {\n\theaders?: Record<string, string | undefined>;\n}\n\n// eslint-disable-next-line ts-eslint/no-empty-object-type -- This needs to be empty to allow users to register their own meta\nexport interface Register {\n\t// == meta: Meta\n}\nexport type DefaultDataType = unknown;\nexport type DefaultMoreOptions = NonNullable<unknown>;\n\ntype WithMoreOptions<TMoreOptions = DefaultMoreOptions> = {\n\toptions: CombinedCallApiExtraOptions & Partial<TMoreOptions>;\n};\n\nexport interface Interceptors<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTMoreOptions = DefaultMoreOptions,\n> {\n\t/**\n\t * @description Interceptor that will be called when any error occurs within the request/response lifecycle, regardless of whether the error is from the api or not.\n\t * It is basically a combination of `onRequestError` and `onResponseError` interceptors\n\t */\n\tonError?: (context: ErrorContext<TErrorData> & WithMoreOptions<TMoreOptions>) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called just before the request is made, allowing for modifications or additional operations.\n\t */\n\tonRequest?: (context: RequestContext & WithMoreOptions<TMoreOptions>) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called when an error occurs during the fetch request.\n\t */\n\tonRequestError?: (context: RequestErrorContext & WithMoreOptions<TMoreOptions>) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called when any response is received from the api, whether successful or not\n\t */\n\tonResponse?: (\n\t\tcontext: ResponseContext<TData, TErrorData> & WithMoreOptions<TMoreOptions>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called when an error response is received from the api.\n\t */\n\tonResponseError?: (\n\t\tcontext: ResponseErrorContext<TErrorData> & WithMoreOptions<TMoreOptions>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * @description Interceptor that will be called when a request is retried.\n\t */\n\tonRetry?: (response: ErrorContext<TErrorData> & WithMoreOptions<TMoreOptions>) => Awaitable<unknown>;\n\t/**\n\t * @description Interceptor that will be called when a successful response is received from the api.\n\t */\n\tonSuccess?: (context: SuccessContext<TData> & WithMoreOptions<TMoreOptions>) => Awaitable<unknown>;\n}\n\n/* eslint-disable perfectionist/sort-union-types -- I need arrays to be last */\nexport type InterceptorsOrInterceptorArray<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTMoreOptions = DefaultMoreOptions,\n> = {\n\t[Key in keyof Interceptors<TData, TErrorData, TMoreOptions>]:\n\t\t| Interceptors<TData, TErrorData, TMoreOptions>[Key]\n\t\t| Array<Interceptors<TData, TErrorData, TMoreOptions>[Key]>;\n};\n/* eslint-enable perfectionist/sort-union-types -- I need arrays to be last */\n\ntype FetchImpl = UnmaskType<(input: string | Request | URL, init?: RequestInit) => Promise<Response>>;\n\nexport type Meta = Register extends { meta?: infer TMeta extends Record<string, unknown> } ? TMeta : never;\n\n// Helper type to extract plugin options\n\n// Helper type to merge all plugin options into a single type\n\nexport type ExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTPluginArray extends CallApiPlugin[] = CallApiPlugin[],\n> = InterceptorsOrInterceptorArray<TData, TErrorData> &\n\tPartial<InferPluginOptions<TPluginArray>> &\n\tRetryOptions<TErrorData> & {\n\t\t/**\n\t\t * @description Authorization header value.\n\t\t */\n\t\tauth?: string | Auth | null;\n\n\t\t/**\n\t\t * @description Base URL to be prepended to all request URLs\n\t\t */\n\t\tbaseURL?: string;\n\n\t\t/**\n\t\t * @description Custom function to serialize the body object into a string.\n\t\t */\n\t\tbodySerializer?: (bodyData: Record<string, unknown>) => string;\n\n\t\t/**\n\t\t * @description Whether or not to clone the response, so response.json() and the like, can be read again else where.\n\t\t * @see https://developer.mozilla.org/en-US/docs/Web/API/Response/clone\n\t\t * @default false\n\t\t */\n\t\tcloneResponse?: boolean;\n\n\t\t/**\n\t\t * @description Custom fetch implementation\n\t\t */\n\t\tcustomFetchImpl?: FetchImpl;\n\n\t\t/**\n\t\t * @description Custom request key to be used to identify a request in the fetch deduplication strategy.\n\t\t * @default the full request url + string formed from the request options\n\t\t */\n\t\tdedupeKey?: string;\n\n\t\t/**\n\t\t * @description Defines the deduplication strategy for the request, can be set to \"none\" | \"defer\" | \"cancel\".\n\t\t * - If set to \"cancel\", the previous pending request with the same request key will be cancelled and lets the new request through.\n\t\t * - If set to \"defer\", all new request with the same request key will be share the same response, until the previous one is completed.\n\t\t * - If set to \"none\", deduplication is disabled.\n\t\t * @default \"cancel\"\n\t\t */\n\t\tdedupeStrategy?: \"cancel\" | \"defer\" | \"none\";\n\n\t\t/**\n\t\t * @description Default error message to use if none is provided from a response.\n\t\t * @default \"Failed to fetch data from server!\"\n\t\t */\n\t\tdefaultErrorMessage?: string;\n\n\t\t/**\n\t\t * @description Resolved request URL\n\t\t */\n\t\treadonly fullURL?: string;\n\n\t\t/**\n\t\t * @description URL to be used in the request.\n\t\t */\n\t\treadonly initURL?: string;\n\n\t\t/**\n\t\t * @description Defines the mode in which the merged hooks are executed, can be set to \"parallel\" | \"sequential\".\n\t\t * - If set to \"parallel\", main and plugin hooks will be executed in parallel.\n\t\t * - If set to \"sequential\", the plugin hooks will be executed first, followed by the main hook.\n\t\t * @default \"parallel\"\n\t\t */\n\t\tmergedHooksExecutionMode?: \"parallel\" | \"sequential\";\n\n\t\t/**\n\t\t * @description - Controls what order in which the merged hooks execute\n\t\t * @default \"mainHooksLast\"\n\t\t */\n\t\tmergedHooksExecutionOrder?: \"mainHooksAfterPlugins\" | \"mainHooksBeforePlugins\";\n\n\t\t/**\n\t\t * @description - An optional field you can fill with additional information,\n\t\t * to associate with the request, typically used for logging or tracing.\n\t\t *\n\t\t * - A good use case for this, would be to use the info to handle specific cases in any of the shared interceptors.\n\t\t *\n\t\t * @example\n\t\t * ```ts\n\t\t * const callMainApi = callApi.create({\n\t\t * \tbaseURL: \"https://main-api.com\",\n\t\t * \tonResponseError: ({ response, options }) => {\n\t\t * \t\tif (options.meta?.userId) {\n\t\t * \t\t\tconsole.error(`User ${options.meta.userId} made an error`);\n\t\t * \t\t}\n\t\t * \t},\n\t\t * });\n\t\t *\n\t\t * const response = await callMainApi({\n\t\t * \turl: \"https://example.com/api/data\",\n\t\t * \tmeta: { userId: \"123\" },\n\t\t * });\n\t\t * ```\n\t\t */\n\t\tmeta?: Meta;\n\n\t\t/**\n\t\t * @description Params to be appended to the URL (i.e: /:id)\n\t\t */\n\t\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the Record to be first\n\t\tparams?: Record<string, boolean | number | string> | Array<boolean | number | string>;\n\n\t\t/**\n\t\t * @description An array of CallApi plugins. It allows you to extend the behavior of the library.\n\t\t */\n\t\tplugins?: TPluginArray | ((context: PluginInitContext) => TPluginArray);\n\n\t\t/**\n\t\t * @description Query parameters to append to the URL.\n\t\t */\n\t\tquery?: Record<string, boolean | number | string>;\n\n\t\t/**\n\t\t * @description Custom function to validate the response error data, stemming from the api.\n\t\t * This only runs if the api actually sends back error status codes, else it will be ignored, in which case you should only use the `responseValidator` option.\n\t\t */\n\t\tresponseErrorValidator?: (data: unknown) => TErrorData;\n\n\t\t/**\n\t\t * @description Custom function to parse the response string into a object.\n\t\t */\n\t\tresponseParser?: (responseString: string) => Awaitable<Record<string, unknown>>;\n\n\t\t/**\n\t\t * @description Expected response type, affects how response is parsed\n\t\t * @default \"json\"\n\t\t */\n\t\tresponseType?: keyof ReturnType<typeof getResponseType>;\n\n\t\t/**\n\t\t * @description Custom function to validate the response data.\n\t\t */\n\t\tresponseValidator?: (data: unknown) => TData;\n\n\t\t/**\n\t\t * @description Mode of the result, can influence how results are handled or returned.\n\t\t * Can be set to \"all\" | \"onlySuccess\" | \"onlyError\" | \"onlyResponse\".\n\t\t * @default \"all\"\n\t\t */\n\t\tresultMode?: TErrorData extends false ? \"onlySuccessWithException\" : TResultMode | undefined;\n\n\t\t/**\n\t\t * If true or the function returns true, throws errors instead of returning them\n\t\t * The function is passed the error object and can be used to conditionally throw the error\n\t\t * @default false\n\t\t */\n\t\tthrowOnError?: boolean | ((context: ErrorContext<TErrorData>) => boolean);\n\n\t\t/**\n\t\t * @description Request timeout in milliseconds\n\t\t */\n\t\ttimeout?: number;\n\t};\n\nexport const optionsEnumToExtendFromBase = defineEnum([\"plugins\"] satisfies Array<keyof ExtraOptions>);\n\nexport type CallApiExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTPluginArray extends CallApiPlugin[] = CallApiPlugin[],\n> = ExtraOptions<TData, TErrorData, TResultMode, TPluginArray> & {\n\t/**\n\t * @description Options that should extend the base options.\n\t */\n\textend?: Pick<\n\t\tExtraOptions<TData, TErrorData, TResultMode, TPluginArray>,\n\t\t(typeof optionsEnumToExtendFromBase)[number]\n\t>;\n};\n\nexport const optionsEnumToOmitFromBase = defineEnum([\"extend\", \"dedupeKey\"] satisfies Array<\n\tkeyof CallApiExtraOptions\n>);\n\nexport type BaseCallApiExtraOptions<\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBasePluginArray extends CallApiPlugin[] = CallApiPlugin[],\n> = Omit<\n\tCallApiExtraOptions<TBaseData, TBaseErrorData, TBaseResultMode, TBasePluginArray>,\n\t(typeof optionsEnumToOmitFromBase)[number]\n>;\n\nexport type CombinedCallApiExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTPluginArray extends CallApiPlugin[] = CallApiPlugin[],\n> = BaseCallApiExtraOptions<TData, TErrorData, TResultMode, TPluginArray> &\n\tCallApiExtraOptions<TData, TErrorData, TResultMode, TPluginArray>;\n\nexport type CallApiConfig<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTPluginArray extends CallApiPlugin[] = CallApiPlugin[],\n> = CallApiExtraOptions<TData, TErrorData, TResultMode, TPluginArray> & CallApiRequestOptions;\n\nexport type BaseCallApiConfig<\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBasePluginArray extends CallApiPlugin[] = CallApiPlugin[],\n> = BaseCallApiExtraOptions<TBaseData, TBaseErrorData, TBaseResultMode, TBasePluginArray> &\n\tCallApiRequestOptions;\n\nexport type CallApiParameters<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTPluginArray extends CallApiPlugin[] = CallApiPlugin[],\n> = [initURL: string, config?: CallApiConfig<TData, TErrorData, TResultMode, TPluginArray>];\n\nexport type RequestContext = UnmaskType<{\n\toptions: CombinedCallApiExtraOptions;\n\trequest: CallApiRequestOptionsForHooks;\n}>;\n\nexport type ResponseContext<TData, TErrorData> = UnmaskType<\n\t| {\n\t\t\tdata: TData;\n\t\t\terror: null;\n\t\t\toptions: CombinedCallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptionsForHooks;\n\t\t\tresponse: Response;\n\t }\n\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the first one to be first\n\t| {\n\t\t\tdata: null;\n\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\toptions: CombinedCallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptionsForHooks;\n\t\t\tresponse: Response;\n\t }\n>;\n\nexport type SuccessContext<TData> = UnmaskType<{\n\tdata: TData;\n\toptions: CombinedCallApiExtraOptions;\n\trequest: CallApiRequestOptionsForHooks;\n\tresponse: Response;\n}>;\n\nexport type PossibleJavascriptErrorNames =\n\t| \"AbortError\"\n\t| \"Error\"\n\t| \"SyntaxError\"\n\t| \"TimeoutError\"\n\t| \"TypeError\"\n\t| (`${string}Error` & {});\n\nexport type PossibleJavaScriptError = UnmaskType<{\n\terrorData: DOMException | Error | SyntaxError | TypeError;\n\tmessage: string;\n\tname: PossibleJavascriptErrorNames;\n}>;\n\nexport type PossibleHTTPError<TErrorData> = UnmaskType<{\n\terrorData: TErrorData;\n\tmessage: string;\n\tname: \"HTTPError\";\n}>;\n\nexport type RequestErrorContext = UnmaskType<{\n\terror: PossibleJavaScriptError;\n\toptions: CombinedCallApiExtraOptions;\n\trequest: CallApiRequestOptionsForHooks;\n}>;\n\nexport type ResponseErrorContext<TErrorData> = UnmaskType<{\n\terror: PossibleHTTPError<TErrorData>;\n\toptions: CombinedCallApiExtraOptions;\n\trequest: CallApiRequestOptionsForHooks;\n\tresponse: Response;\n}>;\n\nexport type ErrorContext<TErrorData> = UnmaskType<\n\t| {\n\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\toptions: CombinedCallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptionsForHooks;\n\t\t\tresponse: Response;\n\t }\n\t| {\n\t\t\terror: PossibleJavaScriptError;\n\t\t\toptions: CombinedCallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptionsForHooks;\n\t\t\tresponse: null;\n\t }\n>;\n\nexport type CallApiResultSuccessVariant<TData> = {\n\tdata: TData;\n\terror: null;\n\tresponse: Response;\n};\n\nexport type CallApiResultErrorVariant<TErrorData> =\n\t| {\n\t\t\tdata: null;\n\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\tresponse: Response;\n\t }\n\t| {\n\t\t\tdata: null;\n\t\t\terror: PossibleJavaScriptError;\n\t\t\tresponse: null;\n\t };\n\nexport type ResultModeMap<TData = DefaultDataType, TErrorData = DefaultDataType> = {\n\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the first one to be first\n\tall: CallApiResultSuccessVariant<TData> | CallApiResultErrorVariant<TErrorData>;\n\tonlyError: CallApiResultErrorVariant<TErrorData>[\"error\"] | CallApiResultSuccessVariant<TData>[\"error\"];\n\tonlyResponse:\n\t\t| CallApiResultErrorVariant<TErrorData>[\"response\"]\n\t\t| CallApiResultSuccessVariant<TData>[\"response\"];\n\tonlySuccess: CallApiResultErrorVariant<TErrorData>[\"data\"] | CallApiResultSuccessVariant<TData>[\"data\"];\n\tonlySuccessWithException: CallApiResultSuccessVariant<TData>[\"data\"];\n};\n\nexport type ResultModeUnion = { [Key in keyof ResultModeMap]: Key }[keyof ResultModeMap] | undefined;\n\nexport type GetCallApiResult<TData, TErrorData, TResultMode> = TErrorData extends false\n\t? ResultModeMap<TData, TErrorData>[\"onlySuccessWithException\"]\n\t: undefined extends TResultMode\n\t\t? ResultModeMap<TData, TErrorData>[\"all\"]\n\t\t: TResultMode extends NonNullable<ResultModeUnion>\n\t\t\t? ResultModeMap<TData, TErrorData>[TResultMode]\n\t\t\t: never;\n","import type { BaseCallApiConfig } from \"../types\";\nimport { defineEnum } from \"./type-helpers\";\n\nexport const fetchSpecificKeys = defineEnum([\n\t\"body\",\n\t\"integrity\",\n\t\"method\",\n\t\"headers\",\n\t\"signal\",\n\t\"cache\",\n\t\"redirect\",\n\t\"window\",\n\t\"credentials\",\n\t\"keepalive\",\n\t\"referrer\",\n\t\"priority\",\n\t\"mode\",\n\t\"referrerPolicy\",\n] satisfies Array<keyof RequestInit>);\n\nconst retryStatusCodesLookup = defineEnum({\n\t408: \"Request Timeout\",\n\t409: \"Conflict\",\n\t425: \"Too Early\",\n\t429: \"Too Many Requests\",\n\t500: \"Internal Server Error\",\n\t502: \"Bad Gateway\",\n\t503: \"Service Unavailable\",\n\t504: \"Gateway Timeout\",\n});\n\nexport const defaultRetryMethods = [\"GET\", \"POST\"] satisfies BaseCallApiConfig[\"retryMethods\"];\n\n// prettier-ignore\nexport const defaultRetryStatusCodes = Object.keys(retryStatusCodesLookup).map(Number) as Required<BaseCallApiConfig>[\"retryStatusCodes\"];\n","import { getAuthHeader } from \"@/auth\";\nimport {\n\ttype BaseCallApiExtraOptions,\n\ttype CallApiConfig,\n\ttype CallApiExtraOptions,\n\ttype CallApiRequestOptions,\n\ttype ResultModeMap,\n\toptionsEnumToOmitFromBase,\n} from \"../types\";\nimport { fetchSpecificKeys } from \"./constants\";\nimport { isArray, isFunction, isPlainObject, isQueryString, isString } from \"./type-guards\";\nimport type { AnyFunction, Awaitable } from \"./type-helpers\";\n\nconst omitKeys = <TObject extends Record<string, unknown>, const TOmitArray extends Array<keyof TObject>>(\n\tinitialObject: TObject,\n\tkeysToOmit: TOmitArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tconst keysToOmitSet = new Set(keysToOmit);\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (!keysToOmitSet.has(key)) {\n\t\t\tupdatedObject[key] = value;\n\t\t}\n\t}\n\n\treturn updatedObject as Omit<TObject, TOmitArray[number]>;\n};\n\nconst pickKeys = <TObject extends Record<string, unknown>, const TPickArray extends Array<keyof TObject>>(\n\tinitialObject: TObject,\n\tkeysToPick: TPickArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tconst keysToPickSet = new Set(keysToPick);\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (keysToPickSet.has(key)) {\n\t\t\tupdatedObject[key] = value;\n\t\t}\n\t}\n\n\treturn updatedObject as Pick<TObject, TPickArray[number]>;\n};\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport const splitBaseConfig = (baseConfig: Record<string, any>) =>\n\t[\n\t\tpickKeys(baseConfig, fetchSpecificKeys) as CallApiRequestOptions,\n\t\tomitKeys(baseConfig, [\n\t\t\t...fetchSpecificKeys,\n\t\t\t...optionsEnumToOmitFromBase,\n\t\t]) as BaseCallApiExtraOptions,\n\t] as const;\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport const splitConfig = (config: Record<string, any>) =>\n\t[\n\t\tpickKeys(config, fetchSpecificKeys) as CallApiRequestOptions,\n\t\tomitKeys(config, fetchSpecificKeys) as CallApiExtraOptions,\n\t] as const;\n\nexport const objectifyHeaders = (headers: CallApiRequestOptions[\"headers\"]) => {\n\tif (!headers || isPlainObject(headers)) {\n\t\treturn headers;\n\t}\n\n\treturn Object.fromEntries(headers);\n};\n\ntype ToQueryStringFn = {\n\t(params: CallApiConfig[\"query\"]): string | null;\n\t(params: Required<CallApiConfig>[\"query\"]): string;\n};\n\nexport const toQueryString: ToQueryStringFn = (params) => {\n\tif (!params) {\n\t\tconsole.error(\"toQueryString:\", \"No query params provided!\");\n\n\t\treturn null as never;\n\t}\n\n\treturn new URLSearchParams(params as Record<string, string>).toString();\n};\n\n// export mergeAndResolve\n\nexport const mergeAndResolveHeaders = (options: {\n\tauth: CallApiConfig[\"auth\"];\n\tbaseHeaders: CallApiConfig[\"headers\"];\n\tbody: CallApiConfig[\"body\"];\n\theaders: CallApiConfig[\"headers\"];\n}) => {\n\tconst { auth, baseHeaders, body, headers } = options;\n\n\t// eslint-disable-next-line ts-eslint/prefer-nullish-coalescing -- Nullish coalescing makes no sense in this boolean context\n\tconst shouldResolveHeaders = Boolean(baseHeaders || headers || body || auth);\n\n\t// == Return early if any of the following conditions are not met (so that native fetch would auto set the correct headers):\n\t// == - headers are provided\n\t// == - The body is an object\n\t// == - The auth option is provided\n\tif (!shouldResolveHeaders) return;\n\n\tconst headersObject: Record<string, string | undefined> = {\n\t\t...getAuthHeader(auth),\n\t\t...objectifyHeaders(baseHeaders),\n\t\t...objectifyHeaders(headers),\n\t};\n\n\tif (isQueryString(body)) {\n\t\theadersObject[\"Content-Type\"] = \"application/x-www-form-urlencoded\";\n\n\t\treturn headersObject;\n\t}\n\n\tif (isPlainObject(body) || (isString(body) && body.startsWith(\"{\"))) {\n\t\theadersObject[\"Content-Type\"] = \"application/json\";\n\t\theadersObject.Accept = \"application/json\";\n\t}\n\n\treturn headersObject;\n};\n\nexport const combineHooks = <\n\tTInterceptor extends\n\t\t| AnyFunction<Awaitable<unknown>>\n\t\t| Array<AnyFunction<Awaitable<unknown>> | undefined>,\n>(\n\tbaseInterceptor: TInterceptor | undefined,\n\tinterceptor: TInterceptor | undefined\n) => {\n\tif (isArray(baseInterceptor)) {\n\t\treturn [baseInterceptor, interceptor].flat() as TInterceptor;\n\t}\n\n\treturn interceptor ?? baseInterceptor;\n};\n\nexport const getFetchImpl = (customFetchImpl: CallApiExtraOptions[\"customFetchImpl\"]) => {\n\tif (customFetchImpl) {\n\t\treturn customFetchImpl;\n\t}\n\n\tif (typeof globalThis !== \"undefined\" && isFunction(globalThis.fetch)) {\n\t\treturn globalThis.fetch;\n\t}\n\n\tthrow new Error(\"No fetch implementation found\");\n};\n\nexport const getResponseType = <TResponse>(\n\tresponse: Response,\n\tparser?: Required<CallApiExtraOptions>[\"responseParser\"]\n) => ({\n\tarrayBuffer: () => response.arrayBuffer() as Promise<TResponse>,\n\tblob: () => response.blob() as Promise<TResponse>,\n\tformData: () => response.formData() as Promise<TResponse>,\n\tjson: async () => {\n\t\tif (parser) {\n\t\t\tconst text = await response.text();\n\t\t\treturn parser(text);\n\t\t}\n\n\t\treturn response.json() as Promise<TResponse>;\n\t},\n\tstream: () => response.body,\n\ttext: () => response.text() as Promise<TResponse>,\n});\n\nexport const executeHooks = <TInterceptor extends Awaitable<unknown>>(...interceptors: TInterceptor[]) =>\n\tPromise.all(interceptors);\n\nexport const getResponseData = async <TResponse>(\n\tresponse: Response,\n\tresponseType: keyof ReturnType<typeof getResponseType>,\n\tparser: CallApiExtraOptions[\"responseParser\"],\n\tvalidator?: CallApiExtraOptions[\"responseValidator\"]\n) => {\n\tconst RESPONSE_TYPE_LOOKUP = getResponseType<TResponse>(response, parser);\n\n\tif (!Object.hasOwn(RESPONSE_TYPE_LOOKUP, responseType)) {\n\t\tthrow new Error(`Invalid response type: ${responseType}`);\n\t}\n\n\tconst responseData = await RESPONSE_TYPE_LOOKUP[responseType]();\n\n\tconst validResponseData = validator ? validator(responseData) : responseData;\n\n\treturn validResponseData;\n};\n\ntype SuccessInfo = {\n\tdata: unknown;\n\tresponse: Response;\n\tresultMode: CallApiExtraOptions[\"resultMode\"];\n};\n\n// == The CallApiResult type is used to cast all return statements due to a design limitation in ts.\n// LINK - See https://www.zhenghao.io/posts/type-functions for more info\nexport const resolveSuccessResult = <TCallApiResult>(info: SuccessInfo): TCallApiResult => {\n\tconst { data, response, resultMode } = info;\n\n\tconst apiDetails = { data, error: null, response };\n\n\tif (!resultMode) {\n\t\treturn apiDetails as TCallApiResult;\n\t}\n\n\tconst resultModeMap: ResultModeMap = {\n\t\tall: apiDetails,\n\t\tonlyError: apiDetails.error,\n\t\tonlyResponse: apiDetails.response,\n\t\tonlySuccess: apiDetails.data,\n\t\tonlySuccessWithException: apiDetails.data,\n\t};\n\n\treturn resultModeMap[resultMode] as TCallApiResult;\n};\n\nconst PromiseWithResolvers = () => {\n\tlet reject!: (reason?: unknown) => void;\n\tlet resolve!: (value: unknown) => void;\n\n\tconst promise = new Promise((res, rej) => {\n\t\tresolve = res;\n\t\treject = rej;\n\t});\n\n\treturn { promise, reject, resolve };\n};\n\nexport const waitUntil = (delay: number) => {\n\tif (delay === 0) return;\n\n\tconst { promise, resolve } = PromiseWithResolvers();\n\n\tsetTimeout(resolve, delay);\n\n\treturn promise;\n};\n","import type { CallApiExtraOptions, CallApiRequestOptions } from \"./types\";\nimport { getFetchImpl, waitUntil } from \"./utils/common\";\n\ntype RequestInfo = {\n\tcontroller: AbortController;\n\tresponsePromise: Promise<Response>;\n};\n\nexport type RequestInfoCache = Map<string | null, RequestInfo>;\n\ntype DedupeContext = {\n\t$RequestInfoCache: RequestInfoCache;\n\tnewFetchController: AbortController;\n\toptions: CallApiExtraOptions;\n\trequest: CallApiRequestOptions;\n};\n\nexport const createDedupeStrategy = async (context: DedupeContext) => {\n\tconst { $RequestInfoCache, newFetchController, options, request } = context;\n\n\tconst generateDedupeKey = () => {\n\t\tconst shouldHaveDedupeKey =\n\t\t\toptions.dedupeStrategy === \"cancel\" || options.dedupeStrategy === \"defer\";\n\n\t\tif (!shouldHaveDedupeKey) {\n\t\t\treturn null;\n\t\t}\n\n\t\treturn `${options.fullURL}-${JSON.stringify({ options, request })}`;\n\t};\n\n\tconst dedupeKey = options.dedupeKey ?? generateDedupeKey();\n\n\t// == This is to ensure cache operations only occur when key is available\n\tconst $RequestInfoCacheOrNull = dedupeKey !== null ? $RequestInfoCache : null;\n\n\t/******\n\t * == Add a small delay to the execution to ensure proper request deduplication when multiple requests with the same key start simultaneously.\n\t * == This gives time for the cache to be updated with the previous request info before the next request checks it.\n\t ******/\n\tif (dedupeKey !== null) {\n\t\tawait waitUntil(0.1);\n\t}\n\n\tconst prevRequestInfo = $RequestInfoCacheOrNull?.get(dedupeKey);\n\n\tconst handleRequestCancelDedupeStrategy = () => {\n\t\tconst shouldCancelRequest = prevRequestInfo && options.dedupeStrategy === \"cancel\";\n\n\t\tif (shouldCancelRequest) {\n\t\t\tconst message = options.dedupeKey\n\t\t\t\t? `Duplicate request detected - Aborting previous request with key '${options.dedupeKey}' as a new request was initiated`\n\t\t\t\t: `Duplicate request detected - Aborting previous request to '${options.fullURL}' as a new request with identical options was initiated`;\n\n\t\t\tconst reason = new DOMException(message, \"AbortError\");\n\n\t\t\tprevRequestInfo.controller.abort(reason);\n\t\t}\n\t};\n\n\tconst handleRequestDeferDedupeStrategy = () => {\n\t\tconst fetchApi = getFetchImpl(options.customFetchImpl);\n\n\t\tconst shouldUsePromiseFromCache = prevRequestInfo && options.dedupeStrategy === \"defer\";\n\n\t\tconst responsePromise = shouldUsePromiseFromCache\n\t\t\t? prevRequestInfo.responsePromise\n\t\t\t: fetchApi(options.fullURL as NonNullable<typeof options.fullURL>, request as RequestInit);\n\n\t\t$RequestInfoCacheOrNull?.set(dedupeKey, { controller: newFetchController, responsePromise });\n\n\t\treturn responsePromise;\n\t};\n\n\tconst removeDedupeKeyFromCache = () => $RequestInfoCacheOrNull?.delete(dedupeKey);\n\n\treturn {\n\t\thandleRequestCancelDedupeStrategy,\n\t\thandleRequestDeferDedupeStrategy,\n\t\tremoveDedupeKeyFromCache,\n\t};\n};\n","import type {\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n\tCombinedCallApiExtraOptions,\n\tExtraOptions,\n\tInterceptors,\n\tInterceptorsOrInterceptorArray,\n} from \"./types\";\nimport { isFunction, isPlainObject, isString } from \"./utils/type-guards\";\nimport type { AnyFunction, Awaitable } from \"./utils/type-helpers\";\n\ntype UnionToIntersection<TUnion> = (TUnion extends unknown ? (param: TUnion) => void : never) extends (\n\tparam: infer TParam\n) => void\n\t? TParam\n\t: never;\n\nexport type InferPluginOptions<TPluginArray extends CallApiPlugin[]> =\n\tTPluginArray extends Array<infer TPlugin extends CallApiPlugin>\n\t\t? TPlugin[\"createExtraOptions\"] extends (...params: never[]) => infer TResult\n\t\t\t? UnionToIntersection<TResult>\n\t\t\t: NonNullable<unknown>\n\t\t: NonNullable<unknown>;\n\nexport type PluginInitContext = {\n\tinitURL: string;\n\toptions: CombinedCallApiExtraOptions;\n\trequest: CallApiRequestOptionsForHooks;\n};\n\nexport type PluginInitResult = Partial<\n\tOmit<PluginInitContext, \"request\"> & { request: CallApiRequestOptions }\n>;\n\nexport type CallApiPlugin = {\n\t/**\n\t * @description Defines additional options that can be passed to callApi\n\t */\n\tcreateExtraOptions?: (...params: never[]) => unknown;\n\n\t/**\n\t * @description A description for the plugin\n\t */\n\tdescription?: string;\n\n\t/**\n\t * Hooks / Interceptors for the plugin\n\t */\n\thooks?: InterceptorsOrInterceptorArray;\n\n\t/**\n\t * @description A unique id for the plugin\n\t */\n\tid: string;\n\n\t/**\n\t * @description A function that will be called when the plugin is\n\t * initialized. This will be called before the any\n\t * of the other internal functions.\n\t */\n\tinit?: (context: PluginInitContext) => Awaitable<PluginInitResult> | Awaitable<void>;\n\n\t/**\n\t * @description A name for the plugin\n\t */\n\tname: string;\n\n\t/**\n\t * @description A version for the plugin\n\t */\n\tversion?: string;\n};\n\n// eslint-disable-next-line perfectionist/sort-union-types -- Let the first one be first\nexport const definePlugin = <TPlugin extends CallApiPlugin | AnyFunction<CallApiPlugin> = CallApiPlugin>(\n\tplugin: TPlugin\n) => {\n\treturn plugin;\n};\n\nconst createMergedHook = (\n\thooks: Array<AnyFunction<Awaitable<unknown>> | undefined>,\n\tmergedHooksExecutionMode: CombinedCallApiExtraOptions[\"mergedHooksExecutionMode\"]\n) => {\n\treturn async (ctx: Record<string, unknown>) => {\n\t\tif (mergedHooksExecutionMode === \"sequential\") {\n\t\t\tfor (const hook of hooks) {\n\t\t\t\t// eslint-disable-next-line no-await-in-loop -- This is necessary in this case\n\t\t\t\tawait hook?.(ctx);\n\t\t\t}\n\n\t\t\treturn;\n\t\t}\n\n\t\tif (mergedHooksExecutionMode === \"parallel\") {\n\t\t\tconst hookArray = [...hooks];\n\n\t\t\tawait Promise.all(hookArray.map((uniqueHook) => uniqueHook?.(ctx)));\n\t\t}\n\t};\n};\n\n// prettier-ignore\ntype HookRegistries = {\n\t[Key in keyof Interceptors]: Set<Interceptors[Key]>;\n};\n\nexport const hooksEnum = {\n\tonError: new Set(),\n\tonRequest: new Set(),\n\tonRequestError: new Set(),\n\tonResponse: new Set(),\n\tonResponseError: new Set(),\n\tonRetry: new Set(),\n\tonSuccess: new Set(),\n} satisfies HookRegistries;\n\nexport const initializePlugins = async (context: PluginInitContext) => {\n\tconst { initURL, options, request } = context;\n\n\tconst hookRegistries = structuredClone(hooksEnum);\n\n\tconst addMainHooks = () => {\n\t\tfor (const key of Object.keys(hooksEnum)) {\n\t\t\tconst mainHook = options[key as keyof Interceptors] as never;\n\n\t\t\thookRegistries[key as keyof Interceptors].add(mainHook);\n\t\t}\n\t};\n\n\tconst addPluginHooks = (pluginHooks: InterceptorsOrInterceptorArray) => {\n\t\tfor (const key of Object.keys(hooksEnum)) {\n\t\t\tconst pluginHook = pluginHooks[key as keyof Interceptors] as never;\n\n\t\t\thookRegistries[key as keyof Interceptors].add(pluginHook);\n\t\t}\n\t};\n\n\tif (options.mergedHooksExecutionOrder === \"mainHooksBeforePlugins\") {\n\t\taddMainHooks();\n\t}\n\n\tconst getPluginArray = (plugins: ExtraOptions[\"plugins\"]) => {\n\t\tif (!plugins) {\n\t\t\treturn [];\n\t\t}\n\n\t\treturn isFunction(plugins) ? plugins({ initURL, options, request }) : plugins;\n\t};\n\n\tconst resolvedPlugins = [\n\t\t...getPluginArray(options.plugins),\n\t\t...getPluginArray(options.extend?.plugins),\n\t];\n\n\tlet resolvedUrl = initURL;\n\tlet resolvedOptions = options;\n\tlet resolvedRequestOptions = request;\n\n\tconst executePluginInit = async (pluginInit: CallApiPlugin[\"init\"]) => {\n\t\tif (!pluginInit) return;\n\n\t\tconst initResult = await pluginInit({ initURL, options, request });\n\n\t\tif (!isPlainObject(initResult)) return;\n\n\t\tif (isString(initResult.initURL)) {\n\t\t\tresolvedUrl = initResult.initURL;\n\t\t}\n\n\t\tif (isPlainObject(initResult.request)) {\n\t\t\tresolvedRequestOptions = initResult.request;\n\t\t}\n\n\t\tif (isPlainObject(initResult.options)) {\n\t\t\tresolvedOptions = initResult.options;\n\t\t}\n\t};\n\n\tfor (const plugin of resolvedPlugins) {\n\t\t// eslint-disable-next-line no-await-in-loop -- Await is necessary in this case.\n\t\tawait executePluginInit(plugin.init);\n\n\t\tif (!plugin.hooks) continue;\n\n\t\taddPluginHooks(plugin.hooks);\n\t}\n\n\tif (\n\t\t!options.mergedHooksExecutionOrder ||\n\t\toptions.mergedHooksExecutionOrder === \"mainHooksAfterPlugins\"\n\t) {\n\t\taddMainHooks();\n\t}\n\n\tconst resolvedHooks = {} as Required<Interceptors>;\n\n\tfor (const [key, hookRegistry] of Object.entries(hookRegistries)) {\n\t\tconst flattenedHookArray = [...hookRegistry].flat();\n\n\t\tconst mergedHook = createMergedHook(flattenedHookArray, options.mergedHooksExecutionMode);\n\n\t\tresolvedHooks[key as keyof Interceptors] = mergedHook;\n\t}\n\n\treturn {\n\t\tresolvedHooks,\n\t\tresolvedOptions,\n\t\tresolvedRequestOptions,\n\t\turl: resolvedUrl,\n\t};\n};\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\n\nimport type { ErrorContext } from \"./types\";\nimport type { AnyNumber, AnyString } from \"./utils/type-helpers\";\n\ntype RetryCondition<TErrorData> = (context: ErrorContext<TErrorData>) => boolean | Promise<boolean>;\n\nexport interface RetryOptions<TErrorData> {\n\t/**\n\t * @description Keeps track of the number of times the request has already been retried\n\t * @deprecated This property is used internally to track retries. Please abstain from modifying it.\n\t */\n\treadonly \"~retryCount\"?: number;\n\n\t/**\n\t * @description Number of allowed retry attempts on HTTP errors\n\t * @default 0\n\t */\n\tretryAttempts?: number;\n\n\t/**\n\t * @description Callback whose return value determines if a request should be retried or not\n\t */\n\tretryCondition?: RetryCondition<TErrorData>;\n\n\t/**\n\t * @description Delay between retries in milliseconds\n\t * @default 1000\n\t */\n\tretryDelay?: number;\n\n\t/**\n\t * @description Maximum delay in milliseconds. Only applies to exponential strategy\n\t * @default 10000\n\t */\n\tretryMaxDelay?: number;\n\n\t/**\n\t * HTTP methods that are allowed to retry\n\t * @default [\"GET\", \"POST\"]\n\t */\n\tretryMethods?: Array<\"GET\" | \"POST\" | AnyString>;\n\n\t/**\n\t * @description HTTP status codes that trigger a retry\n\t * @default [409, 425, 429, 500, 502, 503, 504]\n\t */\n\tretryStatusCodes?: Array<409 | 425 | 429 | 500 | 502 | 503 | 504 | AnyNumber>;\n\n\t/**\n\t * @description Strategy to use when retrying\n\t * @default \"linear\"\n\t */\n\tretryStrategy?: \"exponential\" | \"linear\";\n}\n\nconst getLinearDelay = <TErrorData>(options: RetryOptions<TErrorData>) => options.retryDelay ?? 1000;\n\nconst getExponentialDelay = <TErrorData>(\n\tcurrentAttemptCount: number,\n\toptions: RetryOptions<TErrorData>\n) => {\n\tconst maxDelay = options.retryMaxDelay ?? 10000;\n\n\tconst exponentialDelay = (options.retryDelay ?? 1000) * 2 ** currentAttemptCount;\n\n\treturn Math.min(exponentialDelay, maxDelay);\n};\n\nexport const createRetryStrategy = <TErrorData>(\n\toptions: RetryOptions<TErrorData>,\n\tctx: ErrorContext<TErrorData>\n) => {\n\tconst currentRetryCount = options[\"~retryCount\"] ?? 0;\n\n\treturn {\n\t\tgetDelay: () => {\n\t\t\tif (options.retryStrategy === \"exponential\") {\n\t\t\t\treturn getExponentialDelay(currentRetryCount, options);\n\t\t\t}\n\n\t\t\treturn getLinearDelay(options);\n\t\t},\n\n\t\tshouldAttemptRetry: async () => {\n\t\t\tconst customRetryCondition = (await options.retryCondition?.(ctx)) ?? true;\n\n\t\t\tconst maxRetryAttempts = options.retryAttempts ?? 0;\n\n\t\t\tconst baseRetryCondition = maxRetryAttempts > currentRetryCount && customRetryCondition;\n\n\t\t\tif (ctx.error.name !== \"HTTPError\") {\n\t\t\t\treturn baseRetryCondition;\n\t\t\t}\n\n\t\t\tconst includesMethod =\n\t\t\t\t// eslint-disable-next-line no-implicit-coercion -- Boolean doesn't narrow\n\t\t\t\t!!ctx.request.method && options.retryMethods?.includes(ctx.request.method);\n\n\t\t\tconst includesCodes =\n\t\t\t\t// eslint-disable-next-line no-implicit-coercion -- Boolean doesn't narrow\n\t\t\t\t!!ctx.response?.status && options.retryStatusCodes?.includes(ctx.response.status);\n\n\t\t\treturn includesCodes && includesMethod && baseRetryCondition;\n\t\t},\n\t};\n};\n","import type { CallApiConfig, CallApiExtraOptions } from \"./types\";\nimport { toQueryString } from \"./utils\";\nimport { isArray } from \"./utils/type-guards\";\n\nconst slash = \"/\";\nconst column = \":\";\nconst mergeUrlWithParams = (url: string, params: CallApiExtraOptions[\"params\"]) => {\n\tif (!params) {\n\t\treturn url;\n\t}\n\n\tlet newUrl = url;\n\n\tif (isArray(params)) {\n\t\tconst matchedParamArray = newUrl.split(slash).filter((param) => param.startsWith(column));\n\n\t\tfor (const [index, matchedParam] of matchedParamArray.entries()) {\n\t\t\tconst realParam = params[index] as string;\n\t\t\tnewUrl = newUrl.replace(matchedParam, realParam);\n\t\t}\n\n\t\treturn newUrl;\n\t}\n\n\tfor (const [key, value] of Object.entries(params)) {\n\t\tnewUrl = newUrl.replace(`${column}${key}`, String(value));\n\t}\n\n\treturn newUrl;\n};\n\nconst questionMark = \"?\";\nconst ampersand = \"&\";\nconst mergeUrlWithQuery = (url: string, query: CallApiConfig[\"query\"]): string => {\n\tif (!query) {\n\t\treturn url;\n\t}\n\n\tconst queryString = toQueryString(query);\n\n\tif (queryString?.length === 0) {\n\t\treturn url;\n\t}\n\n\tif (url.endsWith(questionMark)) {\n\t\treturn `${url}${queryString}`;\n\t}\n\n\tif (url.includes(questionMark)) {\n\t\treturn `${url}${ampersand}${queryString}`;\n\t}\n\n\treturn `${url}${questionMark}${queryString}`;\n};\n\nexport const mergeUrlWithParamsAndQuery = (\n\turl: string,\n\tparams: CallApiExtraOptions[\"params\"],\n\tquery: CallApiExtraOptions[\"query\"]\n) => {\n\tconst urlWithMergedParams = mergeUrlWithParams(url, params);\n\n\treturn mergeUrlWithQuery(urlWithMergedParams, query);\n};\n","// prettier-ignore\nexport const createCombinedSignal = (...signals: Array<AbortSignal | null | undefined>) => AbortSignal.any(signals.filter(Boolean));\n\nexport const createTimeoutSignal = (milliseconds: number) => AbortSignal.timeout(milliseconds);\n","import { type RequestInfoCache, createDedupeStrategy } from \"./dedupe\";\nimport { HTTPError, resolveErrorResult } from \"./error\";\nimport { type CallApiPlugin, hooksEnum, initializePlugins } from \"./plugins\";\nimport { createRetryStrategy } from \"./retry\";\nimport type {\n\tBaseCallApiConfig,\n\tCallApiConfig,\n\tCallApiParameters,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n\tCombinedCallApiExtraOptions,\n\tDefaultDataType,\n\tGetCallApiResult,\n\tInterceptors,\n\tResultModeUnion,\n} from \"./types\";\nimport { mergeUrlWithParamsAndQuery } from \"./url\";\nimport {\n\tcombineHooks,\n\texecuteHooks,\n\tgetResponseData,\n\tmergeAndResolveHeaders,\n\tresolveSuccessResult,\n\tsplitBaseConfig,\n\tsplitConfig,\n\twaitUntil,\n} from \"./utils/common\";\nimport { defaultRetryMethods, defaultRetryStatusCodes } from \"./utils/constants\";\nimport { createCombinedSignal, createTimeoutSignal } from \"./utils/polyfills\";\nimport { isFunction, isHTTPErrorInstance, isPlainObject } from \"./utils/type-guards\";\n\nexport const createFetchClient = <\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBasePluginArray extends CallApiPlugin[] = CallApiPlugin[],\n>(\n\tbaseConfig?: BaseCallApiConfig<TBaseData, TBaseErrorData, TBaseResultMode, TBasePluginArray>\n) => {\n\tconst [baseFetchConfig, baseExtraOptions] = splitBaseConfig(baseConfig ?? {});\n\n\tconst $RequestInfoCache: RequestInfoCache = new Map();\n\n\tconst callApi = async <\n\t\tTData = TBaseData,\n\t\tTErrorData = TBaseErrorData,\n\t\tTResultMode extends ResultModeUnion = TBaseResultMode,\n\t\tTPluginArray extends CallApiPlugin[] = TBasePluginArray,\n\t>(\n\t\t...parameters: CallApiParameters<TData, TErrorData, TResultMode, TPluginArray>\n\t): Promise<GetCallApiResult<TData, TErrorData, TResultMode>> => {\n\t\tconst [initURL, config = {} as never] = parameters;\n\n\t\tconst [fetchConfig, extraOptions] = splitConfig(config);\n\n\t\tconst initCombinedHooks = {} as Required<Interceptors>;\n\n\t\tfor (const key of Object.keys(hooksEnum)) {\n\t\t\tconst combinedHook = combineHooks(\n\t\t\t\tbaseExtraOptions[key as keyof Interceptors],\n\t\t\t\textraOptions[key as keyof Interceptors]\n\t\t\t);\n\n\t\t\tinitCombinedHooks[key as keyof Interceptors] = combinedHook as never;\n\t\t}\n\n\t\t// == Default Extra Options\n\t\tconst defaultExtraOptions = {\n\t\t\tbaseURL: \"\",\n\t\t\tbodySerializer: JSON.stringify,\n\t\t\tdedupeStrategy: \"cancel\",\n\t\t\tdefaultErrorMessage: \"Failed to fetch data from server!\",\n\t\t\tmergedHooksExecutionMode: \"parallel\",\n\t\t\tmergedHooksExecutionOrder: \"mainHooksAfterPlugins\",\n\t\t\tresponseType: \"json\",\n\t\t\tresultMode: \"all\",\n\t\t\tretryAttempts: 0,\n\t\t\tretryDelay: 1000,\n\t\t\tretryMaxDelay: 10000,\n\t\t\tretryMethods: defaultRetryMethods,\n\t\t\tretryStatusCodes: defaultRetryStatusCodes,\n\t\t\tretryStrategy: \"linear\",\n\n\t\t\t...baseExtraOptions,\n\t\t\t...extraOptions,\n\n\t\t\t...initCombinedHooks,\n\t\t} satisfies CombinedCallApiExtraOptions;\n\n\t\tconst body = fetchConfig.body ?? baseFetchConfig.body;\n\n\t\t// == Default Request Options\n\t\tconst defaultRequestOptions = {\n\t\t\tbody: isPlainObject(body) ? defaultExtraOptions.bodySerializer(body) : body,\n\t\t\tmethod: \"GET\",\n\n\t\t\t...baseFetchConfig,\n\t\t\t...fetchConfig,\n\n\t\t\theaders: mergeAndResolveHeaders({\n\t\t\t\tauth: defaultExtraOptions.auth,\n\t\t\t\tbaseHeaders: baseFetchConfig.headers,\n\t\t\t\tbody,\n\t\t\t\theaders: fetchConfig.headers,\n\t\t\t}),\n\n\t\t\tsignal: fetchConfig.signal ?? baseFetchConfig.signal,\n\t\t} satisfies CallApiRequestOptions;\n\n\t\tconst { resolvedHooks, resolvedOptions, resolvedRequestOptions, url } = await initializePlugins({\n\t\t\tinitURL,\n\t\t\toptions: defaultExtraOptions,\n\t\t\trequest: defaultRequestOptions,\n\t\t});\n\n\t\tconst fullURL = `${resolvedOptions.baseURL}${mergeUrlWithParamsAndQuery(url, resolvedOptions.params, resolvedOptions.query)}`;\n\n\t\tconst options = {\n\t\t\t...resolvedOptions,\n\t\t\t...resolvedHooks,\n\t\t\tfullURL,\n\t\t\tinitURL,\n\t\t} satisfies CombinedCallApiExtraOptions as typeof defaultExtraOptions & typeof resolvedHooks;\n\n\t\tconst newFetchController = new AbortController();\n\n\t\tconst timeoutSignal = options.timeout != null ? createTimeoutSignal(options.timeout) : null;\n\n\t\tconst combinedSignal = createCombinedSignal(\n\t\t\tresolvedRequestOptions.signal,\n\t\t\ttimeoutSignal,\n\t\t\tnewFetchController.signal\n\t\t);\n\n\t\tconst request = {\n\t\t\t...resolvedRequestOptions,\n\t\t\tsignal: combinedSignal,\n\t\t} satisfies CallApiRequestOptionsForHooks;\n\n\t\tconst {\n\t\t\thandleRequestCancelDedupeStrategy,\n\t\t\thandleRequestDeferDedupeStrategy,\n\t\t\tremoveDedupeKeyFromCache,\n\t\t} = await createDedupeStrategy({ $RequestInfoCache, newFetchController, options, request });\n\n\t\thandleRequestCancelDedupeStrategy();\n\n\t\ttry {\n\t\t\tawait executeHooks(options.onRequest({ options, request }));\n\n\t\t\t// == Apply determined headers again after onRequest incase they were modified\n\t\t\trequest.headers = mergeAndResolveHeaders({\n\t\t\t\tauth: options.auth,\n\t\t\t\tbaseHeaders: baseFetchConfig.headers,\n\t\t\t\tbody,\n\t\t\t\theaders: request.headers,\n\t\t\t});\n\n\t\t\tconst response = await handleRequestDeferDedupeStrategy();\n\n\t\t\t// == Also clone response when dedupeStrategy is set to \"defer\", to avoid error thrown from reading response.(whatever) more than once\n\t\t\tconst shouldCloneResponse = options.dedupeStrategy === \"defer\" || options.cloneResponse;\n\n\t\t\tif (!response.ok) {\n\t\t\t\tconst errorData = await getResponseData<TErrorData>(\n\t\t\t\t\tshouldCloneResponse ? response.clone() : response,\n\t\t\t\t\toptions.responseType,\n\t\t\t\t\toptions.responseParser,\n\t\t\t\t\toptions.responseErrorValidator\n\t\t\t\t);\n\n\t\t\t\t// == Push all error handling responsibilities to the catch block if not retrying\n\t\t\t\tthrow new HTTPError({\n\t\t\t\t\tdefaultErrorMessage: options.defaultErrorMessage,\n\t\t\t\t\terrorData,\n\t\t\t\t\tresponse,\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconst successData = await getResponseData<TData>(\n\t\t\t\tshouldCloneResponse ? response.clone() : response,\n\t\t\t\toptions.responseType,\n\t\t\t\toptions.responseParser,\n\t\t\t\toptions.responseValidator\n\t\t\t);\n\n\t\t\tconst successContext = {\n\t\t\t\tdata: successData as never,\n\t\t\t\toptions,\n\t\t\t\trequest,\n\t\t\t\tresponse: options.cloneResponse ? response.clone() : response,\n\t\t\t};\n\n\t\t\tawait executeHooks(\n\t\t\t\toptions.onSuccess(successContext),\n\n\t\t\t\toptions.onResponse({ ...successContext, error: null })\n\t\t\t);\n\n\t\t\treturn await resolveSuccessResult({\n\t\t\t\tdata: successContext.data,\n\t\t\t\tresponse: successContext.response,\n\t\t\t\tresultMode: options.resultMode,\n\t\t\t});\n\n\t\t\t// == Exhaustive Error handling\n\t\t} catch (error) {\n\t\t\tconst { errorVariantDetails, getErrorResult } = resolveErrorResult({\n\t\t\t\tcloneResponse: options.cloneResponse,\n\t\t\t\tdefaultErrorMessage: options.defaultErrorMessage,\n\t\t\t\terror,\n\t\t\t\tresultMode: options.resultMode,\n\t\t\t});\n\n\t\t\tconst errorContext = {\n\t\t\t\terror: errorVariantDetails.error as never,\n\t\t\t\toptions,\n\t\t\t\trequest,\n\t\t\t};\n\n\t\t\tconst errorContextWithResponse = {\n\t\t\t\t...errorContext,\n\t\t\t\tresponse: errorVariantDetails.response as NonNullable<typeof errorVariantDetails.response>,\n\t\t\t};\n\n\t\t\tconst { getDelay, shouldAttemptRetry } = createRetryStrategy(options, errorContextWithResponse);\n\n\t\t\tconst shouldRetry = !combinedSignal.aborted && (await shouldAttemptRetry());\n\n\t\t\tif (shouldRetry) {\n\t\t\t\tawait executeHooks(options.onRetry(errorContextWithResponse));\n\n\t\t\t\tconst delay = getDelay();\n\n\t\t\t\tawait waitUntil(delay);\n\n\t\t\t\t// prettier-ignore\n\t\t\t\tconst updatedOptions = {...config, \"~retryCount\": (options[\"~retryCount\"] ?? 0) + 1} satisfies CallApiConfig<TData, TErrorData, TResultMode>\n\n\t\t\t\treturn await callApi(initURL, updatedOptions);\n\t\t\t}\n\n\t\t\tconst shouldThrowOnError = isFunction(options.throwOnError)\n\t\t\t\t? options.throwOnError(errorContextWithResponse)\n\t\t\t\t: options.throwOnError;\n\n\t\t\t// eslint-disable-next-line unicorn/consistent-function-scoping -- False alarm: this function is depends on this scope\n\t\t\tconst handleThrowOnError = () => {\n\t\t\t\tif (!shouldThrowOnError) return;\n\n\t\t\t\t// eslint-disable-next-line ts-eslint/only-throw-error -- It's fine to throw this\n\t\t\t\tthrow errorVariantDetails.error;\n\t\t\t};\n\n\t\t\tif (isHTTPErrorInstance<TErrorData>(error)) {\n\t\t\t\tawait executeHooks(\n\t\t\t\t\toptions.onResponseError(errorContextWithResponse),\n\n\t\t\t\t\toptions.onError(errorContextWithResponse),\n\n\t\t\t\t\toptions.onResponse({ ...errorContextWithResponse, data: null })\n\t\t\t\t);\n\n\t\t\t\thandleThrowOnError();\n\n\t\t\t\treturn getErrorResult();\n\t\t\t}\n\n\t\t\tif (error instanceof DOMException && error.name === \"AbortError\") {\n\t\t\t\tconst { message, name } = error;\n\n\t\t\t\tconsole.error(`${name}:`, message);\n\n\t\t\t\thandleThrowOnError();\n\n\t\t\t\treturn getErrorResult();\n\t\t\t}\n\n\t\t\tif (error instanceof DOMException && error.name === \"TimeoutError\") {\n\t\t\t\tconst message = `Request timed out after ${options.timeout}ms`;\n\n\t\t\t\tconsole.error(`${error.name}:`, message);\n\n\t\t\t\thandleThrowOnError();\n\n\t\t\t\treturn getErrorResult({ message });\n\t\t\t}\n\n\t\t\tawait executeHooks(\n\t\t\t\t// == At this point only the request errors exist, so the request error interceptor is called\n\t\t\t\toptions.onRequestError(errorContext),\n\n\t\t\t\t// == Also call the onError interceptor\n\t\t\t\toptions.onError(errorContextWithResponse)\n\t\t\t);\n\n\t\t\thandleThrowOnError();\n\n\t\t\treturn getErrorResult();\n\n\t\t\t// == Removing the now unneeded AbortController from store\n\t\t} finally {\n\t\t\tremoveDedupeKeyFromCache();\n\t\t}\n\t};\n\n\tcallApi.create = createFetchClient;\n\n\treturn callApi;\n};\n\nexport const callApi = createFetchClient({});\n"],"mappings":"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","names":["callApi"]}
@@ -1,16 +1,17 @@
1
- import { R as ResultModeUnion, A as AnyObject, B as BaseCallApiConfig, C as CallApiConfig, G as GetCallApiResult } from './index-BpNetCiS.cjs';
2
- export { b as BaseCallApiExtraOptions, c as CallApiExtraOptions, g as CallApiParameters, a as CallApiPlugin, h as CallApiRequestOptions, i as CallApiRequestOptionsForHooks, j as CallApiResultErrorVariant, k as CallApiResultSuccessVariant, l as CombinedCallApiExtraOptions, E as ErrorContext, I as Interceptors, m as InterceptorsOrInterceptorArray, P as PluginInitContext, f as PossibleHTTPError, e as PossibleJavaScriptError, n as PossibleJavascriptErrorNames, o as Register, p as RequestContext, q as RequestErrorContext, r as ResponseContext, s as ResponseErrorContext, S as SuccessContext, d as definePlugin } from './index-BpNetCiS.cjs';
1
+ import { R as ResultModeUnion, C as CallApiPlugin, B as BaseCallApiConfig, a as CallApiConfig, G as GetCallApiResult } from './plugins-Ds-irdHk.cjs';
2
+ export { b as BaseCallApiExtraOptions, c as CallApiExtraOptions, g as CallApiParameters, h as CallApiRequestOptions, i as CallApiRequestOptionsForHooks, j as CallApiResultErrorVariant, k as CallApiResultSuccessVariant, l as CombinedCallApiExtraOptions, E as ErrorContext, I as Interceptors, m as InterceptorsOrInterceptorArray, P as PluginInitContext, f as PossibleHTTPError, e as PossibleJavaScriptError, n as PossibleJavascriptErrorNames, o as Register, p as RequestContext, q as RequestErrorContext, r as ResponseContext, s as ResponseErrorContext, S as SuccessContext, d as definePlugin } from './plugins-Ds-irdHk.cjs';
3
+ export { H as HTTPError } from './error-lBRMiMeF.cjs';
3
4
 
4
- declare const createFetchClient: <TBaseData = unknown, TBaseErrorData = unknown, TBaseResultMode extends ResultModeUnion = ResultModeUnion, TBaseMoreOptions extends AnyObject = {}>(baseConfig?: BaseCallApiConfig<TBaseData, TBaseErrorData, TBaseResultMode, TBaseMoreOptions>) => {
5
- <TData = TBaseData, TErrorData = TBaseErrorData, TResultMode extends ResultModeUnion = TBaseResultMode, TMoreOptions extends AnyObject = TBaseMoreOptions>(initURL: string, config?: CallApiConfig<TData, TErrorData, TResultMode, TMoreOptions> | undefined): Promise<GetCallApiResult<TData, TErrorData, TResultMode>>;
5
+ declare const createFetchClient: <TBaseData = unknown, TBaseErrorData = unknown, TBaseResultMode extends ResultModeUnion = ResultModeUnion, TBasePluginArray extends CallApiPlugin[] = CallApiPlugin[]>(baseConfig?: BaseCallApiConfig<TBaseData, TBaseErrorData, TBaseResultMode, TBasePluginArray>) => {
6
+ <TData = TBaseData, TErrorData = TBaseErrorData, TResultMode extends ResultModeUnion = TBaseResultMode, TPluginArray extends CallApiPlugin[] = TBasePluginArray>(initURL: string, config?: CallApiConfig<TData, TErrorData, TResultMode, TPluginArray> | undefined): Promise<GetCallApiResult<TData, TErrorData, TResultMode>>;
6
7
  create: /*elided*/ any;
7
8
  };
8
9
  declare const callApi: {
9
- <TData = unknown, TErrorData = unknown, TResultMode extends ResultModeUnion = ResultModeUnion, TMoreOptions extends AnyObject = {}>(initURL: string, config?: CallApiConfig<TData, TErrorData, TResultMode, TMoreOptions> | undefined): Promise<GetCallApiResult<TData, TErrorData, TResultMode>>;
10
- create: <TBaseData = unknown, TBaseErrorData = unknown, TBaseResultMode extends ResultModeUnion = ResultModeUnion, TBaseMoreOptions extends AnyObject = {}>(baseConfig?: BaseCallApiConfig<TBaseData, TBaseErrorData, TBaseResultMode, TBaseMoreOptions>) => {
11
- <TData = TBaseData, TErrorData = TBaseErrorData, TResultMode extends ResultModeUnion = TBaseResultMode, TMoreOptions extends AnyObject = TBaseMoreOptions>(initURL: string, config?: CallApiConfig<TData, TErrorData, TResultMode, TMoreOptions> | undefined): Promise<GetCallApiResult<TData, TErrorData, TResultMode>>;
10
+ <TData = unknown, TErrorData = unknown, TResultMode extends ResultModeUnion = ResultModeUnion, TPluginArray extends CallApiPlugin[] = CallApiPlugin[]>(initURL: string, config?: CallApiConfig<TData, TErrorData, TResultMode, TPluginArray> | undefined): Promise<GetCallApiResult<TData, TErrorData, TResultMode>>;
11
+ create: <TBaseData = unknown, TBaseErrorData = unknown, TBaseResultMode extends ResultModeUnion = ResultModeUnion, TBasePluginArray extends CallApiPlugin[] = CallApiPlugin[]>(baseConfig?: BaseCallApiConfig<TBaseData, TBaseErrorData, TBaseResultMode, TBasePluginArray>) => {
12
+ <TData = TBaseData, TErrorData = TBaseErrorData, TResultMode extends ResultModeUnion = TBaseResultMode, TPluginArray extends CallApiPlugin[] = TBasePluginArray>(initURL: string, config?: CallApiConfig<TData, TErrorData, TResultMode, TPluginArray> | undefined): Promise<GetCallApiResult<TData, TErrorData, TResultMode>>;
12
13
  create: /*elided*/ any;
13
14
  };
14
15
  };
15
16
 
16
- export { BaseCallApiConfig, CallApiConfig, ResultModeUnion, callApi, createFetchClient };
17
+ export { BaseCallApiConfig, CallApiConfig, CallApiPlugin, ResultModeUnion, callApi, createFetchClient };
@@ -1 +1 @@
1
- "use strict";var e,r=Object.defineProperty,t=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,s=Object.prototype.hasOwnProperty,n={};((e,t)=>{for(var o in t)r(e,o,{get:t[o],enumerable:!0})})(n,{callApiWithOptions:()=>G,createFetchClientWithOptions:()=>I,defineOptions:()=>K}),module.exports=(e=n,((e,n,a,i)=>{if(n&&"object"==typeof n||"function"==typeof n)for(let l of o(n))s.call(e,l)||l===a||r(e,l,{get:()=>n[l],enumerable:!(i=t(n,l))||i.enumerable});return e})(r({},"__esModule",{value:!0}),e));var a=e=>Array.isArray(e),i=e=>{if(!(e=>"object"==typeof e&&null!==e)(e))return!1;const r=Object.getPrototypeOf(e);return(null==r||r===Object.prototype||null===Object.getPrototypeOf(r))&&!(Symbol.toStringTag in e)},l=e=>"function"==typeof e,u=e=>"string"==typeof e,c=e=>l(e)?e():e,p=e=>{if(void 0!==e){if(u(e)||null===e)return{Authorization:`Bearer ${e}`};switch(e.type){case"Basic":{const r=c(e.username),t=c(e.password);if(void 0===r||void 0===t)return;return{Authorization:`Basic ${globalThis.btoa(`${r}:${t}`)}`}}case"Custom":{const r=c(e.value);if(void 0===r)return;return{Authorization:`${c(e.prefix)} ${r}`}}default:{const r=c(e.bearer),t=c(e.token);return"token"in e&&void 0!==t?{Authorization:`Token ${t}`}:void 0!==r&&{Authorization:`Bearer ${r}`}}}}},d=["extend","dedupeKey"],y=["body","integrity","method","headers","signal","cache","redirect","window","credentials","keepalive","referrer","priority","mode","referrerPolicy"],f={408:"Request Timeout",409:"Conflict",425:"Too Early",429:"Too Many Requests",500:"Internal Server Error",502:"Bad Gateway",503:"Service Unavailable",504:"Gateway Timeout"},m=["GET","POST"],g=Object.keys(f).map(Number),w=(e,r)=>{const t={},o=new Set(r);for(const[r,s]of Object.entries(e))o.has(r)||(t[r]=s);return t},h=(e,r)=>{const t={},o=new Set(r);for(const[r,s]of Object.entries(e))o.has(r)&&(t[r]=s);return t},E=e=>[h(e,y),w(e,[...y,...d])],b=e=>[h(e,y),w(e,y)],R=e=>!e||i(e)?e:Object.fromEntries(e),O=e=>{const{auth:r,baseHeaders:t,body:o,headers:s}=e;if(!Boolean(t||s||o||r))return;const n={...p(r),...R(t),...R(s)};return u(a=o)&&a.includes("=")?(n["Content-Type"]="application/x-www-form-urlencoded",n):((i(o)||u(o)&&o.startsWith("{"))&&(n["Content-Type"]="application/json",n.Accept="application/json"),n);var a},q=(e,r)=>a(e)?[e,r].flat():r??e,S=(...e)=>Promise.all(e),M=async(e,r,t,o)=>{const s=((e,r)=>({arrayBuffer:()=>e.arrayBuffer(),blob:()=>e.blob(),formData:()=>e.formData(),json:async()=>{if(r){const t=await e.text();return r(t)}return e.json()},stream:()=>e.body,text:()=>e.text()}))(e,t);if(!Object.hasOwn(s,r))throw new Error(`Invalid response type: ${r}`);const n=await s[r]();return o?o(n):n},v=e=>{const{data:r,response:t,resultMode:o}=e,s={data:r,error:null,response:t};if(!o)return s;return{all:s,onlyError:s.error,onlyResponse:s.response,onlySuccess:s.data,onlySuccessWithException:s.data}[o]},T=e=>{const{defaultErrorMessage:r,error:t,message:o,resultMode:s}=e;let n={data:null,error:{errorData:t,message:o??t.message,name:t.name},response:null};if(k(t)){const{errorData:e,message:o=r,name:s,response:a}=t;n={data:null,error:{errorData:e,message:o,name:s},response:a}}return{apiDetails:n,generalErrorResult:{all:n,onlyError:n.error,onlyResponse:n.response,onlySuccess:n.data,onlySuccessWithException:n.data}[s??"all"],resolveCustomErrorInfo:({message:r})=>T({...e,message:r}).generalErrorResult}},D=class extends Error{errorData;isHTTPError=!0;name="HTTPError";response;constructor(e,r){const{defaultErrorMessage:t,errorData:o,response:s}=e;super(o?.message??t,r),this.errorData=o,this.response=s,Error.captureStackTrace(this,this.constructor)}},k=e=>e instanceof D||i(e)&&"HTTPError"===e.name&&!0===e.isHTTPError,$=e=>{if(0===e)return;const{promise:r,resolve:t}=(()=>{let e,r;return{promise:new Promise(((t,o)=>{r=t,e=o})),reject:e,resolve:r}})();return setTimeout(t,e),r},x=(e,r,t)=>"cancel"===t.dedupeStrategy||"defer"===t.dedupeStrategy?`${t.fullURL}-${JSON.stringify({options:t,request:r})}`:null,P=(e,r,t)=>{if(t&&"cancel"===r.dedupeStrategy){const e=r.dedupeKey?`Duplicate request detected - Aborting previous request with key '${r.dedupeKey}' as a new request was initiated`:`Duplicate request detected - Aborting previous request to '${r.fullURL}' as a new request with identical options was initiated`,o=new DOMException(e,"AbortError");t.controller.abort(o)}},j=(e,r,t,o)=>{const s=(e=>{if(e)return e;if("undefined"!=typeof globalThis&&l(globalThis.fetch))return globalThis.fetch;throw new Error("No fetch implementation found")})(r.customFetchImpl);return o&&"defer"===r.dedupeStrategy?o.responsePromise:s(e,t)},A=(e,r)=>async t=>{if("sequential"!==r){if("parallel"===r){const r=[...e];await Promise.all(r.map((e=>e?.(t))))}}else for(const r of e)await(r?.(t))},H={onError:new Set,onRequest:new Set,onRequestError:new Set,onResponse:new Set,onResponseError:new Set,onRetry:new Set,onSuccess:new Set},C=async e=>{const{initURL:r,options:t,request:o}=e,s=structuredClone(H),n=()=>{for(const e of Object.keys(H)){const r=t[e];s[e].add(r)}},a=e=>{for(const r of Object.keys(H)){const t=e[r];s[r].add(t)}};"mainHooksBeforePlugins"===t.mergedHooksExecutionOrder&&n();const c=e=>e?l(e)?e({initURL:r,options:t,request:o}):e:[],p=[...c(t.plugins),...c(t.extend?.plugins)];let d=r,y=t,f=o;const m=async e=>{if(!e)return;const s=await e({initURL:r,options:t,request:o});i(s)&&(u(s.initURL)&&(d=s.initURL),i(s.request)&&(f=s.request),i(s.options)&&(y=s.options))};for(const e of p)await m(e.init),e.hooks&&a(e.hooks);t.mergedHooksExecutionOrder&&"mainHooksAfterPlugins"!==t.mergedHooksExecutionOrder||n();const g={};for(const[e,r]of Object.entries(s)){const o=[...r].flat(),s=A(o,t.mergedHooksExecutionMode);g[e]=s}return{resolvedHooks:g,resolvedOptions:y,resolvedRequestOptions:f,url:d}},U=(e,r)=>{const t=e.retryCount??0;return{getDelay:()=>"exponential"===e.retryStrategy?((e,r)=>{const t=r.retryMaxDelay??1e4,o=(r.retryDelay??1e3)*2**e;return Math.min(o,t)})(t,e):(e=>e.retryDelay??1e3)(e),shouldAttemptRetry:async()=>{const o=await(e.retryCondition?.(r))??!0,s=(e.retryAttempts??0)>t&&o;if("HTTPError"!==r.error.name)return s;const n=!!r.request.method&&e.retryMethods?.includes(r.request.method);return!!r.response?.status&&e.retryStatusCodes?.includes(r.response.status)&&n&&s}}},L=(e,r)=>{if(!r)return e;const t=(o=r)?new URLSearchParams(o).toString():(console.error("toQueryString:","No query params provided!"),null);var o;return 0===t?.length?e:e.endsWith("?")?`${e}${t}`:e.includes("?")?`${e}&${t}`:`${e}?${t}`},B=(e,r,t)=>{const o=((e,r)=>{if(!r)return e;let t=e;if(a(r)){const e=t.split("/").filter((e=>e.startsWith(":")));for(const[o,s]of e.entries()){const e=r[o];t=t.replace(s,e)}return t}for(const[e,o]of Object.entries(r))t=t.replace(`:${e}`,String(o));return t})(e,r);return L(o,t)},z=(...e)=>AbortSignal.any(e.filter(Boolean)),N=e=>AbortSignal.timeout(e),W=(e={})=>{const[r,t]=E(e),{body:o,headers:s,signal:n,...a}=r,u=new Map,c=async(...e)=>{const[r,p={}]=e,[d,y]=b(p),{body:f=o,headers:w,signal:h=n,...E}=d,R={};for(const e of Object.keys(H)){const r=q(t[e],y[e]);R[e]=r}const A={baseURL:"",bodySerializer:JSON.stringify,dedupeStrategy:"cancel",defaultErrorMessage:"Failed to fetch data from server!",mergedHooksExecutionMode:"parallel",mergedHooksExecutionOrder:"mainHooksAfterPlugins",responseType:"json",resultMode:"all",retryAttempts:0,retryDelay:1e3,retryMaxDelay:1e4,retryMethods:m,retryStatusCodes:g,retryStrategy:"linear",...t,...y,...R},{resolvedHooks:L,resolvedOptions:W,resolvedRequestOptions:I,url:G}=await C({initURL:r,options:A,request:{...a,...E}}),K=`${W.baseURL}${B(G,W.params,W.query)}`,F={...W,...L,fullURL:K,initURL:r},V={body:i(f)?F.bodySerializer(f):f,method:"GET",...I},J=new AbortController,_=null!=F.timeout?N(F.timeout):null,Q=z(J.signal,_,h),X={signal:Q,...V},Y=F.dedupeKey??x(0,X,F);null!==Y&&await $(.1);const Z=null!==Y?u:null,ee=Z?.get(Y);P(0,F,ee);try{await S(F.onRequest({options:F,request:X})),X.headers=O({auth:F.auth,baseHeaders:s??w,body:f,headers:X.headers});const e=j(K,F,X,ee);Z?.set(Y,{controller:J,responsePromise:e});const r=await e,t="defer"===F.dedupeStrategy||F.cloneResponse;if(!r.ok){const e=await M(t?r.clone():r,F.responseType,F.responseParser,F.responseErrorValidator);throw new D({defaultErrorMessage:F.defaultErrorMessage,errorData:e,response:r})}const o=await M(t?r.clone():r,F.responseType,F.responseParser,F.responseValidator);return await S(F.onSuccess({data:o,options:F,request:X,response:F.cloneResponse?r.clone():r}),F.onResponse({data:o,error:null,options:F,request:X,response:F.cloneResponse?r.clone():r})),await v({data:o,response:r,resultMode:F.resultMode})}catch(e){const{apiDetails:t,generalErrorResult:o,resolveCustomErrorInfo:s}=T({defaultErrorMessage:F.defaultErrorMessage,error:e,resultMode:F.resultMode}),n={error:t.error,options:F,request:X,response:t.response},{getDelay:a,shouldAttemptRetry:i}=U(F,n);if(!Q.aborted&&await i()){await S(F.onRetry(n));const e=a();await $(e);const t={...p,retryCount:(F.retryCount??0)+1};return await c(r,t)}const u=l(F.throwOnError)?F.throwOnError(n):F.throwOnError,d=()=>{if(u)throw t.error};if(k(e)){const{response:r}=e,t=o.error;return await S(F.onResponseError({error:t,options:F,request:X,response:F.cloneResponse?r.clone():r}),F.onError({error:t,options:F,request:X,response:F.cloneResponse?r.clone():r}),F.onResponse({data:null,error:t,options:F,request:X,response:F.cloneResponse?r.clone():r})),d(),o}if(e instanceof DOMException&&"AbortError"===e.name){const{message:r,name:t}=e;return console.error(`${t}:`,r),d(),o}if(e instanceof DOMException&&"TimeoutError"===e.name){const r=`Request timed out after ${F.timeout}ms`;return console.error(`${e.name}:`,r),d(),s({message:r})}const y=o.error;return await S(F.onRequestError({error:y,options:F,request:X}),F.onError({error:y,options:F,request:X,response:null})),d(),o}finally{Z?.delete(Y)}};return c.create=W,c},I=(W(),(e={})=>{const[r,t]=E(e),{body:o,headers:s,signal:n,...a}=r,u=new Map,c=async e=>{const{initURL:r,...p}=e,[d,y]=b(p),{body:f=o,headers:w,signal:h=n,...E}=d,R={};for(const e of Object.keys(H)){const r=q(t[e],y[e]);R[e]=r}const A={baseURL:"",bodySerializer:JSON.stringify,dedupeStrategy:"cancel",defaultErrorMessage:"Failed to fetch data from server!",mergedHooksExecutionMode:"parallel",mergedHooksExecutionOrder:"mainHooksAfterPlugins",responseType:"json",resultMode:"all",retryAttempts:0,retryDelay:1e3,retryMaxDelay:1e4,retryMethods:m,retryStatusCodes:g,retryStrategy:"linear",...t,...y,...R},{resolvedHooks:L,resolvedOptions:W,resolvedRequestOptions:I,url:G}=await C({initURL:r,options:A,request:{...a,...E}}),K=`${W.baseURL}${B(G,W.params,W.query)}`,F={...W,...L,fullURL:K,initURL:r},V={body:i(f)?F.bodySerializer(f):f,method:"GET",...I},J=new AbortController,_=null!=F.timeout?N(F.timeout):null,Q=z(J.signal,_,h),X={signal:Q,...V},Y=F.dedupeKey??x(0,X,F);null!==Y&&await $(.1);const Z=null!==Y?u:null,ee=Z?.get(Y);P(0,F,ee);try{await S(F.onRequest({options:F,request:X})),X.headers=O({auth:F.auth,baseHeaders:s??w,body:f,headers:X.headers});const e=j(K,F,X,ee);Z?.set(Y,{controller:J,responsePromise:e});const r=await e,t="defer"===F.dedupeStrategy||F.cloneResponse;if(!r.ok){const e=await M(t?r.clone():r,F.responseType,F.responseParser,F.responseErrorValidator);throw new D({defaultErrorMessage:F.defaultErrorMessage,errorData:e,response:r})}const o=await M(t?r.clone():r,F.responseType,F.responseParser,F.responseValidator);return await S(F.onSuccess({data:o,options:F,request:X,response:F.cloneResponse?r.clone():r}),F.onResponse({data:o,error:null,options:F,request:X,response:F.cloneResponse?r.clone():r})),await v({data:o,response:r,resultMode:F.resultMode})}catch(r){const{apiDetails:t,generalErrorResult:o,resolveCustomErrorInfo:s}=T({defaultErrorMessage:F.defaultErrorMessage,error:r,resultMode:F.resultMode}),n={error:t.error,options:F,request:X,response:t.response},{getDelay:a,shouldAttemptRetry:i}=U(F,n);if(!Q.aborted&&await i()){await S(F.onRetry(n));const r=a();await $(r);const t={...e,retryCount:(F.retryCount??0)+1};return await c(t)}const u=l(F.throwOnError)?F.throwOnError(n):F.throwOnError,p=()=>{if(u)throw t.error};if(k(r)){const{response:e}=r,t=o.error;return await S(F.onResponseError({error:t,options:F,request:X,response:F.cloneResponse?e.clone():e}),F.onError({error:t,options:F,request:X,response:F.cloneResponse?e.clone():e}),F.onResponse({data:null,error:t,options:F,request:X,response:F.cloneResponse?e.clone():e})),p(),o}if(r instanceof DOMException&&"AbortError"===r.name){const{message:e,name:t}=r;return console.error(`${t}:`,e),p(),o}if(r instanceof DOMException&&"TimeoutError"===r.name){const e=`Request timed out after ${F.timeout}ms`;return console.error(`${r.name}:`,e),p(),s({message:e})}const d=o.error;return await S(F.onRequestError({error:d,options:F,request:X}),F.onError({error:d,options:F,request:X,response:null})),p(),o}finally{Z?.delete(Y)}};return c.create=W,c}),G=I(),K=e=>e;//# sourceMappingURL=index.cjs.map
1
+ "use strict";var e,r=Object.defineProperty,t=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,s=Object.prototype.hasOwnProperty,n={};((e,t)=>{for(var o in t)r(e,o,{get:t[o],enumerable:!0})})(n,{callApiWithOptions:()=>N,createFetchClientWithOptions:()=>K,defineOptions:()=>V}),module.exports=(e=n,((e,n,a,i)=>{if(n&&"object"==typeof n||"function"==typeof n)for(let l of o(n))s.call(e,l)||l===a||r(e,l,{get:()=>n[l],enumerable:!(i=t(n,l))||i.enumerable});return e})(r({},"__esModule",{value:!0}),e));var a=e=>{const{cloneResponse:r,defaultErrorMessage:t,error:o,message:s,resultMode:n}=e;let a={data:null,error:{errorData:o,message:s??o.message,name:o.name},response:null};if(l(o)){const{errorData:e,message:s=t,name:n,response:i}=o;a={data:null,error:{errorData:e,message:s,name:n},response:r?i.clone():i}}const i={all:a,onlyError:a.error,onlyResponse:a.response,onlySuccess:a.data,onlySuccessWithException:a.data};return{errorVariantDetails:a,getErrorResult:e=>{const r=i[n??"all"];return c(e)?{...r,...e}:r}}},i=class extends Error{errorData;isHTTPError=!0;name="HTTPError";response;constructor(e,r){const{defaultErrorMessage:t,errorData:o,response:s}=e;super(o?.message??t,r),this.errorData=o,this.response=s,Error.captureStackTrace(this,this.constructor)}},l=e=>e instanceof i||d(e)&&"HTTPError"===e.name&&!0===e.isHTTPError,u=e=>Array.isArray(e),c=e=>"object"==typeof e&&null!==e,d=e=>{if(!c(e))return!1;const r=Object.getPrototypeOf(e);return(null==r||r===Object.prototype||null===Object.getPrototypeOf(r))&&!(Symbol.toStringTag in e)},p=e=>"function"==typeof e,y=e=>"string"==typeof e,f=e=>p(e)?e():e,h=e=>{if(void 0!==e){if(y(e)||null===e)return{Authorization:`Bearer ${e}`};switch(e.type){case"Basic":{const r=f(e.username),t=f(e.password);if(void 0===r||void 0===t)return;return{Authorization:`Basic ${globalThis.btoa(`${r}:${t}`)}`}}case"Custom":{const r=f(e.value);if(void 0===r)return;return{Authorization:`${f(e.prefix)} ${r}`}}default:{const r=f(e.bearer),t=f(e.token);return"token"in e&&void 0!==t?{Authorization:`Token ${t}`}:void 0!==r&&{Authorization:`Bearer ${r}`}}}}},m=["extend","dedupeKey"],g=["body","integrity","method","headers","signal","cache","redirect","window","credentials","keepalive","referrer","priority","mode","referrerPolicy"],w={408:"Request Timeout",409:"Conflict",425:"Too Early",429:"Too Many Requests",500:"Internal Server Error",502:"Bad Gateway",503:"Service Unavailable",504:"Gateway Timeout"},b=["GET","POST"],E=Object.keys(w).map(Number),R=(e,r)=>{const t={},o=new Set(r);for(const[r,s]of Object.entries(e))o.has(r)||(t[r]=s);return t},S=(e,r)=>{const t={},o=new Set(r);for(const[r,s]of Object.entries(e))o.has(r)&&(t[r]=s);return t},O=e=>[S(e,g),R(e,[...g,...m])],q=e=>[S(e,g),R(e,g)],D=e=>!e||d(e)?e:Object.fromEntries(e),M=e=>{const{auth:r,baseHeaders:t,body:o,headers:s}=e;if(!Boolean(t||s||o||r))return;const n={...h(r),...D(t),...D(s)};return y(a=o)&&a.includes("=")?(n["Content-Type"]="application/x-www-form-urlencoded",n):((d(o)||y(o)&&o.startsWith("{"))&&(n["Content-Type"]="application/json",n.Accept="application/json"),n);var a},v=(e,r)=>u(e)?[e,r].flat():r??e,T=(...e)=>Promise.all(e),$=async(e,r,t,o)=>{const s=((e,r)=>({arrayBuffer:()=>e.arrayBuffer(),blob:()=>e.blob(),formData:()=>e.formData(),json:async()=>{if(r){const t=await e.text();return r(t)}return e.json()},stream:()=>e.body,text:()=>e.text()}))(e,t);if(!Object.hasOwn(s,r))throw new Error(`Invalid response type: ${r}`);const n=await s[r]();return o?o(n):n},k=e=>{const{data:r,response:t,resultMode:o}=e,s={data:r,error:null,response:t};if(!o)return s;return{all:s,onlyError:s.error,onlyResponse:s.response,onlySuccess:s.data,onlySuccessWithException:s.data}[o]},C=e=>{if(0===e)return;const{promise:r,resolve:t}=(()=>{let e,r;return{promise:new Promise(((t,o)=>{r=t,e=o})),reject:e,resolve:r}})();return setTimeout(t,e),r},x=async e=>{const{$RequestInfoCache:r,newFetchController:t,options:o,request:s}=e,n=o.dedupeKey??("cancel"===o.dedupeStrategy||"defer"===o.dedupeStrategy?`${o.fullURL}-${JSON.stringify({options:o,request:s})}`:null),a=null!==n?r:null;null!==n&&await C(.1);const i=a?.get(n);return{handleRequestCancelDedupeStrategy:()=>{if(i&&"cancel"===o.dedupeStrategy){const e=o.dedupeKey?`Duplicate request detected - Aborting previous request with key '${o.dedupeKey}' as a new request was initiated`:`Duplicate request detected - Aborting previous request to '${o.fullURL}' as a new request with identical options was initiated`,r=new DOMException(e,"AbortError");i.controller.abort(r)}},handleRequestDeferDedupeStrategy:()=>{const e=(e=>{if(e)return e;if("undefined"!=typeof globalThis&&p(globalThis.fetch))return globalThis.fetch;throw new Error("No fetch implementation found")})(o.customFetchImpl),r=i&&"defer"===o.dedupeStrategy?i.responsePromise:e(o.fullURL,s);return a?.set(n,{controller:t,responsePromise:r}),r},removeDedupeKeyFromCache:()=>a?.delete(n)}},j=(e,r)=>async t=>{if("sequential"!==r){if("parallel"===r){const r=[...e];await Promise.all(r.map((e=>e?.(t))))}}else for(const r of e)await(r?.(t))},A={onError:new Set,onRequest:new Set,onRequestError:new Set,onResponse:new Set,onResponseError:new Set,onRetry:new Set,onSuccess:new Set},P=async e=>{const{initURL:r,options:t,request:o}=e,s=structuredClone(A),n=()=>{for(const e of Object.keys(A)){const r=t[e];s[e].add(r)}},a=e=>{for(const r of Object.keys(A)){const t=e[r];s[r].add(t)}};"mainHooksBeforePlugins"===t.mergedHooksExecutionOrder&&n();const i=e=>e?p(e)?e({initURL:r,options:t,request:o}):e:[],l=[...i(t.plugins),...i(t.extend?.plugins)];let u=r,c=t,f=o;const h=async e=>{if(!e)return;const s=await e({initURL:r,options:t,request:o});d(s)&&(y(s.initURL)&&(u=s.initURL),d(s.request)&&(f=s.request),d(s.options)&&(c=s.options))};for(const e of l)await h(e.init),e.hooks&&a(e.hooks);t.mergedHooksExecutionOrder&&"mainHooksAfterPlugins"!==t.mergedHooksExecutionOrder||n();const m={};for(const[e,r]of Object.entries(s)){const o=[...r].flat(),s=j(o,t.mergedHooksExecutionMode);m[e]=s}return{resolvedHooks:m,resolvedOptions:c,resolvedRequestOptions:f,url:u}},H=(e,r)=>{const t=e["~retryCount"]??0;return{getDelay:()=>"exponential"===e.retryStrategy?((e,r)=>{const t=r.retryMaxDelay??1e4,o=(r.retryDelay??1e3)*2**e;return Math.min(o,t)})(t,e):(e=>e.retryDelay??1e3)(e),shouldAttemptRetry:async()=>{const o=await(e.retryCondition?.(r))??!0,s=(e.retryAttempts??0)>t&&o;if("HTTPError"!==r.error.name)return s;const n=!!r.request.method&&e.retryMethods?.includes(r.request.method);return!!r.response?.status&&e.retryStatusCodes?.includes(r.response.status)&&n&&s}}},U=(e,r)=>{if(!r)return e;const t=(o=r)?new URLSearchParams(o).toString():(console.error("toQueryString:","No query params provided!"),null);var o;return 0===t?.length?e:e.endsWith("?")?`${e}${t}`:e.includes("?")?`${e}&${t}`:`${e}?${t}`},L=(e,r,t)=>{const o=((e,r)=>{if(!r)return e;let t=e;if(u(r)){const e=t.split("/").filter((e=>e.startsWith(":")));for(const[o,s]of e.entries()){const e=r[o];t=t.replace(s,e)}return t}for(const[e,o]of Object.entries(r))t=t.replace(`:${e}`,String(o));return t})(e,r);return U(o,t)},B=(...e)=>AbortSignal.any(e.filter(Boolean)),F=e=>AbortSignal.timeout(e),z=e=>{const[r,t]=O(e??{}),o=new Map,s=async(...e)=>{const[n,u={}]=e,[c,y]=q(u),f={};for(const e of Object.keys(A)){const r=v(t[e],y[e]);f[e]=r}const h={baseURL:"",bodySerializer:JSON.stringify,dedupeStrategy:"cancel",defaultErrorMessage:"Failed to fetch data from server!",mergedHooksExecutionMode:"parallel",mergedHooksExecutionOrder:"mainHooksAfterPlugins",responseType:"json",resultMode:"all",retryAttempts:0,retryDelay:1e3,retryMaxDelay:1e4,retryMethods:b,retryStatusCodes:E,retryStrategy:"linear",...t,...y,...f},m=c.body??r.body,g={body:d(m)?h.bodySerializer(m):m,method:"GET",...r,...c,headers:M({auth:h.auth,baseHeaders:r.headers,body:m,headers:c.headers}),signal:c.signal??r.signal},{resolvedHooks:w,resolvedOptions:R,resolvedRequestOptions:S,url:O}=await P({initURL:n,options:h,request:g}),D=`${R.baseURL}${L(O,R.params,R.query)}`,j={...R,...w,fullURL:D,initURL:n},U=new AbortController,z=null!=j.timeout?F(j.timeout):null,K=B(S.signal,z,U.signal),N={...S,signal:K},{handleRequestCancelDedupeStrategy:V,handleRequestDeferDedupeStrategy:W,removeDedupeKeyFromCache:I}=await x({$RequestInfoCache:o,newFetchController:U,options:j,request:N});V();try{await T(j.onRequest({options:j,request:N})),N.headers=M({auth:j.auth,baseHeaders:r.headers,body:m,headers:N.headers});const e=await W(),t="defer"===j.dedupeStrategy||j.cloneResponse;if(!e.ok){const r=await $(t?e.clone():e,j.responseType,j.responseParser,j.responseErrorValidator);throw new i({defaultErrorMessage:j.defaultErrorMessage,errorData:r,response:e})}const o={data:await $(t?e.clone():e,j.responseType,j.responseParser,j.responseValidator),options:j,request:N,response:j.cloneResponse?e.clone():e};return await T(j.onSuccess(o),j.onResponse({...o,error:null})),await k({data:o.data,response:o.response,resultMode:j.resultMode})}catch(e){const{errorVariantDetails:r,getErrorResult:t}=a({cloneResponse:j.cloneResponse,defaultErrorMessage:j.defaultErrorMessage,error:e,resultMode:j.resultMode}),o={error:r.error,options:j,request:N},i={...o,response:r.response},{getDelay:c,shouldAttemptRetry:d}=H(j,i);if(!K.aborted&&await d()){await T(j.onRetry(i));const e=c();await C(e);const r={...u,"~retryCount":(j["~retryCount"]??0)+1};return await s(n,r)}const y=p(j.throwOnError)?j.throwOnError(i):j.throwOnError,f=()=>{if(y)throw r.error};if(l(e))return await T(j.onResponseError(i),j.onError(i),j.onResponse({...i,data:null})),f(),t();if(e instanceof DOMException&&"AbortError"===e.name){const{message:r,name:o}=e;return console.error(`${o}:`,r),f(),t()}if(e instanceof DOMException&&"TimeoutError"===e.name){const r=`Request timed out after ${j.timeout}ms`;return console.error(`${e.name}:`,r),f(),t({message:r})}return await T(j.onRequestError(o),j.onError(i)),f(),t()}finally{I()}};return s.create=z,s},K=(z({}),e=>{const[r,t]=O(e??{}),o=new Map,s=async e=>{const{initURL:n,...u}=e,[c,y]=q(u),f={};for(const e of Object.keys(A)){const r=v(t[e],y[e]);f[e]=r}const h={baseURL:"",bodySerializer:JSON.stringify,dedupeStrategy:"cancel",defaultErrorMessage:"Failed to fetch data from server!",mergedHooksExecutionMode:"parallel",mergedHooksExecutionOrder:"mainHooksAfterPlugins",responseType:"json",resultMode:"all",retryAttempts:0,retryDelay:1e3,retryMaxDelay:1e4,retryMethods:b,retryStatusCodes:E,retryStrategy:"linear",...t,...y,...f},m=c.body??r.body,g={body:d(m)?h.bodySerializer(m):m,method:"GET",...r,...c,headers:M({auth:h.auth,baseHeaders:r.headers,body:m,headers:c.headers}),signal:c.signal??r.signal},{resolvedHooks:w,resolvedOptions:R,resolvedRequestOptions:S,url:O}=await P({initURL:n,options:h,request:g}),D=`${R.baseURL}${L(O,R.params,R.query)}`,j={...R,...w,fullURL:D,initURL:n},U=new AbortController,z=null!=j.timeout?F(j.timeout):null,K=B(S.signal,z,U.signal),N={...S,signal:K},{handleRequestCancelDedupeStrategy:V,handleRequestDeferDedupeStrategy:W,removeDedupeKeyFromCache:I}=await x({$RequestInfoCache:o,newFetchController:U,options:j,request:N});V();try{await T(j.onRequest({options:j,request:N})),N.headers=M({auth:j.auth,baseHeaders:r.headers,body:m,headers:N.headers});const e=await W(),t="defer"===j.dedupeStrategy||j.cloneResponse;if(!e.ok){const r=await $(t?e.clone():e,j.responseType,j.responseParser,j.responseErrorValidator);throw new i({defaultErrorMessage:j.defaultErrorMessage,errorData:r,response:e})}const o={data:await $(t?e.clone():e,j.responseType,j.responseParser,j.responseValidator),options:j,request:N,response:j.cloneResponse?e.clone():e};return await T(j.onSuccess(o),j.onResponse({...o,error:null})),await k({data:o.data,response:o.response,resultMode:j.resultMode})}catch(r){const{errorVariantDetails:t,getErrorResult:o}=a({cloneResponse:j.cloneResponse,defaultErrorMessage:j.defaultErrorMessage,error:r,resultMode:j.resultMode}),n={error:t.error,options:j,request:N},i={...n,response:t.response},{getDelay:u,shouldAttemptRetry:c}=H(j,i);if(!K.aborted&&await c()){await T(j.onRetry(i));const r=u();await C(r);const t={...e,"~retryCount":(j["~retryCount"]??0)+1};return await s(t)}const d=p(j.throwOnError)?j.throwOnError(i):j.throwOnError,y=()=>{if(d)throw t.error};if(l(r))return await T(j.onResponseError(i),j.onError(i),j.onResponse({...i,data:null})),y(),o();if(r instanceof DOMException&&"AbortError"===r.name){const{message:e,name:t}=r;return console.error(`${t}:`,e),y(),o()}if(r instanceof DOMException&&"TimeoutError"===r.name){const e=`Request timed out after ${j.timeout}ms`;return console.error(`${r.name}:`,e),y(),o({message:e})}return await T(j.onRequestError(n),j.onError(i)),y(),o()}finally{I()}};return s.create=z,s}),N=K(),V=e=>e;//# sourceMappingURL=index.cjs.map