@zayne-labs/callapi 1.7.12 → 1.7.14
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.
- package/dist/esm/{chunk-SJZKYDA4.js → chunk-IXCM5X4X.js} +10 -90
- package/dist/esm/chunk-IXCM5X4X.js.map +1 -0
- package/dist/esm/{common-CUR8HxVd.d.ts → common-UwnX74fm.d.ts} +30 -28
- package/dist/esm/index.d.ts +2 -2
- package/dist/esm/index.js +102 -15
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/utils/index.d.ts +1 -1
- package/dist/esm/utils/index.js +1 -1
- package/package.json +3 -7
- package/dist/esm/chunk-SJZKYDA4.js.map +0 -1
@@ -13,7 +13,7 @@ var retryDefaults = defineEnum({
|
|
13
13
|
});
|
14
14
|
var commonDefaults = defineEnum({
|
15
15
|
bodySerializer: JSON.stringify,
|
16
|
-
defaultErrorMessage: "
|
16
|
+
defaultErrorMessage: "An unexpected error occurred during the HTTP request."
|
17
17
|
});
|
18
18
|
var responseDefaults = defineEnum({
|
19
19
|
responseParser: JSON.parse,
|
@@ -31,43 +31,7 @@ var requestOptionDefaults = defineEnum({
|
|
31
31
|
method: "GET"
|
32
32
|
});
|
33
33
|
|
34
|
-
// src/
|
35
|
-
var getResponseType = (response, parser) => ({
|
36
|
-
arrayBuffer: () => response.arrayBuffer(),
|
37
|
-
blob: () => response.blob(),
|
38
|
-
formData: () => response.formData(),
|
39
|
-
json: async () => {
|
40
|
-
const text = await response.text();
|
41
|
-
return parser(text);
|
42
|
-
},
|
43
|
-
stream: () => response.body,
|
44
|
-
text: () => response.text()
|
45
|
-
});
|
46
|
-
var resolveResponseData = (response, responseType, parser) => {
|
47
|
-
const selectedParser = parser ?? responseDefaults.responseParser;
|
48
|
-
const selectedResponseType = responseType ?? responseDefaults.responseType;
|
49
|
-
const RESPONSE_TYPE_LOOKUP = getResponseType(response, selectedParser);
|
50
|
-
if (!Object.hasOwn(RESPONSE_TYPE_LOOKUP, selectedResponseType)) {
|
51
|
-
throw new Error(`Invalid response type: ${responseType}`);
|
52
|
-
}
|
53
|
-
return RESPONSE_TYPE_LOOKUP[selectedResponseType]();
|
54
|
-
};
|
55
|
-
var resolveSuccessResult = (data, info) => {
|
56
|
-
const { response, resultMode } = info;
|
57
|
-
const details = {
|
58
|
-
data,
|
59
|
-
error: null,
|
60
|
-
response
|
61
|
-
};
|
62
|
-
const resultModeMap = {
|
63
|
-
all: details,
|
64
|
-
allWithException: details,
|
65
|
-
onlySuccess: details.data,
|
66
|
-
onlySuccessWithException: details.data
|
67
|
-
};
|
68
|
-
const successResult = resultModeMap[resultMode ?? "all"];
|
69
|
-
return successResult;
|
70
|
-
};
|
34
|
+
// src/error.ts
|
71
35
|
var HTTPError = class extends Error {
|
72
36
|
errorData;
|
73
37
|
isHTTPError = true;
|
@@ -75,7 +39,7 @@ var HTTPError = class extends Error {
|
|
75
39
|
response;
|
76
40
|
constructor(errorDetails, errorOptions) {
|
77
41
|
const { defaultErrorMessage, errorData, response } = errorDetails;
|
78
|
-
const selectedDefaultErrorMessage = defaultErrorMessage ?? commonDefaults.defaultErrorMessage;
|
42
|
+
const selectedDefaultErrorMessage = defaultErrorMessage ?? (response.statusText || commonDefaults.defaultErrorMessage);
|
79
43
|
const message = errorData?.message ?? selectedDefaultErrorMessage;
|
80
44
|
super(message, errorOptions);
|
81
45
|
this.errorData = errorData;
|
@@ -83,56 +47,10 @@ var HTTPError = class extends Error {
|
|
83
47
|
Error.captureStackTrace(this, this.constructor);
|
84
48
|
}
|
85
49
|
};
|
86
|
-
var resolveErrorResult = (error, info) => {
|
87
|
-
const { cloneResponse, defaultErrorMessage, message: customErrorMessage, resultMode } = info;
|
88
|
-
let details = {
|
89
|
-
data: null,
|
90
|
-
error: {
|
91
|
-
errorData: error,
|
92
|
-
message: customErrorMessage ?? error.message,
|
93
|
-
name: error.name
|
94
|
-
},
|
95
|
-
response: null
|
96
|
-
};
|
97
|
-
if (isHTTPErrorInstance(error)) {
|
98
|
-
const selectedDefaultErrorMessage = defaultErrorMessage ?? commonDefaults.defaultErrorMessage;
|
99
|
-
const { errorData, message = selectedDefaultErrorMessage, name, response } = error;
|
100
|
-
details = {
|
101
|
-
data: null,
|
102
|
-
error: {
|
103
|
-
errorData,
|
104
|
-
message,
|
105
|
-
name
|
106
|
-
},
|
107
|
-
response: cloneResponse ? response.clone() : response
|
108
|
-
};
|
109
|
-
}
|
110
|
-
const resultModeMap = {
|
111
|
-
all: details,
|
112
|
-
allWithException: details,
|
113
|
-
onlySuccess: details.data,
|
114
|
-
onlySuccessWithException: details.data
|
115
|
-
};
|
116
|
-
const errorResult = resultModeMap[resultMode ?? "all"];
|
117
|
-
return errorResult;
|
118
|
-
};
|
119
|
-
var getCustomizedErrorResult = (errorResult, customErrorInfo) => {
|
120
|
-
if (!errorResult) {
|
121
|
-
return null;
|
122
|
-
}
|
123
|
-
const { message = errorResult.error.message } = customErrorInfo;
|
124
|
-
return {
|
125
|
-
...errorResult,
|
126
|
-
error: {
|
127
|
-
...errorResult.error,
|
128
|
-
message
|
129
|
-
}
|
130
|
-
};
|
131
|
-
};
|
132
50
|
|
133
51
|
// src/utils/guards.ts
|
134
52
|
var isHTTPError = (error) => {
|
135
|
-
return
|
53
|
+
return isObject(error) && error.name === "HTTPError";
|
136
54
|
};
|
137
55
|
var isHTTPErrorInstance = (error) => {
|
138
56
|
if (error instanceof HTTPError) {
|
@@ -141,7 +59,9 @@ var isHTTPErrorInstance = (error) => {
|
|
141
59
|
return isPlainObject(error) && error.name === "HTTPError" && error.isHTTPError === true;
|
142
60
|
};
|
143
61
|
var isArray = (value) => Array.isArray(value);
|
144
|
-
var isObject = (value) =>
|
62
|
+
var isObject = (value) => {
|
63
|
+
return typeof value === "object" && value !== null;
|
64
|
+
};
|
145
65
|
var hasObjectPrototype = (value) => {
|
146
66
|
return Object.prototype.toString.call(value) === "[object Object]";
|
147
67
|
};
|
@@ -340,6 +260,6 @@ var createCombinedSignal = (...signals) => {
|
|
340
260
|
};
|
341
261
|
var createTimeoutSignal = (milliseconds) => AbortSignal.timeout(milliseconds);
|
342
262
|
|
343
|
-
export { HTTPError, commonDefaults, createCombinedSignal, createTimeoutSignal, dedupeDefaults,
|
344
|
-
//# sourceMappingURL=chunk-
|
345
|
-
//# sourceMappingURL=chunk-
|
263
|
+
export { HTTPError, commonDefaults, createCombinedSignal, createTimeoutSignal, dedupeDefaults, getFetchImpl, getHeaders, hookDefaults, isArray, isFunction, isHTTPError, isHTTPErrorInstance, isObject, isPlainObject, isReadableStream, isSerializable, isString, requestOptionDefaults, responseDefaults, retryDefaults, splitBaseConfig, splitConfig, toQueryString, waitUntil };
|
264
|
+
//# sourceMappingURL=chunk-IXCM5X4X.js.map
|
265
|
+
//# sourceMappingURL=chunk-IXCM5X4X.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"sources":["../../src/utils/type-helpers.ts","../../src/constants/default-options.ts","../../src/error.ts","../../src/utils/guards.ts","../../src/auth.ts","../../src/constants/common.ts","../../src/types/common.ts","../../src/utils/common.ts"],"names":[],"mappings":"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","file":"chunk-IXCM5X4X.js","sourcesContent":["// == 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<keyof any, 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 = unknown> = (...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 WriteableVariantUnion = \"deep\" | \"shallow\";\n\n/**\n * Makes all properties in an object type writeable (removes readonly modifiers).\n * Supports both shallow and deep modes, and handles special cases like arrays, tuples, and unions.\n * @template TObject - The object type to make writeable\n * @template TVariant - The level of writeable transformation (\"shallow\" | \"deep\")\n */\n\ntype ArrayOrObject = Record<number | string | symbol, unknown> | unknown[];\n\nexport type Writeable<\n\tTObject,\n\tTVariant extends WriteableVariantUnion = \"shallow\",\n> = TObject extends readonly [...infer TTupleItems]\n\t? TVariant extends \"deep\"\n\t\t? [\n\t\t\t\t...{\n\t\t\t\t\t[Key in keyof TTupleItems]: TTupleItems[Key] extends ArrayOrObject\n\t\t\t\t\t\t? Writeable<TTupleItems[Key], TVariant>\n\t\t\t\t\t\t: TTupleItems[Key];\n\t\t\t\t},\n\t\t\t]\n\t\t: [...TTupleItems]\n\t: TObject extends ReadonlyArray<infer TArrayItem>\n\t\t? TVariant extends \"deep\"\n\t\t\t? Array<TArrayItem extends ArrayOrObject ? Writeable<TArrayItem, TVariant> : TArrayItem>\n\t\t\t: TArrayItem[]\n\t\t: TObject extends ArrayOrObject\n\t\t\t? {\n\t\t\t\t\t-readonly [Key in keyof TObject]: TVariant extends \"shallow\"\n\t\t\t\t\t\t? TObject[Key]\n\t\t\t\t\t\t: TVariant extends \"deep\"\n\t\t\t\t\t\t\t? TObject[Key] extends ArrayOrObject\n\t\t\t\t\t\t\t\t? Writeable<TObject[Key], TVariant>\n\t\t\t\t\t\t\t\t: TObject[Key]\n\t\t\t\t\t\t\t: never;\n\t\t\t\t}\n\t\t\t: TObject;\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","import type { BaseCallApiExtraOptions } from \"../types\";\nimport { defineEnum } from \"../utils/type-helpers\";\n\nexport const retryDefaults = defineEnum({\n\tattempts: 0,\n\tcondition: () => true,\n\tdelay: 1000,\n\tmaxDelay: 10000,\n\tmethods: [\"GET\", \"POST\"] satisfies BaseCallApiExtraOptions[\"retryMethods\"],\n\tstatusCodes: [] satisfies BaseCallApiExtraOptions[\"retryStatusCodes\"],\n\tstrategy: \"linear\",\n});\n\nexport const defaultRetryStatusCodesLookup = 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 commonDefaults = defineEnum({\n\tbodySerializer: JSON.stringify,\n\tdefaultErrorMessage: \"An unexpected error occurred during the HTTP request.\",\n});\n\nexport const responseDefaults = defineEnum({\n\tresponseParser: JSON.parse,\n\tresponseType: \"json\",\n\tresultMode: \"all\",\n});\n\nexport const hookDefaults = defineEnum({\n\tmergedHooksExecutionMode: \"parallel\",\n\tmergedHooksExecutionOrder: \"mainHooksAfterPlugins\",\n});\n\nexport const dedupeDefaults = defineEnum({\n\tdedupeStrategy: \"cancel\",\n});\n\nexport const requestOptionDefaults = defineEnum({\n\tmethod: \"GET\",\n});\n","import { commonDefaults } from \"./constants/default-options\";\nimport type { CallApiExtraOptions } from \"./types\";\n\ntype ErrorDetails<TErrorResponse> = {\n\tdefaultErrorMessage: CallApiExtraOptions[\"defaultErrorMessage\"];\n\terrorData: TErrorResponse;\n\tresponse: Response;\n};\n\n// export const httpErrorSymbol = Symbol(\"HTTPError\");\n\nexport class HTTPError<TErrorResponse = Record<string, unknown>> extends Error {\n\terrorData: ErrorDetails<TErrorResponse>[\"errorData\"];\n\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\tconst selectedDefaultErrorMessage =\n\t\t\tdefaultErrorMessage ?? (response.statusText || commonDefaults.defaultErrorMessage);\n\n\t\tconst message =\n\t\t\t(errorData as { message?: string } | undefined)?.message ?? selectedDefaultErrorMessage;\n\n\t\tsuper(message, errorOptions);\n\n\t\tthis.errorData = errorData;\n\t\tthis.response = response;\n\t\tError.captureStackTrace(this, this.constructor);\n\t}\n}\n","import { HTTPError } from \"../error\";\nimport type { CallApiResultErrorVariant, PossibleHTTPError } from \"../result\";\nimport type { AnyFunction } from \"./type-helpers\";\n\nexport const isHTTPError = <TErrorData>(\n\terror: CallApiResultErrorVariant<TErrorData>[\"error\"] | null\n): error is PossibleHTTPError<TErrorData> => {\n\treturn isObject(error) && error.name === \"HTTPError\";\n};\n\nexport const isHTTPErrorInstance = <TErrorResponse>(\n\terror: unknown\n): error is HTTPError<TErrorResponse> => {\n\tif (error instanceof HTTPError) {\n\t\treturn true;\n\t}\n\n\treturn isPlainObject(error) && error.name === \"HTTPError\" && error.isHTTPError === true;\n};\n\nexport const isArray = <TArrayItem>(value: unknown): value is TArrayItem[] => Array.isArray(value);\n\nexport const isObject = (value: unknown) => {\n\treturn typeof value === \"object\" && value !== null;\n};\n\nconst hasObjectPrototype = (value: unknown) => {\n\treturn Object.prototype.toString.call(value) === \"[object Object]\";\n};\n\n/**\n * @description Copied from TanStack Query's isPlainObject\n * @see https://github.com/TanStack/query/blob/main/packages/query-core/src/utils.ts#L321\n */\nexport const isPlainObject = <TPlainObject extends Record<string, unknown>>(\n\tvalue: unknown\n): value is TPlainObject => {\n\tif (!hasObjectPrototype(value)) {\n\t\treturn false;\n\t}\n\n\t// If has no constructor\n\tconst constructor = (value as object | undefined)?.constructor;\n\tif (constructor === undefined) {\n\t\treturn true;\n\t}\n\n\t// If has modified prototype\n\tconst prototype = constructor.prototype as object;\n\tif (!hasObjectPrototype(prototype)) {\n\t\treturn false;\n\t}\n\n\t// If constructor does not have an Object-specific method\n\tif (!Object.hasOwn(prototype, \"isPrototypeOf\")) {\n\t\treturn false;\n\t}\n\n\t// Handles Objects created by Object.create(<arbitrary prototype>)\n\tif (Object.getPrototypeOf(value) !== Object.prototype) {\n\t\treturn false;\n\t}\n\n\t// It's probably a plain object at this point\n\treturn true;\n};\n\nexport const isJsonString = (value: unknown): value is string => {\n\tif (!isString(value)) {\n\t\treturn false;\n\t}\n\n\ttry {\n\t\tJSON.parse(value);\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport const isSerializable = (value: unknown) => {\n\treturn (\n\t\tisPlainObject(value)\n\t\t|| isArray(value)\n\t\t|| typeof (value as { toJSON: unknown } | undefined)?.toJSON === \"function\"\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\nexport const isReadableStream = (value: unknown): value is ReadableStream<unknown> => {\n\treturn value instanceof ReadableStream;\n};\n\n// https://github.com/unjs/ofetch/blob/main/src/utils.ts\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(value?.constructor && value.constructor.name === \"Object\")\n\t\t// eslint-disable-next-line ts-eslint/prefer-nullish-coalescing -- Nullish coalescing makes no sense in this boolean context\n\t\t|| typeof (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/common\";\nimport { isFunction, isString } from \"./utils/guards\";\nimport type { Awaitable } from \"./utils/type-helpers\";\n\ntype ValueOrFunctionResult<TValue> = TValue | (() => TValue);\n\ntype ValidAuthValue = ValueOrFunctionResult<Awaitable<string | null | undefined>>;\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?: ValidAuthValue;\n\t\t\ttoken?: never;\n\t }\n\t| {\n\t\t\ttype?: \"Token\";\n\t\t\tbearer?: never;\n\t\t\ttoken?: ValidAuthValue;\n\t };\n\n/**\n * Basic auth\n */\nexport type BasicAuth = {\n\ttype: \"Basic\";\n\tusername: ValidAuthValue;\n\tpassword: ValidAuthValue;\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: ValidAuthValue;\n\tvalue: ValidAuthValue;\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: ValidAuthValue) => {\n\treturn isFunction(value) ? value() : value;\n};\n\ntype AuthorizationHeader = {\n\tAuthorization: string;\n};\n\nexport const getAuthHeader = async (\n\tauth: ExtraOptions[\"auth\"]\n): Promise<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 = await getValue(auth.username);\n\t\t\tconst password = await 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 = await getValue(auth.value);\n\n\t\t\tif (value === undefined) return;\n\n\t\t\tconst prefix = await 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 = await getValue(auth.bearer);\n\t\t\tconst token = await 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","import type { ModifiedRequestInit } from \"../types\";\nimport { defineEnum } from \"../utils/type-helpers\";\n\nexport const fetchSpecificKeys = defineEnum([\n\t\"body\",\n\t\"integrity\",\n\t\"duplex\",\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 ModifiedRequestInit> as Array<keyof ModifiedRequestInit>);\n","import type { Auth } from \"../auth\";\nimport type { fetchSpecificKeys } from \"../constants/common\";\nimport type { ErrorContext, Hooks, HooksOrHooksArray } from \"../hooks\";\nimport type { CallApiPlugin, InferPluginOptions, Plugins } from \"../plugins\";\nimport type { GetCallApiResult, ResponseTypeUnion, ResultModeUnion } from \"../result\";\nimport type { RetryOptions } from \"../retry\";\nimport type { InitURL, UrlOptions } from \"../url\";\nimport { type Awaitable, type Prettify, type UnmaskType, defineEnum } from \"../utils/type-helpers\";\nimport type { CallApiSchemas, CallApiValidators, InferSchemaResult } from \"../validation\";\nimport type {\n\tBodyOption,\n\tHeadersOption,\n\tMetaOption,\n\tMethodOption,\n\tResultModeOption,\n} from \"./conditional-types\";\nimport type {\n\tDefaultDataType,\n\tDefaultMoreOptions,\n\tDefaultPluginArray,\n\tDefaultThrowOnError,\n} from \"./default-types\";\n\ntype FetchSpecificKeysUnion = Exclude<(typeof fetchSpecificKeys)[number], \"body\" | \"headers\" | \"method\">;\n\nexport type ModifiedRequestInit = RequestInit & { duplex?: \"half\" };\n\nexport type CallApiRequestOptions<TSchemas extends CallApiSchemas = DefaultMoreOptions> = Prettify<\n\tBodyOption<TSchemas>\n\t\t& HeadersOption<TSchemas>\n\t\t& MethodOption<TSchemas>\n\t\t& Pick<ModifiedRequestInit, FetchSpecificKeysUnion>\n>;\n\nexport type CallApiRequestOptionsForHooks<TSchemas extends CallApiSchemas = DefaultMoreOptions> = Omit<\n\tCallApiRequestOptions<TSchemas>,\n\t\"headers\"\n> & {\n\theaders?: Record<string, string | undefined>;\n};\n\ntype FetchImpl = UnmaskType<(input: string | Request | URL, init?: RequestInit) => Promise<Response>>;\n\nexport type ExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = {\n\t/**\n\t * Authorization header value.\n\t */\n\tauth?: string | Auth | null;\n\t/**\n\t * Base URL to be prepended to all request URLs\n\t */\n\tbaseURL?: string;\n\n\t/**\n\t * Custom function to serialize the body object into a string.\n\t */\n\tbodySerializer?: (bodyData: Record<string, unknown>) => string;\n\n\t/**\n\t * Whether or not to clone the response, so response.json() and the like can be read again else where.\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/Response/clone\n\t * @default false\n\t */\n\tcloneResponse?: boolean;\n\n\t/**\n\t * Custom fetch implementation\n\t */\n\tcustomFetchImpl?: FetchImpl;\n\n\t/**\n\t * Custom request key to be used to identify a request in the fetch deduplication strategy.\n\t * @default the full request url + string formed from the request options\n\t */\n\tdedupeKey?: string;\n\n\t/**\n\t * Defines the deduplication strategy for the request, can be set to \"none\" | \"defer\" | \"cancel\".\n\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 * - 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 * - If set to \"none\", deduplication is disabled.\n\t * @default \"cancel\"\n\t */\n\tdedupeStrategy?: \"cancel\" | \"defer\" | \"none\";\n\n\t/**\n\t * Default error message to use if none is provided from a response.\n\t * @default \"Failed to fetch data from server!\"\n\t */\n\tdefaultErrorMessage?: string;\n\n\t/**\n\t * If true, forces the calculation of the total byte size from the request or response body, in case the content-length header is not present or is incorrect.\n\t * @default false\n\t */\n\tforceCalculateStreamSize?: boolean | { request?: boolean; response?: boolean };\n\n\t/**\n\t * Resolved request URL\n\t */\n\treadonly fullURL?: string;\n\n\t/**\n\t * Defines the mode in which the composed hooks are executed\".\n\t * - If set to \"parallel\", main and plugin hooks will be executed in parallel.\n\t * - If set to \"sequential\", the plugin hooks will be executed first, followed by the main hook.\n\t * @default \"parallel\"\n\t */\n\tmergedHooksExecutionMode?: \"parallel\" | \"sequential\";\n\n\t/**\n\t * - Controls what order in which the composed hooks execute\n\t * @default \"mainHooksAfterPlugins\"\n\t */\n\tmergedHooksExecutionOrder?: \"mainHooksAfterPlugins\" | \"mainHooksBeforePlugins\";\n\n\t/**\n\t * An array of CallApi plugins. It allows you to extend the behavior of the library.\n\t */\n\tplugins?: Plugins<TPluginArray>;\n\n\t/**\n\t * Custom function to parse the response string\n\t */\n\tresponseParser?: (responseString: string) => Awaitable<Record<string, unknown>>;\n\n\t/**\n\t * Expected response type, affects how response is parsed\n\t * @default \"json\"\n\t */\n\tresponseType?: TResponseType;\n\n\t/**\n\t * Mode of the result, can influence how results are handled or returned.\n\t * Can be set to \"all\" | \"onlySuccess\" | \"onlyError\" | \"onlyResponse\".\n\t * @default \"all\"\n\t */\n\tresultMode?: TResultMode;\n\n\t/**\n\t * Type-safe schemas for the response validation.\n\t */\n\tschemas?: TSchemas;\n\n\t/**\n\t * If true or the function returns true, throws errors instead of returning them\n\t * The function is passed the error object and can be used to conditionally throw the error\n\t * @default false\n\t */\n\tthrowOnError?: TThrowOnError | ((context: ErrorContext<TErrorData>) => TThrowOnError);\n\n\t/**\n\t * Request timeout in milliseconds\n\t */\n\ttimeout?: number;\n\n\t/**\n\t * Custom validation functions for response validation\n\t */\n\tvalidators?: CallApiValidators<TData, TErrorData>;\n\t/* eslint-disable perfectionist/sort-intersection-types -- Allow these to be last for the sake of docs */\n} & HooksOrHooksArray<TData, TErrorData, Partial<InferPluginOptions<TPluginArray>>>\n\t& Partial<InferPluginOptions<TPluginArray>>\n\t& MetaOption<TSchemas>\n\t& RetryOptions<TErrorData>\n\t& ResultModeOption<TErrorData, TResultMode>\n\t& UrlOptions<TSchemas>;\n/* eslint-enable perfectionist/sort-intersection-types -- Allow these to be last for the sake of docs */\n\nexport type CallApiExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = ExtraOptions<TData, TErrorData, TResultMode, TThrowOnError, TResponseType, TPluginArray, TSchemas> & {\n\tplugins?:\n\t\t| Plugins<TPluginArray>\n\t\t| ((context: { basePlugins: Plugins<TPluginArray> }) => Plugins<TPluginArray>);\n\n\tschemas?: TSchemas | ((context: { baseSchemas: TSchemas | undefined }) => TSchemas);\n\n\tvalidators?:\n\t\t| CallApiValidators<TData, TErrorData>\n\t\t| ((context: {\n\t\t\t\tbaseValidators: CallApiValidators<TData, TErrorData> | undefined;\n\t\t }) => CallApiValidators<TData, TErrorData>);\n};\n\nexport const optionsEnumToOmitFromBase = defineEnum([\"dedupeKey\"] satisfies Array<\n\tkeyof CallApiExtraOptions\n>);\n\nexport type BaseCallApiExtraOptions<\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBaseThrowOnError extends boolean = DefaultThrowOnError,\n\tTBaseResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTBasePluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTBaseSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = Omit<\n\tPartial<\n\t\tCallApiExtraOptions<\n\t\t\tTBaseData,\n\t\t\tTBaseErrorData,\n\t\t\tTBaseResultMode,\n\t\t\tTBaseThrowOnError,\n\t\t\tTBaseResponseType,\n\t\t\tTBasePluginArray,\n\t\t\tTBaseSchemas\n\t\t>\n\t>,\n\t(typeof optionsEnumToOmitFromBase)[number]\n> & {\n\t/**\n\t * Specifies which configuration parts should skip automatic merging between base and main configs.\n\t * Use this when you need manual control over how configs are combined.\n\t *\n\t * @values\n\t * - \"all\" - Disables automatic merging for both request and options\n\t * - \"options\" - Disables automatic merging of options only\n\t * - \"request\" - Disables automatic merging of request only\n\t *\n\t * @example\n\t * ```ts\n\t * const client = createFetchClient((ctx) => ({\n\t * skipAutoMergeFor: \"options\",\n\t *\n\t * // Now you can manually merge options in your config function\n\t * ...ctx.options,\n\t * }));\n\t * ```\n\t */\n\tskipAutoMergeFor?: \"all\" | \"options\" | \"request\";\n};\n\ntype CombinedExtraOptionsWithoutHooks = Omit<BaseCallApiExtraOptions & CallApiExtraOptions, keyof Hooks>;\n\n// eslint-disable-next-line ts-eslint/consistent-type-definitions -- Allow this to be an interface\nexport interface CombinedCallApiExtraOptions extends CombinedExtraOptionsWithoutHooks, Hooks {}\n\nexport type BaseCallApiConfig<\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBaseThrowOnError extends boolean = DefaultThrowOnError,\n\tTBaseResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTBasePluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTBaseSchemas extends CallApiSchemas = DefaultMoreOptions,\n> =\n\t| (CallApiRequestOptions<TBaseSchemas> // eslint-disable-next-line perfectionist/sort-intersection-types -- Allow\n\t\t\t& BaseCallApiExtraOptions<\n\t\t\t\tTBaseData,\n\t\t\t\tTBaseErrorData,\n\t\t\t\tTBaseResultMode,\n\t\t\t\tTBaseThrowOnError,\n\t\t\t\tTBaseResponseType,\n\t\t\t\tTBasePluginArray,\n\t\t\t\tTBaseSchemas\n\t\t\t>)\n\t| ((context: {\n\t\t\tinitURL: string;\n\t\t\toptions: CallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptions;\n\t }) => CallApiRequestOptions<TBaseSchemas> // eslint-disable-next-line perfectionist/sort-intersection-types -- Allow\n\t\t\t& BaseCallApiExtraOptions<\n\t\t\t\tTBaseData,\n\t\t\t\tTBaseErrorData,\n\t\t\t\tTBaseResultMode,\n\t\t\t\tTBaseThrowOnError,\n\t\t\t\tTBaseResponseType,\n\t\t\t\tTBasePluginArray,\n\t\t\t\tTBaseSchemas\n\t\t\t>);\n\nexport type CallApiConfig<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = CallApiRequestOptions<TSchemas> // eslint-disable-next-line perfectionist/sort-intersection-types -- Allow these to be last for the sake of docs\n\t& CallApiExtraOptions<\n\t\tTData,\n\t\tTErrorData,\n\t\tTResultMode,\n\t\tTThrowOnError,\n\t\tTResponseType,\n\t\tTPluginArray,\n\t\tTSchemas\n\t>;\n\nexport type CallApiParameters<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = [\n\tinitURL: InferSchemaResult<TSchemas[\"initURL\"], InitURL>,\n\tconfig?: CallApiConfig<\n\t\tTData,\n\t\tTErrorData,\n\t\tTResultMode,\n\t\tTThrowOnError,\n\t\tTResponseType,\n\t\tTPluginArray,\n\t\tTSchemas\n\t>,\n];\n\nexport type CallApiResult<\n\tTData,\n\tTErrorData,\n\tTResultMode extends ResultModeUnion,\n\tTThrowOnError extends boolean,\n\tTResponseType extends ResponseTypeUnion,\n> = Promise<GetCallApiResult<TData, TErrorData, TResultMode, TThrowOnError, TResponseType>>;\n","import { getAuthHeader } from \"../auth\";\nimport { fetchSpecificKeys } from \"../constants/common\";\nimport {\n\ttype BaseCallApiExtraOptions,\n\ttype CallApiExtraOptions,\n\ttype CallApiRequestOptions,\n\toptionsEnumToOmitFromBase,\n} from \"../types/common\";\nimport { isFunction, isJsonString, isPlainObject, isQueryString, isSerializable } from \"./guards\";\n\nexport const omitKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TOmitArray extends Array<keyof TObject>,\n>(\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\nexport const pickKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TPickArray extends Array<keyof TObject>,\n>(\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\ntype ToQueryStringFn = {\n\t(params: CallApiExtraOptions[\"query\"]): string | null;\n\t(params: Required<CallApiExtraOptions>[\"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\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 MergeAndResolveHeadersOptions = {\n\tauth: CallApiExtraOptions[\"auth\"];\n\tbaseHeaders?: CallApiRequestOptions[\"headers\"];\n\tbody: CallApiRequestOptions[\"body\"];\n\theaders: CallApiRequestOptions[\"headers\"];\n};\n\nexport const getHeaders = async (options: MergeAndResolveHeadersOptions) => {\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...(await 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 (isSerializable(body) || isJsonString(body)) {\n\t\theadersObject[\"Content-Type\"] = \"application/json\";\n\t\theadersObject.Accept = \"application/json\";\n\t}\n\n\treturn headersObject;\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\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\nexport const createCombinedSignal = (...signals: Array<AbortSignal | null | undefined>) => {\n\tconst cleanedSignals = signals.filter(Boolean);\n\n\tconst combinedSignal = AbortSignal.any(cleanedSignals);\n\n\treturn combinedSignal;\n};\n\nexport const createTimeoutSignal = (milliseconds: number) => AbortSignal.timeout(milliseconds);\n"]}
|
@@ -1,7 +1,7 @@
|
|
1
1
|
type AnyString = string & {
|
2
2
|
z_placeholder?: never;
|
3
3
|
};
|
4
|
-
type AnyFunction<TResult = unknown> = (...args: any) => TResult;
|
4
|
+
type AnyFunction<TResult = unknown> = (...args: any[]) => TResult;
|
5
5
|
type Prettify<TObject> = NonNullable<unknown> & {
|
6
6
|
[Key in keyof TObject]: TObject[Key];
|
7
7
|
};
|
@@ -65,6 +65,19 @@ type Auth = BearerOrTokenAuth | BasicAuth | CustomAuth;
|
|
65
65
|
|
66
66
|
declare const fetchSpecificKeys: (keyof RequestInit | "duplex")[];
|
67
67
|
|
68
|
+
type ErrorDetails<TErrorResponse> = {
|
69
|
+
defaultErrorMessage: CallApiExtraOptions["defaultErrorMessage"];
|
70
|
+
errorData: TErrorResponse;
|
71
|
+
response: Response;
|
72
|
+
};
|
73
|
+
declare class HTTPError<TErrorResponse = Record<string, unknown>> extends Error {
|
74
|
+
errorData: ErrorDetails<TErrorResponse>["errorData"];
|
75
|
+
isHTTPError: boolean;
|
76
|
+
name: "HTTPError";
|
77
|
+
response: ErrorDetails<TErrorResponse>["response"];
|
78
|
+
constructor(errorDetails: ErrorDetails<TErrorResponse>, errorOptions?: ErrorOptions);
|
79
|
+
}
|
80
|
+
|
68
81
|
/**
|
69
82
|
* The Standard Schema interface.
|
70
83
|
* @see https://github.com/standard-schema/standard-schema
|
@@ -213,7 +226,7 @@ interface CallApiValidators<TData = unknown, TErrorData = unknown> {
|
|
213
226
|
*/
|
214
227
|
errorData?: (value: unknown) => TErrorData;
|
215
228
|
}
|
216
|
-
type InferSchemaResult<TSchema, TData
|
229
|
+
type InferSchemaResult<TSchema, TData = NonNullable<unknown>> = TSchema extends StandardSchemaV1 ? StandardSchemaV1.InferOutput<TSchema> : TData;
|
217
230
|
|
218
231
|
type Params = UnmaskType<Record<string, boolean | number | string> | Array<boolean | number | string>>;
|
219
232
|
type Query = UnmaskType<Record<string, boolean | number | string>>;
|
@@ -234,8 +247,7 @@ interface UrlOptions<TSchemas extends CallApiSchemas> {
|
|
234
247
|
}
|
235
248
|
|
236
249
|
type UnionToIntersection<TUnion> = (TUnion extends unknown ? (param: TUnion) => void : never) extends (param: infer TParam) => void ? TParam : never;
|
237
|
-
type
|
238
|
-
type InferPluginOptions<TPluginArray extends CallApiPlugin[]> = UnionToIntersection<InferSchema<ReturnType<NonNullable<TPluginArray[number]["createExtraOptions"]>>>>;
|
250
|
+
type InferPluginOptions<TPluginArray extends CallApiPlugin[]> = UnionToIntersection<TPluginArray extends Array<infer TPlugin> ? TPlugin extends CallApiPlugin ? TPlugin["createExtraOptions"] extends AnyFunction<infer TResult> ? InferSchemaResult<TResult, TResult> : NonNullable<unknown> : NonNullable<unknown> : NonNullable<unknown>>;
|
239
251
|
type PluginInitContext<TMoreOptions = DefaultMoreOptions> = Prettify<SharedHookContext<TMoreOptions> & {
|
240
252
|
initURL: InitURL | undefined;
|
241
253
|
}>;
|
@@ -302,6 +314,18 @@ type CallApiResultSuccessVariant<TData> = {
|
|
302
314
|
error: null;
|
303
315
|
response: Response;
|
304
316
|
};
|
317
|
+
type PossibleJavaScriptError = UnmaskType<{
|
318
|
+
errorData: DOMException | Error | SyntaxError | TypeError;
|
319
|
+
message: string;
|
320
|
+
name: "AbortError" | "Error" | "SyntaxError" | "TimeoutError" | "TypeError" | (`${string}Error` & {});
|
321
|
+
originalError: DOMException | Error | SyntaxError | TypeError;
|
322
|
+
}>;
|
323
|
+
type PossibleHTTPError<TErrorData> = Prettify<UnmaskType<{
|
324
|
+
errorData: TErrorData;
|
325
|
+
message: string;
|
326
|
+
name: "HTTPError";
|
327
|
+
originalError: HTTPError;
|
328
|
+
}>>;
|
305
329
|
type CallApiResultErrorVariant<TErrorData> = {
|
306
330
|
data: null;
|
307
331
|
error: PossibleHTTPError<TErrorData>;
|
@@ -319,28 +343,6 @@ type ResultModeMap<TData = DefaultDataType, TErrorData = DefaultDataType, TRespo
|
|
319
343
|
}>;
|
320
344
|
type ResultModeUnion = keyof ResultModeMap | null;
|
321
345
|
type GetCallApiResult<TData, TErrorData, TResultMode extends ResultModeUnion, TThrowOnError extends boolean, TResponseType extends ResponseTypeUnion> = TErrorData extends false | undefined ? ResultModeMap<TData, TErrorData, TResponseType>["onlySuccessWithException"] : null extends TResultMode ? TThrowOnError extends true ? ResultModeMap<TData, TErrorData, TResponseType>["allWithException"] : ResultModeMap<TData, TErrorData, TResponseType>["all"] : TResultMode extends NonNullable<ResultModeUnion> ? ResultModeMap<TData, TErrorData, TResponseType>[TResultMode] : never;
|
322
|
-
type ErrorDetails<TErrorResponse> = {
|
323
|
-
defaultErrorMessage: CallApiExtraOptions["defaultErrorMessage"];
|
324
|
-
errorData: TErrorResponse;
|
325
|
-
response: Response;
|
326
|
-
};
|
327
|
-
declare class HTTPError<TErrorResponse = Record<string, unknown>> extends Error {
|
328
|
-
errorData: ErrorDetails<TErrorResponse>["errorData"];
|
329
|
-
isHTTPError: boolean;
|
330
|
-
name: "HTTPError";
|
331
|
-
response: ErrorDetails<TErrorResponse>["response"];
|
332
|
-
constructor(errorDetails: ErrorDetails<TErrorResponse>, errorOptions?: ErrorOptions);
|
333
|
-
}
|
334
|
-
type PossibleJavaScriptError = UnmaskType<{
|
335
|
-
errorData: DOMException | Error | SyntaxError | TypeError;
|
336
|
-
message: string;
|
337
|
-
name: "AbortError" | "Error" | "SyntaxError" | "TimeoutError" | "TypeError" | (`${string}Error` & {});
|
338
|
-
}>;
|
339
|
-
type PossibleHTTPError<TErrorData> = Prettify<UnmaskType<{
|
340
|
-
errorData: TErrorData;
|
341
|
-
message: string;
|
342
|
-
name: "HTTPError";
|
343
|
-
}>>;
|
344
346
|
|
345
347
|
type StreamProgressEvent = {
|
346
348
|
/**
|
@@ -526,7 +528,7 @@ interface RetryOptions<TErrorData> {
|
|
526
528
|
/**
|
527
529
|
* @description Makes a type required if TSchema type is undefined or if the output type of TSchema contains undefined, otherwise keeps it as is
|
528
530
|
*/
|
529
|
-
type MakeSchemaOptionRequired<TSchema extends StandardSchemaV1 | undefined, TObject> = undefined extends TSchema ? TObject : undefined extends InferSchemaResult<TSchema
|
531
|
+
type MakeSchemaOptionRequired<TSchema extends StandardSchemaV1 | undefined, TObject> = undefined extends TSchema ? TObject : undefined extends InferSchemaResult<TSchema> ? TObject : Required<TObject>;
|
530
532
|
type JsonPrimitive = boolean | number | string | null | undefined;
|
531
533
|
type SerializableObject = Record<keyof object, unknown>;
|
532
534
|
type SerializableArray = Array<JsonPrimitive | SerializableArray | SerializableObject> | ReadonlyArray<JsonPrimitive | SerializableArray | SerializableObject>;
|
@@ -616,7 +618,7 @@ type ExtraOptions<TData = DefaultDataType, TErrorData = DefaultDataType, TResult
|
|
616
618
|
*/
|
617
619
|
bodySerializer?: (bodyData: Record<string, unknown>) => string;
|
618
620
|
/**
|
619
|
-
* Whether or not to clone the response, so response.json() and the like
|
621
|
+
* Whether or not to clone the response, so response.json() and the like can be read again else where.
|
620
622
|
* @see https://developer.mozilla.org/en-US/docs/Web/API/Response/clone
|
621
623
|
* @default false
|
622
624
|
*/
|
package/dist/esm/index.d.ts
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
import { R as ResultModeUnion, a as ResponseTypeUnion, C as CallApiPlugin, D as DefaultPluginArray, b as CallApiSchemas, I as InferSchemaResult, c as CallApiConfig, d as CallApiResult, e as DefaultDataType, f as DefaultThrowOnError, g as DefaultMoreOptions, B as BaseCallApiConfig, h as CallApiParameters } from './common-
|
2
|
-
export { z as BaseCallApiExtraOptions, A as CallApiExtraOptions, F as CallApiRequestOptions, G as CallApiRequestOptionsForHooks, o as CallApiResultErrorVariant, p as CallApiResultSuccessVariant, J as CombinedCallApiExtraOptions, E as ErrorContext, H as HTTPError, q as Hooks, r as HooksOrHooksArray, j as PluginHooks, k as PluginHooksWithMoreOptions, P as PluginInitContext, m as PossibleHTTPError, n as PossibleJavaScriptError, K as Register, s as RequestContext, t as RequestErrorContext, u as RequestStreamContext, v as ResponseContext, w as ResponseErrorContext, x as ResponseStreamContext, l as RetryOptions, S as SharedHookContext, y as SuccessContext, i as definePlugin } from './common-
|
1
|
+
import { R as ResultModeUnion, a as ResponseTypeUnion, C as CallApiPlugin, D as DefaultPluginArray, b as CallApiSchemas, I as InferSchemaResult, c as CallApiConfig, d as CallApiResult, e as DefaultDataType, f as DefaultThrowOnError, g as DefaultMoreOptions, B as BaseCallApiConfig, h as CallApiParameters } from './common-UwnX74fm.js';
|
2
|
+
export { z as BaseCallApiExtraOptions, A as CallApiExtraOptions, F as CallApiRequestOptions, G as CallApiRequestOptionsForHooks, o as CallApiResultErrorVariant, p as CallApiResultSuccessVariant, J as CombinedCallApiExtraOptions, E as ErrorContext, H as HTTPError, q as Hooks, r as HooksOrHooksArray, j as PluginHooks, k as PluginHooksWithMoreOptions, P as PluginInitContext, m as PossibleHTTPError, n as PossibleJavaScriptError, K as Register, s as RequestContext, t as RequestErrorContext, u as RequestStreamContext, v as ResponseContext, w as ResponseErrorContext, x as ResponseStreamContext, l as RetryOptions, S as SharedHookContext, y as SuccessContext, i as definePlugin } from './common-UwnX74fm.js';
|
3
3
|
|
4
4
|
declare const createFetchClient: <TBaseData = DefaultDataType, TBaseErrorData = DefaultDataType, TBaseResultMode extends ResultModeUnion = ResultModeUnion, TBaseThrowOnError extends boolean = DefaultThrowOnError, TBaseResponseType extends ResponseTypeUnion = ResponseTypeUnion, TBasePluginArray extends CallApiPlugin[] = DefaultPluginArray, TBaseSchemas extends CallApiSchemas = DefaultMoreOptions>(initBaseConfig?: BaseCallApiConfig<TBaseData, TBaseErrorData, TBaseResultMode, TBaseThrowOnError, TBaseResponseType, TBasePluginArray, TBaseSchemas>) => <TData = InferSchemaResult<TBaseSchemas["data"], TBaseData>, TErrorData = InferSchemaResult<TBaseSchemas["errorData"], TBaseErrorData>, TResultMode extends ResultModeUnion = TBaseResultMode, TThrowOnError extends boolean = TBaseThrowOnError, TResponseType extends ResponseTypeUnion = TBaseResponseType, TPluginArray extends CallApiPlugin[] = TBasePluginArray, TSchemas extends CallApiSchemas = TBaseSchemas>(initURL: InferSchemaResult<TSchemas["initURL"], string | URL>, config?: CallApiConfig<TData, TErrorData, TResultMode, TThrowOnError, TResponseType, TPluginArray, TSchemas> | undefined) => CallApiResult<InferSchemaResult<TSchemas["data"], TData>, InferSchemaResult<TSchemas["errorData"], TErrorData>, TResultMode, TThrowOnError, TResponseType>;
|
5
5
|
declare const callApi: <TData = unknown, TErrorData = unknown, TResultMode extends ResultModeUnion = ResultModeUnion, TThrowOnError extends boolean = boolean, TResponseType extends ResponseTypeUnion = ResponseTypeUnion, TPluginArray extends CallApiPlugin[] = DefaultPluginArray, TSchemas extends CallApiSchemas = {}>(initURL: InferSchemaResult<TSchemas["initURL"], string | URL>, config?: CallApiConfig<TData, TErrorData, TResultMode, TThrowOnError, TResponseType, TPluginArray, TSchemas> | undefined) => CallApiResult<InferSchemaResult<TSchemas["data"], TData>, InferSchemaResult<TSchemas["errorData"], TErrorData>, TResultMode, TThrowOnError, TResponseType>;
|
package/dist/esm/index.js
CHANGED
@@ -1,5 +1,91 @@
|
|
1
|
-
import { splitConfig, isFunction, splitBaseConfig, createTimeoutSignal, createCombinedSignal, commonDefaults, getHeaders, isSerializable,
|
2
|
-
export { HTTPError } from './chunk-
|
1
|
+
import { splitConfig, isFunction, splitBaseConfig, createTimeoutSignal, createCombinedSignal, commonDefaults, getHeaders, isSerializable, HTTPError, isHTTPErrorInstance, waitUntil, hookDefaults, dedupeDefaults, responseDefaults, retryDefaults, isArray, isPlainObject, isString, toQueryString, getFetchImpl, isReadableStream, isHTTPError, requestOptionDefaults, isObject } from './chunk-IXCM5X4X.js';
|
2
|
+
export { HTTPError } from './chunk-IXCM5X4X.js';
|
3
|
+
|
4
|
+
// src/result.ts
|
5
|
+
var getResponseType = (response, parser) => ({
|
6
|
+
arrayBuffer: () => response.arrayBuffer(),
|
7
|
+
blob: () => response.blob(),
|
8
|
+
formData: () => response.formData(),
|
9
|
+
json: async () => {
|
10
|
+
const text = await response.text();
|
11
|
+
return parser(text);
|
12
|
+
},
|
13
|
+
stream: () => response.body,
|
14
|
+
text: () => response.text()
|
15
|
+
});
|
16
|
+
var resolveResponseData = (response, responseType, parser) => {
|
17
|
+
const selectedParser = parser ?? responseDefaults.responseParser;
|
18
|
+
const selectedResponseType = responseType ?? responseDefaults.responseType;
|
19
|
+
const RESPONSE_TYPE_LOOKUP = getResponseType(response, selectedParser);
|
20
|
+
if (!Object.hasOwn(RESPONSE_TYPE_LOOKUP, selectedResponseType)) {
|
21
|
+
throw new Error(`Invalid response type: ${responseType}`);
|
22
|
+
}
|
23
|
+
return RESPONSE_TYPE_LOOKUP[selectedResponseType]();
|
24
|
+
};
|
25
|
+
var resolveSuccessResult = (data, info) => {
|
26
|
+
const { response, resultMode } = info;
|
27
|
+
const details = {
|
28
|
+
data,
|
29
|
+
error: null,
|
30
|
+
response
|
31
|
+
};
|
32
|
+
const resultModeMap = {
|
33
|
+
all: details,
|
34
|
+
allWithException: details,
|
35
|
+
onlySuccess: details.data,
|
36
|
+
onlySuccessWithException: details.data
|
37
|
+
};
|
38
|
+
const successResult = resultModeMap[resultMode ?? "all"];
|
39
|
+
return successResult;
|
40
|
+
};
|
41
|
+
var resolveErrorResult = (error, info) => {
|
42
|
+
const { cloneResponse, defaultErrorMessage, message: customErrorMessage, resultMode } = info;
|
43
|
+
let details = {
|
44
|
+
data: null,
|
45
|
+
error: {
|
46
|
+
errorData: error,
|
47
|
+
message: customErrorMessage ?? error.message,
|
48
|
+
name: error.name,
|
49
|
+
originalError: error
|
50
|
+
},
|
51
|
+
response: null
|
52
|
+
};
|
53
|
+
if (isHTTPErrorInstance(error)) {
|
54
|
+
const selectedDefaultErrorMessage = defaultErrorMessage ?? commonDefaults.defaultErrorMessage;
|
55
|
+
const { errorData, message = selectedDefaultErrorMessage, name, response } = error;
|
56
|
+
details = {
|
57
|
+
data: null,
|
58
|
+
error: {
|
59
|
+
errorData,
|
60
|
+
message,
|
61
|
+
name,
|
62
|
+
originalError: error
|
63
|
+
},
|
64
|
+
response: cloneResponse ? response.clone() : response
|
65
|
+
};
|
66
|
+
}
|
67
|
+
const resultModeMap = {
|
68
|
+
all: details,
|
69
|
+
allWithException: details,
|
70
|
+
onlySuccess: details.data,
|
71
|
+
onlySuccessWithException: details.data
|
72
|
+
};
|
73
|
+
const errorResult = resultModeMap[resultMode ?? "all"];
|
74
|
+
return errorResult;
|
75
|
+
};
|
76
|
+
var getCustomizedErrorResult = (errorResult, customErrorInfo) => {
|
77
|
+
if (!errorResult) {
|
78
|
+
return null;
|
79
|
+
}
|
80
|
+
const { message = errorResult.error.message } = customErrorInfo;
|
81
|
+
return {
|
82
|
+
...errorResult,
|
83
|
+
error: {
|
84
|
+
...errorResult.error,
|
85
|
+
message
|
86
|
+
}
|
87
|
+
};
|
88
|
+
};
|
3
89
|
|
4
90
|
// src/hooks.ts
|
5
91
|
var hookRegistries = {
|
@@ -518,11 +604,14 @@ var createFetchClient = (initBaseConfig = {}) => {
|
|
518
604
|
schemas?.errorData,
|
519
605
|
validators?.errorData
|
520
606
|
);
|
521
|
-
throw new HTTPError(
|
522
|
-
|
523
|
-
|
524
|
-
|
525
|
-
|
607
|
+
throw new HTTPError(
|
608
|
+
{
|
609
|
+
defaultErrorMessage: options.defaultErrorMessage,
|
610
|
+
errorData: validErrorData,
|
611
|
+
response
|
612
|
+
},
|
613
|
+
{ cause: validErrorData }
|
614
|
+
);
|
526
615
|
}
|
527
616
|
const successData = await resolveResponseData(
|
528
617
|
shouldCloneResponse ? response.clone() : response,
|
@@ -601,15 +690,12 @@ var createFetchClient = (initBaseConfig = {}) => {
|
|
601
690
|
return await handleRetryOrGetErrorResult();
|
602
691
|
}
|
603
692
|
if (error instanceof DOMException && error.name === "AbortError") {
|
604
|
-
|
605
|
-
!shouldThrowOnError && console.error(`${name}:`, message);
|
606
|
-
return await handleRetryOrGetErrorResult();
|
693
|
+
!shouldThrowOnError && console.error(`${error.name}:`, error.message);
|
607
694
|
}
|
695
|
+
let timeoutMessage;
|
608
696
|
if (error instanceof DOMException && error.name === "TimeoutError") {
|
609
|
-
|
610
|
-
!shouldThrowOnError && console.error(`${error.name}:`,
|
611
|
-
const errorResult = await handleRetryOrGetErrorResult();
|
612
|
-
return getCustomizedErrorResult(errorResult, { message });
|
697
|
+
timeoutMessage = `Request timed out after ${options.timeout}ms`;
|
698
|
+
!shouldThrowOnError && console.error(`${error.name}:`, timeoutMessage);
|
613
699
|
}
|
614
700
|
const hookError = await executeHooksInCatchBlock(
|
615
701
|
// == At this point only the request errors exist, so the request error hook is called
|
@@ -620,7 +706,8 @@ var createFetchClient = (initBaseConfig = {}) => {
|
|
620
706
|
if (hookError) {
|
621
707
|
return hookError;
|
622
708
|
}
|
623
|
-
|
709
|
+
const errorResult = await handleRetryOrGetErrorResult();
|
710
|
+
return timeoutMessage ? getCustomizedErrorResult(errorResult, { message: timeoutMessage }) : errorResult;
|
624
711
|
} finally {
|
625
712
|
removeDedupeKeyFromCache();
|
626
713
|
}
|
package/dist/esm/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"sources":["../../src/hooks.ts","../../src/stream.ts","../../src/dedupe.ts","../../src/plugins.ts","../../src/retry.ts","../../src/url.ts","../../src/validation.ts","../../src/createFetchClient.ts","../../src/defineParameters.ts"],"names":["callApi","hookError"],"mappings":"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","file":"index.js","sourcesContent":["import {\n\ttype ErrorInfo,\n\ttype PossibleHTTPError,\n\ttype PossibleJavaScriptError,\n\tresolveErrorResult,\n} from \"./result\";\nimport type { StreamProgressEvent } from \"./stream\";\nimport type {\n\tBaseCallApiExtraOptions,\n\tCallApiExtraOptions,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n\tCombinedCallApiExtraOptions,\n} from \"./types/common\";\nimport type { DefaultDataType, DefaultMoreOptions } from \"./types/default-types\";\nimport type { AnyFunction, Awaitable, Prettify, UnmaskType } from \"./utils/type-helpers\";\n\nexport type WithMoreOptions<TMoreOptions = DefaultMoreOptions> = {\n\toptions: CombinedCallApiExtraOptions & Partial<TMoreOptions>;\n};\n\nexport type Hooks<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTMoreOptions = DefaultMoreOptions,\n> = {\n\t/**\n\t * Hook 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` hooks\n\t */\n\tonError?: (context: ErrorContext<TErrorData> & WithMoreOptions<TMoreOptions>) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called just before the request is made, allowing for modifications or additional operations.\n\t */\n\tonRequest?: (context: Prettify<RequestContext & WithMoreOptions<TMoreOptions>>) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when an error occurs during the fetch request.\n\t */\n\tonRequestError?: (\n\t\tcontext: Prettify<RequestErrorContext & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when upload stream progress is tracked\n\t */\n\tonRequestStream?: (\n\t\tcontext: Prettify<RequestStreamContext & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * Hook 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 * Hook that will be called when an error response is received from the api.\n\t */\n\tonResponseError?: (\n\t\tcontext: Prettify<ResponseErrorContext<TErrorData> & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when download stream progress is tracked\n\t */\n\tonResponseStream?: (\n\t\tcontext: Prettify<ResponseStreamContext & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when a request is retried.\n\t */\n\tonRetry?: (response: RetryContext<TErrorData> & WithMoreOptions<TMoreOptions>) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when a successful response is received from the api.\n\t */\n\tonSuccess?: (\n\t\tcontext: Prettify<SuccessContext<TData> & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n};\n\nexport type HooksOrHooksArray<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTMoreOptions = DefaultMoreOptions,\n> = {\n\t[Key in keyof Hooks<TData, TErrorData, TMoreOptions>]:\n\t\t| Hooks<TData, TErrorData, TMoreOptions>[Key]\n\t\t// eslint-disable-next-line perfectionist/sort-union-types -- I need arrays to be last\n\t\t| Array<Hooks<TData, TErrorData, TMoreOptions>[Key]>;\n};\n\nexport type SharedHookContext<TMoreOptions = DefaultMoreOptions> = {\n\t/**\n\t * Config object passed to createFetchClient\n\t */\n\tbaseConfig: BaseCallApiExtraOptions & CallApiRequestOptions;\n\t/**\n\t * Config object passed to the callApi instance\n\t */\n\tconfig: CallApiExtraOptions & CallApiRequestOptions;\n\t/**\n\t * Merged options consisting of extra options from createFetchClient, the callApi instance and default options.\n\t *\n\t */\n\toptions: CombinedCallApiExtraOptions & Partial<TMoreOptions>;\n\t/**\n\t * Merged request consisting of request options from createFetchClient, the callApi instance and default request options.\n\t */\n\trequest: CallApiRequestOptionsForHooks;\n};\n\nexport type RequestContext = UnmaskType<SharedHookContext>;\n\nexport type ResponseContext<TData, TErrorData> = UnmaskType<\n\t| Prettify<\n\t\t\tSharedHookContext & {\n\t\t\t\tdata: TData;\n\t\t\t\terror: null;\n\t\t\t\tresponse: Response;\n\t\t\t}\n\t >\n\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the first one to be first\n\t| Prettify<\n\t\t\tSharedHookContext & {\n\t\t\t\tdata: null;\n\t\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\t\tresponse: Response;\n\t\t\t}\n\t >\n>;\n\nexport type SuccessContext<TData> = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\tdata: TData;\n\t\t\tresponse: Response;\n\t\t}\n\t>\n>;\n\nexport type RequestErrorContext = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\terror: PossibleJavaScriptError;\n\t\t\tresponse: null;\n\t\t}\n\t>\n>;\n\nexport type ResponseErrorContext<TErrorData> = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\tresponse: Response;\n\t\t}\n\t>\n>;\n\nexport type RetryContext<TErrorData> = UnmaskType<\n\tPrettify<ErrorContext<TErrorData> & { retryAttemptCount: number }>\n>;\n\nexport type ErrorContext<TErrorData> = UnmaskType<\n\t| Prettify<\n\t\t\tSharedHookContext & {\n\t\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\t\tresponse: Response;\n\t\t\t}\n\t >\n\t| Prettify<\n\t\t\tSharedHookContext & {\n\t\t\t\terror: PossibleJavaScriptError;\n\t\t\t\tresponse: null;\n\t\t\t}\n\t >\n>;\n\nexport type RequestStreamContext = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\tevent: StreamProgressEvent;\n\t\t\trequestInstance: Request;\n\t\t}\n\t>\n>;\n\nexport type ResponseStreamContext = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\tevent: StreamProgressEvent;\n\t\t\tresponse: Response;\n\t\t}\n\t>\n>;\n\ntype HookRegistries = {\n\t[Key in keyof Hooks]: Set<Hooks[Key]>;\n};\n\nexport const hookRegistries = {\n\tonError: new Set(),\n\tonRequest: new Set(),\n\tonRequestError: new Set(),\n\tonRequestStream: new Set(),\n\tonResponse: new Set(),\n\tonResponseError: new Set(),\n\tonResponseStream: new Set(),\n\tonRetry: new Set(),\n\tonSuccess: new Set(),\n} satisfies HookRegistries;\n\nexport const composeTwoHooks = (\n\thooks: Array<AnyFunction | undefined>,\n\tmergedHooksExecutionMode: CombinedCallApiExtraOptions[\"mergedHooksExecutionMode\"]\n) => {\n\tif (hooks.length === 0) return;\n\n\tconst mergedHook = 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\treturn mergedHook;\n};\n\nexport const executeHooksInTryBlock = async (...hookResults: Array<Awaitable<unknown>>) => {\n\tawait Promise.all(hookResults);\n};\n\ntype Info = {\n\terrorInfo: ErrorInfo;\n\tshouldThrowOnError: boolean | undefined;\n};\n\nexport const createExecuteHooksFn = (info: Info) => {\n\tconst { errorInfo, shouldThrowOnError } = info;\n\n\tconst executeHooksInCatchBlock = async (...hookResults: Array<Awaitable<unknown>>) => {\n\t\ttry {\n\t\t\tawait Promise.all(hookResults);\n\n\t\t\treturn null;\n\t\t} catch (hookError) {\n\t\t\tconst hookErrorResult = resolveErrorResult(hookError, errorInfo);\n\n\t\t\tif (shouldThrowOnError) {\n\t\t\t\tthrow hookError;\n\t\t\t}\n\n\t\t\treturn hookErrorResult;\n\t\t}\n\t};\n\n\treturn executeHooksInCatchBlock;\n};\n","import { type SharedHookContext, executeHooksInTryBlock } from \"./hooks\";\nimport { isObject } from \"./utils/guards\";\n\nexport type StreamProgressEvent = {\n\t/**\n\t * Current chunk of data being streamed\n\t */\n\tchunk: Uint8Array;\n\t/**\n\t * Progress in percentage\n\t */\n\tprogress: number;\n\t/**\n\t * Total size of data in bytes\n\t */\n\ttotalBytes: number;\n\t/**\n\t * Amount of data transferred so far\n\t */\n\ttransferredBytes: number;\n};\n\ndeclare global {\n\t// eslint-disable-next-line ts-eslint/consistent-type-definitions -- Allow\n\tinterface ReadableStream<R> {\n\t\t[Symbol.asyncIterator]: () => AsyncIterableIterator<R>;\n\t}\n}\n\nconst createProgressEvent = (options: {\n\tchunk: Uint8Array;\n\ttotalBytes: number;\n\ttransferredBytes: number;\n}): StreamProgressEvent => {\n\tconst { chunk, totalBytes, transferredBytes } = options;\n\n\treturn {\n\t\tchunk,\n\t\tprogress: Math.round((transferredBytes / totalBytes) * 100) || 0,\n\t\ttotalBytes,\n\t\ttransferredBytes,\n\t};\n};\n\nconst calculateTotalBytesFromBody = async (\n\trequestBody: Request[\"body\"] | null,\n\texistingTotalBytes: number\n) => {\n\tlet totalBytes = existingTotalBytes;\n\n\tif (!requestBody) {\n\t\treturn totalBytes;\n\t}\n\n\tfor await (const chunk of requestBody) {\n\t\ttotalBytes += chunk.byteLength;\n\t}\n\n\treturn totalBytes;\n};\n\ntype ToStreamableRequestContext = SharedHookContext & { requestInstance: Request };\n\nexport const toStreamableRequest = async (context: ToStreamableRequestContext) => {\n\tconst { baseConfig, config, options, request, requestInstance } = context;\n\n\tif (!options.onRequestStream || !requestInstance.body) return;\n\n\tconst contentLength =\n\t\trequestInstance.headers.get(\"content-length\")\n\t\t?? new Headers(request.headers as HeadersInit).get(\"content-length\")\n\t\t?? (request.body as Blob | null)?.size;\n\n\tlet totalBytes = Number(contentLength ?? 0);\n\n\tconst shouldForceContentLengthCalc = isObject(options.forceCalculateStreamSize)\n\t\t? options.forceCalculateStreamSize.request\n\t\t: options.forceCalculateStreamSize;\n\n\t// If no content length is present, we read the total bytes from the body\n\tif (!contentLength && shouldForceContentLengthCalc) {\n\t\ttotalBytes = await calculateTotalBytesFromBody(requestInstance.clone().body, totalBytes);\n\t}\n\n\tlet transferredBytes = 0;\n\n\tawait executeHooksInTryBlock(\n\t\toptions.onRequestStream({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tevent: createProgressEvent({ chunk: new Uint8Array(), totalBytes, transferredBytes }),\n\t\t\toptions,\n\t\t\trequest,\n\t\t\trequestInstance,\n\t\t})\n\t);\n\n\tconst body = requestInstance.body as ReadableStream<Uint8Array> | null;\n\n\tvoid new ReadableStream({\n\t\tstart: async (controller) => {\n\t\t\tif (!body) return;\n\n\t\t\tfor await (const chunk of body) {\n\t\t\t\ttransferredBytes += chunk.byteLength;\n\n\t\t\t\ttotalBytes = Math.max(totalBytes, transferredBytes);\n\n\t\t\t\tawait executeHooksInTryBlock(\n\t\t\t\t\toptions.onRequestStream?.({\n\t\t\t\t\t\tbaseConfig,\n\t\t\t\t\t\tconfig,\n\t\t\t\t\t\tevent: createProgressEvent({ chunk, totalBytes, transferredBytes }),\n\t\t\t\t\t\toptions,\n\t\t\t\t\t\trequest,\n\t\t\t\t\t\trequestInstance,\n\t\t\t\t\t})\n\t\t\t\t);\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t}\n\t\t\tcontroller.close();\n\t\t},\n\t});\n};\n\ntype StreamableResponseContext = SharedHookContext & { response: Response };\nexport const toStreamableResponse = async (context: StreamableResponseContext): Promise<Response> => {\n\tconst { baseConfig, config, options, request, response } = context;\n\n\tif (!options.onResponseStream || !response.body) {\n\t\treturn response;\n\t}\n\n\tconst contentLength = response.headers.get(\"content-length\");\n\n\tlet totalBytes = Number(contentLength ?? 0);\n\n\tconst shouldForceContentLengthCalc = isObject(options.forceCalculateStreamSize)\n\t\t? options.forceCalculateStreamSize.response\n\t\t: options.forceCalculateStreamSize;\n\n\t// If no content length is present and `forceContentLengthCalculation` is enabled, we read the total bytes from the body\n\tif (!contentLength && shouldForceContentLengthCalc) {\n\t\ttotalBytes = await calculateTotalBytesFromBody(response.clone().body, totalBytes);\n\t}\n\n\tlet transferredBytes = 0;\n\n\tawait executeHooksInTryBlock(\n\t\toptions.onResponseStream({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tevent: createProgressEvent({ chunk: new Uint8Array(), totalBytes, transferredBytes }),\n\t\t\toptions,\n\t\t\trequest,\n\t\t\tresponse,\n\t\t})\n\t);\n\n\tconst body = response.body as ReadableStream<Uint8Array> | null;\n\n\tconst stream = new ReadableStream({\n\t\tstart: async (controller) => {\n\t\t\tif (!body) return;\n\n\t\t\tfor await (const chunk of body) {\n\t\t\t\ttransferredBytes += chunk.byteLength;\n\n\t\t\t\ttotalBytes = Math.max(totalBytes, transferredBytes);\n\n\t\t\t\tawait executeHooksInTryBlock(\n\t\t\t\t\toptions.onResponseStream?.({\n\t\t\t\t\t\tbaseConfig,\n\t\t\t\t\t\tconfig,\n\t\t\t\t\t\tevent: createProgressEvent({ chunk, totalBytes, transferredBytes }),\n\t\t\t\t\t\toptions,\n\t\t\t\t\t\trequest,\n\t\t\t\t\t\tresponse,\n\t\t\t\t\t})\n\t\t\t\t);\n\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t}\n\n\t\t\tcontroller.close();\n\t\t},\n\t});\n\n\treturn new Response(stream, response);\n};\n","import { dedupeDefaults, requestOptionDefaults } from \"./constants/default-options\";\nimport type { SharedHookContext } from \"./hooks\";\nimport { toStreamableRequest, toStreamableResponse } from \"./stream\";\nimport { getFetchImpl, waitUntil } from \"./utils/common\";\nimport { isReadableStream } from \"./utils/guards\";\n\ntype RequestInfo = {\n\tcontroller: AbortController;\n\tresponsePromise: Promise<Response>;\n};\n\nexport type RequestInfoCache = Map<string | null, RequestInfo>;\n\ntype DedupeContext = SharedHookContext & {\n\t$RequestInfoCache: RequestInfoCache;\n\tnewFetchController: AbortController;\n};\n\nexport const createDedupeStrategy = async (context: DedupeContext) => {\n\tconst { $RequestInfoCache, baseConfig, config, newFetchController, options, request } = context;\n\n\tconst dedupeStrategy = options.dedupeStrategy ?? dedupeDefaults.dedupeStrategy;\n\n\tconst generateDedupeKey = () => {\n\t\tconst shouldHaveDedupeKey = dedupeStrategy === \"cancel\" || 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 handleRequestCancelStrategy = () => {\n\t\tconst shouldCancelRequest = prevRequestInfo && dedupeStrategy === \"cancel\";\n\n\t\tif (!shouldCancelRequest) return;\n\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\n\t\t// == Adding this just so that eslint forces me put await when calling the function (it looks better that way tbh)\n\t\treturn Promise.resolve();\n\t};\n\n\tconst handleRequestDeferStrategy = async () => {\n\t\tconst fetchApi = getFetchImpl(options.customFetchImpl);\n\n\t\tconst shouldUsePromiseFromCache = prevRequestInfo && dedupeStrategy === \"defer\";\n\n\t\tconst requestInstance = new Request(\n\t\t\toptions.fullURL as NonNullable<typeof options.fullURL>,\n\t\t\t(isReadableStream(request.body) && !request.duplex\n\t\t\t\t? { ...request, duplex: \"half\" }\n\t\t\t\t: request) as RequestInit\n\t\t);\n\n\t\tawait toStreamableRequest({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\toptions,\n\t\t\trequest,\n\t\t\trequestInstance: requestInstance.clone(),\n\t\t});\n\n\t\tconst getFetchApiPromise = () => {\n\t\t\tif (isReadableStream(request.body)) {\n\t\t\t\treturn fetchApi(requestInstance.clone());\n\t\t\t}\n\n\t\t\tconst method = request.method ?? requestOptionDefaults.method;\n\n\t\t\tconst modifiedRequest = { ...request, method } as RequestInit;\n\n\t\t\treturn fetchApi(options.fullURL as NonNullable<typeof options.fullURL>, modifiedRequest);\n\t\t};\n\n\t\tconst responsePromise = shouldUsePromiseFromCache\n\t\t\t? prevRequestInfo.responsePromise\n\t\t\t: getFetchApiPromise();\n\n\t\t$RequestInfoCacheOrNull?.set(dedupeKey, { controller: newFetchController, responsePromise });\n\n\t\tconst streamableResponse = toStreamableResponse({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\toptions,\n\t\t\trequest,\n\t\t\tresponse: await responsePromise,\n\t\t});\n\n\t\treturn streamableResponse;\n\t};\n\n\tconst removeDedupeKeyFromCache = () => {\n\t\t$RequestInfoCacheOrNull?.delete(dedupeKey);\n\t};\n\n\treturn {\n\t\tdedupeStrategy,\n\t\thandleRequestCancelStrategy,\n\t\thandleRequestDeferStrategy,\n\t\tremoveDedupeKeyFromCache,\n\t};\n};\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\nimport { hookDefaults } from \"./constants/default-options\";\nimport {\n\ttype Hooks,\n\ttype HooksOrHooksArray,\n\ttype SharedHookContext,\n\tcomposeTwoHooks,\n\thookRegistries,\n} from \"./hooks\";\nimport type {\n\tBaseCallApiExtraOptions,\n\tCallApiExtraOptions,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n} from \"./types/common\";\nimport type { DefaultMoreOptions } from \"./types/default-types\";\nimport type { StandardSchemaV1 } from \"./types/standard-schema\";\nimport type { InitURL } from \"./url\";\nimport { isArray, isFunction, isPlainObject, isString } from \"./utils/guards\";\nimport type { AnyFunction, Awaitable, Prettify } from \"./utils/type-helpers\";\nimport type { InferSchemaResult } from \"./validation\";\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\ntype InferSchema<TResult> = TResult extends StandardSchemaV1\n\t? InferSchemaResult<TResult, NonNullable<unknown>>\n\t: TResult;\n\nexport type InferPluginOptions<TPluginArray extends CallApiPlugin[]> = UnionToIntersection<\n\tInferSchema<ReturnType<NonNullable<TPluginArray[number][\"createExtraOptions\"]>>>\n>;\n\nexport type PluginInitContext<TMoreOptions = DefaultMoreOptions> = Prettify<\n\tSharedHookContext<TMoreOptions> & { initURL: InitURL | undefined }\n>;\n\nexport type PluginInitResult = Partial<\n\tOmit<PluginInitContext, \"request\"> & { request: CallApiRequestOptions }\n>;\n\nexport type PluginHooksWithMoreOptions<TMoreOptions = DefaultMoreOptions> = HooksOrHooksArray<\n\tnever,\n\tnever,\n\tTMoreOptions\n>;\n\nexport type PluginHooks<\n\tTData = never,\n\tTErrorData = never,\n\tTMoreOptions = DefaultMoreOptions,\n> = HooksOrHooksArray<TData, TErrorData, TMoreOptions>;\n\nexport interface CallApiPlugin {\n\t/**\n\t * Defines additional options that can be passed to callApi\n\t */\n\tcreateExtraOptions?: (...params: never[]) => unknown;\n\n\t/**\n\t * A description for the plugin\n\t */\n\tdescription?: string;\n\n\t/**\n\t * Hooks / Interceptors for the plugin\n\t */\n\thooks?: PluginHooks;\n\n\t/**\n\t * A unique id for the plugin\n\t */\n\tid: string;\n\n\t/**\n\t * A function that will be called when the plugin is initialized. This will be called before the any of the other internal functions.\n\t */\n\tinit?: (context: PluginInitContext) => Awaitable<PluginInitResult> | Awaitable<void>;\n\n\t/**\n\t * A name for the plugin\n\t */\n\tname: string;\n\n\t/**\n\t * A version for the plugin\n\t */\n\tversion?: string;\n}\n\nexport const definePlugin = <\n\t// eslint-disable-next-line perfectionist/sort-union-types -- Let the first one be first\n\tTPlugin extends CallApiPlugin | AnyFunction<CallApiPlugin>,\n>(\n\tplugin: TPlugin\n) => {\n\treturn plugin;\n};\n\nexport type Plugins<TPluginArray extends CallApiPlugin[]> = TPluginArray;\n\nconst resolvePluginArray = (\n\tplugins: CallApiExtraOptions[\"plugins\"] | undefined,\n\tbasePlugins: BaseCallApiExtraOptions[\"plugins\"] | undefined\n) => {\n\tif (!plugins) {\n\t\treturn [];\n\t}\n\n\tif (isFunction(plugins)) {\n\t\treturn plugins({ basePlugins: basePlugins ?? [] });\n\t}\n\n\treturn plugins;\n};\n\nexport const initializePlugins = async (context: PluginInitContext) => {\n\tconst { baseConfig, config, initURL, options, request } = context;\n\n\tconst clonedHookRegistries = structuredClone(hookRegistries);\n\n\tconst addMainHooks = () => {\n\t\tfor (const key of Object.keys(clonedHookRegistries) as Array<keyof Hooks>) {\n\t\t\tconst baseHook = baseConfig[key];\n\t\t\tconst instanceHook = config[key];\n\n\t\t\tconst overriddenHook = options[key] as HooksOrHooksArray[typeof key];\n\n\t\t\t// If the base hook is an array and instance hook is defined, we need to compose it with the overridden hook\n\t\t\tconst mainHook =\n\t\t\t\tisArray(baseHook) && Boolean(instanceHook) ? [baseHook, instanceHook].flat() : overriddenHook;\n\n\t\t\tif (!mainHook) continue;\n\n\t\t\tclonedHookRegistries[key].add(mainHook as never);\n\t\t}\n\t};\n\n\tconst addPluginHooks = (pluginHooks: Required<CallApiPlugin>[\"hooks\"]) => {\n\t\tfor (const key of Object.keys(clonedHookRegistries) as Array<keyof Hooks>) {\n\t\t\tconst pluginHook = pluginHooks[key];\n\n\t\t\tif (!pluginHook) continue;\n\n\t\t\tclonedHookRegistries[key].add(pluginHook as never);\n\t\t}\n\t};\n\n\tconst mergedHooksExecutionOrder =\n\t\toptions.mergedHooksExecutionOrder ?? hookDefaults.mergedHooksExecutionOrder;\n\n\tif (mergedHooksExecutionOrder === \"mainHooksBeforePlugins\") {\n\t\taddMainHooks();\n\t}\n\n\tconst resolvedPlugins = resolvePluginArray(options.plugins, baseConfig.plugins);\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({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tinitURL,\n\t\t\toptions,\n\t\t\trequest,\n\t\t});\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 as CallApiRequestOptionsForHooks;\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 (mergedHooksExecutionOrder === \"mainHooksAfterPlugins\") {\n\t\taddMainHooks();\n\t}\n\n\tconst resolvedHooks: Hooks = {};\n\n\tfor (const [key, hookRegistry] of Object.entries(clonedHookRegistries)) {\n\t\tconst flattenedHookArray = [...hookRegistry].flat();\n\n\t\tconst mergedHooksExecutionMode =\n\t\t\toptions.mergedHooksExecutionMode ?? hookDefaults.mergedHooksExecutionMode;\n\n\t\tconst composedHook = composeTwoHooks(flattenedHookArray, mergedHooksExecutionMode);\n\n\t\tcomposedHook && (resolvedHooks[key as keyof Hooks] = composedHook);\n\t}\n\n\treturn {\n\t\tresolvedHooks,\n\t\tresolvedOptions,\n\t\tresolvedRequestOptions,\n\t\turl: resolvedUrl?.toString(),\n\t};\n};\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\nimport { requestOptionDefaults, retryDefaults } from \"./constants/default-options\";\nimport type { ErrorContext } from \"./hooks\";\nimport type { Method } from \"./types\";\nimport { isFunction, isHTTPError } from \"./utils/guards\";\nimport type { Awaitable } from \"./utils/type-helpers\";\n\ntype RetryCondition<TErrorData> = (context: ErrorContext<TErrorData>) => Awaitable<boolean>;\n\ntype InnerRetryKeys<TErrorData> = Exclude<keyof RetryOptions<TErrorData>, \"~retryAttemptCount\" | \"retry\">;\n\ntype InnerRetryOptions<TErrorData> = {\n\t[Key in InnerRetryKeys<TErrorData> as Key extends `retry${infer TRest}`\n\t\t? Uncapitalize<TRest> extends \"attempts\"\n\t\t\t? never\n\t\t\t: Uncapitalize<TRest>\n\t\t: Key]?: RetryOptions<TErrorData>[Key];\n} & {\n\tattempts: NonNullable<RetryOptions<TErrorData>[\"retryAttempts\"]>;\n};\n\nexport interface RetryOptions<TErrorData> {\n\t/**\n\t * 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 [\"~retryAttemptCount\"]?: number;\n\n\t/**\n\t * All retry options in a single object instead of separate properties\n\t */\n\tretry?: InnerRetryOptions<TErrorData>;\n\n\t/**\n\t * Number of allowed retry attempts on HTTP errors\n\t * @default 0\n\t */\n\tretryAttempts?: number;\n\n\t/**\n\t * Callback whose return value determines if a request should be retried or not\n\t */\n\tretryCondition?: RetryCondition<TErrorData>;\n\n\t/**\n\t * Delay between retries in milliseconds\n\t * @default 1000\n\t */\n\tretryDelay?: number | ((currentAttemptCount: number) => number);\n\n\t/**\n\t * 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?: Method[];\n\n\t/**\n\t * HTTP status codes that trigger a retry\n\t */\n\tretryStatusCodes?: number[];\n\n\t/**\n\t * Strategy to use when retrying\n\t * @default \"linear\"\n\t */\n\tretryStrategy?: \"exponential\" | \"linear\";\n}\n\nconst getLinearDelay = <TErrorData>(currentAttemptCount: number, options: RetryOptions<TErrorData>) => {\n\tconst retryDelay = options.retryDelay ?? options.retry?.delay;\n\n\tconst resolveRetryDelay =\n\t\t(isFunction(retryDelay) ? retryDelay(currentAttemptCount) : retryDelay) ?? retryDefaults.delay;\n\n\treturn resolveRetryDelay;\n};\n\nconst getExponentialDelay = <TErrorData>(\n\tcurrentAttemptCount: number,\n\toptions: RetryOptions<TErrorData>\n) => {\n\tconst retryDelay = options.retryDelay ?? options.retry?.delay ?? retryDefaults.delay;\n\n\tconst resolvedRetryDelay = Number(\n\t\tisFunction(retryDelay) ? retryDelay(currentAttemptCount) : retryDelay\n\t);\n\n\tconst maxDelay = Number(options.retryMaxDelay ?? options.retry?.maxDelay ?? retryDefaults.maxDelay);\n\n\tconst exponentialDelay = resolvedRetryDelay * 2 ** currentAttemptCount;\n\n\treturn Math.min(exponentialDelay, maxDelay);\n};\n\nexport const createRetryStrategy = <TErrorData>(ctx: ErrorContext<TErrorData>) => {\n\tconst { options } = ctx;\n\n\tconst currentAttemptCount = options[\"~retryAttemptCount\"] ?? 1;\n\n\tconst retryStrategy = options.retryStrategy ?? options.retry?.strategy ?? retryDefaults.strategy;\n\n\tconst getDelay = () => {\n\t\tswitch (retryStrategy) {\n\t\t\tcase \"exponential\": {\n\t\t\t\treturn getExponentialDelay(currentAttemptCount, options);\n\t\t\t}\n\t\t\tcase \"linear\": {\n\t\t\t\treturn getLinearDelay(currentAttemptCount, options);\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\tthrow new Error(`Invalid retry strategy: ${String(retryStrategy)}`);\n\t\t\t}\n\t\t}\n\t};\n\n\tconst shouldAttemptRetry = async () => {\n\t\tconst retryCondition = options.retryCondition ?? options.retry?.condition ?? retryDefaults.condition;\n\n\t\tconst maximumRetryAttempts =\n\t\t\toptions.retryAttempts ?? options.retry?.attempts ?? retryDefaults.attempts;\n\n\t\tconst customRetryCondition = await retryCondition(ctx);\n\n\t\tconst baseShouldRetry = maximumRetryAttempts >= currentAttemptCount && customRetryCondition;\n\n\t\tif (!baseShouldRetry) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// == If error is not an HTTP error, just return true since at this point we know it's a retryable error\n\t\tif (!isHTTPError(ctx.error)) {\n\t\t\treturn true;\n\t\t}\n\n\t\tconst selectedMethodArray = options.retryMethods ?? options.retry?.methods ?? retryDefaults.methods;\n\n\t\tconst retryMethods = new Set(selectedMethodArray);\n\n\t\tconst method = ctx.request.method ?? requestOptionDefaults.method;\n\n\t\tconst includesMethod = Boolean(method) && retryMethods.has(method);\n\n\t\tconst selectedStatusCodeArray = options.retryStatusCodes ?? options.retry?.statusCodes;\n\n\t\tconst retryStatusCodes = selectedStatusCodeArray ? new Set(selectedStatusCodeArray) : null;\n\n\t\tconst includesStatusCodes =\n\t\t\tBoolean(ctx.response?.status) && (retryStatusCodes?.has(ctx.response.status) ?? true);\n\n\t\tconst shouldRetry = includesMethod && includesStatusCodes;\n\n\t\treturn shouldRetry;\n\t};\n\n\treturn {\n\t\tcurrentAttemptCount,\n\t\tgetDelay,\n\t\tshouldAttemptRetry,\n\t};\n};\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\nimport type { CallApiExtraOptions } from \"./types/common\";\nimport { toQueryString } from \"./utils\";\nimport { isArray } from \"./utils/guards\";\nimport type { UnmaskType } from \"./utils/type-helpers\";\nimport type { CallApiSchemas, InferSchemaResult } from \"./validation\";\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: CallApiExtraOptions[\"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 | undefined,\n\tparams: CallApiExtraOptions[\"params\"],\n\tquery: CallApiExtraOptions[\"query\"]\n) => {\n\tif (!url) return;\n\n\tconst urlWithMergedParams = mergeUrlWithParams(url, params);\n\n\treturn mergeUrlWithQuery(urlWithMergedParams, query);\n};\n\nexport type Params = UnmaskType<\n\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the Record to be first\n\tRecord<string, boolean | number | string> | Array<boolean | number | string>\n>;\n\nexport type Query = UnmaskType<Record<string, boolean | number | string>>;\n\nexport type InitURL = UnmaskType<string | URL>;\n\nexport interface UrlOptions<TSchemas extends CallApiSchemas> {\n\t/**\n\t * URL to be used in the request.\n\t */\n\treadonly initURL?: string;\n\n\t/**\n\t * Parameters to be appended to the URL (i.e: /:id)\n\t */\n\tparams?: InferSchemaResult<TSchemas[\"params\"], Params>;\n\n\t/**\n\t * Query parameters to append to the URL.\n\t */\n\tquery?: InferSchemaResult<TSchemas[\"query\"], Query>;\n}\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\nimport type { Body, GlobalMeta, Headers, Method } from \"./types\";\nimport type { StandardSchemaV1 } from \"./types/standard-schema\";\nimport type { InitURL, Params, Query } from \"./url\";\n\nexport const standardSchemaParser = async <TSchema extends StandardSchemaV1>(\n\tschema: TSchema,\n\tinputData: StandardSchemaV1.InferInput<TSchema>\n): Promise<StandardSchemaV1.InferOutput<TSchema>> => {\n\tconst result = await schema[\"~standard\"].validate(inputData);\n\n\t// == If the `issues` field exists, it means the validation failed\n\tif (result.issues) {\n\t\tthrow new Error(JSON.stringify(result.issues, null, 2), { cause: result.issues });\n\t}\n\n\treturn result.value;\n};\n\nexport interface CallApiSchemas {\n\t/**\n\t * The schema to use for validating the request body.\n\t */\n\tbody?: StandardSchemaV1<Body>;\n\n\t/**\n\t * The schema to use for validating the response data.\n\t */\n\tdata?: StandardSchemaV1;\n\n\t/**\n\t * The schema to use for validating the response error data.\n\t */\n\terrorData?: StandardSchemaV1;\n\n\t/**\n\t * The schema to use for validating the request headers.\n\t */\n\theaders?: StandardSchemaV1<Headers>;\n\n\t/**\n\t * The schema to use for validating the request url.\n\t */\n\tinitURL?: StandardSchemaV1<InitURL>;\n\n\t/**\n\t * The schema to use for validating the meta option.\n\t */\n\tmeta?: StandardSchemaV1<GlobalMeta>;\n\n\t/**\n\t * The schema to use for validating the request method.\n\t */\n\tmethod?: StandardSchemaV1<Method>;\n\n\t/**\n\t * The schema to use for validating the request url parameter.\n\t */\n\tparams?: StandardSchemaV1<Params>;\n\n\t/**\n\t * The schema to use for validating the request url querys.\n\t */\n\tquery?: StandardSchemaV1<Query>;\n}\n\nexport interface CallApiValidators<TData = unknown, TErrorData = unknown> {\n\t/**\n\t * Custom function to validate the response data.\n\t */\n\tdata?: (value: unknown) => TData;\n\n\t/**\n\t * Custom function to validate the response error data, stemming from the api.\n\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 */\n\terrorData?: (value: unknown) => TErrorData;\n}\n\nexport type InferSchemaResult<TSchema, TData> = TSchema extends StandardSchemaV1\n\t? StandardSchemaV1.InferOutput<TSchema>\n\t: TData;\n\nexport const handleValidation = async (\n\tresponseData: unknown,\n\tschema: CallApiSchemas[keyof NonNullable<CallApiSchemas>],\n\tvalidator?: CallApiValidators[keyof NonNullable<CallApiValidators>]\n) => {\n\tconst validResponseData = validator ? validator(responseData) : responseData;\n\n\tconst schemaValidResponseData = schema\n\t\t? await standardSchemaParser(schema, validResponseData)\n\t\t: validResponseData;\n\n\treturn schemaValidResponseData;\n};\n","import { commonDefaults } from \"./constants/default-options\";\nimport { type RequestInfoCache, createDedupeStrategy } from \"./dedupe\";\nimport {\n\ttype ErrorContext,\n\ttype RetryContext,\n\ttype SuccessContext,\n\tcreateExecuteHooksFn,\n\texecuteHooksInTryBlock,\n} from \"./hooks\";\nimport { type CallApiPlugin, initializePlugins } from \"./plugins\";\nimport {\n\ttype ErrorInfo,\n\tHTTPError,\n\ttype ResponseTypeUnion,\n\ttype ResultModeUnion,\n\tgetCustomizedErrorResult,\n\tresolveErrorResult,\n\tresolveResponseData,\n\tresolveSuccessResult,\n} from \"./result\";\nimport { createRetryStrategy } from \"./retry\";\nimport type {\n\tBaseCallApiConfig,\n\tBaseCallApiExtraOptions,\n\tCallApiExtraOptions,\n\tCallApiParameters,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n\tCallApiResult,\n\tCombinedCallApiExtraOptions,\n} from \"./types/common\";\nimport type {\n\tDefaultDataType,\n\tDefaultMoreOptions,\n\tDefaultPluginArray,\n\tDefaultThrowOnError,\n} from \"./types/default-types\";\nimport { mergeUrlWithParamsAndQuery } from \"./url\";\nimport {\n\tcreateCombinedSignal,\n\tcreateTimeoutSignal,\n\tgetHeaders,\n\tsplitBaseConfig,\n\tsplitConfig,\n\twaitUntil,\n} from \"./utils/common\";\nimport { isFunction, isHTTPErrorInstance, isSerializable } from \"./utils/guards\";\nimport { type CallApiSchemas, type InferSchemaResult, handleValidation } from \"./validation\";\n\nexport const createFetchClient = <\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBaseThrowOnError extends boolean = DefaultThrowOnError,\n\tTBaseResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTBasePluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTBaseSchemas extends CallApiSchemas = DefaultMoreOptions,\n>(\n\tinitBaseConfig: BaseCallApiConfig<\n\t\tTBaseData,\n\t\tTBaseErrorData,\n\t\tTBaseResultMode,\n\t\tTBaseThrowOnError,\n\t\tTBaseResponseType,\n\t\tTBasePluginArray,\n\t\tTBaseSchemas\n\t> = {} as never\n) => {\n\tconst $RequestInfoCache: RequestInfoCache = new Map();\n\n\tconst callApi = async <\n\t\tTData = InferSchemaResult<TBaseSchemas[\"data\"], TBaseData>,\n\t\tTErrorData = InferSchemaResult<TBaseSchemas[\"errorData\"], TBaseErrorData>,\n\t\tTResultMode extends ResultModeUnion = TBaseResultMode,\n\t\tTThrowOnError extends boolean = TBaseThrowOnError,\n\t\tTResponseType extends ResponseTypeUnion = TBaseResponseType,\n\t\tTPluginArray extends CallApiPlugin[] = TBasePluginArray,\n\t\tTSchemas extends CallApiSchemas = TBaseSchemas,\n\t>(\n\t\t...parameters: CallApiParameters<\n\t\t\tTData,\n\t\t\tTErrorData,\n\t\t\tTResultMode,\n\t\t\tTThrowOnError,\n\t\t\tTResponseType,\n\t\t\tTPluginArray,\n\t\t\tTSchemas\n\t\t>\n\t): CallApiResult<\n\t\tInferSchemaResult<TSchemas[\"data\"], TData>,\n\t\tInferSchemaResult<TSchemas[\"errorData\"], TErrorData>,\n\t\tTResultMode,\n\t\tTThrowOnError,\n\t\tTResponseType\n\t> => {\n\t\tconst [initURL, initConfig = {}] = parameters;\n\n\t\tconst [fetchOptions, extraOptions] = splitConfig(initConfig);\n\n\t\tconst resolvedBaseConfig = isFunction(initBaseConfig)\n\t\t\t? initBaseConfig({ initURL: initURL.toString(), options: extraOptions, request: fetchOptions })\n\t\t\t: initBaseConfig;\n\n\t\tconst [baseFetchOptions, baseExtraOptions] = splitBaseConfig(resolvedBaseConfig);\n\n\t\t// == Merged Extra Options\n\t\tconst mergedExtraOptions = {\n\t\t\t...baseExtraOptions,\n\t\t\t...(baseExtraOptions.skipAutoMergeFor !== \"all\"\n\t\t\t\t&& baseExtraOptions.skipAutoMergeFor !== \"options\"\n\t\t\t\t&& extraOptions),\n\t\t};\n\n\t\t// == Merged Request Options\n\t\tconst mergedRequestOptions = {\n\t\t\t...baseFetchOptions,\n\t\t\t...(baseExtraOptions.skipAutoMergeFor !== \"all\"\n\t\t\t\t&& baseExtraOptions.skipAutoMergeFor !== \"request\"\n\t\t\t\t&& fetchOptions),\n\t\t} satisfies CallApiRequestOptions;\n\n\t\tconst baseConfig = resolvedBaseConfig as BaseCallApiExtraOptions & CallApiRequestOptions;\n\t\tconst config = initConfig as CallApiExtraOptions & CallApiRequestOptions;\n\n\t\tconst { resolvedHooks, resolvedOptions, resolvedRequestOptions, url } = await initializePlugins({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tinitURL,\n\t\t\toptions: mergedExtraOptions as CombinedCallApiExtraOptions,\n\t\t\trequest: mergedRequestOptions as CallApiRequestOptionsForHooks,\n\t\t});\n\n\t\tconst fullURL = `${resolvedOptions.baseURL ?? \"\"}${mergeUrlWithParamsAndQuery(url, resolvedOptions.params, resolvedOptions.query)}`;\n\n\t\t// FIXME - Consider adding an option for refetching a callApi request\n\t\tconst options = {\n\t\t\t...resolvedOptions,\n\t\t\t...resolvedHooks,\n\t\t\tfullURL,\n\t\t\tinitURL: initURL.toString(),\n\t\t} satisfies CombinedCallApiExtraOptions as typeof mergedExtraOptions & 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 bodySerializer = options.bodySerializer ?? commonDefaults.bodySerializer;\n\n\t\tconst request = {\n\t\t\t...resolvedRequestOptions,\n\n\t\t\tbody: isSerializable(resolvedRequestOptions.body)\n\t\t\t\t? bodySerializer(resolvedRequestOptions.body)\n\t\t\t\t: resolvedRequestOptions.body,\n\n\t\t\theaders: await getHeaders({\n\t\t\t\tauth: options.auth,\n\t\t\t\tbaseHeaders: baseFetchOptions.headers,\n\t\t\t\tbody: resolvedRequestOptions.body,\n\t\t\t\theaders: fetchOptions.headers,\n\t\t\t}),\n\n\t\t\tsignal: combinedSignal,\n\t\t} satisfies CallApiRequestOptionsForHooks;\n\n\t\tconst {\n\t\t\tdedupeStrategy,\n\t\t\thandleRequestCancelStrategy,\n\t\t\thandleRequestDeferStrategy,\n\t\t\tremoveDedupeKeyFromCache,\n\t\t} = await createDedupeStrategy({\n\t\t\t$RequestInfoCache,\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tnewFetchController,\n\t\t\toptions,\n\t\t\trequest,\n\t\t});\n\n\t\tawait handleRequestCancelStrategy();\n\n\t\ttry {\n\t\t\tawait executeHooksInTryBlock(options.onRequest?.({ baseConfig, config, options, request }));\n\n\t\t\t// == Apply determined headers again after onRequest incase they were modified\n\t\t\trequest.headers = await getHeaders({\n\t\t\t\tauth: options.auth,\n\t\t\t\tbody: request.body,\n\t\t\t\theaders: request.headers,\n\t\t\t});\n\n\t\t\tconst response = await handleRequestDeferStrategy();\n\n\t\t\t// == Also clone response when dedupeStrategy is set to \"defer\" or when onRequestStream is set, to avoid error thrown from reading response.(whatever) more than once\n\n\t\t\tconst shouldCloneResponse = dedupeStrategy === \"defer\" || options.cloneResponse;\n\n\t\t\tconst schemas = (\n\t\t\t\tisFunction(options.schemas)\n\t\t\t\t\t? options.schemas({ baseSchemas: baseExtraOptions.schemas })\n\t\t\t\t\t: options.schemas\n\t\t\t) as CallApiSchemas | undefined;\n\n\t\t\tconst validators = isFunction(options.validators)\n\t\t\t\t? options.validators({ baseValidators: baseExtraOptions.validators })\n\t\t\t\t: options.validators;\n\n\t\t\tif (!response.ok) {\n\t\t\t\tconst errorData = await resolveResponseData<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);\n\n\t\t\t\tconst validErrorData = await handleValidation(\n\t\t\t\t\terrorData,\n\t\t\t\t\tschemas?.errorData,\n\t\t\t\t\tvalidators?.errorData\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: validErrorData,\n\t\t\t\t\tresponse,\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tconst successData = await resolveResponseData<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);\n\n\t\t\tconst validSuccessData = await handleValidation(successData, schemas?.data, validators?.data);\n\n\t\t\tconst successContext = {\n\t\t\t\tbaseConfig,\n\t\t\t\tconfig,\n\t\t\t\tdata: validSuccessData,\n\t\t\t\toptions,\n\t\t\t\trequest,\n\t\t\t\tresponse,\n\t\t\t} satisfies SuccessContext<unknown>;\n\n\t\t\tawait executeHooksInTryBlock(\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\tconst successResult = await resolveSuccessResult(successContext.data, {\n\t\t\t\tresponse: successContext.response,\n\t\t\t\tresultMode: options.resultMode,\n\t\t\t});\n\n\t\t\treturn successResult as never;\n\n\t\t\t// == Exhaustive Error handling\n\t\t} catch (error) {\n\t\t\tconst errorInfo = {\n\t\t\t\tcloneResponse: options.cloneResponse,\n\t\t\t\tdefaultErrorMessage: options.defaultErrorMessage,\n\t\t\t\tresultMode: options.resultMode,\n\t\t\t} satisfies ErrorInfo;\n\n\t\t\tconst generalErrorResult = resolveErrorResult(error, errorInfo);\n\n\t\t\tconst errorContext = {\n\t\t\t\tbaseConfig,\n\t\t\t\tconfig,\n\t\t\t\terror: generalErrorResult?.error as never,\n\t\t\t\toptions,\n\t\t\t\trequest,\n\t\t\t\tresponse: generalErrorResult?.response as never,\n\t\t\t} satisfies ErrorContext<unknown>;\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\tconst executeHooksInCatchBlock = createExecuteHooksFn({ errorInfo, shouldThrowOnError });\n\n\t\t\tconst handleRetryOrGetErrorResult = async () => {\n\t\t\t\tconst { currentAttemptCount, getDelay, shouldAttemptRetry } =\n\t\t\t\t\tcreateRetryStrategy(errorContext);\n\n\t\t\t\tconst shouldRetry = !combinedSignal.aborted && (await shouldAttemptRetry());\n\n\t\t\t\tif (shouldRetry) {\n\t\t\t\t\tconst retryContext = {\n\t\t\t\t\t\t...errorContext,\n\t\t\t\t\t\tretryAttemptCount: currentAttemptCount,\n\t\t\t\t\t} satisfies RetryContext<unknown>;\n\n\t\t\t\t\tconst hookError = await executeHooksInCatchBlock(options.onRetry?.(retryContext));\n\n\t\t\t\t\tif (hookError) {\n\t\t\t\t\t\treturn hookError;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst delay = getDelay();\n\n\t\t\t\t\tawait waitUntil(delay);\n\n\t\t\t\t\tconst updatedOptions = {\n\t\t\t\t\t\t...config,\n\t\t\t\t\t\t\"~retryAttemptCount\": currentAttemptCount + 1,\n\t\t\t\t\t} satisfies typeof config;\n\n\t\t\t\t\treturn callApi(initURL, updatedOptions as never) as never;\n\t\t\t\t}\n\n\t\t\t\tif (shouldThrowOnError) {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\n\t\t\t\treturn generalErrorResult;\n\t\t\t};\n\n\t\t\tif (isHTTPErrorInstance<TErrorData>(error)) {\n\t\t\t\tconst hookError = await executeHooksInCatchBlock(\n\t\t\t\t\toptions.onResponseError?.(errorContext),\n\n\t\t\t\t\toptions.onError?.(errorContext),\n\n\t\t\t\t\toptions.onResponse?.({ ...errorContext, data: null })\n\t\t\t\t);\n\n\t\t\t\t// eslint-disable-next-line max-depth -- Allow for now\n\t\t\t\tif (hookError) {\n\t\t\t\t\treturn hookError as never;\n\t\t\t\t}\n\n\t\t\t\treturn (await handleRetryOrGetErrorResult()) as never;\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\t!shouldThrowOnError && console.error(`${name}:`, message);\n\n\t\t\t\treturn (await handleRetryOrGetErrorResult()) as never;\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\t!shouldThrowOnError && console.error(`${error.name}:`, message);\n\n\t\t\t\tconst errorResult = await handleRetryOrGetErrorResult();\n\n\t\t\t\treturn getCustomizedErrorResult(errorResult, { message }) as never;\n\t\t\t}\n\n\t\t\tconst hookError = await executeHooksInCatchBlock(\n\t\t\t\t// == At this point only the request errors exist, so the request error hook is called\n\t\t\t\toptions.onRequestError?.(errorContext),\n\n\t\t\t\t// == Also call the onError hook\n\t\t\t\toptions.onError?.(errorContext)\n\t\t\t);\n\n\t\t\tif (hookError) {\n\t\t\t\treturn hookError as never;\n\t\t\t}\n\n\t\t\treturn (await handleRetryOrGetErrorResult()) as never;\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\treturn callApi;\n};\n\nexport const callApi = createFetchClient();\n","import type { CallApiPlugin } from \"./plugins\";\nimport type { ResponseTypeUnion, ResultModeUnion } from \"./result\";\nimport type { CallApiParameters } from \"./types\";\nimport type { DefaultMoreOptions, DefaultPluginArray, DefaultThrowOnError } from \"./types/default-types\";\nimport type { CallApiSchemas } from \"./validation\";\n\nconst defineParameters = <\n\tTData = unknown,\n\tTErrorData = unknown,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n>(\n\t...parameters: CallApiParameters<\n\t\tTData,\n\t\tTErrorData,\n\t\tTResultMode,\n\t\tTThrowOnError,\n\t\tTResponseType,\n\t\tTPluginArray,\n\t\tTSchemas\n\t>\n) => {\n\treturn parameters;\n};\n\nexport { defineParameters };\n"]}
|
1
|
+
{"version":3,"sources":["../../src/result.ts","../../src/hooks.ts","../../src/stream.ts","../../src/dedupe.ts","../../src/plugins.ts","../../src/retry.ts","../../src/url.ts","../../src/validation.ts","../../src/createFetchClient.ts","../../src/defineParameters.ts"],"names":["callApi","hookError"],"mappings":"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","file":"index.js","sourcesContent":["import { commonDefaults, responseDefaults } from \"./constants/default-options\";\nimport type { HTTPError } from \"./error\";\nimport type { CallApiExtraOptions } from \"./types\";\nimport type { DefaultDataType } from \"./types/default-types\";\nimport { isHTTPErrorInstance } from \"./utils/guards\";\nimport type { Awaitable, Prettify, UnmaskType } from \"./utils/type-helpers\";\n\ntype Parser = (responseString: string) => Awaitable<Record<string, unknown>>;\n\nexport const getResponseType = <TResponse>(response: Response, parser: Parser) => ({\n\tarrayBuffer: () => response.arrayBuffer(),\n\tblob: () => response.blob(),\n\tformData: () => response.formData(),\n\tjson: async () => {\n\t\tconst text = await response.text();\n\t\treturn parser(text) as TResponse;\n\t},\n\tstream: () => response.body,\n\ttext: () => response.text(),\n});\n\ntype InitResponseTypeMap<TResponse = unknown> = ReturnType<typeof getResponseType<TResponse>>;\n\nexport type ResponseTypeUnion = keyof InitResponseTypeMap | null;\n\nexport type ResponseTypeMap<TResponse> = {\n\t[Key in keyof InitResponseTypeMap<TResponse>]: Awaited<ReturnType<InitResponseTypeMap<TResponse>[Key]>>;\n};\n\nexport type GetResponseType<\n\tTResponse,\n\tTResponseType extends ResponseTypeUnion,\n\tTComputedResponseTypeMap extends ResponseTypeMap<TResponse> = ResponseTypeMap<TResponse>,\n> = null extends TResponseType\n\t? TComputedResponseTypeMap[\"json\"]\n\t: TResponseType extends NonNullable<ResponseTypeUnion>\n\t\t? TComputedResponseTypeMap[TResponseType]\n\t\t: never;\n\nexport const resolveResponseData = <TResponse>(\n\tresponse: Response,\n\tresponseType?: ResponseTypeUnion,\n\tparser?: Parser\n) => {\n\tconst selectedParser = parser ?? responseDefaults.responseParser;\n\tconst selectedResponseType = responseType ?? responseDefaults.responseType;\n\n\tconst RESPONSE_TYPE_LOOKUP = getResponseType<TResponse>(response, selectedParser);\n\n\tif (!Object.hasOwn(RESPONSE_TYPE_LOOKUP, selectedResponseType)) {\n\t\tthrow new Error(`Invalid response type: ${responseType}`);\n\t}\n\n\treturn RESPONSE_TYPE_LOOKUP[selectedResponseType]();\n};\n\nexport type CallApiResultSuccessVariant<TData> = {\n\tdata: TData;\n\terror: null;\n\tresponse: Response;\n};\n\nexport type PossibleJavaScriptError = UnmaskType<{\n\terrorData: DOMException | Error | SyntaxError | TypeError;\n\tmessage: string;\n\tname: \"AbortError\" | \"Error\" | \"SyntaxError\" | \"TimeoutError\" | \"TypeError\" | (`${string}Error` & {});\n\toriginalError: DOMException | Error | SyntaxError | TypeError;\n}>;\n\nexport type PossibleHTTPError<TErrorData> = Prettify<\n\tUnmaskType<{\n\t\terrorData: TErrorData;\n\t\tmessage: string;\n\t\tname: \"HTTPError\";\n\t\toriginalError: HTTPError;\n\t}>\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<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTComputedData = GetResponseType<TData, TResponseType>,\n\tTComputedErrorData = GetResponseType<TErrorData, TResponseType>,\n> = UnmaskType<{\n\t/* eslint-disable perfectionist/sort-union-types -- I need the first one to be first */\n\tall: CallApiResultSuccessVariant<TComputedData> | CallApiResultErrorVariant<TComputedErrorData>;\n\n\tallWithException: CallApiResultSuccessVariant<TComputedData>;\n\n\tonlySuccess:\n\t\t| CallApiResultErrorVariant<TComputedErrorData>[\"data\"]\n\t\t| CallApiResultSuccessVariant<TComputedData>[\"data\"];\n\n\tonlySuccessWithException: CallApiResultSuccessVariant<TComputedData>[\"data\"];\n\t/* eslint-enable perfectionist/sort-union-types -- I need the first one to be first */\n}>;\n\nexport type ResultModeUnion = keyof ResultModeMap | null;\n\nexport type GetCallApiResult<\n\tTData,\n\tTErrorData,\n\tTResultMode extends ResultModeUnion,\n\tTThrowOnError extends boolean,\n\tTResponseType extends ResponseTypeUnion,\n> = TErrorData extends false | undefined\n\t? ResultModeMap<TData, TErrorData, TResponseType>[\"onlySuccessWithException\"]\n\t: null extends TResultMode\n\t\t? TThrowOnError extends true\n\t\t\t? ResultModeMap<TData, TErrorData, TResponseType>[\"allWithException\"]\n\t\t\t: ResultModeMap<TData, TErrorData, TResponseType>[\"all\"]\n\t\t: TResultMode extends NonNullable<ResultModeUnion>\n\t\t\t? ResultModeMap<TData, TErrorData, TResponseType>[TResultMode]\n\t\t\t: never;\n\ntype SuccessInfo = {\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 = (data: unknown, info: SuccessInfo) => {\n\tconst { response, resultMode } = info;\n\n\tconst details = {\n\t\tdata,\n\t\terror: null,\n\t\tresponse,\n\t} satisfies CallApiResultSuccessVariant<unknown>;\n\n\tconst resultModeMap = {\n\t\tall: details,\n\t\tallWithException: details,\n\t\tonlySuccess: details.data,\n\t\tonlySuccessWithException: details.data,\n\t} satisfies ResultModeMap;\n\n\tconst successResult = resultModeMap[resultMode ?? \"all\"];\n\n\treturn successResult;\n};\n\n// export const resolveErrorResultAndContextForHooks = (info: ErrorInfo) => {\n// \tconst { baseConfig, config, error, message: customErrorMessage, options, request } = info;\n\n// \tconst errorContext = {\n// \t\tbaseConfig,\n// \t\tconfig,\n// \t\terror: errorResult?.error as never,\n// \t\toptions,\n// \t\trequest,\n// \t\tresponse: errorResult?.response as never,\n// \t} satisfies ErrorContext<unknown>;\n\n// \tconst shouldThrowOnError = isFunction(options.throwOnError)\n// \t\t? options.throwOnError(errorContext)\n// \t\t: options.throwOnError;\n\n// \tconst executeHooksInCatchBlock = async (...hookResults: Array<Awaitable<unknown>>) => {\n// \t\ttry {\n// \t\t\tawait Promise.all(hookResults);\n\n// \t\t\treturn null;\n// \t\t} catch (hookError) {\n// \t\t\tif (shouldThrowOnError) {\n// \t\t\t\tthrow hookError;\n// \t\t\t}\n\n// \t\t\tconst { errorResult: hookErrorResult } = resolveErrorResult({ ...info, error: hookError });\n\n// \t\t\treturn hookErrorResult;\n// \t\t}\n// \t};\n\n// \treturn { errorContext, errorResult, executeHooksInCatchBlock, shouldThrowOnError };\n// };\n\nexport type ErrorInfo = {\n\tcloneResponse: CallApiExtraOptions[\"cloneResponse\"];\n\tdefaultErrorMessage: CallApiExtraOptions[\"defaultErrorMessage\"];\n\tmessage?: string;\n\tresultMode: CallApiExtraOptions[\"resultMode\"];\n};\n\ntype ErrorResult = CallApiResultErrorVariant<unknown> | null;\n\nexport const resolveErrorResult = (error: unknown, info: ErrorInfo): ErrorResult => {\n\tconst { cloneResponse, defaultErrorMessage, message: customErrorMessage, resultMode } = info;\n\n\tlet details = {\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 PossibleJavaScriptError[\"name\"],\n\t\t\toriginalError: error as Error,\n\t\t},\n\t\tresponse: null,\n\t} satisfies CallApiResultErrorVariant<unknown> as CallApiResultErrorVariant<unknown>;\n\n\tif (isHTTPErrorInstance<never>(error)) {\n\t\tconst selectedDefaultErrorMessage = defaultErrorMessage ?? commonDefaults.defaultErrorMessage;\n\n\t\tconst { errorData, message = selectedDefaultErrorMessage, name, response } = error;\n\n\t\tdetails = {\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\toriginalError: error,\n\t\t\t},\n\t\t\tresponse: cloneResponse ? response.clone() : response,\n\t\t};\n\t}\n\n\tconst resultModeMap = {\n\t\tall: details,\n\t\tallWithException: details as never,\n\t\tonlySuccess: details.data,\n\t\tonlySuccessWithException: details.data,\n\t} satisfies ResultModeMap;\n\n\tconst errorResult = resultModeMap[resultMode ?? \"all\"];\n\n\treturn errorResult;\n};\n\nexport const getCustomizedErrorResult = (\n\terrorResult: ErrorResult,\n\tcustomErrorInfo: { message: string }\n): ErrorResult => {\n\tif (!errorResult) {\n\t\treturn null;\n\t}\n\n\tconst { message = errorResult.error.message } = customErrorInfo;\n\n\treturn {\n\t\t...errorResult,\n\t\terror: {\n\t\t\t...errorResult.error,\n\t\t\tmessage,\n\t\t} satisfies NonNullable<ErrorResult>[\"error\"] as never,\n\t};\n};\n","import {\n\ttype ErrorInfo,\n\ttype PossibleHTTPError,\n\ttype PossibleJavaScriptError,\n\tresolveErrorResult,\n} from \"./result\";\nimport type { StreamProgressEvent } from \"./stream\";\nimport type {\n\tBaseCallApiExtraOptions,\n\tCallApiExtraOptions,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n\tCombinedCallApiExtraOptions,\n} from \"./types/common\";\nimport type { DefaultDataType, DefaultMoreOptions } from \"./types/default-types\";\nimport type { AnyFunction, Awaitable, Prettify, UnmaskType } from \"./utils/type-helpers\";\n\nexport type WithMoreOptions<TMoreOptions = DefaultMoreOptions> = {\n\toptions: CombinedCallApiExtraOptions & Partial<TMoreOptions>;\n};\n\nexport type Hooks<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTMoreOptions = DefaultMoreOptions,\n> = {\n\t/**\n\t * Hook 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` hooks\n\t */\n\tonError?: (context: ErrorContext<TErrorData> & WithMoreOptions<TMoreOptions>) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called just before the request is made, allowing for modifications or additional operations.\n\t */\n\tonRequest?: (context: Prettify<RequestContext & WithMoreOptions<TMoreOptions>>) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when an error occurs during the fetch request.\n\t */\n\tonRequestError?: (\n\t\tcontext: Prettify<RequestErrorContext & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when upload stream progress is tracked\n\t */\n\tonRequestStream?: (\n\t\tcontext: Prettify<RequestStreamContext & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * Hook 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 * Hook that will be called when an error response is received from the api.\n\t */\n\tonResponseError?: (\n\t\tcontext: Prettify<ResponseErrorContext<TErrorData> & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when download stream progress is tracked\n\t */\n\tonResponseStream?: (\n\t\tcontext: Prettify<ResponseStreamContext & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when a request is retried.\n\t */\n\tonRetry?: (response: RetryContext<TErrorData> & WithMoreOptions<TMoreOptions>) => Awaitable<unknown>;\n\n\t/**\n\t * Hook that will be called when a successful response is received from the api.\n\t */\n\tonSuccess?: (\n\t\tcontext: Prettify<SuccessContext<TData> & WithMoreOptions<TMoreOptions>>\n\t) => Awaitable<unknown>;\n};\n\nexport type HooksOrHooksArray<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTMoreOptions = DefaultMoreOptions,\n> = {\n\t[Key in keyof Hooks<TData, TErrorData, TMoreOptions>]:\n\t\t| Hooks<TData, TErrorData, TMoreOptions>[Key]\n\t\t// eslint-disable-next-line perfectionist/sort-union-types -- I need arrays to be last\n\t\t| Array<Hooks<TData, TErrorData, TMoreOptions>[Key]>;\n};\n\nexport type SharedHookContext<TMoreOptions = DefaultMoreOptions> = {\n\t/**\n\t * Config object passed to createFetchClient\n\t */\n\tbaseConfig: BaseCallApiExtraOptions & CallApiRequestOptions;\n\t/**\n\t * Config object passed to the callApi instance\n\t */\n\tconfig: CallApiExtraOptions & CallApiRequestOptions;\n\t/**\n\t * Merged options consisting of extra options from createFetchClient, the callApi instance and default options.\n\t *\n\t */\n\toptions: CombinedCallApiExtraOptions & Partial<TMoreOptions>;\n\t/**\n\t * Merged request consisting of request options from createFetchClient, the callApi instance and default request options.\n\t */\n\trequest: CallApiRequestOptionsForHooks;\n};\n\nexport type RequestContext = UnmaskType<SharedHookContext>;\n\nexport type ResponseContext<TData, TErrorData> = UnmaskType<\n\t| Prettify<\n\t\t\tSharedHookContext & {\n\t\t\t\tdata: TData;\n\t\t\t\terror: null;\n\t\t\t\tresponse: Response;\n\t\t\t}\n\t >\n\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the first one to be first\n\t| Prettify<\n\t\t\tSharedHookContext & {\n\t\t\t\tdata: null;\n\t\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\t\tresponse: Response;\n\t\t\t}\n\t >\n>;\n\nexport type SuccessContext<TData> = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\tdata: TData;\n\t\t\tresponse: Response;\n\t\t}\n\t>\n>;\n\nexport type RequestErrorContext = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\terror: PossibleJavaScriptError;\n\t\t\tresponse: null;\n\t\t}\n\t>\n>;\n\nexport type ResponseErrorContext<TErrorData> = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\tresponse: Response;\n\t\t}\n\t>\n>;\n\nexport type RetryContext<TErrorData> = UnmaskType<\n\tPrettify<ErrorContext<TErrorData> & { retryAttemptCount: number }>\n>;\n\nexport type ErrorContext<TErrorData> = UnmaskType<\n\t| Prettify<\n\t\t\tSharedHookContext & {\n\t\t\t\terror: PossibleHTTPError<TErrorData>;\n\t\t\t\tresponse: Response;\n\t\t\t}\n\t >\n\t| Prettify<\n\t\t\tSharedHookContext & {\n\t\t\t\terror: PossibleJavaScriptError;\n\t\t\t\tresponse: null;\n\t\t\t}\n\t >\n>;\n\nexport type RequestStreamContext = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\tevent: StreamProgressEvent;\n\t\t\trequestInstance: Request;\n\t\t}\n\t>\n>;\n\nexport type ResponseStreamContext = UnmaskType<\n\tPrettify<\n\t\tSharedHookContext & {\n\t\t\tevent: StreamProgressEvent;\n\t\t\tresponse: Response;\n\t\t}\n\t>\n>;\n\ntype HookRegistries = {\n\t[Key in keyof Hooks]: Set<Hooks[Key]>;\n};\n\nexport const hookRegistries = {\n\tonError: new Set(),\n\tonRequest: new Set(),\n\tonRequestError: new Set(),\n\tonRequestStream: new Set(),\n\tonResponse: new Set(),\n\tonResponseError: new Set(),\n\tonResponseStream: new Set(),\n\tonRetry: new Set(),\n\tonSuccess: new Set(),\n} satisfies HookRegistries;\n\nexport const composeTwoHooks = (\n\thooks: Array<AnyFunction | undefined>,\n\tmergedHooksExecutionMode: CombinedCallApiExtraOptions[\"mergedHooksExecutionMode\"]\n) => {\n\tif (hooks.length === 0) return;\n\n\tconst mergedHook = 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\treturn mergedHook;\n};\n\nexport const executeHooksInTryBlock = async (...hookResults: Array<Awaitable<unknown>>) => {\n\tawait Promise.all(hookResults);\n};\n\ntype Info = {\n\terrorInfo: ErrorInfo;\n\tshouldThrowOnError: boolean | undefined;\n};\n\nexport const createExecuteHooksFn = (info: Info) => {\n\tconst { errorInfo, shouldThrowOnError } = info;\n\n\tconst executeHooksInCatchBlock = async (...hookResults: Array<Awaitable<unknown>>) => {\n\t\ttry {\n\t\t\tawait Promise.all(hookResults);\n\n\t\t\treturn null;\n\t\t} catch (hookError) {\n\t\t\tconst hookErrorResult = resolveErrorResult(hookError, errorInfo);\n\n\t\t\tif (shouldThrowOnError) {\n\t\t\t\tthrow hookError;\n\t\t\t}\n\n\t\t\treturn hookErrorResult;\n\t\t}\n\t};\n\n\treturn executeHooksInCatchBlock;\n};\n","import { type SharedHookContext, executeHooksInTryBlock } from \"./hooks\";\nimport { isObject } from \"./utils/guards\";\n\nexport type StreamProgressEvent = {\n\t/**\n\t * Current chunk of data being streamed\n\t */\n\tchunk: Uint8Array;\n\t/**\n\t * Progress in percentage\n\t */\n\tprogress: number;\n\t/**\n\t * Total size of data in bytes\n\t */\n\ttotalBytes: number;\n\t/**\n\t * Amount of data transferred so far\n\t */\n\ttransferredBytes: number;\n};\n\ndeclare global {\n\t// eslint-disable-next-line ts-eslint/consistent-type-definitions -- Allow\n\tinterface ReadableStream<R> {\n\t\t[Symbol.asyncIterator]: () => AsyncIterableIterator<R>;\n\t}\n}\n\nconst createProgressEvent = (options: {\n\tchunk: Uint8Array;\n\ttotalBytes: number;\n\ttransferredBytes: number;\n}): StreamProgressEvent => {\n\tconst { chunk, totalBytes, transferredBytes } = options;\n\n\treturn {\n\t\tchunk,\n\t\tprogress: Math.round((transferredBytes / totalBytes) * 100) || 0,\n\t\ttotalBytes,\n\t\ttransferredBytes,\n\t};\n};\n\nconst calculateTotalBytesFromBody = async (\n\trequestBody: Request[\"body\"] | null,\n\texistingTotalBytes: number\n) => {\n\tlet totalBytes = existingTotalBytes;\n\n\tif (!requestBody) {\n\t\treturn totalBytes;\n\t}\n\n\tfor await (const chunk of requestBody) {\n\t\ttotalBytes += chunk.byteLength;\n\t}\n\n\treturn totalBytes;\n};\n\ntype ToStreamableRequestContext = SharedHookContext & { requestInstance: Request };\n\nexport const toStreamableRequest = async (context: ToStreamableRequestContext) => {\n\tconst { baseConfig, config, options, request, requestInstance } = context;\n\n\tif (!options.onRequestStream || !requestInstance.body) return;\n\n\tconst contentLength =\n\t\trequestInstance.headers.get(\"content-length\")\n\t\t?? new Headers(request.headers as HeadersInit).get(\"content-length\")\n\t\t?? (request.body as Blob | null)?.size;\n\n\tlet totalBytes = Number(contentLength ?? 0);\n\n\tconst shouldForceContentLengthCalc = isObject(options.forceCalculateStreamSize)\n\t\t? options.forceCalculateStreamSize.request\n\t\t: options.forceCalculateStreamSize;\n\n\t// If no content length is present, we read the total bytes from the body\n\tif (!contentLength && shouldForceContentLengthCalc) {\n\t\ttotalBytes = await calculateTotalBytesFromBody(requestInstance.clone().body, totalBytes);\n\t}\n\n\tlet transferredBytes = 0;\n\n\tawait executeHooksInTryBlock(\n\t\toptions.onRequestStream({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tevent: createProgressEvent({ chunk: new Uint8Array(), totalBytes, transferredBytes }),\n\t\t\toptions,\n\t\t\trequest,\n\t\t\trequestInstance,\n\t\t})\n\t);\n\n\tconst body = requestInstance.body as ReadableStream<Uint8Array> | null;\n\n\tvoid new ReadableStream({\n\t\tstart: async (controller) => {\n\t\t\tif (!body) return;\n\n\t\t\tfor await (const chunk of body) {\n\t\t\t\ttransferredBytes += chunk.byteLength;\n\n\t\t\t\ttotalBytes = Math.max(totalBytes, transferredBytes);\n\n\t\t\t\tawait executeHooksInTryBlock(\n\t\t\t\t\toptions.onRequestStream?.({\n\t\t\t\t\t\tbaseConfig,\n\t\t\t\t\t\tconfig,\n\t\t\t\t\t\tevent: createProgressEvent({ chunk, totalBytes, transferredBytes }),\n\t\t\t\t\t\toptions,\n\t\t\t\t\t\trequest,\n\t\t\t\t\t\trequestInstance,\n\t\t\t\t\t})\n\t\t\t\t);\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t}\n\t\t\tcontroller.close();\n\t\t},\n\t});\n};\n\ntype StreamableResponseContext = SharedHookContext & { response: Response };\nexport const toStreamableResponse = async (context: StreamableResponseContext): Promise<Response> => {\n\tconst { baseConfig, config, options, request, response } = context;\n\n\tif (!options.onResponseStream || !response.body) {\n\t\treturn response;\n\t}\n\n\tconst contentLength = response.headers.get(\"content-length\");\n\n\tlet totalBytes = Number(contentLength ?? 0);\n\n\tconst shouldForceContentLengthCalc = isObject(options.forceCalculateStreamSize)\n\t\t? options.forceCalculateStreamSize.response\n\t\t: options.forceCalculateStreamSize;\n\n\t// If no content length is present and `forceContentLengthCalculation` is enabled, we read the total bytes from the body\n\tif (!contentLength && shouldForceContentLengthCalc) {\n\t\ttotalBytes = await calculateTotalBytesFromBody(response.clone().body, totalBytes);\n\t}\n\n\tlet transferredBytes = 0;\n\n\tawait executeHooksInTryBlock(\n\t\toptions.onResponseStream({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tevent: createProgressEvent({ chunk: new Uint8Array(), totalBytes, transferredBytes }),\n\t\t\toptions,\n\t\t\trequest,\n\t\t\tresponse,\n\t\t})\n\t);\n\n\tconst body = response.body as ReadableStream<Uint8Array> | null;\n\n\tconst stream = new ReadableStream({\n\t\tstart: async (controller) => {\n\t\t\tif (!body) return;\n\n\t\t\tfor await (const chunk of body) {\n\t\t\t\ttransferredBytes += chunk.byteLength;\n\n\t\t\t\ttotalBytes = Math.max(totalBytes, transferredBytes);\n\n\t\t\t\tawait executeHooksInTryBlock(\n\t\t\t\t\toptions.onResponseStream?.({\n\t\t\t\t\t\tbaseConfig,\n\t\t\t\t\t\tconfig,\n\t\t\t\t\t\tevent: createProgressEvent({ chunk, totalBytes, transferredBytes }),\n\t\t\t\t\t\toptions,\n\t\t\t\t\t\trequest,\n\t\t\t\t\t\tresponse,\n\t\t\t\t\t})\n\t\t\t\t);\n\n\t\t\t\tcontroller.enqueue(chunk);\n\t\t\t}\n\n\t\t\tcontroller.close();\n\t\t},\n\t});\n\n\treturn new Response(stream, response);\n};\n","import { dedupeDefaults, requestOptionDefaults } from \"./constants/default-options\";\nimport type { SharedHookContext } from \"./hooks\";\nimport { toStreamableRequest, toStreamableResponse } from \"./stream\";\nimport { getFetchImpl, waitUntil } from \"./utils/common\";\nimport { isReadableStream } from \"./utils/guards\";\n\ntype RequestInfo = {\n\tcontroller: AbortController;\n\tresponsePromise: Promise<Response>;\n};\n\nexport type RequestInfoCache = Map<string | null, RequestInfo>;\n\ntype DedupeContext = SharedHookContext & {\n\t$RequestInfoCache: RequestInfoCache;\n\tnewFetchController: AbortController;\n};\n\nexport const createDedupeStrategy = async (context: DedupeContext) => {\n\tconst { $RequestInfoCache, baseConfig, config, newFetchController, options, request } = context;\n\n\tconst dedupeStrategy = options.dedupeStrategy ?? dedupeDefaults.dedupeStrategy;\n\n\tconst generateDedupeKey = () => {\n\t\tconst shouldHaveDedupeKey = dedupeStrategy === \"cancel\" || 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 handleRequestCancelStrategy = () => {\n\t\tconst shouldCancelRequest = prevRequestInfo && dedupeStrategy === \"cancel\";\n\n\t\tif (!shouldCancelRequest) return;\n\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\n\t\t// == Adding this just so that eslint forces me put await when calling the function (it looks better that way tbh)\n\t\treturn Promise.resolve();\n\t};\n\n\tconst handleRequestDeferStrategy = async () => {\n\t\tconst fetchApi = getFetchImpl(options.customFetchImpl);\n\n\t\tconst shouldUsePromiseFromCache = prevRequestInfo && dedupeStrategy === \"defer\";\n\n\t\tconst requestInstance = new Request(\n\t\t\toptions.fullURL as NonNullable<typeof options.fullURL>,\n\t\t\t(isReadableStream(request.body) && !request.duplex\n\t\t\t\t? { ...request, duplex: \"half\" }\n\t\t\t\t: request) as RequestInit\n\t\t);\n\n\t\tawait toStreamableRequest({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\toptions,\n\t\t\trequest,\n\t\t\trequestInstance: requestInstance.clone(),\n\t\t});\n\n\t\tconst getFetchApiPromise = () => {\n\t\t\tif (isReadableStream(request.body)) {\n\t\t\t\treturn fetchApi(requestInstance.clone());\n\t\t\t}\n\n\t\t\tconst method = request.method ?? requestOptionDefaults.method;\n\n\t\t\tconst modifiedRequest = { ...request, method } as RequestInit;\n\n\t\t\treturn fetchApi(options.fullURL as NonNullable<typeof options.fullURL>, modifiedRequest);\n\t\t};\n\n\t\tconst responsePromise = shouldUsePromiseFromCache\n\t\t\t? prevRequestInfo.responsePromise\n\t\t\t: getFetchApiPromise();\n\n\t\t$RequestInfoCacheOrNull?.set(dedupeKey, { controller: newFetchController, responsePromise });\n\n\t\tconst streamableResponse = toStreamableResponse({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\toptions,\n\t\t\trequest,\n\t\t\tresponse: await responsePromise,\n\t\t});\n\n\t\treturn streamableResponse;\n\t};\n\n\tconst removeDedupeKeyFromCache = () => {\n\t\t$RequestInfoCacheOrNull?.delete(dedupeKey);\n\t};\n\n\treturn {\n\t\tdedupeStrategy,\n\t\thandleRequestCancelStrategy,\n\t\thandleRequestDeferStrategy,\n\t\tremoveDedupeKeyFromCache,\n\t};\n};\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\nimport { hookDefaults } from \"./constants/default-options\";\nimport {\n\ttype Hooks,\n\ttype HooksOrHooksArray,\n\ttype SharedHookContext,\n\tcomposeTwoHooks,\n\thookRegistries,\n} from \"./hooks\";\nimport type {\n\tBaseCallApiExtraOptions,\n\tCallApiExtraOptions,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n} from \"./types/common\";\nimport type { DefaultMoreOptions } from \"./types/default-types\";\nimport type { InitURL } from \"./url\";\nimport { isArray, isFunction, isPlainObject, isString } from \"./utils/guards\";\nimport type { AnyFunction, Awaitable, Prettify } from \"./utils/type-helpers\";\nimport type { InferSchemaResult } from \"./validation\";\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<\n\tTPluginArray extends CallApiPlugin[],\n\t// TCreateExtraOptions = ReturnType<NonNullable<TPluginArray[number][\"createExtraOptions\"]>>,\n> = UnionToIntersection<\n\tTPluginArray extends Array<infer TPlugin>\n\t\t? TPlugin extends CallApiPlugin\n\t\t\t? TPlugin[\"createExtraOptions\"] extends AnyFunction<infer TResult>\n\t\t\t\t? InferSchemaResult<TResult, TResult>\n\t\t\t\t: NonNullable<unknown>\n\t\t\t: NonNullable<unknown>\n\t\t: NonNullable<unknown>\n>;\n\nexport type PluginInitContext<TMoreOptions = DefaultMoreOptions> = Prettify<\n\tSharedHookContext<TMoreOptions> & { initURL: InitURL | undefined }\n>;\n\nexport type PluginInitResult = Partial<\n\tOmit<PluginInitContext, \"request\"> & { request: CallApiRequestOptions }\n>;\n\nexport type PluginHooksWithMoreOptions<TMoreOptions = DefaultMoreOptions> = HooksOrHooksArray<\n\tnever,\n\tnever,\n\tTMoreOptions\n>;\n\nexport type PluginHooks<\n\tTData = never,\n\tTErrorData = never,\n\tTMoreOptions = DefaultMoreOptions,\n> = HooksOrHooksArray<TData, TErrorData, TMoreOptions>;\n\nexport interface CallApiPlugin {\n\t/**\n\t * Defines additional options that can be passed to callApi\n\t */\n\tcreateExtraOptions?: (...params: never[]) => unknown;\n\n\t/**\n\t * A description for the plugin\n\t */\n\tdescription?: string;\n\n\t/**\n\t * Hooks / Interceptors for the plugin\n\t */\n\thooks?: PluginHooks;\n\n\t/**\n\t * A unique id for the plugin\n\t */\n\tid: string;\n\n\t/**\n\t * A function that will be called when the plugin is initialized. This will be called before the any of the other internal functions.\n\t */\n\tinit?: (context: PluginInitContext) => Awaitable<PluginInitResult> | Awaitable<void>;\n\n\t/**\n\t * A name for the plugin\n\t */\n\tname: string;\n\n\t/**\n\t * A version for the plugin\n\t */\n\tversion?: string;\n}\n\nexport const definePlugin = <\n\t// eslint-disable-next-line perfectionist/sort-union-types -- Let the first one be first\n\tTPlugin extends CallApiPlugin | AnyFunction<CallApiPlugin>,\n>(\n\tplugin: TPlugin\n) => {\n\treturn plugin;\n};\n\nexport type Plugins<TPluginArray extends CallApiPlugin[]> = TPluginArray;\n\nconst resolvePluginArray = (\n\tplugins: CallApiExtraOptions[\"plugins\"] | undefined,\n\tbasePlugins: BaseCallApiExtraOptions[\"plugins\"] | undefined\n) => {\n\tif (!plugins) {\n\t\treturn [];\n\t}\n\n\tif (isFunction(plugins)) {\n\t\treturn plugins({ basePlugins: basePlugins ?? [] });\n\t}\n\n\treturn plugins;\n};\n\nexport const initializePlugins = async (context: PluginInitContext) => {\n\tconst { baseConfig, config, initURL, options, request } = context;\n\n\tconst clonedHookRegistries = structuredClone(hookRegistries);\n\n\tconst addMainHooks = () => {\n\t\tfor (const key of Object.keys(clonedHookRegistries) as Array<keyof Hooks>) {\n\t\t\tconst baseHook = baseConfig[key];\n\t\t\tconst instanceHook = config[key];\n\n\t\t\tconst overriddenHook = options[key] as HooksOrHooksArray[typeof key];\n\n\t\t\t// If the base hook is an array and instance hook is defined, we need to compose it with the overridden hook\n\t\t\tconst mainHook =\n\t\t\t\tisArray(baseHook) && Boolean(instanceHook) ? [baseHook, instanceHook].flat() : overriddenHook;\n\n\t\t\tif (!mainHook) continue;\n\n\t\t\tclonedHookRegistries[key].add(mainHook as never);\n\t\t}\n\t};\n\n\tconst addPluginHooks = (pluginHooks: Required<CallApiPlugin>[\"hooks\"]) => {\n\t\tfor (const key of Object.keys(clonedHookRegistries) as Array<keyof Hooks>) {\n\t\t\tconst pluginHook = pluginHooks[key];\n\n\t\t\tif (!pluginHook) continue;\n\n\t\t\tclonedHookRegistries[key].add(pluginHook as never);\n\t\t}\n\t};\n\n\tconst mergedHooksExecutionOrder =\n\t\toptions.mergedHooksExecutionOrder ?? hookDefaults.mergedHooksExecutionOrder;\n\n\tif (mergedHooksExecutionOrder === \"mainHooksBeforePlugins\") {\n\t\taddMainHooks();\n\t}\n\n\tconst resolvedPlugins = resolvePluginArray(options.plugins, baseConfig.plugins);\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({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tinitURL,\n\t\t\toptions,\n\t\t\trequest,\n\t\t});\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 as CallApiRequestOptionsForHooks;\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 (mergedHooksExecutionOrder === \"mainHooksAfterPlugins\") {\n\t\taddMainHooks();\n\t}\n\n\tconst resolvedHooks: Hooks = {};\n\n\tfor (const [key, hookRegistry] of Object.entries(clonedHookRegistries)) {\n\t\tconst flattenedHookArray = [...hookRegistry].flat();\n\n\t\tconst mergedHooksExecutionMode =\n\t\t\toptions.mergedHooksExecutionMode ?? hookDefaults.mergedHooksExecutionMode;\n\n\t\tconst composedHook = composeTwoHooks(flattenedHookArray, mergedHooksExecutionMode);\n\n\t\tcomposedHook && (resolvedHooks[key as keyof Hooks] = composedHook);\n\t}\n\n\treturn {\n\t\tresolvedHooks,\n\t\tresolvedOptions,\n\t\tresolvedRequestOptions,\n\t\turl: resolvedUrl?.toString(),\n\t};\n};\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\nimport { requestOptionDefaults, retryDefaults } from \"./constants/default-options\";\nimport type { ErrorContext } from \"./hooks\";\nimport type { Method } from \"./types\";\nimport { isFunction, isHTTPError } from \"./utils/guards\";\nimport type { Awaitable } from \"./utils/type-helpers\";\n\ntype RetryCondition<TErrorData> = (context: ErrorContext<TErrorData>) => Awaitable<boolean>;\n\ntype InnerRetryKeys<TErrorData> = Exclude<keyof RetryOptions<TErrorData>, \"~retryAttemptCount\" | \"retry\">;\n\ntype InnerRetryOptions<TErrorData> = {\n\t[Key in InnerRetryKeys<TErrorData> as Key extends `retry${infer TRest}`\n\t\t? Uncapitalize<TRest> extends \"attempts\"\n\t\t\t? never\n\t\t\t: Uncapitalize<TRest>\n\t\t: Key]?: RetryOptions<TErrorData>[Key];\n} & {\n\tattempts: NonNullable<RetryOptions<TErrorData>[\"retryAttempts\"]>;\n};\n\nexport interface RetryOptions<TErrorData> {\n\t/**\n\t * 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 [\"~retryAttemptCount\"]?: number;\n\n\t/**\n\t * All retry options in a single object instead of separate properties\n\t */\n\tretry?: InnerRetryOptions<TErrorData>;\n\n\t/**\n\t * Number of allowed retry attempts on HTTP errors\n\t * @default 0\n\t */\n\tretryAttempts?: number;\n\n\t/**\n\t * Callback whose return value determines if a request should be retried or not\n\t */\n\tretryCondition?: RetryCondition<TErrorData>;\n\n\t/**\n\t * Delay between retries in milliseconds\n\t * @default 1000\n\t */\n\tretryDelay?: number | ((currentAttemptCount: number) => number);\n\n\t/**\n\t * 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?: Method[];\n\n\t/**\n\t * HTTP status codes that trigger a retry\n\t */\n\tretryStatusCodes?: number[];\n\n\t/**\n\t * Strategy to use when retrying\n\t * @default \"linear\"\n\t */\n\tretryStrategy?: \"exponential\" | \"linear\";\n}\n\nconst getLinearDelay = <TErrorData>(currentAttemptCount: number, options: RetryOptions<TErrorData>) => {\n\tconst retryDelay = options.retryDelay ?? options.retry?.delay;\n\n\tconst resolveRetryDelay =\n\t\t(isFunction(retryDelay) ? retryDelay(currentAttemptCount) : retryDelay) ?? retryDefaults.delay;\n\n\treturn resolveRetryDelay;\n};\n\nconst getExponentialDelay = <TErrorData>(\n\tcurrentAttemptCount: number,\n\toptions: RetryOptions<TErrorData>\n) => {\n\tconst retryDelay = options.retryDelay ?? options.retry?.delay ?? retryDefaults.delay;\n\n\tconst resolvedRetryDelay = Number(\n\t\tisFunction(retryDelay) ? retryDelay(currentAttemptCount) : retryDelay\n\t);\n\n\tconst maxDelay = Number(options.retryMaxDelay ?? options.retry?.maxDelay ?? retryDefaults.maxDelay);\n\n\tconst exponentialDelay = resolvedRetryDelay * 2 ** currentAttemptCount;\n\n\treturn Math.min(exponentialDelay, maxDelay);\n};\n\nexport const createRetryStrategy = <TErrorData>(ctx: ErrorContext<TErrorData>) => {\n\tconst { options } = ctx;\n\n\tconst currentAttemptCount = options[\"~retryAttemptCount\"] ?? 1;\n\n\tconst retryStrategy = options.retryStrategy ?? options.retry?.strategy ?? retryDefaults.strategy;\n\n\tconst getDelay = () => {\n\t\tswitch (retryStrategy) {\n\t\t\tcase \"exponential\": {\n\t\t\t\treturn getExponentialDelay(currentAttemptCount, options);\n\t\t\t}\n\t\t\tcase \"linear\": {\n\t\t\t\treturn getLinearDelay(currentAttemptCount, options);\n\t\t\t}\n\t\t\tdefault: {\n\t\t\t\tthrow new Error(`Invalid retry strategy: ${String(retryStrategy)}`);\n\t\t\t}\n\t\t}\n\t};\n\n\tconst shouldAttemptRetry = async () => {\n\t\tconst retryCondition = options.retryCondition ?? options.retry?.condition ?? retryDefaults.condition;\n\n\t\tconst maximumRetryAttempts =\n\t\t\toptions.retryAttempts ?? options.retry?.attempts ?? retryDefaults.attempts;\n\n\t\tconst customRetryCondition = await retryCondition(ctx);\n\n\t\tconst baseShouldRetry = maximumRetryAttempts >= currentAttemptCount && customRetryCondition;\n\n\t\tif (!baseShouldRetry) {\n\t\t\treturn false;\n\t\t}\n\n\t\t// == If error is not an HTTP error, just return true since at this point we know it's a retryable error\n\t\tif (!isHTTPError(ctx.error)) {\n\t\t\treturn true;\n\t\t}\n\n\t\tconst selectedMethodArray = options.retryMethods ?? options.retry?.methods ?? retryDefaults.methods;\n\n\t\tconst retryMethods = new Set(selectedMethodArray);\n\n\t\tconst method = ctx.request.method ?? requestOptionDefaults.method;\n\n\t\tconst includesMethod = Boolean(method) && retryMethods.has(method);\n\n\t\tconst selectedStatusCodeArray = options.retryStatusCodes ?? options.retry?.statusCodes;\n\n\t\tconst retryStatusCodes = selectedStatusCodeArray ? new Set(selectedStatusCodeArray) : null;\n\n\t\tconst includesStatusCodes =\n\t\t\tBoolean(ctx.response?.status) && (retryStatusCodes?.has(ctx.response.status) ?? true);\n\n\t\tconst shouldRetry = includesMethod && includesStatusCodes;\n\n\t\treturn shouldRetry;\n\t};\n\n\treturn {\n\t\tcurrentAttemptCount,\n\t\tgetDelay,\n\t\tshouldAttemptRetry,\n\t};\n};\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\nimport type { CallApiExtraOptions } from \"./types/common\";\nimport { toQueryString } from \"./utils\";\nimport { isArray } from \"./utils/guards\";\nimport type { UnmaskType } from \"./utils/type-helpers\";\nimport type { CallApiSchemas, InferSchemaResult } from \"./validation\";\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: CallApiExtraOptions[\"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 | undefined,\n\tparams: CallApiExtraOptions[\"params\"],\n\tquery: CallApiExtraOptions[\"query\"]\n) => {\n\tif (!url) return;\n\n\tconst urlWithMergedParams = mergeUrlWithParams(url, params);\n\n\treturn mergeUrlWithQuery(urlWithMergedParams, query);\n};\n\nexport type Params = UnmaskType<\n\t// eslint-disable-next-line perfectionist/sort-union-types -- I need the Record to be first\n\tRecord<string, boolean | number | string> | Array<boolean | number | string>\n>;\n\nexport type Query = UnmaskType<Record<string, boolean | number | string>>;\n\nexport type InitURL = UnmaskType<string | URL>;\n\nexport interface UrlOptions<TSchemas extends CallApiSchemas> {\n\t/**\n\t * URL to be used in the request.\n\t */\n\treadonly initURL?: string;\n\n\t/**\n\t * Parameters to be appended to the URL (i.e: /:id)\n\t */\n\tparams?: InferSchemaResult<TSchemas[\"params\"], Params>;\n\n\t/**\n\t * Query parameters to append to the URL.\n\t */\n\tquery?: InferSchemaResult<TSchemas[\"query\"], Query>;\n}\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\nimport type { Body, GlobalMeta, Headers, Method } from \"./types\";\nimport type { StandardSchemaV1 } from \"./types/standard-schema\";\nimport type { InitURL, Params, Query } from \"./url\";\n\nexport const standardSchemaParser = async <TSchema extends StandardSchemaV1>(\n\tschema: TSchema,\n\tinputData: StandardSchemaV1.InferInput<TSchema>\n): Promise<StandardSchemaV1.InferOutput<TSchema>> => {\n\tconst result = await schema[\"~standard\"].validate(inputData);\n\n\t// == If the `issues` field exists, it means the validation failed\n\tif (result.issues) {\n\t\tthrow new Error(JSON.stringify(result.issues, null, 2), { cause: result.issues });\n\t}\n\n\treturn result.value;\n};\n\nexport interface CallApiSchemas {\n\t/**\n\t * The schema to use for validating the request body.\n\t */\n\tbody?: StandardSchemaV1<Body>;\n\n\t/**\n\t * The schema to use for validating the response data.\n\t */\n\tdata?: StandardSchemaV1;\n\n\t/**\n\t * The schema to use for validating the response error data.\n\t */\n\terrorData?: StandardSchemaV1;\n\n\t/**\n\t * The schema to use for validating the request headers.\n\t */\n\theaders?: StandardSchemaV1<Headers>;\n\n\t/**\n\t * The schema to use for validating the request url.\n\t */\n\tinitURL?: StandardSchemaV1<InitURL>;\n\n\t/**\n\t * The schema to use for validating the meta option.\n\t */\n\tmeta?: StandardSchemaV1<GlobalMeta>;\n\n\t/**\n\t * The schema to use for validating the request method.\n\t */\n\tmethod?: StandardSchemaV1<Method>;\n\n\t/**\n\t * The schema to use for validating the request url parameter.\n\t */\n\tparams?: StandardSchemaV1<Params>;\n\n\t/**\n\t * The schema to use for validating the request url querys.\n\t */\n\tquery?: StandardSchemaV1<Query>;\n}\n\nexport interface CallApiValidators<TData = unknown, TErrorData = unknown> {\n\t/**\n\t * Custom function to validate the response data.\n\t */\n\tdata?: (value: unknown) => TData;\n\n\t/**\n\t * Custom function to validate the response error data, stemming from the api.\n\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 */\n\terrorData?: (value: unknown) => TErrorData;\n}\n\nexport type InferSchemaResult<TSchema, TData = NonNullable<unknown>> = TSchema extends StandardSchemaV1\n\t? StandardSchemaV1.InferOutput<TSchema>\n\t: TData;\n\nexport const handleValidation = async (\n\tresponseData: unknown,\n\tschema: CallApiSchemas[keyof NonNullable<CallApiSchemas>],\n\tvalidator?: CallApiValidators[keyof NonNullable<CallApiValidators>]\n) => {\n\tconst validResponseData = validator ? validator(responseData) : responseData;\n\n\tconst schemaValidResponseData = schema\n\t\t? await standardSchemaParser(schema, validResponseData)\n\t\t: validResponseData;\n\n\treturn schemaValidResponseData;\n};\n","import { commonDefaults } from \"./constants/default-options\";\nimport { type RequestInfoCache, createDedupeStrategy } from \"./dedupe\";\nimport { HTTPError } from \"./error\";\nimport {\n\ttype ErrorContext,\n\ttype RetryContext,\n\ttype SuccessContext,\n\tcreateExecuteHooksFn,\n\texecuteHooksInTryBlock,\n} from \"./hooks\";\nimport { type CallApiPlugin, initializePlugins } from \"./plugins\";\nimport {\n\ttype ErrorInfo,\n\ttype ResponseTypeUnion,\n\ttype ResultModeUnion,\n\tgetCustomizedErrorResult,\n\tresolveErrorResult,\n\tresolveResponseData,\n\tresolveSuccessResult,\n} from \"./result\";\nimport { createRetryStrategy } from \"./retry\";\nimport type {\n\tBaseCallApiConfig,\n\tBaseCallApiExtraOptions,\n\tCallApiExtraOptions,\n\tCallApiParameters,\n\tCallApiRequestOptions,\n\tCallApiRequestOptionsForHooks,\n\tCallApiResult,\n\tCombinedCallApiExtraOptions,\n} from \"./types/common\";\nimport type {\n\tDefaultDataType,\n\tDefaultMoreOptions,\n\tDefaultPluginArray,\n\tDefaultThrowOnError,\n} from \"./types/default-types\";\nimport { mergeUrlWithParamsAndQuery } from \"./url\";\nimport {\n\tcreateCombinedSignal,\n\tcreateTimeoutSignal,\n\tgetHeaders,\n\tsplitBaseConfig,\n\tsplitConfig,\n\twaitUntil,\n} from \"./utils/common\";\nimport { isFunction, isHTTPErrorInstance, isSerializable } from \"./utils/guards\";\nimport { type CallApiSchemas, type InferSchemaResult, handleValidation } from \"./validation\";\n\nexport const createFetchClient = <\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBaseThrowOnError extends boolean = DefaultThrowOnError,\n\tTBaseResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTBasePluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTBaseSchemas extends CallApiSchemas = DefaultMoreOptions,\n>(\n\tinitBaseConfig: BaseCallApiConfig<\n\t\tTBaseData,\n\t\tTBaseErrorData,\n\t\tTBaseResultMode,\n\t\tTBaseThrowOnError,\n\t\tTBaseResponseType,\n\t\tTBasePluginArray,\n\t\tTBaseSchemas\n\t> = {} as never\n) => {\n\tconst $RequestInfoCache: RequestInfoCache = new Map();\n\n\tconst callApi = async <\n\t\tTData = InferSchemaResult<TBaseSchemas[\"data\"], TBaseData>,\n\t\tTErrorData = InferSchemaResult<TBaseSchemas[\"errorData\"], TBaseErrorData>,\n\t\tTResultMode extends ResultModeUnion = TBaseResultMode,\n\t\tTThrowOnError extends boolean = TBaseThrowOnError,\n\t\tTResponseType extends ResponseTypeUnion = TBaseResponseType,\n\t\tTPluginArray extends CallApiPlugin[] = TBasePluginArray,\n\t\tTSchemas extends CallApiSchemas = TBaseSchemas,\n\t>(\n\t\t...parameters: CallApiParameters<\n\t\t\tTData,\n\t\t\tTErrorData,\n\t\t\tTResultMode,\n\t\t\tTThrowOnError,\n\t\t\tTResponseType,\n\t\t\tTPluginArray,\n\t\t\tTSchemas\n\t\t>\n\t): CallApiResult<\n\t\tInferSchemaResult<TSchemas[\"data\"], TData>,\n\t\tInferSchemaResult<TSchemas[\"errorData\"], TErrorData>,\n\t\tTResultMode,\n\t\tTThrowOnError,\n\t\tTResponseType\n\t> => {\n\t\tconst [initURL, initConfig = {}] = parameters;\n\n\t\tconst [fetchOptions, extraOptions] = splitConfig(initConfig);\n\n\t\tconst resolvedBaseConfig = isFunction(initBaseConfig)\n\t\t\t? initBaseConfig({ initURL: initURL.toString(), options: extraOptions, request: fetchOptions })\n\t\t\t: initBaseConfig;\n\n\t\tconst [baseFetchOptions, baseExtraOptions] = splitBaseConfig(resolvedBaseConfig);\n\n\t\t// == Merged Extra Options\n\t\tconst mergedExtraOptions = {\n\t\t\t...baseExtraOptions,\n\t\t\t...(baseExtraOptions.skipAutoMergeFor !== \"all\"\n\t\t\t\t&& baseExtraOptions.skipAutoMergeFor !== \"options\"\n\t\t\t\t&& extraOptions),\n\t\t};\n\n\t\t// == Merged Request Options\n\t\tconst mergedRequestOptions = {\n\t\t\t...baseFetchOptions,\n\t\t\t...(baseExtraOptions.skipAutoMergeFor !== \"all\"\n\t\t\t\t&& baseExtraOptions.skipAutoMergeFor !== \"request\"\n\t\t\t\t&& fetchOptions),\n\t\t} satisfies CallApiRequestOptions;\n\n\t\tconst baseConfig = resolvedBaseConfig as BaseCallApiExtraOptions & CallApiRequestOptions;\n\t\tconst config = initConfig as CallApiExtraOptions & CallApiRequestOptions;\n\n\t\tconst { resolvedHooks, resolvedOptions, resolvedRequestOptions, url } = await initializePlugins({\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tinitURL,\n\t\t\toptions: mergedExtraOptions as CombinedCallApiExtraOptions,\n\t\t\trequest: mergedRequestOptions as CallApiRequestOptionsForHooks,\n\t\t});\n\n\t\tconst fullURL = `${resolvedOptions.baseURL ?? \"\"}${mergeUrlWithParamsAndQuery(url, resolvedOptions.params, resolvedOptions.query)}`;\n\n\t\t// FIXME - Consider adding an option for refetching a callApi request\n\t\tconst options = {\n\t\t\t...resolvedOptions,\n\t\t\t...resolvedHooks,\n\t\t\tfullURL,\n\t\t\tinitURL: initURL.toString(),\n\t\t} satisfies CombinedCallApiExtraOptions as typeof mergedExtraOptions & 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 bodySerializer = options.bodySerializer ?? commonDefaults.bodySerializer;\n\n\t\tconst request = {\n\t\t\t...resolvedRequestOptions,\n\n\t\t\tbody: isSerializable(resolvedRequestOptions.body)\n\t\t\t\t? bodySerializer(resolvedRequestOptions.body)\n\t\t\t\t: resolvedRequestOptions.body,\n\n\t\t\theaders: await getHeaders({\n\t\t\t\tauth: options.auth,\n\t\t\t\tbaseHeaders: baseFetchOptions.headers,\n\t\t\t\tbody: resolvedRequestOptions.body,\n\t\t\t\theaders: fetchOptions.headers,\n\t\t\t}),\n\n\t\t\tsignal: combinedSignal,\n\t\t} satisfies CallApiRequestOptionsForHooks;\n\n\t\tconst {\n\t\t\tdedupeStrategy,\n\t\t\thandleRequestCancelStrategy,\n\t\t\thandleRequestDeferStrategy,\n\t\t\tremoveDedupeKeyFromCache,\n\t\t} = await createDedupeStrategy({\n\t\t\t$RequestInfoCache,\n\t\t\tbaseConfig,\n\t\t\tconfig,\n\t\t\tnewFetchController,\n\t\t\toptions,\n\t\t\trequest,\n\t\t});\n\n\t\tawait handleRequestCancelStrategy();\n\n\t\ttry {\n\t\t\tawait executeHooksInTryBlock(options.onRequest?.({ baseConfig, config, options, request }));\n\n\t\t\t// == Apply determined headers again after onRequest incase they were modified\n\t\t\trequest.headers = await getHeaders({\n\t\t\t\tauth: options.auth,\n\t\t\t\tbody: request.body,\n\t\t\t\theaders: request.headers,\n\t\t\t});\n\n\t\t\tconst response = await handleRequestDeferStrategy();\n\n\t\t\t// == Also clone response when dedupeStrategy is set to \"defer\" or when onRequestStream is set, to avoid error thrown from reading response.(whatever) more than once\n\n\t\t\tconst shouldCloneResponse = dedupeStrategy === \"defer\" || options.cloneResponse;\n\n\t\t\tconst schemas = (\n\t\t\t\tisFunction(options.schemas)\n\t\t\t\t\t? options.schemas({ baseSchemas: baseExtraOptions.schemas })\n\t\t\t\t\t: options.schemas\n\t\t\t) as CallApiSchemas | undefined;\n\n\t\t\tconst validators = isFunction(options.validators)\n\t\t\t\t? options.validators({ baseValidators: baseExtraOptions.validators })\n\t\t\t\t: options.validators;\n\n\t\t\tif (!response.ok) {\n\t\t\t\tconst errorData = await resolveResponseData<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);\n\n\t\t\t\tconst validErrorData = await handleValidation(\n\t\t\t\t\terrorData,\n\t\t\t\t\tschemas?.errorData,\n\t\t\t\t\tvalidators?.errorData\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\t{\n\t\t\t\t\t\tdefaultErrorMessage: options.defaultErrorMessage,\n\t\t\t\t\t\terrorData: validErrorData,\n\t\t\t\t\t\tresponse,\n\t\t\t\t\t},\n\t\t\t\t\t{ cause: validErrorData }\n\t\t\t\t);\n\t\t\t}\n\n\t\t\tconst successData = await resolveResponseData<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);\n\n\t\t\tconst validSuccessData = await handleValidation(successData, schemas?.data, validators?.data);\n\n\t\t\tconst successContext = {\n\t\t\t\tbaseConfig,\n\t\t\t\tconfig,\n\t\t\t\tdata: validSuccessData,\n\t\t\t\toptions,\n\t\t\t\trequest,\n\t\t\t\tresponse,\n\t\t\t} satisfies SuccessContext<unknown>;\n\n\t\t\tawait executeHooksInTryBlock(\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\tconst successResult = await resolveSuccessResult(successContext.data, {\n\t\t\t\tresponse: successContext.response,\n\t\t\t\tresultMode: options.resultMode,\n\t\t\t});\n\n\t\t\treturn successResult as never;\n\n\t\t\t// == Exhaustive Error handling\n\t\t} catch (error) {\n\t\t\tconst errorInfo = {\n\t\t\t\tcloneResponse: options.cloneResponse,\n\t\t\t\tdefaultErrorMessage: options.defaultErrorMessage,\n\t\t\t\tresultMode: options.resultMode,\n\t\t\t} satisfies ErrorInfo;\n\n\t\t\tconst generalErrorResult = resolveErrorResult(error, errorInfo);\n\n\t\t\tconst errorContext = {\n\t\t\t\tbaseConfig,\n\t\t\t\tconfig,\n\t\t\t\terror: generalErrorResult?.error as never,\n\t\t\t\toptions,\n\t\t\t\trequest,\n\t\t\t\tresponse: generalErrorResult?.response as never,\n\t\t\t} satisfies ErrorContext<unknown>;\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\tconst executeHooksInCatchBlock = createExecuteHooksFn({ errorInfo, shouldThrowOnError });\n\n\t\t\tconst handleRetryOrGetErrorResult = async () => {\n\t\t\t\tconst { currentAttemptCount, getDelay, shouldAttemptRetry } =\n\t\t\t\t\tcreateRetryStrategy(errorContext);\n\n\t\t\t\tconst shouldRetry = !combinedSignal.aborted && (await shouldAttemptRetry());\n\n\t\t\t\tif (shouldRetry) {\n\t\t\t\t\tconst retryContext = {\n\t\t\t\t\t\t...errorContext,\n\t\t\t\t\t\tretryAttemptCount: currentAttemptCount,\n\t\t\t\t\t} satisfies RetryContext<unknown>;\n\n\t\t\t\t\tconst hookError = await executeHooksInCatchBlock(options.onRetry?.(retryContext));\n\n\t\t\t\t\tif (hookError) {\n\t\t\t\t\t\treturn hookError;\n\t\t\t\t\t}\n\n\t\t\t\t\tconst delay = getDelay();\n\n\t\t\t\t\tawait waitUntil(delay);\n\n\t\t\t\t\tconst updatedOptions = {\n\t\t\t\t\t\t...config,\n\t\t\t\t\t\t\"~retryAttemptCount\": currentAttemptCount + 1,\n\t\t\t\t\t} satisfies typeof config;\n\n\t\t\t\t\treturn callApi(initURL, updatedOptions as never) as never;\n\t\t\t\t}\n\n\t\t\t\tif (shouldThrowOnError) {\n\t\t\t\t\tthrow error;\n\t\t\t\t}\n\n\t\t\t\treturn generalErrorResult;\n\t\t\t};\n\n\t\t\tif (isHTTPErrorInstance<TErrorData>(error)) {\n\t\t\t\tconst hookError = await executeHooksInCatchBlock(\n\t\t\t\t\toptions.onResponseError?.(errorContext),\n\n\t\t\t\t\toptions.onError?.(errorContext),\n\n\t\t\t\t\toptions.onResponse?.({ ...errorContext, data: null })\n\t\t\t\t);\n\n\t\t\t\t// eslint-disable-next-line max-depth -- Allow for now\n\t\t\t\tif (hookError) {\n\t\t\t\t\treturn hookError as never;\n\t\t\t\t}\n\n\t\t\t\treturn (await handleRetryOrGetErrorResult()) as never;\n\t\t\t}\n\n\t\t\tif (error instanceof DOMException && error.name === \"AbortError\") {\n\t\t\t\t!shouldThrowOnError && console.error(`${error.name}:`, error.message);\n\t\t\t}\n\n\t\t\tlet timeoutMessage: string | undefined;\n\n\t\t\tif (error instanceof DOMException && error.name === \"TimeoutError\") {\n\t\t\t\ttimeoutMessage = `Request timed out after ${options.timeout}ms`;\n\n\t\t\t\t!shouldThrowOnError && console.error(`${error.name}:`, timeoutMessage);\n\t\t\t}\n\n\t\t\tconst hookError = await executeHooksInCatchBlock(\n\t\t\t\t// == At this point only the request errors exist, so the request error hook is called\n\t\t\t\toptions.onRequestError?.(errorContext),\n\n\t\t\t\t// == Also call the onError hook\n\t\t\t\toptions.onError?.(errorContext)\n\t\t\t);\n\n\t\t\tif (hookError) {\n\t\t\t\treturn hookError as never;\n\t\t\t}\n\n\t\t\tconst errorResult = await handleRetryOrGetErrorResult();\n\n\t\t\treturn (\n\t\t\t\ttimeoutMessage\n\t\t\t\t\t? getCustomizedErrorResult(errorResult, { message: timeoutMessage })\n\t\t\t\t\t: errorResult\n\t\t\t) as never;\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\treturn callApi;\n};\n\nexport const callApi = createFetchClient();\n","import type { CallApiPlugin } from \"./plugins\";\nimport type { ResponseTypeUnion, ResultModeUnion } from \"./result\";\nimport type { CallApiParameters } from \"./types\";\nimport type { DefaultMoreOptions, DefaultPluginArray, DefaultThrowOnError } from \"./types/default-types\";\nimport type { CallApiSchemas } from \"./validation\";\n\nconst defineParameters = <\n\tTData = unknown,\n\tTErrorData = unknown,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n>(\n\t...parameters: CallApiParameters<\n\t\tTData,\n\t\tTErrorData,\n\t\tTResultMode,\n\t\tTThrowOnError,\n\t\tTResponseType,\n\t\tTPluginArray,\n\t\tTSchemas\n\t>\n) => {\n\treturn parameters;\n};\n\nexport { defineParameters };\n"]}
|
@@ -1,4 +1,4 @@
|
|
1
|
-
import { A as CallApiExtraOptions, o as CallApiResultErrorVariant, m as PossibleHTTPError, H as HTTPError } from '../common-
|
1
|
+
import { A as CallApiExtraOptions, o as CallApiResultErrorVariant, m as PossibleHTTPError, H as HTTPError } from '../common-UwnX74fm.js';
|
2
2
|
|
3
3
|
type ToQueryStringFn = {
|
4
4
|
(params: CallApiExtraOptions["query"]): string | null;
|
package/dist/esm/utils/index.js
CHANGED
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "@zayne-labs/callapi",
|
3
3
|
"type": "module",
|
4
|
-
"version": "1.7.
|
4
|
+
"version": "1.7.14",
|
5
5
|
"description": "A lightweight wrapper over fetch with quality of life improvements like built-in request cancellation, retries, interceptors and more",
|
6
6
|
"author": "Ryan Zayne",
|
7
7
|
"license": "MIT",
|
@@ -27,9 +27,6 @@
|
|
27
27
|
".": "./dist/esm/index.js",
|
28
28
|
"./utils": "./dist/esm/utils/index.js"
|
29
29
|
},
|
30
|
-
"main": "./dist/esm/index.js",
|
31
|
-
"module": "./dist/esm/index.js",
|
32
|
-
"types": "./dist/esm/index.d.ts",
|
33
30
|
"files": [
|
34
31
|
"dist"
|
35
32
|
],
|
@@ -41,13 +38,12 @@
|
|
41
38
|
"@size-limit/esbuild-why": "11.2.0",
|
42
39
|
"@size-limit/preset-small-lib": "11.2.0",
|
43
40
|
"@total-typescript/ts-reset": "0.6.1",
|
44
|
-
"@zayne-labs/toolkit-type-helpers": "^0.9.
|
45
|
-
"@zayne-labs/tsconfig": "0.8.
|
41
|
+
"@zayne-labs/toolkit-type-helpers": "^0.9.35",
|
42
|
+
"@zayne-labs/tsconfig": "0.8.2",
|
46
43
|
"concurrently": "^9.1.2",
|
47
44
|
"cross-env": "^7.0.3",
|
48
45
|
"publint": "^0.3.12",
|
49
46
|
"size-limit": "11.2.0",
|
50
|
-
"terser": "5.39.0",
|
51
47
|
"tsup": "8.4.0",
|
52
48
|
"typescript": "5.8.3",
|
53
49
|
"vitest": "^3.1.2"
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["../../src/utils/type-helpers.ts","../../src/constants/default-options.ts","../../src/result.ts","../../src/utils/guards.ts","../../src/auth.ts","../../src/constants/common.ts","../../src/types/common.ts","../../src/utils/common.ts"],"names":[],"mappings":";AAuDO,IAAM,UAAA,GAAa,CAAe,KAAkB,KAAA,KAAA;;;ACpDpD,IAAM,gBAAgB,UAAW,CAAA;AAAA,EACvC,QAAU,EAAA,CAAA;AAAA,EACV,WAAW,MAAM,IAAA;AAAA,EACjB,KAAO,EAAA,GAAA;AAAA,EACP,QAAU,EAAA,GAAA;AAAA,EACV,OAAA,EAAS,CAAC,KAAA,EAAO,MAAM,CAAA;AAAA,EACvB,aAAa,EAAC;AAAA,EACd,QAAU,EAAA;AACX,CAAC;AAaM,IAAM,iBAAiB,UAAW,CAAA;AAAA,EACxC,gBAAgB,IAAK,CAAA,SAAA;AAAA,EACrB,mBAAqB,EAAA;AACtB,CAAC;AAEM,IAAM,mBAAmB,UAAW,CAAA;AAAA,EAC1C,gBAAgB,IAAK,CAAA,KAAA;AAAA,EACrB,YAAc,EAAA,MAAA;AAAA,EACd,UAAY,EAAA;AACb,CAAC,CAAA;AAEM,IAAM,eAAe,UAAW,CAAA;AAAA,EACtC,wBAA0B,EAAA,UAAA;AAAA,EAC1B,yBAA2B,EAAA;AAC5B,CAAC;AAEM,IAAM,iBAAiB,UAAW,CAAA;AAAA,EACxC,cAAgB,EAAA;AACjB,CAAC;AAEM,IAAM,wBAAwB,UAAW,CAAA;AAAA,EAC/C,MAAQ,EAAA;AACT,CAAC;;;ACtCM,IAAM,eAAA,GAAkB,CAAY,QAAA,EAAoB,MAAoB,MAAA;AAAA,EAClF,WAAA,EAAa,MAAM,QAAA,CAAS,WAAY,EAAA;AAAA,EACxC,IAAA,EAAM,MAAM,QAAA,CAAS,IAAK,EAAA;AAAA,EAC1B,QAAA,EAAU,MAAM,QAAA,CAAS,QAAS,EAAA;AAAA,EAClC,MAAM,YAAY;AACjB,IAAM,MAAA,IAAA,GAAO,MAAM,QAAA,CAAS,IAAK,EAAA;AACjC,IAAA,OAAO,OAAO,IAAI,CAAA;AAAA,GACnB;AAAA,EACA,MAAA,EAAQ,MAAM,QAAS,CAAA,IAAA;AAAA,EACvB,IAAA,EAAM,MAAM,QAAA,CAAS,IAAK;AAC3B,CAAA,CAAA;AAoBO,IAAM,mBAAsB,GAAA,CAClC,QACA,EAAA,YAAA,EACA,MACI,KAAA;AACJ,EAAM,MAAA,cAAA,GAAiB,UAAU,gBAAiB,CAAA,cAAA;AAClD,EAAM,MAAA,oBAAA,GAAuB,gBAAgB,gBAAiB,CAAA,YAAA;AAE9D,EAAM,MAAA,oBAAA,GAAuB,eAA2B,CAAA,QAAA,EAAU,cAAc,CAAA;AAEhF,EAAA,IAAI,CAAC,MAAA,CAAO,MAAO,CAAA,oBAAA,EAAsB,oBAAoB,CAAG,EAAA;AAC/D,IAAA,MAAM,IAAI,KAAA,CAAM,CAA0B,uBAAA,EAAA,YAAY,CAAE,CAAA,CAAA;AAAA;AAGzD,EAAO,OAAA,oBAAA,CAAqB,oBAAoB,CAAE,EAAA;AACnD;AAiEa,IAAA,oBAAA,GAAuB,CAAC,IAAA,EAAe,IAAsB,KAAA;AACzE,EAAM,MAAA,EAAE,QAAU,EAAA,UAAA,EAAe,GAAA,IAAA;AAEjC,EAAA,MAAM,OAAU,GAAA;AAAA,IACf,IAAA;AAAA,IACA,KAAO,EAAA,IAAA;AAAA,IACP;AAAA,GACD;AAEA,EAAA,MAAM,aAAgB,GAAA;AAAA,IACrB,GAAK,EAAA,OAAA;AAAA,IACL,gBAAkB,EAAA,OAAA;AAAA,IAClB,aAAa,OAAQ,CAAA,IAAA;AAAA,IACrB,0BAA0B,OAAQ,CAAA;AAAA,GACnC;AAEA,EAAM,MAAA,aAAA,GAAgB,aAAc,CAAA,UAAA,IAAc,KAAK,CAAA;AAEvD,EAAO,OAAA,aAAA;AACR;AA6Ca,IAAA,SAAA,GAAN,cAAkE,KAAM,CAAA;AAAA,EAC9E,SAAA;AAAA,EAEA,WAAc,GAAA,IAAA;AAAA,EAEL,IAAO,GAAA,WAAA;AAAA,EAEhB,QAAA;AAAA,EAEA,WAAA,CAAY,cAA4C,YAA6B,EAAA;AACpF,IAAA,MAAM,EAAE,mBAAA,EAAqB,SAAW,EAAA,QAAA,EAAa,GAAA,YAAA;AAErD,IAAM,MAAA,2BAAA,GAA8B,uBAAuB,cAAe,CAAA,mBAAA;AAE1E,IAAM,MAAA,OAAA,GACJ,WAAgD,OAAW,IAAA,2BAAA;AAE7D,IAAA,KAAA,CAAM,SAAS,YAAY,CAAA;AAE3B,IAAA,IAAA,CAAK,SAAY,GAAA,SAAA;AACjB,IAAA,IAAA,CAAK,QAAW,GAAA,QAAA;AAChB,IAAM,KAAA,CAAA,iBAAA,CAAkB,IAAM,EAAA,IAAA,CAAK,WAAW,CAAA;AAAA;AAEhD;AAyBa,IAAA,kBAAA,GAAqB,CAAC,KAAA,EAAgB,IAAiC,KAAA;AACnF,EAAA,MAAM,EAAE,aAAe,EAAA,mBAAA,EAAqB,OAAS,EAAA,kBAAA,EAAoB,YAAe,GAAA,IAAA;AAExF,EAAA,IAAI,OAAU,GAAA;AAAA,IACb,IAAM,EAAA,IAAA;AAAA,IACN,KAAO,EAAA;AAAA,MACN,SAAW,EAAA,KAAA;AAAA,MACX,OAAA,EAAS,sBAAuB,KAAgB,CAAA,OAAA;AAAA,MAChD,MAAO,KAAgB,CAAA;AAAA,KACxB;AAAA,IACA,QAAU,EAAA;AAAA,GACX;AAEA,EAAI,IAAA,mBAAA,CAA2B,KAAK,CAAG,EAAA;AACtC,IAAM,MAAA,2BAAA,GAA8B,uBAAuB,cAAe,CAAA,mBAAA;AAE1E,IAAA,MAAM,EAAE,SAAW,EAAA,OAAA,GAAU,2BAA6B,EAAA,IAAA,EAAM,UAAa,GAAA,KAAA;AAE7E,IAAU,OAAA,GAAA;AAAA,MACT,IAAM,EAAA,IAAA;AAAA,MACN,KAAO,EAAA;AAAA,QACN,SAAA;AAAA,QACA,OAAA;AAAA,QACA;AAAA,OACD;AAAA,MACA,QAAU,EAAA,aAAA,GAAgB,QAAS,CAAA,KAAA,EAAU,GAAA;AAAA,KAC9C;AAAA;AAGD,EAAA,MAAM,aAAgB,GAAA;AAAA,IACrB,GAAK,EAAA,OAAA;AAAA,IACL,gBAAkB,EAAA,OAAA;AAAA,IAClB,aAAa,OAAQ,CAAA,IAAA;AAAA,IACrB,0BAA0B,OAAQ,CAAA;AAAA,GACnC;AAEA,EAAM,MAAA,WAAA,GAAc,aAAc,CAAA,UAAA,IAAc,KAAK,CAAA;AAErD,EAAO,OAAA,WAAA;AACR;AAEa,IAAA,wBAAA,GAA2B,CACvC,WAAA,EACA,eACiB,KAAA;AACjB,EAAA,IAAI,CAAC,WAAa,EAAA;AACjB,IAAO,OAAA,IAAA;AAAA;AAGR,EAAA,MAAM,EAAE,OAAA,GAAU,WAAY,CAAA,KAAA,CAAM,SAAY,GAAA,eAAA;AAEhD,EAAO,OAAA;AAAA,IACN,GAAG,WAAA;AAAA,IACH,KAAO,EAAA;AAAA,MACN,GAAG,WAAY,CAAA,KAAA;AAAA,MACf;AAAA;AACD,GACD;AACD;;;AC7Ra,IAAA,WAAA,GAAc,CAC1B,KAC4C,KAAA;AAC5C,EAAA,OAAO,aAAc,CAAA,KAAK,CAAK,IAAA,KAAA,CAAM,IAAS,KAAA,WAAA;AAC/C;AAEa,IAAA,mBAAA,GAAsB,CAClC,KACwC,KAAA;AACxC,EAAA,IAAI,iBAAiB,SAAW,EAAA;AAC/B,IAAO,OAAA,IAAA;AAAA;AAGR,EAAA,OAAO,cAAc,KAAK,CAAA,IAAK,MAAM,IAAS,KAAA,WAAA,IAAe,MAAM,WAAgB,KAAA,IAAA;AACpF;AAIO,IAAM,OAAU,GAAA,CAAa,KAA0C,KAAA,KAAA,CAAM,QAAQ,KAAK;AAE1F,IAAM,WAAW,CAAC,KAAA,KAAmB,OAAO,KAAA,KAAU,YAAY,KAAU,KAAA;AAEnF,IAAM,kBAAA,GAAqB,CAAC,KAAmB,KAAA;AAC9C,EAAA,OAAO,MAAO,CAAA,SAAA,CAAU,QAAS,CAAA,IAAA,CAAK,KAAK,CAAM,KAAA,iBAAA;AAClD,CAAA;AAMa,IAAA,aAAA,GAAgB,CAC5B,KAC2B,KAAA;AAC3B,EAAI,IAAA,CAAC,kBAAmB,CAAA,KAAK,CAAG,EAAA;AAC/B,IAAO,OAAA,KAAA;AAAA;AAIR,EAAA,MAAM,cAAe,KAA8B,EAAA,WAAA;AACnD,EAAA,IAAI,gBAAgB,MAAW,EAAA;AAC9B,IAAO,OAAA,IAAA;AAAA;AAIR,EAAA,MAAM,YAAY,WAAY,CAAA,SAAA;AAC9B,EAAI,IAAA,CAAC,kBAAmB,CAAA,SAAS,CAAG,EAAA;AACnC,IAAO,OAAA,KAAA;AAAA;AAIR,EAAA,IAAI,CAAC,MAAA,CAAO,MAAO,CAAA,SAAA,EAAW,eAAe,CAAG,EAAA;AAC/C,IAAO,OAAA,KAAA;AAAA;AAIR,EAAA,IAAI,MAAO,CAAA,cAAA,CAAe,KAAK,CAAA,KAAM,OAAO,SAAW,EAAA;AACtD,IAAO,OAAA,KAAA;AAAA;AAIR,EAAO,OAAA,IAAA;AACR;AAEO,IAAM,YAAA,GAAe,CAAC,KAAoC,KAAA;AAChE,EAAI,IAAA,CAAC,QAAS,CAAA,KAAK,CAAG,EAAA;AACrB,IAAO,OAAA,KAAA;AAAA;AAGR,EAAI,IAAA;AACH,IAAA,IAAA,CAAK,MAAM,KAAK,CAAA;AAChB,IAAO,OAAA,IAAA;AAAA,GACA,CAAA,MAAA;AACP,IAAO,OAAA,KAAA;AAAA;AAET,CAAA;AAEa,IAAA,cAAA,GAAiB,CAAC,KAAmB,KAAA;AACjD,EACC,OAAA,aAAA,CAAc,KAAK,CAChB,IAAA,OAAA,CAAQ,KAAK,CACb,IAAA,OAAQ,OAA2C,MAAW,KAAA,UAAA;AAEnE;AAEO,IAAM,UAAa,GAAA,CAAgC,KACzD,KAAA,OAAO,KAAU,KAAA;AAEX,IAAM,aAAA,GAAgB,CAAC,KAAoC,KAAA,QAAA,CAAS,KAAK,CAAK,IAAA,KAAA,CAAM,SAAS,GAAG,CAAA;AAEhG,IAAM,QAAW,GAAA,CAAC,KAAmB,KAAA,OAAO,KAAU,KAAA;AA8BhD,IAAA,gBAAA,GAAmB,CAAC,KAAqD,KAAA;AACrF,EAAA,OAAO,KAAiB,YAAA,cAAA;AACzB;;;AC5DA,IAAM,QAAA,GAAW,CAAC,KAA0B,KAAA;AAC3C,EAAA,OAAO,UAAW,CAAA,KAAK,CAAI,GAAA,KAAA,EAAU,GAAA,KAAA;AACtC,CAAA;AAMO,IAAM,aAAA,GAAgB,OAC5B,IACsD,KAAA;AACtD,EAAA,IAAI,SAAS,MAAW,EAAA;AAExB,EAAA,IAAI,QAAS,CAAA,IAAI,CAAK,IAAA,IAAA,KAAS,IAAM,EAAA;AACpC,IAAA,OAAO,EAAE,aAAA,EAAe,CAAU,OAAA,EAAA,IAAI,CAAG,CAAA,EAAA;AAAA;AAG1C,EAAA,QAAQ,KAAK,IAAM;AAAA,IAClB,KAAK,OAAS,EAAA;AACb,MAAA,MAAM,QAAW,GAAA,MAAM,QAAS,CAAA,IAAA,CAAK,QAAQ,CAAA;AAC7C,MAAA,MAAM,QAAW,GAAA,MAAM,QAAS,CAAA,IAAA,CAAK,QAAQ,CAAA;AAE7C,MAAI,IAAA,QAAA,KAAa,MAAa,IAAA,QAAA,KAAa,MAAW,EAAA;AAEtD,MAAO,OAAA;AAAA,QACN,aAAA,EAAe,SAAS,UAAW,CAAA,IAAA,CAAK,GAAG,QAAQ,CAAA,CAAA,EAAI,QAAQ,CAAA,CAAE,CAAC,CAAA;AAAA,OACnE;AAAA;AACD,IAEA,KAAK,QAAU,EAAA;AACd,MAAA,MAAM,KAAQ,GAAA,MAAM,QAAS,CAAA,IAAA,CAAK,KAAK,CAAA;AAEvC,MAAA,IAAI,UAAU,MAAW,EAAA;AAEzB,MAAA,MAAM,MAAS,GAAA,MAAM,QAAS,CAAA,IAAA,CAAK,MAAM,CAAA;AAEzC,MAAO,OAAA;AAAA,QACN,aAAe,EAAA,CAAA,EAAG,MAAM,CAAA,CAAA,EAAI,KAAK,CAAA;AAAA,OAClC;AAAA;AACD,IAEA,SAAS;AACR,MAAA,MAAM,MAAS,GAAA,MAAM,QAAS,CAAA,IAAA,CAAK,MAAM,CAAA;AACzC,MAAA,MAAM,KAAQ,GAAA,MAAM,QAAS,CAAA,IAAA,CAAK,KAAK,CAAA;AAEvC,MAAI,IAAA,OAAA,IAAW,IAAQ,IAAA,KAAA,KAAU,MAAW,EAAA;AAC3C,QAAA,OAAO,EAAE,aAAA,EAAe,CAAS,MAAA,EAAA,KAAK,CAAG,CAAA,EAAA;AAAA;AAG1C,MAAA,OAAO,WAAW,MAAa,IAAA,EAAE,aAAe,EAAA,CAAA,OAAA,EAAU,MAAM,CAAG,CAAA,EAAA;AAAA;AACpE;AAEF,CAAA;;;ACjHO,IAAM,oBAAoB,UAAW,CAAA;AAAA,EAC3C,MAAA;AAAA,EACA,WAAA;AAAA,EACA,QAAA;AAAA,EACA,QAAA;AAAA,EACA,SAAA;AAAA,EACA,QAAA;AAAA,EACA,OAAA;AAAA,EACA,UAAA;AAAA,EACA,QAAA;AAAA,EACA,aAAA;AAAA,EACA,WAAA;AAAA,EACA,UAAA;AAAA,EACA,UAAA;AAAA,EACA,MAAA;AAAA,EACA;AACD,CAAgF,CAAA;;;ACoLzE,IAAM,yBAA4B,GAAA,UAAA,CAAW,CAAC,WAAW,CAE/D,CAAA;;;AC/LM,IAAM,QAAA,GAAW,CAIvB,aAAA,EACA,UACI,KAAA;AACJ,EAAA,MAAM,gBAAgB,EAAC;AAEvB,EAAM,MAAA,aAAA,GAAgB,IAAI,GAAA,CAAI,UAAU,CAAA;AAExC,EAAA,KAAA,MAAW,CAAC,GAAK,EAAA,KAAK,KAAK,MAAO,CAAA,OAAA,CAAQ,aAAa,CAAG,EAAA;AACzD,IAAA,IAAI,CAAC,aAAA,CAAc,GAAI,CAAA,GAAG,CAAG,EAAA;AAC5B,MAAA,aAAA,CAAc,GAAG,CAAI,GAAA,KAAA;AAAA;AACtB;AAGD,EAAO,OAAA,aAAA;AACR,CAAA;AAEO,IAAM,QAAA,GAAW,CAIvB,aAAA,EACA,UACI,KAAA;AACJ,EAAA,MAAM,gBAAgB,EAAC;AAEvB,EAAM,MAAA,aAAA,GAAgB,IAAI,GAAA,CAAI,UAAU,CAAA;AAExC,EAAA,KAAA,MAAW,CAAC,GAAK,EAAA,KAAK,KAAK,MAAO,CAAA,OAAA,CAAQ,aAAa,CAAG,EAAA;AACzD,IAAI,IAAA,aAAA,CAAc,GAAI,CAAA,GAAG,CAAG,EAAA;AAC3B,MAAA,aAAA,CAAc,GAAG,CAAI,GAAA,KAAA;AAAA;AACtB;AAGD,EAAO,OAAA,aAAA;AACR,CAAA;AAGa,IAAA,eAAA,GAAkB,CAAC,UAC/B,KAAA;AAAA,EACC,QAAA,CAAS,YAAY,iBAAiB,CAAA;AAAA,EACtC,SAAS,UAAY,EAAA;AAAA,IACpB,GAAG,iBAAA;AAAA,IACH,GAAG;AAAA,GACH;AACF;AAGY,IAAA,WAAA,GAAc,CAAC,MAC3B,KAAA;AAAA,EACC,QAAA,CAAS,QAAQ,iBAAiB,CAAA;AAAA,EAClC,QAAA,CAAS,QAAQ,iBAAiB;AACnC;AAOY,IAAA,aAAA,GAAiC,CAAC,MAAW,KAAA;AACzD,EAAA,IAAI,CAAC,MAAQ,EAAA;AACZ,IAAQ,OAAA,CAAA,KAAA,CAAM,kBAAkB,2BAA2B,CAAA;AAE3D,IAAO,OAAA,IAAA;AAAA;AAGR,EAAA,OAAO,IAAI,eAAA,CAAgB,MAAgC,CAAA,CAAE,QAAS,EAAA;AACvE;AAEO,IAAM,gBAAA,GAAmB,CAAC,OAA8C,KAAA;AAC9E,EAAA,IAAI,CAAC,OAAA,IAAW,aAAc,CAAA,OAAO,CAAG,EAAA;AACvC,IAAO,OAAA,OAAA;AAAA;AAGR,EAAO,OAAA,MAAA,CAAO,YAAY,OAAO,CAAA;AAClC,CAAA;AASa,IAAA,UAAA,GAAa,OAAO,OAA2C,KAAA;AAC3E,EAAA,MAAM,EAAE,IAAA,EAAM,WAAa,EAAA,IAAA,EAAM,SAAY,GAAA,OAAA;AAG7C,EAAA,MAAM,oBAAuB,GAAA,OAAA,CAAQ,WAAe,IAAA,OAAA,IAAW,QAAQ,IAAI,CAAA;AAM3E,EAAA,IAAI,CAAC,oBAAsB,EAAA;AAE3B,EAAA,MAAM,aAAoD,GAAA;AAAA,IACzD,GAAI,MAAM,aAAA,CAAc,IAAI,CAAA;AAAA,IAC5B,GAAG,iBAAiB,WAAW,CAAA;AAAA,IAC/B,GAAG,iBAAiB,OAAO;AAAA,GAC5B;AAEA,EAAI,IAAA,aAAA,CAAc,IAAI,CAAG,EAAA;AACxB,IAAA,aAAA,CAAc,cAAc,CAAI,GAAA,mCAAA;AAEhC,IAAO,OAAA,aAAA;AAAA;AAGR,EAAA,IAAI,cAAe,CAAA,IAAI,CAAK,IAAA,YAAA,CAAa,IAAI,CAAG,EAAA;AAC/C,IAAA,aAAA,CAAc,cAAc,CAAI,GAAA,kBAAA;AAChC,IAAA,aAAA,CAAc,MAAS,GAAA,kBAAA;AAAA;AAGxB,EAAO,OAAA,aAAA;AACR;AAEa,IAAA,YAAA,GAAe,CAAC,eAA4D,KAAA;AACxF,EAAA,IAAI,eAAiB,EAAA;AACpB,IAAO,OAAA,eAAA;AAAA;AAGR,EAAA,IAAI,OAAO,UAAe,KAAA,WAAA,IAAe,UAAW,CAAA,UAAA,CAAW,KAAK,CAAG,EAAA;AACtE,IAAA,OAAO,UAAW,CAAA,KAAA;AAAA;AAGnB,EAAM,MAAA,IAAI,MAAM,+BAA+B,CAAA;AAChD;AAEA,IAAM,uBAAuB,MAAM;AAClC,EAAI,IAAA,MAAA;AACJ,EAAI,IAAA,OAAA;AAEJ,EAAA,MAAM,OAAU,GAAA,IAAI,OAAQ,CAAA,CAAC,KAAK,GAAQ,KAAA;AACzC,IAAU,OAAA,GAAA,GAAA;AACV,IAAS,MAAA,GAAA,GAAA;AAAA,GACT,CAAA;AAED,EAAO,OAAA,EAAE,OAAS,EAAA,MAAA,EAAQ,OAAQ,EAAA;AACnC,CAAA;AAEa,IAAA,SAAA,GAAY,CAAC,KAAkB,KAAA;AAC3C,EAAA,IAAI,UAAU,CAAG,EAAA;AAEjB,EAAA,MAAM,EAAE,OAAA,EAAS,OAAQ,EAAA,GAAI,oBAAqB,EAAA;AAElD,EAAA,UAAA,CAAW,SAAS,KAAK,CAAA;AAEzB,EAAO,OAAA,OAAA;AACR;AAEa,IAAA,oBAAA,GAAuB,IAAI,OAAmD,KAAA;AAC1F,EAAM,MAAA,cAAA,GAAiB,OAAQ,CAAA,MAAA,CAAO,OAAO,CAAA;AAE7C,EAAM,MAAA,cAAA,GAAiB,WAAY,CAAA,GAAA,CAAI,cAAc,CAAA;AAErD,EAAO,OAAA,cAAA;AACR;AAEO,IAAM,mBAAsB,GAAA,CAAC,YAAyB,KAAA,WAAA,CAAY,QAAQ,YAAY","file":"chunk-SJZKYDA4.js","sourcesContent":["// == 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<keyof any, 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 = unknown> = (...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 WriteableVariantUnion = \"deep\" | \"shallow\";\n\n/**\n * Makes all properties in an object type writeable (removes readonly modifiers).\n * Supports both shallow and deep modes, and handles special cases like arrays, tuples, and unions.\n * @template TObject - The object type to make writeable\n * @template TVariant - The level of writeable transformation (\"shallow\" | \"deep\")\n */\n\ntype ArrayOrObject = Record<number | string | symbol, unknown> | unknown[];\n\nexport type Writeable<\n\tTObject,\n\tTVariant extends WriteableVariantUnion = \"shallow\",\n> = TObject extends readonly [...infer TTupleItems]\n\t? TVariant extends \"deep\"\n\t\t? [\n\t\t\t\t...{\n\t\t\t\t\t[Key in keyof TTupleItems]: TTupleItems[Key] extends ArrayOrObject\n\t\t\t\t\t\t? Writeable<TTupleItems[Key], TVariant>\n\t\t\t\t\t\t: TTupleItems[Key];\n\t\t\t\t},\n\t\t\t]\n\t\t: [...TTupleItems]\n\t: TObject extends ReadonlyArray<infer TArrayItem>\n\t\t? TVariant extends \"deep\"\n\t\t\t? Array<TArrayItem extends ArrayOrObject ? Writeable<TArrayItem, TVariant> : TArrayItem>\n\t\t\t: TArrayItem[]\n\t\t: TObject extends ArrayOrObject\n\t\t\t? {\n\t\t\t\t\t-readonly [Key in keyof TObject]: TVariant extends \"shallow\"\n\t\t\t\t\t\t? TObject[Key]\n\t\t\t\t\t\t: TVariant extends \"deep\"\n\t\t\t\t\t\t\t? TObject[Key] extends ArrayOrObject\n\t\t\t\t\t\t\t\t? Writeable<TObject[Key], TVariant>\n\t\t\t\t\t\t\t\t: TObject[Key]\n\t\t\t\t\t\t\t: never;\n\t\t\t\t}\n\t\t\t: TObject;\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","import type { BaseCallApiExtraOptions } from \"../types\";\nimport { defineEnum } from \"../utils/type-helpers\";\n\nexport const retryDefaults = defineEnum({\n\tattempts: 0,\n\tcondition: () => true,\n\tdelay: 1000,\n\tmaxDelay: 10000,\n\tmethods: [\"GET\", \"POST\"] satisfies BaseCallApiExtraOptions[\"retryMethods\"],\n\tstatusCodes: [] satisfies BaseCallApiExtraOptions[\"retryStatusCodes\"],\n\tstrategy: \"linear\",\n});\n\nexport const defaultRetryStatusCodesLookup = 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 commonDefaults = defineEnum({\n\tbodySerializer: JSON.stringify,\n\tdefaultErrorMessage: \"Failed to fetch data from server!\",\n});\n\nexport const responseDefaults = defineEnum({\n\tresponseParser: JSON.parse,\n\tresponseType: \"json\",\n\tresultMode: \"all\",\n});\n\nexport const hookDefaults = defineEnum({\n\tmergedHooksExecutionMode: \"parallel\",\n\tmergedHooksExecutionOrder: \"mainHooksAfterPlugins\",\n});\n\nexport const dedupeDefaults = defineEnum({\n\tdedupeStrategy: \"cancel\",\n});\n\nexport const requestOptionDefaults = defineEnum({\n\tmethod: \"GET\",\n});\n","import { commonDefaults, responseDefaults } from \"./constants/default-options\";\nimport type { CallApiExtraOptions } from \"./types\";\nimport type { DefaultDataType } from \"./types/default-types\";\nimport { isHTTPErrorInstance } from \"./utils/guards\";\nimport type { Awaitable, Prettify, UnmaskType } from \"./utils/type-helpers\";\n\ntype Parser = (responseString: string) => Awaitable<Record<string, unknown>>;\n\nexport const getResponseType = <TResponse>(response: Response, parser: Parser) => ({\n\tarrayBuffer: () => response.arrayBuffer(),\n\tblob: () => response.blob(),\n\tformData: () => response.formData(),\n\tjson: async () => {\n\t\tconst text = await response.text();\n\t\treturn parser(text) as TResponse;\n\t},\n\tstream: () => response.body,\n\ttext: () => response.text(),\n});\n\ntype InitResponseTypeMap<TResponse = unknown> = ReturnType<typeof getResponseType<TResponse>>;\n\nexport type ResponseTypeUnion = keyof InitResponseTypeMap | null;\n\nexport type ResponseTypeMap<TResponse> = {\n\t[Key in keyof InitResponseTypeMap<TResponse>]: Awaited<ReturnType<InitResponseTypeMap<TResponse>[Key]>>;\n};\n\nexport type GetResponseType<\n\tTResponse,\n\tTResponseType extends ResponseTypeUnion,\n\tTComputedResponseTypeMap extends ResponseTypeMap<TResponse> = ResponseTypeMap<TResponse>,\n> = null extends TResponseType\n\t? TComputedResponseTypeMap[\"json\"]\n\t: TResponseType extends NonNullable<ResponseTypeUnion>\n\t\t? TComputedResponseTypeMap[TResponseType]\n\t\t: never;\n\nexport const resolveResponseData = <TResponse>(\n\tresponse: Response,\n\tresponseType?: ResponseTypeUnion,\n\tparser?: Parser\n) => {\n\tconst selectedParser = parser ?? responseDefaults.responseParser;\n\tconst selectedResponseType = responseType ?? responseDefaults.responseType;\n\n\tconst RESPONSE_TYPE_LOOKUP = getResponseType<TResponse>(response, selectedParser);\n\n\tif (!Object.hasOwn(RESPONSE_TYPE_LOOKUP, selectedResponseType)) {\n\t\tthrow new Error(`Invalid response type: ${responseType}`);\n\t}\n\n\treturn RESPONSE_TYPE_LOOKUP[selectedResponseType]();\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<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTComputedData = GetResponseType<TData, TResponseType>,\n\tTComputedErrorData = GetResponseType<TErrorData, TResponseType>,\n> = UnmaskType<{\n\t/* eslint-disable perfectionist/sort-union-types -- I need the first one to be first */\n\tall: CallApiResultSuccessVariant<TComputedData> | CallApiResultErrorVariant<TComputedErrorData>;\n\n\tallWithException: CallApiResultSuccessVariant<TComputedData>;\n\n\tonlySuccess:\n\t\t| CallApiResultErrorVariant<TComputedErrorData>[\"data\"]\n\t\t| CallApiResultSuccessVariant<TComputedData>[\"data\"];\n\n\tonlySuccessWithException: CallApiResultSuccessVariant<TComputedData>[\"data\"];\n\t/* eslint-enable perfectionist/sort-union-types -- I need the first one to be first */\n}>;\n\nexport type ResultModeUnion = keyof ResultModeMap | null;\n\nexport type GetCallApiResult<\n\tTData,\n\tTErrorData,\n\tTResultMode extends ResultModeUnion,\n\tTThrowOnError extends boolean,\n\tTResponseType extends ResponseTypeUnion,\n> = TErrorData extends false | undefined\n\t? ResultModeMap<TData, TErrorData, TResponseType>[\"onlySuccessWithException\"]\n\t: null extends TResultMode\n\t\t? TThrowOnError extends true\n\t\t\t? ResultModeMap<TData, TErrorData, TResponseType>[\"allWithException\"]\n\t\t\t: ResultModeMap<TData, TErrorData, TResponseType>[\"all\"]\n\t\t: TResultMode extends NonNullable<ResultModeUnion>\n\t\t\t? ResultModeMap<TData, TErrorData, TResponseType>[TResultMode]\n\t\t\t: never;\n\ntype SuccessInfo = {\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 = (data: unknown, info: SuccessInfo) => {\n\tconst { response, resultMode } = info;\n\n\tconst details = {\n\t\tdata,\n\t\terror: null,\n\t\tresponse,\n\t} satisfies CallApiResultSuccessVariant<unknown>;\n\n\tconst resultModeMap = {\n\t\tall: details,\n\t\tallWithException: details,\n\t\tonlySuccess: details.data,\n\t\tonlySuccessWithException: details.data,\n\t} satisfies ResultModeMap;\n\n\tconst successResult = resultModeMap[resultMode ?? \"all\"];\n\n\treturn successResult;\n};\n\n// export const resolveErrorResultAndContextForHooks = (info: ErrorInfo) => {\n// \tconst { baseConfig, config, error, message: customErrorMessage, options, request } = info;\n\n// \tconst errorContext = {\n// \t\tbaseConfig,\n// \t\tconfig,\n// \t\terror: errorResult?.error as never,\n// \t\toptions,\n// \t\trequest,\n// \t\tresponse: errorResult?.response as never,\n// \t} satisfies ErrorContext<unknown>;\n\n// \tconst shouldThrowOnError = isFunction(options.throwOnError)\n// \t\t? options.throwOnError(errorContext)\n// \t\t: options.throwOnError;\n\n// \tconst executeHooksInCatchBlock = async (...hookResults: Array<Awaitable<unknown>>) => {\n// \t\ttry {\n// \t\t\tawait Promise.all(hookResults);\n\n// \t\t\treturn null;\n// \t\t} catch (hookError) {\n// \t\t\tif (shouldThrowOnError) {\n// \t\t\t\tthrow hookError;\n// \t\t\t}\n\n// \t\t\tconst { errorResult: hookErrorResult } = resolveErrorResult({ ...info, error: hookError });\n\n// \t\t\treturn hookErrorResult;\n// \t\t}\n// \t};\n\n// \treturn { errorContext, errorResult, executeHooksInCatchBlock, shouldThrowOnError };\n// };\n\ntype ErrorDetails<TErrorResponse> = {\n\tdefaultErrorMessage: CallApiExtraOptions[\"defaultErrorMessage\"];\n\terrorData: TErrorResponse;\n\tresponse: Response;\n};\n\n// export const httpErrorSymbol = Symbol(\"HTTPError\");\n\nexport class HTTPError<TErrorResponse = Record<string, unknown>> extends Error {\n\terrorData: ErrorDetails<TErrorResponse>[\"errorData\"];\n\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\tconst selectedDefaultErrorMessage = defaultErrorMessage ?? commonDefaults.defaultErrorMessage;\n\n\t\tconst message =\n\t\t\t(errorData as { message?: string } | undefined)?.message ?? selectedDefaultErrorMessage;\n\n\t\tsuper(message, errorOptions);\n\n\t\tthis.errorData = errorData;\n\t\tthis.response = response;\n\t\tError.captureStackTrace(this, this.constructor);\n\t}\n}\n\nexport type PossibleJavaScriptError = UnmaskType<{\n\terrorData: DOMException | Error | SyntaxError | TypeError;\n\tmessage: string;\n\tname: \"AbortError\" | \"Error\" | \"SyntaxError\" | \"TimeoutError\" | \"TypeError\" | (`${string}Error` & {});\n}>;\n\nexport type PossibleHTTPError<TErrorData> = Prettify<\n\tUnmaskType<{\n\t\terrorData: TErrorData;\n\t\tmessage: string;\n\t\tname: \"HTTPError\";\n\t}>\n>;\n\nexport type ErrorInfo = {\n\tcloneResponse: CallApiExtraOptions[\"cloneResponse\"];\n\tdefaultErrorMessage: CallApiExtraOptions[\"defaultErrorMessage\"];\n\tmessage?: string;\n\tresultMode: CallApiExtraOptions[\"resultMode\"];\n};\n\ntype ErrorResult = CallApiResultErrorVariant<unknown> | null;\n\nexport const resolveErrorResult = (error: unknown, info: ErrorInfo): ErrorResult => {\n\tconst { cloneResponse, defaultErrorMessage, message: customErrorMessage, resultMode } = info;\n\n\tlet details = {\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 PossibleJavaScriptError[\"name\"],\n\t\t},\n\t\tresponse: null,\n\t} satisfies CallApiResultErrorVariant<unknown> as CallApiResultErrorVariant<unknown>;\n\n\tif (isHTTPErrorInstance<never>(error)) {\n\t\tconst selectedDefaultErrorMessage = defaultErrorMessage ?? commonDefaults.defaultErrorMessage;\n\n\t\tconst { errorData, message = selectedDefaultErrorMessage, name, response } = error;\n\n\t\tdetails = {\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 = {\n\t\tall: details,\n\t\tallWithException: details as never,\n\t\tonlySuccess: details.data,\n\t\tonlySuccessWithException: details.data,\n\t} satisfies ResultModeMap;\n\n\tconst errorResult = resultModeMap[resultMode ?? \"all\"];\n\n\treturn errorResult;\n};\n\nexport const getCustomizedErrorResult = (\n\terrorResult: ErrorResult,\n\tcustomErrorInfo: { message: string }\n): ErrorResult => {\n\tif (!errorResult) {\n\t\treturn null;\n\t}\n\n\tconst { message = errorResult.error.message } = customErrorInfo;\n\n\treturn {\n\t\t...errorResult,\n\t\terror: {\n\t\t\t...errorResult.error,\n\t\t\tmessage,\n\t\t} satisfies NonNullable<ErrorResult>[\"error\"] as never,\n\t};\n};\n","import { type CallApiResultErrorVariant, HTTPError, type PossibleHTTPError } from \"../result\";\nimport type { AnyFunction } from \"./type-helpers\";\n\nexport const isHTTPError = <TErrorData>(\n\terror: CallApiResultErrorVariant<TErrorData>[\"error\"] | 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\tif (error instanceof HTTPError) {\n\t\treturn true;\n\t}\n\n\treturn isPlainObject(error) && error.name === \"HTTPError\" && error.isHTTPError === true;\n};\n\n// FIXME: Outsource to type-helpers later as a peer dependency\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\nconst hasObjectPrototype = (value: unknown) => {\n\treturn Object.prototype.toString.call(value) === \"[object Object]\";\n};\n\n/**\n * @description Copied from TanStack Query's isPlainObject\n * @see https://github.com/TanStack/query/blob/main/packages/query-core/src/utils.ts#L321\n */\nexport const isPlainObject = <TPlainObject extends Record<string, unknown>>(\n\tvalue: unknown\n): value is TPlainObject => {\n\tif (!hasObjectPrototype(value)) {\n\t\treturn false;\n\t}\n\n\t// If has no constructor\n\tconst constructor = (value as object | undefined)?.constructor;\n\tif (constructor === undefined) {\n\t\treturn true;\n\t}\n\n\t// If has modified prototype\n\tconst prototype = constructor.prototype as object;\n\tif (!hasObjectPrototype(prototype)) {\n\t\treturn false;\n\t}\n\n\t// If constructor does not have an Object-specific method\n\tif (!Object.hasOwn(prototype, \"isPrototypeOf\")) {\n\t\treturn false;\n\t}\n\n\t// Handles Objects created by Object.create(<arbitrary prototype>)\n\tif (Object.getPrototypeOf(value) !== Object.prototype) {\n\t\treturn false;\n\t}\n\n\t// It's probably a plain object at this point\n\treturn true;\n};\n\nexport const isJsonString = (value: unknown): value is string => {\n\tif (!isString(value)) {\n\t\treturn false;\n\t}\n\n\ttry {\n\t\tJSON.parse(value);\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport const isSerializable = (value: unknown) => {\n\treturn (\n\t\tisPlainObject(value)\n\t\t|| isArray(value)\n\t\t|| typeof (value as { toJSON: unknown } | undefined)?.toJSON === \"function\"\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(value?.constructor && value.constructor.name === \"Object\")\n\t\t// eslint-disable-next-line ts-eslint/prefer-nullish-coalescing -- Nullish coalescing makes no sense in this boolean context\n\t\t|| typeof (value as { toJSON: () => unknown } | null)?.toJSON === \"function\"\n\t);\n};\n\nexport const isReadableStream = (value: unknown): value is ReadableStream<unknown> => {\n\treturn value instanceof ReadableStream;\n};\n","/* eslint-disable perfectionist/sort-object-types -- Avoid Sorting for now */\n\nimport type { ExtraOptions } from \"./types/common\";\nimport { isFunction, isString } from \"./utils/guards\";\nimport type { Awaitable } from \"./utils/type-helpers\";\n\ntype ValueOrFunctionResult<TValue> = TValue | (() => TValue);\n\ntype ValidAuthValue = ValueOrFunctionResult<Awaitable<string | null | undefined>>;\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?: ValidAuthValue;\n\t\t\ttoken?: never;\n\t }\n\t| {\n\t\t\ttype?: \"Token\";\n\t\t\tbearer?: never;\n\t\t\ttoken?: ValidAuthValue;\n\t };\n\n/**\n * Basic auth\n */\nexport type BasicAuth = {\n\ttype: \"Basic\";\n\tusername: ValidAuthValue;\n\tpassword: ValidAuthValue;\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: ValidAuthValue;\n\tvalue: ValidAuthValue;\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: ValidAuthValue) => {\n\treturn isFunction(value) ? value() : value;\n};\n\ntype AuthorizationHeader = {\n\tAuthorization: string;\n};\n\nexport const getAuthHeader = async (\n\tauth: ExtraOptions[\"auth\"]\n): Promise<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 = await getValue(auth.username);\n\t\t\tconst password = await 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 = await getValue(auth.value);\n\n\t\t\tif (value === undefined) return;\n\n\t\t\tconst prefix = await 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 = await getValue(auth.bearer);\n\t\t\tconst token = await 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","import type { ModifiedRequestInit } from \"../types\";\nimport { defineEnum } from \"../utils/type-helpers\";\n\nexport const fetchSpecificKeys = defineEnum([\n\t\"body\",\n\t\"integrity\",\n\t\"duplex\",\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 ModifiedRequestInit> as Array<keyof ModifiedRequestInit>);\n","import type { Auth } from \"../auth\";\nimport type { fetchSpecificKeys } from \"../constants/common\";\nimport type { ErrorContext, Hooks, HooksOrHooksArray } from \"../hooks\";\nimport type { CallApiPlugin, InferPluginOptions, Plugins } from \"../plugins\";\nimport type { GetCallApiResult, ResponseTypeUnion, ResultModeUnion } from \"../result\";\nimport type { RetryOptions } from \"../retry\";\nimport type { InitURL, UrlOptions } from \"../url\";\nimport { type Awaitable, type Prettify, type UnmaskType, defineEnum } from \"../utils/type-helpers\";\nimport type { CallApiSchemas, CallApiValidators, InferSchemaResult } from \"../validation\";\nimport type {\n\tBodyOption,\n\tHeadersOption,\n\tMetaOption,\n\tMethodOption,\n\tResultModeOption,\n} from \"./conditional-types\";\nimport type {\n\tDefaultDataType,\n\tDefaultMoreOptions,\n\tDefaultPluginArray,\n\tDefaultThrowOnError,\n} from \"./default-types\";\n\ntype FetchSpecificKeysUnion = Exclude<(typeof fetchSpecificKeys)[number], \"body\" | \"headers\" | \"method\">;\n\nexport type ModifiedRequestInit = RequestInit & { duplex?: \"half\" };\n\nexport type CallApiRequestOptions<TSchemas extends CallApiSchemas = DefaultMoreOptions> = Prettify<\n\tBodyOption<TSchemas>\n\t\t& HeadersOption<TSchemas>\n\t\t& MethodOption<TSchemas>\n\t\t& Pick<ModifiedRequestInit, FetchSpecificKeysUnion>\n>;\n\nexport type CallApiRequestOptionsForHooks<TSchemas extends CallApiSchemas = DefaultMoreOptions> = Omit<\n\tCallApiRequestOptions<TSchemas>,\n\t\"headers\"\n> & {\n\theaders?: Record<string, string | undefined>;\n};\n\ntype FetchImpl = UnmaskType<(input: string | Request | URL, init?: RequestInit) => Promise<Response>>;\n\nexport type ExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = {\n\t/**\n\t * Authorization header value.\n\t */\n\tauth?: string | Auth | null;\n\t/**\n\t * Base URL to be prepended to all request URLs\n\t */\n\tbaseURL?: string;\n\n\t/**\n\t * Custom function to serialize the body object into a string.\n\t */\n\tbodySerializer?: (bodyData: Record<string, unknown>) => string;\n\n\t/**\n\t * Whether or not to clone the response, so response.json() and the like, can be read again else where.\n\t * @see https://developer.mozilla.org/en-US/docs/Web/API/Response/clone\n\t * @default false\n\t */\n\tcloneResponse?: boolean;\n\n\t/**\n\t * Custom fetch implementation\n\t */\n\tcustomFetchImpl?: FetchImpl;\n\n\t/**\n\t * Custom request key to be used to identify a request in the fetch deduplication strategy.\n\t * @default the full request url + string formed from the request options\n\t */\n\tdedupeKey?: string;\n\n\t/**\n\t * Defines the deduplication strategy for the request, can be set to \"none\" | \"defer\" | \"cancel\".\n\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 * - 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 * - If set to \"none\", deduplication is disabled.\n\t * @default \"cancel\"\n\t */\n\tdedupeStrategy?: \"cancel\" | \"defer\" | \"none\";\n\n\t/**\n\t * Default error message to use if none is provided from a response.\n\t * @default \"Failed to fetch data from server!\"\n\t */\n\tdefaultErrorMessage?: string;\n\n\t/**\n\t * If true, forces the calculation of the total byte size from the request or response body, in case the content-length header is not present or is incorrect.\n\t * @default false\n\t */\n\tforceCalculateStreamSize?: boolean | { request?: boolean; response?: boolean };\n\n\t/**\n\t * Resolved request URL\n\t */\n\treadonly fullURL?: string;\n\n\t/**\n\t * Defines the mode in which the composed hooks are executed\".\n\t * - If set to \"parallel\", main and plugin hooks will be executed in parallel.\n\t * - If set to \"sequential\", the plugin hooks will be executed first, followed by the main hook.\n\t * @default \"parallel\"\n\t */\n\tmergedHooksExecutionMode?: \"parallel\" | \"sequential\";\n\n\t/**\n\t * - Controls what order in which the composed hooks execute\n\t * @default \"mainHooksAfterPlugins\"\n\t */\n\tmergedHooksExecutionOrder?: \"mainHooksAfterPlugins\" | \"mainHooksBeforePlugins\";\n\n\t/**\n\t * An array of CallApi plugins. It allows you to extend the behavior of the library.\n\t */\n\tplugins?: Plugins<TPluginArray>;\n\n\t/**\n\t * Custom function to parse the response string\n\t */\n\tresponseParser?: (responseString: string) => Awaitable<Record<string, unknown>>;\n\n\t/**\n\t * Expected response type, affects how response is parsed\n\t * @default \"json\"\n\t */\n\tresponseType?: TResponseType;\n\n\t/**\n\t * Mode of the result, can influence how results are handled or returned.\n\t * Can be set to \"all\" | \"onlySuccess\" | \"onlyError\" | \"onlyResponse\".\n\t * @default \"all\"\n\t */\n\tresultMode?: TResultMode;\n\n\t/**\n\t * Type-safe schemas for the response validation.\n\t */\n\tschemas?: TSchemas;\n\n\t/**\n\t * If true or the function returns true, throws errors instead of returning them\n\t * The function is passed the error object and can be used to conditionally throw the error\n\t * @default false\n\t */\n\tthrowOnError?: TThrowOnError | ((context: ErrorContext<TErrorData>) => TThrowOnError);\n\n\t/**\n\t * Request timeout in milliseconds\n\t */\n\ttimeout?: number;\n\n\t/**\n\t * Custom validation functions for response validation\n\t */\n\tvalidators?: CallApiValidators<TData, TErrorData>;\n\t/* eslint-disable perfectionist/sort-intersection-types -- Allow these to be last for the sake of docs */\n} & HooksOrHooksArray<TData, TErrorData, Partial<InferPluginOptions<TPluginArray>>>\n\t& Partial<InferPluginOptions<TPluginArray>>\n\t& MetaOption<TSchemas>\n\t& RetryOptions<TErrorData>\n\t& ResultModeOption<TErrorData, TResultMode>\n\t& UrlOptions<TSchemas>;\n/* eslint-enable perfectionist/sort-intersection-types -- Allow these to be last for the sake of docs */\n\nexport type CallApiExtraOptions<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = ExtraOptions<TData, TErrorData, TResultMode, TThrowOnError, TResponseType, TPluginArray, TSchemas> & {\n\tplugins?:\n\t\t| Plugins<TPluginArray>\n\t\t| ((context: { basePlugins: Plugins<TPluginArray> }) => Plugins<TPluginArray>);\n\n\tschemas?: TSchemas | ((context: { baseSchemas: TSchemas | undefined }) => TSchemas);\n\n\tvalidators?:\n\t\t| CallApiValidators<TData, TErrorData>\n\t\t| ((context: {\n\t\t\t\tbaseValidators: CallApiValidators<TData, TErrorData> | undefined;\n\t\t }) => CallApiValidators<TData, TErrorData>);\n};\n\nexport const optionsEnumToOmitFromBase = defineEnum([\"dedupeKey\"] satisfies Array<\n\tkeyof CallApiExtraOptions\n>);\n\nexport type BaseCallApiExtraOptions<\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBaseThrowOnError extends boolean = DefaultThrowOnError,\n\tTBaseResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTBasePluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTBaseSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = Omit<\n\tPartial<\n\t\tCallApiExtraOptions<\n\t\t\tTBaseData,\n\t\t\tTBaseErrorData,\n\t\t\tTBaseResultMode,\n\t\t\tTBaseThrowOnError,\n\t\t\tTBaseResponseType,\n\t\t\tTBasePluginArray,\n\t\t\tTBaseSchemas\n\t\t>\n\t>,\n\t(typeof optionsEnumToOmitFromBase)[number]\n> & {\n\t/**\n\t * Specifies which configuration parts should skip automatic merging between base and main configs.\n\t * Use this when you need manual control over how configs are combined.\n\t *\n\t * @values\n\t * - \"all\" - Disables automatic merging for both request and options\n\t * - \"options\" - Disables automatic merging of options only\n\t * - \"request\" - Disables automatic merging of request only\n\t *\n\t * @example\n\t * ```ts\n\t * const client = createFetchClient((ctx) => ({\n\t * skipAutoMergeFor: \"options\",\n\t *\n\t * // Now you can manually merge options in your config function\n\t * ...ctx.options,\n\t * }));\n\t * ```\n\t */\n\tskipAutoMergeFor?: \"all\" | \"options\" | \"request\";\n};\n\ntype CombinedExtraOptionsWithoutHooks = Omit<BaseCallApiExtraOptions & CallApiExtraOptions, keyof Hooks>;\n\n// eslint-disable-next-line ts-eslint/consistent-type-definitions -- Allow this to be an interface\nexport interface CombinedCallApiExtraOptions extends CombinedExtraOptionsWithoutHooks, Hooks {}\n\nexport type BaseCallApiConfig<\n\tTBaseData = DefaultDataType,\n\tTBaseErrorData = DefaultDataType,\n\tTBaseResultMode extends ResultModeUnion = ResultModeUnion,\n\tTBaseThrowOnError extends boolean = DefaultThrowOnError,\n\tTBaseResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTBasePluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTBaseSchemas extends CallApiSchemas = DefaultMoreOptions,\n> =\n\t| (CallApiRequestOptions<TBaseSchemas> // eslint-disable-next-line perfectionist/sort-intersection-types -- Allow\n\t\t\t& BaseCallApiExtraOptions<\n\t\t\t\tTBaseData,\n\t\t\t\tTBaseErrorData,\n\t\t\t\tTBaseResultMode,\n\t\t\t\tTBaseThrowOnError,\n\t\t\t\tTBaseResponseType,\n\t\t\t\tTBasePluginArray,\n\t\t\t\tTBaseSchemas\n\t\t\t>)\n\t| ((context: {\n\t\t\tinitURL: string;\n\t\t\toptions: CallApiExtraOptions;\n\t\t\trequest: CallApiRequestOptions;\n\t }) => CallApiRequestOptions<TBaseSchemas> // eslint-disable-next-line perfectionist/sort-intersection-types -- Allow\n\t\t\t& BaseCallApiExtraOptions<\n\t\t\t\tTBaseData,\n\t\t\t\tTBaseErrorData,\n\t\t\t\tTBaseResultMode,\n\t\t\t\tTBaseThrowOnError,\n\t\t\t\tTBaseResponseType,\n\t\t\t\tTBasePluginArray,\n\t\t\t\tTBaseSchemas\n\t\t\t>);\n\nexport type CallApiConfig<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = CallApiRequestOptions<TSchemas> // eslint-disable-next-line perfectionist/sort-intersection-types -- Allow these to be last for the sake of docs\n\t& CallApiExtraOptions<\n\t\tTData,\n\t\tTErrorData,\n\t\tTResultMode,\n\t\tTThrowOnError,\n\t\tTResponseType,\n\t\tTPluginArray,\n\t\tTSchemas\n\t>;\n\nexport type CallApiParameters<\n\tTData = DefaultDataType,\n\tTErrorData = DefaultDataType,\n\tTResultMode extends ResultModeUnion = ResultModeUnion,\n\tTThrowOnError extends boolean = DefaultThrowOnError,\n\tTResponseType extends ResponseTypeUnion = ResponseTypeUnion,\n\tTPluginArray extends CallApiPlugin[] = DefaultPluginArray,\n\tTSchemas extends CallApiSchemas = DefaultMoreOptions,\n> = [\n\tinitURL: InferSchemaResult<TSchemas[\"initURL\"], InitURL>,\n\tconfig?: CallApiConfig<\n\t\tTData,\n\t\tTErrorData,\n\t\tTResultMode,\n\t\tTThrowOnError,\n\t\tTResponseType,\n\t\tTPluginArray,\n\t\tTSchemas\n\t>,\n];\n\nexport type CallApiResult<\n\tTData,\n\tTErrorData,\n\tTResultMode extends ResultModeUnion,\n\tTThrowOnError extends boolean,\n\tTResponseType extends ResponseTypeUnion,\n> = Promise<GetCallApiResult<TData, TErrorData, TResultMode, TThrowOnError, TResponseType>>;\n","import { getAuthHeader } from \"../auth\";\nimport { fetchSpecificKeys } from \"../constants/common\";\nimport {\n\ttype BaseCallApiExtraOptions,\n\ttype CallApiExtraOptions,\n\ttype CallApiRequestOptions,\n\toptionsEnumToOmitFromBase,\n} from \"../types/common\";\nimport { isFunction, isJsonString, isPlainObject, isQueryString, isSerializable } from \"./guards\";\n\nexport const omitKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TOmitArray extends Array<keyof TObject>,\n>(\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\nexport const pickKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TPickArray extends Array<keyof TObject>,\n>(\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\ntype ToQueryStringFn = {\n\t(params: CallApiExtraOptions[\"query\"]): string | null;\n\t(params: Required<CallApiExtraOptions>[\"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\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 MergeAndResolveHeadersOptions = {\n\tauth: CallApiExtraOptions[\"auth\"];\n\tbaseHeaders?: CallApiRequestOptions[\"headers\"];\n\tbody: CallApiRequestOptions[\"body\"];\n\theaders: CallApiRequestOptions[\"headers\"];\n};\n\nexport const getHeaders = async (options: MergeAndResolveHeadersOptions) => {\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...(await 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 (isSerializable(body) || isJsonString(body)) {\n\t\theadersObject[\"Content-Type\"] = \"application/json\";\n\t\theadersObject.Accept = \"application/json\";\n\t}\n\n\treturn headersObject;\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\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\nexport const createCombinedSignal = (...signals: Array<AbortSignal | null | undefined>) => {\n\tconst cleanedSignals = signals.filter(Boolean);\n\n\tconst combinedSignal = AbortSignal.any(cleanedSignals);\n\n\treturn combinedSignal;\n};\n\nexport const createTimeoutSignal = (milliseconds: number) => AbortSignal.timeout(milliseconds);\n"]}
|