@zayne-labs/callapi 1.12.5 → 1.12.6

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defaults-IsBgvt90.js","names":[],"sources":["../src/types/type-helpers.ts","../src/utils/guards.ts","../src/auth.ts","../src/constants/common.ts","../src/constants/validation.ts","../src/utils/external/error.ts","../src/validation.ts","../src/url.ts","../src/utils/external/body.ts","../src/utils/external/define.ts","../src/utils/external/guards.ts","../src/utils/external/headers.ts","../src/utils/common.ts","../src/constants/defaults.ts"],"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 & NonNullable<unknown>;\nexport type AnyNumber = number & NonNullable<unknown>;\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 Prettify<TObject> = NonNullable<unknown> & { [Key in keyof TObject]: TObject[Key] };\n\ntype WriteableLevel = \"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[] | readonly unknown[];\n\nexport type Writeable<TObject, TLevel extends WriteableLevel = \"shallow\"> =\n\tTObject extends ArrayOrObject ?\n\t\t{\n\t\t\t-readonly [Key in keyof TObject]: TLevel extends \"deep\" ?\n\t\t\t\tNonNullable<TObject[Key]> extends ArrayOrObject ?\n\t\t\t\t\tWriteable<TObject[Key], \"deep\">\n\t\t\t\t:\tTObject[Key]\n\t\t\t:\tTObject[Key];\n\t\t}\n\t:\tTObject;\n\nexport const defineEnum = <const TValue extends object>(value: TValue) =>\n\tObject.freeze(value) as Readonly<Writeable<TValue>>;\n\nexport type UnionToIntersection<TUnion> =\n\t(TUnion extends unknown ? (param: TUnion) => void : never) extends (param: infer TParam) => void ?\n\t\tTParam\n\t:\tnever;\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> = { value: TValue }[\"value\"];\n\n/**\n * @description Userland implementation of NoInfer intrinsic type, but this one doesn't show up on hover like the intrinsic one\n *\n * Prevents TypeScript from inferring `TGeneric` at this position by creating a circular dependency.\n * The tuple index `[TGeneric extends unknown ? 0 : never]` depends on `TGeneric`, forcing TS to\n * skip this site for inference and use other arguments or defaults instead.\n */\nexport type NoInferUnMasked<TGeneric> = [TGeneric][TGeneric extends unknown ? 0 : never];\n\ntype RemoveSlashImpl<TUrl extends string, TDirection extends \"leading\" | \"trailing\"> =\n\tTDirection extends \"leading\" ?\n\t\tTUrl extends `/${infer TWithoutLeadingSlash}` ?\n\t\t\tTWithoutLeadingSlash\n\t\t:\tTUrl\n\t: TDirection extends \"trailing\" ?\n\t\tTUrl extends `${infer TWithoutTailingSlash}/` ?\n\t\t\tTWithoutTailingSlash\n\t\t:\tTUrl\n\t:\tnever;\n\nexport type RemoveTrailingSlash<TUrl extends string> = RemoveSlashImpl<TUrl, \"trailing\">;\nexport type RemoveLeadingSlash<TUrl extends string> = RemoveSlashImpl<TUrl, \"leading\">;\n\nexport type Awaitable<TValue> = Promise<TValue> | TValue;\n\n// export type MatchExactObjectType<TActualObject extends TExpectedObject, TExpectedObject> = {\n// \t[Key in keyof TActualObject]: Key extends keyof TExpectedObject ? TActualObject[Key] : never;\n// };\n\nexport type Satisfies<TActualType extends TExpectedTypeShape, TExpectedTypeShape> = {\n\t[Key in keyof TActualType]: Key extends keyof TExpectedTypeShape ? TActualType[Key] : never;\n};\n\n// export type Satisfies<TActualObject extends TExpectedObject, TExpectedObject> = {\n// \t[Key in keyof TActualObject & keyof TExpectedObject]: TActualObject[Key];\n// };\n\nexport type DistributiveOmit<TObject, TKeysToOmit extends keyof TObject> =\n\tTObject extends unknown ? Omit<TObject, TKeysToOmit> : never;\n\nexport type DistributivePick<TObject, TKeysToPick extends keyof TObject> =\n\tTObject extends unknown ? Pick<TObject, TKeysToPick> : never;\n\ntype ErrorMessages<TType extends number | string | symbol = never> = Partial<\n\tRecord<\"$all\" | number | symbol | (AnyString | TType), unknown>\n> | null;\n\n/**\n * Type utility that takes two types and allows only the properties of the first type. The properties of the second will be disallowed (typed as `never` by default or a custom message).\n *\n * @template TFirstType The first type. Properties of this type will be required.\n * @template TSecondType The second type. Properties of this type will be disallowed.\n * @template TErrorMessages An object of custom messages to display on the properties of the second type that are disallowed.\n */\ntype AllowOnlyFirst<TFirstType, TSecondType, TErrorMessages extends ErrorMessages = never> = Prettify<\n\tTFirstType & {\n\t\t[Key in keyof Omit<TSecondType, keyof TFirstType>]?: Key extends keyof TErrorMessages ?\n\t\t\tTErrorMessages[Key]\n\t\t: \"$all\" extends keyof TErrorMessages ? TErrorMessages[\"$all\"]\n\t\t: TErrorMessages extends null ? TErrorMessages\n\t\t: never;\n\t}\n>;\n\n/**\n * Merges all types in an array of types into one type.\n *\n * @template TArrayOfTypes Array of types to merge\n * @template TAccumulator Accumulator for the resulting merged type\n */\ntype MergeTypes<TArrayOfTypes extends unknown[], TAccumulator = NonNullable<unknown>> =\n\tTArrayOfTypes extends [infer TFirstType, ...infer TRestOfTypes] ?\n\t\tMergeTypes<\n\t\t\tTRestOfTypes,\n\t\t\t{ [Key in keyof TAccumulator | keyof TFirstType]: (TAccumulator & TFirstType)[Key] }\n\t\t>\n\t:\tTAccumulator;\n\n/**\n * Type utility that extracts discriminated properties from a union of types.\n * Takes an array of types and returns a union of types where each type has unique properties.\n *\n * @template TArrayOfTypes Array of types to process\n * @template TErrorMessages An object of custom messages to display on the properties that are disallowed.\n * @template TAccumulator Accumulator for the resulting union\n * @template TMergedProperties Merged properties from all types\n */\n\nexport type UnionDiscriminator<\n\tTArrayOfTypes extends unknown[],\n\tTErrorMessages extends ErrorMessages<keyof MergeTypes<TArrayOfTypes>> = never,\n\tTAccumulator = never,\n\tTMergedProperties = MergeTypes<TArrayOfTypes>,\n> =\n\tTArrayOfTypes extends [infer TFirstType, ...infer TRestOfTypes] ?\n\t\tUnionDiscriminator<\n\t\t\tTRestOfTypes,\n\t\t\tTErrorMessages,\n\t\t\t// eslint-disable-next-line perfectionist/sort-union-types -- Let TAccumulator be first\n\t\t\tTAccumulator | AllowOnlyFirst<TFirstType, TMergedProperties, TErrorMessages>,\n\t\t\tTMergedProperties\n\t\t>\n\t:\tTAccumulator;\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 { AnyFunction } from \"../types/type-helpers\";\n\nexport const isArray = <TArrayItem>(value: unknown): value is TArrayItem[] => Array.isArray(value);\n\nexport const isBoolean = (value: unknown): value is boolean => typeof value === \"boolean\";\n\nexport const isBlob = (value: unknown): value is Blob => value instanceof Blob;\n\nexport const isObject = <TObject extends object>(value: unknown): value is TObject => {\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 isValidJsonString = (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 isSerializableObject = (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\treturn typeof value === \"function\";\n};\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 isPromise = (value: unknown) => value instanceof Promise;\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\tvalue?.constructor.name === \"Object\"\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 { CallApiExtraOptions } from \"./types/options-types\";\nimport type { Awaitable } from \"./types/type-helpers\";\nimport { isFunction, isObject, isPromise } from \"./utils/guards\";\n\ntype PossibleAuthValue = Awaitable<string | null | undefined>;\n\ntype PossibleAuthValueOrGetter = PossibleAuthValue | (() => PossibleAuthValue);\n\n// export type BearerOrTokenAuth =\n// \t| {\n// \t\t\ttype?: \"Bearer\" | undefined;\n// \t\t\tbearer?: PossibleAuthValueOrGetter;\n// \t\t\ttoken?: never;\n// \t }\n// \t| {\n// \t\t\ttype?: \"Token\";\n// \t\t\tbearer?: never;\n// \t\t\ttoken?: PossibleAuthValueOrGetter;\n// \t };\n\nexport type BearerAuth = {\n\ttype: \"Bearer\";\n\tvalue: PossibleAuthValueOrGetter;\n};\n\nexport type TokenAuth = {\n\ttype: \"Token\";\n\tvalue: PossibleAuthValueOrGetter;\n};\n\nexport type BasicAuth = {\n\ttype: \"Basic\";\n\tusername: PossibleAuthValueOrGetter;\n\tpassword: PossibleAuthValueOrGetter;\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: PossibleAuthValueOrGetter;\n\tvalue: PossibleAuthValueOrGetter;\n};\n\n// eslint-disable-next-line perfectionist/sort-union-types -- Let the first one be first\nexport type AuthOption = PossibleAuthValueOrGetter | BearerAuth | TokenAuth | BasicAuth | CustomAuth;\n\nconst resolveAuthValue = (value: PossibleAuthValueOrGetter) => (isFunction(value) ? value() : value);\n\ntype AuthHeaderObject = { Authorization: string };\n\nexport const getAuthHeader = async (\n\tauth: CallApiExtraOptions[\"auth\"]\n): Promise<AuthHeaderObject | undefined> => {\n\tif (auth === undefined) return;\n\n\tif (isPromise(auth) || isFunction(auth) || !isObject(auth)) {\n\t\tconst authValue = await resolveAuthValue(auth);\n\n\t\tif (authValue === undefined) return;\n\n\t\treturn {\n\t\t\tAuthorization: `Bearer ${authValue}`,\n\t\t};\n\t}\n\n\tswitch (auth.type) {\n\t\tcase \"Basic\": {\n\t\t\tconst [username, password] = await Promise.all([\n\t\t\t\tresolveAuthValue(auth.username),\n\t\t\t\tresolveAuthValue(auth.password),\n\t\t\t]);\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\t\tcase \"Bearer\": {\n\t\t\tconst value = await resolveAuthValue(auth.value);\n\n\t\t\tif (value === undefined) return;\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `Bearer ${value}`,\n\t\t\t};\n\t\t}\n\t\tcase \"Custom\": {\n\t\t\tconst [prefix, value] = await Promise.all([\n\t\t\t\tresolveAuthValue(auth.prefix),\n\t\t\t\tresolveAuthValue(auth.value),\n\t\t\t]);\n\n\t\t\tif (value === undefined) return;\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `${prefix} ${value}`,\n\t\t\t};\n\t\t}\n\n\t\tcase \"Token\": {\n\t\t\tconst value = await resolveAuthValue(auth.value);\n\n\t\t\tif (value === undefined) return;\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `Token ${value}`,\n\t\t\t};\n\t\t}\n\n\t\tdefault: {\n\t\t\tauth satisfies never;\n\t\t\treturn undefined;\n\t\t}\n\n\t\t// default: {\n\t\t// \tconst [bearer, token] = await Promise.all([\n\t\t// \t\tresolveAuthValue(auth.bearer),\n\t\t// \t\tresolveAuthValue(auth.token),\n\t\t// \t]);\n\n\t\t// \tif (bearer !== undefined) {\n\t\t// \t\treturn { Authorization: `Bearer ${bearer}` };\n\t\t// \t}\n\n\t\t// \tif (token === undefined) return;\n\n\t\t// \treturn { Authorization: `Token ${token}` };\n\t\t// }\n\t}\n};\n","import type { ModifiedRequestInit } from \"../types/options-types\";\nimport { defineEnum } from \"../types/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\t\"extraFetchOptions\",\n] satisfies Array<keyof ModifiedRequestInit> as Array<keyof ModifiedRequestInit>);\n","export const fallBackRouteSchemaKey = \"@default\";\n\nexport type FallBackRouteSchemaKey = typeof fallBackRouteSchemaKey;\n","import { extraOptionDefaults } from \"../../constants/defaults\";\nimport type { CallApiExtraOptions } from \"../../types/options-types\";\nimport type { StandardSchemaV1 } from \"../../types/standard-schema\";\nimport type { CallApiSchema, CallApiSchemaConfig } from \"../../validation\";\nimport { isObject, isString } from \"../guards\";\n\ntype HTTPErrorDetails<TErrorData> = Pick<CallApiExtraOptions, \"defaultHTTPErrorMessage\"> & {\n\terrorData: TErrorData;\n\tresponse: Response;\n};\n\nconst httpErrorSymbol = Symbol(\"HTTPError\");\n\nexport class HTTPError<TErrorData = Record<string, unknown>> extends Error {\n\terrorData: HTTPErrorDetails<TErrorData>[\"errorData\"];\n\n\treadonly httpErrorSymbol = httpErrorSymbol;\n\n\toverride name = \"HTTPError\" as const;\n\n\tresponse: HTTPErrorDetails<TErrorData>[\"response\"];\n\n\tconstructor(errorDetails: HTTPErrorDetails<TErrorData>, errorOptions?: ErrorOptions) {\n\t\tconst { defaultHTTPErrorMessage, errorData, response } = errorDetails;\n\n\t\tconst resolvedDefaultHTTPErrorMessage =\n\t\t\tisString(defaultHTTPErrorMessage) ? defaultHTTPErrorMessage : (\n\t\t\t\tdefaultHTTPErrorMessage?.({ errorData, response })\n\t\t\t);\n\n\t\tconst selectedDefaultErrorMessage =\n\t\t\tresolvedDefaultHTTPErrorMessage\n\t\t\t?? (response.statusText || extraOptionDefaults.defaultHTTPErrorMessage);\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}\n\n\t/**\n\t * @description Checks if the given error is an instance of HTTPError\n\t * @param error - The error to check\n\t * @returns true if the error is an instance of HTTPError, false otherwise\n\t */\n\tstatic override isError<TErrorData>(error: unknown): error is HTTPError<TErrorData> {\n\t\tif (!isObject<HTTPError>(error)) {\n\t\t\treturn false;\n\t\t}\n\n\t\tif (error instanceof HTTPError) {\n\t\t\treturn true;\n\t\t}\n\n\t\tconst actualError = error as HTTPError;\n\n\t\treturn (\n\t\t\tactualError.httpErrorSymbol === httpErrorSymbol\n\t\t\t// eslint-disable-next-line ts-eslint/no-unnecessary-condition -- Allow\n\t\t\t&& actualError.name === \"HTTPError\"\n\t\t);\n\t}\n}\n\nconst prettifyPath = (path: ValidationError[\"errorData\"][number][\"path\"]) => {\n\tif (!path || path.length === 0) {\n\t\treturn \"\";\n\t}\n\n\tconst pathString = path.map((segment) => (isObject(segment) ? segment.key : segment)).join(\".\");\n\n\treturn ` → at ${pathString}`;\n};\n\nconst prettifyValidationIssues = (issues: ValidationError[\"errorData\"]) => {\n\tconst issuesString = issues.map((issue) => `✖ ${issue.message}${prettifyPath(issue.path)}`).join(\" | \");\n\n\treturn issuesString;\n};\n\ntype SafeExtract<TUnion, TKey extends TUnion> = Extract<TUnion, TKey>;\n\ntype ValidationErrorDetails = {\n\t/**\n\t * The cause of the validation error.\n\t *\n\t * It's either the name the schema for which validation failed, or the name of the schema config option that led to the validation error.\n\t */\n\tissueCause:\n\t\t| \"toFormData\"\n\t\t| \"toQueryString\"\n\t\t| \"unknown\"\n\t\t| `schemaConfig-(${SafeExtract<keyof CallApiSchemaConfig, \"strict\">})`\n\t\t| keyof CallApiSchema;\n\n\t/**\n\t * The issues that caused the validation error.\n\t */\n\tissues: readonly StandardSchemaV1.Issue[];\n\n\t/**\n\t * The response from server, if any.\n\t */\n\tresponse: Response | null;\n};\n\nconst validationErrorSymbol = Symbol(\"ValidationErrorSymbol\");\n\nexport class ValidationError extends Error {\n\terrorData: ValidationErrorDetails[\"issues\"];\n\n\tissueCause: ValidationErrorDetails[\"issueCause\"];\n\n\toverride name = \"ValidationError\" as const;\n\n\tresponse: ValidationErrorDetails[\"response\"];\n\n\treadonly validationErrorSymbol = validationErrorSymbol;\n\n\tconstructor(details: ValidationErrorDetails, errorOptions?: ErrorOptions) {\n\t\tconst { issueCause, issues, response } = details;\n\n\t\tconst prettyMessage = prettifyValidationIssues(issues);\n\n\t\tconst message = `(${issueCause.toUpperCase()}) - ${prettyMessage}`;\n\n\t\tsuper(message, errorOptions);\n\n\t\tthis.errorData = issues;\n\t\tthis.response = response;\n\t\tthis.issueCause = issueCause;\n\t}\n\n\t/**\n\t * @description Checks if the given error is an instance of ValidationError\n\t * @param error - The error to check\n\t * @returns true if the error is an instance of ValidationError, false otherwise\n\t */\n\tstatic override isError(error: unknown): error is ValidationError {\n\t\tif (!isObject<ValidationError>(error)) {\n\t\t\treturn false;\n\t\t}\n\n\t\tif (error instanceof ValidationError) {\n\t\t\treturn true;\n\t\t}\n\n\t\tconst actualError = error as ValidationError;\n\n\t\treturn (\n\t\t\tactualError.validationErrorSymbol === validationErrorSymbol\n\t\t\t// eslint-disable-next-line ts-eslint/no-unnecessary-condition -- Allow\n\t\t\t&& actualError.name === \"ValidationError\"\n\t\t);\n\t}\n}\n","import type { AuthOption } from \"./auth\";\nimport { fallBackRouteSchemaKey, type FallBackRouteSchemaKey } from \"./constants/validation\";\nimport type { Body, HeadersOption, MethodUnion } from \"./types/conditional-types\";\nimport type {\n\tBaseCallApiExtraOptions,\n\tCallApiExtraOptions,\n\tCallApiRequestOptions,\n\tGlobalMeta,\n} from \"./types/options-types\";\nimport type { StandardSchemaV1 } from \"./types/standard-schema\";\nimport {\n\tdefineEnum,\n\ttype AnyFunction,\n\ttype AnyString,\n\ttype Awaitable,\n\ttype UnionDiscriminator,\n\ttype UnionToIntersection,\n} from \"./types/type-helpers\";\nimport {\n\tatSymbol,\n\textractMethodFromURL,\n\tnormalizeURL,\n\ttype AtSymbol,\n\ttype Params,\n\ttype Query,\n} from \"./url\";\nimport { ValidationError } from \"./utils/external/error\";\nimport { isArray, isFunction, isObject } from \"./utils/guards\";\n\ntype ResultVariant = \"infer-input\" | \"infer-output\";\n\nexport type InferSchemaResult<TSchema, TFallbackResult, TResultVariant extends ResultVariant> =\n\t// == Checking for undefined first and returning fallback to avoid type errors when passing the config around (weird tbh)\n\tundefined extends TSchema ? TFallbackResult\n\t: TSchema extends StandardSchemaV1 ?\n\t\tTResultVariant extends \"infer-input\" ?\n\t\t\tStandardSchemaV1.InferInput<TSchema>\n\t\t:\tStandardSchemaV1.InferOutput<TSchema>\n\t: TSchema extends AnyFunction<infer TResult> ? Awaited<TResult>\n\t: TFallbackResult;\n\nexport type InferSchemaOutput<TSchema, TFallbackResult = unknown> = InferSchemaResult<\n\tTSchema,\n\tTFallbackResult,\n\t\"infer-output\"\n>;\n\nexport type InferSchemaInput<TSchema, TFallbackResult = unknown> = InferSchemaResult<\n\tTSchema,\n\tTFallbackResult,\n\t\"infer-input\"\n>;\n\nconst handleValidatorFunction = <TInput>(\n\tvalidator: AnyFunction,\n\tinputData: TInput\n): Promise<StandardSchemaV1.Result<TInput>> => {\n\tconst result = new Promise((resolve) => resolve(validator(inputData as never)))\n\t\t.then((value) => ({ issues: undefined, value: value as never }))\n\t\t.catch((error) => ({ issues: (isArray(error) ? error : [error]) as never, value: undefined }));\n\n\treturn result;\n};\n\nexport const getValidatedValue = <\n\tTSchema extends AnyFunction | StandardSchemaV1,\n\tTVariant extends \"async\" | \"sync\",\n>(\n\tinputValue: InferSchemaOutput<TSchema>,\n\tschema?: TSchema,\n\t_ignoredOptions?: { variant: TVariant }\n): TVariant extends \"async\" ? Promise<StandardSchemaV1.Result<typeof inputValue>>\n:\tStandardSchemaV1.Result<typeof inputValue> => {\n\tif (!schema) {\n\t\treturn { issues: undefined, value: inputValue } as never;\n\t}\n\n\tconst result =\n\t\tisFunction(schema) ?\n\t\t\thandleValidatorFunction(schema, inputValue)\n\t\t:\tschema[\"~standard\"].validate(inputValue);\n\n\treturn result as never;\n};\n\nconst callApiSchemaParser = async <\n\tTFullSchema extends CallApiSchema,\n\tTSchemaName extends keyof CallApiSchema,\n\tTSchema extends NonNullable<TFullSchema[TSchemaName]>,\n>(\n\tfullSchema: TFullSchema | undefined,\n\tschemaName: TSchemaName,\n\toptions: { inputValue: InferSchemaInput<TSchema>; response?: Response | null }\n): Promise<InferSchemaOutput<TSchema>> => {\n\tconst { inputValue, response } = options;\n\n\tconst schema = fullSchema?.[schemaName];\n\n\tconst result = await getValidatedValue(inputValue, schema);\n\n\tif (result.issues) {\n\t\tthrow new ValidationError({\n\t\t\tissueCause: schemaName,\n\t\t\tissues: result.issues,\n\t\t\tresponse: response ?? null,\n\t\t});\n\t}\n\n\treturn result.value as never;\n};\n\ntype BooleanObject = {\n\t[Key in keyof CallApiSchema]: boolean;\n};\n\nexport interface CallApiSchemaConfig {\n\t/**\n\t * The base url of the schema. By default it's the baseURL of the callApi instance.\n\t */\n\tbaseURL?: \"\" | AnyString;\n\n\t/**\n\t * Disables runtime validation for the schema.\n\t */\n\tdisableRuntimeValidation?: boolean | BooleanObject;\n\n\t/**\n\t * If `true`, the original input value will be used instead of the transformed/validated output.\n\t *\n\t * When true, the original input is returned unchanged after validation, ignoring any schema-level\n\t * transformations such as type coercion, default values, or field mapping. Only the validation\n\t * step is executed; the resulting value is discarded in favor of the raw input.\n\t */\n\tdisableRuntimeValidationTransform?: boolean | BooleanObject;\n\n\t/**\n\t * Optional url prefix that will be substituted for the `baseURL` of the schemaConfig at runtime.\n\t *\n\t * Enables a short, stable prefix for routes while keeping the full `baseURL` centralized in config.\n\t * Keeps route definitions concise and shields them from changes to the underlying base URL.\n\t */\n\tprefix?: \"\" | AnyString;\n\n\t/**\n\t * Controls the strictness of API route validation.\n\t *\n\t * When true:\n\t * - Only routes explicitly defined in the schema will be considered valid to typescript and the runtime.\n\t * - Attempting to call routes not defined in the schema will result in both type errors and runtime validation errors.\n\t * - Useful for ensuring API calls conform exactly to your schema definition\n\t *\n\t * When false or undefined (default):\n\t * - All routes will be allowed, whether they are defined in the schema or not\n\t */\n\tstrict?: boolean;\n}\n\nexport type CallApiSchemaType<TInput> =\n\t| StandardSchemaV1<TInput | undefined>\n\t| ((value: TInput) => Awaitable<TInput | undefined>);\n\nexport interface CallApiSchema {\n\tauth?: CallApiSchemaType<AuthOption>;\n\n\t/**\n\t * The schema to use for validating the request body.\n\t */\n\tbody?: CallApiSchemaType<Body>;\n\n\t/**\n\t * The schema to use for validating the response data.\n\t */\n\tdata?: CallApiSchemaType<unknown>;\n\n\t/**\n\t * The schema to use for validating the response error data.\n\t */\n\terrorData?: CallApiSchemaType<unknown>;\n\n\t/**\n\t * The schema to use for validating the request headers.\n\t */\n\theaders?: CallApiSchemaType<HeadersOption>;\n\n\t/**\n\t * The schema to use for validating the meta option.\n\t */\n\tmeta?: CallApiSchemaType<GlobalMeta>;\n\n\t/**\n\t * The schema to use for validating the request method.\n\t */\n\tmethod?: CallApiSchemaType<MethodUnion>;\n\n\t/**\n\t * The schema to use for validating the request url parameters.\n\t */\n\tparams?: CallApiSchemaType<Params>;\n\n\t/**\n\t * The schema to use for validating the request url queries.\n\t */\n\tquery?: CallApiSchemaType<Query>;\n}\n\nexport const routeKeyMethods = defineEnum([\"delete\", \"get\", \"patch\", \"post\", \"put\"]);\n\nexport type RouteKeyMethods = (typeof routeKeyMethods)[number];\n\nexport type RouteKeyMethodsURLUnion = `${AtSymbol}${RouteKeyMethods}/`;\n\nexport type BaseSchemaRouteKeyPrefixes = FallBackRouteSchemaKey | RouteKeyMethodsURLUnion;\n\nexport type BaseCallApiSchemaRoutes = Partial<\n\tRecord<AnyString | BaseSchemaRouteKeyPrefixes, CallApiSchema>\n>;\n\nexport type BaseCallApiSchemaAndConfig = {\n\tconfig?: CallApiSchemaConfig;\n\troutes: BaseCallApiSchemaRoutes;\n};\n\ntype ValidationOptions<\n\tTSchema extends CallApiSchema[keyof CallApiSchema] = CallApiSchema[keyof CallApiSchema],\n> = {\n\tinputValue: InferSchemaInput<TSchema>;\n\tresponse?: Response | null;\n\tresultMode: CallApiExtraOptions[\"resultMode\"];\n\tschemaConfig: CallApiSchemaConfig | undefined;\n};\n\nexport const handleSchemaValidation = async <\n\tTFullSchema extends CallApiSchema,\n\tTSchemaName extends keyof CallApiSchema,\n\tTSchema extends NonNullable<TFullSchema[TSchemaName]>,\n>(\n\tfullSchema: TFullSchema | undefined,\n\tschemaName: TSchemaName,\n\tvalidationOptions: ValidationOptions<TSchema>\n): Promise<InferSchemaOutput<TSchema>> => {\n\tconst { inputValue, response, resultMode, schemaConfig } = validationOptions;\n\n\t// == If resultMode is set to `fetchApi`, return the input value as is (which is going to be `null` in this)\n\tif (resultMode === \"fetchApi\" && (schemaName === \"data\" || schemaName === \"errorData\")) {\n\t\treturn inputValue;\n\t}\n\n\tconst disableRuntimeValidationBooleanObject =\n\t\tisObject(schemaConfig?.disableRuntimeValidation) ? schemaConfig.disableRuntimeValidation : {};\n\n\tconst shouldDisableRuntimeValidation =\n\t\tschemaConfig?.disableRuntimeValidation === true\n\t\t|| disableRuntimeValidationBooleanObject[schemaName] === true;\n\n\tif (shouldDisableRuntimeValidation) {\n\t\treturn inputValue;\n\t}\n\n\tconst validResult = await callApiSchemaParser(fullSchema, schemaName, { inputValue, response });\n\n\tconst disableResultApplicationBooleanObject =\n\t\tisObject(schemaConfig?.disableRuntimeValidationTransform) ?\n\t\t\tschemaConfig.disableRuntimeValidationTransform\n\t\t:\t{};\n\n\tconst shouldDisableResultApplication =\n\t\tschemaConfig?.disableRuntimeValidationTransform === true\n\t\t|| disableResultApplicationBooleanObject[schemaName] === true;\n\n\tif (shouldDisableResultApplication) {\n\t\treturn inputValue;\n\t}\n\n\treturn validResult;\n};\n\ntype LastOf<TValue> =\n\tUnionToIntersection<TValue extends unknown ? () => TValue : never> extends () => infer R ? R : never;\n\ntype Push<TArray extends unknown[], TArrayItem> = [...TArray, TArrayItem];\n\ntype UnionToTupleImpl<\n\tTUnion,\n\tTComputedLastUnion = LastOf<TUnion>,\n\tTComputedIsUnionEqualToNever = [TUnion] extends [never] ? true : false,\n> =\n\ttrue extends TComputedIsUnionEqualToNever ? []\n\t:\tPush<UnionToTupleImpl<Exclude<TUnion, TComputedLastUnion>>, TComputedLastUnion>;\n\nexport type UnionToTuple<TUnion, TArray extends TUnion[] = []> =\n\tUnionToTupleImpl<TUnion>[\"length\"] extends TArray[\"length\"] ? [...TArray]\n\t:\tUnionToTuple<TUnion, [TUnion, ...TArray]>;\n\ntype ExtraOptionsValidationOptions = {\n\toptions: CallApiExtraOptions;\n};\n\nconst extraOptionsToBeValidated = [\"meta\", \"params\", \"query\", \"auth\"] satisfies UnionToTuple<\n\tExtract<keyof CallApiSchema, keyof CallApiExtraOptions>\n>;\n\ntype RequestOptionsValidationOptions = {\n\trequest: CallApiRequestOptions;\n};\n\nconst requestOptionsToBeValidated = [\"body\", \"headers\", \"method\"] satisfies UnionToTuple<\n\tExtract<keyof CallApiSchema, keyof CallApiRequestOptions>\n>;\n\ntype OptionValidationOptions = UnionDiscriminator<\n\t[ExtraOptionsValidationOptions, RequestOptionsValidationOptions]\n> & {\n\tschema: CallApiSchema | undefined;\n\tschemaConfig: CallApiSchemaConfig | undefined;\n};\n\nconst handleOptionsValidation = async <TValidationOptions extends OptionValidationOptions>(\n\tvalidationOptions: TValidationOptions\n): Promise<\n\tundefined extends TValidationOptions[\"options\"] ?\n\t\tPick<CallApiRequestOptions, (typeof requestOptionsToBeValidated)[number]>\n\t:\tPick<CallApiExtraOptions, (typeof extraOptionsToBeValidated)[number]>\n> => {\n\tconst { options, request, schema, schemaConfig } = validationOptions;\n\n\tconst resolvedOptionsToBeValidated = options ? extraOptionsToBeValidated : requestOptionsToBeValidated;\n\n\tconst resolvedOptions = options ?? request;\n\n\tconst validationResultArray = await Promise.all(\n\t\tresolvedOptionsToBeValidated.map((schemaName) =>\n\t\t\thandleSchemaValidation(schema, schemaName, {\n\t\t\t\tinputValue: resolvedOptions[schemaName as keyof typeof resolvedOptions],\n\t\t\t\tresultMode: options?.resultMode,\n\t\t\t\tschemaConfig,\n\t\t\t})\n\t\t)\n\t);\n\n\tconst validatedResultObject: Record<string, unknown> = {};\n\n\tfor (const [index, schemaName] of resolvedOptionsToBeValidated.entries()) {\n\t\tconst validationResult = validationResultArray[index];\n\n\t\tif (validationResult === undefined) continue;\n\n\t\tvalidatedResultObject[schemaName] = validationResult;\n\t}\n\n\treturn validatedResultObject;\n};\n\nexport const handleConfigValidation = async (\n\tvalidationOptions: ExtraOptionsValidationOptions\n\t\t& GetResolvedSchemaContext\n\t\t& RequestOptionsValidationOptions\n) => {\n\tconst { baseExtraOptions, currentRouteSchemaKey, extraOptions, options, request } = validationOptions;\n\n\tconst { currentRouteSchema, resolvedSchema } = getResolvedSchema({\n\t\tbaseExtraOptions,\n\t\tcurrentRouteSchemaKey,\n\t\textraOptions,\n\t});\n\n\tconst resolvedSchemaConfig = getResolvedSchemaConfig({ baseExtraOptions, extraOptions });\n\n\tif (resolvedSchemaConfig?.strict === true && !currentRouteSchema) {\n\t\tthrow new ValidationError({\n\t\t\tissueCause: \"schemaConfig-(strict)\",\n\t\t\tissues: [{ message: `Strict Mode - No schema found for route '${currentRouteSchemaKey}' ` }],\n\t\t\tresponse: null,\n\t\t});\n\t}\n\n\tif (!resolvedSchema) {\n\t\treturn {\n\t\t\textraOptionsValidationResult: {} as Awaited<ReturnType<typeof handleOptionsValidation>>,\n\t\t\trequestOptionsValidationResult: {} as Awaited<ReturnType<typeof handleOptionsValidation>>,\n\t\t\tresolvedSchema,\n\t\t\tresolvedSchemaConfig,\n\t\t};\n\t}\n\n\tconst [extraOptionsValidationResult, requestOptionsValidationResult] = await Promise.all([\n\t\thandleOptionsValidation({\n\t\t\toptions,\n\t\t\tschema: resolvedSchema,\n\t\t\tschemaConfig: resolvedSchemaConfig,\n\t\t}),\n\t\thandleOptionsValidation({\n\t\t\trequest,\n\t\t\tschema: resolvedSchema,\n\t\t\tschemaConfig: resolvedSchemaConfig,\n\t\t}),\n\t]);\n\n\treturn {\n\t\textraOptionsValidationResult,\n\t\trequestOptionsValidationResult,\n\t\tresolvedSchema,\n\t\tresolvedSchemaConfig,\n\t};\n};\n\ntype GetResolvedSchemaContext = {\n\tbaseExtraOptions: BaseCallApiExtraOptions;\n\tcurrentRouteSchemaKey: string;\n\textraOptions: CallApiExtraOptions;\n};\n\nexport const getResolvedSchema = (context: GetResolvedSchemaContext) => {\n\tconst { baseExtraOptions, currentRouteSchemaKey, extraOptions } = context;\n\n\tconst fallbackRouteSchema = baseExtraOptions.schema?.routes[fallBackRouteSchemaKey];\n\tconst currentRouteSchema = baseExtraOptions.schema?.routes[currentRouteSchemaKey];\n\n\tconst resolvedRouteSchema = {\n\t\t...fallbackRouteSchema,\n\t\t// == Current route schema takes precedence over fallback route schema\n\t\t...currentRouteSchema,\n\t} satisfies CallApiSchema as CallApiSchema | undefined;\n\n\tconst resolvedSchema =\n\t\tisFunction(extraOptions.schema) ?\n\t\t\textraOptions.schema({\n\t\t\t\tbaseSchemaRoutes: baseExtraOptions.schema?.routes ?? {},\n\t\t\t\tcurrentRouteSchema: resolvedRouteSchema ?? {},\n\t\t\t\tcurrentRouteSchemaKey,\n\t\t\t})\n\t\t:\t(extraOptions.schema ?? resolvedRouteSchema);\n\n\treturn { currentRouteSchema, resolvedSchema };\n};\n\nexport const getResolvedSchemaConfig = (\n\tcontext: Omit<GetResolvedSchemaContext, \"currentRouteSchemaKey\">\n) => {\n\tconst { baseExtraOptions, extraOptions } = context;\n\n\tconst resolvedSchemaConfig =\n\t\tisFunction(extraOptions.schemaConfig) ?\n\t\t\textraOptions.schemaConfig({ baseSchemaConfig: baseExtraOptions.schema?.config ?? {} })\n\t\t:\t(extraOptions.schemaConfig ?? baseExtraOptions.schema?.config);\n\n\treturn resolvedSchemaConfig;\n};\n\nconst removeLeadingSlash = (value: string) => (value.startsWith(\"/\") ? value.slice(1) : value);\n\nconst extractURLParts = (initURL: string) => {\n\treturn {\n\t\tmethodFromURL: extractMethodFromURL(initURL),\n\t\tpathWithoutMethod: normalizeURL(initURL, { retainLeadingSlashForRelativeURLs: false }),\n\t};\n};\n\nconst mergeURLParts = (options: { method: string | undefined; path: string }): string => {\n\tconst { method, path } = options;\n\n\treturn method ? `${atSymbol}${method}/${removeLeadingSlash(path)}` : path;\n};\n\nexport const getCurrentRouteSchemaKeyAndMainInitURL = (\n\tcontext: Pick<GetResolvedSchemaContext, \"baseExtraOptions\" | \"extraOptions\"> & { initURL: string }\n) => {\n\tconst { baseExtraOptions, extraOptions, initURL } = context;\n\n\tconst schemaConfig = getResolvedSchemaConfig({ baseExtraOptions, extraOptions });\n\n\tlet currentRouteSchemaKey = initURL;\n\tlet mainInitURL = initURL;\n\n\tconst { methodFromURL, pathWithoutMethod } = extractURLParts(initURL);\n\n\tconst prefixWithoutLeadingSlash = schemaConfig?.prefix && removeLeadingSlash(schemaConfig.prefix);\n\n\tif (prefixWithoutLeadingSlash && pathWithoutMethod.startsWith(prefixWithoutLeadingSlash)) {\n\t\tconst restOfPathWithoutPrefix = pathWithoutMethod.slice(prefixWithoutLeadingSlash.length);\n\n\t\tcurrentRouteSchemaKey = mergeURLParts({ method: methodFromURL, path: restOfPathWithoutPrefix });\n\n\t\tconst pathWithReplacedPrefix = pathWithoutMethod.replace(\n\t\t\tprefixWithoutLeadingSlash,\n\t\t\tschemaConfig.baseURL ?? \"\"\n\t\t);\n\n\t\tmainInitURL = mergeURLParts({ method: methodFromURL, path: pathWithReplacedPrefix });\n\t}\n\n\tif (schemaConfig?.baseURL && pathWithoutMethod.startsWith(schemaConfig.baseURL)) {\n\t\tconst restOfPathWithoutBaseURL = pathWithoutMethod.slice(schemaConfig.baseURL.length);\n\n\t\tcurrentRouteSchemaKey = mergeURLParts({ method: methodFromURL, path: restOfPathWithoutBaseURL });\n\t}\n\n\treturn { currentRouteSchemaKey, initURL, mainInitURL };\n};\n","import { extraOptionDefaults } from \"./constants\";\nimport type { CallApiExtraOptions } from \"./types/options-types\";\nimport type { AnyString, UnmaskType } from \"./types/type-helpers\";\nimport { isArray } from \"./utils/guards\";\nimport { routeKeyMethods, type RouteKeyMethodsURLUnion } from \"./validation\";\n\nconst handleArrayParams = (url: string, params: Extract<CallApiExtraOptions[\"params\"], unknown[]>) => {\n\tlet newUrl = url;\n\n\tconst urlParts = newUrl.split(\"/\");\n\n\t// == Find all parameters in order (both :param and {param} patterns)\n\tconst matchedParamsArray: string[] = [];\n\n\tfor (const part of urlParts) {\n\t\tconst isMatch = part.startsWith(\":\") || (part.startsWith(\"{\") && part.endsWith(\"}\"));\n\n\t\tif (!isMatch) continue;\n\n\t\tmatchedParamsArray.push(part);\n\t}\n\n\tfor (const [paramIndex, matchedParam] of matchedParamsArray.entries()) {\n\t\tconst stringParamValue = String(params[paramIndex]);\n\t\tnewUrl = newUrl.replace(matchedParam, stringParamValue);\n\t}\n\n\treturn newUrl;\n};\n\nconst handleObjectParams = (\n\turl: string,\n\tparams: Extract<CallApiExtraOptions[\"params\"], Record<string, unknown>>\n) => {\n\tlet newUrl = url;\n\n\tfor (const [paramKey, paramValue] of Object.entries(params)) {\n\t\t// == Replace both :param and {param} patterns\n\t\tconst colonPattern = `:${paramKey}` as const;\n\t\tconst bracePattern = `{${paramKey}}` as const;\n\n\t\tconst stringValue = String(paramValue);\n\n\t\tnewUrl = newUrl.replace(colonPattern, stringValue);\n\t\tnewUrl = newUrl.replace(bracePattern, stringValue);\n\t}\n\n\treturn newUrl;\n};\n\nconst mergeUrlWithParams = (url: string, params: CallApiExtraOptions[\"params\"]) => {\n\tif (!params) {\n\t\treturn url;\n\t}\n\n\tconst newUrl = isArray(params) ? handleArrayParams(url, params) : handleObjectParams(url, params);\n\n\treturn newUrl;\n};\n\nconst mergeUrlWithQuery = (url: string, query: CallApiExtraOptions[\"query\"]): string => {\n\tif (!query) {\n\t\treturn url;\n\t}\n\n\tconst queryString = new URLSearchParams(query as Record<string, string> | URLSearchParams).toString();\n\n\tif (queryString.length === 0) {\n\t\treturn url;\n\t}\n\n\tif (url.endsWith(\"?\")) {\n\t\treturn `${url}${queryString}`;\n\t}\n\n\tif (url.includes(\"?\")) {\n\t\treturn `${url}&${queryString}`;\n\t}\n\n\treturn `${url}?${queryString}`;\n};\n\n/**\n * @description Extracts the HTTP method from method-prefixed route patterns.\n *\n * Analyzes URLs that start with method modifiers (e.g., \"@get/\", \"@post/\") and extracts\n * the HTTP method for use in API requests. This enables method specification directly\n * in route definitions.\n *\n * @param initURL - The URL string to analyze for method modifiers\n * @returns The extracted HTTP method (lowercase) if found, otherwise undefined\n *\n * @example\n * ```typescript\n * extractMethodFromURL(\"@get/users\"); // Returns: \"get\"\n * extractMethodFromURL(\"@post/users\"); // Returns: \"post\"\n * ```\n */\nexport const extractMethodFromURL = (initURL: string | undefined) => {\n\tif (!initURL?.startsWith(\"@\")) return;\n\n\tconst methodFromURL = routeKeyMethods.find((method) => initURL.startsWith(`@${method}/`));\n\n\tif (!methodFromURL) return;\n\n\treturn methodFromURL;\n};\n\ntype NormalizeURLOptions = {\n\tretainLeadingSlashForRelativeURLs?: boolean;\n};\n\nexport const atSymbol = \"@\";\nexport type AtSymbol = typeof atSymbol;\n\nexport const normalizeURL = (initURL: string, options: NormalizeURLOptions = {}) => {\n\tconst { retainLeadingSlashForRelativeURLs = true } = options;\n\n\tconst methodFromURL = extractMethodFromURL(initURL);\n\n\tif (!methodFromURL) {\n\t\treturn initURL;\n\t}\n\n\tconst normalizedURL =\n\t\tretainLeadingSlashForRelativeURLs && !initURL.includes(\"http\") ?\n\t\t\tinitURL.replace(`@${methodFromURL}`, \"\")\n\t\t:\tinitURL.replace(`@${methodFromURL}/`, \"\");\n\n\treturn normalizedURL;\n};\n\ntype GetFullURLOptions = {\n\tbaseURL: string | undefined;\n\tinitURL: string;\n\tparams: CallApiExtraOptions[\"params\"];\n\tquery: CallApiExtraOptions[\"query\"];\n};\n\nconst getFullURL = (initURL: string, baseURL: string | undefined) => {\n\tif (!baseURL || initURL.startsWith(\"http\")) {\n\t\treturn initURL;\n\t}\n\n\tconst shouldAddSlash = initURL.length > 0 && !initURL.startsWith(\"/\") && !baseURL.endsWith(\"/\");\n\n\treturn shouldAddSlash ? `${baseURL}/${initURL}` : `${baseURL}${initURL}`;\n};\n\nexport const getFullAndNormalizedURL = (\n\toptions: GetFullURLOptions & {\n\t\tdebugMode: CallApiExtraOptions[\"debugMode\"];\n\t}\n) => {\n\tconst { baseURL, debugMode, initURL, params, query } = options;\n\n\tconst normalizedInitURL = normalizeURL(initURL);\n\n\tconst fullURL = getFullURL(\n\t\tmergeUrlWithQuery(mergeUrlWithParams(normalizedInitURL, params), query),\n\t\tbaseURL\n\t);\n\n\tif ((debugMode ?? extraOptionDefaults.debugMode) && !URL.canParse(fullURL)) {\n\t\tconst errorMessage =\n\t\t\t!baseURL ?\n\t\t\t\t`Invalid URL '${initURL}'. Are you passing a relative url to CallApi without setting the 'baseURL' option?`\n\t\t\t:\t`Invalid URL '${fullURL}'. Please validate that you are passing the correct url.`;\n\n\t\tconsole.error(errorMessage);\n\t}\n\n\treturn {\n\t\tfullURL,\n\t\tnormalizedInitURL,\n\t};\n};\n\nexport type AllowedQueryParamValues = UnmaskType<boolean | number | string>;\n\nexport type RecordStyleParams = UnmaskType<Record<string, AllowedQueryParamValues>>;\n\nexport type TupleStyleParams = UnmaskType<AllowedQueryParamValues[]>;\n\nexport type Params = UnmaskType<RecordStyleParams | TupleStyleParams>;\n\nexport type Query = UnmaskType<Record<string, AllowedQueryParamValues> | URLSearchParams>;\n\nexport type InitURLOrURLObject = AnyString | RouteKeyMethodsURLUnion | URL;\n\nexport interface URLOptions {\n\t/**\n\t * Base URL for all API requests. Will only be prepended to relative URLs.\n\t *\n\t * Absolute URLs (starting with http/https) will not be prepended by the baseURL.\n\t *\n\t * @example\n\t * ```ts\n\t * // Set base URL for all requests\n\t * baseURL: \"https://api.example.com/v1\"\n\t *\n\t * // Then use relative URLs in requests\n\t * callApi(\"/users\") // → https://api.example.com/v1/users\n\t * callApi(\"/posts/123\") // → https://api.example.com/v1/posts/123\n\t *\n\t * // Environment-specific base URLs\n\t * baseURL: process.env.NODE_ENV === \"production\"\n\t * ? \"https://api.example.com\"\n\t * : \"http://localhost:3000/api\"\n\t * ```\n\t */\n\tbaseURL?: string;\n\n\t/**\n\t * Resolved request URL after processing baseURL, parameters, and query strings (readonly)\n\t *\n\t * This is the final URL that will be used for the HTTP request, computed from\n\t * baseURL, initURL, params, and query parameters.\n\t *\n\t */\n\treadonly fullURL?: string;\n\n\t/**\n\t * The original URL string passed to the callApi instance (readonly)\n\t *\n\t * This preserves the original URL as provided, including any method modifiers like \"@get/\" or \"@post/\".\n\t *\n\t */\n\treadonly initURL?: string;\n\n\t/**\n\t * The URL string after normalization, with method modifiers removed(readonly)\n\t *\n\t * Method modifiers like \"@get/\", \"@post/\" are stripped to create a clean URL\n\t * for parameter substitution and final URL construction.\n\t *\n\t */\n\treadonly initURLNormalized?: string;\n\n\t/**\n\t * Parameters to be substituted into URL path segments.\n\t *\n\t * Supports both object-style (named parameters) and array-style (positional parameters)\n\t * for flexible URL parameter substitution.\n\t *\n\t * @example\n\t * ```typescript\n\t * // Object-style parameters (recommended)\n\t * const namedParams: URLOptions = {\n\t * initURL: \"/users/:userId/posts/:postId\",\n\t * params: { userId: \"123\", postId: \"456\" }\n\t * };\n\t * // Results in: /users/123/posts/456\n\t *\n\t * // Array-style parameters (positional)\n\t * const positionalParams: URLOptions = {\n\t * initURL: \"/users/:userId/posts/:postId\",\n\t * params: [\"123\", \"456\"] // Maps in order: userId=123, postId=456\n\t * };\n\t * // Results in: /users/123/posts/456\n\t *\n\t * // Single parameter\n\t * const singleParam: URLOptions = {\n\t * initURL: \"/users/:id\",\n\t * params: { id: \"user-123\" }\n\t * };\n\t * // Results in: /users/user-123\n\t * ```\n\t */\n\tparams?: Params;\n\n\t/**\n\t * Query parameters to append to the URL as search parameters.\n\t *\n\t * These will be serialized into the URL query string using standard\n\t * URL encoding practices.\n\t *\n\t * @example\n\t * ```typescript\n\t * // Basic query parameters\n\t * const queryOptions: URLOptions = {\n\t * initURL: \"/users\",\n\t * query: {\n\t * page: 1,\n\t * limit: 10,\n\t * search: \"john doe\",\n\t * active: true\n\t * }\n\t * };\n\t * // Results in: /users?page=1&limit=10&search=john%20doe&active=true\n\t *\n\t * // Filtering and sorting\n\t * const filterOptions: URLOptions = {\n\t * initURL: \"/products\",\n\t * query: {\n\t * category: \"electronics\",\n\t * minPrice: 100,\n\t * maxPrice: 500,\n\t * sortBy: \"price\",\n\t * order: \"asc\"\n\t * }\n\t * };\n\t * // Results in: /products?category=electronics&minPrice=100&maxPrice=500&sortBy=price&order=asc\n\t * ```\n\t */\n\tquery?: Query;\n}\n","import type { CallApiRequestOptions } from \"../../types/options-types\";\nimport { getValidatedValue, type CallApiSchemaType, type InferSchemaOutput } from \"../../validation\";\nimport { isArray, isBlob, isObject, isString } from \"../guards\";\nimport { ValidationError } from \"./error\";\n\nconst toStringOrStringify = (value: unknown): string => {\n\treturn isString(value) ? value : JSON.stringify(value);\n};\n\ntype BodyType = NonNullable<CallApiRequestOptions[\"body\"]>;\n\nexport const toSearchParams = <TSchema extends CallApiSchemaType<BodyType>>(\n\tdata: InferSchemaOutput<TSchema>,\n\tschema?: TSchema\n) => {\n\tconst result = getValidatedValue(data, schema, { variant: \"sync\" });\n\n\tif (result.issues) {\n\t\tthrow new ValidationError({\n\t\t\tissueCause: \"toQueryString\",\n\t\t\tissues: result.issues,\n\t\t\tresponse: null,\n\t\t});\n\t}\n\n\tconst searchParams = new URLSearchParams();\n\n\tfor (const [key, value] of Object.entries(result.value as Record<string, unknown>)) {\n\t\tif (value == null) continue;\n\n\t\tif (isArray(value)) {\n\t\t\t// eslint-disable-next-line max-depth -- Allow\n\t\t\tfor (const innerValue of value) {\n\t\t\t\tsearchParams.append(key, toStringOrStringify(innerValue));\n\t\t\t}\n\t\t\tcontinue;\n\t\t}\n\n\t\tsearchParams.set(key, toStringOrStringify(value));\n\t}\n\n\treturn searchParams;\n};\n\nexport const toQueryString = <TSchema extends CallApiSchemaType<BodyType>>(\n\t...parameters: Parameters<typeof toSearchParams<TSchema>>\n) => {\n\tconst searchParams = toSearchParams(...parameters);\n\n\treturn searchParams.toString();\n};\n\nconst toBlobOrString = (value: unknown): string | Blob => {\n\treturn isBlob(value) ? value : String(value);\n};\n\n/**\n * @description Converts a plain object to FormData.\n *\n * Handles various data types:\n * - **Primitives** (string, number, boolean): Converted to strings\n * - **Blobs/Files**: Added directly to FormData\n * - **Arrays**: Each item is appended (allows multiple values for same key)\n * - **Objects**: JSON stringified before adding to FormData\n *\n * @example\n * ```ts\n * // Basic usage\n * const formData = toFormData({\n * name: \"John\",\n * age: 30,\n * active: true\n * });\n *\n * // With arrays\n * const formData = toFormData({\n * tags: [\"javascript\", \"typescript\"],\n * name: \"John\"\n * });\n *\n * // With files\n * const formData = toFormData({\n * avatar: fileBlob,\n * name: \"John\"\n * });\n *\n * // With nested objects (one level only)\n * const formData = toFormData({\n * user: { name: \"John\", age: 30 },\n * settings: { theme: \"dark\" }\n * });\n */\nexport const toFormData = <TSchema extends CallApiSchemaType<BodyType>>(\n\tdata: InferSchemaOutput<TSchema>,\n\tschema?: TSchema\n) => {\n\tconst formData = new FormData();\n\n\tconst result = getValidatedValue(data, schema, { variant: \"sync\" });\n\n\tif (result.issues) {\n\t\tthrow new ValidationError({\n\t\t\tissueCause: \"toFormData\",\n\t\t\tissues: result.issues,\n\t\t\tresponse: null,\n\t\t});\n\t}\n\n\tfor (const [key, value] of Object.entries(result.value as Record<string, unknown>)) {\n\t\tif (isArray(value)) {\n\t\t\t// eslint-disable-next-line max-depth -- Allow for now\n\t\t\tfor (const innerValue of value) {\n\t\t\t\tformData.append(key, toBlobOrString(innerValue));\n\t\t\t}\n\t\t\tcontinue;\n\t\t}\n\n\t\tif (isObject(value) && !isBlob(value)) {\n\t\t\tformData.set(key, JSON.stringify(value));\n\t\t\tcontinue;\n\t\t}\n\n\t\tformData.set(key, toBlobOrString(value));\n\t}\n\n\treturn formData;\n};\n","import type { CallApiPlugin } from \"../../plugins\";\nimport type { BaseCallApiConfig, CallApiConfig } from \"../../types/options-types\";\nimport type { AnyFunction, Satisfies, Writeable } from \"../../types/type-helpers\";\nimport type {\n\tBaseCallApiSchemaAndConfig,\n\tBaseCallApiSchemaRoutes,\n\tCallApiSchema,\n\tCallApiSchemaConfig,\n} from \"../../validation\";\n\nexport const defineSchema = <\n\tconst TBaseSchemaRoutes extends BaseCallApiSchemaRoutes,\n\tconst TSchemaConfig extends CallApiSchemaConfig,\n>(\n\troutes: TBaseSchemaRoutes,\n\tconfig?: Satisfies<TSchemaConfig, CallApiSchemaConfig>\n) => {\n\treturn {\n\t\tconfig: defineSchemaConfig(config as NonNullable<typeof config>),\n\t\troutes: defineSchemaRoutes(routes),\n\t} satisfies BaseCallApiSchemaAndConfig;\n};\n\nexport const defineSchemaRoutes = <const TSchemaRoutes extends BaseCallApiSchemaRoutes>(\n\troutes: TSchemaRoutes\n) => {\n\treturn routes as Writeable<typeof routes, \"deep\">;\n};\n\nexport const defineMainSchema = <const TSchema extends CallApiSchema>(\n\tmainSchema: Satisfies<TSchema, CallApiSchema>\n) => {\n\treturn mainSchema as Writeable<typeof mainSchema, \"deep\">;\n};\n\nexport const defineSchemaConfig = <const TSchemaConfig extends CallApiSchemaConfig>(\n\tconfig: Satisfies<TSchemaConfig, CallApiSchemaConfig>\n) => {\n\treturn config as Writeable<typeof config, \"deep\">;\n};\n\nexport const definePlugin = <const TPlugin extends CallApiPlugin>(plugin: TPlugin) => {\n\treturn plugin as Writeable<typeof plugin, \"deep\">;\n};\n\ntype BaseConfigObject = Exclude<BaseCallApiConfig, AnyFunction>;\n\ntype BaseConfigFn = Extract<BaseCallApiConfig, AnyFunction>;\n\ntype DefineBaseConfig = {\n\t<const TBaseConfig extends BaseConfigObject>(\n\t\tbaseConfig: Satisfies<TBaseConfig, BaseConfigObject>\n\t): Writeable<typeof baseConfig, \"deep\">;\n\t<const TBaseConfig extends BaseConfigObject>(\n\t\tbaseConfig: (...parameters: Parameters<BaseConfigFn>) => Writeable<TBaseConfig, \"deep\">\n\t): typeof baseConfig;\n};\n\nexport const defineBaseConfig: DefineBaseConfig = <const TBaseConfig extends BaseCallApiConfig>(\n\tbaseConfig: TBaseConfig\n) => {\n\treturn baseConfig;\n};\n\nexport const defineInstanceConfig = <const TInstanceConfig extends CallApiConfig>(\n\tconfig: TInstanceConfig\n) => {\n\treturn config as Writeable<typeof config, \"deep\">;\n};\n","import type {\n\tCallApiResultErrorVariant,\n\tPossibleHTTPError,\n\tPossibleJavaScriptError,\n\tPossibleValidationError,\n} from \"../../result\";\nimport { isObject } from \"../guards\";\nimport { HTTPError, ValidationError } from \"./error\";\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 = <TErrorData>(error: unknown) => {\n\treturn HTTPError.isError<TErrorData>(error);\n};\n\nexport const isValidationError = (\n\terror: CallApiResultErrorVariant<unknown>[\"error\"] | null\n): error is PossibleValidationError => {\n\treturn isObject(error) && error.name === \"ValidationError\";\n};\n\nexport const isValidationErrorInstance = (error: unknown): error is ValidationError => {\n\treturn ValidationError.isError(error);\n};\n\nexport const isJavascriptError = (\n\terror: CallApiResultErrorVariant<unknown>[\"error\"] | null\n): error is PossibleJavaScriptError => {\n\treturn isObject(error) && !isHTTPError(error) && !isValidationError(error);\n};\n","import type { CallApiRequestOptions } from \"../../types/options-types\";\nimport { isPlainObject } from \"../guards\";\n\nexport const objectifyHeaders = (headers: CallApiRequestOptions[\"headers\"]) => {\n\tif (!headers) {\n\t\treturn {};\n\t}\n\n\tif (isPlainObject(headers)) {\n\t\treturn headers as Record<string, string>;\n\t}\n\n\treturn Object.fromEntries(headers);\n};\n","import { getAuthHeader } from \"../auth\";\nimport { fetchSpecificKeys } from \"../constants/common\";\nimport { extraOptionDefaults, requestOptionDefaults } from \"../constants/defaults\";\nimport type { RequestContext } from \"../hooks\";\nimport type { Middlewares } from \"../middlewares\";\nimport type { InferHeadersOption } from \"../types/conditional-types\";\nimport type {\n\tCallApiExtraOptions,\n\tCallApiRequestOptions,\n\tSharedExtraOptions,\n} from \"../types/options-types\";\nimport type { DistributiveOmit } from \"../types/type-helpers\";\nimport { extractMethodFromURL } from \"../url\";\nimport type { CallApiSchema } from \"../validation\";\nimport { objectifyHeaders } from \"./external\";\nimport {\n\tisFunction,\n\tisPlainObject,\n\tisQueryString,\n\tisSerializableObject,\n\tisValidJsonString,\n} from \"./guards\";\n\nexport const omitKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TOmitArray extends Array<keyof TObject> | ReadonlyArray<keyof TObject>,\n>(\n\tinitialObject: TObject,\n\tkeysToOmit: TOmitArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (!keysToOmit.includes(key)) {\n\t\t\tupdatedObject[key] = value;\n\t\t}\n\t}\n\n\treturn updatedObject as DistributiveOmit<TObject, TOmitArray[number]>;\n};\n\nexport const pickKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TPickArray extends Array<keyof TObject> | ReadonlyArray<keyof TObject>,\n>(\n\tinitialObject: TObject,\n\tkeysToPick: TPickArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (keysToPick.includes(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 splitConfig = <TExtraOptions extends SharedExtraOptions>(config: Record<string, any>) =>\n\t[\n\t\tpickKeys(config, fetchSpecificKeys) as CallApiRequestOptions,\n\t\tomitKeys(config, fetchSpecificKeys) as TExtraOptions,\n\t] as const;\n\nexport type GetResolvedHeadersOptions = {\n\tbaseHeaders: CallApiRequestOptions[\"headers\"];\n\theaders: InferHeadersOption<CallApiSchema>[\"headers\"];\n};\n\nexport const getResolvedHeaders = (options: GetResolvedHeadersOptions) => {\n\tconst { baseHeaders, headers } = options;\n\n\tconst resolvedHeaders =\n\t\tisFunction(headers) ?\n\t\t\theaders({ baseHeaders: objectifyHeaders(baseHeaders) })\n\t\t:\t(headers ?? baseHeaders);\n\n\treturn objectifyHeaders(resolvedHeaders);\n};\n\nconst detectContentTypeHeader = (body: CallApiRequestOptions[\"body\"]) => {\n\tif (isQueryString(body)) {\n\t\treturn { \"Content-Type\": \"application/x-www-form-urlencoded\" };\n\t}\n\n\tif (isSerializableObject(body) || isValidJsonString(body)) {\n\t\treturn { Accept: \"application/json\", \"Content-Type\": \"application/json\" };\n\t}\n\n\treturn null;\n};\n\nexport type GetHeadersOptions = {\n\tauth: CallApiExtraOptions[\"auth\"];\n\tbody: CallApiRequestOptions[\"body\"];\n\tresolvedHeaders: CallApiRequestOptions[\"headers\"];\n};\n\nexport const getHeaders = async (options: GetHeadersOptions) => {\n\tconst { auth, body, resolvedHeaders } = options;\n\n\tconst authHeaderObject = await getAuthHeader(auth);\n\n\tconst resolvedHeadersObject = objectifyHeaders(resolvedHeaders);\n\n\tconst hasExistingContentType =\n\t\tObject.hasOwn(resolvedHeadersObject, \"Content-Type\")\n\t\t|| Object.hasOwn(resolvedHeadersObject, \"content-type\");\n\n\tif (!hasExistingContentType) {\n\t\tconst contentTypeHeader = detectContentTypeHeader(body);\n\t\tcontentTypeHeader && Object.assign(resolvedHeadersObject, contentTypeHeader);\n\t}\n\n\tconst headersObject: Record<string, string> = {\n\t\t...authHeaderObject,\n\t\t...resolvedHeadersObject,\n\t};\n\n\treturn headersObject;\n};\n\nexport type GetMethodContext = {\n\t/** The URL string that may contain method modifiers like \"@get/\" or \"@post/\" */\n\tinitURL: string | undefined;\n\t/** Explicitly specified HTTP method */\n\tmethod: CallApiRequestOptions[\"method\"];\n};\n\nexport const getMethod = (ctx: GetMethodContext) => {\n\tconst { initURL, method } = ctx;\n\n\treturn (\n\t\tmethod?.toUpperCase() ?? extractMethodFromURL(initURL)?.toUpperCase() ?? requestOptionDefaults.method\n\t);\n};\n\nexport type GetBodyOptions = Pick<GetHeadersOptions, \"body\" | \"resolvedHeaders\"> & {\n\tbodySerializer: CallApiExtraOptions[\"bodySerializer\"];\n};\n\nexport const getBody = (options: GetBodyOptions) => {\n\tconst { body, bodySerializer, resolvedHeaders } = options;\n\n\tconst headers = new Headers(resolvedHeaders as Record<string, string>);\n\n\tconst existingContentType = headers.get(\"content-type\");\n\n\tif (!existingContentType && isSerializableObject(body)) {\n\t\tconst selectedBodySerializer = bodySerializer ?? extraOptionDefaults.bodySerializer;\n\n\t\treturn selectedBodySerializer(body);\n\t}\n\n\tif (existingContentType === \"application/x-www-form-urlencoded\" && isSerializableObject(body)) {\n\t\treturn new URLSearchParams(body as Record<string, string>).toString();\n\t}\n\n\treturn body;\n};\n\nexport const getInitFetchImpl = (customFetchImpl: CallApiExtraOptions[\"customFetchImpl\"]) => {\n\tif (customFetchImpl) {\n\t\treturn customFetchImpl;\n\t}\n\n\tif (typeof globalThis !== \"undefined\" && isFunction(globalThis.fetch)) {\n\t\treturn globalThis.fetch;\n\t}\n\n\tthrow new Error(\"No fetch implementation found\");\n};\n\nexport const getFetchImpl = (context: {\n\tcustomFetchImpl: CallApiExtraOptions[\"customFetchImpl\"];\n\tfetchMiddleware: Middlewares[\"fetchMiddleware\"];\n\trequestContext: RequestContext;\n}) => {\n\tconst { customFetchImpl, fetchMiddleware, requestContext } = context;\n\n\tconst initFetchImpl = getInitFetchImpl(customFetchImpl);\n\n\tconst resolvedFetchImpl =\n\t\tfetchMiddleware ? fetchMiddleware({ ...requestContext, fetchImpl: initFetchImpl }) : initFetchImpl;\n\n\treturn resolvedFetchImpl;\n};\n\nexport const waitFor = (ms: number) => {\n\tif (ms === 0) return;\n\n\tconst promise = new Promise((resolve) => setTimeout(resolve, ms));\n\n\treturn promise;\n};\n\nexport const createCombinedSignal = (...signals: Array<AbortSignal | null | undefined>) => {\n\tconst combinedSignal = AbortSignal.any(signals.filter((signal) => signal != null));\n\n\treturn combinedSignal;\n};\n\nexport const createTimeoutSignal = (ms: number | undefined) => {\n\tif (ms == null) return;\n\n\treturn AbortSignal.timeout(ms);\n};\n\nexport const deterministicHashFn = (value: unknown): string => {\n\treturn JSON.stringify(value, (_, innerValue: unknown) => {\n\t\tif (!isPlainObject(innerValue)) {\n\t\t\treturn innerValue;\n\t\t}\n\n\t\tconst result: Record<string, unknown> = {};\n\n\t\t// eslint-disable-next-line unicorn/no-array-sort -- Not necessary here\n\t\tconst sortedKeys = Object.keys(innerValue).sort();\n\n\t\tfor (const key of sortedKeys) {\n\t\t\tresult[key] = innerValue[key];\n\t\t}\n\n\t\treturn result;\n\t});\n};\n","import type { CallApiConfig, CallApiExtraOptions } from \"../types/options-types\";\nimport { defineEnum } from \"../types/type-helpers\";\nimport { deterministicHashFn } from \"../utils/common\";\n\nexport const extraOptionDefaults = Object.freeze(\n\tdefineEnum({\n\t\t// Common defaults\n\t\tbodySerializer: JSON.stringify,\n\t\tdebugMode: true,\n\t\tdefaultHTTPErrorMessage: \"Request failed unexpectedly\",\n\n\t\t// Dedupe defaults\n\t\t/* eslint-disable perfectionist/sort-objects -- Allow */\n\t\tdedupeCacheScope: \"local\",\n\t\tdedupeKey: (ctx) =>\n\t\t\t`${ctx.options.fullURL}-${deterministicHashFn({ options: ctx.options, request: ctx.request })}`,\n\t\tdedupeCacheScopeKey: \"default\",\n\t\tdedupeStrategy: \"cancel\",\n\t\t/* eslint-enable perfectionist/sort-objects -- Allow */\n\n\t\t// Hook defaults\n\t\thooksExecutionMode: \"parallel\",\n\n\t\t// Refetch defaults\n\t\trefetchAttempts: 1,\n\n\t\t// Response defaults\n\t\tresponseParser: JSON.parse,\n\t\tresponseType: \"json\",\n\t\tresultMode: \"all\",\n\n\t\t// Retry Defaults\n\t\tretryAttempts: 0,\n\t\tretryCondition: () => true,\n\t\tretryDelay: 1000,\n\t\tretryMaxDelay: 10000,\n\t\tretryMethods: [\"GET\", \"POST\"],\n\t\tretryStatusCodes: [],\n\t\tretryStrategy: \"linear\",\n\t} satisfies CallApiExtraOptions)\n);\n\nexport const requestOptionDefaults = Object.freeze(\n\tdefineEnum({\n\t\tmethod: \"GET\",\n\t} satisfies CallApiConfig)\n);\n"],"mappings":"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"}
@@ -1,11 +1,11 @@
1
- import { Ct as DistributiveOmit, E as CallApiResult, Et as Writeable, M as GlobalMeta, O as GetBaseSchemaConfig, S as CallApiContext, St as AnyString, _ as ResponseTypeType, _t as InferSchemaOutput, ct as ThrowOnErrorBoolean, d as GetResponseType, dt as BaseCallApiSchemaRoutes, et as ApplyStrictConfig, f as InferCallApiResult, g as ResponseTypeMap, i as CallApiPlugin, k as GetBaseSchemaRoutes, l as CallApiResultSuccessOrErrorVariant, mt as CallApiSchemaConfig, n as DefaultDataType, nt as GetCurrentRouteSchema, ot as InferInitURL, pt as CallApiSchema, r as DefaultPluginArray, rt as GetCurrentRouteSchemaKey, t as DefaultCallApiContext, tt as ApplyURLBasedConfig, u as CallApiResultSuccessVariant, ut as BaseCallApiSchemaAndConfig, v as ResultModeType, vt as InferSchemaResult, wt as NoInferUnMasked, x as CallApiConfig, y as BaseCallApiConfig } from "./default-types-CswfU2bI.js";
1
+ import { A as CallApiConfig, Ct as DistributiveOmit, D as ThrowOnErrorBoolean, Et as Writeable, F as CallApiResult, L as GetBaseSchemaConfig, O as BaseCallApiConfig, R as GetBaseSchemaRoutes, S as GetCurrentRouteSchemaKey, St as AnyString, T as InferInitURL, V as GlobalMeta, _ as ResponseTypeType, _t as InferSchemaOutput, b as ApplyURLBasedConfig, d as GetResponseType, dt as BaseCallApiSchemaRoutes, f as InferCallApiResult, g as ResponseTypeMap, i as CallApiPlugin, j as CallApiContext, l as CallApiResultSuccessOrErrorVariant, mt as CallApiSchemaConfig, n as DefaultDataType, pt as CallApiSchema, r as DefaultPluginArray, t as DefaultCallApiContext, u as CallApiResultSuccessVariant, ut as BaseCallApiSchemaAndConfig, v as ResultModeType, vt as InferSchemaResult, wt as NoInferUnMasked, x as GetCurrentRouteSchema, y as ApplyStrictConfig } from "./default-types-CyPF_5eh.js";
2
2
 
3
3
  //#region src/createFetchClient.d.ts
4
4
  declare const createFetchClientWithContext: <TOuterCallApiContext extends CallApiContext = DefaultCallApiContext>() => <TBaseCallApiContext extends CallApiContext = TOuterCallApiContext, TBaseData = TBaseCallApiContext["Data"], TBaseErrorData = TBaseCallApiContext["ErrorData"], TBaseResultMode extends ResultModeType = (TBaseCallApiContext["ResultMode"] extends ResultModeType ? TBaseCallApiContext["ResultMode"] : ResultModeType), TBaseThrowOnError extends ThrowOnErrorBoolean = boolean, TBaseResponseType extends ResponseTypeType = ResponseTypeType, const TBaseSchemaAndConfig extends BaseCallApiSchemaAndConfig = BaseCallApiSchemaAndConfig, const TBasePluginArray extends CallApiPlugin[] = DefaultPluginArray, TComputedBaseSchemaConfig extends CallApiSchemaConfig = GetBaseSchemaConfig<TBaseSchemaAndConfig>, TComputedBaseSchemaRoutes extends BaseCallApiSchemaRoutes = GetBaseSchemaRoutes<TBaseSchemaAndConfig>>(initBaseConfig?: BaseCallApiConfig<TBaseCallApiContext, TBaseData, TBaseErrorData, TBaseResultMode, TBaseThrowOnError, TBaseResponseType, TBaseSchemaAndConfig, TBasePluginArray>) => <TData = TBaseData, TErrorData = TBaseErrorData, TResultMode extends ResultModeType = TBaseResultMode, TCallApiContext extends CallApiContext = TBaseCallApiContext, TThrowOnError extends ThrowOnErrorBoolean = TBaseThrowOnError, TResponseType extends ResponseTypeType = TBaseResponseType, const TSchemaConfig extends CallApiSchemaConfig = TComputedBaseSchemaConfig, TInitURL extends InferInitURL<TComputedBaseSchemaRoutes, TSchemaConfig> = InferInitURL<TComputedBaseSchemaRoutes, TSchemaConfig>, TCurrentRouteSchemaKey extends GetCurrentRouteSchemaKey<TSchemaConfig, TInitURL> = GetCurrentRouteSchemaKey<TSchemaConfig, TInitURL>, const TSchema extends CallApiSchema = GetCurrentRouteSchema<TComputedBaseSchemaRoutes, TCurrentRouteSchemaKey>, const TPluginArray extends CallApiPlugin[] = TBasePluginArray, TComputedData = InferSchemaOutput<TSchema["data"], GetResponseType<TData, TResponseType>>, TComputedErrorData = InferSchemaOutput<TSchema["errorData"], GetResponseType<TErrorData, TResponseType>>, TComputedResult = CallApiResult<TComputedData, TComputedErrorData, TResultMode, TThrowOnError>>(initURL: TInitURL, initConfig?: CallApiConfig<TCallApiContext, TComputedData, TComputedErrorData, TResultMode, TThrowOnError, TResponseType, TComputedBaseSchemaRoutes, TSchema, TComputedBaseSchemaConfig, TSchemaConfig, TInitURL, TCurrentRouteSchemaKey, TBasePluginArray, TPluginArray>) => Promise<TComputedResult>;
5
5
  declare const createFetchClient: <TBaseCallApiContext extends CallApiContext = {
6
- InferredExtraOptions: unknown;
7
6
  Data: DefaultDataType;
8
7
  ErrorData: DefaultDataType;
8
+ InferredExtraOptions: unknown;
9
9
  ResultMode: ResultModeType;
10
10
  Meta: GlobalMeta;
11
11
  }, TBaseData = TBaseCallApiContext["Data"], TBaseErrorData = TBaseCallApiContext["ErrorData"], TBaseResultMode extends ResultModeType = (TBaseCallApiContext["ResultMode"] extends ResultModeType ? TBaseCallApiContext["ResultMode"] : ResultModeType), TBaseThrowOnError extends ThrowOnErrorBoolean = boolean, TBaseResponseType extends ResponseTypeType = ResponseTypeType, const TBaseSchemaAndConfig extends BaseCallApiSchemaAndConfig = BaseCallApiSchemaAndConfig, const TBasePluginArray extends CallApiPlugin[] = DefaultPluginArray, TComputedBaseSchemaConfig extends CallApiSchemaConfig = Writeable<NonNullable<TBaseSchemaAndConfig["config"]>, "deep">, TComputedBaseSchemaRoutes extends BaseCallApiSchemaRoutes = Writeable<TBaseSchemaAndConfig["routes"], "deep">>(initBaseConfig?: BaseCallApiConfig<TBaseCallApiContext, TBaseData, TBaseErrorData, TBaseResultMode, TBaseThrowOnError, TBaseResponseType, TBaseSchemaAndConfig, TBasePluginArray>) => <TData = TBaseData, TErrorData = TBaseErrorData, TResultMode extends ResultModeType = TBaseResultMode, TCallApiContext extends CallApiContext = TBaseCallApiContext, TThrowOnError extends ThrowOnErrorBoolean = TBaseThrowOnError, TResponseType extends ResponseTypeType = TBaseResponseType, const TSchemaConfig extends CallApiSchemaConfig = TComputedBaseSchemaConfig, TInitURL extends InferInitURL<TComputedBaseSchemaRoutes, TSchemaConfig> = InferInitURL<TComputedBaseSchemaRoutes, TSchemaConfig>, TCurrentRouteSchemaKey extends GetCurrentRouteSchemaKey<TSchemaConfig, TInitURL> = GetCurrentRouteSchemaKey<TSchemaConfig, TInitURL>, const TSchema extends CallApiSchema = GetCurrentRouteSchema<TComputedBaseSchemaRoutes, TCurrentRouteSchemaKey, TComputedBaseSchemaRoutes["@default"], TComputedBaseSchemaRoutes[TCurrentRouteSchemaKey], NonNullable<Omit<TComputedBaseSchemaRoutes["@default"], keyof TComputedBaseSchemaRoutes[TCurrentRouteSchemaKey]> & TComputedBaseSchemaRoutes[TCurrentRouteSchemaKey]>>, const TPluginArray extends CallApiPlugin[] = TBasePluginArray, TComputedData = InferSchemaResult<TSchema["data"], GetResponseType<TData, TResponseType, ResponseTypeMap<TData>>, "infer-output">, TComputedErrorData = InferSchemaResult<TSchema["errorData"], GetResponseType<TErrorData, TResponseType, ResponseTypeMap<TErrorData>>, "infer-output">, TComputedResult = InferCallApiResult<TComputedData, TComputedErrorData, TResultMode, TThrowOnError, {
@@ -25,9 +25,9 @@ declare const createFetchClient: <TBaseCallApiContext extends CallApiContext = {
25
25
  withoutResponse: DistributiveOmit<TThrowOnError extends true ? CallApiResultSuccessVariant<TComputedData> : CallApiResultSuccessOrErrorVariant<TComputedData, TComputedErrorData>, "response"> extends infer T ? { [Key in keyof T]: T[Key] } : never;
26
26
  }>>(initURL: TInitURL, initConfig?: CallApiConfig<TCallApiContext, TComputedData, TComputedErrorData, TResultMode, TThrowOnError, TResponseType, TComputedBaseSchemaRoutes, TSchema, TComputedBaseSchemaConfig, TSchemaConfig, TInitURL, TCurrentRouteSchemaKey, TBasePluginArray, TPluginArray>) => Promise<TComputedResult>;
27
27
  declare const callApi: <TData = unknown, TErrorData = unknown, TResultMode extends ResultModeType = ResultModeType, TCallApiContext extends CallApiContext = {
28
- InferredExtraOptions: unknown;
29
28
  Data: DefaultDataType;
30
29
  ErrorData: DefaultDataType;
30
+ InferredExtraOptions: unknown;
31
31
  ResultMode: ResultModeType;
32
32
  Meta: GlobalMeta;
33
33
  }, TThrowOnError extends ThrowOnErrorBoolean = boolean, TResponseType extends ResponseTypeType = ResponseTypeType, const TSchemaConfig extends CallApiSchemaConfig = CallApiSchemaConfig, TInitURL extends ApplyStrictConfig<TSchemaConfig, ApplyURLBasedConfig<TSchemaConfig, AnyString | "@delete/" | "@get/" | "@patch/" | "@post/" | "@put/">> = ApplyStrictConfig<TSchemaConfig, ApplyURLBasedConfig<TSchemaConfig, AnyString | "@delete/" | "@get/" | "@patch/" | "@post/" | "@put/">>, TCurrentRouteSchemaKey extends GetCurrentRouteSchemaKey<TSchemaConfig, TInitURL> = GetCurrentRouteSchemaKey<TSchemaConfig, TInitURL>, const TSchema extends CallApiSchema = GetCurrentRouteSchema<{
@@ -88,4 +88,4 @@ declare const callApi: <TData = unknown, TErrorData = unknown, TResultMode exten
88
88
  }, TSchema, CallApiSchemaConfig, TSchemaConfig, TInitURL, TCurrentRouteSchemaKey, DefaultPluginArray, TPluginArray>) => Promise<TComputedResult>;
89
89
  //#endregion
90
90
  export { createFetchClient as n, createFetchClientWithContext as r, callApi as t };
91
- //# sourceMappingURL=index-DMCchZ0z.d.ts.map
91
+ //# sourceMappingURL=index-CQfVY7gI.d.ts.map
package/dist/index.d.ts CHANGED
@@ -1,3 +1,3 @@
1
- import { $ as RetryOptions, A as GetCallApiContext, B as DedupeOptions, C as CallApiExtraOptions, D as CallApiResultLoose, G as HooksOrHooksArray, H as CallApiRequestOptionsForHooks, J as ResponseContext, K as RequestContext, L as FetchImpl, N as InstanceContext, P as Register, Q as RefetchOptions, R as FetchMiddlewareContext, T as CallApiRequestOptions, U as ErrorContext, V as CallApiExtraOptionsForHooks, W as Hooks, X as ResponseStreamContext, Y as ResponseErrorContext, Z as SuccessContext, _ as ResponseTypeType, _t as InferSchemaOutput, a as PluginHooks, at as InferAllMainRoutes, b as BaseCallApiExtraOptions, c as CallApiResultErrorVariant, dt as BaseCallApiSchemaRoutes, ft as BaseSchemaRouteKeyPrefixes, gt as InferSchemaInput, h as PossibleValidationError, i as CallApiPlugin, it as InferAllMainRouteKeys, j as GetCallApiContextRequired, l as CallApiResultSuccessOrErrorVariant, lt as URLOptions, m as PossibleJavaScriptError, mt as CallApiSchemaConfig, o as PluginMiddlewares, ot as InferInitURL, p as PossibleHTTPError, pt as CallApiSchema, q as RequestStreamContext, rt as GetCurrentRouteSchemaKey, s as PluginSetupContext, st as InferParamsFromRoute, t as DefaultCallApiContext, u as CallApiResultSuccessVariant, v as ResultModeType, w as CallApiParameters, x as CallApiConfig, y as BaseCallApiConfig, z as Middlewares } from "./default-types-CswfU2bI.js";
2
- import { n as createFetchClient, r as createFetchClientWithContext, t as callApi } from "./index-DMCchZ0z.js";
1
+ import { $ as Hooks, A as CallApiConfig, B as GetCallApiContextRequired, C as InferAllMainRouteKeys, E as InferParamsFromRoute, H as InstanceContext, I as CallApiResultLoose, J as Middlewares, K as FetchImpl, M as CallApiExtraOptions, N as CallApiParameters, O as BaseCallApiConfig, P as CallApiRequestOptions, Q as ErrorContext, S as GetCurrentRouteSchemaKey, T as InferInitURL, U as Register, X as CallApiExtraOptionsForHooks, Y as DedupeOptions, Z as CallApiRequestOptionsForHooks, _ as ResponseTypeType, _t as InferSchemaOutput, a as PluginHooks, at as ResponseStreamContext, c as CallApiResultErrorVariant, ct as RetryOptions, dt as BaseCallApiSchemaRoutes, et as HooksOrHooksArray, ft as BaseSchemaRouteKeyPrefixes, gt as InferSchemaInput, h as PossibleValidationError, i as CallApiPlugin, it as ResponseErrorContext, k as BaseCallApiExtraOptions, l as CallApiResultSuccessOrErrorVariant, lt as URLOptions, m as PossibleJavaScriptError, mt as CallApiSchemaConfig, nt as RequestStreamContext, o as PluginMiddlewares, ot as SuccessContext, p as PossibleHTTPError, pt as CallApiSchema, q as FetchMiddlewareContext, rt as ResponseContext, s as PluginSetupContext, st as RefetchOptions, t as DefaultCallApiContext, tt as RequestContext, u as CallApiResultSuccessVariant, v as ResultModeType, w as InferAllMainRoutes, z as GetCallApiContext } from "./default-types-CyPF_5eh.js";
2
+ import { n as createFetchClient, r as createFetchClientWithContext, t as callApi } from "./index-CQfVY7gI.js";
3
3
  export { BaseCallApiConfig, BaseCallApiExtraOptions, BaseCallApiSchemaRoutes, BaseSchemaRouteKeyPrefixes, CallApiConfig, CallApiExtraOptions, CallApiExtraOptionsForHooks, CallApiParameters, CallApiPlugin, CallApiRequestOptions, CallApiRequestOptionsForHooks, CallApiResultLoose as CallApiResult, CallApiResultErrorVariant, CallApiResultSuccessOrErrorVariant, CallApiResultSuccessVariant, CallApiSchema, CallApiSchemaConfig, DedupeOptions, DefaultCallApiContext, ErrorContext, FetchImpl, FetchMiddlewareContext, GetCallApiContext, GetCallApiContextRequired, GetCurrentRouteSchemaKey, Hooks, HooksOrHooksArray, InferAllMainRouteKeys, InferAllMainRoutes, InferInitURL, InferParamsFromRoute, InferSchemaInput, InferSchemaOutput, InstanceContext, Middlewares, PluginHooks, PluginMiddlewares, PluginSetupContext, PossibleHTTPError, PossibleJavaScriptError, PossibleValidationError, RefetchOptions, Register, RequestContext, RequestStreamContext, ResponseContext, ResponseErrorContext, ResponseStreamContext, ResponseTypeType, ResultModeType, RetryOptions, SuccessContext, URLOptions, callApi, createFetchClient, createFetchClientWithContext };
package/dist/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import { A as getCurrentRouteSchemaKeyAndMainInitURL, B as isString, L as isArray, M as handleSchemaValidation, N as HTTPError, R as isBoolean, a as getBody, c as getMethod, d as splitConfig, f as waitFor, h as isHTTPErrorInstance, i as createTimeoutSignal, j as handleConfigValidation, k as getFullAndNormalizedURL, l as getResolvedHeaders, o as getFetchImpl, r as createCombinedSignal, s as getHeaders, t as extraOptionDefaults, u as omitKeys, v as isValidationErrorInstance, z as isFunction } from "./defaults-D0QJmGE5.js";
1
+ import { A as getCurrentRouteSchemaKeyAndMainInitURL, B as isString, L as isArray, M as handleSchemaValidation, N as HTTPError, R as isBoolean, a as getBody, c as getMethod, d as splitConfig, f as waitFor, h as isHTTPErrorInstance, i as createTimeoutSignal, j as handleConfigValidation, k as getFullAndNormalizedURL, l as getResolvedHeaders, o as getFetchImpl, r as createCombinedSignal, s as getHeaders, t as extraOptionDefaults, u as omitKeys, v as isValidationErrorInstance, z as isFunction } from "./defaults-IsBgvt90.js";
2
2
  //#region src/result.ts
3
3
  const getResponseType = (response, responseParser) => ({
4
4
  arrayBuffer: () => response.arrayBuffer(),
@@ -143,7 +143,9 @@ const composeHooksFromArray = (hooksArray, hooksExecutionMode) => {
143
143
  return composedHook;
144
144
  };
145
145
  const executeHooks = async (...hookResultsOrPromise) => {
146
- await Promise.all(hookResultsOrPromise);
146
+ const validHooks = hookResultsOrPromise.filter(Boolean);
147
+ if (validHooks.length === 0) return;
148
+ await Promise.all(validHooks);
147
149
  };
148
150
  const executeHooksInCatchBlock = async (hookResultsOrPromise, hookInfo) => {
149
151
  const { errorInfo, shouldThrowOnError } = hookInfo;
@@ -289,21 +291,18 @@ const createDedupeStrategy = async (context) => {
289
291
  const { $GlobalRequestInfoCache, $LocalRequestInfoCache, baseConfig, config, newFetchController, options: globalOptions } = context;
290
292
  const dedupeStrategy = globalOptions.dedupeStrategy ?? extraOptionDefaults.dedupeStrategy;
291
293
  const resolvedDedupeStrategy = isFunction(dedupeStrategy) ? dedupeStrategy(context) : dedupeStrategy;
294
+ const shouldDisableDedupe = resolvedDedupeStrategy === "none";
292
295
  const getDedupeKey = () => {
293
- if (!(resolvedDedupeStrategy === "cancel" || resolvedDedupeStrategy === "defer")) return null;
294
296
  const dedupeKey = globalOptions.dedupeKey ?? extraOptionDefaults.dedupeKey;
295
297
  return isFunction(dedupeKey) ? dedupeKey(context) : dedupeKey;
296
298
  };
297
- const getDedupeCacheScopeKey = () => {
298
- const dedupeCacheScopeKey = globalOptions.dedupeCacheScopeKey ?? extraOptionDefaults.dedupeCacheScopeKey;
299
- return isFunction(dedupeCacheScopeKey) ? dedupeCacheScopeKey(context) : dedupeCacheScopeKey;
300
- };
301
- const dedupeKey = getDedupeKey();
299
+ const dedupeKey = shouldDisableDedupe ? null : getDedupeKey();
302
300
  const getRequestInfoCache = () => {
303
- if (!dedupeKey) return;
301
+ if (dedupeKey == null) return;
304
302
  const dedupeCacheScope = globalOptions.dedupeCacheScope ?? extraOptionDefaults.dedupeCacheScope;
305
- const dedupeCacheScopeKey = getDedupeCacheScopeKey();
306
- const $RequestInfoCache = dedupeCacheScope === "global" ? $GlobalRequestInfoCache.get(dedupeCacheScopeKey) ?? $GlobalRequestInfoCache.set(dedupeCacheScopeKey, /* @__PURE__ */ new Map()).get(dedupeCacheScopeKey) : $LocalRequestInfoCache;
303
+ const dedupeCacheScopeKey = globalOptions.dedupeCacheScopeKey ?? extraOptionDefaults.dedupeCacheScopeKey;
304
+ const resolvedDedupeCacheScopeKey = isFunction(dedupeCacheScopeKey) ? dedupeCacheScopeKey(context) : dedupeCacheScopeKey;
305
+ const $RequestInfoCache = dedupeCacheScope === "global" ? $GlobalRequestInfoCache.get(resolvedDedupeCacheScopeKey) ?? $GlobalRequestInfoCache.set(resolvedDedupeCacheScopeKey, /* @__PURE__ */ new Map()).get(resolvedDedupeCacheScopeKey) : $LocalRequestInfoCache;
307
306
  return {
308
307
  delete: () => $RequestInfoCache?.delete(dedupeKey),
309
308
  get: () => $RequestInfoCache?.get(dedupeKey),
@@ -335,28 +334,28 @@ const createDedupeStrategy = async (context) => {
335
334
  * simultaneously (same problem as microtasks). Any non-zero value (even 0.0000000001) forces
336
335
  * proper sequential task queue scheduling, ensuring each request gets its own task slot.
337
336
  */
338
- if (dedupeKey !== null) await waitFor(.01);
337
+ if (!shouldDisableDedupe) await waitFor(.01);
339
338
  const prevRequestInfo = $RequestInfoCache?.get();
340
339
  const getAbortErrorMessage = () => {
341
- if (globalOptions.dedupeKey) return `Duplicate request detected - Aborted previous request with key '${dedupeKey}'`;
342
- return `Duplicate request detected - Aborted previous request to '${globalOptions.fullURL}'`;
340
+ if (shouldDisableDedupe) return;
341
+ return globalOptions.dedupeKey != null ? `Duplicate request detected - Aborted previous request with key '${dedupeKey}'` : `Duplicate request detected - Aborted previous request to '${globalOptions.fullURL}'`;
343
342
  };
344
343
  const handleRequestCancelStrategy = () => {
345
- if (!(prevRequestInfo && resolvedDedupeStrategy === "cancel")) return;
344
+ if (!(!shouldDisableDedupe && prevRequestInfo && resolvedDedupeStrategy === "cancel")) return;
346
345
  const message = getAbortErrorMessage();
347
346
  const reason = new DOMException(message, "AbortError");
348
- prevRequestInfo.controller.abort(reason);
347
+ prevRequestInfo.controller?.abort(reason);
349
348
  };
350
349
  const handleRequestDeferStrategy = async (deferContext) => {
351
350
  const { fetchApi, options: localOptions, request: localRequest } = deferContext;
352
- const shouldUsePromiseFromCache = prevRequestInfo && resolvedDedupeStrategy === "defer";
351
+ const shouldDeferPromise = !shouldDisableDedupe && prevRequestInfo && resolvedDedupeStrategy === "defer";
353
352
  const streamContext = {
354
353
  baseConfig,
355
354
  config,
356
355
  options: localOptions,
357
356
  request: localRequest
358
357
  };
359
- const responsePromise = shouldUsePromiseFromCache ? prevRequestInfo.responsePromise : fetchApi(localOptions.fullURL, toStreamableRequest(streamContext));
358
+ const responsePromise = shouldDeferPromise ? prevRequestInfo.responsePromise : fetchApi(localOptions.fullURL, toStreamableRequest(streamContext));
360
359
  $RequestInfoCache?.set({
361
360
  controller: newFetchController,
362
361
  responsePromise
@@ -411,7 +410,7 @@ const getResolvedPlugins = (context) => {
411
410
  const { baseConfig, options } = context;
412
411
  return isFunction(options.plugins) ? options.plugins({ basePlugins: baseConfig.plugins ?? [] }) : options.plugins ?? [];
413
412
  };
414
- const initializePlugins = async (setupContext) => {
413
+ const initializePluginsAndHooks = async (setupContext) => {
415
414
  const { baseConfig, config, currentRouteSchemaKey, mainInitURL, options, request } = setupContext;
416
415
  const { addMainHooks, addMainMiddlewares, addPluginHooks, addPluginMiddlewares, getResolvedHooks, getResolvedMiddlewares } = setupHooksAndMiddlewares({
417
416
  baseConfig,
@@ -422,35 +421,37 @@ const initializePlugins = async (setupContext) => {
422
421
  let resolvedInitURL = mainInitURL;
423
422
  const resolvedOptions = options;
424
423
  const resolvedRequest = request;
425
- const executePluginSetupFn = async (pluginSetup) => {
426
- if (!pluginSetup) return;
427
- const initResult = await pluginSetup(setupContext);
428
- if (!initResult) return;
429
- const urlString = initResult.initURL?.toString();
430
- if (isString(urlString)) {
431
- const newURLResult = getCurrentRouteSchemaKeyAndMainInitURL({
432
- baseExtraOptions: baseConfig,
433
- extraOptions: config,
434
- initURL: urlString
435
- });
436
- resolvedCurrentRouteSchemaKey = newURLResult.currentRouteSchemaKey;
437
- resolvedInitURL = newURLResult.mainInitURL;
438
- }
439
- if (initResult.request) Object.assign(resolvedRequest, initResult.request, initResult.request.extraFetchOptions);
440
- if (initResult.options) Object.assign(resolvedOptions, initResult.options);
441
- };
442
424
  const resolvedPlugins = getResolvedPlugins({
443
425
  baseConfig,
444
426
  options
445
427
  });
446
- for (const plugin of resolvedPlugins) {
447
- const [, pluginHooks, pluginMiddlewares] = await Promise.all([
448
- executePluginSetupFn(plugin.setup),
449
- isFunction(plugin.hooks) ? plugin.hooks(setupContext) : plugin.hooks,
450
- isFunction(plugin.middlewares) ? plugin.middlewares(setupContext) : plugin.middlewares
451
- ]);
452
- pluginHooks && addPluginHooks(pluginHooks);
453
- pluginMiddlewares && addPluginMiddlewares(pluginMiddlewares);
428
+ if (resolvedPlugins.length > 0) {
429
+ const executePluginSetupFn = async (pluginSetup) => {
430
+ if (!pluginSetup) return;
431
+ const initResult = await pluginSetup(setupContext);
432
+ if (!initResult) return;
433
+ const urlString = initResult.initURL?.toString();
434
+ if (isString(urlString)) {
435
+ const newURLResult = getCurrentRouteSchemaKeyAndMainInitURL({
436
+ baseExtraOptions: baseConfig,
437
+ extraOptions: config,
438
+ initURL: urlString
439
+ });
440
+ resolvedCurrentRouteSchemaKey = newURLResult.currentRouteSchemaKey;
441
+ resolvedInitURL = newURLResult.mainInitURL;
442
+ }
443
+ if (initResult.request) Object.assign(resolvedRequest, initResult.request, initResult.request.extraFetchOptions);
444
+ if (initResult.options) Object.assign(resolvedOptions, initResult.options);
445
+ };
446
+ for (const plugin of resolvedPlugins) {
447
+ const [, pluginHooks, pluginMiddlewares] = await Promise.all([
448
+ executePluginSetupFn(plugin.setup),
449
+ isFunction(plugin.hooks) ? plugin.hooks(setupContext) : plugin.hooks,
450
+ isFunction(plugin.middlewares) ? plugin.middlewares(setupContext) : plugin.middlewares
451
+ ]);
452
+ pluginHooks && addPluginHooks(pluginHooks);
453
+ pluginMiddlewares && addPluginMiddlewares(pluginMiddlewares);
454
+ }
454
455
  }
455
456
  addMainHooks();
456
457
  addMainMiddlewares();
@@ -501,17 +502,23 @@ const setupHooksAndMiddlewares = (context) => {
501
502
  };
502
503
  const getResolvedHooks = () => {
503
504
  const resolvedHooks = {};
504
- for (const [hookName, hookRegistry] of Object.entries(hookRegistries)) {
505
+ for (const hookName of hookRegistryKeys) {
506
+ const hookRegistry = hookRegistries[hookName];
505
507
  if (hookRegistry.size === 0) continue;
506
508
  const flattenedHookArray = [...hookRegistry].flat();
507
509
  if (flattenedHookArray.length === 0) continue;
510
+ if (flattenedHookArray.length === 1) {
511
+ resolvedHooks[hookName] = flattenedHookArray[0];
512
+ continue;
513
+ }
508
514
  resolvedHooks[hookName] = composeHooksFromArray(flattenedHookArray, options.hooksExecutionMode ?? extraOptionDefaults.hooksExecutionMode);
509
515
  }
510
516
  return resolvedHooks;
511
517
  };
512
518
  const getResolvedMiddlewares = () => {
513
519
  const resolvedMiddlewares = {};
514
- for (const [middlewareName, middlewareRegistry] of Object.entries(middlewareRegistries)) {
520
+ for (const middlewareName of middlewareRegistryKeys) {
521
+ const middlewareRegistry = middlewareRegistries[middlewareName];
515
522
  if (middlewareRegistry.size === 0) continue;
516
523
  const middlewareArray = [...middlewareRegistry];
517
524
  if (middlewareArray.length === 0) continue;
@@ -640,7 +647,7 @@ const createFetchClientWithContext = () => {
640
647
  extraOptions: config,
641
648
  initURL: initURLString
642
649
  });
643
- const { resolvedCurrentRouteSchemaKey, resolvedHooks, resolvedInitURL, resolvedMiddlewares, resolvedOptions, resolvedRequest } = await initializePlugins({
650
+ const { resolvedCurrentRouteSchemaKey, resolvedHooks, resolvedInitURL, resolvedMiddlewares, resolvedOptions, resolvedRequest } = await initializePluginsAndHooks({
644
651
  baseConfig,
645
652
  config,
646
653
  ...initURLResult,
@@ -659,6 +666,7 @@ const createFetchClientWithContext = () => {
659
666
  });
660
667
  const { fullURL, normalizedInitURL } = getFullAndNormalizedURL({
661
668
  baseURL: resolvedOptions.baseURL,
669
+ debugMode: resolvedOptions.debugMode,
662
670
  initURL: resolvedInitURL,
663
671
  params: resolvedOptions.params,
664
672
  query: resolvedOptions.query
@@ -680,8 +688,8 @@ const createFetchClientWithContext = () => {
680
688
  options
681
689
  });
682
690
  Object.assign(options, refetchFnResult);
683
- const newFetchController = new AbortController();
684
- const combinedSignal = createCombinedSignal(createTimeoutSignal(options.timeout), resolvedRequest.signal, newFetchController.signal);
691
+ const newFetchController = options.dedupeStrategy === "none" ? null : new AbortController();
692
+ const combinedSignal = createCombinedSignal(createTimeoutSignal(options.timeout), resolvedRequest.signal, newFetchController?.signal);
685
693
  const request = {
686
694
  ...resolvedRequest,
687
695
  signal: combinedSignal