@zayne-labs/callapi 1.8.2 → 1.8.4
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/esm/{common-Cg-2dq0u.d.ts → common-BR-RZ84M.d.ts} +88 -77
- package/dist/esm/index.d.ts +2 -2
- package/dist/esm/index.js +135 -23
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/utils/index.d.ts +1 -1
- package/dist/esm/utils/index.js +1 -1
- package/dist/esm/{utils-B6o_GJAn.js → utils-BbmhntpS.js} +19 -113
- package/dist/esm/utils-BbmhntpS.js.map +1 -0
- package/package.json +1 -1
- package/dist/esm/utils-B6o_GJAn.js.map +0 -1
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"utils-BbmhntpS.js","names":["value: TValue","errorDetails: HTTPErrorDetails<TErrorData>","errorOptions?: ErrorOptions","error: unknown","path: ValidationError[\"errorData\"][number][\"path\"]","issues: ValidationError[\"errorData\"]","details: ValidationErrorDetails","error: CallApiResultErrorVariant<TErrorData>[\"error\"] | null","error: unknown","error: CallApiResultErrorVariant<unknown>[\"error\"] | null","value: unknown","value: ValidAuthValue","auth: CallApiExtraOptions[\"auth\"]","initialObject: TObject","keysToOmit: TOmitArray","keysToPick: TPickArray","baseConfig: Record<string, any>","config: Record<string, any>","toQueryString: ToQueryStringFn","headers: CallApiRequestOptions[\"headers\"]","options: GetHeadersOptions","headersObject: Record<string, string | undefined>","options: GetBodyOptions","customFetchImpl: CallApiExtraOptions[\"customFetchImpl\"]","reject!: (reason?: unknown) => void","resolve!: (value: unknown) => void","delay: number","milliseconds: number"],"sources":["../../src/types/type-helpers.ts","../../src/constants/default-options.ts","../../src/error.ts","../../src/utils/guards.ts","../../src/auth.ts","../../src/constants/common.ts","../../src/utils/common.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 CallbackFn<in TParams, out TResult = void> = (...params: TParams[]) => TResult;\n\nexport type Prettify<TObject> = NonNullable<unknown> & { [Key in keyof TObject]: TObject[Key] };\n\nexport type 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[];\n\nexport type Writeable<TObject, TLevel extends WriteableLevel = \"shallow\"> = TObject extends readonly [\n\t...infer TTupleItems,\n]\n\t? [\n\t\t\t...{\n\t\t\t\t[Index in keyof TTupleItems]: TLevel extends \"deep\"\n\t\t\t\t\t? Writeable<TTupleItems[Index], \"deep\">\n\t\t\t\t\t: TTupleItems[Index];\n\t\t\t},\n\t\t]\n\t: TObject extends ArrayOrObject\n\t\t? {\n\t\t\t\t-readonly [Key in keyof TObject]: TLevel extends \"deep\"\n\t\t\t\t\t? Writeable<TObject[Key], \"deep\">\n\t\t\t\t\t: TObject[Key];\n\t\t\t}\n\t\t: TObject;\n\nexport const defineEnum = <const TValue extends object>(value: TValue) => value as Writeable<TValue>;\n\nexport type UnionToIntersection<TUnion> = (\n\tTUnion extends unknown ? (param: TUnion) => void : never\n) extends (param: infer TParam) => void\n\t? TParam\n\t: never;\n\n// == Using this Immediately Indexed Mapped type helper to help show computed type of anything passed to it instead of just the type name\nexport type UnmaskType<TValue> = { _: TValue }[\"_\"];\n\nexport type Awaitable<TValue> = Promise<TValue> | TValue;\n\nexport type CommonRequestHeaders =\n\t| \"Access-Control-Allow-Credentials\"\n\t| \"Access-Control-Allow-Headers\"\n\t| \"Access-Control-Allow-Methods\"\n\t| \"Access-Control-Allow-Origin\"\n\t| \"Access-Control-Expose-Headers\"\n\t| \"Access-Control-Max-Age\"\n\t| \"Age\"\n\t| \"Allow\"\n\t| \"Cache-Control\"\n\t| \"Clear-Site-Data\"\n\t| \"Content-Disposition\"\n\t| \"Content-Encoding\"\n\t| \"Content-Language\"\n\t| \"Content-Length\"\n\t| \"Content-Location\"\n\t| \"Content-Range\"\n\t| \"Content-Security-Policy-Report-Only\"\n\t| \"Content-Security-Policy\"\n\t| \"Cookie\"\n\t| \"Cross-Origin-Embedder-Policy\"\n\t| \"Cross-Origin-Opener-Policy\"\n\t| \"Cross-Origin-Resource-Policy\"\n\t| \"Date\"\n\t| \"ETag\"\n\t| \"Expires\"\n\t| \"Last-Modified\"\n\t| \"Location\"\n\t| \"Permissions-Policy\"\n\t| \"Pragma\"\n\t| \"Retry-After\"\n\t| \"Save-Data\"\n\t| \"Sec-CH-Prefers-Color-Scheme\"\n\t| \"Sec-CH-Prefers-Reduced-Motion\"\n\t| \"Sec-CH-UA-Arch\"\n\t| \"Sec-CH-UA-Bitness\"\n\t| \"Sec-CH-UA-Form-Factor\"\n\t| \"Sec-CH-UA-Full-Version-List\"\n\t| \"Sec-CH-UA-Full-Version\"\n\t| \"Sec-CH-UA-Mobile\"\n\t| \"Sec-CH-UA-Model\"\n\t| \"Sec-CH-UA-Platform-Version\"\n\t| \"Sec-CH-UA-Platform\"\n\t| \"Sec-CH-UA-WoW64\"\n\t| \"Sec-CH-UA\"\n\t| \"Sec-Fetch-Dest\"\n\t| \"Sec-Fetch-Mode\"\n\t| \"Sec-Fetch-Site\"\n\t| \"Sec-Fetch-User\"\n\t| \"Sec-GPC\"\n\t| \"Server-Timing\"\n\t| \"Server\"\n\t| \"Service-Worker-Navigation-Preload\"\n\t| \"Set-Cookie\"\n\t| \"Strict-Transport-Security\"\n\t| \"Timing-Allow-Origin\"\n\t| \"Trailer\"\n\t| \"Transfer-Encoding\"\n\t| \"Upgrade\"\n\t| \"Vary\"\n\t| \"Warning\"\n\t| \"WWW-Authenticate\"\n\t| \"X-Content-Type-Options\"\n\t| \"X-DNS-Prefetch-Control\"\n\t| \"X-Frame-Options\"\n\t| \"X-Permitted-Cross-Domain-Policies\"\n\t| \"X-Powered-By\"\n\t| \"X-Robots-Tag\"\n\t| \"X-XSS-Protection\"\n\t| AnyString;\n\nexport type CommonAuthorizationHeaders = `${\"Basic\" | \"Bearer\" | \"Token\"} ${string}`;\n\nexport type CommonContentTypes =\n\t| \"application/epub+zip\"\n\t| \"application/gzip\"\n\t| \"application/json\"\n\t| \"application/ld+json\"\n\t| \"application/octet-stream\"\n\t| \"application/ogg\"\n\t| \"application/pdf\"\n\t| \"application/rtf\"\n\t| \"application/vnd.ms-fontobject\"\n\t| \"application/wasm\"\n\t| \"application/xhtml+xml\"\n\t| \"application/xml\"\n\t| \"application/zip\"\n\t| \"audio/aac\"\n\t| \"audio/mpeg\"\n\t| \"audio/ogg\"\n\t| \"audio/opus\"\n\t| \"audio/webm\"\n\t| \"audio/x-midi\"\n\t| \"font/otf\"\n\t| \"font/ttf\"\n\t| \"font/woff\"\n\t| \"font/woff2\"\n\t| \"image/avif\"\n\t| \"image/bmp\"\n\t| \"image/gif\"\n\t| \"image/jpeg\"\n\t| \"image/png\"\n\t| \"image/svg+xml\"\n\t| \"image/tiff\"\n\t| \"image/webp\"\n\t| \"image/x-icon\"\n\t| \"model/gltf-binary\"\n\t| \"model/gltf+json\"\n\t| \"text/calendar\"\n\t| \"text/css\"\n\t| \"text/csv\"\n\t| \"text/html\"\n\t| \"text/javascript\"\n\t| \"text/plain\"\n\t| \"video/3gpp\"\n\t| \"video/3gpp2\"\n\t| \"video/av1\"\n\t| \"video/mp2t\"\n\t| \"video/mp4\"\n\t| \"video/mpeg\"\n\t| \"video/ogg\"\n\t| \"video/webm\"\n\t| \"video/x-msvideo\"\n\t| AnyString;\n","import type { CallApiExtraOptions } from \"../types/common\";\nimport { defineEnum } from \"../types/type-helpers\";\n\nexport const retryDefaults = defineEnum({\n\tattempts: 0,\n\tcondition: () => true,\n\tdelay: 1000,\n\tmaxDelay: 10000,\n\tmethods: [\"GET\", \"POST\"] satisfies CallApiExtraOptions[\"retryMethods\"],\n\tstatusCodes: [] satisfies CallApiExtraOptions[\"retryStatusCodes\"],\n\tstrategy: \"linear\",\n});\n\nexport const defaultRetryStatusCodesLookup = defineEnum({\n\t408: \"Request Timeout\",\n\t409: \"Conflict\",\n\t425: \"Too Early\",\n\t429: \"Too Many Requests\",\n\t500: \"Internal Server Error\",\n\t502: \"Bad Gateway\",\n\t503: \"Service Unavailable\",\n\t504: \"Gateway Timeout\",\n});\n\nexport const commonDefaults = defineEnum({\n\tbodySerializer: JSON.stringify,\n\tdefaultErrorMessage: \"An unexpected error occurred during the HTTP request.\",\n});\n\nexport const responseDefaults = defineEnum({\n\tresponseParser: JSON.parse,\n\tresponseType: \"json\",\n\tresultMode: \"all\",\n});\n\nexport const hookDefaults = defineEnum({\n\tmergedHooksExecutionMode: \"parallel\",\n\tmergedHooksExecutionOrder: \"mainHooksAfterPlugins\",\n});\n\nexport const dedupeDefaults = defineEnum({\n\tdedupeCacheScope: \"local\",\n\tdedupeStrategy: \"cancel\",\n});\n\nexport const requestOptionDefaults = defineEnum({\n\tmethod: \"GET\",\n});\n","import { commonDefaults } from \"./constants/default-options\";\nimport type { CallApiExtraOptions } from \"./types\";\nimport type { StandardSchemaV1 } from \"./types/standard-schema\";\nimport { isObject } from \"./utils/guards\";\n\ntype HTTPErrorDetails<TErrorData> = {\n\tdefaultErrorMessage: CallApiExtraOptions[\"defaultErrorMessage\"];\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\thttpErrorSymbol = httpErrorSymbol;\n\n\tisHTTPError = true;\n\n\toverride name = \"HTTPError\" as const;\n\n\tresponse: HTTPErrorDetails<TErrorData>[\"response\"];\n\n\tconstructor(errorDetails: HTTPErrorDetails<TErrorData>, errorOptions?: ErrorOptions) {\n\t\tconst { defaultErrorMessage, errorData, response } = errorDetails;\n\n\t\tconst selectedDefaultErrorMessage =\n\t\t\tdefaultErrorMessage ?? (response.statusText || commonDefaults.defaultErrorMessage);\n\n\t\tconst message =\n\t\t\t(errorData as { message?: string } | undefined)?.message ?? selectedDefaultErrorMessage;\n\n\t\tsuper(message, errorOptions);\n\n\t\tthis.errorData = errorData;\n\t\tthis.response = response;\n\t\tError.captureStackTrace(this, this.constructor);\n\t}\n\n\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 isError<TErrorData>(error: unknown): error is HTTPError<TErrorData> {\n\t\tif (!isObject<Record<string, unknown>>(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\treturn error.httpErrorSymbol === httpErrorSymbol && error.isHTTPError === true;\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\n\t\t.map((issue) => `✖ ${issue.message}${prettifyPath(issue.path)}`)\n\t\t.join(\" | \");\n\n\treturn issuesString;\n};\n\ntype ValidationErrorDetails = {\n\tissues: readonly StandardSchemaV1.Issue[];\n\tresponse: Response | null;\n};\n\nconst validationErrorSymbol = Symbol(\"validationErrorSymbol\");\n\nexport class ValidationError extends Error {\n\terrorData: ValidationErrorDetails[\"issues\"];\n\n\toverride name = \"ValidationError\";\n\n\tresponse: ValidationErrorDetails[\"response\"];\n\n\tvalidationErrorSymbol = validationErrorSymbol;\n\n\tconstructor(details: ValidationErrorDetails, errorOptions?: ErrorOptions) {\n\t\tconst { issues, response } = details;\n\n\t\tconst message = prettifyValidationIssues(issues);\n\n\t\tsuper(message, errorOptions);\n\n\t\tthis.errorData = issues;\n\t\tthis.response = response;\n\n\t\tError.captureStackTrace(this, this.constructor);\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 isError(error: unknown): error is ValidationError {\n\t\tif (!isObject<Record<string, unknown>>(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\treturn error.validationErrorSymbol === validationErrorSymbol && error.name === \"ValidationError\";\n\t}\n}\n","import { HTTPError, ValidationError } from \"../error\";\nimport type {\n\tCallApiResultErrorVariant,\n\tPossibleHTTPError,\n\tPossibleJavaScriptError,\n\tPossibleValidationError,\n} from \"../result\";\nimport type { AnyFunction } from \"../types/type-helpers\";\n\nexport const isHTTPError = <TErrorData>(\n\terror: CallApiResultErrorVariant<TErrorData>[\"error\"] | null\n): error is PossibleHTTPError<TErrorData> => {\n\treturn isObject(error) && error.name === \"HTTPError\";\n};\n\nexport const isHTTPErrorInstance = <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\nexport const isArray = <TArrayItem>(value: unknown): value is TArrayItem[] => Array.isArray(value);\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 isJsonString = (value: unknown): value is string => {\n\tif (!isString(value)) {\n\t\treturn false;\n\t}\n\n\ttry {\n\t\tJSON.parse(value);\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport const isSerializable = (value: unknown) => {\n\treturn (\n\t\tisPlainObject(value)\n\t\t|| isArray(value)\n\t\t|| typeof (value as { toJSON: unknown } | undefined)?.toJSON === \"function\"\n\t);\n};\n\nexport const isFunction = <TFunction extends AnyFunction>(value: unknown): value is TFunction =>\n\ttypeof value === \"function\";\n\nexport const isQueryString = (value: unknown): value is string => isString(value) && value.includes(\"=\");\n\nexport const isString = (value: unknown) => typeof value === \"string\";\n\nexport const isReadableStream = (value: unknown): value is ReadableStream<unknown> => {\n\treturn value instanceof ReadableStream;\n};\n\n// https://github.com/unjs/ofetch/blob/main/src/utils.ts\nexport const isJSONSerializable = (value: unknown) => {\n\tif (value === undefined) {\n\t\treturn false;\n\t}\n\tconst t = typeof value;\n\t// eslint-disable-next-line ts-eslint/no-unnecessary-condition -- No time to make this more type-safe\n\tif (t === \"string\" || t === \"number\" || t === \"boolean\" || t === null) {\n\t\treturn true;\n\t}\n\tif (t !== \"object\") {\n\t\treturn false;\n\t}\n\tif (isArray(value)) {\n\t\treturn true;\n\t}\n\tif ((value as Buffer | null)?.buffer) {\n\t\treturn false;\n\t}\n\n\treturn (\n\t\t(value?.constructor && value.constructor.name === \"Object\")\n\t\t// eslint-disable-next-line ts-eslint/prefer-nullish-coalescing -- Nullish coalescing makes no sense in this boolean context\n\t\t|| typeof (value as { toJSON: () => unknown } | null)?.toJSON === \"function\"\n\t);\n};\n","/* eslint-disable perfectionist/sort-object-types -- Avoid Sorting for now */\n\nimport type { CallApiExtraOptions } from \"./types/common\";\nimport type { Awaitable } from \"./types/type-helpers\";\nimport { isFunction, isString } from \"./utils/guards\";\n\ntype ValueOrFunctionResult<TValue> = TValue | (() => TValue);\n\ntype ValidAuthValue = ValueOrFunctionResult<Awaitable<string | null | undefined>>;\n\n/**\n * Bearer Or Token authentication\n *\n * The value of `bearer` will be added to a header as\n * `auth: Bearer some-auth-token`,\n *\n * The value of `token` will be added to a header as\n * `auth: Token some-auth-token`,\n */\nexport type BearerOrTokenAuth =\n\t| {\n\t\t\ttype?: \"Bearer\";\n\t\t\tbearer?: ValidAuthValue;\n\t\t\ttoken?: never;\n\t }\n\t| {\n\t\t\ttype?: \"Token\";\n\t\t\tbearer?: never;\n\t\t\ttoken?: ValidAuthValue;\n\t };\n\n/**\n * Basic auth\n */\nexport type BasicAuth = {\n\ttype: \"Basic\";\n\tusername: ValidAuthValue;\n\tpassword: ValidAuthValue;\n};\n\n/**\n * Custom auth\n *\n * @param prefix - prefix of the header\n * @param authValue - value of the header\n *\n * @example\n * ```ts\n * {\n * type: \"Custom\",\n * prefix: \"Token\",\n * authValue: \"token\"\n * }\n * ```\n */\nexport type CustomAuth = {\n\ttype: \"Custom\";\n\tprefix: ValidAuthValue;\n\tvalue: ValidAuthValue;\n};\n\n// eslint-disable-next-line perfectionist/sort-union-types -- Let the first one be first\nexport type Auth = BearerOrTokenAuth | BasicAuth | CustomAuth;\n\nconst getValue = (value: ValidAuthValue) => {\n\treturn isFunction(value) ? value() : value;\n};\n\ntype AuthorizationHeader = {\n\tAuthorization: string;\n};\n\nexport const getAuthHeader = async (\n\tauth: CallApiExtraOptions[\"auth\"]\n): Promise<AuthorizationHeader | undefined> => {\n\tif (auth === undefined) return;\n\n\tif (isString(auth) || auth === null) {\n\t\treturn { Authorization: `Bearer ${auth}` };\n\t}\n\n\tswitch (auth.type) {\n\t\tcase \"Basic\": {\n\t\t\tconst username = await getValue(auth.username);\n\t\t\tconst password = await getValue(auth.password);\n\n\t\t\tif (username === undefined || password === undefined) return;\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `Basic ${globalThis.btoa(`${username}:${password}`)}`,\n\t\t\t};\n\t\t}\n\n\t\tcase \"Custom\": {\n\t\t\tconst value = await getValue(auth.value);\n\n\t\t\tif (value === undefined) return;\n\n\t\t\tconst prefix = await getValue(auth.prefix);\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `${prefix} ${value}`,\n\t\t\t};\n\t\t}\n\n\t\tdefault: {\n\t\t\tconst bearer = await getValue(auth.bearer);\n\t\t\tconst token = await getValue(auth.token);\n\n\t\t\tif (\"token\" in auth && token !== undefined) {\n\t\t\t\treturn { Authorization: `Token ${token}` };\n\t\t\t}\n\n\t\t\tif (bearer === undefined) return;\n\n\t\t\treturn { Authorization: `Bearer ${bearer}` };\n\t\t}\n\t}\n};\n","import type { ModifiedRequestInit } from \"../types\";\nimport { defineEnum } from \"../types/type-helpers\";\n\nexport const fetchSpecificKeys = defineEnum([\n\t\"body\",\n\t\"integrity\",\n\t\"duplex\",\n\t\"method\",\n\t\"headers\",\n\t\"signal\",\n\t\"cache\",\n\t\"redirect\",\n\t\"window\",\n\t\"credentials\",\n\t\"keepalive\",\n\t\"referrer\",\n\t\"priority\",\n\t\"mode\",\n\t\"referrerPolicy\",\n] satisfies Array<keyof ModifiedRequestInit> as Array<keyof ModifiedRequestInit>);\n","import { getAuthHeader } from \"../auth\";\nimport { fetchSpecificKeys } from \"../constants/common\";\nimport { commonDefaults } from \"../constants/default-options\";\nimport type { BaseCallApiExtraOptions, CallApiExtraOptions, CallApiRequestOptions } from \"../types/common\";\nimport { isFunction, isJsonString, isPlainObject, isQueryString, isSerializable } from \"./guards\";\n\nexport const omitKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TOmitArray extends Array<keyof TObject>,\n>(\n\tinitialObject: TObject,\n\tkeysToOmit: TOmitArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tconst keysToOmitSet = new Set(keysToOmit);\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (!keysToOmitSet.has(key)) {\n\t\t\tupdatedObject[key] = value;\n\t\t}\n\t}\n\n\treturn updatedObject as Omit<TObject, TOmitArray[number]>;\n};\n\nexport const pickKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TPickArray extends Array<keyof TObject>,\n>(\n\tinitialObject: TObject,\n\tkeysToPick: TPickArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tconst keysToPickSet = new Set(keysToPick);\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (keysToPickSet.has(key)) {\n\t\t\tupdatedObject[key] = value;\n\t\t}\n\t}\n\n\treturn updatedObject as Pick<TObject, TPickArray[number]>;\n};\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport const splitBaseConfig = (baseConfig: Record<string, any>) =>\n\t[\n\t\tpickKeys(baseConfig, fetchSpecificKeys) as CallApiRequestOptions,\n\t\tomitKeys(baseConfig, fetchSpecificKeys) as BaseCallApiExtraOptions,\n\t] as const;\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport const splitConfig = (config: Record<string, any>) =>\n\t[\n\t\tpickKeys(config, fetchSpecificKeys) as CallApiRequestOptions,\n\t\tomitKeys(config, fetchSpecificKeys) as CallApiExtraOptions,\n\t] as const;\n\ntype ToQueryStringFn = {\n\t(params: CallApiExtraOptions[\"query\"]): string | null;\n\t(params: Required<CallApiExtraOptions>[\"query\"]): string;\n};\n\nexport const toQueryString: ToQueryStringFn = (params) => {\n\tif (!params) {\n\t\tconsole.error(\"toQueryString:\", \"No query params provided!\");\n\n\t\treturn null as never;\n\t}\n\n\treturn new URLSearchParams(params as Record<string, string>).toString();\n};\n\nexport const objectifyHeaders = (headers: CallApiRequestOptions[\"headers\"]) => {\n\tif (!headers || isPlainObject(headers)) {\n\t\treturn headers;\n\t}\n\n\treturn Object.fromEntries(headers);\n};\n\nexport type GetHeadersOptions = {\n\tauth: CallApiExtraOptions[\"auth\"];\n\tbody: CallApiRequestOptions[\"body\"];\n\theaders: CallApiRequestOptions[\"headers\"];\n};\n\nexport const getHeaders = async (options: GetHeadersOptions) => {\n\tconst { auth, body, headers } = options;\n\n\t// == Return early if any of the following conditions are not met (so that native fetch would auto set the correct headers):\n\tconst shouldResolveHeaders = Boolean(headers) || Boolean(body) || Boolean(auth);\n\n\tif (!shouldResolveHeaders) return;\n\n\tconst headersObject: Record<string, string | undefined> = {\n\t\t...(await getAuthHeader(auth)),\n\t\t...objectifyHeaders(headers),\n\t};\n\n\tif (isQueryString(body)) {\n\t\theadersObject[\"Content-Type\"] = \"application/x-www-form-urlencoded\";\n\n\t\treturn headersObject;\n\t}\n\n\tif (isSerializable(body) || isJsonString(body)) {\n\t\theadersObject[\"Content-Type\"] = \"application/json\";\n\t\theadersObject.Accept = \"application/json\";\n\t}\n\n\treturn headersObject;\n};\n\nexport type GetBodyOptions = {\n\tbody: CallApiRequestOptions[\"body\"];\n\tbodySerializer: CallApiExtraOptions[\"bodySerializer\"];\n};\n\nexport const getBody = (options: GetBodyOptions) => {\n\tconst { body, bodySerializer } = options;\n\n\tif (isSerializable(body)) {\n\t\tconst selectedBodySerializer = bodySerializer ?? commonDefaults.bodySerializer;\n\n\t\treturn selectedBodySerializer(body);\n\t}\n\n\treturn body;\n};\n\nexport const getFetchImpl = (customFetchImpl: CallApiExtraOptions[\"customFetchImpl\"]) => {\n\tif (customFetchImpl) {\n\t\treturn customFetchImpl;\n\t}\n\n\tif (typeof globalThis !== \"undefined\" && isFunction(globalThis.fetch)) {\n\t\treturn globalThis.fetch;\n\t}\n\n\tthrow new Error(\"No fetch implementation found\");\n};\n\nconst PromiseWithResolvers = () => {\n\tlet reject!: (reason?: unknown) => void;\n\tlet resolve!: (value: unknown) => void;\n\n\tconst promise = new Promise((res, rej) => {\n\t\tresolve = res;\n\t\treject = rej;\n\t});\n\n\treturn { promise, reject, resolve };\n};\n\nexport const waitFor = (delay: number) => {\n\tif (delay === 0) return;\n\n\tconst { promise, resolve } = PromiseWithResolvers();\n\n\tsetTimeout(resolve, delay);\n\n\treturn promise;\n};\n\nexport const createCombinedSignal = (...signals: Array<AbortSignal | null | undefined>) => {\n\tconst cleanedSignals = signals.filter(Boolean);\n\n\tconst combinedSignal = AbortSignal.any(cleanedSignals);\n\n\treturn combinedSignal;\n};\n\nexport const createTimeoutSignal = (milliseconds: number) => AbortSignal.timeout(milliseconds);\n"],"mappings":"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"}
|
package/package.json
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
{
|
2
2
|
"name": "@zayne-labs/callapi",
|
3
3
|
"type": "module",
|
4
|
-
"version": "1.8.
|
4
|
+
"version": "1.8.4",
|
5
5
|
"description": "A lightweight wrapper over fetch with quality of life improvements like built-in request cancellation, retries, interceptors and more",
|
6
6
|
"author": "Ryan Zayne",
|
7
7
|
"license": "MIT",
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"utils-B6o_GJAn.js","names":["value: TValue","errorDetails: ErrorDetails<TErrorData>","errorOptions?: ErrorOptions","error: unknown","path: StandardSchemaV1.Issue[\"path\"]","issues: ValidationError[\"errorData\"]","details: ValidationErrorDetails","errorOptions?: ErrorOptions","error: unknown","validator: Extract<CallApiSchema[keyof CallApiSchema], AnyFunction>","inputData: TInput","schema: TSchema","inputData: InferSchemaInput<TSchema>","response?: Response | null","baseSchema: TBaseSchema","schema: TSchema | undefined","validationOptions: ValidationOptions<TSchema>","validationOptions: ExtraOptionsValidationOptions","validatedResultObject: Prettify<\n\t\tPick<CallApiExtraOptions, (typeof extraOptionsToBeValidated)[number]>\n\t>","validationOptions: RequestOptionsValidationOptions","validatedResultObject: Prettify<\n\t\tPick<CallApiRequestOptions, (typeof requestOptionsToBeValidated)[number]>\n\t>","validationOptions: ExtraOptionsValidationOptions & RequestOptionsValidationOptions","error: CallApiResultErrorVariant<TErrorData>[\"error\"] | null","error: unknown","error: CallApiResultErrorVariant<unknown>[\"error\"] | null","value: unknown","value: ValidAuthValue","auth: SharedExtraOptions[\"auth\"]","initialObject: TObject","keysToOmit: TOmitArray","keysToPick: TPickArray","baseConfig: Record<string, any>","config: Record<string, any>","toQueryString: ToQueryStringFn","headers: CallApiRequestOptions[\"headers\"]","options: GetHeadersOptions","headersObject: Record<string, string | undefined>","options: GetBodyOptions","customFetchImpl: CallApiExtraOptions[\"customFetchImpl\"]","reject!: (reason?: unknown) => void","resolve!: (value: unknown) => void","delay: number","milliseconds: number"],"sources":["../../src/types/type-helpers.ts","../../src/constants/default-options.ts","../../src/error.ts","../../src/validation.ts","../../src/utils/guards.ts","../../src/auth.ts","../../src/constants/common.ts","../../src/utils/common.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 CallbackFn<in TParams, out TResult = void> = (...params: TParams[]) => TResult;\n\nexport type Prettify<TObject> = NonNullable<unknown> & { [Key in keyof TObject]: TObject[Key] };\n\nexport type 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[];\n\nexport type Writeable<TObject, TLevel extends WriteableLevel = \"shallow\"> = TObject extends readonly [\n\t...infer TTupleItems,\n]\n\t? [\n\t\t\t...{\n\t\t\t\t[Index in keyof TTupleItems]: TLevel extends \"deep\"\n\t\t\t\t\t? Writeable<TTupleItems[Index], \"deep\">\n\t\t\t\t\t: TTupleItems[Index];\n\t\t\t},\n\t\t]\n\t: TObject extends ArrayOrObject\n\t\t? {\n\t\t\t\t-readonly [Key in keyof TObject]: TLevel extends \"deep\"\n\t\t\t\t\t? Writeable<TObject[Key], \"deep\">\n\t\t\t\t\t: TObject[Key];\n\t\t\t}\n\t\t: TObject;\n\nexport const defineEnum = <const TValue extends object>(value: TValue) => value as Writeable<TValue>;\n\nexport type UnionToIntersection<TUnion> = (\n\tTUnion extends unknown ? (param: TUnion) => void : never\n) extends (param: infer TParam) => void\n\t? TParam\n\t: never;\n\n// == Using this Immediately Indexed Mapped type helper to help show computed type of anything passed to it instead of just the type name\nexport type UnmaskType<TValue> = { _: TValue }[\"_\"];\n\nexport type Awaitable<TValue> = Promise<TValue> | TValue;\n\nexport type CommonRequestHeaders =\n\t| \"Access-Control-Allow-Credentials\"\n\t| \"Access-Control-Allow-Headers\"\n\t| \"Access-Control-Allow-Methods\"\n\t| \"Access-Control-Allow-Origin\"\n\t| \"Access-Control-Expose-Headers\"\n\t| \"Access-Control-Max-Age\"\n\t| \"Age\"\n\t| \"Allow\"\n\t| \"Cache-Control\"\n\t| \"Clear-Site-Data\"\n\t| \"Content-Disposition\"\n\t| \"Content-Encoding\"\n\t| \"Content-Language\"\n\t| \"Content-Length\"\n\t| \"Content-Location\"\n\t| \"Content-Range\"\n\t| \"Content-Security-Policy-Report-Only\"\n\t| \"Content-Security-Policy\"\n\t| \"Cookie\"\n\t| \"Cross-Origin-Embedder-Policy\"\n\t| \"Cross-Origin-Opener-Policy\"\n\t| \"Cross-Origin-Resource-Policy\"\n\t| \"Date\"\n\t| \"ETag\"\n\t| \"Expires\"\n\t| \"Last-Modified\"\n\t| \"Location\"\n\t| \"Permissions-Policy\"\n\t| \"Pragma\"\n\t| \"Retry-After\"\n\t| \"Save-Data\"\n\t| \"Sec-CH-Prefers-Color-Scheme\"\n\t| \"Sec-CH-Prefers-Reduced-Motion\"\n\t| \"Sec-CH-UA-Arch\"\n\t| \"Sec-CH-UA-Bitness\"\n\t| \"Sec-CH-UA-Form-Factor\"\n\t| \"Sec-CH-UA-Full-Version-List\"\n\t| \"Sec-CH-UA-Full-Version\"\n\t| \"Sec-CH-UA-Mobile\"\n\t| \"Sec-CH-UA-Model\"\n\t| \"Sec-CH-UA-Platform-Version\"\n\t| \"Sec-CH-UA-Platform\"\n\t| \"Sec-CH-UA-WoW64\"\n\t| \"Sec-CH-UA\"\n\t| \"Sec-Fetch-Dest\"\n\t| \"Sec-Fetch-Mode\"\n\t| \"Sec-Fetch-Site\"\n\t| \"Sec-Fetch-User\"\n\t| \"Sec-GPC\"\n\t| \"Server-Timing\"\n\t| \"Server\"\n\t| \"Service-Worker-Navigation-Preload\"\n\t| \"Set-Cookie\"\n\t| \"Strict-Transport-Security\"\n\t| \"Timing-Allow-Origin\"\n\t| \"Trailer\"\n\t| \"Transfer-Encoding\"\n\t| \"Upgrade\"\n\t| \"Vary\"\n\t| \"Warning\"\n\t| \"WWW-Authenticate\"\n\t| \"X-Content-Type-Options\"\n\t| \"X-DNS-Prefetch-Control\"\n\t| \"X-Frame-Options\"\n\t| \"X-Permitted-Cross-Domain-Policies\"\n\t| \"X-Powered-By\"\n\t| \"X-Robots-Tag\"\n\t| \"X-XSS-Protection\"\n\t| AnyString;\n\nexport type CommonAuthorizationHeaders = `${\"Basic\" | \"Bearer\" | \"Token\"} ${string}`;\n\nexport type CommonContentTypes =\n\t| \"application/epub+zip\"\n\t| \"application/gzip\"\n\t| \"application/json\"\n\t| \"application/ld+json\"\n\t| \"application/octet-stream\"\n\t| \"application/ogg\"\n\t| \"application/pdf\"\n\t| \"application/rtf\"\n\t| \"application/vnd.ms-fontobject\"\n\t| \"application/wasm\"\n\t| \"application/xhtml+xml\"\n\t| \"application/xml\"\n\t| \"application/zip\"\n\t| \"audio/aac\"\n\t| \"audio/mpeg\"\n\t| \"audio/ogg\"\n\t| \"audio/opus\"\n\t| \"audio/webm\"\n\t| \"audio/x-midi\"\n\t| \"font/otf\"\n\t| \"font/ttf\"\n\t| \"font/woff\"\n\t| \"font/woff2\"\n\t| \"image/avif\"\n\t| \"image/bmp\"\n\t| \"image/gif\"\n\t| \"image/jpeg\"\n\t| \"image/png\"\n\t| \"image/svg+xml\"\n\t| \"image/tiff\"\n\t| \"image/webp\"\n\t| \"image/x-icon\"\n\t| \"model/gltf-binary\"\n\t| \"model/gltf+json\"\n\t| \"text/calendar\"\n\t| \"text/css\"\n\t| \"text/csv\"\n\t| \"text/html\"\n\t| \"text/javascript\"\n\t| \"text/plain\"\n\t| \"video/3gpp\"\n\t| \"video/3gpp2\"\n\t| \"video/av1\"\n\t| \"video/mp2t\"\n\t| \"video/mp4\"\n\t| \"video/mpeg\"\n\t| \"video/ogg\"\n\t| \"video/webm\"\n\t| \"video/x-msvideo\"\n\t| AnyString;\n","import type { SharedExtraOptions } from \"../types\";\nimport { defineEnum } from \"../types/type-helpers\";\n\nexport const retryDefaults = defineEnum({\n\tattempts: 0,\n\tcondition: () => true,\n\tdelay: 1000,\n\tmaxDelay: 10000,\n\tmethods: [\"GET\", \"POST\"] satisfies SharedExtraOptions[\"retryMethods\"],\n\tstatusCodes: [] satisfies SharedExtraOptions[\"retryStatusCodes\"],\n\tstrategy: \"linear\",\n});\n\nexport const defaultRetryStatusCodesLookup = defineEnum({\n\t408: \"Request Timeout\",\n\t409: \"Conflict\",\n\t425: \"Too Early\",\n\t429: \"Too Many Requests\",\n\t500: \"Internal Server Error\",\n\t502: \"Bad Gateway\",\n\t503: \"Service Unavailable\",\n\t504: \"Gateway Timeout\",\n});\n\nexport const commonDefaults = defineEnum({\n\tbodySerializer: JSON.stringify,\n\tdefaultErrorMessage: \"An unexpected error occurred during the HTTP request.\",\n});\n\nexport const responseDefaults = defineEnum({\n\tresponseParser: JSON.parse,\n\tresponseType: \"json\",\n\tresultMode: \"all\",\n});\n\nexport const hookDefaults = defineEnum({\n\tmergedHooksExecutionMode: \"parallel\",\n\tmergedHooksExecutionOrder: \"mainHooksAfterPlugins\",\n});\n\nexport const dedupeDefaults = defineEnum({\n\tdedupeStrategy: \"cancel\",\n});\n\nexport const requestOptionDefaults = defineEnum({\n\tmethod: \"GET\",\n});\n","import { commonDefaults } from \"./constants/default-options\";\nimport type { CallApiExtraOptions } from \"./types\";\nimport { isObject } from \"./utils/guards\";\n\ntype ErrorDetails<TErrorData> = {\n\tdefaultErrorMessage: CallApiExtraOptions[\"defaultErrorMessage\"];\n\terrorData: TErrorData;\n\tresponse: Response;\n};\n\nconst httpErrorSymbol = Symbol(\"HTTPError\");\n\nexport class HTTPError<TErrorData = Record<string, unknown>> extends Error {\n\terrorData: ErrorDetails<TErrorData>[\"errorData\"];\n\n\thttpErrorSymbol = httpErrorSymbol;\n\n\tisHTTPError = true;\n\n\toverride name = \"HTTPError\" as const;\n\n\tresponse: ErrorDetails<TErrorData>[\"response\"];\n\n\tconstructor(errorDetails: ErrorDetails<TErrorData>, errorOptions?: ErrorOptions) {\n\t\tconst { defaultErrorMessage, errorData, response } = errorDetails;\n\n\t\tconst selectedDefaultErrorMessage =\n\t\t\tdefaultErrorMessage ?? (response.statusText || commonDefaults.defaultErrorMessage);\n\n\t\tconst message =\n\t\t\t(errorData as { message?: string } | undefined)?.message ?? selectedDefaultErrorMessage;\n\n\t\tsuper(message, errorOptions);\n\n\t\tthis.errorData = errorData;\n\t\tthis.response = response;\n\t\tError.captureStackTrace(this, this.constructor);\n\t}\n\n\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 isError<TErrorData>(error: unknown): error is HTTPError<TErrorData> {\n\t\tif (!isObject<Record<string, unknown>>(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\treturn error.httpErrorSymbol === httpErrorSymbol && error.isHTTPError === true;\n\t}\n}\n","/* eslint-disable ts-eslint/consistent-type-definitions -- I need to use interfaces for the sake of user overrides */\nimport type {\n\tBody,\n\tCallApiExtraOptions,\n\tCallApiRequestOptions,\n\tGlobalMeta,\n\tHeadersOption,\n\tMethodUnion,\n} from \"./types\";\nimport type { StandardSchemaV1 } from \"./types/standard-schema\";\nimport {\n\ttype AnyFunction,\n\ttype AnyString,\n\ttype Awaitable,\n\ttype Prettify,\n\ttype UnionToIntersection,\n\ttype Writeable,\n\tdefineEnum,\n} from \"./types/type-helpers\";\nimport type { Params, Query } from \"./url\";\nimport { isFunction, isObject } from \"./utils/guards\";\n\ntype InferSchemaInput<TSchema extends CallApiSchema[keyof CallApiSchema]> =\n\tTSchema extends StandardSchemaV1\n\t\t? StandardSchemaV1.InferInput<TSchema>\n\t\t: TSchema extends (value: infer TInput) => unknown\n\t\t\t? TInput\n\t\t\t: never;\n\nexport type InferSchemaResult<TSchema, TFallbackResult = NonNullable<unknown>> = undefined extends TSchema\n\t? TFallbackResult\n\t: TSchema extends StandardSchemaV1\n\t\t? StandardSchemaV1.InferOutput<TSchema>\n\t\t: TSchema extends AnyFunction<infer TResult>\n\t\t\t? Awaited<TResult>\n\t\t\t: TFallbackResult;\n\nconst validationErrorSymbol = Symbol(\"validationErrorSymbol\");\n\ntype ValidationErrorDetails = {\n\tissues: readonly StandardSchemaV1.Issue[];\n\tresponse: Response | null;\n};\n\nconst formatPath = (path: StandardSchemaV1.Issue[\"path\"]) => {\n\tif (!path || path.length === 0) {\n\t\treturn \"\";\n\t}\n\n\treturn ` → at ${path.map((segment) => (isObject(segment) ? segment.key : String(segment))).join(\".\")}`;\n};\n\nconst formatValidationIssues = (issues: ValidationError[\"errorData\"]) => {\n\treturn issues.map((issue) => `✖ ${issue.message}${formatPath(issue.path)}`).join(\" | \");\n};\n\nexport class ValidationError extends Error {\n\terrorData: readonly StandardSchemaV1.Issue[];\n\n\toverride name = \"ValidationError\";\n\n\tresponse: Response | null;\n\n\tvalidationErrorSymbol = validationErrorSymbol;\n\n\tconstructor(details: ValidationErrorDetails, errorOptions?: ErrorOptions) {\n\t\tconst { issues, response } = details;\n\n\t\tconst message = formatValidationIssues(issues);\n\n\t\tsuper(message, errorOptions);\n\n\t\tthis.errorData = issues;\n\t\tthis.response = response;\n\n\t\tError.captureStackTrace(this, this.constructor);\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 isError(error: unknown): error is ValidationError {\n\t\tif (!isObject<Record<string, unknown>>(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\treturn error.validationErrorSymbol === validationErrorSymbol && error.name === \"ValidationError\";\n\t}\n}\n\nconst handleValidatorFunction = async <TInput>(\n\tvalidator: Extract<CallApiSchema[keyof CallApiSchema], AnyFunction>,\n\tinputData: TInput\n): Promise<StandardSchemaV1.Result<TInput>> => {\n\ttry {\n\t\tconst result = await validator(inputData as never);\n\n\t\treturn { issues: undefined, value: result as never };\n\t} catch (error) {\n\t\treturn { issues: error as never, value: undefined };\n\t}\n};\n\nexport const standardSchemaParser = async <\n\tTSchema extends NonNullable<CallApiSchema[keyof CallApiSchema]>,\n>(\n\tschema: TSchema,\n\tinputData: InferSchemaInput<TSchema>,\n\tresponse?: Response | null\n): Promise<InferSchemaResult<TSchema>> => {\n\tconst result = isFunction(schema)\n\t\t? await handleValidatorFunction(schema, inputData)\n\t\t: await schema[\"~standard\"].validate(inputData);\n\n\t// == If the `issues` field exists, it means the validation failed\n\tif (result.issues) {\n\t\tthrow new ValidationError(\n\t\t\t{ issues: result.issues, response: response ?? null },\n\t\t\t{ cause: result.issues }\n\t\t);\n\t}\n\n\treturn result.value as never;\n};\n\nexport interface CallApiSchemaConfig {\n\t/**\n\t * The base url of the schema. By default it's the baseURL of the fetch instance.\n\t */\n\tbaseURL?: string;\n\n\t/**\n\t * Disables runtime validation for the schema.\n\t */\n\tdisableRuntimeValidation?: boolean;\n\n\t/**\n\t * If `true`, the original input value will be used instead of the transformed/validated output.\n\t *\n\t * This is useful when you want to validate the input but don't want any transformations\n\t * applied by the validation schema (e.g., type coercion, default values, etc).\n\t */\n\tdisableValidationOutputApplication?: boolean;\n\n\t/**\n\t * Controls the inference of the method option based on the route modifiers (`@get/`, `@post/`, `@put/`, `@patch/`, `@delete/`).\n\t *\n\t * - When `true`, the method option is made required on the type level and is not automatically added to the request options.\n\t * - When `false` or `undefined` (default), the method option is not required on the type level, and is automatically added to the request options.\n\t *\n\t */\n\trequireHttpMethodProvision?: boolean;\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\n\t * - Attempting to call undefined routes will result in type 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 * - Provides more flexibility but less type safety\n\t *\n\t * @default false\n\t */\n\tstrict?: boolean;\n}\n\nexport interface CallApiSchema {\n\t/**\n\t * The schema to use for validating the request body.\n\t */\n\tbody?: StandardSchemaV1<Body> | ((body: Body) => Awaitable<Body>);\n\n\t/**\n\t * The schema to use for validating the response data.\n\t */\n\tdata?: StandardSchemaV1 | ((data: unknown) => unknown);\n\n\t/**\n\t * The schema to use for validating the response error data.\n\t */\n\terrorData?: StandardSchemaV1 | ((errorData: unknown) => unknown);\n\n\t/**\n\t * The schema to use for validating the request headers.\n\t */\n\theaders?:\n\t\t| StandardSchemaV1<HeadersOption | undefined>\n\t\t| ((headers: HeadersOption) => Awaitable<HeadersOption>);\n\n\t/**\n\t * The schema to use for validating the meta option.\n\t */\n\tmeta?: StandardSchemaV1<GlobalMeta | undefined> | ((meta: GlobalMeta) => Awaitable<GlobalMeta>);\n\n\t/**\n\t * The schema to use for validating the request method.\n\t */\n\tmethod?: StandardSchemaV1<MethodUnion | undefined> | ((method: MethodUnion) => Awaitable<MethodUnion>);\n\n\t/**\n\t * The schema to use for validating the request url parameters.\n\t */\n\tparams?: StandardSchemaV1<Params | undefined> | ((params: Params) => Awaitable<Params>);\n\n\t/**\n\t * The schema to use for validating the request url queries.\n\t */\n\tquery?: StandardSchemaV1<Query | undefined> | ((query: Query) => Awaitable<Query>);\n}\n\nexport const routeKeyMethods = defineEnum([\"delete\", \"get\", \"patch\", \"post\", \"put\"]);\n\nexport type RouteKeyMethods = (typeof routeKeyMethods)[number];\n\ntype PossibleRouteKey = `@${RouteKeyMethods}/` | AnyString;\n\nexport type BaseCallApiSchema = {\n\t[Key in PossibleRouteKey]?: CallApiSchema;\n};\n\nexport const defineSchema = <const TBaseSchema extends BaseCallApiSchema>(baseSchema: TBaseSchema) => {\n\treturn baseSchema as Writeable<typeof baseSchema, \"deep\">;\n};\n\ntype ValidationOptions<\n\tTSchema extends CallApiSchema[keyof CallApiSchema] = CallApiSchema[keyof CallApiSchema],\n> = {\n\tinputValue: InferSchemaInput<TSchema>;\n\tresponse?: Response | null;\n\tschemaConfig: CallApiSchemaConfig | undefined;\n};\n\nexport const handleValidation = async <TSchema extends CallApiSchema[keyof CallApiSchema]>(\n\tschema: TSchema | undefined,\n\tvalidationOptions: ValidationOptions<TSchema>\n): Promise<InferSchemaResult<TSchema>> => {\n\tconst { inputValue, response, schemaConfig } = validationOptions;\n\n\tif (!schema || schemaConfig?.disableRuntimeValidation) {\n\t\treturn inputValue as never;\n\t}\n\n\tconst validResult = await standardSchemaParser(schema, inputValue, response);\n\n\treturn validResult as never;\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 UnionToTuple<\n\tTUnion,\n\tTComputedLastUnion = LastOf<TUnion>,\n\tTComputedIsUnionEqualToNever = [TUnion] extends [never] ? true : false,\n> = true extends TComputedIsUnionEqualToNever\n\t? []\n\t: Push<UnionToTuple<Exclude<TUnion, TComputedLastUnion>>, TComputedLastUnion>;\n\nexport type Tuple<\n\tTTuple,\n\tTArray extends TTuple[] = [],\n> = UnionToTuple<TTuple>[\"length\"] extends TArray[\"length\"]\n\t? [...TArray]\n\t: Tuple<TTuple, [TTuple, ...TArray]>;\n\nconst extraOptionsToBeValidated = [\"meta\", \"params\", \"query\"] satisfies Tuple<\n\tExtract<keyof CallApiSchema, keyof CallApiExtraOptions>\n>;\n\ntype ExtraOptionsValidationOptions = {\n\textraOptions: CallApiExtraOptions;\n\tschema: CallApiSchema | undefined;\n\tschemaConfig: CallApiSchemaConfig | undefined;\n};\n\nconst handleExtraOptionsValidation = async (validationOptions: ExtraOptionsValidationOptions) => {\n\tconst { extraOptions, schema, schemaConfig } = validationOptions;\n\n\tconst validationResultArray = await Promise.all(\n\t\textraOptionsToBeValidated.map((propertyKey) =>\n\t\t\thandleValidation(schema?.[propertyKey], {\n\t\t\t\tinputValue: extraOptions[propertyKey],\n\t\t\t\tschemaConfig,\n\t\t\t})\n\t\t)\n\t);\n\n\tconst validatedResultObject: Prettify<\n\t\tPick<CallApiExtraOptions, (typeof extraOptionsToBeValidated)[number]>\n\t> = {};\n\n\tfor (const [index, propertyKey] of extraOptionsToBeValidated.entries()) {\n\t\tconst validationResult = validationResultArray[index];\n\n\t\tif (validationResult === undefined) continue;\n\n\t\tvalidatedResultObject[propertyKey] = validationResult as never;\n\t}\n\n\treturn validatedResultObject;\n};\n\nconst requestOptionsToBeValidated = [\"body\", \"headers\", \"method\"] satisfies Tuple<\n\tExtract<keyof CallApiSchema, keyof CallApiRequestOptions>\n>;\n\ntype RequestOptionsValidationOptions = {\n\trequestOptions: CallApiRequestOptions;\n\tschema: CallApiSchema | undefined;\n\tschemaConfig: CallApiSchemaConfig | undefined;\n};\n\nconst handleRequestOptionsValidation = async (validationOptions: RequestOptionsValidationOptions) => {\n\tconst { requestOptions, schema, schemaConfig } = validationOptions;\n\n\tconst validationResultArray = await Promise.all(\n\t\trequestOptionsToBeValidated.map((propertyKey) =>\n\t\t\thandleValidation(schema?.[propertyKey], {\n\t\t\t\tinputValue: requestOptions[propertyKey],\n\t\t\t\tschemaConfig,\n\t\t\t})\n\t\t)\n\t);\n\n\tconst validatedResultObject: Prettify<\n\t\tPick<CallApiRequestOptions, (typeof requestOptionsToBeValidated)[number]>\n\t> = {};\n\n\tfor (const [index, propertyKey] of requestOptionsToBeValidated.entries()) {\n\t\tconst validationResult = validationResultArray[index];\n\n\t\tif (validationResult === undefined) continue;\n\n\t\tvalidatedResultObject[propertyKey] = validationResult as never;\n\t}\n\n\treturn validatedResultObject;\n};\n\nexport const handleOptionsValidation = async (\n\tvalidationOptions: ExtraOptionsValidationOptions & RequestOptionsValidationOptions\n) => {\n\tconst { extraOptions, requestOptions, schema, schemaConfig } = validationOptions;\n\n\tif (schemaConfig?.disableRuntimeValidation) {\n\t\treturn {\n\t\t\textraOptionsValidationResult: null,\n\t\t\trequestOptionsValidationResult: null,\n\t\t};\n\t}\n\n\tconst [extraOptionsValidationResult, requestOptionsValidationResult] = await Promise.all([\n\t\thandleExtraOptionsValidation({ extraOptions, schema, schemaConfig }),\n\t\thandleRequestOptionsValidation({ requestOptions, schema, schemaConfig }),\n\t]);\n\n\treturn { extraOptionsValidationResult, requestOptionsValidationResult };\n};\n","import { HTTPError } from \"../error\";\nimport type {\n\tCallApiResultErrorVariant,\n\tPossibleHTTPError,\n\tPossibleJavaScriptError,\n\tPossibleValidationError,\n} from \"../result\";\nimport type { AnyFunction } from \"../types/type-helpers\";\nimport { ValidationError } from \"../validation\";\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\nexport const isArray = <TArrayItem>(value: unknown): value is TArrayItem[] => Array.isArray(value);\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 isJsonString = (value: unknown): value is string => {\n\tif (!isString(value)) {\n\t\treturn false;\n\t}\n\n\ttry {\n\t\tJSON.parse(value);\n\t\treturn true;\n\t} catch {\n\t\treturn false;\n\t}\n};\n\nexport const isSerializable = (value: unknown) => {\n\treturn (\n\t\tisPlainObject(value)\n\t\t|| isArray(value)\n\t\t|| typeof (value as { toJSON: unknown } | undefined)?.toJSON === \"function\"\n\t);\n};\n\nexport const isFunction = <TFunction extends AnyFunction>(value: unknown): value is TFunction =>\n\ttypeof value === \"function\";\n\nexport const isQueryString = (value: unknown): value is string => isString(value) && value.includes(\"=\");\n\nexport const isString = (value: unknown) => typeof value === \"string\";\n\nexport const isReadableStream = (value: unknown): value is ReadableStream<unknown> => {\n\treturn value instanceof ReadableStream;\n};\n\n// https://github.com/unjs/ofetch/blob/main/src/utils.ts\nexport const isJSONSerializable = (value: unknown) => {\n\tif (value === undefined) {\n\t\treturn false;\n\t}\n\tconst t = typeof value;\n\t// eslint-disable-next-line ts-eslint/no-unnecessary-condition -- No time to make this more type-safe\n\tif (t === \"string\" || t === \"number\" || t === \"boolean\" || t === null) {\n\t\treturn true;\n\t}\n\tif (t !== \"object\") {\n\t\treturn false;\n\t}\n\tif (isArray(value)) {\n\t\treturn true;\n\t}\n\tif ((value as Buffer | null)?.buffer) {\n\t\treturn false;\n\t}\n\n\treturn (\n\t\t(value?.constructor && value.constructor.name === \"Object\")\n\t\t// eslint-disable-next-line ts-eslint/prefer-nullish-coalescing -- Nullish coalescing makes no sense in this boolean context\n\t\t|| typeof (value as { toJSON: () => unknown } | null)?.toJSON === \"function\"\n\t);\n};\n","/* eslint-disable perfectionist/sort-object-types -- Avoid Sorting for now */\n\nimport type { SharedExtraOptions } from \"./types/common\";\nimport type { Awaitable } from \"./types/type-helpers\";\nimport { isFunction, isString } from \"./utils/guards\";\n\ntype ValueOrFunctionResult<TValue> = TValue | (() => TValue);\n\ntype ValidAuthValue = ValueOrFunctionResult<Awaitable<string | null | undefined>>;\n\n/**\n * Bearer Or Token authentication\n *\n * The value of `bearer` will be added to a header as\n * `auth: Bearer some-auth-token`,\n *\n * The value of `token` will be added to a header as\n * `auth: Token some-auth-token`,\n */\nexport type BearerOrTokenAuth =\n\t| {\n\t\t\ttype?: \"Bearer\";\n\t\t\tbearer?: ValidAuthValue;\n\t\t\ttoken?: never;\n\t }\n\t| {\n\t\t\ttype?: \"Token\";\n\t\t\tbearer?: never;\n\t\t\ttoken?: ValidAuthValue;\n\t };\n\n/**\n * Basic auth\n */\nexport type BasicAuth = {\n\ttype: \"Basic\";\n\tusername: ValidAuthValue;\n\tpassword: ValidAuthValue;\n};\n\n/**\n * Custom auth\n *\n * @param prefix - prefix of the header\n * @param authValue - value of the header\n *\n * @example\n * ```ts\n * {\n * type: \"Custom\",\n * prefix: \"Token\",\n * authValue: \"token\"\n * }\n * ```\n */\nexport type CustomAuth = {\n\ttype: \"Custom\";\n\tprefix: ValidAuthValue;\n\tvalue: ValidAuthValue;\n};\n\n// eslint-disable-next-line perfectionist/sort-union-types -- Let the first one be first\nexport type Auth = BearerOrTokenAuth | BasicAuth | CustomAuth;\n\nconst getValue = (value: ValidAuthValue) => {\n\treturn isFunction(value) ? value() : value;\n};\n\ntype AuthorizationHeader = {\n\tAuthorization: string;\n};\n\nexport const getAuthHeader = async (\n\tauth: SharedExtraOptions[\"auth\"]\n): Promise<false | AuthorizationHeader | undefined> => {\n\tif (auth === undefined) return;\n\n\tif (isString(auth) || auth === null) {\n\t\treturn { Authorization: `Bearer ${auth}` };\n\t}\n\n\tswitch (auth.type) {\n\t\tcase \"Basic\": {\n\t\t\tconst username = await getValue(auth.username);\n\t\t\tconst password = await getValue(auth.password);\n\n\t\t\tif (username === undefined || password === undefined) return;\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `Basic ${globalThis.btoa(`${username}:${password}`)}`,\n\t\t\t};\n\t\t}\n\n\t\tcase \"Custom\": {\n\t\t\tconst value = await getValue(auth.value);\n\n\t\t\tif (value === undefined) return;\n\n\t\t\tconst prefix = await getValue(auth.prefix);\n\n\t\t\treturn {\n\t\t\t\tAuthorization: `${prefix} ${value}`,\n\t\t\t};\n\t\t}\n\n\t\tdefault: {\n\t\t\tconst bearer = await getValue(auth.bearer);\n\t\t\tconst token = await getValue(auth.token);\n\n\t\t\tif (\"token\" in auth && token !== undefined) {\n\t\t\t\treturn { Authorization: `Token ${token}` };\n\t\t\t}\n\n\t\t\treturn bearer !== undefined && { Authorization: `Bearer ${bearer}` };\n\t\t}\n\t}\n};\n","import type { ModifiedRequestInit } from \"../types\";\nimport { defineEnum } from \"../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] satisfies Array<keyof ModifiedRequestInit> as Array<keyof ModifiedRequestInit>);\n","import { getAuthHeader } from \"../auth\";\nimport { fetchSpecificKeys } from \"../constants/common\";\nimport { commonDefaults } from \"../constants/default-options\";\nimport type { InferHeadersOption } from \"../types\";\nimport type { BaseCallApiExtraOptions, CallApiExtraOptions, CallApiRequestOptions } from \"../types/common\";\nimport type { AnyFunction } from \"../types/type-helpers\";\nimport type { CallApiSchema } from \"../validation\";\nimport { isFunction, isJsonString, isPlainObject, isQueryString, isSerializable } from \"./guards\";\n\nexport const omitKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TOmitArray extends Array<keyof TObject>,\n>(\n\tinitialObject: TObject,\n\tkeysToOmit: TOmitArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tconst keysToOmitSet = new Set(keysToOmit);\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (!keysToOmitSet.has(key)) {\n\t\t\tupdatedObject[key] = value;\n\t\t}\n\t}\n\n\treturn updatedObject as Omit<TObject, TOmitArray[number]>;\n};\n\nexport const pickKeys = <\n\tTObject extends Record<string, unknown>,\n\tconst TPickArray extends Array<keyof TObject>,\n>(\n\tinitialObject: TObject,\n\tkeysToPick: TPickArray\n) => {\n\tconst updatedObject = {} as Record<string, unknown>;\n\n\tconst keysToPickSet = new Set(keysToPick);\n\n\tfor (const [key, value] of Object.entries(initialObject)) {\n\t\tif (keysToPickSet.has(key)) {\n\t\t\tupdatedObject[key] = value;\n\t\t}\n\t}\n\n\treturn updatedObject as Pick<TObject, TPickArray[number]>;\n};\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport const splitBaseConfig = (baseConfig: Record<string, any>) =>\n\t[\n\t\tpickKeys(baseConfig, fetchSpecificKeys) as CallApiRequestOptions,\n\t\tomitKeys(baseConfig, fetchSpecificKeys) as BaseCallApiExtraOptions,\n\t] as const;\n\n// eslint-disable-next-line ts-eslint/no-explicit-any -- Any is required here so that one can pass custom function type without type errors\nexport const splitConfig = (config: Record<string, any>) =>\n\t[\n\t\tpickKeys(config, fetchSpecificKeys) as CallApiRequestOptions,\n\t\tomitKeys(config, fetchSpecificKeys) as CallApiExtraOptions,\n\t] as const;\n\ntype ToQueryStringFn = {\n\t(params: CallApiExtraOptions[\"query\"]): string | null;\n\t(params: Required<CallApiExtraOptions>[\"query\"]): string;\n};\n\nexport const toQueryString: ToQueryStringFn = (params) => {\n\tif (!params) {\n\t\tconsole.error(\"toQueryString:\", \"No query params provided!\");\n\n\t\treturn null as never;\n\t}\n\n\treturn new URLSearchParams(params as Record<string, string>).toString();\n};\n\nexport const objectifyHeaders = (headers: CallApiRequestOptions[\"headers\"]) => {\n\tif (!headers || isPlainObject(headers)) {\n\t\treturn headers;\n\t}\n\n\treturn Object.fromEntries(headers);\n};\n\nexport type GetHeadersOptions = {\n\tauth: CallApiExtraOptions[\"auth\"];\n\tbaseHeaders: CallApiRequestOptions[\"headers\"];\n\tbody: CallApiRequestOptions[\"body\"];\n\theaders: CallApiRequestOptions[\"headers\"];\n};\n\nexport const getHeaders = async (options: GetHeadersOptions) => {\n\tconst { auth, baseHeaders, body, headers } = options;\n\n\ttype HeaderFn = Extract<InferHeadersOption<CallApiSchema>[\"headers\"], AnyFunction>;\n\n\tconst resolvedHeaders = isFunction<HeaderFn>(headers)\n\t\t? headers({ baseHeaders: baseHeaders ?? {} })\n\t\t: (headers ?? baseHeaders);\n\n\t// == Return early if any of the following conditions are met (so that native fetch would auto set the correct headers):\n\t// == - The headers are not provided\n\t// == - The body is not provided\n\t// == - The auth option is not provided\n\tconst shouldResolveHeaders = Boolean(resolvedHeaders) || Boolean(body) || Boolean(auth);\n\n\tif (!shouldResolveHeaders) return;\n\n\tconst headersObject: Record<string, string | undefined> = {\n\t\t...(await getAuthHeader(auth)),\n\t\t...objectifyHeaders(resolvedHeaders),\n\t};\n\n\tif (isQueryString(body)) {\n\t\theadersObject[\"Content-Type\"] = \"application/x-www-form-urlencoded\";\n\n\t\treturn headersObject;\n\t}\n\n\tif (isSerializable(body) || isJsonString(body)) {\n\t\theadersObject[\"Content-Type\"] = \"application/json\";\n\t\theadersObject.Accept = \"application/json\";\n\t}\n\n\treturn headersObject;\n};\n\nexport type GetBodyOptions = {\n\tbody: CallApiRequestOptions[\"body\"];\n\tbodySerializer: CallApiExtraOptions[\"bodySerializer\"];\n};\n\nexport const getBody = (options: GetBodyOptions) => {\n\tconst { body, bodySerializer } = options;\n\n\tif (isSerializable(body)) {\n\t\tconst selectedBodySerializer = bodySerializer ?? commonDefaults.bodySerializer;\n\n\t\treturn selectedBodySerializer(body);\n\t}\n\n\treturn body;\n};\n\nexport const getFetchImpl = (customFetchImpl: CallApiExtraOptions[\"customFetchImpl\"]) => {\n\tif (customFetchImpl) {\n\t\treturn customFetchImpl;\n\t}\n\n\tif (typeof globalThis !== \"undefined\" && isFunction(globalThis.fetch)) {\n\t\treturn globalThis.fetch;\n\t}\n\n\tthrow new Error(\"No fetch implementation found\");\n};\n\nconst PromiseWithResolvers = () => {\n\tlet reject!: (reason?: unknown) => void;\n\tlet resolve!: (value: unknown) => void;\n\n\tconst promise = new Promise((res, rej) => {\n\t\tresolve = res;\n\t\treject = rej;\n\t});\n\n\treturn { promise, reject, resolve };\n};\n\nexport const waitFor = (delay: number) => {\n\tif (delay === 0) return;\n\n\tconst { promise, resolve } = PromiseWithResolvers();\n\n\tsetTimeout(resolve, delay);\n\n\treturn promise;\n};\n\nexport const createCombinedSignal = (...signals: Array<AbortSignal | null | undefined>) => {\n\tconst cleanedSignals = signals.filter(Boolean);\n\n\tconst combinedSignal = AbortSignal.any(cleanedSignals);\n\n\treturn combinedSignal;\n};\n\nexport const createTimeoutSignal = (milliseconds: number) => AbortSignal.timeout(milliseconds);\n"],"mappings":"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"}
|