@zayne-labs/callapi 1.12.4 → 1.12.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/constants/index.d.ts +1 -1
- package/dist/constants/index.js +1 -1
- package/dist/{default-types-CF53Uvuq.d.ts → default-types-CswfU2bI.d.ts} +9 -17
- package/dist/{defaults-WfRTxvn6.js → defaults-D0QJmGE5.js} +5 -6
- package/dist/defaults-D0QJmGE5.js.map +1 -0
- package/dist/{index-BnLH3CAo.d.ts → index-DMCchZ0z.d.ts} +4 -4
- package/dist/index.d.ts +2 -2
- package/dist/index.js +104 -80
- package/dist/index.js.map +1 -1
- package/dist/utils/external/index.d.ts +1 -1
- package/dist/utils/external/index.js +1 -1
- package/package.json +13 -13
- package/dist/defaults-WfRTxvn6.js.map +0 -1
package/README.md
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Dt as fetchSpecificKeys, K as RequestContext, bt as fallBackRouteSchemaKey, yt as FallBackRouteSchemaKey } from "../default-types-
|
|
1
|
+
import { Dt as fetchSpecificKeys, K as RequestContext, bt as fallBackRouteSchemaKey, yt as FallBackRouteSchemaKey } from "../default-types-CswfU2bI.js";
|
|
2
2
|
|
|
3
3
|
//#region src/constants/defaults.d.ts
|
|
4
4
|
declare const extraOptionDefaults: Readonly<Readonly<{
|
package/dist/constants/index.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { F as fallBackRouteSchemaKey, I as fetchSpecificKeys, n as requestOptionDefaults, t as extraOptionDefaults } from "../defaults-
|
|
1
|
+
import { F as fallBackRouteSchemaKey, I as fetchSpecificKeys, n as requestOptionDefaults, t as extraOptionDefaults } from "../defaults-D0QJmGE5.js";
|
|
2
2
|
export { extraOptionDefaults, fallBackRouteSchemaKey, fetchSpecificKeys, requestOptionDefaults };
|
|
@@ -559,9 +559,9 @@ type RetryCondition<TErrorData> = (context: ErrorContext<{
|
|
|
559
559
|
}>) => Awaitable<boolean>;
|
|
560
560
|
interface RetryOptions<TErrorData> {
|
|
561
561
|
/**
|
|
562
|
-
* Keeps track of the number of times the request has already been retried
|
|
562
|
+
* Keeps track of the number of times the request has already been retried internally
|
|
563
563
|
* @internal
|
|
564
|
-
* @deprecated **
|
|
564
|
+
* @deprecated **WARNING**: This property is used internally to track retries. Please abstain from reading or modifying it.
|
|
565
565
|
*/
|
|
566
566
|
readonly ["~retryAttemptCount"]?: number;
|
|
567
567
|
/**
|
|
@@ -602,9 +602,9 @@ interface RetryOptions<TErrorData> {
|
|
|
602
602
|
//#region src/refetch.d.ts
|
|
603
603
|
interface RefetchOptions {
|
|
604
604
|
/**
|
|
605
|
-
* Tracks the number of times
|
|
605
|
+
* Tracks the number of times the request has been refetched internally
|
|
606
606
|
* @internal
|
|
607
|
-
* @deprecated **
|
|
607
|
+
* @deprecated **WARNING**: This property is used internally to track refetch calls. Please abstain from reading or modifying it.
|
|
608
608
|
*/
|
|
609
609
|
readonly ["~refetchCount"]?: number;
|
|
610
610
|
/**
|
|
@@ -637,9 +637,11 @@ interface RefetchFnOption {
|
|
|
637
637
|
//#region src/stream.d.ts
|
|
638
638
|
type StreamProgressEvent = {
|
|
639
639
|
/**
|
|
640
|
-
* Current chunk of data being streamed
|
|
640
|
+
* Current chunk of data being streamed.
|
|
641
|
+
*
|
|
642
|
+
* Will be `null` on the final completion tick (when progress reaches 100%).
|
|
641
643
|
*/
|
|
642
|
-
chunk: Uint8Array;
|
|
644
|
+
chunk: Uint8Array | null;
|
|
643
645
|
/**
|
|
644
646
|
* Progress in percentage
|
|
645
647
|
*/
|
|
@@ -1331,16 +1333,6 @@ type SharedExtraOptions<TCallApiContext extends CallApiContext = DefaultCallApiC
|
|
|
1331
1333
|
* ```
|
|
1332
1334
|
*/
|
|
1333
1335
|
defaultHTTPErrorMessage?: string | ((context: Pick<HTTPError<TErrorData>, "errorData" | "response">) => string);
|
|
1334
|
-
/**
|
|
1335
|
-
* Forces calculation of total byte size from request body streams.
|
|
1336
|
-
*
|
|
1337
|
-
* Useful when the Content-Length header is missing or incorrect, and you need
|
|
1338
|
-
* accurate size information for progress tracking.
|
|
1339
|
-
*
|
|
1340
|
-
* @default false
|
|
1341
|
-
*
|
|
1342
|
-
*/
|
|
1343
|
-
forcefullyCalculateRequestStreamSize?: boolean;
|
|
1344
1336
|
/**
|
|
1345
1337
|
* Optional metadata field for associating additional information with requests.
|
|
1346
1338
|
*
|
|
@@ -1828,4 +1820,4 @@ type DefaultCallApiContext = Prettify<OverrideCallApiContext<Required<CallApiCon
|
|
|
1828
1820
|
}>>;
|
|
1829
1821
|
//#endregion
|
|
1830
1822
|
export { RetryOptions as $, GetCallApiContext as A, DedupeOptions as B, CallApiExtraOptions as C, DistributiveOmit as Ct, CallApiResultLoose as D, fetchSpecificKeys as Dt, CallApiResult as E, Writeable as Et, HTTPError as F, HooksOrHooksArray as G, CallApiRequestOptionsForHooks as H, ValidationError as I, ResponseContext as J, RequestContext as K, FetchImpl as L, GlobalMeta as M, InstanceContext as N, GetBaseSchemaConfig as O, Register as P, RefetchOptions as Q, FetchMiddlewareContext as R, CallApiContext as S, AnyString as St, CallApiRequestOptions as T, Satisfies as Tt, ErrorContext as U, CallApiExtraOptionsForHooks as V, Hooks as W, ResponseStreamContext as X, ResponseErrorContext as Y, SuccessContext as Z, ResponseTypeType as _, InferSchemaOutput as _t, PluginHooks as a, InferAllMainRoutes as at, BaseCallApiExtraOptions as b, fallBackRouteSchemaKey as bt, CallApiResultErrorVariant as c, ThrowOnErrorBoolean as ct, GetResponseType as d, BaseCallApiSchemaRoutes as dt, ApplyStrictConfig as et, InferCallApiResult as f, BaseSchemaRouteKeyPrefixes as ft, ResponseTypeMap as g, InferSchemaInput as gt, PossibleValidationError as h, CallApiSchemaType as ht, CallApiPlugin as i, InferAllMainRouteKeys as it, GetCallApiContextRequired as j, GetBaseSchemaRoutes as k, CallApiResultSuccessOrErrorVariant as l, URLOptions as lt, PossibleJavaScriptError as m, CallApiSchemaConfig as mt, DefaultDataType as n, GetCurrentRouteSchema as nt, PluginMiddlewares as o, InferInitURL as ot, PossibleHTTPError as p, CallApiSchema as pt, RequestStreamContext as q, DefaultPluginArray as r, GetCurrentRouteSchemaKey as rt, PluginSetupContext as s, InferParamsFromRoute as st, DefaultCallApiContext as t, ApplyURLBasedConfig as tt, CallApiResultSuccessVariant as u, BaseCallApiSchemaAndConfig as ut, ResultModeType as v, InferSchemaResult as vt, CallApiParameters as w, NoInferUnMasked as wt, CallApiConfig as x, AnyFunction as xt, BaseCallApiConfig as y, FallBackRouteSchemaKey as yt, Middlewares as z };
|
|
1831
|
-
//# sourceMappingURL=default-types-
|
|
1823
|
+
//# sourceMappingURL=default-types-CswfU2bI.d.ts.map
|
|
@@ -37,13 +37,12 @@ const isValidJsonString = (value) => {
|
|
|
37
37
|
const isSerializableObject = (value) => {
|
|
38
38
|
return isPlainObject(value) || isArray(value) || typeof value?.toJSON === "function";
|
|
39
39
|
};
|
|
40
|
-
const isFunction = (value) =>
|
|
40
|
+
const isFunction = (value) => {
|
|
41
|
+
return typeof value === "function";
|
|
42
|
+
};
|
|
41
43
|
const isQueryString = (value) => isString(value) && value.includes("=");
|
|
42
44
|
const isString = (value) => typeof value === "string";
|
|
43
45
|
const isPromise = (value) => value instanceof Promise;
|
|
44
|
-
const isReadableStream = (value) => {
|
|
45
|
-
return value instanceof ReadableStream;
|
|
46
|
-
};
|
|
47
46
|
//#endregion
|
|
48
47
|
//#region src/auth.ts
|
|
49
48
|
const resolveAuthValue = (value) => isFunction(value) ? value() : value;
|
|
@@ -667,6 +666,6 @@ const extraOptionDefaults = Object.freeze(defineEnum({
|
|
|
667
666
|
}));
|
|
668
667
|
const requestOptionDefaults = Object.freeze(defineEnum({ method: "GET" }));
|
|
669
668
|
//#endregion
|
|
670
|
-
export { getCurrentRouteSchemaKeyAndMainInitURL as A,
|
|
669
|
+
export { getCurrentRouteSchemaKeyAndMainInitURL as A, isString as B, defineSchema as C, toQueryString as D, toFormData as E, fallBackRouteSchemaKey as F, fetchSpecificKeys as I, isArray as L, handleSchemaValidation as M, HTTPError as N, toSearchParams as O, ValidationError as P, isBoolean as R, definePlugin as S, defineSchemaRoutes as T, isValidationError as _, getBody as a, defineInstanceConfig as b, getMethod as c, splitConfig as d, waitFor as f, isJavascriptError as g, isHTTPErrorInstance as h, createTimeoutSignal as i, handleConfigValidation as j, getFullAndNormalizedURL as k, getResolvedHeaders as l, isHTTPError as m, requestOptionDefaults as n, getFetchImpl as o, objectifyHeaders as p, createCombinedSignal as r, getHeaders as s, extraOptionDefaults as t, omitKeys as u, isValidationErrorInstance as v, defineSchemaConfig as w, defineMainSchema as x, defineBaseConfig as y, isFunction as z };
|
|
671
670
|
|
|
672
|
-
//# sourceMappingURL=defaults-
|
|
671
|
+
//# sourceMappingURL=defaults-D0QJmGE5.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"defaults-D0QJmGE5.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/common\";\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/common\";\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/common\";\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 {\n\tBaseCallApiExtraOptions,\n\tCallApiExtraOptions,\n\tCallApiRequestOptions,\n\tGlobalMeta,\n} from \"./types/common\";\nimport type { Body, HeadersOption, MethodUnion } from \"./types/conditional-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\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 type { CallApiExtraOptions } from \"./types/common\";\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\t/** Base URL to prepend to relative URLs */\n\tbaseURL: string | undefined;\n\t/** Initial URL pattern that may contain parameters and method modifiers */\n\tinitURL: string;\n\t/** Parameters to substitute into the URL path */\n\tparams: CallApiExtraOptions[\"params\"];\n\t/** Query parameters to append to the URL */\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 = (options: GetFullURLOptions) => {\n\tconst { baseURL, initURL, params, query } = options;\n\n\tconst normalizedInitURL = normalizeURL(initURL);\n\n\tconst initURLWithParams = mergeUrlWithParams(normalizedInitURL, params);\n\n\tconst initURLWithParamsAndQuery = mergeUrlWithQuery(initURLWithParams, query);\n\n\tconst fullURL = getFullURL(initURLWithParamsAndQuery, baseURL);\n\n\tif (!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/common\";\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/common\";\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/common\";\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 { CallApiExtraOptions, CallApiRequestOptions, SharedExtraOptions } from \"../types/common\";\nimport type { InferHeadersOption } from \"../types/conditional-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/common\";\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\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-
|
|
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";
|
|
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;
|
|
6
7
|
Data: DefaultDataType;
|
|
7
8
|
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;
|
|
28
29
|
Data: DefaultDataType;
|
|
29
30
|
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-
|
|
91
|
+
//# sourceMappingURL=index-DMCchZ0z.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-
|
|
2
|
-
import { n as createFetchClient, r as createFetchClientWithContext, t as callApi } from "./index-
|
|
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";
|
|
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
|
|
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";
|
|
2
2
|
//#region src/result.ts
|
|
3
3
|
const getResponseType = (response, responseParser) => ({
|
|
4
4
|
arrayBuffer: () => response.arrayBuffer(),
|
|
@@ -159,104 +159,128 @@ const executeHooksInCatchBlock = async (hookResultsOrPromise, hookInfo) => {
|
|
|
159
159
|
//#endregion
|
|
160
160
|
//#region src/stream.ts
|
|
161
161
|
const createProgressEvent = (options) => {
|
|
162
|
-
const { chunk, totalBytes, transferredBytes } = options;
|
|
162
|
+
const { chunk, isDone, totalBytes, transferredBytes } = options;
|
|
163
|
+
let percentage = totalBytes === 0 ? 0 : transferredBytes / totalBytes;
|
|
164
|
+
if (percentage >= 1) percentage = 1 - Number.EPSILON;
|
|
163
165
|
return {
|
|
164
166
|
chunk,
|
|
165
|
-
progress:
|
|
167
|
+
progress: (isDone ? 1 : percentage) * 100,
|
|
166
168
|
totalBytes,
|
|
167
169
|
transferredBytes
|
|
168
170
|
};
|
|
169
171
|
};
|
|
170
|
-
const
|
|
171
|
-
|
|
172
|
-
if (!
|
|
173
|
-
|
|
174
|
-
|
|
172
|
+
const textEncoder = new TextEncoder();
|
|
173
|
+
const estimateBodySize = (body) => {
|
|
174
|
+
if (!body) return 0;
|
|
175
|
+
if (body instanceof ReadableStream) return 0;
|
|
176
|
+
if (body instanceof FormData) {
|
|
177
|
+
let size = 0;
|
|
178
|
+
for (const [key, value] of body) {
|
|
179
|
+
size += 40;
|
|
180
|
+
size += textEncoder.encode(`Content-Disposition: form-data; name="${key}"`).byteLength;
|
|
181
|
+
size += isString(value) ? textEncoder.encode(value).byteLength : value.size;
|
|
182
|
+
}
|
|
183
|
+
return size;
|
|
184
|
+
}
|
|
185
|
+
if (body instanceof Blob) return body.size;
|
|
186
|
+
if (body instanceof ArrayBuffer || ArrayBuffer.isView(body)) return body.byteLength;
|
|
187
|
+
if (isString(body) || body instanceof URLSearchParams) return textEncoder.encode(String(body)).byteLength;
|
|
188
|
+
return 0;
|
|
175
189
|
};
|
|
176
|
-
const
|
|
190
|
+
const createTrackedStream = (streamOptions) => {
|
|
191
|
+
const { initialTotalBytes, onStream, streamBody } = streamOptions;
|
|
192
|
+
let totalBytes = initialTotalBytes;
|
|
193
|
+
let transferredBytes = 0;
|
|
194
|
+
const reportProgress = async (progressOptions) => {
|
|
195
|
+
const { chunk, isDone } = progressOptions;
|
|
196
|
+
if (isDone) {
|
|
197
|
+
await onStream(createProgressEvent({
|
|
198
|
+
chunk: null,
|
|
199
|
+
isDone: true,
|
|
200
|
+
totalBytes,
|
|
201
|
+
transferredBytes
|
|
202
|
+
}));
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
transferredBytes += chunk.byteLength;
|
|
206
|
+
totalBytes = Math.max(totalBytes, transferredBytes);
|
|
207
|
+
await onStream(createProgressEvent({
|
|
208
|
+
chunk,
|
|
209
|
+
totalBytes,
|
|
210
|
+
transferredBytes
|
|
211
|
+
}));
|
|
212
|
+
};
|
|
213
|
+
return streamBody.pipeThrough(new TransformStream({
|
|
214
|
+
flush: async () => {
|
|
215
|
+
await reportProgress({
|
|
216
|
+
chunk: null,
|
|
217
|
+
isDone: true
|
|
218
|
+
});
|
|
219
|
+
},
|
|
220
|
+
start: async () => {
|
|
221
|
+
await reportProgress({ chunk: new Uint8Array() });
|
|
222
|
+
},
|
|
223
|
+
transform: async (chunk, controller) => {
|
|
224
|
+
controller.enqueue(chunk);
|
|
225
|
+
await reportProgress({ chunk });
|
|
226
|
+
}
|
|
227
|
+
}));
|
|
228
|
+
};
|
|
229
|
+
const toStreamableRequest = (context) => {
|
|
177
230
|
const { baseConfig, config, options, request } = context;
|
|
178
|
-
if (!options.onRequestStream || !
|
|
231
|
+
if (!options.onRequestStream || !request.body) return request;
|
|
179
232
|
const requestInstance = new Request(options.fullURL, {
|
|
180
233
|
...request,
|
|
181
234
|
duplex: "half"
|
|
182
235
|
});
|
|
183
236
|
const contentLength = requestInstance.headers.get("content-length");
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
const
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
}),
|
|
198
|
-
options,
|
|
199
|
-
request,
|
|
200
|
-
requestInstance
|
|
201
|
-
};
|
|
202
|
-
await executeHooks(options.onRequestStream?.(requestStreamContext));
|
|
203
|
-
for await (const chunk of body) {
|
|
204
|
-
transferredBytes += chunk.byteLength;
|
|
205
|
-
totalBytes = Math.max(totalBytes, transferredBytes);
|
|
237
|
+
const initialTotalBytes = contentLength ? Math.max(0, Number(contentLength) || 0) : estimateBodySize(config.body ?? request.body);
|
|
238
|
+
const streamBody = requestInstance.body;
|
|
239
|
+
if (!streamBody) return requestInstance;
|
|
240
|
+
const requestStreamContext = {
|
|
241
|
+
baseConfig,
|
|
242
|
+
config,
|
|
243
|
+
options,
|
|
244
|
+
request,
|
|
245
|
+
requestInstance
|
|
246
|
+
};
|
|
247
|
+
const trackedStream = createTrackedStream({
|
|
248
|
+
initialTotalBytes,
|
|
249
|
+
onStream: async (event) => {
|
|
206
250
|
await executeHooks(options.onRequestStream?.({
|
|
207
251
|
...requestStreamContext,
|
|
208
|
-
event
|
|
209
|
-
chunk,
|
|
210
|
-
totalBytes,
|
|
211
|
-
transferredBytes
|
|
212
|
-
})
|
|
252
|
+
event
|
|
213
253
|
}));
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
} });
|
|
254
|
+
},
|
|
255
|
+
streamBody
|
|
256
|
+
});
|
|
218
257
|
return new Request(requestInstance, {
|
|
219
|
-
body:
|
|
258
|
+
body: trackedStream,
|
|
220
259
|
duplex: "half"
|
|
221
260
|
});
|
|
222
261
|
};
|
|
223
262
|
const toStreamableResponse = (context) => {
|
|
224
263
|
const { baseConfig, config, options, request, response } = context;
|
|
225
|
-
if (!options.onResponseStream || !response.body) return response;
|
|
226
|
-
const
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
transferredBytes
|
|
239
|
-
}),
|
|
240
|
-
options,
|
|
241
|
-
request,
|
|
242
|
-
response
|
|
243
|
-
};
|
|
244
|
-
await executeHooks(options.onResponseStream?.(responseStreamContext));
|
|
245
|
-
for await (const chunk of body) {
|
|
246
|
-
transferredBytes += chunk.byteLength;
|
|
247
|
-
totalBytes = Math.max(totalBytes, transferredBytes);
|
|
264
|
+
if (!options.onResponseStream || !response.body || response.status === 204) return response;
|
|
265
|
+
const initialTotalBytes = Math.max(0, Number(response.headers.get("content-length")) || 0);
|
|
266
|
+
const streamBody = response.body;
|
|
267
|
+
const responseStreamContext = {
|
|
268
|
+
baseConfig,
|
|
269
|
+
config,
|
|
270
|
+
options,
|
|
271
|
+
request,
|
|
272
|
+
response
|
|
273
|
+
};
|
|
274
|
+
const stream = createTrackedStream({
|
|
275
|
+
initialTotalBytes,
|
|
276
|
+
onStream: async (event) => {
|
|
248
277
|
await executeHooks(options.onResponseStream?.({
|
|
249
278
|
...responseStreamContext,
|
|
250
|
-
event
|
|
251
|
-
chunk,
|
|
252
|
-
totalBytes,
|
|
253
|
-
transferredBytes
|
|
254
|
-
})
|
|
279
|
+
event
|
|
255
280
|
}));
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
} });
|
|
281
|
+
},
|
|
282
|
+
streamBody
|
|
283
|
+
});
|
|
260
284
|
return new Response(stream, response);
|
|
261
285
|
};
|
|
262
286
|
//#endregion
|
|
@@ -326,20 +350,19 @@ const createDedupeStrategy = async (context) => {
|
|
|
326
350
|
const handleRequestDeferStrategy = async (deferContext) => {
|
|
327
351
|
const { fetchApi, options: localOptions, request: localRequest } = deferContext;
|
|
328
352
|
const shouldUsePromiseFromCache = prevRequestInfo && resolvedDedupeStrategy === "defer";
|
|
329
|
-
const
|
|
353
|
+
const streamContext = {
|
|
330
354
|
baseConfig,
|
|
331
355
|
config,
|
|
332
356
|
options: localOptions,
|
|
333
357
|
request: localRequest
|
|
334
358
|
};
|
|
335
|
-
const
|
|
336
|
-
const responsePromise = shouldUsePromiseFromCache ? prevRequestInfo.responsePromise : fetchApi(localOptions.fullURL, streamableRequest);
|
|
359
|
+
const responsePromise = shouldUsePromiseFromCache ? prevRequestInfo.responsePromise : fetchApi(localOptions.fullURL, toStreamableRequest(streamContext));
|
|
337
360
|
$RequestInfoCache?.set({
|
|
338
361
|
controller: newFetchController,
|
|
339
362
|
responsePromise
|
|
340
363
|
});
|
|
341
364
|
return toStreamableResponse({
|
|
342
|
-
...
|
|
365
|
+
...streamContext,
|
|
343
366
|
response: await responsePromise
|
|
344
367
|
});
|
|
345
368
|
};
|
|
@@ -592,8 +615,9 @@ const createFetchClientWithContext = () => {
|
|
|
592
615
|
const $LocalRequestInfoCache = /* @__PURE__ */ new Map();
|
|
593
616
|
const callApi = async (initURL, initConfig = {}) => {
|
|
594
617
|
const [fetchOptions, extraOptions] = splitConfig(initConfig);
|
|
618
|
+
const initURLString = initURL.toString();
|
|
595
619
|
const baseConfig = isFunction(initBaseConfig) ? initBaseConfig({
|
|
596
|
-
initURL:
|
|
620
|
+
initURL: initURLString,
|
|
597
621
|
options: extraOptions,
|
|
598
622
|
request: fetchOptions
|
|
599
623
|
}) : initBaseConfig;
|
|
@@ -614,7 +638,7 @@ const createFetchClientWithContext = () => {
|
|
|
614
638
|
const initURLResult = getCurrentRouteSchemaKeyAndMainInitURL({
|
|
615
639
|
baseExtraOptions: baseConfig,
|
|
616
640
|
extraOptions: config,
|
|
617
|
-
initURL:
|
|
641
|
+
initURL: initURLString
|
|
618
642
|
});
|
|
619
643
|
const { resolvedCurrentRouteSchemaKey, resolvedHooks, resolvedInitURL, resolvedMiddlewares, resolvedOptions, resolvedRequest } = await initializePlugins({
|
|
620
644
|
baseConfig,
|