13902 lines
456 KiB
JavaScript
13902 lines
456 KiB
JavaScript
|
|
import {
|
|||
|
|
__export
|
|||
|
|
} from "./chunk-V4OQ3NZ2.js";
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/external.js
|
|||
|
|
var external_exports = {};
|
|||
|
|
__export(external_exports, {
|
|||
|
|
$brand: () => $brand,
|
|||
|
|
$input: () => $input,
|
|||
|
|
$output: () => $output,
|
|||
|
|
NEVER: () => NEVER,
|
|||
|
|
TimePrecision: () => TimePrecision,
|
|||
|
|
ZodAny: () => ZodAny,
|
|||
|
|
ZodArray: () => ZodArray,
|
|||
|
|
ZodBase64: () => ZodBase64,
|
|||
|
|
ZodBase64URL: () => ZodBase64URL,
|
|||
|
|
ZodBigInt: () => ZodBigInt,
|
|||
|
|
ZodBigIntFormat: () => ZodBigIntFormat,
|
|||
|
|
ZodBoolean: () => ZodBoolean,
|
|||
|
|
ZodCIDRv4: () => ZodCIDRv4,
|
|||
|
|
ZodCIDRv6: () => ZodCIDRv6,
|
|||
|
|
ZodCUID: () => ZodCUID,
|
|||
|
|
ZodCUID2: () => ZodCUID2,
|
|||
|
|
ZodCatch: () => ZodCatch,
|
|||
|
|
ZodCodec: () => ZodCodec,
|
|||
|
|
ZodCustom: () => ZodCustom,
|
|||
|
|
ZodCustomStringFormat: () => ZodCustomStringFormat,
|
|||
|
|
ZodDate: () => ZodDate,
|
|||
|
|
ZodDefault: () => ZodDefault,
|
|||
|
|
ZodDiscriminatedUnion: () => ZodDiscriminatedUnion,
|
|||
|
|
ZodE164: () => ZodE164,
|
|||
|
|
ZodEmail: () => ZodEmail,
|
|||
|
|
ZodEmoji: () => ZodEmoji,
|
|||
|
|
ZodEnum: () => ZodEnum,
|
|||
|
|
ZodError: () => ZodError,
|
|||
|
|
ZodExactOptional: () => ZodExactOptional,
|
|||
|
|
ZodFile: () => ZodFile,
|
|||
|
|
ZodFirstPartyTypeKind: () => ZodFirstPartyTypeKind,
|
|||
|
|
ZodFunction: () => ZodFunction,
|
|||
|
|
ZodGUID: () => ZodGUID,
|
|||
|
|
ZodIPv4: () => ZodIPv4,
|
|||
|
|
ZodIPv6: () => ZodIPv6,
|
|||
|
|
ZodISODate: () => ZodISODate,
|
|||
|
|
ZodISODateTime: () => ZodISODateTime,
|
|||
|
|
ZodISODuration: () => ZodISODuration,
|
|||
|
|
ZodISOTime: () => ZodISOTime,
|
|||
|
|
ZodIntersection: () => ZodIntersection,
|
|||
|
|
ZodIssueCode: () => ZodIssueCode,
|
|||
|
|
ZodJWT: () => ZodJWT,
|
|||
|
|
ZodKSUID: () => ZodKSUID,
|
|||
|
|
ZodLazy: () => ZodLazy,
|
|||
|
|
ZodLiteral: () => ZodLiteral,
|
|||
|
|
ZodMAC: () => ZodMAC,
|
|||
|
|
ZodMap: () => ZodMap,
|
|||
|
|
ZodNaN: () => ZodNaN,
|
|||
|
|
ZodNanoID: () => ZodNanoID,
|
|||
|
|
ZodNever: () => ZodNever,
|
|||
|
|
ZodNonOptional: () => ZodNonOptional,
|
|||
|
|
ZodNull: () => ZodNull,
|
|||
|
|
ZodNullable: () => ZodNullable,
|
|||
|
|
ZodNumber: () => ZodNumber,
|
|||
|
|
ZodNumberFormat: () => ZodNumberFormat,
|
|||
|
|
ZodObject: () => ZodObject,
|
|||
|
|
ZodOptional: () => ZodOptional,
|
|||
|
|
ZodPipe: () => ZodPipe,
|
|||
|
|
ZodPrefault: () => ZodPrefault,
|
|||
|
|
ZodPromise: () => ZodPromise,
|
|||
|
|
ZodReadonly: () => ZodReadonly,
|
|||
|
|
ZodRealError: () => ZodRealError,
|
|||
|
|
ZodRecord: () => ZodRecord,
|
|||
|
|
ZodSet: () => ZodSet,
|
|||
|
|
ZodString: () => ZodString,
|
|||
|
|
ZodStringFormat: () => ZodStringFormat,
|
|||
|
|
ZodSuccess: () => ZodSuccess,
|
|||
|
|
ZodSymbol: () => ZodSymbol,
|
|||
|
|
ZodTemplateLiteral: () => ZodTemplateLiteral,
|
|||
|
|
ZodTransform: () => ZodTransform,
|
|||
|
|
ZodTuple: () => ZodTuple,
|
|||
|
|
ZodType: () => ZodType,
|
|||
|
|
ZodULID: () => ZodULID,
|
|||
|
|
ZodURL: () => ZodURL,
|
|||
|
|
ZodUUID: () => ZodUUID,
|
|||
|
|
ZodUndefined: () => ZodUndefined,
|
|||
|
|
ZodUnion: () => ZodUnion,
|
|||
|
|
ZodUnknown: () => ZodUnknown,
|
|||
|
|
ZodVoid: () => ZodVoid,
|
|||
|
|
ZodXID: () => ZodXID,
|
|||
|
|
ZodXor: () => ZodXor,
|
|||
|
|
_ZodString: () => _ZodString,
|
|||
|
|
_default: () => _default2,
|
|||
|
|
_function: () => _function,
|
|||
|
|
any: () => any,
|
|||
|
|
array: () => array,
|
|||
|
|
base64: () => base642,
|
|||
|
|
base64url: () => base64url2,
|
|||
|
|
bigint: () => bigint2,
|
|||
|
|
boolean: () => boolean2,
|
|||
|
|
catch: () => _catch2,
|
|||
|
|
check: () => check,
|
|||
|
|
cidrv4: () => cidrv42,
|
|||
|
|
cidrv6: () => cidrv62,
|
|||
|
|
clone: () => clone,
|
|||
|
|
codec: () => codec,
|
|||
|
|
coerce: () => coerce_exports,
|
|||
|
|
config: () => config,
|
|||
|
|
core: () => core_exports2,
|
|||
|
|
cuid: () => cuid3,
|
|||
|
|
cuid2: () => cuid22,
|
|||
|
|
custom: () => custom,
|
|||
|
|
date: () => date3,
|
|||
|
|
decode: () => decode2,
|
|||
|
|
decodeAsync: () => decodeAsync2,
|
|||
|
|
describe: () => describe2,
|
|||
|
|
discriminatedUnion: () => discriminatedUnion,
|
|||
|
|
e164: () => e1642,
|
|||
|
|
email: () => email2,
|
|||
|
|
emoji: () => emoji2,
|
|||
|
|
encode: () => encode2,
|
|||
|
|
encodeAsync: () => encodeAsync2,
|
|||
|
|
endsWith: () => _endsWith,
|
|||
|
|
enum: () => _enum2,
|
|||
|
|
exactOptional: () => exactOptional,
|
|||
|
|
file: () => file,
|
|||
|
|
flattenError: () => flattenError,
|
|||
|
|
float32: () => float32,
|
|||
|
|
float64: () => float64,
|
|||
|
|
formatError: () => formatError,
|
|||
|
|
fromJSONSchema: () => fromJSONSchema,
|
|||
|
|
function: () => _function,
|
|||
|
|
getErrorMap: () => getErrorMap,
|
|||
|
|
globalRegistry: () => globalRegistry,
|
|||
|
|
gt: () => _gt,
|
|||
|
|
gte: () => _gte,
|
|||
|
|
guid: () => guid2,
|
|||
|
|
hash: () => hash,
|
|||
|
|
hex: () => hex2,
|
|||
|
|
hostname: () => hostname2,
|
|||
|
|
httpUrl: () => httpUrl,
|
|||
|
|
includes: () => _includes,
|
|||
|
|
instanceof: () => _instanceof,
|
|||
|
|
int: () => int,
|
|||
|
|
int32: () => int32,
|
|||
|
|
int64: () => int64,
|
|||
|
|
intersection: () => intersection,
|
|||
|
|
ipv4: () => ipv42,
|
|||
|
|
ipv6: () => ipv62,
|
|||
|
|
iso: () => iso_exports,
|
|||
|
|
json: () => json,
|
|||
|
|
jwt: () => jwt,
|
|||
|
|
keyof: () => keyof,
|
|||
|
|
ksuid: () => ksuid2,
|
|||
|
|
lazy: () => lazy,
|
|||
|
|
length: () => _length,
|
|||
|
|
literal: () => literal,
|
|||
|
|
locales: () => locales_exports,
|
|||
|
|
looseObject: () => looseObject,
|
|||
|
|
looseRecord: () => looseRecord,
|
|||
|
|
lowercase: () => _lowercase,
|
|||
|
|
lt: () => _lt,
|
|||
|
|
lte: () => _lte,
|
|||
|
|
mac: () => mac2,
|
|||
|
|
map: () => map,
|
|||
|
|
maxLength: () => _maxLength,
|
|||
|
|
maxSize: () => _maxSize,
|
|||
|
|
meta: () => meta2,
|
|||
|
|
mime: () => _mime,
|
|||
|
|
minLength: () => _minLength,
|
|||
|
|
minSize: () => _minSize,
|
|||
|
|
multipleOf: () => _multipleOf,
|
|||
|
|
nan: () => nan,
|
|||
|
|
nanoid: () => nanoid2,
|
|||
|
|
nativeEnum: () => nativeEnum,
|
|||
|
|
negative: () => _negative,
|
|||
|
|
never: () => never,
|
|||
|
|
nonnegative: () => _nonnegative,
|
|||
|
|
nonoptional: () => nonoptional,
|
|||
|
|
nonpositive: () => _nonpositive,
|
|||
|
|
normalize: () => _normalize,
|
|||
|
|
null: () => _null3,
|
|||
|
|
nullable: () => nullable,
|
|||
|
|
nullish: () => nullish2,
|
|||
|
|
number: () => number2,
|
|||
|
|
object: () => object,
|
|||
|
|
optional: () => optional,
|
|||
|
|
overwrite: () => _overwrite,
|
|||
|
|
parse: () => parse2,
|
|||
|
|
parseAsync: () => parseAsync2,
|
|||
|
|
partialRecord: () => partialRecord,
|
|||
|
|
pipe: () => pipe,
|
|||
|
|
positive: () => _positive,
|
|||
|
|
prefault: () => prefault,
|
|||
|
|
preprocess: () => preprocess,
|
|||
|
|
prettifyError: () => prettifyError,
|
|||
|
|
promise: () => promise,
|
|||
|
|
property: () => _property,
|
|||
|
|
readonly: () => readonly,
|
|||
|
|
record: () => record,
|
|||
|
|
refine: () => refine,
|
|||
|
|
regex: () => _regex,
|
|||
|
|
regexes: () => regexes_exports,
|
|||
|
|
registry: () => registry,
|
|||
|
|
safeDecode: () => safeDecode2,
|
|||
|
|
safeDecodeAsync: () => safeDecodeAsync2,
|
|||
|
|
safeEncode: () => safeEncode2,
|
|||
|
|
safeEncodeAsync: () => safeEncodeAsync2,
|
|||
|
|
safeParse: () => safeParse2,
|
|||
|
|
safeParseAsync: () => safeParseAsync2,
|
|||
|
|
set: () => set,
|
|||
|
|
setErrorMap: () => setErrorMap,
|
|||
|
|
size: () => _size,
|
|||
|
|
slugify: () => _slugify,
|
|||
|
|
startsWith: () => _startsWith,
|
|||
|
|
strictObject: () => strictObject,
|
|||
|
|
string: () => string2,
|
|||
|
|
stringFormat: () => stringFormat,
|
|||
|
|
stringbool: () => stringbool,
|
|||
|
|
success: () => success,
|
|||
|
|
superRefine: () => superRefine,
|
|||
|
|
symbol: () => symbol,
|
|||
|
|
templateLiteral: () => templateLiteral,
|
|||
|
|
toJSONSchema: () => toJSONSchema,
|
|||
|
|
toLowerCase: () => _toLowerCase,
|
|||
|
|
toUpperCase: () => _toUpperCase,
|
|||
|
|
transform: () => transform,
|
|||
|
|
treeifyError: () => treeifyError,
|
|||
|
|
trim: () => _trim,
|
|||
|
|
tuple: () => tuple,
|
|||
|
|
uint32: () => uint32,
|
|||
|
|
uint64: () => uint64,
|
|||
|
|
ulid: () => ulid2,
|
|||
|
|
undefined: () => _undefined3,
|
|||
|
|
union: () => union,
|
|||
|
|
unknown: () => unknown,
|
|||
|
|
uppercase: () => _uppercase,
|
|||
|
|
url: () => url,
|
|||
|
|
util: () => util_exports,
|
|||
|
|
uuid: () => uuid2,
|
|||
|
|
uuidv4: () => uuidv4,
|
|||
|
|
uuidv6: () => uuidv6,
|
|||
|
|
uuidv7: () => uuidv7,
|
|||
|
|
void: () => _void2,
|
|||
|
|
xid: () => xid2,
|
|||
|
|
xor: () => xor
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/index.js
|
|||
|
|
var core_exports2 = {};
|
|||
|
|
__export(core_exports2, {
|
|||
|
|
$ZodAny: () => $ZodAny,
|
|||
|
|
$ZodArray: () => $ZodArray,
|
|||
|
|
$ZodAsyncError: () => $ZodAsyncError,
|
|||
|
|
$ZodBase64: () => $ZodBase64,
|
|||
|
|
$ZodBase64URL: () => $ZodBase64URL,
|
|||
|
|
$ZodBigInt: () => $ZodBigInt,
|
|||
|
|
$ZodBigIntFormat: () => $ZodBigIntFormat,
|
|||
|
|
$ZodBoolean: () => $ZodBoolean,
|
|||
|
|
$ZodCIDRv4: () => $ZodCIDRv4,
|
|||
|
|
$ZodCIDRv6: () => $ZodCIDRv6,
|
|||
|
|
$ZodCUID: () => $ZodCUID,
|
|||
|
|
$ZodCUID2: () => $ZodCUID2,
|
|||
|
|
$ZodCatch: () => $ZodCatch,
|
|||
|
|
$ZodCheck: () => $ZodCheck,
|
|||
|
|
$ZodCheckBigIntFormat: () => $ZodCheckBigIntFormat,
|
|||
|
|
$ZodCheckEndsWith: () => $ZodCheckEndsWith,
|
|||
|
|
$ZodCheckGreaterThan: () => $ZodCheckGreaterThan,
|
|||
|
|
$ZodCheckIncludes: () => $ZodCheckIncludes,
|
|||
|
|
$ZodCheckLengthEquals: () => $ZodCheckLengthEquals,
|
|||
|
|
$ZodCheckLessThan: () => $ZodCheckLessThan,
|
|||
|
|
$ZodCheckLowerCase: () => $ZodCheckLowerCase,
|
|||
|
|
$ZodCheckMaxLength: () => $ZodCheckMaxLength,
|
|||
|
|
$ZodCheckMaxSize: () => $ZodCheckMaxSize,
|
|||
|
|
$ZodCheckMimeType: () => $ZodCheckMimeType,
|
|||
|
|
$ZodCheckMinLength: () => $ZodCheckMinLength,
|
|||
|
|
$ZodCheckMinSize: () => $ZodCheckMinSize,
|
|||
|
|
$ZodCheckMultipleOf: () => $ZodCheckMultipleOf,
|
|||
|
|
$ZodCheckNumberFormat: () => $ZodCheckNumberFormat,
|
|||
|
|
$ZodCheckOverwrite: () => $ZodCheckOverwrite,
|
|||
|
|
$ZodCheckProperty: () => $ZodCheckProperty,
|
|||
|
|
$ZodCheckRegex: () => $ZodCheckRegex,
|
|||
|
|
$ZodCheckSizeEquals: () => $ZodCheckSizeEquals,
|
|||
|
|
$ZodCheckStartsWith: () => $ZodCheckStartsWith,
|
|||
|
|
$ZodCheckStringFormat: () => $ZodCheckStringFormat,
|
|||
|
|
$ZodCheckUpperCase: () => $ZodCheckUpperCase,
|
|||
|
|
$ZodCodec: () => $ZodCodec,
|
|||
|
|
$ZodCustom: () => $ZodCustom,
|
|||
|
|
$ZodCustomStringFormat: () => $ZodCustomStringFormat,
|
|||
|
|
$ZodDate: () => $ZodDate,
|
|||
|
|
$ZodDefault: () => $ZodDefault,
|
|||
|
|
$ZodDiscriminatedUnion: () => $ZodDiscriminatedUnion,
|
|||
|
|
$ZodE164: () => $ZodE164,
|
|||
|
|
$ZodEmail: () => $ZodEmail,
|
|||
|
|
$ZodEmoji: () => $ZodEmoji,
|
|||
|
|
$ZodEncodeError: () => $ZodEncodeError,
|
|||
|
|
$ZodEnum: () => $ZodEnum,
|
|||
|
|
$ZodError: () => $ZodError,
|
|||
|
|
$ZodExactOptional: () => $ZodExactOptional,
|
|||
|
|
$ZodFile: () => $ZodFile,
|
|||
|
|
$ZodFunction: () => $ZodFunction,
|
|||
|
|
$ZodGUID: () => $ZodGUID,
|
|||
|
|
$ZodIPv4: () => $ZodIPv4,
|
|||
|
|
$ZodIPv6: () => $ZodIPv6,
|
|||
|
|
$ZodISODate: () => $ZodISODate,
|
|||
|
|
$ZodISODateTime: () => $ZodISODateTime,
|
|||
|
|
$ZodISODuration: () => $ZodISODuration,
|
|||
|
|
$ZodISOTime: () => $ZodISOTime,
|
|||
|
|
$ZodIntersection: () => $ZodIntersection,
|
|||
|
|
$ZodJWT: () => $ZodJWT,
|
|||
|
|
$ZodKSUID: () => $ZodKSUID,
|
|||
|
|
$ZodLazy: () => $ZodLazy,
|
|||
|
|
$ZodLiteral: () => $ZodLiteral,
|
|||
|
|
$ZodMAC: () => $ZodMAC,
|
|||
|
|
$ZodMap: () => $ZodMap,
|
|||
|
|
$ZodNaN: () => $ZodNaN,
|
|||
|
|
$ZodNanoID: () => $ZodNanoID,
|
|||
|
|
$ZodNever: () => $ZodNever,
|
|||
|
|
$ZodNonOptional: () => $ZodNonOptional,
|
|||
|
|
$ZodNull: () => $ZodNull,
|
|||
|
|
$ZodNullable: () => $ZodNullable,
|
|||
|
|
$ZodNumber: () => $ZodNumber,
|
|||
|
|
$ZodNumberFormat: () => $ZodNumberFormat,
|
|||
|
|
$ZodObject: () => $ZodObject,
|
|||
|
|
$ZodObjectJIT: () => $ZodObjectJIT,
|
|||
|
|
$ZodOptional: () => $ZodOptional,
|
|||
|
|
$ZodPipe: () => $ZodPipe,
|
|||
|
|
$ZodPrefault: () => $ZodPrefault,
|
|||
|
|
$ZodPromise: () => $ZodPromise,
|
|||
|
|
$ZodReadonly: () => $ZodReadonly,
|
|||
|
|
$ZodRealError: () => $ZodRealError,
|
|||
|
|
$ZodRecord: () => $ZodRecord,
|
|||
|
|
$ZodRegistry: () => $ZodRegistry,
|
|||
|
|
$ZodSet: () => $ZodSet,
|
|||
|
|
$ZodString: () => $ZodString,
|
|||
|
|
$ZodStringFormat: () => $ZodStringFormat,
|
|||
|
|
$ZodSuccess: () => $ZodSuccess,
|
|||
|
|
$ZodSymbol: () => $ZodSymbol,
|
|||
|
|
$ZodTemplateLiteral: () => $ZodTemplateLiteral,
|
|||
|
|
$ZodTransform: () => $ZodTransform,
|
|||
|
|
$ZodTuple: () => $ZodTuple,
|
|||
|
|
$ZodType: () => $ZodType,
|
|||
|
|
$ZodULID: () => $ZodULID,
|
|||
|
|
$ZodURL: () => $ZodURL,
|
|||
|
|
$ZodUUID: () => $ZodUUID,
|
|||
|
|
$ZodUndefined: () => $ZodUndefined,
|
|||
|
|
$ZodUnion: () => $ZodUnion,
|
|||
|
|
$ZodUnknown: () => $ZodUnknown,
|
|||
|
|
$ZodVoid: () => $ZodVoid,
|
|||
|
|
$ZodXID: () => $ZodXID,
|
|||
|
|
$ZodXor: () => $ZodXor,
|
|||
|
|
$brand: () => $brand,
|
|||
|
|
$constructor: () => $constructor,
|
|||
|
|
$input: () => $input,
|
|||
|
|
$output: () => $output,
|
|||
|
|
Doc: () => Doc,
|
|||
|
|
JSONSchema: () => json_schema_exports,
|
|||
|
|
JSONSchemaGenerator: () => JSONSchemaGenerator,
|
|||
|
|
NEVER: () => NEVER,
|
|||
|
|
TimePrecision: () => TimePrecision,
|
|||
|
|
_any: () => _any,
|
|||
|
|
_array: () => _array,
|
|||
|
|
_base64: () => _base64,
|
|||
|
|
_base64url: () => _base64url,
|
|||
|
|
_bigint: () => _bigint,
|
|||
|
|
_boolean: () => _boolean,
|
|||
|
|
_catch: () => _catch,
|
|||
|
|
_check: () => _check,
|
|||
|
|
_cidrv4: () => _cidrv4,
|
|||
|
|
_cidrv6: () => _cidrv6,
|
|||
|
|
_coercedBigint: () => _coercedBigint,
|
|||
|
|
_coercedBoolean: () => _coercedBoolean,
|
|||
|
|
_coercedDate: () => _coercedDate,
|
|||
|
|
_coercedNumber: () => _coercedNumber,
|
|||
|
|
_coercedString: () => _coercedString,
|
|||
|
|
_cuid: () => _cuid,
|
|||
|
|
_cuid2: () => _cuid2,
|
|||
|
|
_custom: () => _custom,
|
|||
|
|
_date: () => _date,
|
|||
|
|
_decode: () => _decode,
|
|||
|
|
_decodeAsync: () => _decodeAsync,
|
|||
|
|
_default: () => _default,
|
|||
|
|
_discriminatedUnion: () => _discriminatedUnion,
|
|||
|
|
_e164: () => _e164,
|
|||
|
|
_email: () => _email,
|
|||
|
|
_emoji: () => _emoji2,
|
|||
|
|
_encode: () => _encode,
|
|||
|
|
_encodeAsync: () => _encodeAsync,
|
|||
|
|
_endsWith: () => _endsWith,
|
|||
|
|
_enum: () => _enum,
|
|||
|
|
_file: () => _file,
|
|||
|
|
_float32: () => _float32,
|
|||
|
|
_float64: () => _float64,
|
|||
|
|
_gt: () => _gt,
|
|||
|
|
_gte: () => _gte,
|
|||
|
|
_guid: () => _guid,
|
|||
|
|
_includes: () => _includes,
|
|||
|
|
_int: () => _int,
|
|||
|
|
_int32: () => _int32,
|
|||
|
|
_int64: () => _int64,
|
|||
|
|
_intersection: () => _intersection,
|
|||
|
|
_ipv4: () => _ipv4,
|
|||
|
|
_ipv6: () => _ipv6,
|
|||
|
|
_isoDate: () => _isoDate,
|
|||
|
|
_isoDateTime: () => _isoDateTime,
|
|||
|
|
_isoDuration: () => _isoDuration,
|
|||
|
|
_isoTime: () => _isoTime,
|
|||
|
|
_jwt: () => _jwt,
|
|||
|
|
_ksuid: () => _ksuid,
|
|||
|
|
_lazy: () => _lazy,
|
|||
|
|
_length: () => _length,
|
|||
|
|
_literal: () => _literal,
|
|||
|
|
_lowercase: () => _lowercase,
|
|||
|
|
_lt: () => _lt,
|
|||
|
|
_lte: () => _lte,
|
|||
|
|
_mac: () => _mac,
|
|||
|
|
_map: () => _map,
|
|||
|
|
_max: () => _lte,
|
|||
|
|
_maxLength: () => _maxLength,
|
|||
|
|
_maxSize: () => _maxSize,
|
|||
|
|
_mime: () => _mime,
|
|||
|
|
_min: () => _gte,
|
|||
|
|
_minLength: () => _minLength,
|
|||
|
|
_minSize: () => _minSize,
|
|||
|
|
_multipleOf: () => _multipleOf,
|
|||
|
|
_nan: () => _nan,
|
|||
|
|
_nanoid: () => _nanoid,
|
|||
|
|
_nativeEnum: () => _nativeEnum,
|
|||
|
|
_negative: () => _negative,
|
|||
|
|
_never: () => _never,
|
|||
|
|
_nonnegative: () => _nonnegative,
|
|||
|
|
_nonoptional: () => _nonoptional,
|
|||
|
|
_nonpositive: () => _nonpositive,
|
|||
|
|
_normalize: () => _normalize,
|
|||
|
|
_null: () => _null2,
|
|||
|
|
_nullable: () => _nullable,
|
|||
|
|
_number: () => _number,
|
|||
|
|
_optional: () => _optional,
|
|||
|
|
_overwrite: () => _overwrite,
|
|||
|
|
_parse: () => _parse,
|
|||
|
|
_parseAsync: () => _parseAsync,
|
|||
|
|
_pipe: () => _pipe,
|
|||
|
|
_positive: () => _positive,
|
|||
|
|
_promise: () => _promise,
|
|||
|
|
_property: () => _property,
|
|||
|
|
_readonly: () => _readonly,
|
|||
|
|
_record: () => _record,
|
|||
|
|
_refine: () => _refine,
|
|||
|
|
_regex: () => _regex,
|
|||
|
|
_safeDecode: () => _safeDecode,
|
|||
|
|
_safeDecodeAsync: () => _safeDecodeAsync,
|
|||
|
|
_safeEncode: () => _safeEncode,
|
|||
|
|
_safeEncodeAsync: () => _safeEncodeAsync,
|
|||
|
|
_safeParse: () => _safeParse,
|
|||
|
|
_safeParseAsync: () => _safeParseAsync,
|
|||
|
|
_set: () => _set,
|
|||
|
|
_size: () => _size,
|
|||
|
|
_slugify: () => _slugify,
|
|||
|
|
_startsWith: () => _startsWith,
|
|||
|
|
_string: () => _string,
|
|||
|
|
_stringFormat: () => _stringFormat,
|
|||
|
|
_stringbool: () => _stringbool,
|
|||
|
|
_success: () => _success,
|
|||
|
|
_superRefine: () => _superRefine,
|
|||
|
|
_symbol: () => _symbol,
|
|||
|
|
_templateLiteral: () => _templateLiteral,
|
|||
|
|
_toLowerCase: () => _toLowerCase,
|
|||
|
|
_toUpperCase: () => _toUpperCase,
|
|||
|
|
_transform: () => _transform,
|
|||
|
|
_trim: () => _trim,
|
|||
|
|
_tuple: () => _tuple,
|
|||
|
|
_uint32: () => _uint32,
|
|||
|
|
_uint64: () => _uint64,
|
|||
|
|
_ulid: () => _ulid,
|
|||
|
|
_undefined: () => _undefined2,
|
|||
|
|
_union: () => _union,
|
|||
|
|
_unknown: () => _unknown,
|
|||
|
|
_uppercase: () => _uppercase,
|
|||
|
|
_url: () => _url,
|
|||
|
|
_uuid: () => _uuid,
|
|||
|
|
_uuidv4: () => _uuidv4,
|
|||
|
|
_uuidv6: () => _uuidv6,
|
|||
|
|
_uuidv7: () => _uuidv7,
|
|||
|
|
_void: () => _void,
|
|||
|
|
_xid: () => _xid,
|
|||
|
|
_xor: () => _xor,
|
|||
|
|
clone: () => clone,
|
|||
|
|
config: () => config,
|
|||
|
|
createStandardJSONSchemaMethod: () => createStandardJSONSchemaMethod,
|
|||
|
|
createToJSONSchemaMethod: () => createToJSONSchemaMethod,
|
|||
|
|
decode: () => decode,
|
|||
|
|
decodeAsync: () => decodeAsync,
|
|||
|
|
describe: () => describe,
|
|||
|
|
encode: () => encode,
|
|||
|
|
encodeAsync: () => encodeAsync,
|
|||
|
|
extractDefs: () => extractDefs,
|
|||
|
|
finalize: () => finalize,
|
|||
|
|
flattenError: () => flattenError,
|
|||
|
|
formatError: () => formatError,
|
|||
|
|
globalConfig: () => globalConfig,
|
|||
|
|
globalRegistry: () => globalRegistry,
|
|||
|
|
initializeContext: () => initializeContext,
|
|||
|
|
isValidBase64: () => isValidBase64,
|
|||
|
|
isValidBase64URL: () => isValidBase64URL,
|
|||
|
|
isValidJWT: () => isValidJWT,
|
|||
|
|
locales: () => locales_exports,
|
|||
|
|
meta: () => meta,
|
|||
|
|
parse: () => parse,
|
|||
|
|
parseAsync: () => parseAsync,
|
|||
|
|
prettifyError: () => prettifyError,
|
|||
|
|
process: () => process,
|
|||
|
|
regexes: () => regexes_exports,
|
|||
|
|
registry: () => registry,
|
|||
|
|
safeDecode: () => safeDecode,
|
|||
|
|
safeDecodeAsync: () => safeDecodeAsync,
|
|||
|
|
safeEncode: () => safeEncode,
|
|||
|
|
safeEncodeAsync: () => safeEncodeAsync,
|
|||
|
|
safeParse: () => safeParse,
|
|||
|
|
safeParseAsync: () => safeParseAsync,
|
|||
|
|
toDotPath: () => toDotPath,
|
|||
|
|
toJSONSchema: () => toJSONSchema,
|
|||
|
|
treeifyError: () => treeifyError,
|
|||
|
|
util: () => util_exports,
|
|||
|
|
version: () => version
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/core.js
|
|||
|
|
var NEVER = Object.freeze({
|
|||
|
|
status: "aborted"
|
|||
|
|
});
|
|||
|
|
function $constructor(name, initializer3, params) {
|
|||
|
|
function init(inst, def) {
|
|||
|
|
if (!inst._zod) {
|
|||
|
|
Object.defineProperty(inst, "_zod", {
|
|||
|
|
value: {
|
|||
|
|
def,
|
|||
|
|
constr: _,
|
|||
|
|
traits: /* @__PURE__ */ new Set()
|
|||
|
|
},
|
|||
|
|
enumerable: false
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
if (inst._zod.traits.has(name)) {
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
inst._zod.traits.add(name);
|
|||
|
|
initializer3(inst, def);
|
|||
|
|
const proto = _.prototype;
|
|||
|
|
const keys = Object.keys(proto);
|
|||
|
|
for (let i = 0; i < keys.length; i++) {
|
|||
|
|
const k = keys[i];
|
|||
|
|
if (!(k in inst)) {
|
|||
|
|
inst[k] = proto[k].bind(inst);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const Parent = params?.Parent ?? Object;
|
|||
|
|
class Definition extends Parent {
|
|||
|
|
}
|
|||
|
|
Object.defineProperty(Definition, "name", { value: name });
|
|||
|
|
function _(def) {
|
|||
|
|
var _a2;
|
|||
|
|
const inst = params?.Parent ? new Definition() : this;
|
|||
|
|
init(inst, def);
|
|||
|
|
(_a2 = inst._zod).deferred ?? (_a2.deferred = []);
|
|||
|
|
for (const fn of inst._zod.deferred) {
|
|||
|
|
fn();
|
|||
|
|
}
|
|||
|
|
return inst;
|
|||
|
|
}
|
|||
|
|
Object.defineProperty(_, "init", { value: init });
|
|||
|
|
Object.defineProperty(_, Symbol.hasInstance, {
|
|||
|
|
value: (inst) => {
|
|||
|
|
if (params?.Parent && inst instanceof params.Parent)
|
|||
|
|
return true;
|
|||
|
|
return inst?._zod?.traits?.has(name);
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
Object.defineProperty(_, "name", { value: name });
|
|||
|
|
return _;
|
|||
|
|
}
|
|||
|
|
var $brand = /* @__PURE__ */ Symbol("zod_brand");
|
|||
|
|
var $ZodAsyncError = class extends Error {
|
|||
|
|
constructor() {
|
|||
|
|
super(`Encountered Promise during synchronous parse. Use .parseAsync() instead.`);
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var $ZodEncodeError = class extends Error {
|
|||
|
|
constructor(name) {
|
|||
|
|
super(`Encountered unidirectional transform during encode: ${name}`);
|
|||
|
|
this.name = "ZodEncodeError";
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var globalConfig = {};
|
|||
|
|
function config(newConfig) {
|
|||
|
|
if (newConfig)
|
|||
|
|
Object.assign(globalConfig, newConfig);
|
|||
|
|
return globalConfig;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/util.js
|
|||
|
|
var util_exports = {};
|
|||
|
|
__export(util_exports, {
|
|||
|
|
BIGINT_FORMAT_RANGES: () => BIGINT_FORMAT_RANGES,
|
|||
|
|
Class: () => Class,
|
|||
|
|
NUMBER_FORMAT_RANGES: () => NUMBER_FORMAT_RANGES,
|
|||
|
|
aborted: () => aborted,
|
|||
|
|
allowsEval: () => allowsEval,
|
|||
|
|
assert: () => assert,
|
|||
|
|
assertEqual: () => assertEqual,
|
|||
|
|
assertIs: () => assertIs,
|
|||
|
|
assertNever: () => assertNever,
|
|||
|
|
assertNotEqual: () => assertNotEqual,
|
|||
|
|
assignProp: () => assignProp,
|
|||
|
|
base64ToUint8Array: () => base64ToUint8Array,
|
|||
|
|
base64urlToUint8Array: () => base64urlToUint8Array,
|
|||
|
|
cached: () => cached,
|
|||
|
|
captureStackTrace: () => captureStackTrace,
|
|||
|
|
cleanEnum: () => cleanEnum,
|
|||
|
|
cleanRegex: () => cleanRegex,
|
|||
|
|
clone: () => clone,
|
|||
|
|
cloneDef: () => cloneDef,
|
|||
|
|
createTransparentProxy: () => createTransparentProxy,
|
|||
|
|
defineLazy: () => defineLazy,
|
|||
|
|
esc: () => esc,
|
|||
|
|
escapeRegex: () => escapeRegex,
|
|||
|
|
extend: () => extend,
|
|||
|
|
finalizeIssue: () => finalizeIssue,
|
|||
|
|
floatSafeRemainder: () => floatSafeRemainder,
|
|||
|
|
getElementAtPath: () => getElementAtPath,
|
|||
|
|
getEnumValues: () => getEnumValues,
|
|||
|
|
getLengthableOrigin: () => getLengthableOrigin,
|
|||
|
|
getParsedType: () => getParsedType,
|
|||
|
|
getSizableOrigin: () => getSizableOrigin,
|
|||
|
|
hexToUint8Array: () => hexToUint8Array,
|
|||
|
|
isObject: () => isObject,
|
|||
|
|
isPlainObject: () => isPlainObject,
|
|||
|
|
issue: () => issue,
|
|||
|
|
joinValues: () => joinValues,
|
|||
|
|
jsonStringifyReplacer: () => jsonStringifyReplacer,
|
|||
|
|
merge: () => merge,
|
|||
|
|
mergeDefs: () => mergeDefs,
|
|||
|
|
normalizeParams: () => normalizeParams,
|
|||
|
|
nullish: () => nullish,
|
|||
|
|
numKeys: () => numKeys,
|
|||
|
|
objectClone: () => objectClone,
|
|||
|
|
omit: () => omit,
|
|||
|
|
optionalKeys: () => optionalKeys,
|
|||
|
|
parsedType: () => parsedType,
|
|||
|
|
partial: () => partial,
|
|||
|
|
pick: () => pick,
|
|||
|
|
prefixIssues: () => prefixIssues,
|
|||
|
|
primitiveTypes: () => primitiveTypes,
|
|||
|
|
promiseAllObject: () => promiseAllObject,
|
|||
|
|
propertyKeyTypes: () => propertyKeyTypes,
|
|||
|
|
randomString: () => randomString,
|
|||
|
|
required: () => required,
|
|||
|
|
safeExtend: () => safeExtend,
|
|||
|
|
shallowClone: () => shallowClone,
|
|||
|
|
slugify: () => slugify,
|
|||
|
|
stringifyPrimitive: () => stringifyPrimitive,
|
|||
|
|
uint8ArrayToBase64: () => uint8ArrayToBase64,
|
|||
|
|
uint8ArrayToBase64url: () => uint8ArrayToBase64url,
|
|||
|
|
uint8ArrayToHex: () => uint8ArrayToHex,
|
|||
|
|
unwrapMessage: () => unwrapMessage
|
|||
|
|
});
|
|||
|
|
function assertEqual(val) {
|
|||
|
|
return val;
|
|||
|
|
}
|
|||
|
|
function assertNotEqual(val) {
|
|||
|
|
return val;
|
|||
|
|
}
|
|||
|
|
function assertIs(_arg) {
|
|||
|
|
}
|
|||
|
|
function assertNever(_x) {
|
|||
|
|
throw new Error("Unexpected value in exhaustive check");
|
|||
|
|
}
|
|||
|
|
function assert(_) {
|
|||
|
|
}
|
|||
|
|
function getEnumValues(entries) {
|
|||
|
|
const numericValues = Object.values(entries).filter((v) => typeof v === "number");
|
|||
|
|
const values = Object.entries(entries).filter(([k, _]) => numericValues.indexOf(+k) === -1).map(([_, v]) => v);
|
|||
|
|
return values;
|
|||
|
|
}
|
|||
|
|
function joinValues(array2, separator = "|") {
|
|||
|
|
return array2.map((val) => stringifyPrimitive(val)).join(separator);
|
|||
|
|
}
|
|||
|
|
function jsonStringifyReplacer(_, value) {
|
|||
|
|
if (typeof value === "bigint")
|
|||
|
|
return value.toString();
|
|||
|
|
return value;
|
|||
|
|
}
|
|||
|
|
function cached(getter) {
|
|||
|
|
const set2 = false;
|
|||
|
|
return {
|
|||
|
|
get value() {
|
|||
|
|
if (!set2) {
|
|||
|
|
const value = getter();
|
|||
|
|
Object.defineProperty(this, "value", { value });
|
|||
|
|
return value;
|
|||
|
|
}
|
|||
|
|
throw new Error("cached value already set");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
function nullish(input) {
|
|||
|
|
return input === null || input === void 0;
|
|||
|
|
}
|
|||
|
|
function cleanRegex(source) {
|
|||
|
|
const start = source.startsWith("^") ? 1 : 0;
|
|||
|
|
const end = source.endsWith("$") ? source.length - 1 : source.length;
|
|||
|
|
return source.slice(start, end);
|
|||
|
|
}
|
|||
|
|
function floatSafeRemainder(val, step) {
|
|||
|
|
const valDecCount = (val.toString().split(".")[1] || "").length;
|
|||
|
|
const stepString = step.toString();
|
|||
|
|
let stepDecCount = (stepString.split(".")[1] || "").length;
|
|||
|
|
if (stepDecCount === 0 && /\d?e-\d?/.test(stepString)) {
|
|||
|
|
const match = stepString.match(/\d?e-(\d?)/);
|
|||
|
|
if (match?.[1]) {
|
|||
|
|
stepDecCount = Number.parseInt(match[1]);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const decCount = valDecCount > stepDecCount ? valDecCount : stepDecCount;
|
|||
|
|
const valInt = Number.parseInt(val.toFixed(decCount).replace(".", ""));
|
|||
|
|
const stepInt = Number.parseInt(step.toFixed(decCount).replace(".", ""));
|
|||
|
|
return valInt % stepInt / 10 ** decCount;
|
|||
|
|
}
|
|||
|
|
var EVALUATING = /* @__PURE__ */ Symbol("evaluating");
|
|||
|
|
function defineLazy(object2, key, getter) {
|
|||
|
|
let value = void 0;
|
|||
|
|
Object.defineProperty(object2, key, {
|
|||
|
|
get() {
|
|||
|
|
if (value === EVALUATING) {
|
|||
|
|
return void 0;
|
|||
|
|
}
|
|||
|
|
if (value === void 0) {
|
|||
|
|
value = EVALUATING;
|
|||
|
|
value = getter();
|
|||
|
|
}
|
|||
|
|
return value;
|
|||
|
|
},
|
|||
|
|
set(v) {
|
|||
|
|
Object.defineProperty(object2, key, {
|
|||
|
|
value: v
|
|||
|
|
// configurable: true,
|
|||
|
|
});
|
|||
|
|
},
|
|||
|
|
configurable: true
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function objectClone(obj) {
|
|||
|
|
return Object.create(Object.getPrototypeOf(obj), Object.getOwnPropertyDescriptors(obj));
|
|||
|
|
}
|
|||
|
|
function assignProp(target, prop, value) {
|
|||
|
|
Object.defineProperty(target, prop, {
|
|||
|
|
value,
|
|||
|
|
writable: true,
|
|||
|
|
enumerable: true,
|
|||
|
|
configurable: true
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function mergeDefs(...defs) {
|
|||
|
|
const mergedDescriptors = {};
|
|||
|
|
for (const def of defs) {
|
|||
|
|
const descriptors = Object.getOwnPropertyDescriptors(def);
|
|||
|
|
Object.assign(mergedDescriptors, descriptors);
|
|||
|
|
}
|
|||
|
|
return Object.defineProperties({}, mergedDescriptors);
|
|||
|
|
}
|
|||
|
|
function cloneDef(schema) {
|
|||
|
|
return mergeDefs(schema._zod.def);
|
|||
|
|
}
|
|||
|
|
function getElementAtPath(obj, path) {
|
|||
|
|
if (!path)
|
|||
|
|
return obj;
|
|||
|
|
return path.reduce((acc, key) => acc?.[key], obj);
|
|||
|
|
}
|
|||
|
|
function promiseAllObject(promisesObj) {
|
|||
|
|
const keys = Object.keys(promisesObj);
|
|||
|
|
const promises = keys.map((key) => promisesObj[key]);
|
|||
|
|
return Promise.all(promises).then((results) => {
|
|||
|
|
const resolvedObj = {};
|
|||
|
|
for (let i = 0; i < keys.length; i++) {
|
|||
|
|
resolvedObj[keys[i]] = results[i];
|
|||
|
|
}
|
|||
|
|
return resolvedObj;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function randomString(length = 10) {
|
|||
|
|
const chars = "abcdefghijklmnopqrstuvwxyz";
|
|||
|
|
let str = "";
|
|||
|
|
for (let i = 0; i < length; i++) {
|
|||
|
|
str += chars[Math.floor(Math.random() * chars.length)];
|
|||
|
|
}
|
|||
|
|
return str;
|
|||
|
|
}
|
|||
|
|
function esc(str) {
|
|||
|
|
return JSON.stringify(str);
|
|||
|
|
}
|
|||
|
|
function slugify(input) {
|
|||
|
|
return input.toLowerCase().trim().replace(/[^\w\s-]/g, "").replace(/[\s_-]+/g, "-").replace(/^-+|-+$/g, "");
|
|||
|
|
}
|
|||
|
|
var captureStackTrace = "captureStackTrace" in Error ? Error.captureStackTrace : (..._args) => {
|
|||
|
|
};
|
|||
|
|
function isObject(data) {
|
|||
|
|
return typeof data === "object" && data !== null && !Array.isArray(data);
|
|||
|
|
}
|
|||
|
|
var allowsEval = cached(() => {
|
|||
|
|
if (typeof navigator !== "undefined" && navigator?.userAgent?.includes("Cloudflare")) {
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
try {
|
|||
|
|
const F = Function;
|
|||
|
|
new F("");
|
|||
|
|
return true;
|
|||
|
|
} catch (_) {
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
function isPlainObject(o) {
|
|||
|
|
if (isObject(o) === false)
|
|||
|
|
return false;
|
|||
|
|
const ctor = o.constructor;
|
|||
|
|
if (ctor === void 0)
|
|||
|
|
return true;
|
|||
|
|
if (typeof ctor !== "function")
|
|||
|
|
return true;
|
|||
|
|
const prot = ctor.prototype;
|
|||
|
|
if (isObject(prot) === false)
|
|||
|
|
return false;
|
|||
|
|
if (Object.prototype.hasOwnProperty.call(prot, "isPrototypeOf") === false) {
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
function shallowClone(o) {
|
|||
|
|
if (isPlainObject(o))
|
|||
|
|
return { ...o };
|
|||
|
|
if (Array.isArray(o))
|
|||
|
|
return [...o];
|
|||
|
|
return o;
|
|||
|
|
}
|
|||
|
|
function numKeys(data) {
|
|||
|
|
let keyCount = 0;
|
|||
|
|
for (const key in data) {
|
|||
|
|
if (Object.prototype.hasOwnProperty.call(data, key)) {
|
|||
|
|
keyCount++;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return keyCount;
|
|||
|
|
}
|
|||
|
|
var getParsedType = (data) => {
|
|||
|
|
const t = typeof data;
|
|||
|
|
switch (t) {
|
|||
|
|
case "undefined":
|
|||
|
|
return "undefined";
|
|||
|
|
case "string":
|
|||
|
|
return "string";
|
|||
|
|
case "number":
|
|||
|
|
return Number.isNaN(data) ? "nan" : "number";
|
|||
|
|
case "boolean":
|
|||
|
|
return "boolean";
|
|||
|
|
case "function":
|
|||
|
|
return "function";
|
|||
|
|
case "bigint":
|
|||
|
|
return "bigint";
|
|||
|
|
case "symbol":
|
|||
|
|
return "symbol";
|
|||
|
|
case "object":
|
|||
|
|
if (Array.isArray(data)) {
|
|||
|
|
return "array";
|
|||
|
|
}
|
|||
|
|
if (data === null) {
|
|||
|
|
return "null";
|
|||
|
|
}
|
|||
|
|
if (data.then && typeof data.then === "function" && data.catch && typeof data.catch === "function") {
|
|||
|
|
return "promise";
|
|||
|
|
}
|
|||
|
|
if (typeof Map !== "undefined" && data instanceof Map) {
|
|||
|
|
return "map";
|
|||
|
|
}
|
|||
|
|
if (typeof Set !== "undefined" && data instanceof Set) {
|
|||
|
|
return "set";
|
|||
|
|
}
|
|||
|
|
if (typeof Date !== "undefined" && data instanceof Date) {
|
|||
|
|
return "date";
|
|||
|
|
}
|
|||
|
|
if (typeof File !== "undefined" && data instanceof File) {
|
|||
|
|
return "file";
|
|||
|
|
}
|
|||
|
|
return "object";
|
|||
|
|
default:
|
|||
|
|
throw new Error(`Unknown data type: ${t}`);
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var propertyKeyTypes = /* @__PURE__ */ new Set(["string", "number", "symbol"]);
|
|||
|
|
var primitiveTypes = /* @__PURE__ */ new Set(["string", "number", "bigint", "boolean", "symbol", "undefined"]);
|
|||
|
|
function escapeRegex(str) {
|
|||
|
|
return str.replace(/[.*+?^${}()|[\]\\]/g, "\\$&");
|
|||
|
|
}
|
|||
|
|
function clone(inst, def, params) {
|
|||
|
|
const cl = new inst._zod.constr(def ?? inst._zod.def);
|
|||
|
|
if (!def || params?.parent)
|
|||
|
|
cl._zod.parent = inst;
|
|||
|
|
return cl;
|
|||
|
|
}
|
|||
|
|
function normalizeParams(_params) {
|
|||
|
|
const params = _params;
|
|||
|
|
if (!params)
|
|||
|
|
return {};
|
|||
|
|
if (typeof params === "string")
|
|||
|
|
return { error: () => params };
|
|||
|
|
if (params?.message !== void 0) {
|
|||
|
|
if (params?.error !== void 0)
|
|||
|
|
throw new Error("Cannot specify both `message` and `error` params");
|
|||
|
|
params.error = params.message;
|
|||
|
|
}
|
|||
|
|
delete params.message;
|
|||
|
|
if (typeof params.error === "string")
|
|||
|
|
return { ...params, error: () => params.error };
|
|||
|
|
return params;
|
|||
|
|
}
|
|||
|
|
function createTransparentProxy(getter) {
|
|||
|
|
let target;
|
|||
|
|
return new Proxy({}, {
|
|||
|
|
get(_, prop, receiver) {
|
|||
|
|
target ?? (target = getter());
|
|||
|
|
return Reflect.get(target, prop, receiver);
|
|||
|
|
},
|
|||
|
|
set(_, prop, value, receiver) {
|
|||
|
|
target ?? (target = getter());
|
|||
|
|
return Reflect.set(target, prop, value, receiver);
|
|||
|
|
},
|
|||
|
|
has(_, prop) {
|
|||
|
|
target ?? (target = getter());
|
|||
|
|
return Reflect.has(target, prop);
|
|||
|
|
},
|
|||
|
|
deleteProperty(_, prop) {
|
|||
|
|
target ?? (target = getter());
|
|||
|
|
return Reflect.deleteProperty(target, prop);
|
|||
|
|
},
|
|||
|
|
ownKeys(_) {
|
|||
|
|
target ?? (target = getter());
|
|||
|
|
return Reflect.ownKeys(target);
|
|||
|
|
},
|
|||
|
|
getOwnPropertyDescriptor(_, prop) {
|
|||
|
|
target ?? (target = getter());
|
|||
|
|
return Reflect.getOwnPropertyDescriptor(target, prop);
|
|||
|
|
},
|
|||
|
|
defineProperty(_, prop, descriptor) {
|
|||
|
|
target ?? (target = getter());
|
|||
|
|
return Reflect.defineProperty(target, prop, descriptor);
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function stringifyPrimitive(value) {
|
|||
|
|
if (typeof value === "bigint")
|
|||
|
|
return value.toString() + "n";
|
|||
|
|
if (typeof value === "string")
|
|||
|
|
return `"${value}"`;
|
|||
|
|
return `${value}`;
|
|||
|
|
}
|
|||
|
|
function optionalKeys(shape) {
|
|||
|
|
return Object.keys(shape).filter((k) => {
|
|||
|
|
return shape[k]._zod.optin === "optional" && shape[k]._zod.optout === "optional";
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var NUMBER_FORMAT_RANGES = {
|
|||
|
|
safeint: [Number.MIN_SAFE_INTEGER, Number.MAX_SAFE_INTEGER],
|
|||
|
|
int32: [-2147483648, 2147483647],
|
|||
|
|
uint32: [0, 4294967295],
|
|||
|
|
float32: [-34028234663852886e22, 34028234663852886e22],
|
|||
|
|
float64: [-Number.MAX_VALUE, Number.MAX_VALUE]
|
|||
|
|
};
|
|||
|
|
var BIGINT_FORMAT_RANGES = {
|
|||
|
|
int64: [BigInt("-9223372036854775808"), BigInt("9223372036854775807")],
|
|||
|
|
uint64: [BigInt(0), BigInt("18446744073709551615")]
|
|||
|
|
};
|
|||
|
|
function pick(schema, mask) {
|
|||
|
|
const currDef = schema._zod.def;
|
|||
|
|
const checks = currDef.checks;
|
|||
|
|
const hasChecks = checks && checks.length > 0;
|
|||
|
|
if (hasChecks) {
|
|||
|
|
throw new Error(".pick() cannot be used on object schemas containing refinements");
|
|||
|
|
}
|
|||
|
|
const def = mergeDefs(schema._zod.def, {
|
|||
|
|
get shape() {
|
|||
|
|
const newShape = {};
|
|||
|
|
for (const key in mask) {
|
|||
|
|
if (!(key in currDef.shape)) {
|
|||
|
|
throw new Error(`Unrecognized key: "${key}"`);
|
|||
|
|
}
|
|||
|
|
if (!mask[key])
|
|||
|
|
continue;
|
|||
|
|
newShape[key] = currDef.shape[key];
|
|||
|
|
}
|
|||
|
|
assignProp(this, "shape", newShape);
|
|||
|
|
return newShape;
|
|||
|
|
},
|
|||
|
|
checks: []
|
|||
|
|
});
|
|||
|
|
return clone(schema, def);
|
|||
|
|
}
|
|||
|
|
function omit(schema, mask) {
|
|||
|
|
const currDef = schema._zod.def;
|
|||
|
|
const checks = currDef.checks;
|
|||
|
|
const hasChecks = checks && checks.length > 0;
|
|||
|
|
if (hasChecks) {
|
|||
|
|
throw new Error(".omit() cannot be used on object schemas containing refinements");
|
|||
|
|
}
|
|||
|
|
const def = mergeDefs(schema._zod.def, {
|
|||
|
|
get shape() {
|
|||
|
|
const newShape = { ...schema._zod.def.shape };
|
|||
|
|
for (const key in mask) {
|
|||
|
|
if (!(key in currDef.shape)) {
|
|||
|
|
throw new Error(`Unrecognized key: "${key}"`);
|
|||
|
|
}
|
|||
|
|
if (!mask[key])
|
|||
|
|
continue;
|
|||
|
|
delete newShape[key];
|
|||
|
|
}
|
|||
|
|
assignProp(this, "shape", newShape);
|
|||
|
|
return newShape;
|
|||
|
|
},
|
|||
|
|
checks: []
|
|||
|
|
});
|
|||
|
|
return clone(schema, def);
|
|||
|
|
}
|
|||
|
|
function extend(schema, shape) {
|
|||
|
|
if (!isPlainObject(shape)) {
|
|||
|
|
throw new Error("Invalid input to extend: expected a plain object");
|
|||
|
|
}
|
|||
|
|
const checks = schema._zod.def.checks;
|
|||
|
|
const hasChecks = checks && checks.length > 0;
|
|||
|
|
if (hasChecks) {
|
|||
|
|
const existingShape = schema._zod.def.shape;
|
|||
|
|
for (const key in shape) {
|
|||
|
|
if (Object.getOwnPropertyDescriptor(existingShape, key) !== void 0) {
|
|||
|
|
throw new Error("Cannot overwrite keys on object schemas containing refinements. Use `.safeExtend()` instead.");
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const def = mergeDefs(schema._zod.def, {
|
|||
|
|
get shape() {
|
|||
|
|
const _shape = { ...schema._zod.def.shape, ...shape };
|
|||
|
|
assignProp(this, "shape", _shape);
|
|||
|
|
return _shape;
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
return clone(schema, def);
|
|||
|
|
}
|
|||
|
|
function safeExtend(schema, shape) {
|
|||
|
|
if (!isPlainObject(shape)) {
|
|||
|
|
throw new Error("Invalid input to safeExtend: expected a plain object");
|
|||
|
|
}
|
|||
|
|
const def = mergeDefs(schema._zod.def, {
|
|||
|
|
get shape() {
|
|||
|
|
const _shape = { ...schema._zod.def.shape, ...shape };
|
|||
|
|
assignProp(this, "shape", _shape);
|
|||
|
|
return _shape;
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
return clone(schema, def);
|
|||
|
|
}
|
|||
|
|
function merge(a, b) {
|
|||
|
|
const def = mergeDefs(a._zod.def, {
|
|||
|
|
get shape() {
|
|||
|
|
const _shape = { ...a._zod.def.shape, ...b._zod.def.shape };
|
|||
|
|
assignProp(this, "shape", _shape);
|
|||
|
|
return _shape;
|
|||
|
|
},
|
|||
|
|
get catchall() {
|
|||
|
|
return b._zod.def.catchall;
|
|||
|
|
},
|
|||
|
|
checks: []
|
|||
|
|
// delete existing checks
|
|||
|
|
});
|
|||
|
|
return clone(a, def);
|
|||
|
|
}
|
|||
|
|
function partial(Class2, schema, mask) {
|
|||
|
|
const currDef = schema._zod.def;
|
|||
|
|
const checks = currDef.checks;
|
|||
|
|
const hasChecks = checks && checks.length > 0;
|
|||
|
|
if (hasChecks) {
|
|||
|
|
throw new Error(".partial() cannot be used on object schemas containing refinements");
|
|||
|
|
}
|
|||
|
|
const def = mergeDefs(schema._zod.def, {
|
|||
|
|
get shape() {
|
|||
|
|
const oldShape = schema._zod.def.shape;
|
|||
|
|
const shape = { ...oldShape };
|
|||
|
|
if (mask) {
|
|||
|
|
for (const key in mask) {
|
|||
|
|
if (!(key in oldShape)) {
|
|||
|
|
throw new Error(`Unrecognized key: "${key}"`);
|
|||
|
|
}
|
|||
|
|
if (!mask[key])
|
|||
|
|
continue;
|
|||
|
|
shape[key] = Class2 ? new Class2({
|
|||
|
|
type: "optional",
|
|||
|
|
innerType: oldShape[key]
|
|||
|
|
}) : oldShape[key];
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
for (const key in oldShape) {
|
|||
|
|
shape[key] = Class2 ? new Class2({
|
|||
|
|
type: "optional",
|
|||
|
|
innerType: oldShape[key]
|
|||
|
|
}) : oldShape[key];
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
assignProp(this, "shape", shape);
|
|||
|
|
return shape;
|
|||
|
|
},
|
|||
|
|
checks: []
|
|||
|
|
});
|
|||
|
|
return clone(schema, def);
|
|||
|
|
}
|
|||
|
|
function required(Class2, schema, mask) {
|
|||
|
|
const def = mergeDefs(schema._zod.def, {
|
|||
|
|
get shape() {
|
|||
|
|
const oldShape = schema._zod.def.shape;
|
|||
|
|
const shape = { ...oldShape };
|
|||
|
|
if (mask) {
|
|||
|
|
for (const key in mask) {
|
|||
|
|
if (!(key in shape)) {
|
|||
|
|
throw new Error(`Unrecognized key: "${key}"`);
|
|||
|
|
}
|
|||
|
|
if (!mask[key])
|
|||
|
|
continue;
|
|||
|
|
shape[key] = new Class2({
|
|||
|
|
type: "nonoptional",
|
|||
|
|
innerType: oldShape[key]
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
for (const key in oldShape) {
|
|||
|
|
shape[key] = new Class2({
|
|||
|
|
type: "nonoptional",
|
|||
|
|
innerType: oldShape[key]
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
assignProp(this, "shape", shape);
|
|||
|
|
return shape;
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
return clone(schema, def);
|
|||
|
|
}
|
|||
|
|
function aborted(x, startIndex = 0) {
|
|||
|
|
if (x.aborted === true)
|
|||
|
|
return true;
|
|||
|
|
for (let i = startIndex; i < x.issues.length; i++) {
|
|||
|
|
if (x.issues[i]?.continue !== true) {
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
function prefixIssues(path, issues) {
|
|||
|
|
return issues.map((iss) => {
|
|||
|
|
var _a2;
|
|||
|
|
(_a2 = iss).path ?? (_a2.path = []);
|
|||
|
|
iss.path.unshift(path);
|
|||
|
|
return iss;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function unwrapMessage(message) {
|
|||
|
|
return typeof message === "string" ? message : message?.message;
|
|||
|
|
}
|
|||
|
|
function finalizeIssue(iss, ctx, config2) {
|
|||
|
|
const full = { ...iss, path: iss.path ?? [] };
|
|||
|
|
if (!iss.message) {
|
|||
|
|
const message = unwrapMessage(iss.inst?._zod.def?.error?.(iss)) ?? unwrapMessage(ctx?.error?.(iss)) ?? unwrapMessage(config2.customError?.(iss)) ?? unwrapMessage(config2.localeError?.(iss)) ?? "Invalid input";
|
|||
|
|
full.message = message;
|
|||
|
|
}
|
|||
|
|
delete full.inst;
|
|||
|
|
delete full.continue;
|
|||
|
|
if (!ctx?.reportInput) {
|
|||
|
|
delete full.input;
|
|||
|
|
}
|
|||
|
|
return full;
|
|||
|
|
}
|
|||
|
|
function getSizableOrigin(input) {
|
|||
|
|
if (input instanceof Set)
|
|||
|
|
return "set";
|
|||
|
|
if (input instanceof Map)
|
|||
|
|
return "map";
|
|||
|
|
if (input instanceof File)
|
|||
|
|
return "file";
|
|||
|
|
return "unknown";
|
|||
|
|
}
|
|||
|
|
function getLengthableOrigin(input) {
|
|||
|
|
if (Array.isArray(input))
|
|||
|
|
return "array";
|
|||
|
|
if (typeof input === "string")
|
|||
|
|
return "string";
|
|||
|
|
return "unknown";
|
|||
|
|
}
|
|||
|
|
function parsedType(data) {
|
|||
|
|
const t = typeof data;
|
|||
|
|
switch (t) {
|
|||
|
|
case "number": {
|
|||
|
|
return Number.isNaN(data) ? "nan" : "number";
|
|||
|
|
}
|
|||
|
|
case "object": {
|
|||
|
|
if (data === null) {
|
|||
|
|
return "null";
|
|||
|
|
}
|
|||
|
|
if (Array.isArray(data)) {
|
|||
|
|
return "array";
|
|||
|
|
}
|
|||
|
|
const obj = data;
|
|||
|
|
if (obj && Object.getPrototypeOf(obj) !== Object.prototype && "constructor" in obj && obj.constructor) {
|
|||
|
|
return obj.constructor.name;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return t;
|
|||
|
|
}
|
|||
|
|
function issue(...args) {
|
|||
|
|
const [iss, input, inst] = args;
|
|||
|
|
if (typeof iss === "string") {
|
|||
|
|
return {
|
|||
|
|
message: iss,
|
|||
|
|
code: "custom",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
return { ...iss };
|
|||
|
|
}
|
|||
|
|
function cleanEnum(obj) {
|
|||
|
|
return Object.entries(obj).filter(([k, _]) => {
|
|||
|
|
return Number.isNaN(Number.parseInt(k, 10));
|
|||
|
|
}).map((el) => el[1]);
|
|||
|
|
}
|
|||
|
|
function base64ToUint8Array(base643) {
|
|||
|
|
const binaryString = atob(base643);
|
|||
|
|
const bytes = new Uint8Array(binaryString.length);
|
|||
|
|
for (let i = 0; i < binaryString.length; i++) {
|
|||
|
|
bytes[i] = binaryString.charCodeAt(i);
|
|||
|
|
}
|
|||
|
|
return bytes;
|
|||
|
|
}
|
|||
|
|
function uint8ArrayToBase64(bytes) {
|
|||
|
|
let binaryString = "";
|
|||
|
|
for (let i = 0; i < bytes.length; i++) {
|
|||
|
|
binaryString += String.fromCharCode(bytes[i]);
|
|||
|
|
}
|
|||
|
|
return btoa(binaryString);
|
|||
|
|
}
|
|||
|
|
function base64urlToUint8Array(base64url3) {
|
|||
|
|
const base643 = base64url3.replace(/-/g, "+").replace(/_/g, "/");
|
|||
|
|
const padding = "=".repeat((4 - base643.length % 4) % 4);
|
|||
|
|
return base64ToUint8Array(base643 + padding);
|
|||
|
|
}
|
|||
|
|
function uint8ArrayToBase64url(bytes) {
|
|||
|
|
return uint8ArrayToBase64(bytes).replace(/\+/g, "-").replace(/\//g, "_").replace(/=/g, "");
|
|||
|
|
}
|
|||
|
|
function hexToUint8Array(hex3) {
|
|||
|
|
const cleanHex = hex3.replace(/^0x/, "");
|
|||
|
|
if (cleanHex.length % 2 !== 0) {
|
|||
|
|
throw new Error("Invalid hex string length");
|
|||
|
|
}
|
|||
|
|
const bytes = new Uint8Array(cleanHex.length / 2);
|
|||
|
|
for (let i = 0; i < cleanHex.length; i += 2) {
|
|||
|
|
bytes[i / 2] = Number.parseInt(cleanHex.slice(i, i + 2), 16);
|
|||
|
|
}
|
|||
|
|
return bytes;
|
|||
|
|
}
|
|||
|
|
function uint8ArrayToHex(bytes) {
|
|||
|
|
return Array.from(bytes).map((b) => b.toString(16).padStart(2, "0")).join("");
|
|||
|
|
}
|
|||
|
|
var Class = class {
|
|||
|
|
constructor(..._args) {
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/errors.js
|
|||
|
|
var initializer = (inst, def) => {
|
|||
|
|
inst.name = "$ZodError";
|
|||
|
|
Object.defineProperty(inst, "_zod", {
|
|||
|
|
value: inst._zod,
|
|||
|
|
enumerable: false
|
|||
|
|
});
|
|||
|
|
Object.defineProperty(inst, "issues", {
|
|||
|
|
value: def,
|
|||
|
|
enumerable: false
|
|||
|
|
});
|
|||
|
|
inst.message = JSON.stringify(def, jsonStringifyReplacer, 2);
|
|||
|
|
Object.defineProperty(inst, "toString", {
|
|||
|
|
value: () => inst.message,
|
|||
|
|
enumerable: false
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
var $ZodError = $constructor("$ZodError", initializer);
|
|||
|
|
var $ZodRealError = $constructor("$ZodError", initializer, { Parent: Error });
|
|||
|
|
function flattenError(error48, mapper = (issue2) => issue2.message) {
|
|||
|
|
const fieldErrors = {};
|
|||
|
|
const formErrors = [];
|
|||
|
|
for (const sub of error48.issues) {
|
|||
|
|
if (sub.path.length > 0) {
|
|||
|
|
fieldErrors[sub.path[0]] = fieldErrors[sub.path[0]] || [];
|
|||
|
|
fieldErrors[sub.path[0]].push(mapper(sub));
|
|||
|
|
} else {
|
|||
|
|
formErrors.push(mapper(sub));
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return { formErrors, fieldErrors };
|
|||
|
|
}
|
|||
|
|
function formatError(error48, mapper = (issue2) => issue2.message) {
|
|||
|
|
const fieldErrors = { _errors: [] };
|
|||
|
|
const processError = (error49) => {
|
|||
|
|
for (const issue2 of error49.issues) {
|
|||
|
|
if (issue2.code === "invalid_union" && issue2.errors.length) {
|
|||
|
|
issue2.errors.map((issues) => processError({ issues }));
|
|||
|
|
} else if (issue2.code === "invalid_key") {
|
|||
|
|
processError({ issues: issue2.issues });
|
|||
|
|
} else if (issue2.code === "invalid_element") {
|
|||
|
|
processError({ issues: issue2.issues });
|
|||
|
|
} else if (issue2.path.length === 0) {
|
|||
|
|
fieldErrors._errors.push(mapper(issue2));
|
|||
|
|
} else {
|
|||
|
|
let curr = fieldErrors;
|
|||
|
|
let i = 0;
|
|||
|
|
while (i < issue2.path.length) {
|
|||
|
|
const el = issue2.path[i];
|
|||
|
|
const terminal = i === issue2.path.length - 1;
|
|||
|
|
if (!terminal) {
|
|||
|
|
curr[el] = curr[el] || { _errors: [] };
|
|||
|
|
} else {
|
|||
|
|
curr[el] = curr[el] || { _errors: [] };
|
|||
|
|
curr[el]._errors.push(mapper(issue2));
|
|||
|
|
}
|
|||
|
|
curr = curr[el];
|
|||
|
|
i++;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
processError(error48);
|
|||
|
|
return fieldErrors;
|
|||
|
|
}
|
|||
|
|
function treeifyError(error48, mapper = (issue2) => issue2.message) {
|
|||
|
|
const result = { errors: [] };
|
|||
|
|
const processError = (error49, path = []) => {
|
|||
|
|
var _a2, _b;
|
|||
|
|
for (const issue2 of error49.issues) {
|
|||
|
|
if (issue2.code === "invalid_union" && issue2.errors.length) {
|
|||
|
|
issue2.errors.map((issues) => processError({ issues }, issue2.path));
|
|||
|
|
} else if (issue2.code === "invalid_key") {
|
|||
|
|
processError({ issues: issue2.issues }, issue2.path);
|
|||
|
|
} else if (issue2.code === "invalid_element") {
|
|||
|
|
processError({ issues: issue2.issues }, issue2.path);
|
|||
|
|
} else {
|
|||
|
|
const fullpath = [...path, ...issue2.path];
|
|||
|
|
if (fullpath.length === 0) {
|
|||
|
|
result.errors.push(mapper(issue2));
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
let curr = result;
|
|||
|
|
let i = 0;
|
|||
|
|
while (i < fullpath.length) {
|
|||
|
|
const el = fullpath[i];
|
|||
|
|
const terminal = i === fullpath.length - 1;
|
|||
|
|
if (typeof el === "string") {
|
|||
|
|
curr.properties ?? (curr.properties = {});
|
|||
|
|
(_a2 = curr.properties)[el] ?? (_a2[el] = { errors: [] });
|
|||
|
|
curr = curr.properties[el];
|
|||
|
|
} else {
|
|||
|
|
curr.items ?? (curr.items = []);
|
|||
|
|
(_b = curr.items)[el] ?? (_b[el] = { errors: [] });
|
|||
|
|
curr = curr.items[el];
|
|||
|
|
}
|
|||
|
|
if (terminal) {
|
|||
|
|
curr.errors.push(mapper(issue2));
|
|||
|
|
}
|
|||
|
|
i++;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
processError(error48);
|
|||
|
|
return result;
|
|||
|
|
}
|
|||
|
|
function toDotPath(_path) {
|
|||
|
|
const segs = [];
|
|||
|
|
const path = _path.map((seg) => typeof seg === "object" ? seg.key : seg);
|
|||
|
|
for (const seg of path) {
|
|||
|
|
if (typeof seg === "number")
|
|||
|
|
segs.push(`[${seg}]`);
|
|||
|
|
else if (typeof seg === "symbol")
|
|||
|
|
segs.push(`[${JSON.stringify(String(seg))}]`);
|
|||
|
|
else if (/[^\w$]/.test(seg))
|
|||
|
|
segs.push(`[${JSON.stringify(seg)}]`);
|
|||
|
|
else {
|
|||
|
|
if (segs.length)
|
|||
|
|
segs.push(".");
|
|||
|
|
segs.push(seg);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return segs.join("");
|
|||
|
|
}
|
|||
|
|
function prettifyError(error48) {
|
|||
|
|
const lines = [];
|
|||
|
|
const issues = [...error48.issues].sort((a, b) => (a.path ?? []).length - (b.path ?? []).length);
|
|||
|
|
for (const issue2 of issues) {
|
|||
|
|
lines.push(`✖ ${issue2.message}`);
|
|||
|
|
if (issue2.path?.length)
|
|||
|
|
lines.push(` → at ${toDotPath(issue2.path)}`);
|
|||
|
|
}
|
|||
|
|
return lines.join("\n");
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/parse.js
|
|||
|
|
var _parse = (_Err) => (schema, value, _ctx, _params) => {
|
|||
|
|
const ctx = _ctx ? Object.assign(_ctx, { async: false }) : { async: false };
|
|||
|
|
const result = schema._zod.run({ value, issues: [] }, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
throw new $ZodAsyncError();
|
|||
|
|
}
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
const e = new (_params?.Err ?? _Err)(result.issues.map((iss) => finalizeIssue(iss, ctx, config())));
|
|||
|
|
captureStackTrace(e, _params?.callee);
|
|||
|
|
throw e;
|
|||
|
|
}
|
|||
|
|
return result.value;
|
|||
|
|
};
|
|||
|
|
var parse = _parse($ZodRealError);
|
|||
|
|
var _parseAsync = (_Err) => async (schema, value, _ctx, params) => {
|
|||
|
|
const ctx = _ctx ? Object.assign(_ctx, { async: true }) : { async: true };
|
|||
|
|
let result = schema._zod.run({ value, issues: [] }, ctx);
|
|||
|
|
if (result instanceof Promise)
|
|||
|
|
result = await result;
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
const e = new (params?.Err ?? _Err)(result.issues.map((iss) => finalizeIssue(iss, ctx, config())));
|
|||
|
|
captureStackTrace(e, params?.callee);
|
|||
|
|
throw e;
|
|||
|
|
}
|
|||
|
|
return result.value;
|
|||
|
|
};
|
|||
|
|
var parseAsync = _parseAsync($ZodRealError);
|
|||
|
|
var _safeParse = (_Err) => (schema, value, _ctx) => {
|
|||
|
|
const ctx = _ctx ? { ..._ctx, async: false } : { async: false };
|
|||
|
|
const result = schema._zod.run({ value, issues: [] }, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
throw new $ZodAsyncError();
|
|||
|
|
}
|
|||
|
|
return result.issues.length ? {
|
|||
|
|
success: false,
|
|||
|
|
error: new (_Err ?? $ZodError)(result.issues.map((iss) => finalizeIssue(iss, ctx, config())))
|
|||
|
|
} : { success: true, data: result.value };
|
|||
|
|
};
|
|||
|
|
var safeParse = _safeParse($ZodRealError);
|
|||
|
|
var _safeParseAsync = (_Err) => async (schema, value, _ctx) => {
|
|||
|
|
const ctx = _ctx ? Object.assign(_ctx, { async: true }) : { async: true };
|
|||
|
|
let result = schema._zod.run({ value, issues: [] }, ctx);
|
|||
|
|
if (result instanceof Promise)
|
|||
|
|
result = await result;
|
|||
|
|
return result.issues.length ? {
|
|||
|
|
success: false,
|
|||
|
|
error: new _Err(result.issues.map((iss) => finalizeIssue(iss, ctx, config())))
|
|||
|
|
} : { success: true, data: result.value };
|
|||
|
|
};
|
|||
|
|
var safeParseAsync = _safeParseAsync($ZodRealError);
|
|||
|
|
var _encode = (_Err) => (schema, value, _ctx) => {
|
|||
|
|
const ctx = _ctx ? Object.assign(_ctx, { direction: "backward" }) : { direction: "backward" };
|
|||
|
|
return _parse(_Err)(schema, value, ctx);
|
|||
|
|
};
|
|||
|
|
var encode = _encode($ZodRealError);
|
|||
|
|
var _decode = (_Err) => (schema, value, _ctx) => {
|
|||
|
|
return _parse(_Err)(schema, value, _ctx);
|
|||
|
|
};
|
|||
|
|
var decode = _decode($ZodRealError);
|
|||
|
|
var _encodeAsync = (_Err) => async (schema, value, _ctx) => {
|
|||
|
|
const ctx = _ctx ? Object.assign(_ctx, { direction: "backward" }) : { direction: "backward" };
|
|||
|
|
return _parseAsync(_Err)(schema, value, ctx);
|
|||
|
|
};
|
|||
|
|
var encodeAsync = _encodeAsync($ZodRealError);
|
|||
|
|
var _decodeAsync = (_Err) => async (schema, value, _ctx) => {
|
|||
|
|
return _parseAsync(_Err)(schema, value, _ctx);
|
|||
|
|
};
|
|||
|
|
var decodeAsync = _decodeAsync($ZodRealError);
|
|||
|
|
var _safeEncode = (_Err) => (schema, value, _ctx) => {
|
|||
|
|
const ctx = _ctx ? Object.assign(_ctx, { direction: "backward" }) : { direction: "backward" };
|
|||
|
|
return _safeParse(_Err)(schema, value, ctx);
|
|||
|
|
};
|
|||
|
|
var safeEncode = _safeEncode($ZodRealError);
|
|||
|
|
var _safeDecode = (_Err) => (schema, value, _ctx) => {
|
|||
|
|
return _safeParse(_Err)(schema, value, _ctx);
|
|||
|
|
};
|
|||
|
|
var safeDecode = _safeDecode($ZodRealError);
|
|||
|
|
var _safeEncodeAsync = (_Err) => async (schema, value, _ctx) => {
|
|||
|
|
const ctx = _ctx ? Object.assign(_ctx, { direction: "backward" }) : { direction: "backward" };
|
|||
|
|
return _safeParseAsync(_Err)(schema, value, ctx);
|
|||
|
|
};
|
|||
|
|
var safeEncodeAsync = _safeEncodeAsync($ZodRealError);
|
|||
|
|
var _safeDecodeAsync = (_Err) => async (schema, value, _ctx) => {
|
|||
|
|
return _safeParseAsync(_Err)(schema, value, _ctx);
|
|||
|
|
};
|
|||
|
|
var safeDecodeAsync = _safeDecodeAsync($ZodRealError);
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/regexes.js
|
|||
|
|
var regexes_exports = {};
|
|||
|
|
__export(regexes_exports, {
|
|||
|
|
base64: () => base64,
|
|||
|
|
base64url: () => base64url,
|
|||
|
|
bigint: () => bigint,
|
|||
|
|
boolean: () => boolean,
|
|||
|
|
browserEmail: () => browserEmail,
|
|||
|
|
cidrv4: () => cidrv4,
|
|||
|
|
cidrv6: () => cidrv6,
|
|||
|
|
cuid: () => cuid,
|
|||
|
|
cuid2: () => cuid2,
|
|||
|
|
date: () => date,
|
|||
|
|
datetime: () => datetime,
|
|||
|
|
domain: () => domain,
|
|||
|
|
duration: () => duration,
|
|||
|
|
e164: () => e164,
|
|||
|
|
email: () => email,
|
|||
|
|
emoji: () => emoji,
|
|||
|
|
extendedDuration: () => extendedDuration,
|
|||
|
|
guid: () => guid,
|
|||
|
|
hex: () => hex,
|
|||
|
|
hostname: () => hostname,
|
|||
|
|
html5Email: () => html5Email,
|
|||
|
|
idnEmail: () => idnEmail,
|
|||
|
|
integer: () => integer,
|
|||
|
|
ipv4: () => ipv4,
|
|||
|
|
ipv6: () => ipv6,
|
|||
|
|
ksuid: () => ksuid,
|
|||
|
|
lowercase: () => lowercase,
|
|||
|
|
mac: () => mac,
|
|||
|
|
md5_base64: () => md5_base64,
|
|||
|
|
md5_base64url: () => md5_base64url,
|
|||
|
|
md5_hex: () => md5_hex,
|
|||
|
|
nanoid: () => nanoid,
|
|||
|
|
null: () => _null,
|
|||
|
|
number: () => number,
|
|||
|
|
rfc5322Email: () => rfc5322Email,
|
|||
|
|
sha1_base64: () => sha1_base64,
|
|||
|
|
sha1_base64url: () => sha1_base64url,
|
|||
|
|
sha1_hex: () => sha1_hex,
|
|||
|
|
sha256_base64: () => sha256_base64,
|
|||
|
|
sha256_base64url: () => sha256_base64url,
|
|||
|
|
sha256_hex: () => sha256_hex,
|
|||
|
|
sha384_base64: () => sha384_base64,
|
|||
|
|
sha384_base64url: () => sha384_base64url,
|
|||
|
|
sha384_hex: () => sha384_hex,
|
|||
|
|
sha512_base64: () => sha512_base64,
|
|||
|
|
sha512_base64url: () => sha512_base64url,
|
|||
|
|
sha512_hex: () => sha512_hex,
|
|||
|
|
string: () => string,
|
|||
|
|
time: () => time,
|
|||
|
|
ulid: () => ulid,
|
|||
|
|
undefined: () => _undefined,
|
|||
|
|
unicodeEmail: () => unicodeEmail,
|
|||
|
|
uppercase: () => uppercase,
|
|||
|
|
uuid: () => uuid,
|
|||
|
|
uuid4: () => uuid4,
|
|||
|
|
uuid6: () => uuid6,
|
|||
|
|
uuid7: () => uuid7,
|
|||
|
|
xid: () => xid
|
|||
|
|
});
|
|||
|
|
var cuid = /^[cC][^\s-]{8,}$/;
|
|||
|
|
var cuid2 = /^[0-9a-z]+$/;
|
|||
|
|
var ulid = /^[0-9A-HJKMNP-TV-Za-hjkmnp-tv-z]{26}$/;
|
|||
|
|
var xid = /^[0-9a-vA-V]{20}$/;
|
|||
|
|
var ksuid = /^[A-Za-z0-9]{27}$/;
|
|||
|
|
var nanoid = /^[a-zA-Z0-9_-]{21}$/;
|
|||
|
|
var duration = /^P(?:(\d+W)|(?!.*W)(?=\d|T\d)(\d+Y)?(\d+M)?(\d+D)?(T(?=\d)(\d+H)?(\d+M)?(\d+([.,]\d+)?S)?)?)$/;
|
|||
|
|
var extendedDuration = /^[-+]?P(?!$)(?:(?:[-+]?\d+Y)|(?:[-+]?\d+[.,]\d+Y$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:(?:[-+]?\d+W)|(?:[-+]?\d+[.,]\d+W$))?(?:(?:[-+]?\d+D)|(?:[-+]?\d+[.,]\d+D$))?(?:T(?=[\d+-])(?:(?:[-+]?\d+H)|(?:[-+]?\d+[.,]\d+H$))?(?:(?:[-+]?\d+M)|(?:[-+]?\d+[.,]\d+M$))?(?:[-+]?\d+(?:[.,]\d+)?S)?)??$/;
|
|||
|
|
var guid = /^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{4}-[0-9a-fA-F]{12})$/;
|
|||
|
|
var uuid = (version2) => {
|
|||
|
|
if (!version2)
|
|||
|
|
return /^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-[1-8][0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12}|00000000-0000-0000-0000-000000000000|ffffffff-ffff-ffff-ffff-ffffffffffff)$/;
|
|||
|
|
return new RegExp(`^([0-9a-fA-F]{8}-[0-9a-fA-F]{4}-${version2}[0-9a-fA-F]{3}-[89abAB][0-9a-fA-F]{3}-[0-9a-fA-F]{12})$`);
|
|||
|
|
};
|
|||
|
|
var uuid4 = uuid(4);
|
|||
|
|
var uuid6 = uuid(6);
|
|||
|
|
var uuid7 = uuid(7);
|
|||
|
|
var email = /^(?!\.)(?!.*\.\.)([A-Za-z0-9_'+\-\.]*)[A-Za-z0-9_+-]@([A-Za-z0-9][A-Za-z0-9\-]*\.)+[A-Za-z]{2,}$/;
|
|||
|
|
var html5Email = /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;
|
|||
|
|
var rfc5322Email = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
|
|||
|
|
var unicodeEmail = /^[^\s@"]{1,64}@[^\s@]{1,255}$/u;
|
|||
|
|
var idnEmail = unicodeEmail;
|
|||
|
|
var browserEmail = /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/;
|
|||
|
|
var _emoji = `^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$`;
|
|||
|
|
function emoji() {
|
|||
|
|
return new RegExp(_emoji, "u");
|
|||
|
|
}
|
|||
|
|
var ipv4 = /^(?:(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(?:25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])$/;
|
|||
|
|
var ipv6 = /^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:))$/;
|
|||
|
|
var mac = (delimiter) => {
|
|||
|
|
const escapedDelim = escapeRegex(delimiter ?? ":");
|
|||
|
|
return new RegExp(`^(?:[0-9A-F]{2}${escapedDelim}){5}[0-9A-F]{2}$|^(?:[0-9a-f]{2}${escapedDelim}){5}[0-9a-f]{2}$`);
|
|||
|
|
};
|
|||
|
|
var cidrv4 = /^((25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\.){3}(25[0-5]|2[0-4][0-9]|1[0-9][0-9]|[1-9][0-9]|[0-9])\/([0-9]|[1-2][0-9]|3[0-2])$/;
|
|||
|
|
var cidrv6 = /^(([0-9a-fA-F]{1,4}:){7}[0-9a-fA-F]{1,4}|::|([0-9a-fA-F]{1,4})?::([0-9a-fA-F]{1,4}:?){0,6})\/(12[0-8]|1[01][0-9]|[1-9]?[0-9])$/;
|
|||
|
|
var base64 = /^$|^(?:[0-9a-zA-Z+/]{4})*(?:(?:[0-9a-zA-Z+/]{2}==)|(?:[0-9a-zA-Z+/]{3}=))?$/;
|
|||
|
|
var base64url = /^[A-Za-z0-9_-]*$/;
|
|||
|
|
var hostname = /^(?=.{1,253}\.?$)[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[-0-9a-zA-Z]{0,61}[0-9a-zA-Z])?)*\.?$/;
|
|||
|
|
var domain = /^([a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,}$/;
|
|||
|
|
var e164 = /^\+[1-9]\d{6,14}$/;
|
|||
|
|
var dateSource = `(?:(?:\\d\\d[2468][048]|\\d\\d[13579][26]|\\d\\d0[48]|[02468][048]00|[13579][26]00)-02-29|\\d{4}-(?:(?:0[13578]|1[02])-(?:0[1-9]|[12]\\d|3[01])|(?:0[469]|11)-(?:0[1-9]|[12]\\d|30)|(?:02)-(?:0[1-9]|1\\d|2[0-8])))`;
|
|||
|
|
var date = new RegExp(`^${dateSource}$`);
|
|||
|
|
function timeSource(args) {
|
|||
|
|
const hhmm = `(?:[01]\\d|2[0-3]):[0-5]\\d`;
|
|||
|
|
const regex = typeof args.precision === "number" ? args.precision === -1 ? `${hhmm}` : args.precision === 0 ? `${hhmm}:[0-5]\\d` : `${hhmm}:[0-5]\\d\\.\\d{${args.precision}}` : `${hhmm}(?::[0-5]\\d(?:\\.\\d+)?)?`;
|
|||
|
|
return regex;
|
|||
|
|
}
|
|||
|
|
function time(args) {
|
|||
|
|
return new RegExp(`^${timeSource(args)}$`);
|
|||
|
|
}
|
|||
|
|
function datetime(args) {
|
|||
|
|
const time3 = timeSource({ precision: args.precision });
|
|||
|
|
const opts = ["Z"];
|
|||
|
|
if (args.local)
|
|||
|
|
opts.push("");
|
|||
|
|
if (args.offset)
|
|||
|
|
opts.push(`([+-](?:[01]\\d|2[0-3]):[0-5]\\d)`);
|
|||
|
|
const timeRegex = `${time3}(?:${opts.join("|")})`;
|
|||
|
|
return new RegExp(`^${dateSource}T(?:${timeRegex})$`);
|
|||
|
|
}
|
|||
|
|
var string = (params) => {
|
|||
|
|
const regex = params ? `[\\s\\S]{${params?.minimum ?? 0},${params?.maximum ?? ""}}` : `[\\s\\S]*`;
|
|||
|
|
return new RegExp(`^${regex}$`);
|
|||
|
|
};
|
|||
|
|
var bigint = /^-?\d+n?$/;
|
|||
|
|
var integer = /^-?\d+$/;
|
|||
|
|
var number = /^-?\d+(?:\.\d+)?$/;
|
|||
|
|
var boolean = /^(?:true|false)$/i;
|
|||
|
|
var _null = /^null$/i;
|
|||
|
|
var _undefined = /^undefined$/i;
|
|||
|
|
var lowercase = /^[^A-Z]*$/;
|
|||
|
|
var uppercase = /^[^a-z]*$/;
|
|||
|
|
var hex = /^[0-9a-fA-F]*$/;
|
|||
|
|
function fixedBase64(bodyLength, padding) {
|
|||
|
|
return new RegExp(`^[A-Za-z0-9+/]{${bodyLength}}${padding}$`);
|
|||
|
|
}
|
|||
|
|
function fixedBase64url(length) {
|
|||
|
|
return new RegExp(`^[A-Za-z0-9_-]{${length}}$`);
|
|||
|
|
}
|
|||
|
|
var md5_hex = /^[0-9a-fA-F]{32}$/;
|
|||
|
|
var md5_base64 = fixedBase64(22, "==");
|
|||
|
|
var md5_base64url = fixedBase64url(22);
|
|||
|
|
var sha1_hex = /^[0-9a-fA-F]{40}$/;
|
|||
|
|
var sha1_base64 = fixedBase64(27, "=");
|
|||
|
|
var sha1_base64url = fixedBase64url(27);
|
|||
|
|
var sha256_hex = /^[0-9a-fA-F]{64}$/;
|
|||
|
|
var sha256_base64 = fixedBase64(43, "=");
|
|||
|
|
var sha256_base64url = fixedBase64url(43);
|
|||
|
|
var sha384_hex = /^[0-9a-fA-F]{96}$/;
|
|||
|
|
var sha384_base64 = fixedBase64(64, "");
|
|||
|
|
var sha384_base64url = fixedBase64url(64);
|
|||
|
|
var sha512_hex = /^[0-9a-fA-F]{128}$/;
|
|||
|
|
var sha512_base64 = fixedBase64(86, "==");
|
|||
|
|
var sha512_base64url = fixedBase64url(86);
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/checks.js
|
|||
|
|
var $ZodCheck = $constructor("$ZodCheck", (inst, def) => {
|
|||
|
|
var _a2;
|
|||
|
|
inst._zod ?? (inst._zod = {});
|
|||
|
|
inst._zod.def = def;
|
|||
|
|
(_a2 = inst._zod).onattach ?? (_a2.onattach = []);
|
|||
|
|
});
|
|||
|
|
var numericOriginMap = {
|
|||
|
|
number: "number",
|
|||
|
|
bigint: "bigint",
|
|||
|
|
object: "date"
|
|||
|
|
};
|
|||
|
|
var $ZodCheckLessThan = $constructor("$ZodCheckLessThan", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
const origin = numericOriginMap[typeof def.value];
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
const curr = (def.inclusive ? bag.maximum : bag.exclusiveMaximum) ?? Number.POSITIVE_INFINITY;
|
|||
|
|
if (def.value < curr) {
|
|||
|
|
if (def.inclusive)
|
|||
|
|
bag.maximum = def.value;
|
|||
|
|
else
|
|||
|
|
bag.exclusiveMaximum = def.value;
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (def.inclusive ? payload.value <= def.value : payload.value < def.value) {
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin,
|
|||
|
|
code: "too_big",
|
|||
|
|
maximum: typeof def.value === "object" ? def.value.getTime() : def.value,
|
|||
|
|
input: payload.value,
|
|||
|
|
inclusive: def.inclusive,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckGreaterThan = $constructor("$ZodCheckGreaterThan", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
const origin = numericOriginMap[typeof def.value];
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
const curr = (def.inclusive ? bag.minimum : bag.exclusiveMinimum) ?? Number.NEGATIVE_INFINITY;
|
|||
|
|
if (def.value > curr) {
|
|||
|
|
if (def.inclusive)
|
|||
|
|
bag.minimum = def.value;
|
|||
|
|
else
|
|||
|
|
bag.exclusiveMinimum = def.value;
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (def.inclusive ? payload.value >= def.value : payload.value > def.value) {
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin,
|
|||
|
|
code: "too_small",
|
|||
|
|
minimum: typeof def.value === "object" ? def.value.getTime() : def.value,
|
|||
|
|
input: payload.value,
|
|||
|
|
inclusive: def.inclusive,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckMultipleOf = $constructor("$ZodCheckMultipleOf", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
var _a2;
|
|||
|
|
(_a2 = inst2._zod.bag).multipleOf ?? (_a2.multipleOf = def.value);
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (typeof payload.value !== typeof def.value)
|
|||
|
|
throw new Error("Cannot mix number and bigint in multiple_of check.");
|
|||
|
|
const isMultiple = typeof payload.value === "bigint" ? payload.value % def.value === BigInt(0) : floatSafeRemainder(payload.value, def.value) === 0;
|
|||
|
|
if (isMultiple)
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: typeof payload.value,
|
|||
|
|
code: "not_multiple_of",
|
|||
|
|
divisor: def.value,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckNumberFormat = $constructor("$ZodCheckNumberFormat", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
def.format = def.format || "float64";
|
|||
|
|
const isInt = def.format?.includes("int");
|
|||
|
|
const origin = isInt ? "int" : "number";
|
|||
|
|
const [minimum, maximum] = NUMBER_FORMAT_RANGES[def.format];
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
bag.format = def.format;
|
|||
|
|
bag.minimum = minimum;
|
|||
|
|
bag.maximum = maximum;
|
|||
|
|
if (isInt)
|
|||
|
|
bag.pattern = integer;
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (isInt) {
|
|||
|
|
if (!Number.isInteger(input)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: origin,
|
|||
|
|
format: def.format,
|
|||
|
|
code: "invalid_type",
|
|||
|
|
continue: false,
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
if (!Number.isSafeInteger(input)) {
|
|||
|
|
if (input > 0) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
input,
|
|||
|
|
code: "too_big",
|
|||
|
|
maximum: Number.MAX_SAFE_INTEGER,
|
|||
|
|
note: "Integers must be within the safe integer range.",
|
|||
|
|
inst,
|
|||
|
|
origin,
|
|||
|
|
inclusive: true,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
} else {
|
|||
|
|
payload.issues.push({
|
|||
|
|
input,
|
|||
|
|
code: "too_small",
|
|||
|
|
minimum: Number.MIN_SAFE_INTEGER,
|
|||
|
|
note: "Integers must be within the safe integer range.",
|
|||
|
|
inst,
|
|||
|
|
origin,
|
|||
|
|
inclusive: true,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (input < minimum) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: "number",
|
|||
|
|
input,
|
|||
|
|
code: "too_small",
|
|||
|
|
minimum,
|
|||
|
|
inclusive: true,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
if (input > maximum) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: "number",
|
|||
|
|
input,
|
|||
|
|
code: "too_big",
|
|||
|
|
maximum,
|
|||
|
|
inclusive: true,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckBigIntFormat = $constructor("$ZodCheckBigIntFormat", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
const [minimum, maximum] = BIGINT_FORMAT_RANGES[def.format];
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
bag.format = def.format;
|
|||
|
|
bag.minimum = minimum;
|
|||
|
|
bag.maximum = maximum;
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (input < minimum) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: "bigint",
|
|||
|
|
input,
|
|||
|
|
code: "too_small",
|
|||
|
|
minimum,
|
|||
|
|
inclusive: true,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
if (input > maximum) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: "bigint",
|
|||
|
|
input,
|
|||
|
|
code: "too_big",
|
|||
|
|
maximum,
|
|||
|
|
inclusive: true,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckMaxSize = $constructor("$ZodCheckMaxSize", (inst, def) => {
|
|||
|
|
var _a2;
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
(_a2 = inst._zod.def).when ?? (_a2.when = (payload) => {
|
|||
|
|
const val = payload.value;
|
|||
|
|
return !nullish(val) && val.size !== void 0;
|
|||
|
|
});
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const curr = inst2._zod.bag.maximum ?? Number.POSITIVE_INFINITY;
|
|||
|
|
if (def.maximum < curr)
|
|||
|
|
inst2._zod.bag.maximum = def.maximum;
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
const size = input.size;
|
|||
|
|
if (size <= def.maximum)
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: getSizableOrigin(input),
|
|||
|
|
code: "too_big",
|
|||
|
|
maximum: def.maximum,
|
|||
|
|
inclusive: true,
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckMinSize = $constructor("$ZodCheckMinSize", (inst, def) => {
|
|||
|
|
var _a2;
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
(_a2 = inst._zod.def).when ?? (_a2.when = (payload) => {
|
|||
|
|
const val = payload.value;
|
|||
|
|
return !nullish(val) && val.size !== void 0;
|
|||
|
|
});
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const curr = inst2._zod.bag.minimum ?? Number.NEGATIVE_INFINITY;
|
|||
|
|
if (def.minimum > curr)
|
|||
|
|
inst2._zod.bag.minimum = def.minimum;
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
const size = input.size;
|
|||
|
|
if (size >= def.minimum)
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: getSizableOrigin(input),
|
|||
|
|
code: "too_small",
|
|||
|
|
minimum: def.minimum,
|
|||
|
|
inclusive: true,
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckSizeEquals = $constructor("$ZodCheckSizeEquals", (inst, def) => {
|
|||
|
|
var _a2;
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
(_a2 = inst._zod.def).when ?? (_a2.when = (payload) => {
|
|||
|
|
const val = payload.value;
|
|||
|
|
return !nullish(val) && val.size !== void 0;
|
|||
|
|
});
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
bag.minimum = def.size;
|
|||
|
|
bag.maximum = def.size;
|
|||
|
|
bag.size = def.size;
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
const size = input.size;
|
|||
|
|
if (size === def.size)
|
|||
|
|
return;
|
|||
|
|
const tooBig = size > def.size;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: getSizableOrigin(input),
|
|||
|
|
...tooBig ? { code: "too_big", maximum: def.size } : { code: "too_small", minimum: def.size },
|
|||
|
|
inclusive: true,
|
|||
|
|
exact: true,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckMaxLength = $constructor("$ZodCheckMaxLength", (inst, def) => {
|
|||
|
|
var _a2;
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
(_a2 = inst._zod.def).when ?? (_a2.when = (payload) => {
|
|||
|
|
const val = payload.value;
|
|||
|
|
return !nullish(val) && val.length !== void 0;
|
|||
|
|
});
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const curr = inst2._zod.bag.maximum ?? Number.POSITIVE_INFINITY;
|
|||
|
|
if (def.maximum < curr)
|
|||
|
|
inst2._zod.bag.maximum = def.maximum;
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
const length = input.length;
|
|||
|
|
if (length <= def.maximum)
|
|||
|
|
return;
|
|||
|
|
const origin = getLengthableOrigin(input);
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin,
|
|||
|
|
code: "too_big",
|
|||
|
|
maximum: def.maximum,
|
|||
|
|
inclusive: true,
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckMinLength = $constructor("$ZodCheckMinLength", (inst, def) => {
|
|||
|
|
var _a2;
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
(_a2 = inst._zod.def).when ?? (_a2.when = (payload) => {
|
|||
|
|
const val = payload.value;
|
|||
|
|
return !nullish(val) && val.length !== void 0;
|
|||
|
|
});
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const curr = inst2._zod.bag.minimum ?? Number.NEGATIVE_INFINITY;
|
|||
|
|
if (def.minimum > curr)
|
|||
|
|
inst2._zod.bag.minimum = def.minimum;
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
const length = input.length;
|
|||
|
|
if (length >= def.minimum)
|
|||
|
|
return;
|
|||
|
|
const origin = getLengthableOrigin(input);
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin,
|
|||
|
|
code: "too_small",
|
|||
|
|
minimum: def.minimum,
|
|||
|
|
inclusive: true,
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckLengthEquals = $constructor("$ZodCheckLengthEquals", (inst, def) => {
|
|||
|
|
var _a2;
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
(_a2 = inst._zod.def).when ?? (_a2.when = (payload) => {
|
|||
|
|
const val = payload.value;
|
|||
|
|
return !nullish(val) && val.length !== void 0;
|
|||
|
|
});
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
bag.minimum = def.length;
|
|||
|
|
bag.maximum = def.length;
|
|||
|
|
bag.length = def.length;
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
const length = input.length;
|
|||
|
|
if (length === def.length)
|
|||
|
|
return;
|
|||
|
|
const origin = getLengthableOrigin(input);
|
|||
|
|
const tooBig = length > def.length;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin,
|
|||
|
|
...tooBig ? { code: "too_big", maximum: def.length } : { code: "too_small", minimum: def.length },
|
|||
|
|
inclusive: true,
|
|||
|
|
exact: true,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckStringFormat = $constructor("$ZodCheckStringFormat", (inst, def) => {
|
|||
|
|
var _a2, _b;
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
bag.format = def.format;
|
|||
|
|
if (def.pattern) {
|
|||
|
|
bag.patterns ?? (bag.patterns = /* @__PURE__ */ new Set());
|
|||
|
|
bag.patterns.add(def.pattern);
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
if (def.pattern)
|
|||
|
|
(_a2 = inst._zod).check ?? (_a2.check = (payload) => {
|
|||
|
|
def.pattern.lastIndex = 0;
|
|||
|
|
if (def.pattern.test(payload.value))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: "string",
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: def.format,
|
|||
|
|
input: payload.value,
|
|||
|
|
...def.pattern ? { pattern: def.pattern.toString() } : {},
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
});
|
|||
|
|
else
|
|||
|
|
(_b = inst._zod).check ?? (_b.check = () => {
|
|||
|
|
});
|
|||
|
|
});
|
|||
|
|
var $ZodCheckRegex = $constructor("$ZodCheckRegex", (inst, def) => {
|
|||
|
|
$ZodCheckStringFormat.init(inst, def);
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
def.pattern.lastIndex = 0;
|
|||
|
|
if (def.pattern.test(payload.value))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: "string",
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "regex",
|
|||
|
|
input: payload.value,
|
|||
|
|
pattern: def.pattern.toString(),
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckLowerCase = $constructor("$ZodCheckLowerCase", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = lowercase);
|
|||
|
|
$ZodCheckStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodCheckUpperCase = $constructor("$ZodCheckUpperCase", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = uppercase);
|
|||
|
|
$ZodCheckStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodCheckIncludes = $constructor("$ZodCheckIncludes", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
const escapedRegex = escapeRegex(def.includes);
|
|||
|
|
const pattern = new RegExp(typeof def.position === "number" ? `^.{${def.position}}${escapedRegex}` : escapedRegex);
|
|||
|
|
def.pattern = pattern;
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
bag.patterns ?? (bag.patterns = /* @__PURE__ */ new Set());
|
|||
|
|
bag.patterns.add(pattern);
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (payload.value.includes(def.includes, def.position))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: "string",
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "includes",
|
|||
|
|
includes: def.includes,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckStartsWith = $constructor("$ZodCheckStartsWith", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
const pattern = new RegExp(`^${escapeRegex(def.prefix)}.*`);
|
|||
|
|
def.pattern ?? (def.pattern = pattern);
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
bag.patterns ?? (bag.patterns = /* @__PURE__ */ new Set());
|
|||
|
|
bag.patterns.add(pattern);
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (payload.value.startsWith(def.prefix))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: "string",
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "starts_with",
|
|||
|
|
prefix: def.prefix,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckEndsWith = $constructor("$ZodCheckEndsWith", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
const pattern = new RegExp(`.*${escapeRegex(def.suffix)}$`);
|
|||
|
|
def.pattern ?? (def.pattern = pattern);
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
const bag = inst2._zod.bag;
|
|||
|
|
bag.patterns ?? (bag.patterns = /* @__PURE__ */ new Set());
|
|||
|
|
bag.patterns.add(pattern);
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (payload.value.endsWith(def.suffix))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
origin: "string",
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "ends_with",
|
|||
|
|
suffix: def.suffix,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleCheckPropertyResult(result, payload, property) {
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
payload.issues.push(...prefixIssues(property, result.issues));
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
var $ZodCheckProperty = $constructor("$ZodCheckProperty", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const result = def.schema._zod.run({
|
|||
|
|
value: payload.value[def.property],
|
|||
|
|
issues: []
|
|||
|
|
}, {});
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
return result.then((result2) => handleCheckPropertyResult(result2, payload, def.property));
|
|||
|
|
}
|
|||
|
|
handleCheckPropertyResult(result, payload, def.property);
|
|||
|
|
return;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckMimeType = $constructor("$ZodCheckMimeType", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
const mimeSet = new Set(def.mime);
|
|||
|
|
inst._zod.onattach.push((inst2) => {
|
|||
|
|
inst2._zod.bag.mime = def.mime;
|
|||
|
|
});
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (mimeSet.has(payload.value.type))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_value",
|
|||
|
|
values: def.mime,
|
|||
|
|
input: payload.value.type,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCheckOverwrite = $constructor("$ZodCheckOverwrite", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
payload.value = def.tx(payload.value);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/doc.js
|
|||
|
|
var Doc = class {
|
|||
|
|
constructor(args = []) {
|
|||
|
|
this.content = [];
|
|||
|
|
this.indent = 0;
|
|||
|
|
if (this)
|
|||
|
|
this.args = args;
|
|||
|
|
}
|
|||
|
|
indented(fn) {
|
|||
|
|
this.indent += 1;
|
|||
|
|
fn(this);
|
|||
|
|
this.indent -= 1;
|
|||
|
|
}
|
|||
|
|
write(arg) {
|
|||
|
|
if (typeof arg === "function") {
|
|||
|
|
arg(this, { execution: "sync" });
|
|||
|
|
arg(this, { execution: "async" });
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
const content = arg;
|
|||
|
|
const lines = content.split("\n").filter((x) => x);
|
|||
|
|
const minIndent = Math.min(...lines.map((x) => x.length - x.trimStart().length));
|
|||
|
|
const dedented = lines.map((x) => x.slice(minIndent)).map((x) => " ".repeat(this.indent * 2) + x);
|
|||
|
|
for (const line of dedented) {
|
|||
|
|
this.content.push(line);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
compile() {
|
|||
|
|
const F = Function;
|
|||
|
|
const args = this?.args;
|
|||
|
|
const content = this?.content ?? [``];
|
|||
|
|
const lines = [...content.map((x) => ` ${x}`)];
|
|||
|
|
return new F(...args, lines.join("\n"));
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/versions.js
|
|||
|
|
var version = {
|
|||
|
|
major: 4,
|
|||
|
|
minor: 3,
|
|||
|
|
patch: 6
|
|||
|
|
};
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/schemas.js
|
|||
|
|
var $ZodType = $constructor("$ZodType", (inst, def) => {
|
|||
|
|
var _a2;
|
|||
|
|
inst ?? (inst = {});
|
|||
|
|
inst._zod.def = def;
|
|||
|
|
inst._zod.bag = inst._zod.bag || {};
|
|||
|
|
inst._zod.version = version;
|
|||
|
|
const checks = [...inst._zod.def.checks ?? []];
|
|||
|
|
if (inst._zod.traits.has("$ZodCheck")) {
|
|||
|
|
checks.unshift(inst);
|
|||
|
|
}
|
|||
|
|
for (const ch of checks) {
|
|||
|
|
for (const fn of ch._zod.onattach) {
|
|||
|
|
fn(inst);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (checks.length === 0) {
|
|||
|
|
(_a2 = inst._zod).deferred ?? (_a2.deferred = []);
|
|||
|
|
inst._zod.deferred?.push(() => {
|
|||
|
|
inst._zod.run = inst._zod.parse;
|
|||
|
|
});
|
|||
|
|
} else {
|
|||
|
|
const runChecks = (payload, checks2, ctx) => {
|
|||
|
|
let isAborted = aborted(payload);
|
|||
|
|
let asyncResult;
|
|||
|
|
for (const ch of checks2) {
|
|||
|
|
if (ch._zod.def.when) {
|
|||
|
|
const shouldRun = ch._zod.def.when(payload);
|
|||
|
|
if (!shouldRun)
|
|||
|
|
continue;
|
|||
|
|
} else if (isAborted) {
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
const currLen = payload.issues.length;
|
|||
|
|
const _ = ch._zod.check(payload);
|
|||
|
|
if (_ instanceof Promise && ctx?.async === false) {
|
|||
|
|
throw new $ZodAsyncError();
|
|||
|
|
}
|
|||
|
|
if (asyncResult || _ instanceof Promise) {
|
|||
|
|
asyncResult = (asyncResult ?? Promise.resolve()).then(async () => {
|
|||
|
|
await _;
|
|||
|
|
const nextLen = payload.issues.length;
|
|||
|
|
if (nextLen === currLen)
|
|||
|
|
return;
|
|||
|
|
if (!isAborted)
|
|||
|
|
isAborted = aborted(payload, currLen);
|
|||
|
|
});
|
|||
|
|
} else {
|
|||
|
|
const nextLen = payload.issues.length;
|
|||
|
|
if (nextLen === currLen)
|
|||
|
|
continue;
|
|||
|
|
if (!isAborted)
|
|||
|
|
isAborted = aborted(payload, currLen);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (asyncResult) {
|
|||
|
|
return asyncResult.then(() => {
|
|||
|
|
return payload;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
const handleCanaryResult = (canary, payload, ctx) => {
|
|||
|
|
if (aborted(canary)) {
|
|||
|
|
canary.aborted = true;
|
|||
|
|
return canary;
|
|||
|
|
}
|
|||
|
|
const checkResult = runChecks(payload, checks, ctx);
|
|||
|
|
if (checkResult instanceof Promise) {
|
|||
|
|
if (ctx.async === false)
|
|||
|
|
throw new $ZodAsyncError();
|
|||
|
|
return checkResult.then((checkResult2) => inst._zod.parse(checkResult2, ctx));
|
|||
|
|
}
|
|||
|
|
return inst._zod.parse(checkResult, ctx);
|
|||
|
|
};
|
|||
|
|
inst._zod.run = (payload, ctx) => {
|
|||
|
|
if (ctx.skipChecks) {
|
|||
|
|
return inst._zod.parse(payload, ctx);
|
|||
|
|
}
|
|||
|
|
if (ctx.direction === "backward") {
|
|||
|
|
const canary = inst._zod.parse({ value: payload.value, issues: [] }, { ...ctx, skipChecks: true });
|
|||
|
|
if (canary instanceof Promise) {
|
|||
|
|
return canary.then((canary2) => {
|
|||
|
|
return handleCanaryResult(canary2, payload, ctx);
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
return handleCanaryResult(canary, payload, ctx);
|
|||
|
|
}
|
|||
|
|
const result = inst._zod.parse(payload, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
if (ctx.async === false)
|
|||
|
|
throw new $ZodAsyncError();
|
|||
|
|
return result.then((result2) => runChecks(result2, checks, ctx));
|
|||
|
|
}
|
|||
|
|
return runChecks(result, checks, ctx);
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
defineLazy(inst, "~standard", () => ({
|
|||
|
|
validate: (value) => {
|
|||
|
|
try {
|
|||
|
|
const r = safeParse(inst, value);
|
|||
|
|
return r.success ? { value: r.data } : { issues: r.error?.issues };
|
|||
|
|
} catch (_) {
|
|||
|
|
return safeParseAsync(inst, value).then((r) => r.success ? { value: r.data } : { issues: r.error?.issues });
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
vendor: "zod",
|
|||
|
|
version: 1
|
|||
|
|
}));
|
|||
|
|
});
|
|||
|
|
var $ZodString = $constructor("$ZodString", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.pattern = [...inst?._zod.bag?.patterns ?? []].pop() ?? string(inst._zod.bag);
|
|||
|
|
inst._zod.parse = (payload, _) => {
|
|||
|
|
if (def.coerce)
|
|||
|
|
try {
|
|||
|
|
payload.value = String(payload.value);
|
|||
|
|
} catch (_2) {
|
|||
|
|
}
|
|||
|
|
if (typeof payload.value === "string")
|
|||
|
|
return payload;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "string",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodStringFormat = $constructor("$ZodStringFormat", (inst, def) => {
|
|||
|
|
$ZodCheckStringFormat.init(inst, def);
|
|||
|
|
$ZodString.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodGUID = $constructor("$ZodGUID", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = guid);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodUUID = $constructor("$ZodUUID", (inst, def) => {
|
|||
|
|
if (def.version) {
|
|||
|
|
const versionMap = {
|
|||
|
|
v1: 1,
|
|||
|
|
v2: 2,
|
|||
|
|
v3: 3,
|
|||
|
|
v4: 4,
|
|||
|
|
v5: 5,
|
|||
|
|
v6: 6,
|
|||
|
|
v7: 7,
|
|||
|
|
v8: 8
|
|||
|
|
};
|
|||
|
|
const v = versionMap[def.version];
|
|||
|
|
if (v === void 0)
|
|||
|
|
throw new Error(`Invalid UUID version: "${def.version}"`);
|
|||
|
|
def.pattern ?? (def.pattern = uuid(v));
|
|||
|
|
} else
|
|||
|
|
def.pattern ?? (def.pattern = uuid());
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodEmail = $constructor("$ZodEmail", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = email);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodURL = $constructor("$ZodURL", (inst, def) => {
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
try {
|
|||
|
|
const trimmed = payload.value.trim();
|
|||
|
|
const url2 = new URL(trimmed);
|
|||
|
|
if (def.hostname) {
|
|||
|
|
def.hostname.lastIndex = 0;
|
|||
|
|
if (!def.hostname.test(url2.hostname)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "url",
|
|||
|
|
note: "Invalid hostname",
|
|||
|
|
pattern: def.hostname.source,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (def.protocol) {
|
|||
|
|
def.protocol.lastIndex = 0;
|
|||
|
|
if (!def.protocol.test(url2.protocol.endsWith(":") ? url2.protocol.slice(0, -1) : url2.protocol)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "url",
|
|||
|
|
note: "Invalid protocol",
|
|||
|
|
pattern: def.protocol.source,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (def.normalize) {
|
|||
|
|
payload.value = url2.href;
|
|||
|
|
} else {
|
|||
|
|
payload.value = trimmed;
|
|||
|
|
}
|
|||
|
|
return;
|
|||
|
|
} catch (_) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "url",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodEmoji = $constructor("$ZodEmoji", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = emoji());
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodNanoID = $constructor("$ZodNanoID", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = nanoid);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodCUID = $constructor("$ZodCUID", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = cuid);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodCUID2 = $constructor("$ZodCUID2", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = cuid2);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodULID = $constructor("$ZodULID", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = ulid);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodXID = $constructor("$ZodXID", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = xid);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodKSUID = $constructor("$ZodKSUID", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = ksuid);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodISODateTime = $constructor("$ZodISODateTime", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = datetime(def));
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodISODate = $constructor("$ZodISODate", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = date);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodISOTime = $constructor("$ZodISOTime", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = time(def));
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodISODuration = $constructor("$ZodISODuration", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = duration);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodIPv4 = $constructor("$ZodIPv4", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = ipv4);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
inst._zod.bag.format = `ipv4`;
|
|||
|
|
});
|
|||
|
|
var $ZodIPv6 = $constructor("$ZodIPv6", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = ipv6);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
inst._zod.bag.format = `ipv6`;
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
try {
|
|||
|
|
new URL(`http://[${payload.value}]`);
|
|||
|
|
} catch {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "ipv6",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodMAC = $constructor("$ZodMAC", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = mac(def.delimiter));
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
inst._zod.bag.format = `mac`;
|
|||
|
|
});
|
|||
|
|
var $ZodCIDRv4 = $constructor("$ZodCIDRv4", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = cidrv4);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodCIDRv6 = $constructor("$ZodCIDRv6", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = cidrv6);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const parts = payload.value.split("/");
|
|||
|
|
try {
|
|||
|
|
if (parts.length !== 2)
|
|||
|
|
throw new Error();
|
|||
|
|
const [address, prefix] = parts;
|
|||
|
|
if (!prefix)
|
|||
|
|
throw new Error();
|
|||
|
|
const prefixNum = Number(prefix);
|
|||
|
|
if (`${prefixNum}` !== prefix)
|
|||
|
|
throw new Error();
|
|||
|
|
if (prefixNum < 0 || prefixNum > 128)
|
|||
|
|
throw new Error();
|
|||
|
|
new URL(`http://[${address}]`);
|
|||
|
|
} catch {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "cidrv6",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function isValidBase64(data) {
|
|||
|
|
if (data === "")
|
|||
|
|
return true;
|
|||
|
|
if (data.length % 4 !== 0)
|
|||
|
|
return false;
|
|||
|
|
try {
|
|||
|
|
atob(data);
|
|||
|
|
return true;
|
|||
|
|
} catch {
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
var $ZodBase64 = $constructor("$ZodBase64", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = base64);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
inst._zod.bag.contentEncoding = "base64";
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (isValidBase64(payload.value))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "base64",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function isValidBase64URL(data) {
|
|||
|
|
if (!base64url.test(data))
|
|||
|
|
return false;
|
|||
|
|
const base643 = data.replace(/[-_]/g, (c) => c === "-" ? "+" : "/");
|
|||
|
|
const padded = base643.padEnd(Math.ceil(base643.length / 4) * 4, "=");
|
|||
|
|
return isValidBase64(padded);
|
|||
|
|
}
|
|||
|
|
var $ZodBase64URL = $constructor("$ZodBase64URL", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = base64url);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
inst._zod.bag.contentEncoding = "base64url";
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (isValidBase64URL(payload.value))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "base64url",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodE164 = $constructor("$ZodE164", (inst, def) => {
|
|||
|
|
def.pattern ?? (def.pattern = e164);
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function isValidJWT(token, algorithm = null) {
|
|||
|
|
try {
|
|||
|
|
const tokensParts = token.split(".");
|
|||
|
|
if (tokensParts.length !== 3)
|
|||
|
|
return false;
|
|||
|
|
const [header] = tokensParts;
|
|||
|
|
if (!header)
|
|||
|
|
return false;
|
|||
|
|
const parsedHeader = JSON.parse(atob(header));
|
|||
|
|
if ("typ" in parsedHeader && parsedHeader?.typ !== "JWT")
|
|||
|
|
return false;
|
|||
|
|
if (!parsedHeader.alg)
|
|||
|
|
return false;
|
|||
|
|
if (algorithm && (!("alg" in parsedHeader) || parsedHeader.alg !== algorithm))
|
|||
|
|
return false;
|
|||
|
|
return true;
|
|||
|
|
} catch {
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
var $ZodJWT = $constructor("$ZodJWT", (inst, def) => {
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (isValidJWT(payload.value, def.alg))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: "jwt",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCustomStringFormat = $constructor("$ZodCustomStringFormat", (inst, def) => {
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (def.fn(payload.value))
|
|||
|
|
return;
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: def.format,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
continue: !def.abort
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodNumber = $constructor("$ZodNumber", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.pattern = inst._zod.bag.pattern ?? number;
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
if (def.coerce)
|
|||
|
|
try {
|
|||
|
|
payload.value = Number(payload.value);
|
|||
|
|
} catch (_) {
|
|||
|
|
}
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (typeof input === "number" && !Number.isNaN(input) && Number.isFinite(input)) {
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
const received = typeof input === "number" ? Number.isNaN(input) ? "NaN" : !Number.isFinite(input) ? "Infinity" : void 0 : void 0;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "number",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
...received ? { received } : {}
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodNumberFormat = $constructor("$ZodNumberFormat", (inst, def) => {
|
|||
|
|
$ZodCheckNumberFormat.init(inst, def);
|
|||
|
|
$ZodNumber.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodBoolean = $constructor("$ZodBoolean", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.pattern = boolean;
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
if (def.coerce)
|
|||
|
|
try {
|
|||
|
|
payload.value = Boolean(payload.value);
|
|||
|
|
} catch (_) {
|
|||
|
|
}
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (typeof input === "boolean")
|
|||
|
|
return payload;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "boolean",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodBigInt = $constructor("$ZodBigInt", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.pattern = bigint;
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
if (def.coerce)
|
|||
|
|
try {
|
|||
|
|
payload.value = BigInt(payload.value);
|
|||
|
|
} catch (_) {
|
|||
|
|
}
|
|||
|
|
if (typeof payload.value === "bigint")
|
|||
|
|
return payload;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "bigint",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodBigIntFormat = $constructor("$ZodBigIntFormat", (inst, def) => {
|
|||
|
|
$ZodCheckBigIntFormat.init(inst, def);
|
|||
|
|
$ZodBigInt.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var $ZodSymbol = $constructor("$ZodSymbol", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (typeof input === "symbol")
|
|||
|
|
return payload;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "symbol",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodUndefined = $constructor("$ZodUndefined", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.pattern = _undefined;
|
|||
|
|
inst._zod.values = /* @__PURE__ */ new Set([void 0]);
|
|||
|
|
inst._zod.optin = "optional";
|
|||
|
|
inst._zod.optout = "optional";
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (typeof input === "undefined")
|
|||
|
|
return payload;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "undefined",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodNull = $constructor("$ZodNull", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.pattern = _null;
|
|||
|
|
inst._zod.values = /* @__PURE__ */ new Set([null]);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (input === null)
|
|||
|
|
return payload;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "null",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodAny = $constructor("$ZodAny", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload) => payload;
|
|||
|
|
});
|
|||
|
|
var $ZodUnknown = $constructor("$ZodUnknown", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload) => payload;
|
|||
|
|
});
|
|||
|
|
var $ZodNever = $constructor("$ZodNever", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "never",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodVoid = $constructor("$ZodVoid", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (typeof input === "undefined")
|
|||
|
|
return payload;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "void",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodDate = $constructor("$ZodDate", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
if (def.coerce) {
|
|||
|
|
try {
|
|||
|
|
payload.value = new Date(payload.value);
|
|||
|
|
} catch (_err) {
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const input = payload.value;
|
|||
|
|
const isDate = input instanceof Date;
|
|||
|
|
const isValidDate = isDate && !Number.isNaN(input.getTime());
|
|||
|
|
if (isValidDate)
|
|||
|
|
return payload;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "date",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
...isDate ? { received: "Invalid Date" } : {},
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleArrayResult(result, final, index) {
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
final.issues.push(...prefixIssues(index, result.issues));
|
|||
|
|
}
|
|||
|
|
final.value[index] = result.value;
|
|||
|
|
}
|
|||
|
|
var $ZodArray = $constructor("$ZodArray", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (!Array.isArray(input)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "array",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
payload.value = Array(input.length);
|
|||
|
|
const proms = [];
|
|||
|
|
for (let i = 0; i < input.length; i++) {
|
|||
|
|
const item = input[i];
|
|||
|
|
const result = def.element._zod.run({
|
|||
|
|
value: item,
|
|||
|
|
issues: []
|
|||
|
|
}, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
proms.push(result.then((result2) => handleArrayResult(result2, payload, i)));
|
|||
|
|
} else {
|
|||
|
|
handleArrayResult(result, payload, i);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (proms.length) {
|
|||
|
|
return Promise.all(proms).then(() => payload);
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handlePropertyResult(result, final, key, input, isOptionalOut) {
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
if (isOptionalOut && !(key in input)) {
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
final.issues.push(...prefixIssues(key, result.issues));
|
|||
|
|
}
|
|||
|
|
if (result.value === void 0) {
|
|||
|
|
if (key in input) {
|
|||
|
|
final.value[key] = void 0;
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
final.value[key] = result.value;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
function normalizeDef(def) {
|
|||
|
|
const keys = Object.keys(def.shape);
|
|||
|
|
for (const k of keys) {
|
|||
|
|
if (!def.shape?.[k]?._zod?.traits?.has("$ZodType")) {
|
|||
|
|
throw new Error(`Invalid element at key "${k}": expected a Zod schema`);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const okeys = optionalKeys(def.shape);
|
|||
|
|
return {
|
|||
|
|
...def,
|
|||
|
|
keys,
|
|||
|
|
keySet: new Set(keys),
|
|||
|
|
numKeys: keys.length,
|
|||
|
|
optionalKeys: new Set(okeys)
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
function handleCatchall(proms, input, payload, ctx, def, inst) {
|
|||
|
|
const unrecognized = [];
|
|||
|
|
const keySet = def.keySet;
|
|||
|
|
const _catchall = def.catchall._zod;
|
|||
|
|
const t = _catchall.def.type;
|
|||
|
|
const isOptionalOut = _catchall.optout === "optional";
|
|||
|
|
for (const key in input) {
|
|||
|
|
if (keySet.has(key))
|
|||
|
|
continue;
|
|||
|
|
if (t === "never") {
|
|||
|
|
unrecognized.push(key);
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
const r = _catchall.run({ value: input[key], issues: [] }, ctx);
|
|||
|
|
if (r instanceof Promise) {
|
|||
|
|
proms.push(r.then((r2) => handlePropertyResult(r2, payload, key, input, isOptionalOut)));
|
|||
|
|
} else {
|
|||
|
|
handlePropertyResult(r, payload, key, input, isOptionalOut);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (unrecognized.length) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "unrecognized_keys",
|
|||
|
|
keys: unrecognized,
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
if (!proms.length)
|
|||
|
|
return payload;
|
|||
|
|
return Promise.all(proms).then(() => {
|
|||
|
|
return payload;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var $ZodObject = $constructor("$ZodObject", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
const desc = Object.getOwnPropertyDescriptor(def, "shape");
|
|||
|
|
if (!desc?.get) {
|
|||
|
|
const sh = def.shape;
|
|||
|
|
Object.defineProperty(def, "shape", {
|
|||
|
|
get: () => {
|
|||
|
|
const newSh = { ...sh };
|
|||
|
|
Object.defineProperty(def, "shape", {
|
|||
|
|
value: newSh
|
|||
|
|
});
|
|||
|
|
return newSh;
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
const _normalized = cached(() => normalizeDef(def));
|
|||
|
|
defineLazy(inst._zod, "propValues", () => {
|
|||
|
|
const shape = def.shape;
|
|||
|
|
const propValues = {};
|
|||
|
|
for (const key in shape) {
|
|||
|
|
const field = shape[key]._zod;
|
|||
|
|
if (field.values) {
|
|||
|
|
propValues[key] ?? (propValues[key] = /* @__PURE__ */ new Set());
|
|||
|
|
for (const v of field.values)
|
|||
|
|
propValues[key].add(v);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return propValues;
|
|||
|
|
});
|
|||
|
|
const isObject2 = isObject;
|
|||
|
|
const catchall = def.catchall;
|
|||
|
|
let value;
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
value ?? (value = _normalized.value);
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (!isObject2(input)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "object",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
payload.value = {};
|
|||
|
|
const proms = [];
|
|||
|
|
const shape = value.shape;
|
|||
|
|
for (const key of value.keys) {
|
|||
|
|
const el = shape[key];
|
|||
|
|
const isOptionalOut = el._zod.optout === "optional";
|
|||
|
|
const r = el._zod.run({ value: input[key], issues: [] }, ctx);
|
|||
|
|
if (r instanceof Promise) {
|
|||
|
|
proms.push(r.then((r2) => handlePropertyResult(r2, payload, key, input, isOptionalOut)));
|
|||
|
|
} else {
|
|||
|
|
handlePropertyResult(r, payload, key, input, isOptionalOut);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (!catchall) {
|
|||
|
|
return proms.length ? Promise.all(proms).then(() => payload) : payload;
|
|||
|
|
}
|
|||
|
|
return handleCatchall(proms, input, payload, ctx, _normalized.value, inst);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodObjectJIT = $constructor("$ZodObjectJIT", (inst, def) => {
|
|||
|
|
$ZodObject.init(inst, def);
|
|||
|
|
const superParse = inst._zod.parse;
|
|||
|
|
const _normalized = cached(() => normalizeDef(def));
|
|||
|
|
const generateFastpass = (shape) => {
|
|||
|
|
const doc = new Doc(["shape", "payload", "ctx"]);
|
|||
|
|
const normalized = _normalized.value;
|
|||
|
|
const parseStr = (key) => {
|
|||
|
|
const k = esc(key);
|
|||
|
|
return `shape[${k}]._zod.run({ value: input[${k}], issues: [] }, ctx)`;
|
|||
|
|
};
|
|||
|
|
doc.write(`const input = payload.value;`);
|
|||
|
|
const ids = /* @__PURE__ */ Object.create(null);
|
|||
|
|
let counter = 0;
|
|||
|
|
for (const key of normalized.keys) {
|
|||
|
|
ids[key] = `key_${counter++}`;
|
|||
|
|
}
|
|||
|
|
doc.write(`const newResult = {};`);
|
|||
|
|
for (const key of normalized.keys) {
|
|||
|
|
const id = ids[key];
|
|||
|
|
const k = esc(key);
|
|||
|
|
const schema = shape[key];
|
|||
|
|
const isOptionalOut = schema?._zod?.optout === "optional";
|
|||
|
|
doc.write(`const ${id} = ${parseStr(key)};`);
|
|||
|
|
if (isOptionalOut) {
|
|||
|
|
doc.write(`
|
|||
|
|
if (${id}.issues.length) {
|
|||
|
|
if (${k} in input) {
|
|||
|
|
payload.issues = payload.issues.concat(${id}.issues.map(iss => ({
|
|||
|
|
...iss,
|
|||
|
|
path: iss.path ? [${k}, ...iss.path] : [${k}]
|
|||
|
|
})));
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
if (${id}.value === undefined) {
|
|||
|
|
if (${k} in input) {
|
|||
|
|
newResult[${k}] = undefined;
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
newResult[${k}] = ${id}.value;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
`);
|
|||
|
|
} else {
|
|||
|
|
doc.write(`
|
|||
|
|
if (${id}.issues.length) {
|
|||
|
|
payload.issues = payload.issues.concat(${id}.issues.map(iss => ({
|
|||
|
|
...iss,
|
|||
|
|
path: iss.path ? [${k}, ...iss.path] : [${k}]
|
|||
|
|
})));
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
if (${id}.value === undefined) {
|
|||
|
|
if (${k} in input) {
|
|||
|
|
newResult[${k}] = undefined;
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
newResult[${k}] = ${id}.value;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
`);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
doc.write(`payload.value = newResult;`);
|
|||
|
|
doc.write(`return payload;`);
|
|||
|
|
const fn = doc.compile();
|
|||
|
|
return (payload, ctx) => fn(shape, payload, ctx);
|
|||
|
|
};
|
|||
|
|
let fastpass;
|
|||
|
|
const isObject2 = isObject;
|
|||
|
|
const jit = !globalConfig.jitless;
|
|||
|
|
const allowsEval2 = allowsEval;
|
|||
|
|
const fastEnabled = jit && allowsEval2.value;
|
|||
|
|
const catchall = def.catchall;
|
|||
|
|
let value;
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
value ?? (value = _normalized.value);
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (!isObject2(input)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "object",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
if (jit && fastEnabled && ctx?.async === false && ctx.jitless !== true) {
|
|||
|
|
if (!fastpass)
|
|||
|
|
fastpass = generateFastpass(def.shape);
|
|||
|
|
payload = fastpass(payload, ctx);
|
|||
|
|
if (!catchall)
|
|||
|
|
return payload;
|
|||
|
|
return handleCatchall([], input, payload, ctx, value, inst);
|
|||
|
|
}
|
|||
|
|
return superParse(payload, ctx);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleUnionResults(results, final, inst, ctx) {
|
|||
|
|
for (const result of results) {
|
|||
|
|
if (result.issues.length === 0) {
|
|||
|
|
final.value = result.value;
|
|||
|
|
return final;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const nonaborted = results.filter((r) => !aborted(r));
|
|||
|
|
if (nonaborted.length === 1) {
|
|||
|
|
final.value = nonaborted[0].value;
|
|||
|
|
return nonaborted[0];
|
|||
|
|
}
|
|||
|
|
final.issues.push({
|
|||
|
|
code: "invalid_union",
|
|||
|
|
input: final.value,
|
|||
|
|
inst,
|
|||
|
|
errors: results.map((result) => result.issues.map((iss) => finalizeIssue(iss, ctx, config())))
|
|||
|
|
});
|
|||
|
|
return final;
|
|||
|
|
}
|
|||
|
|
var $ZodUnion = $constructor("$ZodUnion", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
defineLazy(inst._zod, "optin", () => def.options.some((o) => o._zod.optin === "optional") ? "optional" : void 0);
|
|||
|
|
defineLazy(inst._zod, "optout", () => def.options.some((o) => o._zod.optout === "optional") ? "optional" : void 0);
|
|||
|
|
defineLazy(inst._zod, "values", () => {
|
|||
|
|
if (def.options.every((o) => o._zod.values)) {
|
|||
|
|
return new Set(def.options.flatMap((option) => Array.from(option._zod.values)));
|
|||
|
|
}
|
|||
|
|
return void 0;
|
|||
|
|
});
|
|||
|
|
defineLazy(inst._zod, "pattern", () => {
|
|||
|
|
if (def.options.every((o) => o._zod.pattern)) {
|
|||
|
|
const patterns = def.options.map((o) => o._zod.pattern);
|
|||
|
|
return new RegExp(`^(${patterns.map((p) => cleanRegex(p.source)).join("|")})$`);
|
|||
|
|
}
|
|||
|
|
return void 0;
|
|||
|
|
});
|
|||
|
|
const single = def.options.length === 1;
|
|||
|
|
const first = def.options[0]._zod.run;
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (single) {
|
|||
|
|
return first(payload, ctx);
|
|||
|
|
}
|
|||
|
|
let async = false;
|
|||
|
|
const results = [];
|
|||
|
|
for (const option of def.options) {
|
|||
|
|
const result = option._zod.run({
|
|||
|
|
value: payload.value,
|
|||
|
|
issues: []
|
|||
|
|
}, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
results.push(result);
|
|||
|
|
async = true;
|
|||
|
|
} else {
|
|||
|
|
if (result.issues.length === 0)
|
|||
|
|
return result;
|
|||
|
|
results.push(result);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (!async)
|
|||
|
|
return handleUnionResults(results, payload, inst, ctx);
|
|||
|
|
return Promise.all(results).then((results2) => {
|
|||
|
|
return handleUnionResults(results2, payload, inst, ctx);
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleExclusiveUnionResults(results, final, inst, ctx) {
|
|||
|
|
const successes = results.filter((r) => r.issues.length === 0);
|
|||
|
|
if (successes.length === 1) {
|
|||
|
|
final.value = successes[0].value;
|
|||
|
|
return final;
|
|||
|
|
}
|
|||
|
|
if (successes.length === 0) {
|
|||
|
|
final.issues.push({
|
|||
|
|
code: "invalid_union",
|
|||
|
|
input: final.value,
|
|||
|
|
inst,
|
|||
|
|
errors: results.map((result) => result.issues.map((iss) => finalizeIssue(iss, ctx, config())))
|
|||
|
|
});
|
|||
|
|
} else {
|
|||
|
|
final.issues.push({
|
|||
|
|
code: "invalid_union",
|
|||
|
|
input: final.value,
|
|||
|
|
inst,
|
|||
|
|
errors: [],
|
|||
|
|
inclusive: false
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
return final;
|
|||
|
|
}
|
|||
|
|
var $ZodXor = $constructor("$ZodXor", (inst, def) => {
|
|||
|
|
$ZodUnion.init(inst, def);
|
|||
|
|
def.inclusive = false;
|
|||
|
|
const single = def.options.length === 1;
|
|||
|
|
const first = def.options[0]._zod.run;
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (single) {
|
|||
|
|
return first(payload, ctx);
|
|||
|
|
}
|
|||
|
|
let async = false;
|
|||
|
|
const results = [];
|
|||
|
|
for (const option of def.options) {
|
|||
|
|
const result = option._zod.run({
|
|||
|
|
value: payload.value,
|
|||
|
|
issues: []
|
|||
|
|
}, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
results.push(result);
|
|||
|
|
async = true;
|
|||
|
|
} else {
|
|||
|
|
results.push(result);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (!async)
|
|||
|
|
return handleExclusiveUnionResults(results, payload, inst, ctx);
|
|||
|
|
return Promise.all(results).then((results2) => {
|
|||
|
|
return handleExclusiveUnionResults(results2, payload, inst, ctx);
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodDiscriminatedUnion = $constructor("$ZodDiscriminatedUnion", (inst, def) => {
|
|||
|
|
def.inclusive = false;
|
|||
|
|
$ZodUnion.init(inst, def);
|
|||
|
|
const _super = inst._zod.parse;
|
|||
|
|
defineLazy(inst._zod, "propValues", () => {
|
|||
|
|
const propValues = {};
|
|||
|
|
for (const option of def.options) {
|
|||
|
|
const pv = option._zod.propValues;
|
|||
|
|
if (!pv || Object.keys(pv).length === 0)
|
|||
|
|
throw new Error(`Invalid discriminated union option at index "${def.options.indexOf(option)}"`);
|
|||
|
|
for (const [k, v] of Object.entries(pv)) {
|
|||
|
|
if (!propValues[k])
|
|||
|
|
propValues[k] = /* @__PURE__ */ new Set();
|
|||
|
|
for (const val of v) {
|
|||
|
|
propValues[k].add(val);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return propValues;
|
|||
|
|
});
|
|||
|
|
const disc = cached(() => {
|
|||
|
|
const opts = def.options;
|
|||
|
|
const map2 = /* @__PURE__ */ new Map();
|
|||
|
|
for (const o of opts) {
|
|||
|
|
const values = o._zod.propValues?.[def.discriminator];
|
|||
|
|
if (!values || values.size === 0)
|
|||
|
|
throw new Error(`Invalid discriminated union option at index "${def.options.indexOf(o)}"`);
|
|||
|
|
for (const v of values) {
|
|||
|
|
if (map2.has(v)) {
|
|||
|
|
throw new Error(`Duplicate discriminator value "${String(v)}"`);
|
|||
|
|
}
|
|||
|
|
map2.set(v, o);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return map2;
|
|||
|
|
});
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (!isObject(input)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_type",
|
|||
|
|
expected: "object",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
const opt = disc.value.get(input?.[def.discriminator]);
|
|||
|
|
if (opt) {
|
|||
|
|
return opt._zod.run(payload, ctx);
|
|||
|
|
}
|
|||
|
|
if (def.unionFallback) {
|
|||
|
|
return _super(payload, ctx);
|
|||
|
|
}
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_union",
|
|||
|
|
errors: [],
|
|||
|
|
note: "No matching discriminator",
|
|||
|
|
discriminator: def.discriminator,
|
|||
|
|
input,
|
|||
|
|
path: [def.discriminator],
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodIntersection = $constructor("$ZodIntersection", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
const left = def.left._zod.run({ value: input, issues: [] }, ctx);
|
|||
|
|
const right = def.right._zod.run({ value: input, issues: [] }, ctx);
|
|||
|
|
const async = left instanceof Promise || right instanceof Promise;
|
|||
|
|
if (async) {
|
|||
|
|
return Promise.all([left, right]).then(([left2, right2]) => {
|
|||
|
|
return handleIntersectionResults(payload, left2, right2);
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
return handleIntersectionResults(payload, left, right);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function mergeValues(a, b) {
|
|||
|
|
if (a === b) {
|
|||
|
|
return { valid: true, data: a };
|
|||
|
|
}
|
|||
|
|
if (a instanceof Date && b instanceof Date && +a === +b) {
|
|||
|
|
return { valid: true, data: a };
|
|||
|
|
}
|
|||
|
|
if (isPlainObject(a) && isPlainObject(b)) {
|
|||
|
|
const bKeys = Object.keys(b);
|
|||
|
|
const sharedKeys = Object.keys(a).filter((key) => bKeys.indexOf(key) !== -1);
|
|||
|
|
const newObj = { ...a, ...b };
|
|||
|
|
for (const key of sharedKeys) {
|
|||
|
|
const sharedValue = mergeValues(a[key], b[key]);
|
|||
|
|
if (!sharedValue.valid) {
|
|||
|
|
return {
|
|||
|
|
valid: false,
|
|||
|
|
mergeErrorPath: [key, ...sharedValue.mergeErrorPath]
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
newObj[key] = sharedValue.data;
|
|||
|
|
}
|
|||
|
|
return { valid: true, data: newObj };
|
|||
|
|
}
|
|||
|
|
if (Array.isArray(a) && Array.isArray(b)) {
|
|||
|
|
if (a.length !== b.length) {
|
|||
|
|
return { valid: false, mergeErrorPath: [] };
|
|||
|
|
}
|
|||
|
|
const newArray = [];
|
|||
|
|
for (let index = 0; index < a.length; index++) {
|
|||
|
|
const itemA = a[index];
|
|||
|
|
const itemB = b[index];
|
|||
|
|
const sharedValue = mergeValues(itemA, itemB);
|
|||
|
|
if (!sharedValue.valid) {
|
|||
|
|
return {
|
|||
|
|
valid: false,
|
|||
|
|
mergeErrorPath: [index, ...sharedValue.mergeErrorPath]
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
newArray.push(sharedValue.data);
|
|||
|
|
}
|
|||
|
|
return { valid: true, data: newArray };
|
|||
|
|
}
|
|||
|
|
return { valid: false, mergeErrorPath: [] };
|
|||
|
|
}
|
|||
|
|
function handleIntersectionResults(result, left, right) {
|
|||
|
|
const unrecKeys = /* @__PURE__ */ new Map();
|
|||
|
|
let unrecIssue;
|
|||
|
|
for (const iss of left.issues) {
|
|||
|
|
if (iss.code === "unrecognized_keys") {
|
|||
|
|
unrecIssue ?? (unrecIssue = iss);
|
|||
|
|
for (const k of iss.keys) {
|
|||
|
|
if (!unrecKeys.has(k))
|
|||
|
|
unrecKeys.set(k, {});
|
|||
|
|
unrecKeys.get(k).l = true;
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
result.issues.push(iss);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
for (const iss of right.issues) {
|
|||
|
|
if (iss.code === "unrecognized_keys") {
|
|||
|
|
for (const k of iss.keys) {
|
|||
|
|
if (!unrecKeys.has(k))
|
|||
|
|
unrecKeys.set(k, {});
|
|||
|
|
unrecKeys.get(k).r = true;
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
result.issues.push(iss);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const bothKeys = [...unrecKeys].filter(([, f]) => f.l && f.r).map(([k]) => k);
|
|||
|
|
if (bothKeys.length && unrecIssue) {
|
|||
|
|
result.issues.push({ ...unrecIssue, keys: bothKeys });
|
|||
|
|
}
|
|||
|
|
if (aborted(result))
|
|||
|
|
return result;
|
|||
|
|
const merged = mergeValues(left.value, right.value);
|
|||
|
|
if (!merged.valid) {
|
|||
|
|
throw new Error(`Unmergable intersection. Error path: ${JSON.stringify(merged.mergeErrorPath)}`);
|
|||
|
|
}
|
|||
|
|
result.value = merged.data;
|
|||
|
|
return result;
|
|||
|
|
}
|
|||
|
|
var $ZodTuple = $constructor("$ZodTuple", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
const items = def.items;
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (!Array.isArray(input)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
expected: "tuple",
|
|||
|
|
code: "invalid_type"
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
payload.value = [];
|
|||
|
|
const proms = [];
|
|||
|
|
const reversedIndex = [...items].reverse().findIndex((item) => item._zod.optin !== "optional");
|
|||
|
|
const optStart = reversedIndex === -1 ? 0 : items.length - reversedIndex;
|
|||
|
|
if (!def.rest) {
|
|||
|
|
const tooBig = input.length > items.length;
|
|||
|
|
const tooSmall = input.length < optStart - 1;
|
|||
|
|
if (tooBig || tooSmall) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
...tooBig ? { code: "too_big", maximum: items.length, inclusive: true } : { code: "too_small", minimum: items.length },
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
origin: "array"
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
let i = -1;
|
|||
|
|
for (const item of items) {
|
|||
|
|
i++;
|
|||
|
|
if (i >= input.length) {
|
|||
|
|
if (i >= optStart)
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
const result = item._zod.run({
|
|||
|
|
value: input[i],
|
|||
|
|
issues: []
|
|||
|
|
}, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
proms.push(result.then((result2) => handleTupleResult(result2, payload, i)));
|
|||
|
|
} else {
|
|||
|
|
handleTupleResult(result, payload, i);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (def.rest) {
|
|||
|
|
const rest = input.slice(items.length);
|
|||
|
|
for (const el of rest) {
|
|||
|
|
i++;
|
|||
|
|
const result = def.rest._zod.run({
|
|||
|
|
value: el,
|
|||
|
|
issues: []
|
|||
|
|
}, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
proms.push(result.then((result2) => handleTupleResult(result2, payload, i)));
|
|||
|
|
} else {
|
|||
|
|
handleTupleResult(result, payload, i);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (proms.length)
|
|||
|
|
return Promise.all(proms).then(() => payload);
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleTupleResult(result, final, index) {
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
final.issues.push(...prefixIssues(index, result.issues));
|
|||
|
|
}
|
|||
|
|
final.value[index] = result.value;
|
|||
|
|
}
|
|||
|
|
var $ZodRecord = $constructor("$ZodRecord", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (!isPlainObject(input)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "record",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
const proms = [];
|
|||
|
|
const values = def.keyType._zod.values;
|
|||
|
|
if (values) {
|
|||
|
|
payload.value = {};
|
|||
|
|
const recordKeys = /* @__PURE__ */ new Set();
|
|||
|
|
for (const key of values) {
|
|||
|
|
if (typeof key === "string" || typeof key === "number" || typeof key === "symbol") {
|
|||
|
|
recordKeys.add(typeof key === "number" ? key.toString() : key);
|
|||
|
|
const result = def.valueType._zod.run({ value: input[key], issues: [] }, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
proms.push(result.then((result2) => {
|
|||
|
|
if (result2.issues.length) {
|
|||
|
|
payload.issues.push(...prefixIssues(key, result2.issues));
|
|||
|
|
}
|
|||
|
|
payload.value[key] = result2.value;
|
|||
|
|
}));
|
|||
|
|
} else {
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
payload.issues.push(...prefixIssues(key, result.issues));
|
|||
|
|
}
|
|||
|
|
payload.value[key] = result.value;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
let unrecognized;
|
|||
|
|
for (const key in input) {
|
|||
|
|
if (!recordKeys.has(key)) {
|
|||
|
|
unrecognized = unrecognized ?? [];
|
|||
|
|
unrecognized.push(key);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (unrecognized && unrecognized.length > 0) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "unrecognized_keys",
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
keys: unrecognized
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
payload.value = {};
|
|||
|
|
for (const key of Reflect.ownKeys(input)) {
|
|||
|
|
if (key === "__proto__")
|
|||
|
|
continue;
|
|||
|
|
let keyResult = def.keyType._zod.run({ value: key, issues: [] }, ctx);
|
|||
|
|
if (keyResult instanceof Promise) {
|
|||
|
|
throw new Error("Async schemas not supported in object keys currently");
|
|||
|
|
}
|
|||
|
|
const checkNumericKey = typeof key === "string" && number.test(key) && keyResult.issues.length;
|
|||
|
|
if (checkNumericKey) {
|
|||
|
|
const retryResult = def.keyType._zod.run({ value: Number(key), issues: [] }, ctx);
|
|||
|
|
if (retryResult instanceof Promise) {
|
|||
|
|
throw new Error("Async schemas not supported in object keys currently");
|
|||
|
|
}
|
|||
|
|
if (retryResult.issues.length === 0) {
|
|||
|
|
keyResult = retryResult;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (keyResult.issues.length) {
|
|||
|
|
if (def.mode === "loose") {
|
|||
|
|
payload.value[key] = input[key];
|
|||
|
|
} else {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_key",
|
|||
|
|
origin: "record",
|
|||
|
|
issues: keyResult.issues.map((iss) => finalizeIssue(iss, ctx, config())),
|
|||
|
|
input: key,
|
|||
|
|
path: [key],
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
const result = def.valueType._zod.run({ value: input[key], issues: [] }, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
proms.push(result.then((result2) => {
|
|||
|
|
if (result2.issues.length) {
|
|||
|
|
payload.issues.push(...prefixIssues(key, result2.issues));
|
|||
|
|
}
|
|||
|
|
payload.value[keyResult.value] = result2.value;
|
|||
|
|
}));
|
|||
|
|
} else {
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
payload.issues.push(...prefixIssues(key, result.issues));
|
|||
|
|
}
|
|||
|
|
payload.value[keyResult.value] = result.value;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (proms.length) {
|
|||
|
|
return Promise.all(proms).then(() => payload);
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodMap = $constructor("$ZodMap", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (!(input instanceof Map)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "map",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
const proms = [];
|
|||
|
|
payload.value = /* @__PURE__ */ new Map();
|
|||
|
|
for (const [key, value] of input) {
|
|||
|
|
const keyResult = def.keyType._zod.run({ value: key, issues: [] }, ctx);
|
|||
|
|
const valueResult = def.valueType._zod.run({ value, issues: [] }, ctx);
|
|||
|
|
if (keyResult instanceof Promise || valueResult instanceof Promise) {
|
|||
|
|
proms.push(Promise.all([keyResult, valueResult]).then(([keyResult2, valueResult2]) => {
|
|||
|
|
handleMapResult(keyResult2, valueResult2, payload, key, input, inst, ctx);
|
|||
|
|
}));
|
|||
|
|
} else {
|
|||
|
|
handleMapResult(keyResult, valueResult, payload, key, input, inst, ctx);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (proms.length)
|
|||
|
|
return Promise.all(proms).then(() => payload);
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleMapResult(keyResult, valueResult, final, key, input, inst, ctx) {
|
|||
|
|
if (keyResult.issues.length) {
|
|||
|
|
if (propertyKeyTypes.has(typeof key)) {
|
|||
|
|
final.issues.push(...prefixIssues(key, keyResult.issues));
|
|||
|
|
} else {
|
|||
|
|
final.issues.push({
|
|||
|
|
code: "invalid_key",
|
|||
|
|
origin: "map",
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
issues: keyResult.issues.map((iss) => finalizeIssue(iss, ctx, config()))
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (valueResult.issues.length) {
|
|||
|
|
if (propertyKeyTypes.has(typeof key)) {
|
|||
|
|
final.issues.push(...prefixIssues(key, valueResult.issues));
|
|||
|
|
} else {
|
|||
|
|
final.issues.push({
|
|||
|
|
origin: "map",
|
|||
|
|
code: "invalid_element",
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
key,
|
|||
|
|
issues: valueResult.issues.map((iss) => finalizeIssue(iss, ctx, config()))
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
final.value.set(keyResult.value, valueResult.value);
|
|||
|
|
}
|
|||
|
|
var $ZodSet = $constructor("$ZodSet", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (!(input instanceof Set)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
expected: "set",
|
|||
|
|
code: "invalid_type"
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
const proms = [];
|
|||
|
|
payload.value = /* @__PURE__ */ new Set();
|
|||
|
|
for (const item of input) {
|
|||
|
|
const result = def.valueType._zod.run({ value: item, issues: [] }, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
proms.push(result.then((result2) => handleSetResult(result2, payload)));
|
|||
|
|
} else
|
|||
|
|
handleSetResult(result, payload);
|
|||
|
|
}
|
|||
|
|
if (proms.length)
|
|||
|
|
return Promise.all(proms).then(() => payload);
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleSetResult(result, final) {
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
final.issues.push(...result.issues);
|
|||
|
|
}
|
|||
|
|
final.value.add(result.value);
|
|||
|
|
}
|
|||
|
|
var $ZodEnum = $constructor("$ZodEnum", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
const values = getEnumValues(def.entries);
|
|||
|
|
const valuesSet = new Set(values);
|
|||
|
|
inst._zod.values = valuesSet;
|
|||
|
|
inst._zod.pattern = new RegExp(`^(${values.filter((k) => propertyKeyTypes.has(typeof k)).map((o) => typeof o === "string" ? escapeRegex(o) : o.toString()).join("|")})$`);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (valuesSet.has(input)) {
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_value",
|
|||
|
|
values,
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodLiteral = $constructor("$ZodLiteral", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
if (def.values.length === 0) {
|
|||
|
|
throw new Error("Cannot create literal schema with no valid values");
|
|||
|
|
}
|
|||
|
|
const values = new Set(def.values);
|
|||
|
|
inst._zod.values = values;
|
|||
|
|
inst._zod.pattern = new RegExp(`^(${def.values.map((o) => typeof o === "string" ? escapeRegex(o) : o ? escapeRegex(o.toString()) : String(o)).join("|")})$`);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (values.has(input)) {
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_value",
|
|||
|
|
values: def.values,
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodFile = $constructor("$ZodFile", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
if (input instanceof File)
|
|||
|
|
return payload;
|
|||
|
|
payload.issues.push({
|
|||
|
|
expected: "file",
|
|||
|
|
code: "invalid_type",
|
|||
|
|
input,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodTransform = $constructor("$ZodTransform", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (ctx.direction === "backward") {
|
|||
|
|
throw new $ZodEncodeError(inst.constructor.name);
|
|||
|
|
}
|
|||
|
|
const _out = def.transform(payload.value, payload);
|
|||
|
|
if (ctx.async) {
|
|||
|
|
const output = _out instanceof Promise ? _out : Promise.resolve(_out);
|
|||
|
|
return output.then((output2) => {
|
|||
|
|
payload.value = output2;
|
|||
|
|
return payload;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
if (_out instanceof Promise) {
|
|||
|
|
throw new $ZodAsyncError();
|
|||
|
|
}
|
|||
|
|
payload.value = _out;
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleOptionalResult(result, input) {
|
|||
|
|
if (result.issues.length && input === void 0) {
|
|||
|
|
return { issues: [], value: void 0 };
|
|||
|
|
}
|
|||
|
|
return result;
|
|||
|
|
}
|
|||
|
|
var $ZodOptional = $constructor("$ZodOptional", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.optin = "optional";
|
|||
|
|
inst._zod.optout = "optional";
|
|||
|
|
defineLazy(inst._zod, "values", () => {
|
|||
|
|
return def.innerType._zod.values ? /* @__PURE__ */ new Set([...def.innerType._zod.values, void 0]) : void 0;
|
|||
|
|
});
|
|||
|
|
defineLazy(inst._zod, "pattern", () => {
|
|||
|
|
const pattern = def.innerType._zod.pattern;
|
|||
|
|
return pattern ? new RegExp(`^(${cleanRegex(pattern.source)})?$`) : void 0;
|
|||
|
|
});
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (def.innerType._zod.optin === "optional") {
|
|||
|
|
const result = def.innerType._zod.run(payload, ctx);
|
|||
|
|
if (result instanceof Promise)
|
|||
|
|
return result.then((r) => handleOptionalResult(r, payload.value));
|
|||
|
|
return handleOptionalResult(result, payload.value);
|
|||
|
|
}
|
|||
|
|
if (payload.value === void 0) {
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
return def.innerType._zod.run(payload, ctx);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodExactOptional = $constructor("$ZodExactOptional", (inst, def) => {
|
|||
|
|
$ZodOptional.init(inst, def);
|
|||
|
|
defineLazy(inst._zod, "values", () => def.innerType._zod.values);
|
|||
|
|
defineLazy(inst._zod, "pattern", () => def.innerType._zod.pattern);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
return def.innerType._zod.run(payload, ctx);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodNullable = $constructor("$ZodNullable", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
defineLazy(inst._zod, "optin", () => def.innerType._zod.optin);
|
|||
|
|
defineLazy(inst._zod, "optout", () => def.innerType._zod.optout);
|
|||
|
|
defineLazy(inst._zod, "pattern", () => {
|
|||
|
|
const pattern = def.innerType._zod.pattern;
|
|||
|
|
return pattern ? new RegExp(`^(${cleanRegex(pattern.source)}|null)$`) : void 0;
|
|||
|
|
});
|
|||
|
|
defineLazy(inst._zod, "values", () => {
|
|||
|
|
return def.innerType._zod.values ? /* @__PURE__ */ new Set([...def.innerType._zod.values, null]) : void 0;
|
|||
|
|
});
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (payload.value === null)
|
|||
|
|
return payload;
|
|||
|
|
return def.innerType._zod.run(payload, ctx);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodDefault = $constructor("$ZodDefault", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.optin = "optional";
|
|||
|
|
defineLazy(inst._zod, "values", () => def.innerType._zod.values);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (ctx.direction === "backward") {
|
|||
|
|
return def.innerType._zod.run(payload, ctx);
|
|||
|
|
}
|
|||
|
|
if (payload.value === void 0) {
|
|||
|
|
payload.value = def.defaultValue;
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
const result = def.innerType._zod.run(payload, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
return result.then((result2) => handleDefaultResult(result2, def));
|
|||
|
|
}
|
|||
|
|
return handleDefaultResult(result, def);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleDefaultResult(payload, def) {
|
|||
|
|
if (payload.value === void 0) {
|
|||
|
|
payload.value = def.defaultValue;
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
var $ZodPrefault = $constructor("$ZodPrefault", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.optin = "optional";
|
|||
|
|
defineLazy(inst._zod, "values", () => def.innerType._zod.values);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (ctx.direction === "backward") {
|
|||
|
|
return def.innerType._zod.run(payload, ctx);
|
|||
|
|
}
|
|||
|
|
if (payload.value === void 0) {
|
|||
|
|
payload.value = def.defaultValue;
|
|||
|
|
}
|
|||
|
|
return def.innerType._zod.run(payload, ctx);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodNonOptional = $constructor("$ZodNonOptional", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
defineLazy(inst._zod, "values", () => {
|
|||
|
|
const v = def.innerType._zod.values;
|
|||
|
|
return v ? new Set([...v].filter((x) => x !== void 0)) : void 0;
|
|||
|
|
});
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const result = def.innerType._zod.run(payload, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
return result.then((result2) => handleNonOptionalResult(result2, inst));
|
|||
|
|
}
|
|||
|
|
return handleNonOptionalResult(result, inst);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleNonOptionalResult(payload, inst) {
|
|||
|
|
if (!payload.issues.length && payload.value === void 0) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_type",
|
|||
|
|
expected: "nonoptional",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
var $ZodSuccess = $constructor("$ZodSuccess", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (ctx.direction === "backward") {
|
|||
|
|
throw new $ZodEncodeError("ZodSuccess");
|
|||
|
|
}
|
|||
|
|
const result = def.innerType._zod.run(payload, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
return result.then((result2) => {
|
|||
|
|
payload.value = result2.issues.length === 0;
|
|||
|
|
return payload;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
payload.value = result.issues.length === 0;
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCatch = $constructor("$ZodCatch", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
defineLazy(inst._zod, "optin", () => def.innerType._zod.optin);
|
|||
|
|
defineLazy(inst._zod, "optout", () => def.innerType._zod.optout);
|
|||
|
|
defineLazy(inst._zod, "values", () => def.innerType._zod.values);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (ctx.direction === "backward") {
|
|||
|
|
return def.innerType._zod.run(payload, ctx);
|
|||
|
|
}
|
|||
|
|
const result = def.innerType._zod.run(payload, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
return result.then((result2) => {
|
|||
|
|
payload.value = result2.value;
|
|||
|
|
if (result2.issues.length) {
|
|||
|
|
payload.value = def.catchValue({
|
|||
|
|
...payload,
|
|||
|
|
error: {
|
|||
|
|
issues: result2.issues.map((iss) => finalizeIssue(iss, ctx, config()))
|
|||
|
|
},
|
|||
|
|
input: payload.value
|
|||
|
|
});
|
|||
|
|
payload.issues = [];
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
payload.value = result.value;
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
payload.value = def.catchValue({
|
|||
|
|
...payload,
|
|||
|
|
error: {
|
|||
|
|
issues: result.issues.map((iss) => finalizeIssue(iss, ctx, config()))
|
|||
|
|
},
|
|||
|
|
input: payload.value
|
|||
|
|
});
|
|||
|
|
payload.issues = [];
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodNaN = $constructor("$ZodNaN", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
if (typeof payload.value !== "number" || !Number.isNaN(payload.value)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
expected: "nan",
|
|||
|
|
code: "invalid_type"
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodPipe = $constructor("$ZodPipe", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
defineLazy(inst._zod, "values", () => def.in._zod.values);
|
|||
|
|
defineLazy(inst._zod, "optin", () => def.in._zod.optin);
|
|||
|
|
defineLazy(inst._zod, "optout", () => def.out._zod.optout);
|
|||
|
|
defineLazy(inst._zod, "propValues", () => def.in._zod.propValues);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (ctx.direction === "backward") {
|
|||
|
|
const right = def.out._zod.run(payload, ctx);
|
|||
|
|
if (right instanceof Promise) {
|
|||
|
|
return right.then((right2) => handlePipeResult(right2, def.in, ctx));
|
|||
|
|
}
|
|||
|
|
return handlePipeResult(right, def.in, ctx);
|
|||
|
|
}
|
|||
|
|
const left = def.in._zod.run(payload, ctx);
|
|||
|
|
if (left instanceof Promise) {
|
|||
|
|
return left.then((left2) => handlePipeResult(left2, def.out, ctx));
|
|||
|
|
}
|
|||
|
|
return handlePipeResult(left, def.out, ctx);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handlePipeResult(left, next, ctx) {
|
|||
|
|
if (left.issues.length) {
|
|||
|
|
left.aborted = true;
|
|||
|
|
return left;
|
|||
|
|
}
|
|||
|
|
return next._zod.run({ value: left.value, issues: left.issues }, ctx);
|
|||
|
|
}
|
|||
|
|
var $ZodCodec = $constructor("$ZodCodec", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
defineLazy(inst._zod, "values", () => def.in._zod.values);
|
|||
|
|
defineLazy(inst._zod, "optin", () => def.in._zod.optin);
|
|||
|
|
defineLazy(inst._zod, "optout", () => def.out._zod.optout);
|
|||
|
|
defineLazy(inst._zod, "propValues", () => def.in._zod.propValues);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const direction = ctx.direction || "forward";
|
|||
|
|
if (direction === "forward") {
|
|||
|
|
const left = def.in._zod.run(payload, ctx);
|
|||
|
|
if (left instanceof Promise) {
|
|||
|
|
return left.then((left2) => handleCodecAResult(left2, def, ctx));
|
|||
|
|
}
|
|||
|
|
return handleCodecAResult(left, def, ctx);
|
|||
|
|
} else {
|
|||
|
|
const right = def.out._zod.run(payload, ctx);
|
|||
|
|
if (right instanceof Promise) {
|
|||
|
|
return right.then((right2) => handleCodecAResult(right2, def, ctx));
|
|||
|
|
}
|
|||
|
|
return handleCodecAResult(right, def, ctx);
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleCodecAResult(result, def, ctx) {
|
|||
|
|
if (result.issues.length) {
|
|||
|
|
result.aborted = true;
|
|||
|
|
return result;
|
|||
|
|
}
|
|||
|
|
const direction = ctx.direction || "forward";
|
|||
|
|
if (direction === "forward") {
|
|||
|
|
const transformed = def.transform(result.value, result);
|
|||
|
|
if (transformed instanceof Promise) {
|
|||
|
|
return transformed.then((value) => handleCodecTxResult(result, value, def.out, ctx));
|
|||
|
|
}
|
|||
|
|
return handleCodecTxResult(result, transformed, def.out, ctx);
|
|||
|
|
} else {
|
|||
|
|
const transformed = def.reverseTransform(result.value, result);
|
|||
|
|
if (transformed instanceof Promise) {
|
|||
|
|
return transformed.then((value) => handleCodecTxResult(result, value, def.in, ctx));
|
|||
|
|
}
|
|||
|
|
return handleCodecTxResult(result, transformed, def.in, ctx);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
function handleCodecTxResult(left, value, nextSchema, ctx) {
|
|||
|
|
if (left.issues.length) {
|
|||
|
|
left.aborted = true;
|
|||
|
|
return left;
|
|||
|
|
}
|
|||
|
|
return nextSchema._zod.run({ value, issues: left.issues }, ctx);
|
|||
|
|
}
|
|||
|
|
var $ZodReadonly = $constructor("$ZodReadonly", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
defineLazy(inst._zod, "propValues", () => def.innerType._zod.propValues);
|
|||
|
|
defineLazy(inst._zod, "values", () => def.innerType._zod.values);
|
|||
|
|
defineLazy(inst._zod, "optin", () => def.innerType?._zod?.optin);
|
|||
|
|
defineLazy(inst._zod, "optout", () => def.innerType?._zod?.optout);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
if (ctx.direction === "backward") {
|
|||
|
|
return def.innerType._zod.run(payload, ctx);
|
|||
|
|
}
|
|||
|
|
const result = def.innerType._zod.run(payload, ctx);
|
|||
|
|
if (result instanceof Promise) {
|
|||
|
|
return result.then(handleReadonlyResult);
|
|||
|
|
}
|
|||
|
|
return handleReadonlyResult(result);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleReadonlyResult(payload) {
|
|||
|
|
payload.value = Object.freeze(payload.value);
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
var $ZodTemplateLiteral = $constructor("$ZodTemplateLiteral", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
const regexParts = [];
|
|||
|
|
for (const part of def.parts) {
|
|||
|
|
if (typeof part === "object" && part !== null) {
|
|||
|
|
if (!part._zod.pattern) {
|
|||
|
|
throw new Error(`Invalid template literal part, no pattern found: ${[...part._zod.traits].shift()}`);
|
|||
|
|
}
|
|||
|
|
const source = part._zod.pattern instanceof RegExp ? part._zod.pattern.source : part._zod.pattern;
|
|||
|
|
if (!source)
|
|||
|
|
throw new Error(`Invalid template literal part: ${part._zod.traits}`);
|
|||
|
|
const start = source.startsWith("^") ? 1 : 0;
|
|||
|
|
const end = source.endsWith("$") ? source.length - 1 : source.length;
|
|||
|
|
regexParts.push(source.slice(start, end));
|
|||
|
|
} else if (part === null || primitiveTypes.has(typeof part)) {
|
|||
|
|
regexParts.push(escapeRegex(`${part}`));
|
|||
|
|
} else {
|
|||
|
|
throw new Error(`Invalid template literal part: ${part}`);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
inst._zod.pattern = new RegExp(`^${regexParts.join("")}$`);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
if (typeof payload.value !== "string") {
|
|||
|
|
payload.issues.push({
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
expected: "string",
|
|||
|
|
code: "invalid_type"
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
inst._zod.pattern.lastIndex = 0;
|
|||
|
|
if (!inst._zod.pattern.test(payload.value)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
code: "invalid_format",
|
|||
|
|
format: def.format ?? "template_literal",
|
|||
|
|
pattern: inst._zod.pattern.source
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodFunction = $constructor("$ZodFunction", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._def = def;
|
|||
|
|
inst._zod.def = def;
|
|||
|
|
inst.implement = (func) => {
|
|||
|
|
if (typeof func !== "function") {
|
|||
|
|
throw new Error("implement() must be called with a function");
|
|||
|
|
}
|
|||
|
|
return function(...args) {
|
|||
|
|
const parsedArgs = inst._def.input ? parse(inst._def.input, args) : args;
|
|||
|
|
const result = Reflect.apply(func, this, parsedArgs);
|
|||
|
|
if (inst._def.output) {
|
|||
|
|
return parse(inst._def.output, result);
|
|||
|
|
}
|
|||
|
|
return result;
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
inst.implementAsync = (func) => {
|
|||
|
|
if (typeof func !== "function") {
|
|||
|
|
throw new Error("implementAsync() must be called with a function");
|
|||
|
|
}
|
|||
|
|
return async function(...args) {
|
|||
|
|
const parsedArgs = inst._def.input ? await parseAsync(inst._def.input, args) : args;
|
|||
|
|
const result = await Reflect.apply(func, this, parsedArgs);
|
|||
|
|
if (inst._def.output) {
|
|||
|
|
return await parseAsync(inst._def.output, result);
|
|||
|
|
}
|
|||
|
|
return result;
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
if (typeof payload.value !== "function") {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_type",
|
|||
|
|
expected: "function",
|
|||
|
|
input: payload.value,
|
|||
|
|
inst
|
|||
|
|
});
|
|||
|
|
return payload;
|
|||
|
|
}
|
|||
|
|
const hasPromiseOutput = inst._def.output && inst._def.output._zod.def.type === "promise";
|
|||
|
|
if (hasPromiseOutput) {
|
|||
|
|
payload.value = inst.implementAsync(payload.value);
|
|||
|
|
} else {
|
|||
|
|
payload.value = inst.implement(payload.value);
|
|||
|
|
}
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
inst.input = (...args) => {
|
|||
|
|
const F = inst.constructor;
|
|||
|
|
if (Array.isArray(args[0])) {
|
|||
|
|
return new F({
|
|||
|
|
type: "function",
|
|||
|
|
input: new $ZodTuple({
|
|||
|
|
type: "tuple",
|
|||
|
|
items: args[0],
|
|||
|
|
rest: args[1]
|
|||
|
|
}),
|
|||
|
|
output: inst._def.output
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
return new F({
|
|||
|
|
type: "function",
|
|||
|
|
input: args[0],
|
|||
|
|
output: inst._def.output
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
inst.output = (output) => {
|
|||
|
|
const F = inst.constructor;
|
|||
|
|
return new F({
|
|||
|
|
type: "function",
|
|||
|
|
input: inst._def.input,
|
|||
|
|
output
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
return inst;
|
|||
|
|
});
|
|||
|
|
var $ZodPromise = $constructor("$ZodPromise", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
return Promise.resolve(payload.value).then((inner) => def.innerType._zod.run({ value: inner, issues: [] }, ctx));
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodLazy = $constructor("$ZodLazy", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
defineLazy(inst._zod, "innerType", () => def.getter());
|
|||
|
|
defineLazy(inst._zod, "pattern", () => inst._zod.innerType?._zod?.pattern);
|
|||
|
|
defineLazy(inst._zod, "propValues", () => inst._zod.innerType?._zod?.propValues);
|
|||
|
|
defineLazy(inst._zod, "optin", () => inst._zod.innerType?._zod?.optin ?? void 0);
|
|||
|
|
defineLazy(inst._zod, "optout", () => inst._zod.innerType?._zod?.optout ?? void 0);
|
|||
|
|
inst._zod.parse = (payload, ctx) => {
|
|||
|
|
const inner = inst._zod.innerType;
|
|||
|
|
return inner._zod.run(payload, ctx);
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
var $ZodCustom = $constructor("$ZodCustom", (inst, def) => {
|
|||
|
|
$ZodCheck.init(inst, def);
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
inst._zod.parse = (payload, _) => {
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
const input = payload.value;
|
|||
|
|
const r = def.fn(input);
|
|||
|
|
if (r instanceof Promise) {
|
|||
|
|
return r.then((r2) => handleRefineResult(r2, payload, input, inst));
|
|||
|
|
}
|
|||
|
|
handleRefineResult(r, payload, input, inst);
|
|||
|
|
return;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function handleRefineResult(result, payload, input, inst) {
|
|||
|
|
if (!result) {
|
|||
|
|
const _iss = {
|
|||
|
|
code: "custom",
|
|||
|
|
input,
|
|||
|
|
inst,
|
|||
|
|
// incorporates params.error into issue reporting
|
|||
|
|
path: [...inst._zod.def.path ?? []],
|
|||
|
|
// incorporates params.error into issue reporting
|
|||
|
|
continue: !inst._zod.def.abort
|
|||
|
|
// params: inst._zod.def.params,
|
|||
|
|
};
|
|||
|
|
if (inst._zod.def.params)
|
|||
|
|
_iss.params = inst._zod.def.params;
|
|||
|
|
payload.issues.push(issue(_iss));
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/index.js
|
|||
|
|
var locales_exports = {};
|
|||
|
|
__export(locales_exports, {
|
|||
|
|
ar: () => ar_default,
|
|||
|
|
az: () => az_default,
|
|||
|
|
be: () => be_default,
|
|||
|
|
bg: () => bg_default,
|
|||
|
|
ca: () => ca_default,
|
|||
|
|
cs: () => cs_default,
|
|||
|
|
da: () => da_default,
|
|||
|
|
de: () => de_default,
|
|||
|
|
en: () => en_default,
|
|||
|
|
eo: () => eo_default,
|
|||
|
|
es: () => es_default,
|
|||
|
|
fa: () => fa_default,
|
|||
|
|
fi: () => fi_default,
|
|||
|
|
fr: () => fr_default,
|
|||
|
|
frCA: () => fr_CA_default,
|
|||
|
|
he: () => he_default,
|
|||
|
|
hu: () => hu_default,
|
|||
|
|
hy: () => hy_default,
|
|||
|
|
id: () => id_default,
|
|||
|
|
is: () => is_default,
|
|||
|
|
it: () => it_default,
|
|||
|
|
ja: () => ja_default,
|
|||
|
|
ka: () => ka_default,
|
|||
|
|
kh: () => kh_default,
|
|||
|
|
km: () => km_default,
|
|||
|
|
ko: () => ko_default,
|
|||
|
|
lt: () => lt_default,
|
|||
|
|
mk: () => mk_default,
|
|||
|
|
ms: () => ms_default,
|
|||
|
|
nl: () => nl_default,
|
|||
|
|
no: () => no_default,
|
|||
|
|
ota: () => ota_default,
|
|||
|
|
pl: () => pl_default,
|
|||
|
|
ps: () => ps_default,
|
|||
|
|
pt: () => pt_default,
|
|||
|
|
ru: () => ru_default,
|
|||
|
|
sl: () => sl_default,
|
|||
|
|
sv: () => sv_default,
|
|||
|
|
ta: () => ta_default,
|
|||
|
|
th: () => th_default,
|
|||
|
|
tr: () => tr_default,
|
|||
|
|
ua: () => ua_default,
|
|||
|
|
uk: () => uk_default,
|
|||
|
|
ur: () => ur_default,
|
|||
|
|
uz: () => uz_default,
|
|||
|
|
vi: () => vi_default,
|
|||
|
|
yo: () => yo_default,
|
|||
|
|
zhCN: () => zh_CN_default,
|
|||
|
|
zhTW: () => zh_TW_default
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ar.js
|
|||
|
|
var error = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "حرف", verb: "أن يحوي" },
|
|||
|
|
file: { unit: "بايت", verb: "أن يحوي" },
|
|||
|
|
array: { unit: "عنصر", verb: "أن يحوي" },
|
|||
|
|
set: { unit: "عنصر", verb: "أن يحوي" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "مدخل",
|
|||
|
|
email: "بريد إلكتروني",
|
|||
|
|
url: "رابط",
|
|||
|
|
emoji: "إيموجي",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "تاريخ ووقت بمعيار ISO",
|
|||
|
|
date: "تاريخ بمعيار ISO",
|
|||
|
|
time: "وقت بمعيار ISO",
|
|||
|
|
duration: "مدة بمعيار ISO",
|
|||
|
|
ipv4: "عنوان IPv4",
|
|||
|
|
ipv6: "عنوان IPv6",
|
|||
|
|
cidrv4: "مدى عناوين بصيغة IPv4",
|
|||
|
|
cidrv6: "مدى عناوين بصيغة IPv6",
|
|||
|
|
base64: "نَص بترميز base64-encoded",
|
|||
|
|
base64url: "نَص بترميز base64url-encoded",
|
|||
|
|
json_string: "نَص على هيئة JSON",
|
|||
|
|
e164: "رقم هاتف بمعيار E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "مدخل"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `مدخلات غير مقبولة: يفترض إدخال instanceof ${issue2.expected}، ولكن تم إدخال ${received}`;
|
|||
|
|
}
|
|||
|
|
return `مدخلات غير مقبولة: يفترض إدخال ${expected}، ولكن تم إدخال ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `مدخلات غير مقبولة: يفترض إدخال ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `اختيار غير مقبول: يتوقع انتقاء أحد هذه الخيارات: ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return ` أكبر من اللازم: يفترض أن تكون ${issue2.origin ?? "القيمة"} ${adj} ${issue2.maximum.toString()} ${sizing.unit ?? "عنصر"}`;
|
|||
|
|
return `أكبر من اللازم: يفترض أن تكون ${issue2.origin ?? "القيمة"} ${adj} ${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `أصغر من اللازم: يفترض لـ ${issue2.origin} أن يكون ${adj} ${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `أصغر من اللازم: يفترض لـ ${issue2.origin} أن يكون ${adj} ${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `نَص غير مقبول: يجب أن يبدأ بـ "${issue2.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `نَص غير مقبول: يجب أن ينتهي بـ "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `نَص غير مقبول: يجب أن يتضمَّن "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `نَص غير مقبول: يجب أن يطابق النمط ${_issue.pattern}`;
|
|||
|
|
return `${FormatDictionary[_issue.format] ?? issue2.format} غير مقبول`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `رقم غير مقبول: يجب أن يكون من مضاعفات ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `معرف${issue2.keys.length > 1 ? "ات" : ""} غريب${issue2.keys.length > 1 ? "ة" : ""}: ${joinValues(issue2.keys, "، ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `معرف غير مقبول في ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "مدخل غير مقبول";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `مدخل غير مقبول في ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return "مدخل غير مقبول";
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ar_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/az.js
|
|||
|
|
var error2 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "simvol", verb: "olmalıdır" },
|
|||
|
|
file: { unit: "bayt", verb: "olmalıdır" },
|
|||
|
|
array: { unit: "element", verb: "olmalıdır" },
|
|||
|
|
set: { unit: "element", verb: "olmalıdır" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "input",
|
|||
|
|
email: "email address",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO datetime",
|
|||
|
|
date: "ISO date",
|
|||
|
|
time: "ISO time",
|
|||
|
|
duration: "ISO duration",
|
|||
|
|
ipv4: "IPv4 address",
|
|||
|
|
ipv6: "IPv6 address",
|
|||
|
|
cidrv4: "IPv4 range",
|
|||
|
|
cidrv6: "IPv6 range",
|
|||
|
|
base64: "base64-encoded string",
|
|||
|
|
base64url: "base64url-encoded string",
|
|||
|
|
json_string: "JSON string",
|
|||
|
|
e164: "E.164 number",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "input"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Yanlış dəyər: gözlənilən instanceof ${issue2.expected}, daxil olan ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Yanlış dəyər: gözlənilən ${expected}, daxil olan ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Yanlış dəyər: gözlənilən ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Yanlış seçim: aşağıdakılardan biri olmalıdır: ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Çox böyük: gözlənilən ${issue2.origin ?? "dəyər"} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "element"}`;
|
|||
|
|
return `Çox böyük: gözlənilən ${issue2.origin ?? "dəyər"} ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Çox kiçik: gözlənilən ${issue2.origin} ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
return `Çox kiçik: gözlənilən ${issue2.origin} ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Yanlış mətn: "${_issue.prefix}" ilə başlamalıdır`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Yanlış mətn: "${_issue.suffix}" ilə bitməlidir`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Yanlış mətn: "${_issue.includes}" daxil olmalıdır`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Yanlış mətn: ${_issue.pattern} şablonuna uyğun olmalıdır`;
|
|||
|
|
return `Yanlış ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Yanlış ədəd: ${issue2.divisor} ilə bölünə bilən olmalıdır`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Tanınmayan açar${issue2.keys.length > 1 ? "lar" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `${issue2.origin} daxilində yanlış açar`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Yanlış dəyər";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `${issue2.origin} daxilində yanlış dəyər`;
|
|||
|
|
default:
|
|||
|
|
return `Yanlış dəyər`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function az_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error2()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/be.js
|
|||
|
|
function getBelarusianPlural(count, one, few, many) {
|
|||
|
|
const absCount = Math.abs(count);
|
|||
|
|
const lastDigit = absCount % 10;
|
|||
|
|
const lastTwoDigits = absCount % 100;
|
|||
|
|
if (lastTwoDigits >= 11 && lastTwoDigits <= 19) {
|
|||
|
|
return many;
|
|||
|
|
}
|
|||
|
|
if (lastDigit === 1) {
|
|||
|
|
return one;
|
|||
|
|
}
|
|||
|
|
if (lastDigit >= 2 && lastDigit <= 4) {
|
|||
|
|
return few;
|
|||
|
|
}
|
|||
|
|
return many;
|
|||
|
|
}
|
|||
|
|
var error3 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: {
|
|||
|
|
unit: {
|
|||
|
|
one: "сімвал",
|
|||
|
|
few: "сімвалы",
|
|||
|
|
many: "сімвалаў"
|
|||
|
|
},
|
|||
|
|
verb: "мець"
|
|||
|
|
},
|
|||
|
|
array: {
|
|||
|
|
unit: {
|
|||
|
|
one: "элемент",
|
|||
|
|
few: "элементы",
|
|||
|
|
many: "элементаў"
|
|||
|
|
},
|
|||
|
|
verb: "мець"
|
|||
|
|
},
|
|||
|
|
set: {
|
|||
|
|
unit: {
|
|||
|
|
one: "элемент",
|
|||
|
|
few: "элементы",
|
|||
|
|
many: "элементаў"
|
|||
|
|
},
|
|||
|
|
verb: "мець"
|
|||
|
|
},
|
|||
|
|
file: {
|
|||
|
|
unit: {
|
|||
|
|
one: "байт",
|
|||
|
|
few: "байты",
|
|||
|
|
many: "байтаў"
|
|||
|
|
},
|
|||
|
|
verb: "мець"
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "увод",
|
|||
|
|
email: "email адрас",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "эмодзі",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO дата і час",
|
|||
|
|
date: "ISO дата",
|
|||
|
|
time: "ISO час",
|
|||
|
|
duration: "ISO працягласць",
|
|||
|
|
ipv4: "IPv4 адрас",
|
|||
|
|
ipv6: "IPv6 адрас",
|
|||
|
|
cidrv4: "IPv4 дыяпазон",
|
|||
|
|
cidrv6: "IPv6 дыяпазон",
|
|||
|
|
base64: "радок у фармаце base64",
|
|||
|
|
base64url: "радок у фармаце base64url",
|
|||
|
|
json_string: "JSON радок",
|
|||
|
|
e164: "нумар E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "увод"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "лік",
|
|||
|
|
array: "масіў"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Няправільны ўвод: чакаўся instanceof ${issue2.expected}, атрымана ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Няправільны ўвод: чакаўся ${expected}, атрымана ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Няправільны ўвод: чакалася ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Няправільны варыянт: чакаўся адзін з ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
const maxValue = Number(issue2.maximum);
|
|||
|
|
const unit = getBelarusianPlural(maxValue, sizing.unit.one, sizing.unit.few, sizing.unit.many);
|
|||
|
|
return `Занадта вялікі: чакалася, што ${issue2.origin ?? "значэнне"} павінна ${sizing.verb} ${adj}${issue2.maximum.toString()} ${unit}`;
|
|||
|
|
}
|
|||
|
|
return `Занадта вялікі: чакалася, што ${issue2.origin ?? "значэнне"} павінна быць ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
const minValue = Number(issue2.minimum);
|
|||
|
|
const unit = getBelarusianPlural(minValue, sizing.unit.one, sizing.unit.few, sizing.unit.many);
|
|||
|
|
return `Занадта малы: чакалася, што ${issue2.origin} павінна ${sizing.verb} ${adj}${issue2.minimum.toString()} ${unit}`;
|
|||
|
|
}
|
|||
|
|
return `Занадта малы: чакалася, што ${issue2.origin} павінна быць ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Няправільны радок: павінен пачынацца з "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Няправільны радок: павінен заканчвацца на "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Няправільны радок: павінен змяшчаць "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Няправільны радок: павінен адпавядаць шаблону ${_issue.pattern}`;
|
|||
|
|
return `Няправільны ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Няправільны лік: павінен быць кратным ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Нераспазнаны ${issue2.keys.length > 1 ? "ключы" : "ключ"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Няправільны ключ у ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Няправільны ўвод";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Няправільнае значэнне ў ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Няправільны ўвод`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function be_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error3()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/bg.js
|
|||
|
|
var error4 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "символа", verb: "да съдържа" },
|
|||
|
|
file: { unit: "байта", verb: "да съдържа" },
|
|||
|
|
array: { unit: "елемента", verb: "да съдържа" },
|
|||
|
|
set: { unit: "елемента", verb: "да съдържа" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "вход",
|
|||
|
|
email: "имейл адрес",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "емоджи",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO време",
|
|||
|
|
date: "ISO дата",
|
|||
|
|
time: "ISO време",
|
|||
|
|
duration: "ISO продължителност",
|
|||
|
|
ipv4: "IPv4 адрес",
|
|||
|
|
ipv6: "IPv6 адрес",
|
|||
|
|
cidrv4: "IPv4 диапазон",
|
|||
|
|
cidrv6: "IPv6 диапазон",
|
|||
|
|
base64: "base64-кодиран низ",
|
|||
|
|
base64url: "base64url-кодиран низ",
|
|||
|
|
json_string: "JSON низ",
|
|||
|
|
e164: "E.164 номер",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "вход"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "число",
|
|||
|
|
array: "масив"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Невалиден вход: очакван instanceof ${issue2.expected}, получен ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Невалиден вход: очакван ${expected}, получен ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Невалиден вход: очакван ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Невалидна опция: очаквано едно от ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Твърде голямо: очаква се ${issue2.origin ?? "стойност"} да съдържа ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "елемента"}`;
|
|||
|
|
return `Твърде голямо: очаква се ${issue2.origin ?? "стойност"} да бъде ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Твърде малко: очаква се ${issue2.origin} да съдържа ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Твърде малко: очаква се ${issue2.origin} да бъде ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Невалиден низ: трябва да започва с "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Невалиден низ: трябва да завършва с "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Невалиден низ: трябва да включва "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Невалиден низ: трябва да съвпада с ${_issue.pattern}`;
|
|||
|
|
let invalid_adj = "Невалиден";
|
|||
|
|
if (_issue.format === "emoji")
|
|||
|
|
invalid_adj = "Невалидно";
|
|||
|
|
if (_issue.format === "datetime")
|
|||
|
|
invalid_adj = "Невалидно";
|
|||
|
|
if (_issue.format === "date")
|
|||
|
|
invalid_adj = "Невалидна";
|
|||
|
|
if (_issue.format === "time")
|
|||
|
|
invalid_adj = "Невалидно";
|
|||
|
|
if (_issue.format === "duration")
|
|||
|
|
invalid_adj = "Невалидна";
|
|||
|
|
return `${invalid_adj} ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Невалидно число: трябва да бъде кратно на ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Неразпознат${issue2.keys.length > 1 ? "и" : ""} ключ${issue2.keys.length > 1 ? "ове" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Невалиден ключ в ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Невалиден вход";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Невалидна стойност в ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Невалиден вход`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function bg_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error4()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ca.js
|
|||
|
|
var error5 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "caràcters", verb: "contenir" },
|
|||
|
|
file: { unit: "bytes", verb: "contenir" },
|
|||
|
|
array: { unit: "elements", verb: "contenir" },
|
|||
|
|
set: { unit: "elements", verb: "contenir" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "entrada",
|
|||
|
|
email: "adreça electrònica",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "data i hora ISO",
|
|||
|
|
date: "data ISO",
|
|||
|
|
time: "hora ISO",
|
|||
|
|
duration: "durada ISO",
|
|||
|
|
ipv4: "adreça IPv4",
|
|||
|
|
ipv6: "adreça IPv6",
|
|||
|
|
cidrv4: "rang IPv4",
|
|||
|
|
cidrv6: "rang IPv6",
|
|||
|
|
base64: "cadena codificada en base64",
|
|||
|
|
base64url: "cadena codificada en base64url",
|
|||
|
|
json_string: "cadena JSON",
|
|||
|
|
e164: "número E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "entrada"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Tipus invàlid: s'esperava instanceof ${issue2.expected}, s'ha rebut ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Tipus invàlid: s'esperava ${expected}, s'ha rebut ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Valor invàlid: s'esperava ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Opció invàlida: s'esperava una de ${joinValues(issue2.values, " o ")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "com a màxim" : "menys de";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Massa gran: s'esperava que ${issue2.origin ?? "el valor"} contingués ${adj} ${issue2.maximum.toString()} ${sizing.unit ?? "elements"}`;
|
|||
|
|
return `Massa gran: s'esperava que ${issue2.origin ?? "el valor"} fos ${adj} ${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? "com a mínim" : "més de";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Massa petit: s'esperava que ${issue2.origin} contingués ${adj} ${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Massa petit: s'esperava que ${issue2.origin} fos ${adj} ${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Format invàlid: ha de començar amb "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Format invàlid: ha d'acabar amb "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Format invàlid: ha d'incloure "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Format invàlid: ha de coincidir amb el patró ${_issue.pattern}`;
|
|||
|
|
return `Format invàlid per a ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Número invàlid: ha de ser múltiple de ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Clau${issue2.keys.length > 1 ? "s" : ""} no reconeguda${issue2.keys.length > 1 ? "s" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Clau invàlida a ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Entrada invàlida";
|
|||
|
|
// Could also be "Tipus d'unió invàlid" but "Entrada invàlida" is more general
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Element invàlid a ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Entrada invàlida`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ca_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error5()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/cs.js
|
|||
|
|
var error6 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "znaků", verb: "mít" },
|
|||
|
|
file: { unit: "bajtů", verb: "mít" },
|
|||
|
|
array: { unit: "prvků", verb: "mít" },
|
|||
|
|
set: { unit: "prvků", verb: "mít" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "regulární výraz",
|
|||
|
|
email: "e-mailová adresa",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "datum a čas ve formátu ISO",
|
|||
|
|
date: "datum ve formátu ISO",
|
|||
|
|
time: "čas ve formátu ISO",
|
|||
|
|
duration: "doba trvání ISO",
|
|||
|
|
ipv4: "IPv4 adresa",
|
|||
|
|
ipv6: "IPv6 adresa",
|
|||
|
|
cidrv4: "rozsah IPv4",
|
|||
|
|
cidrv6: "rozsah IPv6",
|
|||
|
|
base64: "řetězec zakódovaný ve formátu base64",
|
|||
|
|
base64url: "řetězec zakódovaný ve formátu base64url",
|
|||
|
|
json_string: "řetězec ve formátu JSON",
|
|||
|
|
e164: "číslo E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "vstup"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "číslo",
|
|||
|
|
string: "řetězec",
|
|||
|
|
function: "funkce",
|
|||
|
|
array: "pole"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Neplatný vstup: očekáváno instanceof ${issue2.expected}, obdrženo ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Neplatný vstup: očekáváno ${expected}, obdrženo ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Neplatný vstup: očekáváno ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Neplatná možnost: očekávána jedna z hodnot ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Hodnota je příliš velká: ${issue2.origin ?? "hodnota"} musí mít ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "prvků"}`;
|
|||
|
|
}
|
|||
|
|
return `Hodnota je příliš velká: ${issue2.origin ?? "hodnota"} musí být ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Hodnota je příliš malá: ${issue2.origin ?? "hodnota"} musí mít ${adj}${issue2.minimum.toString()} ${sizing.unit ?? "prvků"}`;
|
|||
|
|
}
|
|||
|
|
return `Hodnota je příliš malá: ${issue2.origin ?? "hodnota"} musí být ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Neplatný řetězec: musí začínat na "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Neplatný řetězec: musí končit na "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Neplatný řetězec: musí obsahovat "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Neplatný řetězec: musí odpovídat vzoru ${_issue.pattern}`;
|
|||
|
|
return `Neplatný formát ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Neplatné číslo: musí být násobkem ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Neznámé klíče: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Neplatný klíč v ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Neplatný vstup";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Neplatná hodnota v ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Neplatný vstup`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function cs_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error6()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/da.js
|
|||
|
|
var error7 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "tegn", verb: "havde" },
|
|||
|
|
file: { unit: "bytes", verb: "havde" },
|
|||
|
|
array: { unit: "elementer", verb: "indeholdt" },
|
|||
|
|
set: { unit: "elementer", verb: "indeholdt" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "input",
|
|||
|
|
email: "e-mailadresse",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO dato- og klokkeslæt",
|
|||
|
|
date: "ISO-dato",
|
|||
|
|
time: "ISO-klokkeslæt",
|
|||
|
|
duration: "ISO-varighed",
|
|||
|
|
ipv4: "IPv4-område",
|
|||
|
|
ipv6: "IPv6-område",
|
|||
|
|
cidrv4: "IPv4-spektrum",
|
|||
|
|
cidrv6: "IPv6-spektrum",
|
|||
|
|
base64: "base64-kodet streng",
|
|||
|
|
base64url: "base64url-kodet streng",
|
|||
|
|
json_string: "JSON-streng",
|
|||
|
|
e164: "E.164-nummer",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "input"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
string: "streng",
|
|||
|
|
number: "tal",
|
|||
|
|
boolean: "boolean",
|
|||
|
|
array: "liste",
|
|||
|
|
object: "objekt",
|
|||
|
|
set: "sæt",
|
|||
|
|
file: "fil"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Ugyldigt input: forventede instanceof ${issue2.expected}, fik ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Ugyldigt input: forventede ${expected}, fik ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Ugyldig værdi: forventede ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Ugyldigt valg: forventede en af følgende ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const origin = TypeDictionary[issue2.origin] ?? issue2.origin;
|
|||
|
|
if (sizing)
|
|||
|
|
return `For stor: forventede ${origin ?? "value"} ${sizing.verb} ${adj} ${issue2.maximum.toString()} ${sizing.unit ?? "elementer"}`;
|
|||
|
|
return `For stor: forventede ${origin ?? "value"} havde ${adj} ${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const origin = TypeDictionary[issue2.origin] ?? issue2.origin;
|
|||
|
|
if (sizing) {
|
|||
|
|
return `For lille: forventede ${origin} ${sizing.verb} ${adj} ${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `For lille: forventede ${origin} havde ${adj} ${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Ugyldig streng: skal starte med "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Ugyldig streng: skal ende med "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Ugyldig streng: skal indeholde "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Ugyldig streng: skal matche mønsteret ${_issue.pattern}`;
|
|||
|
|
return `Ugyldig ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Ugyldigt tal: skal være deleligt med ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `${issue2.keys.length > 1 ? "Ukendte nøgler" : "Ukendt nøgle"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Ugyldig nøgle i ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Ugyldigt input: matcher ingen af de tilladte typer";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Ugyldig værdi i ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Ugyldigt input`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function da_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error7()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/de.js
|
|||
|
|
var error8 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "Zeichen", verb: "zu haben" },
|
|||
|
|
file: { unit: "Bytes", verb: "zu haben" },
|
|||
|
|
array: { unit: "Elemente", verb: "zu haben" },
|
|||
|
|
set: { unit: "Elemente", verb: "zu haben" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "Eingabe",
|
|||
|
|
email: "E-Mail-Adresse",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "Emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO-Datum und -Uhrzeit",
|
|||
|
|
date: "ISO-Datum",
|
|||
|
|
time: "ISO-Uhrzeit",
|
|||
|
|
duration: "ISO-Dauer",
|
|||
|
|
ipv4: "IPv4-Adresse",
|
|||
|
|
ipv6: "IPv6-Adresse",
|
|||
|
|
cidrv4: "IPv4-Bereich",
|
|||
|
|
cidrv6: "IPv6-Bereich",
|
|||
|
|
base64: "Base64-codierter String",
|
|||
|
|
base64url: "Base64-URL-codierter String",
|
|||
|
|
json_string: "JSON-String",
|
|||
|
|
e164: "E.164-Nummer",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "Eingabe"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "Zahl",
|
|||
|
|
array: "Array"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Ungültige Eingabe: erwartet instanceof ${issue2.expected}, erhalten ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Ungültige Eingabe: erwartet ${expected}, erhalten ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Ungültige Eingabe: erwartet ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Ungültige Option: erwartet eine von ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Zu groß: erwartet, dass ${issue2.origin ?? "Wert"} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "Elemente"} hat`;
|
|||
|
|
return `Zu groß: erwartet, dass ${issue2.origin ?? "Wert"} ${adj}${issue2.maximum.toString()} ist`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Zu klein: erwartet, dass ${issue2.origin} ${adj}${issue2.minimum.toString()} ${sizing.unit} hat`;
|
|||
|
|
}
|
|||
|
|
return `Zu klein: erwartet, dass ${issue2.origin} ${adj}${issue2.minimum.toString()} ist`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Ungültiger String: muss mit "${_issue.prefix}" beginnen`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Ungültiger String: muss mit "${_issue.suffix}" enden`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Ungültiger String: muss "${_issue.includes}" enthalten`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Ungültiger String: muss dem Muster ${_issue.pattern} entsprechen`;
|
|||
|
|
return `Ungültig: ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Ungültige Zahl: muss ein Vielfaches von ${issue2.divisor} sein`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `${issue2.keys.length > 1 ? "Unbekannte Schlüssel" : "Unbekannter Schlüssel"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Ungültiger Schlüssel in ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Ungültige Eingabe";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Ungültiger Wert in ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Ungültige Eingabe`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function de_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error8()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/en.js
|
|||
|
|
var error9 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "characters", verb: "to have" },
|
|||
|
|
file: { unit: "bytes", verb: "to have" },
|
|||
|
|
array: { unit: "items", verb: "to have" },
|
|||
|
|
set: { unit: "items", verb: "to have" },
|
|||
|
|
map: { unit: "entries", verb: "to have" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "input",
|
|||
|
|
email: "email address",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO datetime",
|
|||
|
|
date: "ISO date",
|
|||
|
|
time: "ISO time",
|
|||
|
|
duration: "ISO duration",
|
|||
|
|
ipv4: "IPv4 address",
|
|||
|
|
ipv6: "IPv6 address",
|
|||
|
|
mac: "MAC address",
|
|||
|
|
cidrv4: "IPv4 range",
|
|||
|
|
cidrv6: "IPv6 range",
|
|||
|
|
base64: "base64-encoded string",
|
|||
|
|
base64url: "base64url-encoded string",
|
|||
|
|
json_string: "JSON string",
|
|||
|
|
e164: "E.164 number",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "input"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
// Compatibility: "nan" -> "NaN" for display
|
|||
|
|
nan: "NaN"
|
|||
|
|
// All other type names omitted - they fall back to raw values via ?? operator
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
return `Invalid input: expected ${expected}, received ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Invalid input: expected ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Invalid option: expected one of ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Too big: expected ${issue2.origin ?? "value"} to have ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elements"}`;
|
|||
|
|
return `Too big: expected ${issue2.origin ?? "value"} to be ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Too small: expected ${issue2.origin} to have ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Too small: expected ${issue2.origin} to be ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Invalid string: must start with "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Invalid string: must end with "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Invalid string: must include "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Invalid string: must match pattern ${_issue.pattern}`;
|
|||
|
|
return `Invalid ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Invalid number: must be a multiple of ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Unrecognized key${issue2.keys.length > 1 ? "s" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Invalid key in ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Invalid input";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Invalid value in ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Invalid input`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function en_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error9()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/eo.js
|
|||
|
|
var error10 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "karaktrojn", verb: "havi" },
|
|||
|
|
file: { unit: "bajtojn", verb: "havi" },
|
|||
|
|
array: { unit: "elementojn", verb: "havi" },
|
|||
|
|
set: { unit: "elementojn", verb: "havi" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "enigo",
|
|||
|
|
email: "retadreso",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoĝio",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO-datotempo",
|
|||
|
|
date: "ISO-dato",
|
|||
|
|
time: "ISO-tempo",
|
|||
|
|
duration: "ISO-daŭro",
|
|||
|
|
ipv4: "IPv4-adreso",
|
|||
|
|
ipv6: "IPv6-adreso",
|
|||
|
|
cidrv4: "IPv4-rango",
|
|||
|
|
cidrv6: "IPv6-rango",
|
|||
|
|
base64: "64-ume kodita karaktraro",
|
|||
|
|
base64url: "URL-64-ume kodita karaktraro",
|
|||
|
|
json_string: "JSON-karaktraro",
|
|||
|
|
e164: "E.164-nombro",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "enigo"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "nombro",
|
|||
|
|
array: "tabelo",
|
|||
|
|
null: "senvalora"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Nevalida enigo: atendiĝis instanceof ${issue2.expected}, riceviĝis ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Nevalida enigo: atendiĝis ${expected}, riceviĝis ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Nevalida enigo: atendiĝis ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Nevalida opcio: atendiĝis unu el ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Tro granda: atendiĝis ke ${issue2.origin ?? "valoro"} havu ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elementojn"}`;
|
|||
|
|
return `Tro granda: atendiĝis ke ${issue2.origin ?? "valoro"} havu ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Tro malgranda: atendiĝis ke ${issue2.origin} havu ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Tro malgranda: atendiĝis ke ${issue2.origin} estu ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Nevalida karaktraro: devas komenciĝi per "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Nevalida karaktraro: devas finiĝi per "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Nevalida karaktraro: devas inkluzivi "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Nevalida karaktraro: devas kongrui kun la modelo ${_issue.pattern}`;
|
|||
|
|
return `Nevalida ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Nevalida nombro: devas esti oblo de ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Nekonata${issue2.keys.length > 1 ? "j" : ""} ŝlosilo${issue2.keys.length > 1 ? "j" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Nevalida ŝlosilo en ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Nevalida enigo";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Nevalida valoro en ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Nevalida enigo`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function eo_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error10()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/es.js
|
|||
|
|
var error11 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "caracteres", verb: "tener" },
|
|||
|
|
file: { unit: "bytes", verb: "tener" },
|
|||
|
|
array: { unit: "elementos", verb: "tener" },
|
|||
|
|
set: { unit: "elementos", verb: "tener" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "entrada",
|
|||
|
|
email: "dirección de correo electrónico",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "fecha y hora ISO",
|
|||
|
|
date: "fecha ISO",
|
|||
|
|
time: "hora ISO",
|
|||
|
|
duration: "duración ISO",
|
|||
|
|
ipv4: "dirección IPv4",
|
|||
|
|
ipv6: "dirección IPv6",
|
|||
|
|
cidrv4: "rango IPv4",
|
|||
|
|
cidrv6: "rango IPv6",
|
|||
|
|
base64: "cadena codificada en base64",
|
|||
|
|
base64url: "URL codificada en base64",
|
|||
|
|
json_string: "cadena JSON",
|
|||
|
|
e164: "número E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "entrada"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
string: "texto",
|
|||
|
|
number: "número",
|
|||
|
|
boolean: "booleano",
|
|||
|
|
array: "arreglo",
|
|||
|
|
object: "objeto",
|
|||
|
|
set: "conjunto",
|
|||
|
|
file: "archivo",
|
|||
|
|
date: "fecha",
|
|||
|
|
bigint: "número grande",
|
|||
|
|
symbol: "símbolo",
|
|||
|
|
undefined: "indefinido",
|
|||
|
|
null: "nulo",
|
|||
|
|
function: "función",
|
|||
|
|
map: "mapa",
|
|||
|
|
record: "registro",
|
|||
|
|
tuple: "tupla",
|
|||
|
|
enum: "enumeración",
|
|||
|
|
union: "unión",
|
|||
|
|
literal: "literal",
|
|||
|
|
promise: "promesa",
|
|||
|
|
void: "vacío",
|
|||
|
|
never: "nunca",
|
|||
|
|
unknown: "desconocido",
|
|||
|
|
any: "cualquiera"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Entrada inválida: se esperaba instanceof ${issue2.expected}, recibido ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Entrada inválida: se esperaba ${expected}, recibido ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Entrada inválida: se esperaba ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Opción inválida: se esperaba una de ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const origin = TypeDictionary[issue2.origin] ?? issue2.origin;
|
|||
|
|
if (sizing)
|
|||
|
|
return `Demasiado grande: se esperaba que ${origin ?? "valor"} tuviera ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elementos"}`;
|
|||
|
|
return `Demasiado grande: se esperaba que ${origin ?? "valor"} fuera ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const origin = TypeDictionary[issue2.origin] ?? issue2.origin;
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Demasiado pequeño: se esperaba que ${origin} tuviera ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Demasiado pequeño: se esperaba que ${origin} fuera ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Cadena inválida: debe comenzar con "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Cadena inválida: debe terminar en "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Cadena inválida: debe incluir "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Cadena inválida: debe coincidir con el patrón ${_issue.pattern}`;
|
|||
|
|
return `Inválido ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Número inválido: debe ser múltiplo de ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Llave${issue2.keys.length > 1 ? "s" : ""} desconocida${issue2.keys.length > 1 ? "s" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Llave inválida en ${TypeDictionary[issue2.origin] ?? issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Entrada inválida";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Valor inválido en ${TypeDictionary[issue2.origin] ?? issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Entrada inválida`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function es_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error11()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/fa.js
|
|||
|
|
var error12 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "کاراکتر", verb: "داشته باشد" },
|
|||
|
|
file: { unit: "بایت", verb: "داشته باشد" },
|
|||
|
|
array: { unit: "آیتم", verb: "داشته باشد" },
|
|||
|
|
set: { unit: "آیتم", verb: "داشته باشد" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "ورودی",
|
|||
|
|
email: "آدرس ایمیل",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "ایموجی",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "تاریخ و زمان ایزو",
|
|||
|
|
date: "تاریخ ایزو",
|
|||
|
|
time: "زمان ایزو",
|
|||
|
|
duration: "مدت زمان ایزو",
|
|||
|
|
ipv4: "IPv4 آدرس",
|
|||
|
|
ipv6: "IPv6 آدرس",
|
|||
|
|
cidrv4: "IPv4 دامنه",
|
|||
|
|
cidrv6: "IPv6 دامنه",
|
|||
|
|
base64: "base64-encoded رشته",
|
|||
|
|
base64url: "base64url-encoded رشته",
|
|||
|
|
json_string: "JSON رشته",
|
|||
|
|
e164: "E.164 عدد",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "ورودی"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "عدد",
|
|||
|
|
array: "آرایه"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `ورودی نامعتبر: میبایست instanceof ${issue2.expected} میبود، ${received} دریافت شد`;
|
|||
|
|
}
|
|||
|
|
return `ورودی نامعتبر: میبایست ${expected} میبود، ${received} دریافت شد`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1) {
|
|||
|
|
return `ورودی نامعتبر: میبایست ${stringifyPrimitive(issue2.values[0])} میبود`;
|
|||
|
|
}
|
|||
|
|
return `گزینه نامعتبر: میبایست یکی از ${joinValues(issue2.values, "|")} میبود`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `خیلی بزرگ: ${issue2.origin ?? "مقدار"} باید ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "عنصر"} باشد`;
|
|||
|
|
}
|
|||
|
|
return `خیلی بزرگ: ${issue2.origin ?? "مقدار"} باید ${adj}${issue2.maximum.toString()} باشد`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `خیلی کوچک: ${issue2.origin} باید ${adj}${issue2.minimum.toString()} ${sizing.unit} باشد`;
|
|||
|
|
}
|
|||
|
|
return `خیلی کوچک: ${issue2.origin} باید ${adj}${issue2.minimum.toString()} باشد`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `رشته نامعتبر: باید با "${_issue.prefix}" شروع شود`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with") {
|
|||
|
|
return `رشته نامعتبر: باید با "${_issue.suffix}" تمام شود`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "includes") {
|
|||
|
|
return `رشته نامعتبر: باید شامل "${_issue.includes}" باشد`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "regex") {
|
|||
|
|
return `رشته نامعتبر: باید با الگوی ${_issue.pattern} مطابقت داشته باشد`;
|
|||
|
|
}
|
|||
|
|
return `${FormatDictionary[_issue.format] ?? issue2.format} نامعتبر`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `عدد نامعتبر: باید مضرب ${issue2.divisor} باشد`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `کلید${issue2.keys.length > 1 ? "های" : ""} ناشناس: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `کلید ناشناس در ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return `ورودی نامعتبر`;
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `مقدار نامعتبر در ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `ورودی نامعتبر`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function fa_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error12()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/fi.js
|
|||
|
|
var error13 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "merkkiä", subject: "merkkijonon" },
|
|||
|
|
file: { unit: "tavua", subject: "tiedoston" },
|
|||
|
|
array: { unit: "alkiota", subject: "listan" },
|
|||
|
|
set: { unit: "alkiota", subject: "joukon" },
|
|||
|
|
number: { unit: "", subject: "luvun" },
|
|||
|
|
bigint: { unit: "", subject: "suuren kokonaisluvun" },
|
|||
|
|
int: { unit: "", subject: "kokonaisluvun" },
|
|||
|
|
date: { unit: "", subject: "päivämäärän" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "säännöllinen lauseke",
|
|||
|
|
email: "sähköpostiosoite",
|
|||
|
|
url: "URL-osoite",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO-aikaleima",
|
|||
|
|
date: "ISO-päivämäärä",
|
|||
|
|
time: "ISO-aika",
|
|||
|
|
duration: "ISO-kesto",
|
|||
|
|
ipv4: "IPv4-osoite",
|
|||
|
|
ipv6: "IPv6-osoite",
|
|||
|
|
cidrv4: "IPv4-alue",
|
|||
|
|
cidrv6: "IPv6-alue",
|
|||
|
|
base64: "base64-koodattu merkkijono",
|
|||
|
|
base64url: "base64url-koodattu merkkijono",
|
|||
|
|
json_string: "JSON-merkkijono",
|
|||
|
|
e164: "E.164-luku",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "templaattimerkkijono"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Virheellinen tyyppi: odotettiin instanceof ${issue2.expected}, oli ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Virheellinen tyyppi: odotettiin ${expected}, oli ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Virheellinen syöte: täytyy olla ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Virheellinen valinta: täytyy olla yksi seuraavista: ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Liian suuri: ${sizing.subject} täytyy olla ${adj}${issue2.maximum.toString()} ${sizing.unit}`.trim();
|
|||
|
|
}
|
|||
|
|
return `Liian suuri: arvon täytyy olla ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Liian pieni: ${sizing.subject} täytyy olla ${adj}${issue2.minimum.toString()} ${sizing.unit}`.trim();
|
|||
|
|
}
|
|||
|
|
return `Liian pieni: arvon täytyy olla ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Virheellinen syöte: täytyy alkaa "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Virheellinen syöte: täytyy loppua "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Virheellinen syöte: täytyy sisältää "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex") {
|
|||
|
|
return `Virheellinen syöte: täytyy vastata säännöllistä lauseketta ${_issue.pattern}`;
|
|||
|
|
}
|
|||
|
|
return `Virheellinen ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Virheellinen luku: täytyy olla luvun ${issue2.divisor} monikerta`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `${issue2.keys.length > 1 ? "Tuntemattomat avaimet" : "Tuntematon avain"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return "Virheellinen avain tietueessa";
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Virheellinen unioni";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return "Virheellinen arvo joukossa";
|
|||
|
|
default:
|
|||
|
|
return `Virheellinen syöte`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function fi_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error13()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/fr.js
|
|||
|
|
var error14 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "caractères", verb: "avoir" },
|
|||
|
|
file: { unit: "octets", verb: "avoir" },
|
|||
|
|
array: { unit: "éléments", verb: "avoir" },
|
|||
|
|
set: { unit: "éléments", verb: "avoir" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "entrée",
|
|||
|
|
email: "adresse e-mail",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "date et heure ISO",
|
|||
|
|
date: "date ISO",
|
|||
|
|
time: "heure ISO",
|
|||
|
|
duration: "durée ISO",
|
|||
|
|
ipv4: "adresse IPv4",
|
|||
|
|
ipv6: "adresse IPv6",
|
|||
|
|
cidrv4: "plage IPv4",
|
|||
|
|
cidrv6: "plage IPv6",
|
|||
|
|
base64: "chaîne encodée en base64",
|
|||
|
|
base64url: "chaîne encodée en base64url",
|
|||
|
|
json_string: "chaîne JSON",
|
|||
|
|
e164: "numéro E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "entrée"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "nombre",
|
|||
|
|
array: "tableau"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Entrée invalide : instanceof ${issue2.expected} attendu, ${received} reçu`;
|
|||
|
|
}
|
|||
|
|
return `Entrée invalide : ${expected} attendu, ${received} reçu`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Entrée invalide : ${stringifyPrimitive(issue2.values[0])} attendu`;
|
|||
|
|
return `Option invalide : une valeur parmi ${joinValues(issue2.values, "|")} attendue`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Trop grand : ${issue2.origin ?? "valeur"} doit ${sizing.verb} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "élément(s)"}`;
|
|||
|
|
return `Trop grand : ${issue2.origin ?? "valeur"} doit être ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Trop petit : ${issue2.origin} doit ${sizing.verb} ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Trop petit : ${issue2.origin} doit être ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Chaîne invalide : doit commencer par "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Chaîne invalide : doit se terminer par "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Chaîne invalide : doit inclure "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Chaîne invalide : doit correspondre au modèle ${_issue.pattern}`;
|
|||
|
|
return `${FormatDictionary[_issue.format] ?? issue2.format} invalide`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Nombre invalide : doit être un multiple de ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Clé${issue2.keys.length > 1 ? "s" : ""} non reconnue${issue2.keys.length > 1 ? "s" : ""} : ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Clé invalide dans ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Entrée invalide";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Valeur invalide dans ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Entrée invalide`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function fr_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error14()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/fr-CA.js
|
|||
|
|
var error15 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "caractères", verb: "avoir" },
|
|||
|
|
file: { unit: "octets", verb: "avoir" },
|
|||
|
|
array: { unit: "éléments", verb: "avoir" },
|
|||
|
|
set: { unit: "éléments", verb: "avoir" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "entrée",
|
|||
|
|
email: "adresse courriel",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "date-heure ISO",
|
|||
|
|
date: "date ISO",
|
|||
|
|
time: "heure ISO",
|
|||
|
|
duration: "durée ISO",
|
|||
|
|
ipv4: "adresse IPv4",
|
|||
|
|
ipv6: "adresse IPv6",
|
|||
|
|
cidrv4: "plage IPv4",
|
|||
|
|
cidrv6: "plage IPv6",
|
|||
|
|
base64: "chaîne encodée en base64",
|
|||
|
|
base64url: "chaîne encodée en base64url",
|
|||
|
|
json_string: "chaîne JSON",
|
|||
|
|
e164: "numéro E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "entrée"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Entrée invalide : attendu instanceof ${issue2.expected}, reçu ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Entrée invalide : attendu ${expected}, reçu ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Entrée invalide : attendu ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Option invalide : attendu l'une des valeurs suivantes ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "≤" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Trop grand : attendu que ${issue2.origin ?? "la valeur"} ait ${adj}${issue2.maximum.toString()} ${sizing.unit}`;
|
|||
|
|
return `Trop grand : attendu que ${issue2.origin ?? "la valeur"} soit ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? "≥" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Trop petit : attendu que ${issue2.origin} ait ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Trop petit : attendu que ${issue2.origin} soit ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Chaîne invalide : doit commencer par "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Chaîne invalide : doit se terminer par "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Chaîne invalide : doit inclure "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Chaîne invalide : doit correspondre au motif ${_issue.pattern}`;
|
|||
|
|
return `${FormatDictionary[_issue.format] ?? issue2.format} invalide`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Nombre invalide : doit être un multiple de ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Clé${issue2.keys.length > 1 ? "s" : ""} non reconnue${issue2.keys.length > 1 ? "s" : ""} : ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Clé invalide dans ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Entrée invalide";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Valeur invalide dans ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Entrée invalide`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function fr_CA_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error15()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/he.js
|
|||
|
|
var error16 = () => {
|
|||
|
|
const TypeNames = {
|
|||
|
|
string: { label: "מחרוזת", gender: "f" },
|
|||
|
|
number: { label: "מספר", gender: "m" },
|
|||
|
|
boolean: { label: "ערך בוליאני", gender: "m" },
|
|||
|
|
bigint: { label: "BigInt", gender: "m" },
|
|||
|
|
date: { label: "תאריך", gender: "m" },
|
|||
|
|
array: { label: "מערך", gender: "m" },
|
|||
|
|
object: { label: "אובייקט", gender: "m" },
|
|||
|
|
null: { label: "ערך ריק (null)", gender: "m" },
|
|||
|
|
undefined: { label: "ערך לא מוגדר (undefined)", gender: "m" },
|
|||
|
|
symbol: { label: "סימבול (Symbol)", gender: "m" },
|
|||
|
|
function: { label: "פונקציה", gender: "f" },
|
|||
|
|
map: { label: "מפה (Map)", gender: "f" },
|
|||
|
|
set: { label: "קבוצה (Set)", gender: "f" },
|
|||
|
|
file: { label: "קובץ", gender: "m" },
|
|||
|
|
promise: { label: "Promise", gender: "m" },
|
|||
|
|
NaN: { label: "NaN", gender: "m" },
|
|||
|
|
unknown: { label: "ערך לא ידוע", gender: "m" },
|
|||
|
|
value: { label: "ערך", gender: "m" }
|
|||
|
|
};
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "תווים", shortLabel: "קצר", longLabel: "ארוך" },
|
|||
|
|
file: { unit: "בייטים", shortLabel: "קטן", longLabel: "גדול" },
|
|||
|
|
array: { unit: "פריטים", shortLabel: "קטן", longLabel: "גדול" },
|
|||
|
|
set: { unit: "פריטים", shortLabel: "קטן", longLabel: "גדול" },
|
|||
|
|
number: { unit: "", shortLabel: "קטן", longLabel: "גדול" }
|
|||
|
|
// no unit
|
|||
|
|
};
|
|||
|
|
const typeEntry = (t) => t ? TypeNames[t] : void 0;
|
|||
|
|
const typeLabel = (t) => {
|
|||
|
|
const e = typeEntry(t);
|
|||
|
|
if (e)
|
|||
|
|
return e.label;
|
|||
|
|
return t ?? TypeNames.unknown.label;
|
|||
|
|
};
|
|||
|
|
const withDefinite = (t) => `ה${typeLabel(t)}`;
|
|||
|
|
const verbFor = (t) => {
|
|||
|
|
const e = typeEntry(t);
|
|||
|
|
const gender = e?.gender ?? "m";
|
|||
|
|
return gender === "f" ? "צריכה להיות" : "צריך להיות";
|
|||
|
|
};
|
|||
|
|
const getSizing = (origin) => {
|
|||
|
|
if (!origin)
|
|||
|
|
return null;
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
};
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: { label: "קלט", gender: "m" },
|
|||
|
|
email: { label: "כתובת אימייל", gender: "f" },
|
|||
|
|
url: { label: "כתובת רשת", gender: "f" },
|
|||
|
|
emoji: { label: "אימוג'י", gender: "m" },
|
|||
|
|
uuid: { label: "UUID", gender: "m" },
|
|||
|
|
nanoid: { label: "nanoid", gender: "m" },
|
|||
|
|
guid: { label: "GUID", gender: "m" },
|
|||
|
|
cuid: { label: "cuid", gender: "m" },
|
|||
|
|
cuid2: { label: "cuid2", gender: "m" },
|
|||
|
|
ulid: { label: "ULID", gender: "m" },
|
|||
|
|
xid: { label: "XID", gender: "m" },
|
|||
|
|
ksuid: { label: "KSUID", gender: "m" },
|
|||
|
|
datetime: { label: "תאריך וזמן ISO", gender: "m" },
|
|||
|
|
date: { label: "תאריך ISO", gender: "m" },
|
|||
|
|
time: { label: "זמן ISO", gender: "m" },
|
|||
|
|
duration: { label: "משך זמן ISO", gender: "m" },
|
|||
|
|
ipv4: { label: "כתובת IPv4", gender: "f" },
|
|||
|
|
ipv6: { label: "כתובת IPv6", gender: "f" },
|
|||
|
|
cidrv4: { label: "טווח IPv4", gender: "m" },
|
|||
|
|
cidrv6: { label: "טווח IPv6", gender: "m" },
|
|||
|
|
base64: { label: "מחרוזת בבסיס 64", gender: "f" },
|
|||
|
|
base64url: { label: "מחרוזת בבסיס 64 לכתובות רשת", gender: "f" },
|
|||
|
|
json_string: { label: "מחרוזת JSON", gender: "f" },
|
|||
|
|
e164: { label: "מספר E.164", gender: "m" },
|
|||
|
|
jwt: { label: "JWT", gender: "m" },
|
|||
|
|
ends_with: { label: "קלט", gender: "m" },
|
|||
|
|
includes: { label: "קלט", gender: "m" },
|
|||
|
|
lowercase: { label: "קלט", gender: "m" },
|
|||
|
|
starts_with: { label: "קלט", gender: "m" },
|
|||
|
|
uppercase: { label: "קלט", gender: "m" }
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expectedKey = issue2.expected;
|
|||
|
|
const expected = TypeDictionary[expectedKey ?? ""] ?? typeLabel(expectedKey);
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? TypeNames[receivedType]?.label ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `קלט לא תקין: צריך להיות instanceof ${issue2.expected}, התקבל ${received}`;
|
|||
|
|
}
|
|||
|
|
return `קלט לא תקין: צריך להיות ${expected}, התקבל ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value": {
|
|||
|
|
if (issue2.values.length === 1) {
|
|||
|
|
return `ערך לא תקין: הערך חייב להיות ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
}
|
|||
|
|
const stringified = issue2.values.map((v) => stringifyPrimitive(v));
|
|||
|
|
if (issue2.values.length === 2) {
|
|||
|
|
return `ערך לא תקין: האפשרויות המתאימות הן ${stringified[0]} או ${stringified[1]}`;
|
|||
|
|
}
|
|||
|
|
const lastValue = stringified[stringified.length - 1];
|
|||
|
|
const restValues = stringified.slice(0, -1).join(", ");
|
|||
|
|
return `ערך לא תקין: האפשרויות המתאימות הן ${restValues} או ${lastValue}`;
|
|||
|
|
}
|
|||
|
|
case "too_big": {
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const subject = withDefinite(issue2.origin ?? "value");
|
|||
|
|
if (issue2.origin === "string") {
|
|||
|
|
return `${sizing?.longLabel ?? "ארוך"} מדי: ${subject} צריכה להכיל ${issue2.maximum.toString()} ${sizing?.unit ?? ""} ${issue2.inclusive ? "או פחות" : "לכל היותר"}`.trim();
|
|||
|
|
}
|
|||
|
|
if (issue2.origin === "number") {
|
|||
|
|
const comparison = issue2.inclusive ? `קטן או שווה ל-${issue2.maximum}` : `קטן מ-${issue2.maximum}`;
|
|||
|
|
return `גדול מדי: ${subject} צריך להיות ${comparison}`;
|
|||
|
|
}
|
|||
|
|
if (issue2.origin === "array" || issue2.origin === "set") {
|
|||
|
|
const verb = issue2.origin === "set" ? "צריכה" : "צריך";
|
|||
|
|
const comparison = issue2.inclusive ? `${issue2.maximum} ${sizing?.unit ?? ""} או פחות` : `פחות מ-${issue2.maximum} ${sizing?.unit ?? ""}`;
|
|||
|
|
return `גדול מדי: ${subject} ${verb} להכיל ${comparison}`.trim();
|
|||
|
|
}
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const be = verbFor(issue2.origin ?? "value");
|
|||
|
|
if (sizing?.unit) {
|
|||
|
|
return `${sizing.longLabel} מדי: ${subject} ${be} ${adj}${issue2.maximum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `${sizing?.longLabel ?? "גדול"} מדי: ${subject} ${be} ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const subject = withDefinite(issue2.origin ?? "value");
|
|||
|
|
if (issue2.origin === "string") {
|
|||
|
|
return `${sizing?.shortLabel ?? "קצר"} מדי: ${subject} צריכה להכיל ${issue2.minimum.toString()} ${sizing?.unit ?? ""} ${issue2.inclusive ? "או יותר" : "לפחות"}`.trim();
|
|||
|
|
}
|
|||
|
|
if (issue2.origin === "number") {
|
|||
|
|
const comparison = issue2.inclusive ? `גדול או שווה ל-${issue2.minimum}` : `גדול מ-${issue2.minimum}`;
|
|||
|
|
return `קטן מדי: ${subject} צריך להיות ${comparison}`;
|
|||
|
|
}
|
|||
|
|
if (issue2.origin === "array" || issue2.origin === "set") {
|
|||
|
|
const verb = issue2.origin === "set" ? "צריכה" : "צריך";
|
|||
|
|
if (issue2.minimum === 1 && issue2.inclusive) {
|
|||
|
|
const singularPhrase = issue2.origin === "set" ? "לפחות פריט אחד" : "לפחות פריט אחד";
|
|||
|
|
return `קטן מדי: ${subject} ${verb} להכיל ${singularPhrase}`;
|
|||
|
|
}
|
|||
|
|
const comparison = issue2.inclusive ? `${issue2.minimum} ${sizing?.unit ?? ""} או יותר` : `יותר מ-${issue2.minimum} ${sizing?.unit ?? ""}`;
|
|||
|
|
return `קטן מדי: ${subject} ${verb} להכיל ${comparison}`.trim();
|
|||
|
|
}
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const be = verbFor(issue2.origin ?? "value");
|
|||
|
|
if (sizing?.unit) {
|
|||
|
|
return `${sizing.shortLabel} מדי: ${subject} ${be} ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `${sizing?.shortLabel ?? "קטן"} מדי: ${subject} ${be} ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `המחרוזת חייבת להתחיל ב "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `המחרוזת חייבת להסתיים ב "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `המחרוזת חייבת לכלול "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `המחרוזת חייבת להתאים לתבנית ${_issue.pattern}`;
|
|||
|
|
const nounEntry = FormatDictionary[_issue.format];
|
|||
|
|
const noun = nounEntry?.label ?? _issue.format;
|
|||
|
|
const gender = nounEntry?.gender ?? "m";
|
|||
|
|
const adjective = gender === "f" ? "תקינה" : "תקין";
|
|||
|
|
return `${noun} לא ${adjective}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `מספר לא תקין: חייב להיות מכפלה של ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `מפתח${issue2.keys.length > 1 ? "ות" : ""} לא מזוה${issue2.keys.length > 1 ? "ים" : "ה"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key": {
|
|||
|
|
return `שדה לא תקין באובייקט`;
|
|||
|
|
}
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "קלט לא תקין";
|
|||
|
|
case "invalid_element": {
|
|||
|
|
const place = withDefinite(issue2.origin ?? "array");
|
|||
|
|
return `ערך לא תקין ב${place}`;
|
|||
|
|
}
|
|||
|
|
default:
|
|||
|
|
return `קלט לא תקין`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function he_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error16()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/hu.js
|
|||
|
|
var error17 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "karakter", verb: "legyen" },
|
|||
|
|
file: { unit: "byte", verb: "legyen" },
|
|||
|
|
array: { unit: "elem", verb: "legyen" },
|
|||
|
|
set: { unit: "elem", verb: "legyen" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "bemenet",
|
|||
|
|
email: "email cím",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO időbélyeg",
|
|||
|
|
date: "ISO dátum",
|
|||
|
|
time: "ISO idő",
|
|||
|
|
duration: "ISO időintervallum",
|
|||
|
|
ipv4: "IPv4 cím",
|
|||
|
|
ipv6: "IPv6 cím",
|
|||
|
|
cidrv4: "IPv4 tartomány",
|
|||
|
|
cidrv6: "IPv6 tartomány",
|
|||
|
|
base64: "base64-kódolt string",
|
|||
|
|
base64url: "base64url-kódolt string",
|
|||
|
|
json_string: "JSON string",
|
|||
|
|
e164: "E.164 szám",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "bemenet"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "szám",
|
|||
|
|
array: "tömb"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Érvénytelen bemenet: a várt érték instanceof ${issue2.expected}, a kapott érték ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Érvénytelen bemenet: a várt érték ${expected}, a kapott érték ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Érvénytelen bemenet: a várt érték ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Érvénytelen opció: valamelyik érték várt ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Túl nagy: ${issue2.origin ?? "érték"} mérete túl nagy ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elem"}`;
|
|||
|
|
return `Túl nagy: a bemeneti érték ${issue2.origin ?? "érték"} túl nagy: ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Túl kicsi: a bemeneti érték ${issue2.origin} mérete túl kicsi ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Túl kicsi: a bemeneti érték ${issue2.origin} túl kicsi ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Érvénytelen string: "${_issue.prefix}" értékkel kell kezdődnie`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Érvénytelen string: "${_issue.suffix}" értékkel kell végződnie`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Érvénytelen string: "${_issue.includes}" értéket kell tartalmaznia`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Érvénytelen string: ${_issue.pattern} mintának kell megfelelnie`;
|
|||
|
|
return `Érvénytelen ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Érvénytelen szám: ${issue2.divisor} többszörösének kell lennie`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Ismeretlen kulcs${issue2.keys.length > 1 ? "s" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Érvénytelen kulcs ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Érvénytelen bemenet";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Érvénytelen érték: ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Érvénytelen bemenet`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function hu_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error17()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/hy.js
|
|||
|
|
function getArmenianPlural(count, one, many) {
|
|||
|
|
return Math.abs(count) === 1 ? one : many;
|
|||
|
|
}
|
|||
|
|
function withDefiniteArticle(word) {
|
|||
|
|
if (!word)
|
|||
|
|
return "";
|
|||
|
|
const vowels = ["ա", "ե", "ը", "ի", "ո", "ու", "օ"];
|
|||
|
|
const lastChar = word[word.length - 1];
|
|||
|
|
return word + (vowels.includes(lastChar) ? "ն" : "ը");
|
|||
|
|
}
|
|||
|
|
var error18 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: {
|
|||
|
|
unit: {
|
|||
|
|
one: "նշան",
|
|||
|
|
many: "նշաններ"
|
|||
|
|
},
|
|||
|
|
verb: "ունենալ"
|
|||
|
|
},
|
|||
|
|
file: {
|
|||
|
|
unit: {
|
|||
|
|
one: "բայթ",
|
|||
|
|
many: "բայթեր"
|
|||
|
|
},
|
|||
|
|
verb: "ունենալ"
|
|||
|
|
},
|
|||
|
|
array: {
|
|||
|
|
unit: {
|
|||
|
|
one: "տարր",
|
|||
|
|
many: "տարրեր"
|
|||
|
|
},
|
|||
|
|
verb: "ունենալ"
|
|||
|
|
},
|
|||
|
|
set: {
|
|||
|
|
unit: {
|
|||
|
|
one: "տարր",
|
|||
|
|
many: "տարրեր"
|
|||
|
|
},
|
|||
|
|
verb: "ունենալ"
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "մուտք",
|
|||
|
|
email: "էլ. հասցե",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "էմոջի",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO ամսաթիվ և ժամ",
|
|||
|
|
date: "ISO ամսաթիվ",
|
|||
|
|
time: "ISO ժամ",
|
|||
|
|
duration: "ISO տևողություն",
|
|||
|
|
ipv4: "IPv4 հասցե",
|
|||
|
|
ipv6: "IPv6 հասցե",
|
|||
|
|
cidrv4: "IPv4 միջակայք",
|
|||
|
|
cidrv6: "IPv6 միջակայք",
|
|||
|
|
base64: "base64 ձևաչափով տող",
|
|||
|
|
base64url: "base64url ձևաչափով տող",
|
|||
|
|
json_string: "JSON տող",
|
|||
|
|
e164: "E.164 համար",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "մուտք"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "թիվ",
|
|||
|
|
array: "զանգված"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Սխալ մուտքագրում․ սպասվում էր instanceof ${issue2.expected}, ստացվել է ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Սխալ մուտքագրում․ սպասվում էր ${expected}, ստացվել է ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Սխալ մուտքագրում․ սպասվում էր ${stringifyPrimitive(issue2.values[1])}`;
|
|||
|
|
return `Սխալ տարբերակ․ սպասվում էր հետևյալներից մեկը՝ ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
const maxValue = Number(issue2.maximum);
|
|||
|
|
const unit = getArmenianPlural(maxValue, sizing.unit.one, sizing.unit.many);
|
|||
|
|
return `Չափազանց մեծ արժեք․ սպասվում է, որ ${withDefiniteArticle(issue2.origin ?? "արժեք")} կունենա ${adj}${issue2.maximum.toString()} ${unit}`;
|
|||
|
|
}
|
|||
|
|
return `Չափազանց մեծ արժեք․ սպասվում է, որ ${withDefiniteArticle(issue2.origin ?? "արժեք")} լինի ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
const minValue = Number(issue2.minimum);
|
|||
|
|
const unit = getArmenianPlural(minValue, sizing.unit.one, sizing.unit.many);
|
|||
|
|
return `Չափազանց փոքր արժեք․ սպասվում է, որ ${withDefiniteArticle(issue2.origin)} կունենա ${adj}${issue2.minimum.toString()} ${unit}`;
|
|||
|
|
}
|
|||
|
|
return `Չափազանց փոքր արժեք․ սպասվում է, որ ${withDefiniteArticle(issue2.origin)} լինի ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Սխալ տող․ պետք է սկսվի "${_issue.prefix}"-ով`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Սխալ տող․ պետք է ավարտվի "${_issue.suffix}"-ով`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Սխալ տող․ պետք է պարունակի "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Սխալ տող․ պետք է համապատասխանի ${_issue.pattern} ձևաչափին`;
|
|||
|
|
return `Սխալ ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Սխալ թիվ․ պետք է բազմապատիկ լինի ${issue2.divisor}-ի`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Չճանաչված բանալի${issue2.keys.length > 1 ? "ներ" : ""}. ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Սխալ բանալի ${withDefiniteArticle(issue2.origin)}-ում`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Սխալ մուտքագրում";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Սխալ արժեք ${withDefiniteArticle(issue2.origin)}-ում`;
|
|||
|
|
default:
|
|||
|
|
return `Սխալ մուտքագրում`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function hy_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error18()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/id.js
|
|||
|
|
var error19 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "karakter", verb: "memiliki" },
|
|||
|
|
file: { unit: "byte", verb: "memiliki" },
|
|||
|
|
array: { unit: "item", verb: "memiliki" },
|
|||
|
|
set: { unit: "item", verb: "memiliki" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "input",
|
|||
|
|
email: "alamat email",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "tanggal dan waktu format ISO",
|
|||
|
|
date: "tanggal format ISO",
|
|||
|
|
time: "jam format ISO",
|
|||
|
|
duration: "durasi format ISO",
|
|||
|
|
ipv4: "alamat IPv4",
|
|||
|
|
ipv6: "alamat IPv6",
|
|||
|
|
cidrv4: "rentang alamat IPv4",
|
|||
|
|
cidrv6: "rentang alamat IPv6",
|
|||
|
|
base64: "string dengan enkode base64",
|
|||
|
|
base64url: "string dengan enkode base64url",
|
|||
|
|
json_string: "string JSON",
|
|||
|
|
e164: "angka E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "input"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Input tidak valid: diharapkan instanceof ${issue2.expected}, diterima ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Input tidak valid: diharapkan ${expected}, diterima ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Input tidak valid: diharapkan ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Pilihan tidak valid: diharapkan salah satu dari ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Terlalu besar: diharapkan ${issue2.origin ?? "value"} memiliki ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elemen"}`;
|
|||
|
|
return `Terlalu besar: diharapkan ${issue2.origin ?? "value"} menjadi ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Terlalu kecil: diharapkan ${issue2.origin} memiliki ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Terlalu kecil: diharapkan ${issue2.origin} menjadi ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `String tidak valid: harus dimulai dengan "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `String tidak valid: harus berakhir dengan "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `String tidak valid: harus menyertakan "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `String tidak valid: harus sesuai pola ${_issue.pattern}`;
|
|||
|
|
return `${FormatDictionary[_issue.format] ?? issue2.format} tidak valid`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Angka tidak valid: harus kelipatan dari ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Kunci tidak dikenali ${issue2.keys.length > 1 ? "s" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Kunci tidak valid di ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Input tidak valid";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Nilai tidak valid di ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Input tidak valid`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function id_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error19()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/is.js
|
|||
|
|
var error20 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "stafi", verb: "að hafa" },
|
|||
|
|
file: { unit: "bæti", verb: "að hafa" },
|
|||
|
|
array: { unit: "hluti", verb: "að hafa" },
|
|||
|
|
set: { unit: "hluti", verb: "að hafa" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "gildi",
|
|||
|
|
email: "netfang",
|
|||
|
|
url: "vefslóð",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO dagsetning og tími",
|
|||
|
|
date: "ISO dagsetning",
|
|||
|
|
time: "ISO tími",
|
|||
|
|
duration: "ISO tímalengd",
|
|||
|
|
ipv4: "IPv4 address",
|
|||
|
|
ipv6: "IPv6 address",
|
|||
|
|
cidrv4: "IPv4 range",
|
|||
|
|
cidrv6: "IPv6 range",
|
|||
|
|
base64: "base64-encoded strengur",
|
|||
|
|
base64url: "base64url-encoded strengur",
|
|||
|
|
json_string: "JSON strengur",
|
|||
|
|
e164: "E.164 tölugildi",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "gildi"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "númer",
|
|||
|
|
array: "fylki"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Rangt gildi: Þú slóst inn ${received} þar sem á að vera instanceof ${issue2.expected}`;
|
|||
|
|
}
|
|||
|
|
return `Rangt gildi: Þú slóst inn ${received} þar sem á að vera ${expected}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Rangt gildi: gert ráð fyrir ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Ógilt val: má vera eitt af eftirfarandi ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Of stórt: gert er ráð fyrir að ${issue2.origin ?? "gildi"} hafi ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "hluti"}`;
|
|||
|
|
return `Of stórt: gert er ráð fyrir að ${issue2.origin ?? "gildi"} sé ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Of lítið: gert er ráð fyrir að ${issue2.origin} hafi ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Of lítið: gert er ráð fyrir að ${issue2.origin} sé ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Ógildur strengur: verður að byrja á "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Ógildur strengur: verður að enda á "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Ógildur strengur: verður að innihalda "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Ógildur strengur: verður að fylgja mynstri ${_issue.pattern}`;
|
|||
|
|
return `Rangt ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Röng tala: verður að vera margfeldi af ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Óþekkt ${issue2.keys.length > 1 ? "ir lyklar" : "ur lykill"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Rangur lykill í ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Rangt gildi";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Rangt gildi í ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Rangt gildi`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function is_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error20()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/it.js
|
|||
|
|
var error21 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "caratteri", verb: "avere" },
|
|||
|
|
file: { unit: "byte", verb: "avere" },
|
|||
|
|
array: { unit: "elementi", verb: "avere" },
|
|||
|
|
set: { unit: "elementi", verb: "avere" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "input",
|
|||
|
|
email: "indirizzo email",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "data e ora ISO",
|
|||
|
|
date: "data ISO",
|
|||
|
|
time: "ora ISO",
|
|||
|
|
duration: "durata ISO",
|
|||
|
|
ipv4: "indirizzo IPv4",
|
|||
|
|
ipv6: "indirizzo IPv6",
|
|||
|
|
cidrv4: "intervallo IPv4",
|
|||
|
|
cidrv6: "intervallo IPv6",
|
|||
|
|
base64: "stringa codificata in base64",
|
|||
|
|
base64url: "URL codificata in base64",
|
|||
|
|
json_string: "stringa JSON",
|
|||
|
|
e164: "numero E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "input"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "numero",
|
|||
|
|
array: "vettore"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Input non valido: atteso instanceof ${issue2.expected}, ricevuto ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Input non valido: atteso ${expected}, ricevuto ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Input non valido: atteso ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Opzione non valida: atteso uno tra ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Troppo grande: ${issue2.origin ?? "valore"} deve avere ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elementi"}`;
|
|||
|
|
return `Troppo grande: ${issue2.origin ?? "valore"} deve essere ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Troppo piccolo: ${issue2.origin} deve avere ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Troppo piccolo: ${issue2.origin} deve essere ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Stringa non valida: deve iniziare con "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Stringa non valida: deve terminare con "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Stringa non valida: deve includere "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Stringa non valida: deve corrispondere al pattern ${_issue.pattern}`;
|
|||
|
|
return `Invalid ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Numero non valido: deve essere un multiplo di ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Chiav${issue2.keys.length > 1 ? "i" : "e"} non riconosciut${issue2.keys.length > 1 ? "e" : "a"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Chiave non valida in ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Input non valido";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Valore non valido in ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Input non valido`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function it_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error21()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ja.js
|
|||
|
|
var error22 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "文字", verb: "である" },
|
|||
|
|
file: { unit: "バイト", verb: "である" },
|
|||
|
|
array: { unit: "要素", verb: "である" },
|
|||
|
|
set: { unit: "要素", verb: "である" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "入力値",
|
|||
|
|
email: "メールアドレス",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "絵文字",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO日時",
|
|||
|
|
date: "ISO日付",
|
|||
|
|
time: "ISO時刻",
|
|||
|
|
duration: "ISO期間",
|
|||
|
|
ipv4: "IPv4アドレス",
|
|||
|
|
ipv6: "IPv6アドレス",
|
|||
|
|
cidrv4: "IPv4範囲",
|
|||
|
|
cidrv6: "IPv6範囲",
|
|||
|
|
base64: "base64エンコード文字列",
|
|||
|
|
base64url: "base64urlエンコード文字列",
|
|||
|
|
json_string: "JSON文字列",
|
|||
|
|
e164: "E.164番号",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "入力値"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "数値",
|
|||
|
|
array: "配列"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `無効な入力: instanceof ${issue2.expected}が期待されましたが、${received}が入力されました`;
|
|||
|
|
}
|
|||
|
|
return `無効な入力: ${expected}が期待されましたが、${received}が入力されました`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `無効な入力: ${stringifyPrimitive(issue2.values[0])}が期待されました`;
|
|||
|
|
return `無効な選択: ${joinValues(issue2.values, "、")}のいずれかである必要があります`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "以下である" : "より小さい";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `大きすぎる値: ${issue2.origin ?? "値"}は${issue2.maximum.toString()}${sizing.unit ?? "要素"}${adj}必要があります`;
|
|||
|
|
return `大きすぎる値: ${issue2.origin ?? "値"}は${issue2.maximum.toString()}${adj}必要があります`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? "以上である" : "より大きい";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `小さすぎる値: ${issue2.origin}は${issue2.minimum.toString()}${sizing.unit}${adj}必要があります`;
|
|||
|
|
return `小さすぎる値: ${issue2.origin}は${issue2.minimum.toString()}${adj}必要があります`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `無効な文字列: "${_issue.prefix}"で始まる必要があります`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `無効な文字列: "${_issue.suffix}"で終わる必要があります`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `無効な文字列: "${_issue.includes}"を含む必要があります`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `無効な文字列: パターン${_issue.pattern}に一致する必要があります`;
|
|||
|
|
return `無効な${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `無効な数値: ${issue2.divisor}の倍数である必要があります`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `認識されていないキー${issue2.keys.length > 1 ? "群" : ""}: ${joinValues(issue2.keys, "、")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `${issue2.origin}内の無効なキー`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "無効な入力";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `${issue2.origin}内の無効な値`;
|
|||
|
|
default:
|
|||
|
|
return `無効な入力`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ja_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error22()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ka.js
|
|||
|
|
var error23 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "სიმბოლო", verb: "უნდა შეიცავდეს" },
|
|||
|
|
file: { unit: "ბაიტი", verb: "უნდა შეიცავდეს" },
|
|||
|
|
array: { unit: "ელემენტი", verb: "უნდა შეიცავდეს" },
|
|||
|
|
set: { unit: "ელემენტი", verb: "უნდა შეიცავდეს" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "შეყვანა",
|
|||
|
|
email: "ელ-ფოსტის მისამართი",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "ემოჯი",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "თარიღი-დრო",
|
|||
|
|
date: "თარიღი",
|
|||
|
|
time: "დრო",
|
|||
|
|
duration: "ხანგრძლივობა",
|
|||
|
|
ipv4: "IPv4 მისამართი",
|
|||
|
|
ipv6: "IPv6 მისამართი",
|
|||
|
|
cidrv4: "IPv4 დიაპაზონი",
|
|||
|
|
cidrv6: "IPv6 დიაპაზონი",
|
|||
|
|
base64: "base64-კოდირებული სტრინგი",
|
|||
|
|
base64url: "base64url-კოდირებული სტრინგი",
|
|||
|
|
json_string: "JSON სტრინგი",
|
|||
|
|
e164: "E.164 ნომერი",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "შეყვანა"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "რიცხვი",
|
|||
|
|
string: "სტრინგი",
|
|||
|
|
boolean: "ბულეანი",
|
|||
|
|
function: "ფუნქცია",
|
|||
|
|
array: "მასივი"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `არასწორი შეყვანა: მოსალოდნელი instanceof ${issue2.expected}, მიღებული ${received}`;
|
|||
|
|
}
|
|||
|
|
return `არასწორი შეყვანა: მოსალოდნელი ${expected}, მიღებული ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `არასწორი შეყვანა: მოსალოდნელი ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `არასწორი ვარიანტი: მოსალოდნელია ერთ-ერთი ${joinValues(issue2.values, "|")}-დან`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `ზედმეტად დიდი: მოსალოდნელი ${issue2.origin ?? "მნიშვნელობა"} ${sizing.verb} ${adj}${issue2.maximum.toString()} ${sizing.unit}`;
|
|||
|
|
return `ზედმეტად დიდი: მოსალოდნელი ${issue2.origin ?? "მნიშვნელობა"} იყოს ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `ზედმეტად პატარა: მოსალოდნელი ${issue2.origin} ${sizing.verb} ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `ზედმეტად პატარა: მოსალოდნელი ${issue2.origin} იყოს ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `არასწორი სტრინგი: უნდა იწყებოდეს "${_issue.prefix}"-ით`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `არასწორი სტრინგი: უნდა მთავრდებოდეს "${_issue.suffix}"-ით`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `არასწორი სტრინგი: უნდა შეიცავდეს "${_issue.includes}"-ს`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `არასწორი სტრინგი: უნდა შეესაბამებოდეს შაბლონს ${_issue.pattern}`;
|
|||
|
|
return `არასწორი ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `არასწორი რიცხვი: უნდა იყოს ${issue2.divisor}-ის ჯერადი`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `უცნობი გასაღებ${issue2.keys.length > 1 ? "ები" : "ი"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `არასწორი გასაღები ${issue2.origin}-ში`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "არასწორი შეყვანა";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `არასწორი მნიშვნელობა ${issue2.origin}-ში`;
|
|||
|
|
default:
|
|||
|
|
return `არასწორი შეყვანა`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ka_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error23()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/km.js
|
|||
|
|
var error24 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "តួអក្សរ", verb: "គួរមាន" },
|
|||
|
|
file: { unit: "បៃ", verb: "គួរមាន" },
|
|||
|
|
array: { unit: "ធាតុ", verb: "គួរមាន" },
|
|||
|
|
set: { unit: "ធាតុ", verb: "គួរមាន" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "ទិន្នន័យបញ្ចូល",
|
|||
|
|
email: "អាសយដ្ឋានអ៊ីមែល",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "សញ្ញាអារម្មណ៍",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "កាលបរិច្ឆេទ និងម៉ោង ISO",
|
|||
|
|
date: "កាលបរិច្ឆេទ ISO",
|
|||
|
|
time: "ម៉ោង ISO",
|
|||
|
|
duration: "រយៈពេល ISO",
|
|||
|
|
ipv4: "អាសយដ្ឋាន IPv4",
|
|||
|
|
ipv6: "អាសយដ្ឋាន IPv6",
|
|||
|
|
cidrv4: "ដែនអាសយដ្ឋាន IPv4",
|
|||
|
|
cidrv6: "ដែនអាសយដ្ឋាន IPv6",
|
|||
|
|
base64: "ខ្សែអក្សរអ៊ិកូដ base64",
|
|||
|
|
base64url: "ខ្សែអក្សរអ៊ិកូដ base64url",
|
|||
|
|
json_string: "ខ្សែអក្សរ JSON",
|
|||
|
|
e164: "លេខ E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "ទិន្នន័យបញ្ចូល"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "លេខ",
|
|||
|
|
array: "អារេ (Array)",
|
|||
|
|
null: "គ្មានតម្លៃ (null)"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `ទិន្នន័យបញ្ចូលមិនត្រឹមត្រូវ៖ ត្រូវការ instanceof ${issue2.expected} ប៉ុន្តែទទួលបាន ${received}`;
|
|||
|
|
}
|
|||
|
|
return `ទិន្នន័យបញ្ចូលមិនត្រឹមត្រូវ៖ ត្រូវការ ${expected} ប៉ុន្តែទទួលបាន ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `ទិន្នន័យបញ្ចូលមិនត្រឹមត្រូវ៖ ត្រូវការ ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `ជម្រើសមិនត្រឹមត្រូវ៖ ត្រូវជាមួយក្នុងចំណោម ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `ធំពេក៖ ត្រូវការ ${issue2.origin ?? "តម្លៃ"} ${adj} ${issue2.maximum.toString()} ${sizing.unit ?? "ធាតុ"}`;
|
|||
|
|
return `ធំពេក៖ ត្រូវការ ${issue2.origin ?? "តម្លៃ"} ${adj} ${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `តូចពេក៖ ត្រូវការ ${issue2.origin} ${adj} ${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `តូចពេក៖ ត្រូវការ ${issue2.origin} ${adj} ${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `ខ្សែអក្សរមិនត្រឹមត្រូវ៖ ត្រូវចាប់ផ្តើមដោយ "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `ខ្សែអក្សរមិនត្រឹមត្រូវ៖ ត្រូវបញ្ចប់ដោយ "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `ខ្សែអក្សរមិនត្រឹមត្រូវ៖ ត្រូវមាន "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `ខ្សែអក្សរមិនត្រឹមត្រូវ៖ ត្រូវតែផ្គូផ្គងនឹងទម្រង់ដែលបានកំណត់ ${_issue.pattern}`;
|
|||
|
|
return `មិនត្រឹមត្រូវ៖ ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `លេខមិនត្រឹមត្រូវ៖ ត្រូវតែជាពហុគុណនៃ ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `រកឃើញសោមិនស្គាល់៖ ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `សោមិនត្រឹមត្រូវនៅក្នុង ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return `ទិន្នន័យមិនត្រឹមត្រូវ`;
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `ទិន្នន័យមិនត្រឹមត្រូវនៅក្នុង ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `ទិន្នន័យមិនត្រឹមត្រូវ`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function km_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error24()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/kh.js
|
|||
|
|
function kh_default() {
|
|||
|
|
return km_default();
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ko.js
|
|||
|
|
var error25 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "문자", verb: "to have" },
|
|||
|
|
file: { unit: "바이트", verb: "to have" },
|
|||
|
|
array: { unit: "개", verb: "to have" },
|
|||
|
|
set: { unit: "개", verb: "to have" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "입력",
|
|||
|
|
email: "이메일 주소",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "이모지",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO 날짜시간",
|
|||
|
|
date: "ISO 날짜",
|
|||
|
|
time: "ISO 시간",
|
|||
|
|
duration: "ISO 기간",
|
|||
|
|
ipv4: "IPv4 주소",
|
|||
|
|
ipv6: "IPv6 주소",
|
|||
|
|
cidrv4: "IPv4 범위",
|
|||
|
|
cidrv6: "IPv6 범위",
|
|||
|
|
base64: "base64 인코딩 문자열",
|
|||
|
|
base64url: "base64url 인코딩 문자열",
|
|||
|
|
json_string: "JSON 문자열",
|
|||
|
|
e164: "E.164 번호",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "입력"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `잘못된 입력: 예상 타입은 instanceof ${issue2.expected}, 받은 타입은 ${received}입니다`;
|
|||
|
|
}
|
|||
|
|
return `잘못된 입력: 예상 타입은 ${expected}, 받은 타입은 ${received}입니다`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `잘못된 입력: 값은 ${stringifyPrimitive(issue2.values[0])} 이어야 합니다`;
|
|||
|
|
return `잘못된 옵션: ${joinValues(issue2.values, "또는 ")} 중 하나여야 합니다`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "이하" : "미만";
|
|||
|
|
const suffix = adj === "미만" ? "이어야 합니다" : "여야 합니다";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const unit = sizing?.unit ?? "요소";
|
|||
|
|
if (sizing)
|
|||
|
|
return `${issue2.origin ?? "값"}이 너무 큽니다: ${issue2.maximum.toString()}${unit} ${adj}${suffix}`;
|
|||
|
|
return `${issue2.origin ?? "값"}이 너무 큽니다: ${issue2.maximum.toString()} ${adj}${suffix}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? "이상" : "초과";
|
|||
|
|
const suffix = adj === "이상" ? "이어야 합니다" : "여야 합니다";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const unit = sizing?.unit ?? "요소";
|
|||
|
|
if (sizing) {
|
|||
|
|
return `${issue2.origin ?? "값"}이 너무 작습니다: ${issue2.minimum.toString()}${unit} ${adj}${suffix}`;
|
|||
|
|
}
|
|||
|
|
return `${issue2.origin ?? "값"}이 너무 작습니다: ${issue2.minimum.toString()} ${adj}${suffix}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `잘못된 문자열: "${_issue.prefix}"(으)로 시작해야 합니다`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `잘못된 문자열: "${_issue.suffix}"(으)로 끝나야 합니다`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `잘못된 문자열: "${_issue.includes}"을(를) 포함해야 합니다`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `잘못된 문자열: 정규식 ${_issue.pattern} 패턴과 일치해야 합니다`;
|
|||
|
|
return `잘못된 ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `잘못된 숫자: ${issue2.divisor}의 배수여야 합니다`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `인식할 수 없는 키: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `잘못된 키: ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return `잘못된 입력`;
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `잘못된 값: ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `잘못된 입력`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ko_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error25()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/lt.js
|
|||
|
|
var capitalizeFirstCharacter = (text) => {
|
|||
|
|
return text.charAt(0).toUpperCase() + text.slice(1);
|
|||
|
|
};
|
|||
|
|
function getUnitTypeFromNumber(number4) {
|
|||
|
|
const abs = Math.abs(number4);
|
|||
|
|
const last = abs % 10;
|
|||
|
|
const last2 = abs % 100;
|
|||
|
|
if (last2 >= 11 && last2 <= 19 || last === 0)
|
|||
|
|
return "many";
|
|||
|
|
if (last === 1)
|
|||
|
|
return "one";
|
|||
|
|
return "few";
|
|||
|
|
}
|
|||
|
|
var error26 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: {
|
|||
|
|
unit: {
|
|||
|
|
one: "simbolis",
|
|||
|
|
few: "simboliai",
|
|||
|
|
many: "simbolių"
|
|||
|
|
},
|
|||
|
|
verb: {
|
|||
|
|
smaller: {
|
|||
|
|
inclusive: "turi būti ne ilgesnė kaip",
|
|||
|
|
notInclusive: "turi būti trumpesnė kaip"
|
|||
|
|
},
|
|||
|
|
bigger: {
|
|||
|
|
inclusive: "turi būti ne trumpesnė kaip",
|
|||
|
|
notInclusive: "turi būti ilgesnė kaip"
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
file: {
|
|||
|
|
unit: {
|
|||
|
|
one: "baitas",
|
|||
|
|
few: "baitai",
|
|||
|
|
many: "baitų"
|
|||
|
|
},
|
|||
|
|
verb: {
|
|||
|
|
smaller: {
|
|||
|
|
inclusive: "turi būti ne didesnis kaip",
|
|||
|
|
notInclusive: "turi būti mažesnis kaip"
|
|||
|
|
},
|
|||
|
|
bigger: {
|
|||
|
|
inclusive: "turi būti ne mažesnis kaip",
|
|||
|
|
notInclusive: "turi būti didesnis kaip"
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
array: {
|
|||
|
|
unit: {
|
|||
|
|
one: "elementą",
|
|||
|
|
few: "elementus",
|
|||
|
|
many: "elementų"
|
|||
|
|
},
|
|||
|
|
verb: {
|
|||
|
|
smaller: {
|
|||
|
|
inclusive: "turi turėti ne daugiau kaip",
|
|||
|
|
notInclusive: "turi turėti mažiau kaip"
|
|||
|
|
},
|
|||
|
|
bigger: {
|
|||
|
|
inclusive: "turi turėti ne mažiau kaip",
|
|||
|
|
notInclusive: "turi turėti daugiau kaip"
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
set: {
|
|||
|
|
unit: {
|
|||
|
|
one: "elementą",
|
|||
|
|
few: "elementus",
|
|||
|
|
many: "elementų"
|
|||
|
|
},
|
|||
|
|
verb: {
|
|||
|
|
smaller: {
|
|||
|
|
inclusive: "turi turėti ne daugiau kaip",
|
|||
|
|
notInclusive: "turi turėti mažiau kaip"
|
|||
|
|
},
|
|||
|
|
bigger: {
|
|||
|
|
inclusive: "turi turėti ne mažiau kaip",
|
|||
|
|
notInclusive: "turi turėti daugiau kaip"
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
function getSizing(origin, unitType, inclusive, targetShouldBe) {
|
|||
|
|
const result = Sizable[origin] ?? null;
|
|||
|
|
if (result === null)
|
|||
|
|
return result;
|
|||
|
|
return {
|
|||
|
|
unit: result.unit[unitType],
|
|||
|
|
verb: result.verb[targetShouldBe][inclusive ? "inclusive" : "notInclusive"]
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "įvestis",
|
|||
|
|
email: "el. pašto adresas",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "jaustukas",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO data ir laikas",
|
|||
|
|
date: "ISO data",
|
|||
|
|
time: "ISO laikas",
|
|||
|
|
duration: "ISO trukmė",
|
|||
|
|
ipv4: "IPv4 adresas",
|
|||
|
|
ipv6: "IPv6 adresas",
|
|||
|
|
cidrv4: "IPv4 tinklo prefiksas (CIDR)",
|
|||
|
|
cidrv6: "IPv6 tinklo prefiksas (CIDR)",
|
|||
|
|
base64: "base64 užkoduota eilutė",
|
|||
|
|
base64url: "base64url užkoduota eilutė",
|
|||
|
|
json_string: "JSON eilutė",
|
|||
|
|
e164: "E.164 numeris",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "įvestis"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "skaičius",
|
|||
|
|
bigint: "sveikasis skaičius",
|
|||
|
|
string: "eilutė",
|
|||
|
|
boolean: "loginė reikšmė",
|
|||
|
|
undefined: "neapibrėžta reikšmė",
|
|||
|
|
function: "funkcija",
|
|||
|
|
symbol: "simbolis",
|
|||
|
|
array: "masyvas",
|
|||
|
|
object: "objektas",
|
|||
|
|
null: "nulinė reikšmė"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Gautas tipas ${received}, o tikėtasi - instanceof ${issue2.expected}`;
|
|||
|
|
}
|
|||
|
|
return `Gautas tipas ${received}, o tikėtasi - ${expected}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Privalo būti ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Privalo būti vienas iš ${joinValues(issue2.values, "|")} pasirinkimų`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const origin = TypeDictionary[issue2.origin] ?? issue2.origin;
|
|||
|
|
const sizing = getSizing(issue2.origin, getUnitTypeFromNumber(Number(issue2.maximum)), issue2.inclusive ?? false, "smaller");
|
|||
|
|
if (sizing?.verb)
|
|||
|
|
return `${capitalizeFirstCharacter(origin ?? issue2.origin ?? "reikšmė")} ${sizing.verb} ${issue2.maximum.toString()} ${sizing.unit ?? "elementų"}`;
|
|||
|
|
const adj = issue2.inclusive ? "ne didesnis kaip" : "mažesnis kaip";
|
|||
|
|
return `${capitalizeFirstCharacter(origin ?? issue2.origin ?? "reikšmė")} turi būti ${adj} ${issue2.maximum.toString()} ${sizing?.unit}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const origin = TypeDictionary[issue2.origin] ?? issue2.origin;
|
|||
|
|
const sizing = getSizing(issue2.origin, getUnitTypeFromNumber(Number(issue2.minimum)), issue2.inclusive ?? false, "bigger");
|
|||
|
|
if (sizing?.verb)
|
|||
|
|
return `${capitalizeFirstCharacter(origin ?? issue2.origin ?? "reikšmė")} ${sizing.verb} ${issue2.minimum.toString()} ${sizing.unit ?? "elementų"}`;
|
|||
|
|
const adj = issue2.inclusive ? "ne mažesnis kaip" : "didesnis kaip";
|
|||
|
|
return `${capitalizeFirstCharacter(origin ?? issue2.origin ?? "reikšmė")} turi būti ${adj} ${issue2.minimum.toString()} ${sizing?.unit}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Eilutė privalo prasidėti "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Eilutė privalo pasibaigti "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Eilutė privalo įtraukti "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Eilutė privalo atitikti ${_issue.pattern}`;
|
|||
|
|
return `Neteisingas ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Skaičius privalo būti ${issue2.divisor} kartotinis.`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Neatpažint${issue2.keys.length > 1 ? "i" : "as"} rakt${issue2.keys.length > 1 ? "ai" : "as"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return "Rastas klaidingas raktas";
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Klaidinga įvestis";
|
|||
|
|
case "invalid_element": {
|
|||
|
|
const origin = TypeDictionary[issue2.origin] ?? issue2.origin;
|
|||
|
|
return `${capitalizeFirstCharacter(origin ?? issue2.origin ?? "reikšmė")} turi klaidingą įvestį`;
|
|||
|
|
}
|
|||
|
|
default:
|
|||
|
|
return "Klaidinga įvestis";
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function lt_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error26()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/mk.js
|
|||
|
|
var error27 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "знаци", verb: "да имаат" },
|
|||
|
|
file: { unit: "бајти", verb: "да имаат" },
|
|||
|
|
array: { unit: "ставки", verb: "да имаат" },
|
|||
|
|
set: { unit: "ставки", verb: "да имаат" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "внес",
|
|||
|
|
email: "адреса на е-пошта",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "емоџи",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO датум и време",
|
|||
|
|
date: "ISO датум",
|
|||
|
|
time: "ISO време",
|
|||
|
|
duration: "ISO времетраење",
|
|||
|
|
ipv4: "IPv4 адреса",
|
|||
|
|
ipv6: "IPv6 адреса",
|
|||
|
|
cidrv4: "IPv4 опсег",
|
|||
|
|
cidrv6: "IPv6 опсег",
|
|||
|
|
base64: "base64-енкодирана низа",
|
|||
|
|
base64url: "base64url-енкодирана низа",
|
|||
|
|
json_string: "JSON низа",
|
|||
|
|
e164: "E.164 број",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "внес"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "број",
|
|||
|
|
array: "низа"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Грешен внес: се очекува instanceof ${issue2.expected}, примено ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Грешен внес: се очекува ${expected}, примено ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Invalid input: expected ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Грешана опција: се очекува една ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Премногу голем: се очекува ${issue2.origin ?? "вредноста"} да има ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "елементи"}`;
|
|||
|
|
return `Премногу голем: се очекува ${issue2.origin ?? "вредноста"} да биде ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Премногу мал: се очекува ${issue2.origin} да има ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Премногу мал: се очекува ${issue2.origin} да биде ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Неважечка низа: мора да започнува со "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Неважечка низа: мора да завршува со "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Неважечка низа: мора да вклучува "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Неважечка низа: мора да одгоара на патернот ${_issue.pattern}`;
|
|||
|
|
return `Invalid ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Грешен број: мора да биде делив со ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `${issue2.keys.length > 1 ? "Непрепознаени клучеви" : "Непрепознаен клуч"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Грешен клуч во ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Грешен внес";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Грешна вредност во ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Грешен внес`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function mk_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error27()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ms.js
|
|||
|
|
var error28 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "aksara", verb: "mempunyai" },
|
|||
|
|
file: { unit: "bait", verb: "mempunyai" },
|
|||
|
|
array: { unit: "elemen", verb: "mempunyai" },
|
|||
|
|
set: { unit: "elemen", verb: "mempunyai" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "input",
|
|||
|
|
email: "alamat e-mel",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "tarikh masa ISO",
|
|||
|
|
date: "tarikh ISO",
|
|||
|
|
time: "masa ISO",
|
|||
|
|
duration: "tempoh ISO",
|
|||
|
|
ipv4: "alamat IPv4",
|
|||
|
|
ipv6: "alamat IPv6",
|
|||
|
|
cidrv4: "julat IPv4",
|
|||
|
|
cidrv6: "julat IPv6",
|
|||
|
|
base64: "string dikodkan base64",
|
|||
|
|
base64url: "string dikodkan base64url",
|
|||
|
|
json_string: "string JSON",
|
|||
|
|
e164: "nombor E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "input"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "nombor"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Input tidak sah: dijangka instanceof ${issue2.expected}, diterima ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Input tidak sah: dijangka ${expected}, diterima ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Input tidak sah: dijangka ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Pilihan tidak sah: dijangka salah satu daripada ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Terlalu besar: dijangka ${issue2.origin ?? "nilai"} ${sizing.verb} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elemen"}`;
|
|||
|
|
return `Terlalu besar: dijangka ${issue2.origin ?? "nilai"} adalah ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Terlalu kecil: dijangka ${issue2.origin} ${sizing.verb} ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Terlalu kecil: dijangka ${issue2.origin} adalah ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `String tidak sah: mesti bermula dengan "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `String tidak sah: mesti berakhir dengan "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `String tidak sah: mesti mengandungi "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `String tidak sah: mesti sepadan dengan corak ${_issue.pattern}`;
|
|||
|
|
return `${FormatDictionary[_issue.format] ?? issue2.format} tidak sah`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Nombor tidak sah: perlu gandaan ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Kunci tidak dikenali: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Kunci tidak sah dalam ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Input tidak sah";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Nilai tidak sah dalam ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Input tidak sah`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ms_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error28()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/nl.js
|
|||
|
|
var error29 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "tekens", verb: "heeft" },
|
|||
|
|
file: { unit: "bytes", verb: "heeft" },
|
|||
|
|
array: { unit: "elementen", verb: "heeft" },
|
|||
|
|
set: { unit: "elementen", verb: "heeft" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "invoer",
|
|||
|
|
email: "emailadres",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO datum en tijd",
|
|||
|
|
date: "ISO datum",
|
|||
|
|
time: "ISO tijd",
|
|||
|
|
duration: "ISO duur",
|
|||
|
|
ipv4: "IPv4-adres",
|
|||
|
|
ipv6: "IPv6-adres",
|
|||
|
|
cidrv4: "IPv4-bereik",
|
|||
|
|
cidrv6: "IPv6-bereik",
|
|||
|
|
base64: "base64-gecodeerde tekst",
|
|||
|
|
base64url: "base64 URL-gecodeerde tekst",
|
|||
|
|
json_string: "JSON string",
|
|||
|
|
e164: "E.164-nummer",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "invoer"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "getal"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Ongeldige invoer: verwacht instanceof ${issue2.expected}, ontving ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Ongeldige invoer: verwacht ${expected}, ontving ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Ongeldige invoer: verwacht ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Ongeldige optie: verwacht één van ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const longName = issue2.origin === "date" ? "laat" : issue2.origin === "string" ? "lang" : "groot";
|
|||
|
|
if (sizing)
|
|||
|
|
return `Te ${longName}: verwacht dat ${issue2.origin ?? "waarde"} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elementen"} ${sizing.verb}`;
|
|||
|
|
return `Te ${longName}: verwacht dat ${issue2.origin ?? "waarde"} ${adj}${issue2.maximum.toString()} is`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
const shortName = issue2.origin === "date" ? "vroeg" : issue2.origin === "string" ? "kort" : "klein";
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Te ${shortName}: verwacht dat ${issue2.origin} ${adj}${issue2.minimum.toString()} ${sizing.unit} ${sizing.verb}`;
|
|||
|
|
}
|
|||
|
|
return `Te ${shortName}: verwacht dat ${issue2.origin} ${adj}${issue2.minimum.toString()} is`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Ongeldige tekst: moet met "${_issue.prefix}" beginnen`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Ongeldige tekst: moet op "${_issue.suffix}" eindigen`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Ongeldige tekst: moet "${_issue.includes}" bevatten`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Ongeldige tekst: moet overeenkomen met patroon ${_issue.pattern}`;
|
|||
|
|
return `Ongeldig: ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Ongeldig getal: moet een veelvoud van ${issue2.divisor} zijn`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Onbekende key${issue2.keys.length > 1 ? "s" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Ongeldige key in ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Ongeldige invoer";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Ongeldige waarde in ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Ongeldige invoer`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function nl_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error29()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/no.js
|
|||
|
|
var error30 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "tegn", verb: "å ha" },
|
|||
|
|
file: { unit: "bytes", verb: "å ha" },
|
|||
|
|
array: { unit: "elementer", verb: "å inneholde" },
|
|||
|
|
set: { unit: "elementer", verb: "å inneholde" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "input",
|
|||
|
|
email: "e-postadresse",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO dato- og klokkeslett",
|
|||
|
|
date: "ISO-dato",
|
|||
|
|
time: "ISO-klokkeslett",
|
|||
|
|
duration: "ISO-varighet",
|
|||
|
|
ipv4: "IPv4-område",
|
|||
|
|
ipv6: "IPv6-område",
|
|||
|
|
cidrv4: "IPv4-spekter",
|
|||
|
|
cidrv6: "IPv6-spekter",
|
|||
|
|
base64: "base64-enkodet streng",
|
|||
|
|
base64url: "base64url-enkodet streng",
|
|||
|
|
json_string: "JSON-streng",
|
|||
|
|
e164: "E.164-nummer",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "input"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "tall",
|
|||
|
|
array: "liste"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Ugyldig input: forventet instanceof ${issue2.expected}, fikk ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Ugyldig input: forventet ${expected}, fikk ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Ugyldig verdi: forventet ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Ugyldig valg: forventet en av ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `For stor(t): forventet ${issue2.origin ?? "value"} til å ha ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elementer"}`;
|
|||
|
|
return `For stor(t): forventet ${issue2.origin ?? "value"} til å ha ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `For lite(n): forventet ${issue2.origin} til å ha ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `For lite(n): forventet ${issue2.origin} til å ha ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Ugyldig streng: må starte med "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Ugyldig streng: må ende med "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Ugyldig streng: må inneholde "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Ugyldig streng: må matche mønsteret ${_issue.pattern}`;
|
|||
|
|
return `Ugyldig ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Ugyldig tall: må være et multiplum av ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `${issue2.keys.length > 1 ? "Ukjente nøkler" : "Ukjent nøkkel"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Ugyldig nøkkel i ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Ugyldig input";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Ugyldig verdi i ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Ugyldig input`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function no_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error30()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ota.js
|
|||
|
|
var error31 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "harf", verb: "olmalıdır" },
|
|||
|
|
file: { unit: "bayt", verb: "olmalıdır" },
|
|||
|
|
array: { unit: "unsur", verb: "olmalıdır" },
|
|||
|
|
set: { unit: "unsur", verb: "olmalıdır" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "giren",
|
|||
|
|
email: "epostagâh",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO hengâmı",
|
|||
|
|
date: "ISO tarihi",
|
|||
|
|
time: "ISO zamanı",
|
|||
|
|
duration: "ISO müddeti",
|
|||
|
|
ipv4: "IPv4 nişânı",
|
|||
|
|
ipv6: "IPv6 nişânı",
|
|||
|
|
cidrv4: "IPv4 menzili",
|
|||
|
|
cidrv6: "IPv6 menzili",
|
|||
|
|
base64: "base64-şifreli metin",
|
|||
|
|
base64url: "base64url-şifreli metin",
|
|||
|
|
json_string: "JSON metin",
|
|||
|
|
e164: "E.164 sayısı",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "giren"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "numara",
|
|||
|
|
array: "saf",
|
|||
|
|
null: "gayb"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Fâsit giren: umulan instanceof ${issue2.expected}, alınan ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Fâsit giren: umulan ${expected}, alınan ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Fâsit giren: umulan ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Fâsit tercih: mûteberler ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Fazla büyük: ${issue2.origin ?? "value"}, ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elements"} sahip olmalıydı.`;
|
|||
|
|
return `Fazla büyük: ${issue2.origin ?? "value"}, ${adj}${issue2.maximum.toString()} olmalıydı.`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Fazla küçük: ${issue2.origin}, ${adj}${issue2.minimum.toString()} ${sizing.unit} sahip olmalıydı.`;
|
|||
|
|
}
|
|||
|
|
return `Fazla küçük: ${issue2.origin}, ${adj}${issue2.minimum.toString()} olmalıydı.`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Fâsit metin: "${_issue.prefix}" ile başlamalı.`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Fâsit metin: "${_issue.suffix}" ile bitmeli.`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Fâsit metin: "${_issue.includes}" ihtivâ etmeli.`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Fâsit metin: ${_issue.pattern} nakşına uymalı.`;
|
|||
|
|
return `Fâsit ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Fâsit sayı: ${issue2.divisor} katı olmalıydı.`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Tanınmayan anahtar ${issue2.keys.length > 1 ? "s" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `${issue2.origin} için tanınmayan anahtar var.`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Giren tanınamadı.";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `${issue2.origin} için tanınmayan kıymet var.`;
|
|||
|
|
default:
|
|||
|
|
return `Kıymet tanınamadı.`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ota_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error31()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ps.js
|
|||
|
|
var error32 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "توکي", verb: "ولري" },
|
|||
|
|
file: { unit: "بایټس", verb: "ولري" },
|
|||
|
|
array: { unit: "توکي", verb: "ولري" },
|
|||
|
|
set: { unit: "توکي", verb: "ولري" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "ورودي",
|
|||
|
|
email: "بریښنالیک",
|
|||
|
|
url: "یو آر ال",
|
|||
|
|
emoji: "ایموجي",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "نیټه او وخت",
|
|||
|
|
date: "نېټه",
|
|||
|
|
time: "وخت",
|
|||
|
|
duration: "موده",
|
|||
|
|
ipv4: "د IPv4 پته",
|
|||
|
|
ipv6: "د IPv6 پته",
|
|||
|
|
cidrv4: "د IPv4 ساحه",
|
|||
|
|
cidrv6: "د IPv6 ساحه",
|
|||
|
|
base64: "base64-encoded متن",
|
|||
|
|
base64url: "base64url-encoded متن",
|
|||
|
|
json_string: "JSON متن",
|
|||
|
|
e164: "د E.164 شمېره",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "ورودي"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "عدد",
|
|||
|
|
array: "ارې"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `ناسم ورودي: باید instanceof ${issue2.expected} وای, مګر ${received} ترلاسه شو`;
|
|||
|
|
}
|
|||
|
|
return `ناسم ورودي: باید ${expected} وای, مګر ${received} ترلاسه شو`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1) {
|
|||
|
|
return `ناسم ورودي: باید ${stringifyPrimitive(issue2.values[0])} وای`;
|
|||
|
|
}
|
|||
|
|
return `ناسم انتخاب: باید یو له ${joinValues(issue2.values, "|")} څخه وای`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `ډیر لوی: ${issue2.origin ?? "ارزښت"} باید ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "عنصرونه"} ولري`;
|
|||
|
|
}
|
|||
|
|
return `ډیر لوی: ${issue2.origin ?? "ارزښت"} باید ${adj}${issue2.maximum.toString()} وي`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `ډیر کوچنی: ${issue2.origin} باید ${adj}${issue2.minimum.toString()} ${sizing.unit} ولري`;
|
|||
|
|
}
|
|||
|
|
return `ډیر کوچنی: ${issue2.origin} باید ${adj}${issue2.minimum.toString()} وي`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `ناسم متن: باید د "${_issue.prefix}" سره پیل شي`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with") {
|
|||
|
|
return `ناسم متن: باید د "${_issue.suffix}" سره پای ته ورسيږي`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "includes") {
|
|||
|
|
return `ناسم متن: باید "${_issue.includes}" ولري`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "regex") {
|
|||
|
|
return `ناسم متن: باید د ${_issue.pattern} سره مطابقت ولري`;
|
|||
|
|
}
|
|||
|
|
return `${FormatDictionary[_issue.format] ?? issue2.format} ناسم دی`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `ناسم عدد: باید د ${issue2.divisor} مضرب وي`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `ناسم ${issue2.keys.length > 1 ? "کلیډونه" : "کلیډ"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `ناسم کلیډ په ${issue2.origin} کې`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return `ناسمه ورودي`;
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `ناسم عنصر په ${issue2.origin} کې`;
|
|||
|
|
default:
|
|||
|
|
return `ناسمه ورودي`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ps_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error32()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/pl.js
|
|||
|
|
var error33 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "znaków", verb: "mieć" },
|
|||
|
|
file: { unit: "bajtów", verb: "mieć" },
|
|||
|
|
array: { unit: "elementów", verb: "mieć" },
|
|||
|
|
set: { unit: "elementów", verb: "mieć" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "wyrażenie",
|
|||
|
|
email: "adres email",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "data i godzina w formacie ISO",
|
|||
|
|
date: "data w formacie ISO",
|
|||
|
|
time: "godzina w formacie ISO",
|
|||
|
|
duration: "czas trwania ISO",
|
|||
|
|
ipv4: "adres IPv4",
|
|||
|
|
ipv6: "adres IPv6",
|
|||
|
|
cidrv4: "zakres IPv4",
|
|||
|
|
cidrv6: "zakres IPv6",
|
|||
|
|
base64: "ciąg znaków zakodowany w formacie base64",
|
|||
|
|
base64url: "ciąg znaków zakodowany w formacie base64url",
|
|||
|
|
json_string: "ciąg znaków w formacie JSON",
|
|||
|
|
e164: "liczba E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "wejście"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "liczba",
|
|||
|
|
array: "tablica"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Nieprawidłowe dane wejściowe: oczekiwano instanceof ${issue2.expected}, otrzymano ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Nieprawidłowe dane wejściowe: oczekiwano ${expected}, otrzymano ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Nieprawidłowe dane wejściowe: oczekiwano ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Nieprawidłowa opcja: oczekiwano jednej z wartości ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Za duża wartość: oczekiwano, że ${issue2.origin ?? "wartość"} będzie mieć ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elementów"}`;
|
|||
|
|
}
|
|||
|
|
return `Zbyt duż(y/a/e): oczekiwano, że ${issue2.origin ?? "wartość"} będzie wynosić ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Za mała wartość: oczekiwano, że ${issue2.origin ?? "wartość"} będzie mieć ${adj}${issue2.minimum.toString()} ${sizing.unit ?? "elementów"}`;
|
|||
|
|
}
|
|||
|
|
return `Zbyt mał(y/a/e): oczekiwano, że ${issue2.origin ?? "wartość"} będzie wynosić ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Nieprawidłowy ciąg znaków: musi zaczynać się od "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Nieprawidłowy ciąg znaków: musi kończyć się na "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Nieprawidłowy ciąg znaków: musi zawierać "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Nieprawidłowy ciąg znaków: musi odpowiadać wzorcowi ${_issue.pattern}`;
|
|||
|
|
return `Nieprawidłow(y/a/e) ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Nieprawidłowa liczba: musi być wielokrotnością ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Nierozpoznane klucze${issue2.keys.length > 1 ? "s" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Nieprawidłowy klucz w ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Nieprawidłowe dane wejściowe";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Nieprawidłowa wartość w ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Nieprawidłowe dane wejściowe`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function pl_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error33()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/pt.js
|
|||
|
|
var error34 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "caracteres", verb: "ter" },
|
|||
|
|
file: { unit: "bytes", verb: "ter" },
|
|||
|
|
array: { unit: "itens", verb: "ter" },
|
|||
|
|
set: { unit: "itens", verb: "ter" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "padrão",
|
|||
|
|
email: "endereço de e-mail",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "data e hora ISO",
|
|||
|
|
date: "data ISO",
|
|||
|
|
time: "hora ISO",
|
|||
|
|
duration: "duração ISO",
|
|||
|
|
ipv4: "endereço IPv4",
|
|||
|
|
ipv6: "endereço IPv6",
|
|||
|
|
cidrv4: "faixa de IPv4",
|
|||
|
|
cidrv6: "faixa de IPv6",
|
|||
|
|
base64: "texto codificado em base64",
|
|||
|
|
base64url: "URL codificada em base64",
|
|||
|
|
json_string: "texto JSON",
|
|||
|
|
e164: "número E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "entrada"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "número",
|
|||
|
|
null: "nulo"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Tipo inválido: esperado instanceof ${issue2.expected}, recebido ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Tipo inválido: esperado ${expected}, recebido ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Entrada inválida: esperado ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Opção inválida: esperada uma das ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Muito grande: esperado que ${issue2.origin ?? "valor"} tivesse ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elementos"}`;
|
|||
|
|
return `Muito grande: esperado que ${issue2.origin ?? "valor"} fosse ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Muito pequeno: esperado que ${issue2.origin} tivesse ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Muito pequeno: esperado que ${issue2.origin} fosse ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Texto inválido: deve começar com "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Texto inválido: deve terminar com "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Texto inválido: deve incluir "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Texto inválido: deve corresponder ao padrão ${_issue.pattern}`;
|
|||
|
|
return `${FormatDictionary[_issue.format] ?? issue2.format} inválido`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Número inválido: deve ser múltiplo de ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Chave${issue2.keys.length > 1 ? "s" : ""} desconhecida${issue2.keys.length > 1 ? "s" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Chave inválida em ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Entrada inválida";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Valor inválido em ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Campo inválido`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function pt_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error34()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ru.js
|
|||
|
|
function getRussianPlural(count, one, few, many) {
|
|||
|
|
const absCount = Math.abs(count);
|
|||
|
|
const lastDigit = absCount % 10;
|
|||
|
|
const lastTwoDigits = absCount % 100;
|
|||
|
|
if (lastTwoDigits >= 11 && lastTwoDigits <= 19) {
|
|||
|
|
return many;
|
|||
|
|
}
|
|||
|
|
if (lastDigit === 1) {
|
|||
|
|
return one;
|
|||
|
|
}
|
|||
|
|
if (lastDigit >= 2 && lastDigit <= 4) {
|
|||
|
|
return few;
|
|||
|
|
}
|
|||
|
|
return many;
|
|||
|
|
}
|
|||
|
|
var error35 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: {
|
|||
|
|
unit: {
|
|||
|
|
one: "символ",
|
|||
|
|
few: "символа",
|
|||
|
|
many: "символов"
|
|||
|
|
},
|
|||
|
|
verb: "иметь"
|
|||
|
|
},
|
|||
|
|
file: {
|
|||
|
|
unit: {
|
|||
|
|
one: "байт",
|
|||
|
|
few: "байта",
|
|||
|
|
many: "байт"
|
|||
|
|
},
|
|||
|
|
verb: "иметь"
|
|||
|
|
},
|
|||
|
|
array: {
|
|||
|
|
unit: {
|
|||
|
|
one: "элемент",
|
|||
|
|
few: "элемента",
|
|||
|
|
many: "элементов"
|
|||
|
|
},
|
|||
|
|
verb: "иметь"
|
|||
|
|
},
|
|||
|
|
set: {
|
|||
|
|
unit: {
|
|||
|
|
one: "элемент",
|
|||
|
|
few: "элемента",
|
|||
|
|
many: "элементов"
|
|||
|
|
},
|
|||
|
|
verb: "иметь"
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "ввод",
|
|||
|
|
email: "email адрес",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "эмодзи",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO дата и время",
|
|||
|
|
date: "ISO дата",
|
|||
|
|
time: "ISO время",
|
|||
|
|
duration: "ISO длительность",
|
|||
|
|
ipv4: "IPv4 адрес",
|
|||
|
|
ipv6: "IPv6 адрес",
|
|||
|
|
cidrv4: "IPv4 диапазон",
|
|||
|
|
cidrv6: "IPv6 диапазон",
|
|||
|
|
base64: "строка в формате base64",
|
|||
|
|
base64url: "строка в формате base64url",
|
|||
|
|
json_string: "JSON строка",
|
|||
|
|
e164: "номер E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "ввод"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "число",
|
|||
|
|
array: "массив"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Неверный ввод: ожидалось instanceof ${issue2.expected}, получено ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Неверный ввод: ожидалось ${expected}, получено ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Неверный ввод: ожидалось ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Неверный вариант: ожидалось одно из ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
const maxValue = Number(issue2.maximum);
|
|||
|
|
const unit = getRussianPlural(maxValue, sizing.unit.one, sizing.unit.few, sizing.unit.many);
|
|||
|
|
return `Слишком большое значение: ожидалось, что ${issue2.origin ?? "значение"} будет иметь ${adj}${issue2.maximum.toString()} ${unit}`;
|
|||
|
|
}
|
|||
|
|
return `Слишком большое значение: ожидалось, что ${issue2.origin ?? "значение"} будет ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
const minValue = Number(issue2.minimum);
|
|||
|
|
const unit = getRussianPlural(minValue, sizing.unit.one, sizing.unit.few, sizing.unit.many);
|
|||
|
|
return `Слишком маленькое значение: ожидалось, что ${issue2.origin} будет иметь ${adj}${issue2.minimum.toString()} ${unit}`;
|
|||
|
|
}
|
|||
|
|
return `Слишком маленькое значение: ожидалось, что ${issue2.origin} будет ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Неверная строка: должна начинаться с "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Неверная строка: должна заканчиваться на "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Неверная строка: должна содержать "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Неверная строка: должна соответствовать шаблону ${_issue.pattern}`;
|
|||
|
|
return `Неверный ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Неверное число: должно быть кратным ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Нераспознанн${issue2.keys.length > 1 ? "ые" : "ый"} ключ${issue2.keys.length > 1 ? "и" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Неверный ключ в ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Неверные входные данные";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Неверное значение в ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Неверные входные данные`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ru_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error35()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/sl.js
|
|||
|
|
var error36 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "znakov", verb: "imeti" },
|
|||
|
|
file: { unit: "bajtov", verb: "imeti" },
|
|||
|
|
array: { unit: "elementov", verb: "imeti" },
|
|||
|
|
set: { unit: "elementov", verb: "imeti" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "vnos",
|
|||
|
|
email: "e-poštni naslov",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO datum in čas",
|
|||
|
|
date: "ISO datum",
|
|||
|
|
time: "ISO čas",
|
|||
|
|
duration: "ISO trajanje",
|
|||
|
|
ipv4: "IPv4 naslov",
|
|||
|
|
ipv6: "IPv6 naslov",
|
|||
|
|
cidrv4: "obseg IPv4",
|
|||
|
|
cidrv6: "obseg IPv6",
|
|||
|
|
base64: "base64 kodiran niz",
|
|||
|
|
base64url: "base64url kodiran niz",
|
|||
|
|
json_string: "JSON niz",
|
|||
|
|
e164: "E.164 številka",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "vnos"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "število",
|
|||
|
|
array: "tabela"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Neveljaven vnos: pričakovano instanceof ${issue2.expected}, prejeto ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Neveljaven vnos: pričakovano ${expected}, prejeto ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Neveljaven vnos: pričakovano ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Neveljavna možnost: pričakovano eno izmed ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Preveliko: pričakovano, da bo ${issue2.origin ?? "vrednost"} imelo ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "elementov"}`;
|
|||
|
|
return `Preveliko: pričakovano, da bo ${issue2.origin ?? "vrednost"} ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Premajhno: pričakovano, da bo ${issue2.origin} imelo ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Premajhno: pričakovano, da bo ${issue2.origin} ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Neveljaven niz: mora se začeti z "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Neveljaven niz: mora se končati z "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Neveljaven niz: mora vsebovati "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Neveljaven niz: mora ustrezati vzorcu ${_issue.pattern}`;
|
|||
|
|
return `Neveljaven ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Neveljavno število: mora biti večkratnik ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Neprepoznan${issue2.keys.length > 1 ? "i ključi" : " ključ"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Neveljaven ključ v ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Neveljaven vnos";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Neveljavna vrednost v ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return "Neveljaven vnos";
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function sl_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error36()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/sv.js
|
|||
|
|
var error37 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "tecken", verb: "att ha" },
|
|||
|
|
file: { unit: "bytes", verb: "att ha" },
|
|||
|
|
array: { unit: "objekt", verb: "att innehålla" },
|
|||
|
|
set: { unit: "objekt", verb: "att innehålla" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "reguljärt uttryck",
|
|||
|
|
email: "e-postadress",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO-datum och tid",
|
|||
|
|
date: "ISO-datum",
|
|||
|
|
time: "ISO-tid",
|
|||
|
|
duration: "ISO-varaktighet",
|
|||
|
|
ipv4: "IPv4-intervall",
|
|||
|
|
ipv6: "IPv6-intervall",
|
|||
|
|
cidrv4: "IPv4-spektrum",
|
|||
|
|
cidrv6: "IPv6-spektrum",
|
|||
|
|
base64: "base64-kodad sträng",
|
|||
|
|
base64url: "base64url-kodad sträng",
|
|||
|
|
json_string: "JSON-sträng",
|
|||
|
|
e164: "E.164-nummer",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "mall-literal"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "antal",
|
|||
|
|
array: "lista"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Ogiltig inmatning: förväntat instanceof ${issue2.expected}, fick ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Ogiltig inmatning: förväntat ${expected}, fick ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Ogiltig inmatning: förväntat ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Ogiltigt val: förväntade en av ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `För stor(t): förväntade ${issue2.origin ?? "värdet"} att ha ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "element"}`;
|
|||
|
|
}
|
|||
|
|
return `För stor(t): förväntat ${issue2.origin ?? "värdet"} att ha ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `För lite(t): förväntade ${issue2.origin ?? "värdet"} att ha ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `För lite(t): förväntade ${issue2.origin ?? "värdet"} att ha ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `Ogiltig sträng: måste börja med "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Ogiltig sträng: måste sluta med "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Ogiltig sträng: måste innehålla "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Ogiltig sträng: måste matcha mönstret "${_issue.pattern}"`;
|
|||
|
|
return `Ogiltig(t) ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Ogiltigt tal: måste vara en multipel av ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `${issue2.keys.length > 1 ? "Okända nycklar" : "Okänd nyckel"}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Ogiltig nyckel i ${issue2.origin ?? "värdet"}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Ogiltig input";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Ogiltigt värde i ${issue2.origin ?? "värdet"}`;
|
|||
|
|
default:
|
|||
|
|
return `Ogiltig input`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function sv_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error37()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ta.js
|
|||
|
|
var error38 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "எழுத்துக்கள்", verb: "கொண்டிருக்க வேண்டும்" },
|
|||
|
|
file: { unit: "பைட்டுகள்", verb: "கொண்டிருக்க வேண்டும்" },
|
|||
|
|
array: { unit: "உறுப்புகள்", verb: "கொண்டிருக்க வேண்டும்" },
|
|||
|
|
set: { unit: "உறுப்புகள்", verb: "கொண்டிருக்க வேண்டும்" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "உள்ளீடு",
|
|||
|
|
email: "மின்னஞ்சல் முகவரி",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO தேதி நேரம்",
|
|||
|
|
date: "ISO தேதி",
|
|||
|
|
time: "ISO நேரம்",
|
|||
|
|
duration: "ISO கால அளவு",
|
|||
|
|
ipv4: "IPv4 முகவரி",
|
|||
|
|
ipv6: "IPv6 முகவரி",
|
|||
|
|
cidrv4: "IPv4 வரம்பு",
|
|||
|
|
cidrv6: "IPv6 வரம்பு",
|
|||
|
|
base64: "base64-encoded சரம்",
|
|||
|
|
base64url: "base64url-encoded சரம்",
|
|||
|
|
json_string: "JSON சரம்",
|
|||
|
|
e164: "E.164 எண்",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "input"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "எண்",
|
|||
|
|
array: "அணி",
|
|||
|
|
null: "வெறுமை"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `தவறான உள்ளீடு: எதிர்பார்க்கப்பட்டது instanceof ${issue2.expected}, பெறப்பட்டது ${received}`;
|
|||
|
|
}
|
|||
|
|
return `தவறான உள்ளீடு: எதிர்பார்க்கப்பட்டது ${expected}, பெறப்பட்டது ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `தவறான உள்ளீடு: எதிர்பார்க்கப்பட்டது ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `தவறான விருப்பம்: எதிர்பார்க்கப்பட்டது ${joinValues(issue2.values, "|")} இல் ஒன்று`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `மிக பெரியது: எதிர்பார்க்கப்பட்டது ${issue2.origin ?? "மதிப்பு"} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "உறுப்புகள்"} ஆக இருக்க வேண்டும்`;
|
|||
|
|
}
|
|||
|
|
return `மிக பெரியது: எதிர்பார்க்கப்பட்டது ${issue2.origin ?? "மதிப்பு"} ${adj}${issue2.maximum.toString()} ஆக இருக்க வேண்டும்`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `மிகச் சிறியது: எதிர்பார்க்கப்பட்டது ${issue2.origin} ${adj}${issue2.minimum.toString()} ${sizing.unit} ஆக இருக்க வேண்டும்`;
|
|||
|
|
}
|
|||
|
|
return `மிகச் சிறியது: எதிர்பார்க்கப்பட்டது ${issue2.origin} ${adj}${issue2.minimum.toString()} ஆக இருக்க வேண்டும்`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `தவறான சரம்: "${_issue.prefix}" இல் தொடங்க வேண்டும்`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `தவறான சரம்: "${_issue.suffix}" இல் முடிவடைய வேண்டும்`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `தவறான சரம்: "${_issue.includes}" ஐ உள்ளடக்க வேண்டும்`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `தவறான சரம்: ${_issue.pattern} முறைபாட்டுடன் பொருந்த வேண்டும்`;
|
|||
|
|
return `தவறான ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `தவறான எண்: ${issue2.divisor} இன் பலமாக இருக்க வேண்டும்`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `அடையாளம் தெரியாத விசை${issue2.keys.length > 1 ? "கள்" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `${issue2.origin} இல் தவறான விசை`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "தவறான உள்ளீடு";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `${issue2.origin} இல் தவறான மதிப்பு`;
|
|||
|
|
default:
|
|||
|
|
return `தவறான உள்ளீடு`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ta_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error38()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/th.js
|
|||
|
|
var error39 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "ตัวอักษร", verb: "ควรมี" },
|
|||
|
|
file: { unit: "ไบต์", verb: "ควรมี" },
|
|||
|
|
array: { unit: "รายการ", verb: "ควรมี" },
|
|||
|
|
set: { unit: "รายการ", verb: "ควรมี" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "ข้อมูลที่ป้อน",
|
|||
|
|
email: "ที่อยู่อีเมล",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "อิโมจิ",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "วันที่เวลาแบบ ISO",
|
|||
|
|
date: "วันที่แบบ ISO",
|
|||
|
|
time: "เวลาแบบ ISO",
|
|||
|
|
duration: "ช่วงเวลาแบบ ISO",
|
|||
|
|
ipv4: "ที่อยู่ IPv4",
|
|||
|
|
ipv6: "ที่อยู่ IPv6",
|
|||
|
|
cidrv4: "ช่วง IP แบบ IPv4",
|
|||
|
|
cidrv6: "ช่วง IP แบบ IPv6",
|
|||
|
|
base64: "ข้อความแบบ Base64",
|
|||
|
|
base64url: "ข้อความแบบ Base64 สำหรับ URL",
|
|||
|
|
json_string: "ข้อความแบบ JSON",
|
|||
|
|
e164: "เบอร์โทรศัพท์ระหว่างประเทศ (E.164)",
|
|||
|
|
jwt: "โทเคน JWT",
|
|||
|
|
template_literal: "ข้อมูลที่ป้อน"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "ตัวเลข",
|
|||
|
|
array: "อาร์เรย์ (Array)",
|
|||
|
|
null: "ไม่มีค่า (null)"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `ประเภทข้อมูลไม่ถูกต้อง: ควรเป็น instanceof ${issue2.expected} แต่ได้รับ ${received}`;
|
|||
|
|
}
|
|||
|
|
return `ประเภทข้อมูลไม่ถูกต้อง: ควรเป็น ${expected} แต่ได้รับ ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `ค่าไม่ถูกต้อง: ควรเป็น ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `ตัวเลือกไม่ถูกต้อง: ควรเป็นหนึ่งใน ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "ไม่เกิน" : "น้อยกว่า";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `เกินกำหนด: ${issue2.origin ?? "ค่า"} ควรมี${adj} ${issue2.maximum.toString()} ${sizing.unit ?? "รายการ"}`;
|
|||
|
|
return `เกินกำหนด: ${issue2.origin ?? "ค่า"} ควรมี${adj} ${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? "อย่างน้อย" : "มากกว่า";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `น้อยกว่ากำหนด: ${issue2.origin} ควรมี${adj} ${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `น้อยกว่ากำหนด: ${issue2.origin} ควรมี${adj} ${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `รูปแบบไม่ถูกต้อง: ข้อความต้องขึ้นต้นด้วย "${_issue.prefix}"`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `รูปแบบไม่ถูกต้อง: ข้อความต้องลงท้ายด้วย "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `รูปแบบไม่ถูกต้อง: ข้อความต้องมี "${_issue.includes}" อยู่ในข้อความ`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `รูปแบบไม่ถูกต้อง: ต้องตรงกับรูปแบบที่กำหนด ${_issue.pattern}`;
|
|||
|
|
return `รูปแบบไม่ถูกต้อง: ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `ตัวเลขไม่ถูกต้อง: ต้องเป็นจำนวนที่หารด้วย ${issue2.divisor} ได้ลงตัว`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `พบคีย์ที่ไม่รู้จัก: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `คีย์ไม่ถูกต้องใน ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "ข้อมูลไม่ถูกต้อง: ไม่ตรงกับรูปแบบยูเนียนที่กำหนดไว้";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `ข้อมูลไม่ถูกต้องใน ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `ข้อมูลไม่ถูกต้อง`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function th_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error39()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/tr.js
|
|||
|
|
var error40 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "karakter", verb: "olmalı" },
|
|||
|
|
file: { unit: "bayt", verb: "olmalı" },
|
|||
|
|
array: { unit: "öğe", verb: "olmalı" },
|
|||
|
|
set: { unit: "öğe", verb: "olmalı" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "girdi",
|
|||
|
|
email: "e-posta adresi",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO tarih ve saat",
|
|||
|
|
date: "ISO tarih",
|
|||
|
|
time: "ISO saat",
|
|||
|
|
duration: "ISO süre",
|
|||
|
|
ipv4: "IPv4 adresi",
|
|||
|
|
ipv6: "IPv6 adresi",
|
|||
|
|
cidrv4: "IPv4 aralığı",
|
|||
|
|
cidrv6: "IPv6 aralığı",
|
|||
|
|
base64: "base64 ile şifrelenmiş metin",
|
|||
|
|
base64url: "base64url ile şifrelenmiş metin",
|
|||
|
|
json_string: "JSON dizesi",
|
|||
|
|
e164: "E.164 sayısı",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "Şablon dizesi"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Geçersiz değer: beklenen instanceof ${issue2.expected}, alınan ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Geçersiz değer: beklenen ${expected}, alınan ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Geçersiz değer: beklenen ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Geçersiz seçenek: aşağıdakilerden biri olmalı: ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Çok büyük: beklenen ${issue2.origin ?? "değer"} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "öğe"}`;
|
|||
|
|
return `Çok büyük: beklenen ${issue2.origin ?? "değer"} ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Çok küçük: beklenen ${issue2.origin} ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
return `Çok küçük: beklenen ${issue2.origin} ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Geçersiz metin: "${_issue.prefix}" ile başlamalı`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Geçersiz metin: "${_issue.suffix}" ile bitmeli`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Geçersiz metin: "${_issue.includes}" içermeli`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Geçersiz metin: ${_issue.pattern} desenine uymalı`;
|
|||
|
|
return `Geçersiz ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Geçersiz sayı: ${issue2.divisor} ile tam bölünebilmeli`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Tanınmayan anahtar${issue2.keys.length > 1 ? "lar" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `${issue2.origin} içinde geçersiz anahtar`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Geçersiz değer";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `${issue2.origin} içinde geçersiz değer`;
|
|||
|
|
default:
|
|||
|
|
return `Geçersiz değer`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function tr_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error40()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/uk.js
|
|||
|
|
var error41 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "символів", verb: "матиме" },
|
|||
|
|
file: { unit: "байтів", verb: "матиме" },
|
|||
|
|
array: { unit: "елементів", verb: "матиме" },
|
|||
|
|
set: { unit: "елементів", verb: "матиме" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "вхідні дані",
|
|||
|
|
email: "адреса електронної пошти",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "емодзі",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "дата та час ISO",
|
|||
|
|
date: "дата ISO",
|
|||
|
|
time: "час ISO",
|
|||
|
|
duration: "тривалість ISO",
|
|||
|
|
ipv4: "адреса IPv4",
|
|||
|
|
ipv6: "адреса IPv6",
|
|||
|
|
cidrv4: "діапазон IPv4",
|
|||
|
|
cidrv6: "діапазон IPv6",
|
|||
|
|
base64: "рядок у кодуванні base64",
|
|||
|
|
base64url: "рядок у кодуванні base64url",
|
|||
|
|
json_string: "рядок JSON",
|
|||
|
|
e164: "номер E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "вхідні дані"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "число",
|
|||
|
|
array: "масив"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Неправильні вхідні дані: очікується instanceof ${issue2.expected}, отримано ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Неправильні вхідні дані: очікується ${expected}, отримано ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Неправильні вхідні дані: очікується ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Неправильна опція: очікується одне з ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Занадто велике: очікується, що ${issue2.origin ?? "значення"} ${sizing.verb} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "елементів"}`;
|
|||
|
|
return `Занадто велике: очікується, що ${issue2.origin ?? "значення"} буде ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Занадто мале: очікується, що ${issue2.origin} ${sizing.verb} ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Занадто мале: очікується, що ${issue2.origin} буде ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Неправильний рядок: повинен починатися з "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Неправильний рядок: повинен закінчуватися на "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Неправильний рядок: повинен містити "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Неправильний рядок: повинен відповідати шаблону ${_issue.pattern}`;
|
|||
|
|
return `Неправильний ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Неправильне число: повинно бути кратним ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Нерозпізнаний ключ${issue2.keys.length > 1 ? "і" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Неправильний ключ у ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Неправильні вхідні дані";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Неправильне значення у ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Неправильні вхідні дані`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function uk_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error41()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ua.js
|
|||
|
|
function ua_default() {
|
|||
|
|
return uk_default();
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/ur.js
|
|||
|
|
var error42 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "حروف", verb: "ہونا" },
|
|||
|
|
file: { unit: "بائٹس", verb: "ہونا" },
|
|||
|
|
array: { unit: "آئٹمز", verb: "ہونا" },
|
|||
|
|
set: { unit: "آئٹمز", verb: "ہونا" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "ان پٹ",
|
|||
|
|
email: "ای میل ایڈریس",
|
|||
|
|
url: "یو آر ایل",
|
|||
|
|
emoji: "ایموجی",
|
|||
|
|
uuid: "یو یو آئی ڈی",
|
|||
|
|
uuidv4: "یو یو آئی ڈی وی 4",
|
|||
|
|
uuidv6: "یو یو آئی ڈی وی 6",
|
|||
|
|
nanoid: "نینو آئی ڈی",
|
|||
|
|
guid: "جی یو آئی ڈی",
|
|||
|
|
cuid: "سی یو آئی ڈی",
|
|||
|
|
cuid2: "سی یو آئی ڈی 2",
|
|||
|
|
ulid: "یو ایل آئی ڈی",
|
|||
|
|
xid: "ایکس آئی ڈی",
|
|||
|
|
ksuid: "کے ایس یو آئی ڈی",
|
|||
|
|
datetime: "آئی ایس او ڈیٹ ٹائم",
|
|||
|
|
date: "آئی ایس او تاریخ",
|
|||
|
|
time: "آئی ایس او وقت",
|
|||
|
|
duration: "آئی ایس او مدت",
|
|||
|
|
ipv4: "آئی پی وی 4 ایڈریس",
|
|||
|
|
ipv6: "آئی پی وی 6 ایڈریس",
|
|||
|
|
cidrv4: "آئی پی وی 4 رینج",
|
|||
|
|
cidrv6: "آئی پی وی 6 رینج",
|
|||
|
|
base64: "بیس 64 ان کوڈڈ سٹرنگ",
|
|||
|
|
base64url: "بیس 64 یو آر ایل ان کوڈڈ سٹرنگ",
|
|||
|
|
json_string: "جے ایس او این سٹرنگ",
|
|||
|
|
e164: "ای 164 نمبر",
|
|||
|
|
jwt: "جے ڈبلیو ٹی",
|
|||
|
|
template_literal: "ان پٹ"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "نمبر",
|
|||
|
|
array: "آرے",
|
|||
|
|
null: "نل"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `غلط ان پٹ: instanceof ${issue2.expected} متوقع تھا، ${received} موصول ہوا`;
|
|||
|
|
}
|
|||
|
|
return `غلط ان پٹ: ${expected} متوقع تھا، ${received} موصول ہوا`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `غلط ان پٹ: ${stringifyPrimitive(issue2.values[0])} متوقع تھا`;
|
|||
|
|
return `غلط آپشن: ${joinValues(issue2.values, "|")} میں سے ایک متوقع تھا`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `بہت بڑا: ${issue2.origin ?? "ویلیو"} کے ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "عناصر"} ہونے متوقع تھے`;
|
|||
|
|
return `بہت بڑا: ${issue2.origin ?? "ویلیو"} کا ${adj}${issue2.maximum.toString()} ہونا متوقع تھا`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `بہت چھوٹا: ${issue2.origin} کے ${adj}${issue2.minimum.toString()} ${sizing.unit} ہونے متوقع تھے`;
|
|||
|
|
}
|
|||
|
|
return `بہت چھوٹا: ${issue2.origin} کا ${adj}${issue2.minimum.toString()} ہونا متوقع تھا`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `غلط سٹرنگ: "${_issue.prefix}" سے شروع ہونا چاہیے`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `غلط سٹرنگ: "${_issue.suffix}" پر ختم ہونا چاہیے`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `غلط سٹرنگ: "${_issue.includes}" شامل ہونا چاہیے`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `غلط سٹرنگ: پیٹرن ${_issue.pattern} سے میچ ہونا چاہیے`;
|
|||
|
|
return `غلط ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `غلط نمبر: ${issue2.divisor} کا مضاعف ہونا چاہیے`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `غیر تسلیم شدہ کی${issue2.keys.length > 1 ? "ز" : ""}: ${joinValues(issue2.keys, "، ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `${issue2.origin} میں غلط کی`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "غلط ان پٹ";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `${issue2.origin} میں غلط ویلیو`;
|
|||
|
|
default:
|
|||
|
|
return `غلط ان پٹ`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function ur_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error42()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/uz.js
|
|||
|
|
var error43 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "belgi", verb: "bo‘lishi kerak" },
|
|||
|
|
file: { unit: "bayt", verb: "bo‘lishi kerak" },
|
|||
|
|
array: { unit: "element", verb: "bo‘lishi kerak" },
|
|||
|
|
set: { unit: "element", verb: "bo‘lishi kerak" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "kirish",
|
|||
|
|
email: "elektron pochta manzili",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO sana va vaqti",
|
|||
|
|
date: "ISO sana",
|
|||
|
|
time: "ISO vaqt",
|
|||
|
|
duration: "ISO davomiylik",
|
|||
|
|
ipv4: "IPv4 manzil",
|
|||
|
|
ipv6: "IPv6 manzil",
|
|||
|
|
mac: "MAC manzil",
|
|||
|
|
cidrv4: "IPv4 diapazon",
|
|||
|
|
cidrv6: "IPv6 diapazon",
|
|||
|
|
base64: "base64 kodlangan satr",
|
|||
|
|
base64url: "base64url kodlangan satr",
|
|||
|
|
json_string: "JSON satr",
|
|||
|
|
e164: "E.164 raqam",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "kirish"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "raqam",
|
|||
|
|
array: "massiv"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Noto‘g‘ri kirish: kutilgan instanceof ${issue2.expected}, qabul qilingan ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Noto‘g‘ri kirish: kutilgan ${expected}, qabul qilingan ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Noto‘g‘ri kirish: kutilgan ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Noto‘g‘ri variant: quyidagilardan biri kutilgan ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Juda katta: kutilgan ${issue2.origin ?? "qiymat"} ${adj}${issue2.maximum.toString()} ${sizing.unit} ${sizing.verb}`;
|
|||
|
|
return `Juda katta: kutilgan ${issue2.origin ?? "qiymat"} ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Juda kichik: kutilgan ${issue2.origin} ${adj}${issue2.minimum.toString()} ${sizing.unit} ${sizing.verb}`;
|
|||
|
|
}
|
|||
|
|
return `Juda kichik: kutilgan ${issue2.origin} ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Noto‘g‘ri satr: "${_issue.prefix}" bilan boshlanishi kerak`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Noto‘g‘ri satr: "${_issue.suffix}" bilan tugashi kerak`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Noto‘g‘ri satr: "${_issue.includes}" ni o‘z ichiga olishi kerak`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Noto‘g‘ri satr: ${_issue.pattern} shabloniga mos kelishi kerak`;
|
|||
|
|
return `Noto‘g‘ri ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Noto‘g‘ri raqam: ${issue2.divisor} ning karralisi bo‘lishi kerak`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Noma’lum kalit${issue2.keys.length > 1 ? "lar" : ""}: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `${issue2.origin} dagi kalit noto‘g‘ri`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Noto‘g‘ri kirish";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `${issue2.origin} da noto‘g‘ri qiymat`;
|
|||
|
|
default:
|
|||
|
|
return `Noto‘g‘ri kirish`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function uz_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error43()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/vi.js
|
|||
|
|
var error44 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "ký tự", verb: "có" },
|
|||
|
|
file: { unit: "byte", verb: "có" },
|
|||
|
|
array: { unit: "phần tử", verb: "có" },
|
|||
|
|
set: { unit: "phần tử", verb: "có" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "đầu vào",
|
|||
|
|
email: "địa chỉ email",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ngày giờ ISO",
|
|||
|
|
date: "ngày ISO",
|
|||
|
|
time: "giờ ISO",
|
|||
|
|
duration: "khoảng thời gian ISO",
|
|||
|
|
ipv4: "địa chỉ IPv4",
|
|||
|
|
ipv6: "địa chỉ IPv6",
|
|||
|
|
cidrv4: "dải IPv4",
|
|||
|
|
cidrv6: "dải IPv6",
|
|||
|
|
base64: "chuỗi mã hóa base64",
|
|||
|
|
base64url: "chuỗi mã hóa base64url",
|
|||
|
|
json_string: "chuỗi JSON",
|
|||
|
|
e164: "số E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "đầu vào"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "số",
|
|||
|
|
array: "mảng"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Đầu vào không hợp lệ: mong đợi instanceof ${issue2.expected}, nhận được ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Đầu vào không hợp lệ: mong đợi ${expected}, nhận được ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Đầu vào không hợp lệ: mong đợi ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Tùy chọn không hợp lệ: mong đợi một trong các giá trị ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Quá lớn: mong đợi ${issue2.origin ?? "giá trị"} ${sizing.verb} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "phần tử"}`;
|
|||
|
|
return `Quá lớn: mong đợi ${issue2.origin ?? "giá trị"} ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `Quá nhỏ: mong đợi ${issue2.origin} ${sizing.verb} ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `Quá nhỏ: mong đợi ${issue2.origin} ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Chuỗi không hợp lệ: phải bắt đầu bằng "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Chuỗi không hợp lệ: phải kết thúc bằng "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Chuỗi không hợp lệ: phải bao gồm "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Chuỗi không hợp lệ: phải khớp với mẫu ${_issue.pattern}`;
|
|||
|
|
return `${FormatDictionary[_issue.format] ?? issue2.format} không hợp lệ`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Số không hợp lệ: phải là bội số của ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Khóa không được nhận dạng: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Khóa không hợp lệ trong ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Đầu vào không hợp lệ";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Giá trị không hợp lệ trong ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return `Đầu vào không hợp lệ`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function vi_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error44()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/zh-CN.js
|
|||
|
|
var error45 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "字符", verb: "包含" },
|
|||
|
|
file: { unit: "字节", verb: "包含" },
|
|||
|
|
array: { unit: "项", verb: "包含" },
|
|||
|
|
set: { unit: "项", verb: "包含" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "输入",
|
|||
|
|
email: "电子邮件",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "表情符号",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO日期时间",
|
|||
|
|
date: "ISO日期",
|
|||
|
|
time: "ISO时间",
|
|||
|
|
duration: "ISO时长",
|
|||
|
|
ipv4: "IPv4地址",
|
|||
|
|
ipv6: "IPv6地址",
|
|||
|
|
cidrv4: "IPv4网段",
|
|||
|
|
cidrv6: "IPv6网段",
|
|||
|
|
base64: "base64编码字符串",
|
|||
|
|
base64url: "base64url编码字符串",
|
|||
|
|
json_string: "JSON字符串",
|
|||
|
|
e164: "E.164号码",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "输入"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "数字",
|
|||
|
|
array: "数组",
|
|||
|
|
null: "空值(null)"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `无效输入:期望 instanceof ${issue2.expected},实际接收 ${received}`;
|
|||
|
|
}
|
|||
|
|
return `无效输入:期望 ${expected},实际接收 ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `无效输入:期望 ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `无效选项:期望以下之一 ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `数值过大:期望 ${issue2.origin ?? "值"} ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "个元素"}`;
|
|||
|
|
return `数值过大:期望 ${issue2.origin ?? "值"} ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `数值过小:期望 ${issue2.origin} ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `数值过小:期望 ${issue2.origin} ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `无效字符串:必须以 "${_issue.prefix}" 开头`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `无效字符串:必须以 "${_issue.suffix}" 结尾`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `无效字符串:必须包含 "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `无效字符串:必须满足正则表达式 ${_issue.pattern}`;
|
|||
|
|
return `无效${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `无效数字:必须是 ${issue2.divisor} 的倍数`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `出现未知的键(key): ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `${issue2.origin} 中的键(key)无效`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "无效输入";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `${issue2.origin} 中包含无效值(value)`;
|
|||
|
|
default:
|
|||
|
|
return `无效输入`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function zh_CN_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error45()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/zh-TW.js
|
|||
|
|
var error46 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "字元", verb: "擁有" },
|
|||
|
|
file: { unit: "位元組", verb: "擁有" },
|
|||
|
|
array: { unit: "項目", verb: "擁有" },
|
|||
|
|
set: { unit: "項目", verb: "擁有" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "輸入",
|
|||
|
|
email: "郵件地址",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "ISO 日期時間",
|
|||
|
|
date: "ISO 日期",
|
|||
|
|
time: "ISO 時間",
|
|||
|
|
duration: "ISO 期間",
|
|||
|
|
ipv4: "IPv4 位址",
|
|||
|
|
ipv6: "IPv6 位址",
|
|||
|
|
cidrv4: "IPv4 範圍",
|
|||
|
|
cidrv6: "IPv6 範圍",
|
|||
|
|
base64: "base64 編碼字串",
|
|||
|
|
base64url: "base64url 編碼字串",
|
|||
|
|
json_string: "JSON 字串",
|
|||
|
|
e164: "E.164 數值",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "輸入"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `無效的輸入值:預期為 instanceof ${issue2.expected},但收到 ${received}`;
|
|||
|
|
}
|
|||
|
|
return `無效的輸入值:預期為 ${expected},但收到 ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `無效的輸入值:預期為 ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `無效的選項:預期為以下其中之一 ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `數值過大:預期 ${issue2.origin ?? "值"} 應為 ${adj}${issue2.maximum.toString()} ${sizing.unit ?? "個元素"}`;
|
|||
|
|
return `數值過大:預期 ${issue2.origin ?? "值"} 應為 ${adj}${issue2.maximum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing) {
|
|||
|
|
return `數值過小:預期 ${issue2.origin} 應為 ${adj}${issue2.minimum.toString()} ${sizing.unit}`;
|
|||
|
|
}
|
|||
|
|
return `數值過小:預期 ${issue2.origin} 應為 ${adj}${issue2.minimum.toString()}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with") {
|
|||
|
|
return `無效的字串:必須以 "${_issue.prefix}" 開頭`;
|
|||
|
|
}
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `無效的字串:必須以 "${_issue.suffix}" 結尾`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `無效的字串:必須包含 "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `無效的字串:必須符合格式 ${_issue.pattern}`;
|
|||
|
|
return `無效的 ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `無效的數字:必須為 ${issue2.divisor} 的倍數`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `無法識別的鍵值${issue2.keys.length > 1 ? "們" : ""}:${joinValues(issue2.keys, "、")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `${issue2.origin} 中有無效的鍵值`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "無效的輸入值";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `${issue2.origin} 中有無效的值`;
|
|||
|
|
default:
|
|||
|
|
return `無效的輸入值`;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function zh_TW_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error46()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/locales/yo.js
|
|||
|
|
var error47 = () => {
|
|||
|
|
const Sizable = {
|
|||
|
|
string: { unit: "àmi", verb: "ní" },
|
|||
|
|
file: { unit: "bytes", verb: "ní" },
|
|||
|
|
array: { unit: "nkan", verb: "ní" },
|
|||
|
|
set: { unit: "nkan", verb: "ní" }
|
|||
|
|
};
|
|||
|
|
function getSizing(origin) {
|
|||
|
|
return Sizable[origin] ?? null;
|
|||
|
|
}
|
|||
|
|
const FormatDictionary = {
|
|||
|
|
regex: "ẹ̀rọ ìbáwọlé",
|
|||
|
|
email: "àdírẹ́sì ìmẹ́lì",
|
|||
|
|
url: "URL",
|
|||
|
|
emoji: "emoji",
|
|||
|
|
uuid: "UUID",
|
|||
|
|
uuidv4: "UUIDv4",
|
|||
|
|
uuidv6: "UUIDv6",
|
|||
|
|
nanoid: "nanoid",
|
|||
|
|
guid: "GUID",
|
|||
|
|
cuid: "cuid",
|
|||
|
|
cuid2: "cuid2",
|
|||
|
|
ulid: "ULID",
|
|||
|
|
xid: "XID",
|
|||
|
|
ksuid: "KSUID",
|
|||
|
|
datetime: "àkókò ISO",
|
|||
|
|
date: "ọjọ́ ISO",
|
|||
|
|
time: "àkókò ISO",
|
|||
|
|
duration: "àkókò tó pé ISO",
|
|||
|
|
ipv4: "àdírẹ́sì IPv4",
|
|||
|
|
ipv6: "àdírẹ́sì IPv6",
|
|||
|
|
cidrv4: "àgbègbè IPv4",
|
|||
|
|
cidrv6: "àgbègbè IPv6",
|
|||
|
|
base64: "ọ̀rọ̀ tí a kọ́ ní base64",
|
|||
|
|
base64url: "ọ̀rọ̀ base64url",
|
|||
|
|
json_string: "ọ̀rọ̀ JSON",
|
|||
|
|
e164: "nọ́mbà E.164",
|
|||
|
|
jwt: "JWT",
|
|||
|
|
template_literal: "ẹ̀rọ ìbáwọlé"
|
|||
|
|
};
|
|||
|
|
const TypeDictionary = {
|
|||
|
|
nan: "NaN",
|
|||
|
|
number: "nọ́mbà",
|
|||
|
|
array: "akopọ"
|
|||
|
|
};
|
|||
|
|
return (issue2) => {
|
|||
|
|
switch (issue2.code) {
|
|||
|
|
case "invalid_type": {
|
|||
|
|
const expected = TypeDictionary[issue2.expected] ?? issue2.expected;
|
|||
|
|
const receivedType = parsedType(issue2.input);
|
|||
|
|
const received = TypeDictionary[receivedType] ?? receivedType;
|
|||
|
|
if (/^[A-Z]/.test(issue2.expected)) {
|
|||
|
|
return `Ìbáwọlé aṣìṣe: a ní láti fi instanceof ${issue2.expected}, àmọ̀ a rí ${received}`;
|
|||
|
|
}
|
|||
|
|
return `Ìbáwọlé aṣìṣe: a ní láti fi ${expected}, àmọ̀ a rí ${received}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_value":
|
|||
|
|
if (issue2.values.length === 1)
|
|||
|
|
return `Ìbáwọlé aṣìṣe: a ní láti fi ${stringifyPrimitive(issue2.values[0])}`;
|
|||
|
|
return `Àṣàyàn aṣìṣe: yan ọ̀kan lára ${joinValues(issue2.values, "|")}`;
|
|||
|
|
case "too_big": {
|
|||
|
|
const adj = issue2.inclusive ? "<=" : "<";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Tó pọ̀ jù: a ní láti jẹ́ pé ${issue2.origin ?? "iye"} ${sizing.verb} ${adj}${issue2.maximum} ${sizing.unit}`;
|
|||
|
|
return `Tó pọ̀ jù: a ní láti jẹ́ ${adj}${issue2.maximum}`;
|
|||
|
|
}
|
|||
|
|
case "too_small": {
|
|||
|
|
const adj = issue2.inclusive ? ">=" : ">";
|
|||
|
|
const sizing = getSizing(issue2.origin);
|
|||
|
|
if (sizing)
|
|||
|
|
return `Kéré ju: a ní láti jẹ́ pé ${issue2.origin} ${sizing.verb} ${adj}${issue2.minimum} ${sizing.unit}`;
|
|||
|
|
return `Kéré ju: a ní láti jẹ́ ${adj}${issue2.minimum}`;
|
|||
|
|
}
|
|||
|
|
case "invalid_format": {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.format === "starts_with")
|
|||
|
|
return `Ọ̀rọ̀ aṣìṣe: gbọ́dọ̀ bẹ̀rẹ̀ pẹ̀lú "${_issue.prefix}"`;
|
|||
|
|
if (_issue.format === "ends_with")
|
|||
|
|
return `Ọ̀rọ̀ aṣìṣe: gbọ́dọ̀ parí pẹ̀lú "${_issue.suffix}"`;
|
|||
|
|
if (_issue.format === "includes")
|
|||
|
|
return `Ọ̀rọ̀ aṣìṣe: gbọ́dọ̀ ní "${_issue.includes}"`;
|
|||
|
|
if (_issue.format === "regex")
|
|||
|
|
return `Ọ̀rọ̀ aṣìṣe: gbọ́dọ̀ bá àpẹẹrẹ mu ${_issue.pattern}`;
|
|||
|
|
return `Aṣìṣe: ${FormatDictionary[_issue.format] ?? issue2.format}`;
|
|||
|
|
}
|
|||
|
|
case "not_multiple_of":
|
|||
|
|
return `Nọ́mbà aṣìṣe: gbọ́dọ̀ jẹ́ èyà pípín ti ${issue2.divisor}`;
|
|||
|
|
case "unrecognized_keys":
|
|||
|
|
return `Bọtìnì àìmọ̀: ${joinValues(issue2.keys, ", ")}`;
|
|||
|
|
case "invalid_key":
|
|||
|
|
return `Bọtìnì aṣìṣe nínú ${issue2.origin}`;
|
|||
|
|
case "invalid_union":
|
|||
|
|
return "Ìbáwọlé aṣìṣe";
|
|||
|
|
case "invalid_element":
|
|||
|
|
return `Iye aṣìṣe nínú ${issue2.origin}`;
|
|||
|
|
default:
|
|||
|
|
return "Ìbáwọlé aṣìṣe";
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
};
|
|||
|
|
function yo_default() {
|
|||
|
|
return {
|
|||
|
|
localeError: error47()
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/registries.js
|
|||
|
|
var _a;
|
|||
|
|
var $output = /* @__PURE__ */ Symbol("ZodOutput");
|
|||
|
|
var $input = /* @__PURE__ */ Symbol("ZodInput");
|
|||
|
|
var $ZodRegistry = class {
|
|||
|
|
constructor() {
|
|||
|
|
this._map = /* @__PURE__ */ new WeakMap();
|
|||
|
|
this._idmap = /* @__PURE__ */ new Map();
|
|||
|
|
}
|
|||
|
|
add(schema, ..._meta) {
|
|||
|
|
const meta3 = _meta[0];
|
|||
|
|
this._map.set(schema, meta3);
|
|||
|
|
if (meta3 && typeof meta3 === "object" && "id" in meta3) {
|
|||
|
|
this._idmap.set(meta3.id, schema);
|
|||
|
|
}
|
|||
|
|
return this;
|
|||
|
|
}
|
|||
|
|
clear() {
|
|||
|
|
this._map = /* @__PURE__ */ new WeakMap();
|
|||
|
|
this._idmap = /* @__PURE__ */ new Map();
|
|||
|
|
return this;
|
|||
|
|
}
|
|||
|
|
remove(schema) {
|
|||
|
|
const meta3 = this._map.get(schema);
|
|||
|
|
if (meta3 && typeof meta3 === "object" && "id" in meta3) {
|
|||
|
|
this._idmap.delete(meta3.id);
|
|||
|
|
}
|
|||
|
|
this._map.delete(schema);
|
|||
|
|
return this;
|
|||
|
|
}
|
|||
|
|
get(schema) {
|
|||
|
|
const p = schema._zod.parent;
|
|||
|
|
if (p) {
|
|||
|
|
const pm = { ...this.get(p) ?? {} };
|
|||
|
|
delete pm.id;
|
|||
|
|
const f = { ...pm, ...this._map.get(schema) };
|
|||
|
|
return Object.keys(f).length ? f : void 0;
|
|||
|
|
}
|
|||
|
|
return this._map.get(schema);
|
|||
|
|
}
|
|||
|
|
has(schema) {
|
|||
|
|
return this._map.has(schema);
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
function registry() {
|
|||
|
|
return new $ZodRegistry();
|
|||
|
|
}
|
|||
|
|
(_a = globalThis).__zod_globalRegistry ?? (_a.__zod_globalRegistry = registry());
|
|||
|
|
var globalRegistry = globalThis.__zod_globalRegistry;
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/api.js
|
|||
|
|
function _string(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _coercedString(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
coerce: true,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _email(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "email",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _guid(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "guid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _uuid(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "uuid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _uuidv4(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "uuid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
version: "v4",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _uuidv6(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "uuid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
version: "v6",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _uuidv7(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "uuid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
version: "v7",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _url(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "url",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _emoji2(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "emoji",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _nanoid(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "nanoid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _cuid(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "cuid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _cuid2(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "cuid2",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _ulid(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "ulid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _xid(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "xid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _ksuid(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "ksuid",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _ipv4(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "ipv4",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _ipv6(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "ipv6",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _mac(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "mac",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _cidrv4(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "cidrv4",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _cidrv6(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "cidrv6",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _base64(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "base64",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _base64url(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "base64url",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _e164(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "e164",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _jwt(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "jwt",
|
|||
|
|
check: "string_format",
|
|||
|
|
abort: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var TimePrecision = {
|
|||
|
|
Any: null,
|
|||
|
|
Minute: -1,
|
|||
|
|
Second: 0,
|
|||
|
|
Millisecond: 3,
|
|||
|
|
Microsecond: 6
|
|||
|
|
};
|
|||
|
|
function _isoDateTime(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "datetime",
|
|||
|
|
check: "string_format",
|
|||
|
|
offset: false,
|
|||
|
|
local: false,
|
|||
|
|
precision: null,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _isoDate(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "date",
|
|||
|
|
check: "string_format",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _isoTime(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "time",
|
|||
|
|
check: "string_format",
|
|||
|
|
precision: null,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _isoDuration(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "string",
|
|||
|
|
format: "duration",
|
|||
|
|
check: "string_format",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _number(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "number",
|
|||
|
|
checks: [],
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _coercedNumber(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "number",
|
|||
|
|
coerce: true,
|
|||
|
|
checks: [],
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _int(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "number",
|
|||
|
|
check: "number_format",
|
|||
|
|
abort: false,
|
|||
|
|
format: "safeint",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _float32(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "number",
|
|||
|
|
check: "number_format",
|
|||
|
|
abort: false,
|
|||
|
|
format: "float32",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _float64(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "number",
|
|||
|
|
check: "number_format",
|
|||
|
|
abort: false,
|
|||
|
|
format: "float64",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _int32(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "number",
|
|||
|
|
check: "number_format",
|
|||
|
|
abort: false,
|
|||
|
|
format: "int32",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _uint32(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "number",
|
|||
|
|
check: "number_format",
|
|||
|
|
abort: false,
|
|||
|
|
format: "uint32",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _boolean(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "boolean",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _coercedBoolean(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "boolean",
|
|||
|
|
coerce: true,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _bigint(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "bigint",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _coercedBigint(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "bigint",
|
|||
|
|
coerce: true,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _int64(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "bigint",
|
|||
|
|
check: "bigint_format",
|
|||
|
|
abort: false,
|
|||
|
|
format: "int64",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _uint64(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "bigint",
|
|||
|
|
check: "bigint_format",
|
|||
|
|
abort: false,
|
|||
|
|
format: "uint64",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _symbol(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "symbol",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _undefined2(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "undefined",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _null2(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "null",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _any(Class2) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "any"
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _unknown(Class2) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "unknown"
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _never(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "never",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _void(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "void",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _date(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "date",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _coercedDate(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "date",
|
|||
|
|
coerce: true,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _nan(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "nan",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _lt(value, params) {
|
|||
|
|
return new $ZodCheckLessThan({
|
|||
|
|
check: "less_than",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
value,
|
|||
|
|
inclusive: false
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _lte(value, params) {
|
|||
|
|
return new $ZodCheckLessThan({
|
|||
|
|
check: "less_than",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
value,
|
|||
|
|
inclusive: true
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _gt(value, params) {
|
|||
|
|
return new $ZodCheckGreaterThan({
|
|||
|
|
check: "greater_than",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
value,
|
|||
|
|
inclusive: false
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _gte(value, params) {
|
|||
|
|
return new $ZodCheckGreaterThan({
|
|||
|
|
check: "greater_than",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
value,
|
|||
|
|
inclusive: true
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _positive(params) {
|
|||
|
|
return _gt(0, params);
|
|||
|
|
}
|
|||
|
|
function _negative(params) {
|
|||
|
|
return _lt(0, params);
|
|||
|
|
}
|
|||
|
|
function _nonpositive(params) {
|
|||
|
|
return _lte(0, params);
|
|||
|
|
}
|
|||
|
|
function _nonnegative(params) {
|
|||
|
|
return _gte(0, params);
|
|||
|
|
}
|
|||
|
|
function _multipleOf(value, params) {
|
|||
|
|
return new $ZodCheckMultipleOf({
|
|||
|
|
check: "multiple_of",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
value
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _maxSize(maximum, params) {
|
|||
|
|
return new $ZodCheckMaxSize({
|
|||
|
|
check: "max_size",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
maximum
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _minSize(minimum, params) {
|
|||
|
|
return new $ZodCheckMinSize({
|
|||
|
|
check: "min_size",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
minimum
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _size(size, params) {
|
|||
|
|
return new $ZodCheckSizeEquals({
|
|||
|
|
check: "size_equals",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
size
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _maxLength(maximum, params) {
|
|||
|
|
const ch = new $ZodCheckMaxLength({
|
|||
|
|
check: "max_length",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
maximum
|
|||
|
|
});
|
|||
|
|
return ch;
|
|||
|
|
}
|
|||
|
|
function _minLength(minimum, params) {
|
|||
|
|
return new $ZodCheckMinLength({
|
|||
|
|
check: "min_length",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
minimum
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _length(length, params) {
|
|||
|
|
return new $ZodCheckLengthEquals({
|
|||
|
|
check: "length_equals",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
length
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _regex(pattern, params) {
|
|||
|
|
return new $ZodCheckRegex({
|
|||
|
|
check: "string_format",
|
|||
|
|
format: "regex",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
pattern
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _lowercase(params) {
|
|||
|
|
return new $ZodCheckLowerCase({
|
|||
|
|
check: "string_format",
|
|||
|
|
format: "lowercase",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _uppercase(params) {
|
|||
|
|
return new $ZodCheckUpperCase({
|
|||
|
|
check: "string_format",
|
|||
|
|
format: "uppercase",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _includes(includes, params) {
|
|||
|
|
return new $ZodCheckIncludes({
|
|||
|
|
check: "string_format",
|
|||
|
|
format: "includes",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
includes
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _startsWith(prefix, params) {
|
|||
|
|
return new $ZodCheckStartsWith({
|
|||
|
|
check: "string_format",
|
|||
|
|
format: "starts_with",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
prefix
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _endsWith(suffix, params) {
|
|||
|
|
return new $ZodCheckEndsWith({
|
|||
|
|
check: "string_format",
|
|||
|
|
format: "ends_with",
|
|||
|
|
...normalizeParams(params),
|
|||
|
|
suffix
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _property(property, schema, params) {
|
|||
|
|
return new $ZodCheckProperty({
|
|||
|
|
check: "property",
|
|||
|
|
property,
|
|||
|
|
schema,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _mime(types, params) {
|
|||
|
|
return new $ZodCheckMimeType({
|
|||
|
|
check: "mime_type",
|
|||
|
|
mime: types,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _overwrite(tx) {
|
|||
|
|
return new $ZodCheckOverwrite({
|
|||
|
|
check: "overwrite",
|
|||
|
|
tx
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _normalize(form) {
|
|||
|
|
return _overwrite((input) => input.normalize(form));
|
|||
|
|
}
|
|||
|
|
function _trim() {
|
|||
|
|
return _overwrite((input) => input.trim());
|
|||
|
|
}
|
|||
|
|
function _toLowerCase() {
|
|||
|
|
return _overwrite((input) => input.toLowerCase());
|
|||
|
|
}
|
|||
|
|
function _toUpperCase() {
|
|||
|
|
return _overwrite((input) => input.toUpperCase());
|
|||
|
|
}
|
|||
|
|
function _slugify() {
|
|||
|
|
return _overwrite((input) => slugify(input));
|
|||
|
|
}
|
|||
|
|
function _array(Class2, element, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "array",
|
|||
|
|
element,
|
|||
|
|
// get element() {
|
|||
|
|
// return element;
|
|||
|
|
// },
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _union(Class2, options, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "union",
|
|||
|
|
options,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _xor(Class2, options, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "union",
|
|||
|
|
options,
|
|||
|
|
inclusive: false,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _discriminatedUnion(Class2, discriminator, options, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "union",
|
|||
|
|
options,
|
|||
|
|
discriminator,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _intersection(Class2, left, right) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "intersection",
|
|||
|
|
left,
|
|||
|
|
right
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _tuple(Class2, items, _paramsOrRest, _params) {
|
|||
|
|
const hasRest = _paramsOrRest instanceof $ZodType;
|
|||
|
|
const params = hasRest ? _params : _paramsOrRest;
|
|||
|
|
const rest = hasRest ? _paramsOrRest : null;
|
|||
|
|
return new Class2({
|
|||
|
|
type: "tuple",
|
|||
|
|
items,
|
|||
|
|
rest,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _record(Class2, keyType, valueType, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "record",
|
|||
|
|
keyType,
|
|||
|
|
valueType,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _map(Class2, keyType, valueType, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "map",
|
|||
|
|
keyType,
|
|||
|
|
valueType,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _set(Class2, valueType, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "set",
|
|||
|
|
valueType,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _enum(Class2, values, params) {
|
|||
|
|
const entries = Array.isArray(values) ? Object.fromEntries(values.map((v) => [v, v])) : values;
|
|||
|
|
return new Class2({
|
|||
|
|
type: "enum",
|
|||
|
|
entries,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _nativeEnum(Class2, entries, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "enum",
|
|||
|
|
entries,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _literal(Class2, value, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "literal",
|
|||
|
|
values: Array.isArray(value) ? value : [value],
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _file(Class2, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "file",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _transform(Class2, fn) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "transform",
|
|||
|
|
transform: fn
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _optional(Class2, innerType) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "optional",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _nullable(Class2, innerType) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "nullable",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _default(Class2, innerType, defaultValue) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "default",
|
|||
|
|
innerType,
|
|||
|
|
get defaultValue() {
|
|||
|
|
return typeof defaultValue === "function" ? defaultValue() : shallowClone(defaultValue);
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _nonoptional(Class2, innerType, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "nonoptional",
|
|||
|
|
innerType,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _success(Class2, innerType) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "success",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _catch(Class2, innerType, catchValue) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "catch",
|
|||
|
|
innerType,
|
|||
|
|
catchValue: typeof catchValue === "function" ? catchValue : () => catchValue
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _pipe(Class2, in_, out) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "pipe",
|
|||
|
|
in: in_,
|
|||
|
|
out
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _readonly(Class2, innerType) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "readonly",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _templateLiteral(Class2, parts, params) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "template_literal",
|
|||
|
|
parts,
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _lazy(Class2, getter) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "lazy",
|
|||
|
|
getter
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _promise(Class2, innerType) {
|
|||
|
|
return new Class2({
|
|||
|
|
type: "promise",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function _custom(Class2, fn, _params) {
|
|||
|
|
const norm = normalizeParams(_params);
|
|||
|
|
norm.abort ?? (norm.abort = true);
|
|||
|
|
const schema = new Class2({
|
|||
|
|
type: "custom",
|
|||
|
|
check: "custom",
|
|||
|
|
fn,
|
|||
|
|
...norm
|
|||
|
|
});
|
|||
|
|
return schema;
|
|||
|
|
}
|
|||
|
|
function _refine(Class2, fn, _params) {
|
|||
|
|
const schema = new Class2({
|
|||
|
|
type: "custom",
|
|||
|
|
check: "custom",
|
|||
|
|
fn,
|
|||
|
|
...normalizeParams(_params)
|
|||
|
|
});
|
|||
|
|
return schema;
|
|||
|
|
}
|
|||
|
|
function _superRefine(fn) {
|
|||
|
|
const ch = _check((payload) => {
|
|||
|
|
payload.addIssue = (issue2) => {
|
|||
|
|
if (typeof issue2 === "string") {
|
|||
|
|
payload.issues.push(issue(issue2, payload.value, ch._zod.def));
|
|||
|
|
} else {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.fatal)
|
|||
|
|
_issue.continue = false;
|
|||
|
|
_issue.code ?? (_issue.code = "custom");
|
|||
|
|
_issue.input ?? (_issue.input = payload.value);
|
|||
|
|
_issue.inst ?? (_issue.inst = ch);
|
|||
|
|
_issue.continue ?? (_issue.continue = !ch._zod.def.abort);
|
|||
|
|
payload.issues.push(issue(_issue));
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
return fn(payload.value, payload);
|
|||
|
|
});
|
|||
|
|
return ch;
|
|||
|
|
}
|
|||
|
|
function _check(fn, params) {
|
|||
|
|
const ch = new $ZodCheck({
|
|||
|
|
check: "custom",
|
|||
|
|
...normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
ch._zod.check = fn;
|
|||
|
|
return ch;
|
|||
|
|
}
|
|||
|
|
function describe(description) {
|
|||
|
|
const ch = new $ZodCheck({ check: "describe" });
|
|||
|
|
ch._zod.onattach = [
|
|||
|
|
(inst) => {
|
|||
|
|
const existing = globalRegistry.get(inst) ?? {};
|
|||
|
|
globalRegistry.add(inst, { ...existing, description });
|
|||
|
|
}
|
|||
|
|
];
|
|||
|
|
ch._zod.check = () => {
|
|||
|
|
};
|
|||
|
|
return ch;
|
|||
|
|
}
|
|||
|
|
function meta(metadata) {
|
|||
|
|
const ch = new $ZodCheck({ check: "meta" });
|
|||
|
|
ch._zod.onattach = [
|
|||
|
|
(inst) => {
|
|||
|
|
const existing = globalRegistry.get(inst) ?? {};
|
|||
|
|
globalRegistry.add(inst, { ...existing, ...metadata });
|
|||
|
|
}
|
|||
|
|
];
|
|||
|
|
ch._zod.check = () => {
|
|||
|
|
};
|
|||
|
|
return ch;
|
|||
|
|
}
|
|||
|
|
function _stringbool(Classes, _params) {
|
|||
|
|
const params = normalizeParams(_params);
|
|||
|
|
let truthyArray = params.truthy ?? ["true", "1", "yes", "on", "y", "enabled"];
|
|||
|
|
let falsyArray = params.falsy ?? ["false", "0", "no", "off", "n", "disabled"];
|
|||
|
|
if (params.case !== "sensitive") {
|
|||
|
|
truthyArray = truthyArray.map((v) => typeof v === "string" ? v.toLowerCase() : v);
|
|||
|
|
falsyArray = falsyArray.map((v) => typeof v === "string" ? v.toLowerCase() : v);
|
|||
|
|
}
|
|||
|
|
const truthySet = new Set(truthyArray);
|
|||
|
|
const falsySet = new Set(falsyArray);
|
|||
|
|
const _Codec = Classes.Codec ?? $ZodCodec;
|
|||
|
|
const _Boolean = Classes.Boolean ?? $ZodBoolean;
|
|||
|
|
const _String = Classes.String ?? $ZodString;
|
|||
|
|
const stringSchema = new _String({ type: "string", error: params.error });
|
|||
|
|
const booleanSchema = new _Boolean({ type: "boolean", error: params.error });
|
|||
|
|
const codec2 = new _Codec({
|
|||
|
|
type: "pipe",
|
|||
|
|
in: stringSchema,
|
|||
|
|
out: booleanSchema,
|
|||
|
|
transform: ((input, payload) => {
|
|||
|
|
let data = input;
|
|||
|
|
if (params.case !== "sensitive")
|
|||
|
|
data = data.toLowerCase();
|
|||
|
|
if (truthySet.has(data)) {
|
|||
|
|
return true;
|
|||
|
|
} else if (falsySet.has(data)) {
|
|||
|
|
return false;
|
|||
|
|
} else {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_value",
|
|||
|
|
expected: "stringbool",
|
|||
|
|
values: [...truthySet, ...falsySet],
|
|||
|
|
input: payload.value,
|
|||
|
|
inst: codec2,
|
|||
|
|
continue: false
|
|||
|
|
});
|
|||
|
|
return {};
|
|||
|
|
}
|
|||
|
|
}),
|
|||
|
|
reverseTransform: ((input, _payload) => {
|
|||
|
|
if (input === true) {
|
|||
|
|
return truthyArray[0] || "true";
|
|||
|
|
} else {
|
|||
|
|
return falsyArray[0] || "false";
|
|||
|
|
}
|
|||
|
|
}),
|
|||
|
|
error: params.error
|
|||
|
|
});
|
|||
|
|
return codec2;
|
|||
|
|
}
|
|||
|
|
function _stringFormat(Class2, format, fnOrRegex, _params = {}) {
|
|||
|
|
const params = normalizeParams(_params);
|
|||
|
|
const def = {
|
|||
|
|
...normalizeParams(_params),
|
|||
|
|
check: "string_format",
|
|||
|
|
type: "string",
|
|||
|
|
format,
|
|||
|
|
fn: typeof fnOrRegex === "function" ? fnOrRegex : (val) => fnOrRegex.test(val),
|
|||
|
|
...params
|
|||
|
|
};
|
|||
|
|
if (fnOrRegex instanceof RegExp) {
|
|||
|
|
def.pattern = fnOrRegex;
|
|||
|
|
}
|
|||
|
|
const inst = new Class2(def);
|
|||
|
|
return inst;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/to-json-schema.js
|
|||
|
|
function initializeContext(params) {
|
|||
|
|
let target = params?.target ?? "draft-2020-12";
|
|||
|
|
if (target === "draft-4")
|
|||
|
|
target = "draft-04";
|
|||
|
|
if (target === "draft-7")
|
|||
|
|
target = "draft-07";
|
|||
|
|
return {
|
|||
|
|
processors: params.processors ?? {},
|
|||
|
|
metadataRegistry: params?.metadata ?? globalRegistry,
|
|||
|
|
target,
|
|||
|
|
unrepresentable: params?.unrepresentable ?? "throw",
|
|||
|
|
override: params?.override ?? (() => {
|
|||
|
|
}),
|
|||
|
|
io: params?.io ?? "output",
|
|||
|
|
counter: 0,
|
|||
|
|
seen: /* @__PURE__ */ new Map(),
|
|||
|
|
cycles: params?.cycles ?? "ref",
|
|||
|
|
reused: params?.reused ?? "inline",
|
|||
|
|
external: params?.external ?? void 0
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
function process(schema, ctx, _params = { path: [], schemaPath: [] }) {
|
|||
|
|
var _a2;
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
if (seen) {
|
|||
|
|
seen.count++;
|
|||
|
|
const isCycle = _params.schemaPath.includes(schema);
|
|||
|
|
if (isCycle) {
|
|||
|
|
seen.cycle = _params.path;
|
|||
|
|
}
|
|||
|
|
return seen.schema;
|
|||
|
|
}
|
|||
|
|
const result = { schema: {}, count: 1, cycle: void 0, path: _params.path };
|
|||
|
|
ctx.seen.set(schema, result);
|
|||
|
|
const overrideSchema = schema._zod.toJSONSchema?.();
|
|||
|
|
if (overrideSchema) {
|
|||
|
|
result.schema = overrideSchema;
|
|||
|
|
} else {
|
|||
|
|
const params = {
|
|||
|
|
..._params,
|
|||
|
|
schemaPath: [..._params.schemaPath, schema],
|
|||
|
|
path: _params.path
|
|||
|
|
};
|
|||
|
|
if (schema._zod.processJSONSchema) {
|
|||
|
|
schema._zod.processJSONSchema(ctx, result.schema, params);
|
|||
|
|
} else {
|
|||
|
|
const _json = result.schema;
|
|||
|
|
const processor = ctx.processors[def.type];
|
|||
|
|
if (!processor) {
|
|||
|
|
throw new Error(`[toJSONSchema]: Non-representable type encountered: ${def.type}`);
|
|||
|
|
}
|
|||
|
|
processor(schema, ctx, _json, params);
|
|||
|
|
}
|
|||
|
|
const parent = schema._zod.parent;
|
|||
|
|
if (parent) {
|
|||
|
|
if (!result.ref)
|
|||
|
|
result.ref = parent;
|
|||
|
|
process(parent, ctx, params);
|
|||
|
|
ctx.seen.get(parent).isParent = true;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const meta3 = ctx.metadataRegistry.get(schema);
|
|||
|
|
if (meta3)
|
|||
|
|
Object.assign(result.schema, meta3);
|
|||
|
|
if (ctx.io === "input" && isTransforming(schema)) {
|
|||
|
|
delete result.schema.examples;
|
|||
|
|
delete result.schema.default;
|
|||
|
|
}
|
|||
|
|
if (ctx.io === "input" && result.schema._prefault)
|
|||
|
|
(_a2 = result.schema).default ?? (_a2.default = result.schema._prefault);
|
|||
|
|
delete result.schema._prefault;
|
|||
|
|
const _result = ctx.seen.get(schema);
|
|||
|
|
return _result.schema;
|
|||
|
|
}
|
|||
|
|
function extractDefs(ctx, schema) {
|
|||
|
|
const root = ctx.seen.get(schema);
|
|||
|
|
if (!root)
|
|||
|
|
throw new Error("Unprocessed schema. This is a bug in Zod.");
|
|||
|
|
const idToSchema = /* @__PURE__ */ new Map();
|
|||
|
|
for (const entry of ctx.seen.entries()) {
|
|||
|
|
const id = ctx.metadataRegistry.get(entry[0])?.id;
|
|||
|
|
if (id) {
|
|||
|
|
const existing = idToSchema.get(id);
|
|||
|
|
if (existing && existing !== entry[0]) {
|
|||
|
|
throw new Error(`Duplicate schema id "${id}" detected during JSON Schema conversion. Two different schemas cannot share the same id when converted together.`);
|
|||
|
|
}
|
|||
|
|
idToSchema.set(id, entry[0]);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const makeURI = (entry) => {
|
|||
|
|
const defsSegment = ctx.target === "draft-2020-12" ? "$defs" : "definitions";
|
|||
|
|
if (ctx.external) {
|
|||
|
|
const externalId = ctx.external.registry.get(entry[0])?.id;
|
|||
|
|
const uriGenerator = ctx.external.uri ?? ((id2) => id2);
|
|||
|
|
if (externalId) {
|
|||
|
|
return { ref: uriGenerator(externalId) };
|
|||
|
|
}
|
|||
|
|
const id = entry[1].defId ?? entry[1].schema.id ?? `schema${ctx.counter++}`;
|
|||
|
|
entry[1].defId = id;
|
|||
|
|
return { defId: id, ref: `${uriGenerator("__shared")}#/${defsSegment}/${id}` };
|
|||
|
|
}
|
|||
|
|
if (entry[1] === root) {
|
|||
|
|
return { ref: "#" };
|
|||
|
|
}
|
|||
|
|
const uriPrefix = `#`;
|
|||
|
|
const defUriPrefix = `${uriPrefix}/${defsSegment}/`;
|
|||
|
|
const defId = entry[1].schema.id ?? `__schema${ctx.counter++}`;
|
|||
|
|
return { defId, ref: defUriPrefix + defId };
|
|||
|
|
};
|
|||
|
|
const extractToDef = (entry) => {
|
|||
|
|
if (entry[1].schema.$ref) {
|
|||
|
|
return;
|
|||
|
|
}
|
|||
|
|
const seen = entry[1];
|
|||
|
|
const { ref, defId } = makeURI(entry);
|
|||
|
|
seen.def = { ...seen.schema };
|
|||
|
|
if (defId)
|
|||
|
|
seen.defId = defId;
|
|||
|
|
const schema2 = seen.schema;
|
|||
|
|
for (const key in schema2) {
|
|||
|
|
delete schema2[key];
|
|||
|
|
}
|
|||
|
|
schema2.$ref = ref;
|
|||
|
|
};
|
|||
|
|
if (ctx.cycles === "throw") {
|
|||
|
|
for (const entry of ctx.seen.entries()) {
|
|||
|
|
const seen = entry[1];
|
|||
|
|
if (seen.cycle) {
|
|||
|
|
throw new Error(`Cycle detected: #/${seen.cycle?.join("/")}/<root>
|
|||
|
|
|
|||
|
|
Set the \`cycles\` parameter to \`"ref"\` to resolve cyclical schemas with defs.`);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
for (const entry of ctx.seen.entries()) {
|
|||
|
|
const seen = entry[1];
|
|||
|
|
if (schema === entry[0]) {
|
|||
|
|
extractToDef(entry);
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
if (ctx.external) {
|
|||
|
|
const ext = ctx.external.registry.get(entry[0])?.id;
|
|||
|
|
if (schema !== entry[0] && ext) {
|
|||
|
|
extractToDef(entry);
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const id = ctx.metadataRegistry.get(entry[0])?.id;
|
|||
|
|
if (id) {
|
|||
|
|
extractToDef(entry);
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
if (seen.cycle) {
|
|||
|
|
extractToDef(entry);
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
if (seen.count > 1) {
|
|||
|
|
if (ctx.reused === "ref") {
|
|||
|
|
extractToDef(entry);
|
|||
|
|
continue;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
function finalize(ctx, schema) {
|
|||
|
|
const root = ctx.seen.get(schema);
|
|||
|
|
if (!root)
|
|||
|
|
throw new Error("Unprocessed schema. This is a bug in Zod.");
|
|||
|
|
const flattenRef = (zodSchema) => {
|
|||
|
|
const seen = ctx.seen.get(zodSchema);
|
|||
|
|
if (seen.ref === null)
|
|||
|
|
return;
|
|||
|
|
const schema2 = seen.def ?? seen.schema;
|
|||
|
|
const _cached = { ...schema2 };
|
|||
|
|
const ref = seen.ref;
|
|||
|
|
seen.ref = null;
|
|||
|
|
if (ref) {
|
|||
|
|
flattenRef(ref);
|
|||
|
|
const refSeen = ctx.seen.get(ref);
|
|||
|
|
const refSchema = refSeen.schema;
|
|||
|
|
if (refSchema.$ref && (ctx.target === "draft-07" || ctx.target === "draft-04" || ctx.target === "openapi-3.0")) {
|
|||
|
|
schema2.allOf = schema2.allOf ?? [];
|
|||
|
|
schema2.allOf.push(refSchema);
|
|||
|
|
} else {
|
|||
|
|
Object.assign(schema2, refSchema);
|
|||
|
|
}
|
|||
|
|
Object.assign(schema2, _cached);
|
|||
|
|
const isParentRef = zodSchema._zod.parent === ref;
|
|||
|
|
if (isParentRef) {
|
|||
|
|
for (const key in schema2) {
|
|||
|
|
if (key === "$ref" || key === "allOf")
|
|||
|
|
continue;
|
|||
|
|
if (!(key in _cached)) {
|
|||
|
|
delete schema2[key];
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (refSchema.$ref && refSeen.def) {
|
|||
|
|
for (const key in schema2) {
|
|||
|
|
if (key === "$ref" || key === "allOf")
|
|||
|
|
continue;
|
|||
|
|
if (key in refSeen.def && JSON.stringify(schema2[key]) === JSON.stringify(refSeen.def[key])) {
|
|||
|
|
delete schema2[key];
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const parent = zodSchema._zod.parent;
|
|||
|
|
if (parent && parent !== ref) {
|
|||
|
|
flattenRef(parent);
|
|||
|
|
const parentSeen = ctx.seen.get(parent);
|
|||
|
|
if (parentSeen?.schema.$ref) {
|
|||
|
|
schema2.$ref = parentSeen.schema.$ref;
|
|||
|
|
if (parentSeen.def) {
|
|||
|
|
for (const key in schema2) {
|
|||
|
|
if (key === "$ref" || key === "allOf")
|
|||
|
|
continue;
|
|||
|
|
if (key in parentSeen.def && JSON.stringify(schema2[key]) === JSON.stringify(parentSeen.def[key])) {
|
|||
|
|
delete schema2[key];
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
ctx.override({
|
|||
|
|
zodSchema,
|
|||
|
|
jsonSchema: schema2,
|
|||
|
|
path: seen.path ?? []
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
for (const entry of [...ctx.seen.entries()].reverse()) {
|
|||
|
|
flattenRef(entry[0]);
|
|||
|
|
}
|
|||
|
|
const result = {};
|
|||
|
|
if (ctx.target === "draft-2020-12") {
|
|||
|
|
result.$schema = "https://json-schema.org/draft/2020-12/schema";
|
|||
|
|
} else if (ctx.target === "draft-07") {
|
|||
|
|
result.$schema = "http://json-schema.org/draft-07/schema#";
|
|||
|
|
} else if (ctx.target === "draft-04") {
|
|||
|
|
result.$schema = "http://json-schema.org/draft-04/schema#";
|
|||
|
|
} else if (ctx.target === "openapi-3.0") {
|
|||
|
|
} else {
|
|||
|
|
}
|
|||
|
|
if (ctx.external?.uri) {
|
|||
|
|
const id = ctx.external.registry.get(schema)?.id;
|
|||
|
|
if (!id)
|
|||
|
|
throw new Error("Schema is missing an `id` property");
|
|||
|
|
result.$id = ctx.external.uri(id);
|
|||
|
|
}
|
|||
|
|
Object.assign(result, root.def ?? root.schema);
|
|||
|
|
const defs = ctx.external?.defs ?? {};
|
|||
|
|
for (const entry of ctx.seen.entries()) {
|
|||
|
|
const seen = entry[1];
|
|||
|
|
if (seen.def && seen.defId) {
|
|||
|
|
defs[seen.defId] = seen.def;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (ctx.external) {
|
|||
|
|
} else {
|
|||
|
|
if (Object.keys(defs).length > 0) {
|
|||
|
|
if (ctx.target === "draft-2020-12") {
|
|||
|
|
result.$defs = defs;
|
|||
|
|
} else {
|
|||
|
|
result.definitions = defs;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
try {
|
|||
|
|
const finalized = JSON.parse(JSON.stringify(result));
|
|||
|
|
Object.defineProperty(finalized, "~standard", {
|
|||
|
|
value: {
|
|||
|
|
...schema["~standard"],
|
|||
|
|
jsonSchema: {
|
|||
|
|
input: createStandardJSONSchemaMethod(schema, "input", ctx.processors),
|
|||
|
|
output: createStandardJSONSchemaMethod(schema, "output", ctx.processors)
|
|||
|
|
}
|
|||
|
|
},
|
|||
|
|
enumerable: false,
|
|||
|
|
writable: false
|
|||
|
|
});
|
|||
|
|
return finalized;
|
|||
|
|
} catch (_err) {
|
|||
|
|
throw new Error("Error converting schema to JSON.");
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
function isTransforming(_schema, _ctx) {
|
|||
|
|
const ctx = _ctx ?? { seen: /* @__PURE__ */ new Set() };
|
|||
|
|
if (ctx.seen.has(_schema))
|
|||
|
|
return false;
|
|||
|
|
ctx.seen.add(_schema);
|
|||
|
|
const def = _schema._zod.def;
|
|||
|
|
if (def.type === "transform")
|
|||
|
|
return true;
|
|||
|
|
if (def.type === "array")
|
|||
|
|
return isTransforming(def.element, ctx);
|
|||
|
|
if (def.type === "set")
|
|||
|
|
return isTransforming(def.valueType, ctx);
|
|||
|
|
if (def.type === "lazy")
|
|||
|
|
return isTransforming(def.getter(), ctx);
|
|||
|
|
if (def.type === "promise" || def.type === "optional" || def.type === "nonoptional" || def.type === "nullable" || def.type === "readonly" || def.type === "default" || def.type === "prefault") {
|
|||
|
|
return isTransforming(def.innerType, ctx);
|
|||
|
|
}
|
|||
|
|
if (def.type === "intersection") {
|
|||
|
|
return isTransforming(def.left, ctx) || isTransforming(def.right, ctx);
|
|||
|
|
}
|
|||
|
|
if (def.type === "record" || def.type === "map") {
|
|||
|
|
return isTransforming(def.keyType, ctx) || isTransforming(def.valueType, ctx);
|
|||
|
|
}
|
|||
|
|
if (def.type === "pipe") {
|
|||
|
|
return isTransforming(def.in, ctx) || isTransforming(def.out, ctx);
|
|||
|
|
}
|
|||
|
|
if (def.type === "object") {
|
|||
|
|
for (const key in def.shape) {
|
|||
|
|
if (isTransforming(def.shape[key], ctx))
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
if (def.type === "union") {
|
|||
|
|
for (const option of def.options) {
|
|||
|
|
if (isTransforming(option, ctx))
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
if (def.type === "tuple") {
|
|||
|
|
for (const item of def.items) {
|
|||
|
|
if (isTransforming(item, ctx))
|
|||
|
|
return true;
|
|||
|
|
}
|
|||
|
|
if (def.rest && isTransforming(def.rest, ctx))
|
|||
|
|
return true;
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
return false;
|
|||
|
|
}
|
|||
|
|
var createToJSONSchemaMethod = (schema, processors = {}) => (params) => {
|
|||
|
|
const ctx = initializeContext({ ...params, processors });
|
|||
|
|
process(schema, ctx);
|
|||
|
|
extractDefs(ctx, schema);
|
|||
|
|
return finalize(ctx, schema);
|
|||
|
|
};
|
|||
|
|
var createStandardJSONSchemaMethod = (schema, io, processors = {}) => (params) => {
|
|||
|
|
const { libraryOptions, target } = params ?? {};
|
|||
|
|
const ctx = initializeContext({ ...libraryOptions ?? {}, target, io, processors });
|
|||
|
|
process(schema, ctx);
|
|||
|
|
extractDefs(ctx, schema);
|
|||
|
|
return finalize(ctx, schema);
|
|||
|
|
};
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/json-schema-processors.js
|
|||
|
|
var formatMap = {
|
|||
|
|
guid: "uuid",
|
|||
|
|
url: "uri",
|
|||
|
|
datetime: "date-time",
|
|||
|
|
json_string: "json-string",
|
|||
|
|
regex: ""
|
|||
|
|
// do not set
|
|||
|
|
};
|
|||
|
|
var stringProcessor = (schema, ctx, _json, _params) => {
|
|||
|
|
const json2 = _json;
|
|||
|
|
json2.type = "string";
|
|||
|
|
const { minimum, maximum, format, patterns, contentEncoding } = schema._zod.bag;
|
|||
|
|
if (typeof minimum === "number")
|
|||
|
|
json2.minLength = minimum;
|
|||
|
|
if (typeof maximum === "number")
|
|||
|
|
json2.maxLength = maximum;
|
|||
|
|
if (format) {
|
|||
|
|
json2.format = formatMap[format] ?? format;
|
|||
|
|
if (json2.format === "")
|
|||
|
|
delete json2.format;
|
|||
|
|
if (format === "time") {
|
|||
|
|
delete json2.format;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (contentEncoding)
|
|||
|
|
json2.contentEncoding = contentEncoding;
|
|||
|
|
if (patterns && patterns.size > 0) {
|
|||
|
|
const regexes = [...patterns];
|
|||
|
|
if (regexes.length === 1)
|
|||
|
|
json2.pattern = regexes[0].source;
|
|||
|
|
else if (regexes.length > 1) {
|
|||
|
|
json2.allOf = [
|
|||
|
|
...regexes.map((regex) => ({
|
|||
|
|
...ctx.target === "draft-07" || ctx.target === "draft-04" || ctx.target === "openapi-3.0" ? { type: "string" } : {},
|
|||
|
|
pattern: regex.source
|
|||
|
|
}))
|
|||
|
|
];
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var numberProcessor = (schema, ctx, _json, _params) => {
|
|||
|
|
const json2 = _json;
|
|||
|
|
const { minimum, maximum, format, multipleOf, exclusiveMaximum, exclusiveMinimum } = schema._zod.bag;
|
|||
|
|
if (typeof format === "string" && format.includes("int"))
|
|||
|
|
json2.type = "integer";
|
|||
|
|
else
|
|||
|
|
json2.type = "number";
|
|||
|
|
if (typeof exclusiveMinimum === "number") {
|
|||
|
|
if (ctx.target === "draft-04" || ctx.target === "openapi-3.0") {
|
|||
|
|
json2.minimum = exclusiveMinimum;
|
|||
|
|
json2.exclusiveMinimum = true;
|
|||
|
|
} else {
|
|||
|
|
json2.exclusiveMinimum = exclusiveMinimum;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (typeof minimum === "number") {
|
|||
|
|
json2.minimum = minimum;
|
|||
|
|
if (typeof exclusiveMinimum === "number" && ctx.target !== "draft-04") {
|
|||
|
|
if (exclusiveMinimum >= minimum)
|
|||
|
|
delete json2.minimum;
|
|||
|
|
else
|
|||
|
|
delete json2.exclusiveMinimum;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (typeof exclusiveMaximum === "number") {
|
|||
|
|
if (ctx.target === "draft-04" || ctx.target === "openapi-3.0") {
|
|||
|
|
json2.maximum = exclusiveMaximum;
|
|||
|
|
json2.exclusiveMaximum = true;
|
|||
|
|
} else {
|
|||
|
|
json2.exclusiveMaximum = exclusiveMaximum;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (typeof maximum === "number") {
|
|||
|
|
json2.maximum = maximum;
|
|||
|
|
if (typeof exclusiveMaximum === "number" && ctx.target !== "draft-04") {
|
|||
|
|
if (exclusiveMaximum <= maximum)
|
|||
|
|
delete json2.maximum;
|
|||
|
|
else
|
|||
|
|
delete json2.exclusiveMaximum;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (typeof multipleOf === "number")
|
|||
|
|
json2.multipleOf = multipleOf;
|
|||
|
|
};
|
|||
|
|
var booleanProcessor = (_schema, _ctx, json2, _params) => {
|
|||
|
|
json2.type = "boolean";
|
|||
|
|
};
|
|||
|
|
var bigintProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("BigInt cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var symbolProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Symbols cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var nullProcessor = (_schema, ctx, json2, _params) => {
|
|||
|
|
if (ctx.target === "openapi-3.0") {
|
|||
|
|
json2.type = "string";
|
|||
|
|
json2.nullable = true;
|
|||
|
|
json2.enum = [null];
|
|||
|
|
} else {
|
|||
|
|
json2.type = "null";
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var undefinedProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Undefined cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var voidProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Void cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var neverProcessor = (_schema, _ctx, json2, _params) => {
|
|||
|
|
json2.not = {};
|
|||
|
|
};
|
|||
|
|
var anyProcessor = (_schema, _ctx, _json, _params) => {
|
|||
|
|
};
|
|||
|
|
var unknownProcessor = (_schema, _ctx, _json, _params) => {
|
|||
|
|
};
|
|||
|
|
var dateProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Date cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var enumProcessor = (schema, _ctx, json2, _params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
const values = getEnumValues(def.entries);
|
|||
|
|
if (values.every((v) => typeof v === "number"))
|
|||
|
|
json2.type = "number";
|
|||
|
|
if (values.every((v) => typeof v === "string"))
|
|||
|
|
json2.type = "string";
|
|||
|
|
json2.enum = values;
|
|||
|
|
};
|
|||
|
|
var literalProcessor = (schema, ctx, json2, _params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
const vals = [];
|
|||
|
|
for (const val of def.values) {
|
|||
|
|
if (val === void 0) {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Literal `undefined` cannot be represented in JSON Schema");
|
|||
|
|
} else {
|
|||
|
|
}
|
|||
|
|
} else if (typeof val === "bigint") {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("BigInt literals cannot be represented in JSON Schema");
|
|||
|
|
} else {
|
|||
|
|
vals.push(Number(val));
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
vals.push(val);
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (vals.length === 0) {
|
|||
|
|
} else if (vals.length === 1) {
|
|||
|
|
const val = vals[0];
|
|||
|
|
json2.type = val === null ? "null" : typeof val;
|
|||
|
|
if (ctx.target === "draft-04" || ctx.target === "openapi-3.0") {
|
|||
|
|
json2.enum = [val];
|
|||
|
|
} else {
|
|||
|
|
json2.const = val;
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
if (vals.every((v) => typeof v === "number"))
|
|||
|
|
json2.type = "number";
|
|||
|
|
if (vals.every((v) => typeof v === "string"))
|
|||
|
|
json2.type = "string";
|
|||
|
|
if (vals.every((v) => typeof v === "boolean"))
|
|||
|
|
json2.type = "boolean";
|
|||
|
|
if (vals.every((v) => v === null))
|
|||
|
|
json2.type = "null";
|
|||
|
|
json2.enum = vals;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var nanProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("NaN cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var templateLiteralProcessor = (schema, _ctx, json2, _params) => {
|
|||
|
|
const _json = json2;
|
|||
|
|
const pattern = schema._zod.pattern;
|
|||
|
|
if (!pattern)
|
|||
|
|
throw new Error("Pattern not found in template literal");
|
|||
|
|
_json.type = "string";
|
|||
|
|
_json.pattern = pattern.source;
|
|||
|
|
};
|
|||
|
|
var fileProcessor = (schema, _ctx, json2, _params) => {
|
|||
|
|
const _json = json2;
|
|||
|
|
const file2 = {
|
|||
|
|
type: "string",
|
|||
|
|
format: "binary",
|
|||
|
|
contentEncoding: "binary"
|
|||
|
|
};
|
|||
|
|
const { minimum, maximum, mime } = schema._zod.bag;
|
|||
|
|
if (minimum !== void 0)
|
|||
|
|
file2.minLength = minimum;
|
|||
|
|
if (maximum !== void 0)
|
|||
|
|
file2.maxLength = maximum;
|
|||
|
|
if (mime) {
|
|||
|
|
if (mime.length === 1) {
|
|||
|
|
file2.contentMediaType = mime[0];
|
|||
|
|
Object.assign(_json, file2);
|
|||
|
|
} else {
|
|||
|
|
Object.assign(_json, file2);
|
|||
|
|
_json.anyOf = mime.map((m) => ({ contentMediaType: m }));
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
Object.assign(_json, file2);
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var successProcessor = (_schema, _ctx, json2, _params) => {
|
|||
|
|
json2.type = "boolean";
|
|||
|
|
};
|
|||
|
|
var customProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Custom types cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var functionProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Function types cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var transformProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Transforms cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var mapProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Map cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var setProcessor = (_schema, ctx, _json, _params) => {
|
|||
|
|
if (ctx.unrepresentable === "throw") {
|
|||
|
|
throw new Error("Set cannot be represented in JSON Schema");
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var arrayProcessor = (schema, ctx, _json, params) => {
|
|||
|
|
const json2 = _json;
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
const { minimum, maximum } = schema._zod.bag;
|
|||
|
|
if (typeof minimum === "number")
|
|||
|
|
json2.minItems = minimum;
|
|||
|
|
if (typeof maximum === "number")
|
|||
|
|
json2.maxItems = maximum;
|
|||
|
|
json2.type = "array";
|
|||
|
|
json2.items = process(def.element, ctx, { ...params, path: [...params.path, "items"] });
|
|||
|
|
};
|
|||
|
|
var objectProcessor = (schema, ctx, _json, params) => {
|
|||
|
|
const json2 = _json;
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
json2.type = "object";
|
|||
|
|
json2.properties = {};
|
|||
|
|
const shape = def.shape;
|
|||
|
|
for (const key in shape) {
|
|||
|
|
json2.properties[key] = process(shape[key], ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, "properties", key]
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
const allKeys = new Set(Object.keys(shape));
|
|||
|
|
const requiredKeys = new Set([...allKeys].filter((key) => {
|
|||
|
|
const v = def.shape[key]._zod;
|
|||
|
|
if (ctx.io === "input") {
|
|||
|
|
return v.optin === void 0;
|
|||
|
|
} else {
|
|||
|
|
return v.optout === void 0;
|
|||
|
|
}
|
|||
|
|
}));
|
|||
|
|
if (requiredKeys.size > 0) {
|
|||
|
|
json2.required = Array.from(requiredKeys);
|
|||
|
|
}
|
|||
|
|
if (def.catchall?._zod.def.type === "never") {
|
|||
|
|
json2.additionalProperties = false;
|
|||
|
|
} else if (!def.catchall) {
|
|||
|
|
if (ctx.io === "output")
|
|||
|
|
json2.additionalProperties = false;
|
|||
|
|
} else if (def.catchall) {
|
|||
|
|
json2.additionalProperties = process(def.catchall, ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, "additionalProperties"]
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var unionProcessor = (schema, ctx, json2, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
const isExclusive = def.inclusive === false;
|
|||
|
|
const options = def.options.map((x, i) => process(x, ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, isExclusive ? "oneOf" : "anyOf", i]
|
|||
|
|
}));
|
|||
|
|
if (isExclusive) {
|
|||
|
|
json2.oneOf = options;
|
|||
|
|
} else {
|
|||
|
|
json2.anyOf = options;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var intersectionProcessor = (schema, ctx, json2, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
const a = process(def.left, ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, "allOf", 0]
|
|||
|
|
});
|
|||
|
|
const b = process(def.right, ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, "allOf", 1]
|
|||
|
|
});
|
|||
|
|
const isSimpleIntersection = (val) => "allOf" in val && Object.keys(val).length === 1;
|
|||
|
|
const allOf = [
|
|||
|
|
...isSimpleIntersection(a) ? a.allOf : [a],
|
|||
|
|
...isSimpleIntersection(b) ? b.allOf : [b]
|
|||
|
|
];
|
|||
|
|
json2.allOf = allOf;
|
|||
|
|
};
|
|||
|
|
var tupleProcessor = (schema, ctx, _json, params) => {
|
|||
|
|
const json2 = _json;
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
json2.type = "array";
|
|||
|
|
const prefixPath = ctx.target === "draft-2020-12" ? "prefixItems" : "items";
|
|||
|
|
const restPath = ctx.target === "draft-2020-12" ? "items" : ctx.target === "openapi-3.0" ? "items" : "additionalItems";
|
|||
|
|
const prefixItems = def.items.map((x, i) => process(x, ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, prefixPath, i]
|
|||
|
|
}));
|
|||
|
|
const rest = def.rest ? process(def.rest, ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, restPath, ...ctx.target === "openapi-3.0" ? [def.items.length] : []]
|
|||
|
|
}) : null;
|
|||
|
|
if (ctx.target === "draft-2020-12") {
|
|||
|
|
json2.prefixItems = prefixItems;
|
|||
|
|
if (rest) {
|
|||
|
|
json2.items = rest;
|
|||
|
|
}
|
|||
|
|
} else if (ctx.target === "openapi-3.0") {
|
|||
|
|
json2.items = {
|
|||
|
|
anyOf: prefixItems
|
|||
|
|
};
|
|||
|
|
if (rest) {
|
|||
|
|
json2.items.anyOf.push(rest);
|
|||
|
|
}
|
|||
|
|
json2.minItems = prefixItems.length;
|
|||
|
|
if (!rest) {
|
|||
|
|
json2.maxItems = prefixItems.length;
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
json2.items = prefixItems;
|
|||
|
|
if (rest) {
|
|||
|
|
json2.additionalItems = rest;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const { minimum, maximum } = schema._zod.bag;
|
|||
|
|
if (typeof minimum === "number")
|
|||
|
|
json2.minItems = minimum;
|
|||
|
|
if (typeof maximum === "number")
|
|||
|
|
json2.maxItems = maximum;
|
|||
|
|
};
|
|||
|
|
var recordProcessor = (schema, ctx, _json, params) => {
|
|||
|
|
const json2 = _json;
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
json2.type = "object";
|
|||
|
|
const keyType = def.keyType;
|
|||
|
|
const keyBag = keyType._zod.bag;
|
|||
|
|
const patterns = keyBag?.patterns;
|
|||
|
|
if (def.mode === "loose" && patterns && patterns.size > 0) {
|
|||
|
|
const valueSchema = process(def.valueType, ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, "patternProperties", "*"]
|
|||
|
|
});
|
|||
|
|
json2.patternProperties = {};
|
|||
|
|
for (const pattern of patterns) {
|
|||
|
|
json2.patternProperties[pattern.source] = valueSchema;
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
if (ctx.target === "draft-07" || ctx.target === "draft-2020-12") {
|
|||
|
|
json2.propertyNames = process(def.keyType, ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, "propertyNames"]
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
json2.additionalProperties = process(def.valueType, ctx, {
|
|||
|
|
...params,
|
|||
|
|
path: [...params.path, "additionalProperties"]
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
const keyValues = keyType._zod.values;
|
|||
|
|
if (keyValues) {
|
|||
|
|
const validKeyValues = [...keyValues].filter((v) => typeof v === "string" || typeof v === "number");
|
|||
|
|
if (validKeyValues.length > 0) {
|
|||
|
|
json2.required = validKeyValues;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var nullableProcessor = (schema, ctx, json2, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
const inner = process(def.innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
if (ctx.target === "openapi-3.0") {
|
|||
|
|
seen.ref = def.innerType;
|
|||
|
|
json2.nullable = true;
|
|||
|
|
} else {
|
|||
|
|
json2.anyOf = [inner, { type: "null" }];
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
var nonoptionalProcessor = (schema, ctx, _json, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
process(def.innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
seen.ref = def.innerType;
|
|||
|
|
};
|
|||
|
|
var defaultProcessor = (schema, ctx, json2, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
process(def.innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
seen.ref = def.innerType;
|
|||
|
|
json2.default = JSON.parse(JSON.stringify(def.defaultValue));
|
|||
|
|
};
|
|||
|
|
var prefaultProcessor = (schema, ctx, json2, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
process(def.innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
seen.ref = def.innerType;
|
|||
|
|
if (ctx.io === "input")
|
|||
|
|
json2._prefault = JSON.parse(JSON.stringify(def.defaultValue));
|
|||
|
|
};
|
|||
|
|
var catchProcessor = (schema, ctx, json2, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
process(def.innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
seen.ref = def.innerType;
|
|||
|
|
let catchValue;
|
|||
|
|
try {
|
|||
|
|
catchValue = def.catchValue(void 0);
|
|||
|
|
} catch {
|
|||
|
|
throw new Error("Dynamic catch values are not supported in JSON Schema");
|
|||
|
|
}
|
|||
|
|
json2.default = catchValue;
|
|||
|
|
};
|
|||
|
|
var pipeProcessor = (schema, ctx, _json, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
const innerType = ctx.io === "input" ? def.in._zod.def.type === "transform" ? def.out : def.in : def.out;
|
|||
|
|
process(innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
seen.ref = innerType;
|
|||
|
|
};
|
|||
|
|
var readonlyProcessor = (schema, ctx, json2, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
process(def.innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
seen.ref = def.innerType;
|
|||
|
|
json2.readOnly = true;
|
|||
|
|
};
|
|||
|
|
var promiseProcessor = (schema, ctx, _json, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
process(def.innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
seen.ref = def.innerType;
|
|||
|
|
};
|
|||
|
|
var optionalProcessor = (schema, ctx, _json, params) => {
|
|||
|
|
const def = schema._zod.def;
|
|||
|
|
process(def.innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
seen.ref = def.innerType;
|
|||
|
|
};
|
|||
|
|
var lazyProcessor = (schema, ctx, _json, params) => {
|
|||
|
|
const innerType = schema._zod.innerType;
|
|||
|
|
process(innerType, ctx, params);
|
|||
|
|
const seen = ctx.seen.get(schema);
|
|||
|
|
seen.ref = innerType;
|
|||
|
|
};
|
|||
|
|
var allProcessors = {
|
|||
|
|
string: stringProcessor,
|
|||
|
|
number: numberProcessor,
|
|||
|
|
boolean: booleanProcessor,
|
|||
|
|
bigint: bigintProcessor,
|
|||
|
|
symbol: symbolProcessor,
|
|||
|
|
null: nullProcessor,
|
|||
|
|
undefined: undefinedProcessor,
|
|||
|
|
void: voidProcessor,
|
|||
|
|
never: neverProcessor,
|
|||
|
|
any: anyProcessor,
|
|||
|
|
unknown: unknownProcessor,
|
|||
|
|
date: dateProcessor,
|
|||
|
|
enum: enumProcessor,
|
|||
|
|
literal: literalProcessor,
|
|||
|
|
nan: nanProcessor,
|
|||
|
|
template_literal: templateLiteralProcessor,
|
|||
|
|
file: fileProcessor,
|
|||
|
|
success: successProcessor,
|
|||
|
|
custom: customProcessor,
|
|||
|
|
function: functionProcessor,
|
|||
|
|
transform: transformProcessor,
|
|||
|
|
map: mapProcessor,
|
|||
|
|
set: setProcessor,
|
|||
|
|
array: arrayProcessor,
|
|||
|
|
object: objectProcessor,
|
|||
|
|
union: unionProcessor,
|
|||
|
|
intersection: intersectionProcessor,
|
|||
|
|
tuple: tupleProcessor,
|
|||
|
|
record: recordProcessor,
|
|||
|
|
nullable: nullableProcessor,
|
|||
|
|
nonoptional: nonoptionalProcessor,
|
|||
|
|
default: defaultProcessor,
|
|||
|
|
prefault: prefaultProcessor,
|
|||
|
|
catch: catchProcessor,
|
|||
|
|
pipe: pipeProcessor,
|
|||
|
|
readonly: readonlyProcessor,
|
|||
|
|
promise: promiseProcessor,
|
|||
|
|
optional: optionalProcessor,
|
|||
|
|
lazy: lazyProcessor
|
|||
|
|
};
|
|||
|
|
function toJSONSchema(input, params) {
|
|||
|
|
if ("_idmap" in input) {
|
|||
|
|
const registry2 = input;
|
|||
|
|
const ctx2 = initializeContext({ ...params, processors: allProcessors });
|
|||
|
|
const defs = {};
|
|||
|
|
for (const entry of registry2._idmap.entries()) {
|
|||
|
|
const [_, schema] = entry;
|
|||
|
|
process(schema, ctx2);
|
|||
|
|
}
|
|||
|
|
const schemas = {};
|
|||
|
|
const external = {
|
|||
|
|
registry: registry2,
|
|||
|
|
uri: params?.uri,
|
|||
|
|
defs
|
|||
|
|
};
|
|||
|
|
ctx2.external = external;
|
|||
|
|
for (const entry of registry2._idmap.entries()) {
|
|||
|
|
const [key, schema] = entry;
|
|||
|
|
extractDefs(ctx2, schema);
|
|||
|
|
schemas[key] = finalize(ctx2, schema);
|
|||
|
|
}
|
|||
|
|
if (Object.keys(defs).length > 0) {
|
|||
|
|
const defsSegment = ctx2.target === "draft-2020-12" ? "$defs" : "definitions";
|
|||
|
|
schemas.__shared = {
|
|||
|
|
[defsSegment]: defs
|
|||
|
|
};
|
|||
|
|
}
|
|||
|
|
return { schemas };
|
|||
|
|
}
|
|||
|
|
const ctx = initializeContext({ ...params, processors: allProcessors });
|
|||
|
|
process(input, ctx);
|
|||
|
|
extractDefs(ctx, input);
|
|||
|
|
return finalize(ctx, input);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/json-schema-generator.js
|
|||
|
|
var JSONSchemaGenerator = class {
|
|||
|
|
/** @deprecated Access via ctx instead */
|
|||
|
|
get metadataRegistry() {
|
|||
|
|
return this.ctx.metadataRegistry;
|
|||
|
|
}
|
|||
|
|
/** @deprecated Access via ctx instead */
|
|||
|
|
get target() {
|
|||
|
|
return this.ctx.target;
|
|||
|
|
}
|
|||
|
|
/** @deprecated Access via ctx instead */
|
|||
|
|
get unrepresentable() {
|
|||
|
|
return this.ctx.unrepresentable;
|
|||
|
|
}
|
|||
|
|
/** @deprecated Access via ctx instead */
|
|||
|
|
get override() {
|
|||
|
|
return this.ctx.override;
|
|||
|
|
}
|
|||
|
|
/** @deprecated Access via ctx instead */
|
|||
|
|
get io() {
|
|||
|
|
return this.ctx.io;
|
|||
|
|
}
|
|||
|
|
/** @deprecated Access via ctx instead */
|
|||
|
|
get counter() {
|
|||
|
|
return this.ctx.counter;
|
|||
|
|
}
|
|||
|
|
set counter(value) {
|
|||
|
|
this.ctx.counter = value;
|
|||
|
|
}
|
|||
|
|
/** @deprecated Access via ctx instead */
|
|||
|
|
get seen() {
|
|||
|
|
return this.ctx.seen;
|
|||
|
|
}
|
|||
|
|
constructor(params) {
|
|||
|
|
let normalizedTarget = params?.target ?? "draft-2020-12";
|
|||
|
|
if (normalizedTarget === "draft-4")
|
|||
|
|
normalizedTarget = "draft-04";
|
|||
|
|
if (normalizedTarget === "draft-7")
|
|||
|
|
normalizedTarget = "draft-07";
|
|||
|
|
this.ctx = initializeContext({
|
|||
|
|
processors: allProcessors,
|
|||
|
|
target: normalizedTarget,
|
|||
|
|
...params?.metadata && { metadata: params.metadata },
|
|||
|
|
...params?.unrepresentable && { unrepresentable: params.unrepresentable },
|
|||
|
|
...params?.override && { override: params.override },
|
|||
|
|
...params?.io && { io: params.io }
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
/**
|
|||
|
|
* Process a schema to prepare it for JSON Schema generation.
|
|||
|
|
* This must be called before emit().
|
|||
|
|
*/
|
|||
|
|
process(schema, _params = { path: [], schemaPath: [] }) {
|
|||
|
|
return process(schema, this.ctx, _params);
|
|||
|
|
}
|
|||
|
|
/**
|
|||
|
|
* Emit the final JSON Schema after processing.
|
|||
|
|
* Must call process() first.
|
|||
|
|
*/
|
|||
|
|
emit(schema, _params) {
|
|||
|
|
if (_params) {
|
|||
|
|
if (_params.cycles)
|
|||
|
|
this.ctx.cycles = _params.cycles;
|
|||
|
|
if (_params.reused)
|
|||
|
|
this.ctx.reused = _params.reused;
|
|||
|
|
if (_params.external)
|
|||
|
|
this.ctx.external = _params.external;
|
|||
|
|
}
|
|||
|
|
extractDefs(this.ctx, schema);
|
|||
|
|
const result = finalize(this.ctx, schema);
|
|||
|
|
const { "~standard": _, ...plainResult } = result;
|
|||
|
|
return plainResult;
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/core/json-schema.js
|
|||
|
|
var json_schema_exports = {};
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/schemas.js
|
|||
|
|
var schemas_exports2 = {};
|
|||
|
|
__export(schemas_exports2, {
|
|||
|
|
ZodAny: () => ZodAny,
|
|||
|
|
ZodArray: () => ZodArray,
|
|||
|
|
ZodBase64: () => ZodBase64,
|
|||
|
|
ZodBase64URL: () => ZodBase64URL,
|
|||
|
|
ZodBigInt: () => ZodBigInt,
|
|||
|
|
ZodBigIntFormat: () => ZodBigIntFormat,
|
|||
|
|
ZodBoolean: () => ZodBoolean,
|
|||
|
|
ZodCIDRv4: () => ZodCIDRv4,
|
|||
|
|
ZodCIDRv6: () => ZodCIDRv6,
|
|||
|
|
ZodCUID: () => ZodCUID,
|
|||
|
|
ZodCUID2: () => ZodCUID2,
|
|||
|
|
ZodCatch: () => ZodCatch,
|
|||
|
|
ZodCodec: () => ZodCodec,
|
|||
|
|
ZodCustom: () => ZodCustom,
|
|||
|
|
ZodCustomStringFormat: () => ZodCustomStringFormat,
|
|||
|
|
ZodDate: () => ZodDate,
|
|||
|
|
ZodDefault: () => ZodDefault,
|
|||
|
|
ZodDiscriminatedUnion: () => ZodDiscriminatedUnion,
|
|||
|
|
ZodE164: () => ZodE164,
|
|||
|
|
ZodEmail: () => ZodEmail,
|
|||
|
|
ZodEmoji: () => ZodEmoji,
|
|||
|
|
ZodEnum: () => ZodEnum,
|
|||
|
|
ZodExactOptional: () => ZodExactOptional,
|
|||
|
|
ZodFile: () => ZodFile,
|
|||
|
|
ZodFunction: () => ZodFunction,
|
|||
|
|
ZodGUID: () => ZodGUID,
|
|||
|
|
ZodIPv4: () => ZodIPv4,
|
|||
|
|
ZodIPv6: () => ZodIPv6,
|
|||
|
|
ZodIntersection: () => ZodIntersection,
|
|||
|
|
ZodJWT: () => ZodJWT,
|
|||
|
|
ZodKSUID: () => ZodKSUID,
|
|||
|
|
ZodLazy: () => ZodLazy,
|
|||
|
|
ZodLiteral: () => ZodLiteral,
|
|||
|
|
ZodMAC: () => ZodMAC,
|
|||
|
|
ZodMap: () => ZodMap,
|
|||
|
|
ZodNaN: () => ZodNaN,
|
|||
|
|
ZodNanoID: () => ZodNanoID,
|
|||
|
|
ZodNever: () => ZodNever,
|
|||
|
|
ZodNonOptional: () => ZodNonOptional,
|
|||
|
|
ZodNull: () => ZodNull,
|
|||
|
|
ZodNullable: () => ZodNullable,
|
|||
|
|
ZodNumber: () => ZodNumber,
|
|||
|
|
ZodNumberFormat: () => ZodNumberFormat,
|
|||
|
|
ZodObject: () => ZodObject,
|
|||
|
|
ZodOptional: () => ZodOptional,
|
|||
|
|
ZodPipe: () => ZodPipe,
|
|||
|
|
ZodPrefault: () => ZodPrefault,
|
|||
|
|
ZodPromise: () => ZodPromise,
|
|||
|
|
ZodReadonly: () => ZodReadonly,
|
|||
|
|
ZodRecord: () => ZodRecord,
|
|||
|
|
ZodSet: () => ZodSet,
|
|||
|
|
ZodString: () => ZodString,
|
|||
|
|
ZodStringFormat: () => ZodStringFormat,
|
|||
|
|
ZodSuccess: () => ZodSuccess,
|
|||
|
|
ZodSymbol: () => ZodSymbol,
|
|||
|
|
ZodTemplateLiteral: () => ZodTemplateLiteral,
|
|||
|
|
ZodTransform: () => ZodTransform,
|
|||
|
|
ZodTuple: () => ZodTuple,
|
|||
|
|
ZodType: () => ZodType,
|
|||
|
|
ZodULID: () => ZodULID,
|
|||
|
|
ZodURL: () => ZodURL,
|
|||
|
|
ZodUUID: () => ZodUUID,
|
|||
|
|
ZodUndefined: () => ZodUndefined,
|
|||
|
|
ZodUnion: () => ZodUnion,
|
|||
|
|
ZodUnknown: () => ZodUnknown,
|
|||
|
|
ZodVoid: () => ZodVoid,
|
|||
|
|
ZodXID: () => ZodXID,
|
|||
|
|
ZodXor: () => ZodXor,
|
|||
|
|
_ZodString: () => _ZodString,
|
|||
|
|
_default: () => _default2,
|
|||
|
|
_function: () => _function,
|
|||
|
|
any: () => any,
|
|||
|
|
array: () => array,
|
|||
|
|
base64: () => base642,
|
|||
|
|
base64url: () => base64url2,
|
|||
|
|
bigint: () => bigint2,
|
|||
|
|
boolean: () => boolean2,
|
|||
|
|
catch: () => _catch2,
|
|||
|
|
check: () => check,
|
|||
|
|
cidrv4: () => cidrv42,
|
|||
|
|
cidrv6: () => cidrv62,
|
|||
|
|
codec: () => codec,
|
|||
|
|
cuid: () => cuid3,
|
|||
|
|
cuid2: () => cuid22,
|
|||
|
|
custom: () => custom,
|
|||
|
|
date: () => date3,
|
|||
|
|
describe: () => describe2,
|
|||
|
|
discriminatedUnion: () => discriminatedUnion,
|
|||
|
|
e164: () => e1642,
|
|||
|
|
email: () => email2,
|
|||
|
|
emoji: () => emoji2,
|
|||
|
|
enum: () => _enum2,
|
|||
|
|
exactOptional: () => exactOptional,
|
|||
|
|
file: () => file,
|
|||
|
|
float32: () => float32,
|
|||
|
|
float64: () => float64,
|
|||
|
|
function: () => _function,
|
|||
|
|
guid: () => guid2,
|
|||
|
|
hash: () => hash,
|
|||
|
|
hex: () => hex2,
|
|||
|
|
hostname: () => hostname2,
|
|||
|
|
httpUrl: () => httpUrl,
|
|||
|
|
instanceof: () => _instanceof,
|
|||
|
|
int: () => int,
|
|||
|
|
int32: () => int32,
|
|||
|
|
int64: () => int64,
|
|||
|
|
intersection: () => intersection,
|
|||
|
|
ipv4: () => ipv42,
|
|||
|
|
ipv6: () => ipv62,
|
|||
|
|
json: () => json,
|
|||
|
|
jwt: () => jwt,
|
|||
|
|
keyof: () => keyof,
|
|||
|
|
ksuid: () => ksuid2,
|
|||
|
|
lazy: () => lazy,
|
|||
|
|
literal: () => literal,
|
|||
|
|
looseObject: () => looseObject,
|
|||
|
|
looseRecord: () => looseRecord,
|
|||
|
|
mac: () => mac2,
|
|||
|
|
map: () => map,
|
|||
|
|
meta: () => meta2,
|
|||
|
|
nan: () => nan,
|
|||
|
|
nanoid: () => nanoid2,
|
|||
|
|
nativeEnum: () => nativeEnum,
|
|||
|
|
never: () => never,
|
|||
|
|
nonoptional: () => nonoptional,
|
|||
|
|
null: () => _null3,
|
|||
|
|
nullable: () => nullable,
|
|||
|
|
nullish: () => nullish2,
|
|||
|
|
number: () => number2,
|
|||
|
|
object: () => object,
|
|||
|
|
optional: () => optional,
|
|||
|
|
partialRecord: () => partialRecord,
|
|||
|
|
pipe: () => pipe,
|
|||
|
|
prefault: () => prefault,
|
|||
|
|
preprocess: () => preprocess,
|
|||
|
|
promise: () => promise,
|
|||
|
|
readonly: () => readonly,
|
|||
|
|
record: () => record,
|
|||
|
|
refine: () => refine,
|
|||
|
|
set: () => set,
|
|||
|
|
strictObject: () => strictObject,
|
|||
|
|
string: () => string2,
|
|||
|
|
stringFormat: () => stringFormat,
|
|||
|
|
stringbool: () => stringbool,
|
|||
|
|
success: () => success,
|
|||
|
|
superRefine: () => superRefine,
|
|||
|
|
symbol: () => symbol,
|
|||
|
|
templateLiteral: () => templateLiteral,
|
|||
|
|
transform: () => transform,
|
|||
|
|
tuple: () => tuple,
|
|||
|
|
uint32: () => uint32,
|
|||
|
|
uint64: () => uint64,
|
|||
|
|
ulid: () => ulid2,
|
|||
|
|
undefined: () => _undefined3,
|
|||
|
|
union: () => union,
|
|||
|
|
unknown: () => unknown,
|
|||
|
|
url: () => url,
|
|||
|
|
uuid: () => uuid2,
|
|||
|
|
uuidv4: () => uuidv4,
|
|||
|
|
uuidv6: () => uuidv6,
|
|||
|
|
uuidv7: () => uuidv7,
|
|||
|
|
void: () => _void2,
|
|||
|
|
xid: () => xid2,
|
|||
|
|
xor: () => xor
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/checks.js
|
|||
|
|
var checks_exports2 = {};
|
|||
|
|
__export(checks_exports2, {
|
|||
|
|
endsWith: () => _endsWith,
|
|||
|
|
gt: () => _gt,
|
|||
|
|
gte: () => _gte,
|
|||
|
|
includes: () => _includes,
|
|||
|
|
length: () => _length,
|
|||
|
|
lowercase: () => _lowercase,
|
|||
|
|
lt: () => _lt,
|
|||
|
|
lte: () => _lte,
|
|||
|
|
maxLength: () => _maxLength,
|
|||
|
|
maxSize: () => _maxSize,
|
|||
|
|
mime: () => _mime,
|
|||
|
|
minLength: () => _minLength,
|
|||
|
|
minSize: () => _minSize,
|
|||
|
|
multipleOf: () => _multipleOf,
|
|||
|
|
negative: () => _negative,
|
|||
|
|
nonnegative: () => _nonnegative,
|
|||
|
|
nonpositive: () => _nonpositive,
|
|||
|
|
normalize: () => _normalize,
|
|||
|
|
overwrite: () => _overwrite,
|
|||
|
|
positive: () => _positive,
|
|||
|
|
property: () => _property,
|
|||
|
|
regex: () => _regex,
|
|||
|
|
size: () => _size,
|
|||
|
|
slugify: () => _slugify,
|
|||
|
|
startsWith: () => _startsWith,
|
|||
|
|
toLowerCase: () => _toLowerCase,
|
|||
|
|
toUpperCase: () => _toUpperCase,
|
|||
|
|
trim: () => _trim,
|
|||
|
|
uppercase: () => _uppercase
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/iso.js
|
|||
|
|
var iso_exports = {};
|
|||
|
|
__export(iso_exports, {
|
|||
|
|
ZodISODate: () => ZodISODate,
|
|||
|
|
ZodISODateTime: () => ZodISODateTime,
|
|||
|
|
ZodISODuration: () => ZodISODuration,
|
|||
|
|
ZodISOTime: () => ZodISOTime,
|
|||
|
|
date: () => date2,
|
|||
|
|
datetime: () => datetime2,
|
|||
|
|
duration: () => duration2,
|
|||
|
|
time: () => time2
|
|||
|
|
});
|
|||
|
|
var ZodISODateTime = $constructor("ZodISODateTime", (inst, def) => {
|
|||
|
|
$ZodISODateTime.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function datetime2(params) {
|
|||
|
|
return _isoDateTime(ZodISODateTime, params);
|
|||
|
|
}
|
|||
|
|
var ZodISODate = $constructor("ZodISODate", (inst, def) => {
|
|||
|
|
$ZodISODate.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function date2(params) {
|
|||
|
|
return _isoDate(ZodISODate, params);
|
|||
|
|
}
|
|||
|
|
var ZodISOTime = $constructor("ZodISOTime", (inst, def) => {
|
|||
|
|
$ZodISOTime.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function time2(params) {
|
|||
|
|
return _isoTime(ZodISOTime, params);
|
|||
|
|
}
|
|||
|
|
var ZodISODuration = $constructor("ZodISODuration", (inst, def) => {
|
|||
|
|
$ZodISODuration.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function duration2(params) {
|
|||
|
|
return _isoDuration(ZodISODuration, params);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/errors.js
|
|||
|
|
var initializer2 = (inst, issues) => {
|
|||
|
|
$ZodError.init(inst, issues);
|
|||
|
|
inst.name = "ZodError";
|
|||
|
|
Object.defineProperties(inst, {
|
|||
|
|
format: {
|
|||
|
|
value: (mapper) => formatError(inst, mapper)
|
|||
|
|
// enumerable: false,
|
|||
|
|
},
|
|||
|
|
flatten: {
|
|||
|
|
value: (mapper) => flattenError(inst, mapper)
|
|||
|
|
// enumerable: false,
|
|||
|
|
},
|
|||
|
|
addIssue: {
|
|||
|
|
value: (issue2) => {
|
|||
|
|
inst.issues.push(issue2);
|
|||
|
|
inst.message = JSON.stringify(inst.issues, jsonStringifyReplacer, 2);
|
|||
|
|
}
|
|||
|
|
// enumerable: false,
|
|||
|
|
},
|
|||
|
|
addIssues: {
|
|||
|
|
value: (issues2) => {
|
|||
|
|
inst.issues.push(...issues2);
|
|||
|
|
inst.message = JSON.stringify(inst.issues, jsonStringifyReplacer, 2);
|
|||
|
|
}
|
|||
|
|
// enumerable: false,
|
|||
|
|
},
|
|||
|
|
isEmpty: {
|
|||
|
|
get() {
|
|||
|
|
return inst.issues.length === 0;
|
|||
|
|
}
|
|||
|
|
// enumerable: false,
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
var ZodError = $constructor("ZodError", initializer2);
|
|||
|
|
var ZodRealError = $constructor("ZodError", initializer2, {
|
|||
|
|
Parent: Error
|
|||
|
|
});
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/parse.js
|
|||
|
|
var parse2 = _parse(ZodRealError);
|
|||
|
|
var parseAsync2 = _parseAsync(ZodRealError);
|
|||
|
|
var safeParse2 = _safeParse(ZodRealError);
|
|||
|
|
var safeParseAsync2 = _safeParseAsync(ZodRealError);
|
|||
|
|
var encode2 = _encode(ZodRealError);
|
|||
|
|
var decode2 = _decode(ZodRealError);
|
|||
|
|
var encodeAsync2 = _encodeAsync(ZodRealError);
|
|||
|
|
var decodeAsync2 = _decodeAsync(ZodRealError);
|
|||
|
|
var safeEncode2 = _safeEncode(ZodRealError);
|
|||
|
|
var safeDecode2 = _safeDecode(ZodRealError);
|
|||
|
|
var safeEncodeAsync2 = _safeEncodeAsync(ZodRealError);
|
|||
|
|
var safeDecodeAsync2 = _safeDecodeAsync(ZodRealError);
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/schemas.js
|
|||
|
|
var ZodType = $constructor("ZodType", (inst, def) => {
|
|||
|
|
$ZodType.init(inst, def);
|
|||
|
|
Object.assign(inst["~standard"], {
|
|||
|
|
jsonSchema: {
|
|||
|
|
input: createStandardJSONSchemaMethod(inst, "input"),
|
|||
|
|
output: createStandardJSONSchemaMethod(inst, "output")
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
inst.toJSONSchema = createToJSONSchemaMethod(inst, {});
|
|||
|
|
inst.def = def;
|
|||
|
|
inst.type = def.type;
|
|||
|
|
Object.defineProperty(inst, "_def", { value: def });
|
|||
|
|
inst.check = (...checks) => {
|
|||
|
|
return inst.clone(util_exports.mergeDefs(def, {
|
|||
|
|
checks: [
|
|||
|
|
...def.checks ?? [],
|
|||
|
|
...checks.map((ch) => typeof ch === "function" ? { _zod: { check: ch, def: { check: "custom" }, onattach: [] } } : ch)
|
|||
|
|
]
|
|||
|
|
}), {
|
|||
|
|
parent: true
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
inst.with = inst.check;
|
|||
|
|
inst.clone = (def2, params) => clone(inst, def2, params);
|
|||
|
|
inst.brand = () => inst;
|
|||
|
|
inst.register = ((reg, meta3) => {
|
|||
|
|
reg.add(inst, meta3);
|
|||
|
|
return inst;
|
|||
|
|
});
|
|||
|
|
inst.parse = (data, params) => parse2(inst, data, params, { callee: inst.parse });
|
|||
|
|
inst.safeParse = (data, params) => safeParse2(inst, data, params);
|
|||
|
|
inst.parseAsync = async (data, params) => parseAsync2(inst, data, params, { callee: inst.parseAsync });
|
|||
|
|
inst.safeParseAsync = async (data, params) => safeParseAsync2(inst, data, params);
|
|||
|
|
inst.spa = inst.safeParseAsync;
|
|||
|
|
inst.encode = (data, params) => encode2(inst, data, params);
|
|||
|
|
inst.decode = (data, params) => decode2(inst, data, params);
|
|||
|
|
inst.encodeAsync = async (data, params) => encodeAsync2(inst, data, params);
|
|||
|
|
inst.decodeAsync = async (data, params) => decodeAsync2(inst, data, params);
|
|||
|
|
inst.safeEncode = (data, params) => safeEncode2(inst, data, params);
|
|||
|
|
inst.safeDecode = (data, params) => safeDecode2(inst, data, params);
|
|||
|
|
inst.safeEncodeAsync = async (data, params) => safeEncodeAsync2(inst, data, params);
|
|||
|
|
inst.safeDecodeAsync = async (data, params) => safeDecodeAsync2(inst, data, params);
|
|||
|
|
inst.refine = (check2, params) => inst.check(refine(check2, params));
|
|||
|
|
inst.superRefine = (refinement) => inst.check(superRefine(refinement));
|
|||
|
|
inst.overwrite = (fn) => inst.check(_overwrite(fn));
|
|||
|
|
inst.optional = () => optional(inst);
|
|||
|
|
inst.exactOptional = () => exactOptional(inst);
|
|||
|
|
inst.nullable = () => nullable(inst);
|
|||
|
|
inst.nullish = () => optional(nullable(inst));
|
|||
|
|
inst.nonoptional = (params) => nonoptional(inst, params);
|
|||
|
|
inst.array = () => array(inst);
|
|||
|
|
inst.or = (arg) => union([inst, arg]);
|
|||
|
|
inst.and = (arg) => intersection(inst, arg);
|
|||
|
|
inst.transform = (tx) => pipe(inst, transform(tx));
|
|||
|
|
inst.default = (def2) => _default2(inst, def2);
|
|||
|
|
inst.prefault = (def2) => prefault(inst, def2);
|
|||
|
|
inst.catch = (params) => _catch2(inst, params);
|
|||
|
|
inst.pipe = (target) => pipe(inst, target);
|
|||
|
|
inst.readonly = () => readonly(inst);
|
|||
|
|
inst.describe = (description) => {
|
|||
|
|
const cl = inst.clone();
|
|||
|
|
globalRegistry.add(cl, { description });
|
|||
|
|
return cl;
|
|||
|
|
};
|
|||
|
|
Object.defineProperty(inst, "description", {
|
|||
|
|
get() {
|
|||
|
|
return globalRegistry.get(inst)?.description;
|
|||
|
|
},
|
|||
|
|
configurable: true
|
|||
|
|
});
|
|||
|
|
inst.meta = (...args) => {
|
|||
|
|
if (args.length === 0) {
|
|||
|
|
return globalRegistry.get(inst);
|
|||
|
|
}
|
|||
|
|
const cl = inst.clone();
|
|||
|
|
globalRegistry.add(cl, args[0]);
|
|||
|
|
return cl;
|
|||
|
|
};
|
|||
|
|
inst.isOptional = () => inst.safeParse(void 0).success;
|
|||
|
|
inst.isNullable = () => inst.safeParse(null).success;
|
|||
|
|
inst.apply = (fn) => fn(inst);
|
|||
|
|
return inst;
|
|||
|
|
});
|
|||
|
|
var _ZodString = $constructor("_ZodString", (inst, def) => {
|
|||
|
|
$ZodString.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => stringProcessor(inst, ctx, json2, params);
|
|||
|
|
const bag = inst._zod.bag;
|
|||
|
|
inst.format = bag.format ?? null;
|
|||
|
|
inst.minLength = bag.minimum ?? null;
|
|||
|
|
inst.maxLength = bag.maximum ?? null;
|
|||
|
|
inst.regex = (...args) => inst.check(_regex(...args));
|
|||
|
|
inst.includes = (...args) => inst.check(_includes(...args));
|
|||
|
|
inst.startsWith = (...args) => inst.check(_startsWith(...args));
|
|||
|
|
inst.endsWith = (...args) => inst.check(_endsWith(...args));
|
|||
|
|
inst.min = (...args) => inst.check(_minLength(...args));
|
|||
|
|
inst.max = (...args) => inst.check(_maxLength(...args));
|
|||
|
|
inst.length = (...args) => inst.check(_length(...args));
|
|||
|
|
inst.nonempty = (...args) => inst.check(_minLength(1, ...args));
|
|||
|
|
inst.lowercase = (params) => inst.check(_lowercase(params));
|
|||
|
|
inst.uppercase = (params) => inst.check(_uppercase(params));
|
|||
|
|
inst.trim = () => inst.check(_trim());
|
|||
|
|
inst.normalize = (...args) => inst.check(_normalize(...args));
|
|||
|
|
inst.toLowerCase = () => inst.check(_toLowerCase());
|
|||
|
|
inst.toUpperCase = () => inst.check(_toUpperCase());
|
|||
|
|
inst.slugify = () => inst.check(_slugify());
|
|||
|
|
});
|
|||
|
|
var ZodString = $constructor("ZodString", (inst, def) => {
|
|||
|
|
$ZodString.init(inst, def);
|
|||
|
|
_ZodString.init(inst, def);
|
|||
|
|
inst.email = (params) => inst.check(_email(ZodEmail, params));
|
|||
|
|
inst.url = (params) => inst.check(_url(ZodURL, params));
|
|||
|
|
inst.jwt = (params) => inst.check(_jwt(ZodJWT, params));
|
|||
|
|
inst.emoji = (params) => inst.check(_emoji2(ZodEmoji, params));
|
|||
|
|
inst.guid = (params) => inst.check(_guid(ZodGUID, params));
|
|||
|
|
inst.uuid = (params) => inst.check(_uuid(ZodUUID, params));
|
|||
|
|
inst.uuidv4 = (params) => inst.check(_uuidv4(ZodUUID, params));
|
|||
|
|
inst.uuidv6 = (params) => inst.check(_uuidv6(ZodUUID, params));
|
|||
|
|
inst.uuidv7 = (params) => inst.check(_uuidv7(ZodUUID, params));
|
|||
|
|
inst.nanoid = (params) => inst.check(_nanoid(ZodNanoID, params));
|
|||
|
|
inst.guid = (params) => inst.check(_guid(ZodGUID, params));
|
|||
|
|
inst.cuid = (params) => inst.check(_cuid(ZodCUID, params));
|
|||
|
|
inst.cuid2 = (params) => inst.check(_cuid2(ZodCUID2, params));
|
|||
|
|
inst.ulid = (params) => inst.check(_ulid(ZodULID, params));
|
|||
|
|
inst.base64 = (params) => inst.check(_base64(ZodBase64, params));
|
|||
|
|
inst.base64url = (params) => inst.check(_base64url(ZodBase64URL, params));
|
|||
|
|
inst.xid = (params) => inst.check(_xid(ZodXID, params));
|
|||
|
|
inst.ksuid = (params) => inst.check(_ksuid(ZodKSUID, params));
|
|||
|
|
inst.ipv4 = (params) => inst.check(_ipv4(ZodIPv4, params));
|
|||
|
|
inst.ipv6 = (params) => inst.check(_ipv6(ZodIPv6, params));
|
|||
|
|
inst.cidrv4 = (params) => inst.check(_cidrv4(ZodCIDRv4, params));
|
|||
|
|
inst.cidrv6 = (params) => inst.check(_cidrv6(ZodCIDRv6, params));
|
|||
|
|
inst.e164 = (params) => inst.check(_e164(ZodE164, params));
|
|||
|
|
inst.datetime = (params) => inst.check(datetime2(params));
|
|||
|
|
inst.date = (params) => inst.check(date2(params));
|
|||
|
|
inst.time = (params) => inst.check(time2(params));
|
|||
|
|
inst.duration = (params) => inst.check(duration2(params));
|
|||
|
|
});
|
|||
|
|
function string2(params) {
|
|||
|
|
return _string(ZodString, params);
|
|||
|
|
}
|
|||
|
|
var ZodStringFormat = $constructor("ZodStringFormat", (inst, def) => {
|
|||
|
|
$ZodStringFormat.init(inst, def);
|
|||
|
|
_ZodString.init(inst, def);
|
|||
|
|
});
|
|||
|
|
var ZodEmail = $constructor("ZodEmail", (inst, def) => {
|
|||
|
|
$ZodEmail.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function email2(params) {
|
|||
|
|
return _email(ZodEmail, params);
|
|||
|
|
}
|
|||
|
|
var ZodGUID = $constructor("ZodGUID", (inst, def) => {
|
|||
|
|
$ZodGUID.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function guid2(params) {
|
|||
|
|
return _guid(ZodGUID, params);
|
|||
|
|
}
|
|||
|
|
var ZodUUID = $constructor("ZodUUID", (inst, def) => {
|
|||
|
|
$ZodUUID.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function uuid2(params) {
|
|||
|
|
return _uuid(ZodUUID, params);
|
|||
|
|
}
|
|||
|
|
function uuidv4(params) {
|
|||
|
|
return _uuidv4(ZodUUID, params);
|
|||
|
|
}
|
|||
|
|
function uuidv6(params) {
|
|||
|
|
return _uuidv6(ZodUUID, params);
|
|||
|
|
}
|
|||
|
|
function uuidv7(params) {
|
|||
|
|
return _uuidv7(ZodUUID, params);
|
|||
|
|
}
|
|||
|
|
var ZodURL = $constructor("ZodURL", (inst, def) => {
|
|||
|
|
$ZodURL.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function url(params) {
|
|||
|
|
return _url(ZodURL, params);
|
|||
|
|
}
|
|||
|
|
function httpUrl(params) {
|
|||
|
|
return _url(ZodURL, {
|
|||
|
|
protocol: /^https?$/,
|
|||
|
|
hostname: regexes_exports.domain,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodEmoji = $constructor("ZodEmoji", (inst, def) => {
|
|||
|
|
$ZodEmoji.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function emoji2(params) {
|
|||
|
|
return _emoji2(ZodEmoji, params);
|
|||
|
|
}
|
|||
|
|
var ZodNanoID = $constructor("ZodNanoID", (inst, def) => {
|
|||
|
|
$ZodNanoID.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function nanoid2(params) {
|
|||
|
|
return _nanoid(ZodNanoID, params);
|
|||
|
|
}
|
|||
|
|
var ZodCUID = $constructor("ZodCUID", (inst, def) => {
|
|||
|
|
$ZodCUID.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function cuid3(params) {
|
|||
|
|
return _cuid(ZodCUID, params);
|
|||
|
|
}
|
|||
|
|
var ZodCUID2 = $constructor("ZodCUID2", (inst, def) => {
|
|||
|
|
$ZodCUID2.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function cuid22(params) {
|
|||
|
|
return _cuid2(ZodCUID2, params);
|
|||
|
|
}
|
|||
|
|
var ZodULID = $constructor("ZodULID", (inst, def) => {
|
|||
|
|
$ZodULID.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function ulid2(params) {
|
|||
|
|
return _ulid(ZodULID, params);
|
|||
|
|
}
|
|||
|
|
var ZodXID = $constructor("ZodXID", (inst, def) => {
|
|||
|
|
$ZodXID.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function xid2(params) {
|
|||
|
|
return _xid(ZodXID, params);
|
|||
|
|
}
|
|||
|
|
var ZodKSUID = $constructor("ZodKSUID", (inst, def) => {
|
|||
|
|
$ZodKSUID.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function ksuid2(params) {
|
|||
|
|
return _ksuid(ZodKSUID, params);
|
|||
|
|
}
|
|||
|
|
var ZodIPv4 = $constructor("ZodIPv4", (inst, def) => {
|
|||
|
|
$ZodIPv4.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function ipv42(params) {
|
|||
|
|
return _ipv4(ZodIPv4, params);
|
|||
|
|
}
|
|||
|
|
var ZodMAC = $constructor("ZodMAC", (inst, def) => {
|
|||
|
|
$ZodMAC.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function mac2(params) {
|
|||
|
|
return _mac(ZodMAC, params);
|
|||
|
|
}
|
|||
|
|
var ZodIPv6 = $constructor("ZodIPv6", (inst, def) => {
|
|||
|
|
$ZodIPv6.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function ipv62(params) {
|
|||
|
|
return _ipv6(ZodIPv6, params);
|
|||
|
|
}
|
|||
|
|
var ZodCIDRv4 = $constructor("ZodCIDRv4", (inst, def) => {
|
|||
|
|
$ZodCIDRv4.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function cidrv42(params) {
|
|||
|
|
return _cidrv4(ZodCIDRv4, params);
|
|||
|
|
}
|
|||
|
|
var ZodCIDRv6 = $constructor("ZodCIDRv6", (inst, def) => {
|
|||
|
|
$ZodCIDRv6.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function cidrv62(params) {
|
|||
|
|
return _cidrv6(ZodCIDRv6, params);
|
|||
|
|
}
|
|||
|
|
var ZodBase64 = $constructor("ZodBase64", (inst, def) => {
|
|||
|
|
$ZodBase64.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function base642(params) {
|
|||
|
|
return _base64(ZodBase64, params);
|
|||
|
|
}
|
|||
|
|
var ZodBase64URL = $constructor("ZodBase64URL", (inst, def) => {
|
|||
|
|
$ZodBase64URL.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function base64url2(params) {
|
|||
|
|
return _base64url(ZodBase64URL, params);
|
|||
|
|
}
|
|||
|
|
var ZodE164 = $constructor("ZodE164", (inst, def) => {
|
|||
|
|
$ZodE164.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function e1642(params) {
|
|||
|
|
return _e164(ZodE164, params);
|
|||
|
|
}
|
|||
|
|
var ZodJWT = $constructor("ZodJWT", (inst, def) => {
|
|||
|
|
$ZodJWT.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function jwt(params) {
|
|||
|
|
return _jwt(ZodJWT, params);
|
|||
|
|
}
|
|||
|
|
var ZodCustomStringFormat = $constructor("ZodCustomStringFormat", (inst, def) => {
|
|||
|
|
$ZodCustomStringFormat.init(inst, def);
|
|||
|
|
ZodStringFormat.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function stringFormat(format, fnOrRegex, _params = {}) {
|
|||
|
|
return _stringFormat(ZodCustomStringFormat, format, fnOrRegex, _params);
|
|||
|
|
}
|
|||
|
|
function hostname2(_params) {
|
|||
|
|
return _stringFormat(ZodCustomStringFormat, "hostname", regexes_exports.hostname, _params);
|
|||
|
|
}
|
|||
|
|
function hex2(_params) {
|
|||
|
|
return _stringFormat(ZodCustomStringFormat, "hex", regexes_exports.hex, _params);
|
|||
|
|
}
|
|||
|
|
function hash(alg, params) {
|
|||
|
|
const enc = params?.enc ?? "hex";
|
|||
|
|
const format = `${alg}_${enc}`;
|
|||
|
|
const regex = regexes_exports[format];
|
|||
|
|
if (!regex)
|
|||
|
|
throw new Error(`Unrecognized hash format: ${format}`);
|
|||
|
|
return _stringFormat(ZodCustomStringFormat, format, regex, params);
|
|||
|
|
}
|
|||
|
|
var ZodNumber = $constructor("ZodNumber", (inst, def) => {
|
|||
|
|
$ZodNumber.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => numberProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.gt = (value, params) => inst.check(_gt(value, params));
|
|||
|
|
inst.gte = (value, params) => inst.check(_gte(value, params));
|
|||
|
|
inst.min = (value, params) => inst.check(_gte(value, params));
|
|||
|
|
inst.lt = (value, params) => inst.check(_lt(value, params));
|
|||
|
|
inst.lte = (value, params) => inst.check(_lte(value, params));
|
|||
|
|
inst.max = (value, params) => inst.check(_lte(value, params));
|
|||
|
|
inst.int = (params) => inst.check(int(params));
|
|||
|
|
inst.safe = (params) => inst.check(int(params));
|
|||
|
|
inst.positive = (params) => inst.check(_gt(0, params));
|
|||
|
|
inst.nonnegative = (params) => inst.check(_gte(0, params));
|
|||
|
|
inst.negative = (params) => inst.check(_lt(0, params));
|
|||
|
|
inst.nonpositive = (params) => inst.check(_lte(0, params));
|
|||
|
|
inst.multipleOf = (value, params) => inst.check(_multipleOf(value, params));
|
|||
|
|
inst.step = (value, params) => inst.check(_multipleOf(value, params));
|
|||
|
|
inst.finite = () => inst;
|
|||
|
|
const bag = inst._zod.bag;
|
|||
|
|
inst.minValue = Math.max(bag.minimum ?? Number.NEGATIVE_INFINITY, bag.exclusiveMinimum ?? Number.NEGATIVE_INFINITY) ?? null;
|
|||
|
|
inst.maxValue = Math.min(bag.maximum ?? Number.POSITIVE_INFINITY, bag.exclusiveMaximum ?? Number.POSITIVE_INFINITY) ?? null;
|
|||
|
|
inst.isInt = (bag.format ?? "").includes("int") || Number.isSafeInteger(bag.multipleOf ?? 0.5);
|
|||
|
|
inst.isFinite = true;
|
|||
|
|
inst.format = bag.format ?? null;
|
|||
|
|
});
|
|||
|
|
function number2(params) {
|
|||
|
|
return _number(ZodNumber, params);
|
|||
|
|
}
|
|||
|
|
var ZodNumberFormat = $constructor("ZodNumberFormat", (inst, def) => {
|
|||
|
|
$ZodNumberFormat.init(inst, def);
|
|||
|
|
ZodNumber.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function int(params) {
|
|||
|
|
return _int(ZodNumberFormat, params);
|
|||
|
|
}
|
|||
|
|
function float32(params) {
|
|||
|
|
return _float32(ZodNumberFormat, params);
|
|||
|
|
}
|
|||
|
|
function float64(params) {
|
|||
|
|
return _float64(ZodNumberFormat, params);
|
|||
|
|
}
|
|||
|
|
function int32(params) {
|
|||
|
|
return _int32(ZodNumberFormat, params);
|
|||
|
|
}
|
|||
|
|
function uint32(params) {
|
|||
|
|
return _uint32(ZodNumberFormat, params);
|
|||
|
|
}
|
|||
|
|
var ZodBoolean = $constructor("ZodBoolean", (inst, def) => {
|
|||
|
|
$ZodBoolean.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => booleanProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function boolean2(params) {
|
|||
|
|
return _boolean(ZodBoolean, params);
|
|||
|
|
}
|
|||
|
|
var ZodBigInt = $constructor("ZodBigInt", (inst, def) => {
|
|||
|
|
$ZodBigInt.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => bigintProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.gte = (value, params) => inst.check(_gte(value, params));
|
|||
|
|
inst.min = (value, params) => inst.check(_gte(value, params));
|
|||
|
|
inst.gt = (value, params) => inst.check(_gt(value, params));
|
|||
|
|
inst.gte = (value, params) => inst.check(_gte(value, params));
|
|||
|
|
inst.min = (value, params) => inst.check(_gte(value, params));
|
|||
|
|
inst.lt = (value, params) => inst.check(_lt(value, params));
|
|||
|
|
inst.lte = (value, params) => inst.check(_lte(value, params));
|
|||
|
|
inst.max = (value, params) => inst.check(_lte(value, params));
|
|||
|
|
inst.positive = (params) => inst.check(_gt(BigInt(0), params));
|
|||
|
|
inst.negative = (params) => inst.check(_lt(BigInt(0), params));
|
|||
|
|
inst.nonpositive = (params) => inst.check(_lte(BigInt(0), params));
|
|||
|
|
inst.nonnegative = (params) => inst.check(_gte(BigInt(0), params));
|
|||
|
|
inst.multipleOf = (value, params) => inst.check(_multipleOf(value, params));
|
|||
|
|
const bag = inst._zod.bag;
|
|||
|
|
inst.minValue = bag.minimum ?? null;
|
|||
|
|
inst.maxValue = bag.maximum ?? null;
|
|||
|
|
inst.format = bag.format ?? null;
|
|||
|
|
});
|
|||
|
|
function bigint2(params) {
|
|||
|
|
return _bigint(ZodBigInt, params);
|
|||
|
|
}
|
|||
|
|
var ZodBigIntFormat = $constructor("ZodBigIntFormat", (inst, def) => {
|
|||
|
|
$ZodBigIntFormat.init(inst, def);
|
|||
|
|
ZodBigInt.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function int64(params) {
|
|||
|
|
return _int64(ZodBigIntFormat, params);
|
|||
|
|
}
|
|||
|
|
function uint64(params) {
|
|||
|
|
return _uint64(ZodBigIntFormat, params);
|
|||
|
|
}
|
|||
|
|
var ZodSymbol = $constructor("ZodSymbol", (inst, def) => {
|
|||
|
|
$ZodSymbol.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => symbolProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function symbol(params) {
|
|||
|
|
return _symbol(ZodSymbol, params);
|
|||
|
|
}
|
|||
|
|
var ZodUndefined = $constructor("ZodUndefined", (inst, def) => {
|
|||
|
|
$ZodUndefined.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => undefinedProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function _undefined3(params) {
|
|||
|
|
return _undefined2(ZodUndefined, params);
|
|||
|
|
}
|
|||
|
|
var ZodNull = $constructor("ZodNull", (inst, def) => {
|
|||
|
|
$ZodNull.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => nullProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function _null3(params) {
|
|||
|
|
return _null2(ZodNull, params);
|
|||
|
|
}
|
|||
|
|
var ZodAny = $constructor("ZodAny", (inst, def) => {
|
|||
|
|
$ZodAny.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => anyProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function any() {
|
|||
|
|
return _any(ZodAny);
|
|||
|
|
}
|
|||
|
|
var ZodUnknown = $constructor("ZodUnknown", (inst, def) => {
|
|||
|
|
$ZodUnknown.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => unknownProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function unknown() {
|
|||
|
|
return _unknown(ZodUnknown);
|
|||
|
|
}
|
|||
|
|
var ZodNever = $constructor("ZodNever", (inst, def) => {
|
|||
|
|
$ZodNever.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => neverProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function never(params) {
|
|||
|
|
return _never(ZodNever, params);
|
|||
|
|
}
|
|||
|
|
var ZodVoid = $constructor("ZodVoid", (inst, def) => {
|
|||
|
|
$ZodVoid.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => voidProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function _void2(params) {
|
|||
|
|
return _void(ZodVoid, params);
|
|||
|
|
}
|
|||
|
|
var ZodDate = $constructor("ZodDate", (inst, def) => {
|
|||
|
|
$ZodDate.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => dateProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.min = (value, params) => inst.check(_gte(value, params));
|
|||
|
|
inst.max = (value, params) => inst.check(_lte(value, params));
|
|||
|
|
const c = inst._zod.bag;
|
|||
|
|
inst.minDate = c.minimum ? new Date(c.minimum) : null;
|
|||
|
|
inst.maxDate = c.maximum ? new Date(c.maximum) : null;
|
|||
|
|
});
|
|||
|
|
function date3(params) {
|
|||
|
|
return _date(ZodDate, params);
|
|||
|
|
}
|
|||
|
|
var ZodArray = $constructor("ZodArray", (inst, def) => {
|
|||
|
|
$ZodArray.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => arrayProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.element = def.element;
|
|||
|
|
inst.min = (minLength, params) => inst.check(_minLength(minLength, params));
|
|||
|
|
inst.nonempty = (params) => inst.check(_minLength(1, params));
|
|||
|
|
inst.max = (maxLength, params) => inst.check(_maxLength(maxLength, params));
|
|||
|
|
inst.length = (len, params) => inst.check(_length(len, params));
|
|||
|
|
inst.unwrap = () => inst.element;
|
|||
|
|
});
|
|||
|
|
function array(element, params) {
|
|||
|
|
return _array(ZodArray, element, params);
|
|||
|
|
}
|
|||
|
|
function keyof(schema) {
|
|||
|
|
const shape = schema._zod.def.shape;
|
|||
|
|
return _enum2(Object.keys(shape));
|
|||
|
|
}
|
|||
|
|
var ZodObject = $constructor("ZodObject", (inst, def) => {
|
|||
|
|
$ZodObjectJIT.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => objectProcessor(inst, ctx, json2, params);
|
|||
|
|
util_exports.defineLazy(inst, "shape", () => {
|
|||
|
|
return def.shape;
|
|||
|
|
});
|
|||
|
|
inst.keyof = () => _enum2(Object.keys(inst._zod.def.shape));
|
|||
|
|
inst.catchall = (catchall) => inst.clone({ ...inst._zod.def, catchall });
|
|||
|
|
inst.passthrough = () => inst.clone({ ...inst._zod.def, catchall: unknown() });
|
|||
|
|
inst.loose = () => inst.clone({ ...inst._zod.def, catchall: unknown() });
|
|||
|
|
inst.strict = () => inst.clone({ ...inst._zod.def, catchall: never() });
|
|||
|
|
inst.strip = () => inst.clone({ ...inst._zod.def, catchall: void 0 });
|
|||
|
|
inst.extend = (incoming) => {
|
|||
|
|
return util_exports.extend(inst, incoming);
|
|||
|
|
};
|
|||
|
|
inst.safeExtend = (incoming) => {
|
|||
|
|
return util_exports.safeExtend(inst, incoming);
|
|||
|
|
};
|
|||
|
|
inst.merge = (other) => util_exports.merge(inst, other);
|
|||
|
|
inst.pick = (mask) => util_exports.pick(inst, mask);
|
|||
|
|
inst.omit = (mask) => util_exports.omit(inst, mask);
|
|||
|
|
inst.partial = (...args) => util_exports.partial(ZodOptional, inst, args[0]);
|
|||
|
|
inst.required = (...args) => util_exports.required(ZodNonOptional, inst, args[0]);
|
|||
|
|
});
|
|||
|
|
function object(shape, params) {
|
|||
|
|
const def = {
|
|||
|
|
type: "object",
|
|||
|
|
shape: shape ?? {},
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
};
|
|||
|
|
return new ZodObject(def);
|
|||
|
|
}
|
|||
|
|
function strictObject(shape, params) {
|
|||
|
|
return new ZodObject({
|
|||
|
|
type: "object",
|
|||
|
|
shape,
|
|||
|
|
catchall: never(),
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function looseObject(shape, params) {
|
|||
|
|
return new ZodObject({
|
|||
|
|
type: "object",
|
|||
|
|
shape,
|
|||
|
|
catchall: unknown(),
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodUnion = $constructor("ZodUnion", (inst, def) => {
|
|||
|
|
$ZodUnion.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => unionProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.options = def.options;
|
|||
|
|
});
|
|||
|
|
function union(options, params) {
|
|||
|
|
return new ZodUnion({
|
|||
|
|
type: "union",
|
|||
|
|
options,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodXor = $constructor("ZodXor", (inst, def) => {
|
|||
|
|
ZodUnion.init(inst, def);
|
|||
|
|
$ZodXor.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => unionProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.options = def.options;
|
|||
|
|
});
|
|||
|
|
function xor(options, params) {
|
|||
|
|
return new ZodXor({
|
|||
|
|
type: "union",
|
|||
|
|
options,
|
|||
|
|
inclusive: false,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodDiscriminatedUnion = $constructor("ZodDiscriminatedUnion", (inst, def) => {
|
|||
|
|
ZodUnion.init(inst, def);
|
|||
|
|
$ZodDiscriminatedUnion.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function discriminatedUnion(discriminator, options, params) {
|
|||
|
|
return new ZodDiscriminatedUnion({
|
|||
|
|
type: "union",
|
|||
|
|
options,
|
|||
|
|
discriminator,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodIntersection = $constructor("ZodIntersection", (inst, def) => {
|
|||
|
|
$ZodIntersection.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => intersectionProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function intersection(left, right) {
|
|||
|
|
return new ZodIntersection({
|
|||
|
|
type: "intersection",
|
|||
|
|
left,
|
|||
|
|
right
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodTuple = $constructor("ZodTuple", (inst, def) => {
|
|||
|
|
$ZodTuple.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => tupleProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.rest = (rest) => inst.clone({
|
|||
|
|
...inst._zod.def,
|
|||
|
|
rest
|
|||
|
|
});
|
|||
|
|
});
|
|||
|
|
function tuple(items, _paramsOrRest, _params) {
|
|||
|
|
const hasRest = _paramsOrRest instanceof $ZodType;
|
|||
|
|
const params = hasRest ? _params : _paramsOrRest;
|
|||
|
|
const rest = hasRest ? _paramsOrRest : null;
|
|||
|
|
return new ZodTuple({
|
|||
|
|
type: "tuple",
|
|||
|
|
items,
|
|||
|
|
rest,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodRecord = $constructor("ZodRecord", (inst, def) => {
|
|||
|
|
$ZodRecord.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => recordProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.keyType = def.keyType;
|
|||
|
|
inst.valueType = def.valueType;
|
|||
|
|
});
|
|||
|
|
function record(keyType, valueType, params) {
|
|||
|
|
return new ZodRecord({
|
|||
|
|
type: "record",
|
|||
|
|
keyType,
|
|||
|
|
valueType,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function partialRecord(keyType, valueType, params) {
|
|||
|
|
const k = clone(keyType);
|
|||
|
|
k._zod.values = void 0;
|
|||
|
|
return new ZodRecord({
|
|||
|
|
type: "record",
|
|||
|
|
keyType: k,
|
|||
|
|
valueType,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function looseRecord(keyType, valueType, params) {
|
|||
|
|
return new ZodRecord({
|
|||
|
|
type: "record",
|
|||
|
|
keyType,
|
|||
|
|
valueType,
|
|||
|
|
mode: "loose",
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodMap = $constructor("ZodMap", (inst, def) => {
|
|||
|
|
$ZodMap.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => mapProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.keyType = def.keyType;
|
|||
|
|
inst.valueType = def.valueType;
|
|||
|
|
inst.min = (...args) => inst.check(_minSize(...args));
|
|||
|
|
inst.nonempty = (params) => inst.check(_minSize(1, params));
|
|||
|
|
inst.max = (...args) => inst.check(_maxSize(...args));
|
|||
|
|
inst.size = (...args) => inst.check(_size(...args));
|
|||
|
|
});
|
|||
|
|
function map(keyType, valueType, params) {
|
|||
|
|
return new ZodMap({
|
|||
|
|
type: "map",
|
|||
|
|
keyType,
|
|||
|
|
valueType,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodSet = $constructor("ZodSet", (inst, def) => {
|
|||
|
|
$ZodSet.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => setProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.min = (...args) => inst.check(_minSize(...args));
|
|||
|
|
inst.nonempty = (params) => inst.check(_minSize(1, params));
|
|||
|
|
inst.max = (...args) => inst.check(_maxSize(...args));
|
|||
|
|
inst.size = (...args) => inst.check(_size(...args));
|
|||
|
|
});
|
|||
|
|
function set(valueType, params) {
|
|||
|
|
return new ZodSet({
|
|||
|
|
type: "set",
|
|||
|
|
valueType,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodEnum = $constructor("ZodEnum", (inst, def) => {
|
|||
|
|
$ZodEnum.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => enumProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.enum = def.entries;
|
|||
|
|
inst.options = Object.values(def.entries);
|
|||
|
|
const keys = new Set(Object.keys(def.entries));
|
|||
|
|
inst.extract = (values, params) => {
|
|||
|
|
const newEntries = {};
|
|||
|
|
for (const value of values) {
|
|||
|
|
if (keys.has(value)) {
|
|||
|
|
newEntries[value] = def.entries[value];
|
|||
|
|
} else
|
|||
|
|
throw new Error(`Key ${value} not found in enum`);
|
|||
|
|
}
|
|||
|
|
return new ZodEnum({
|
|||
|
|
...def,
|
|||
|
|
checks: [],
|
|||
|
|
...util_exports.normalizeParams(params),
|
|||
|
|
entries: newEntries
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
inst.exclude = (values, params) => {
|
|||
|
|
const newEntries = { ...def.entries };
|
|||
|
|
for (const value of values) {
|
|||
|
|
if (keys.has(value)) {
|
|||
|
|
delete newEntries[value];
|
|||
|
|
} else
|
|||
|
|
throw new Error(`Key ${value} not found in enum`);
|
|||
|
|
}
|
|||
|
|
return new ZodEnum({
|
|||
|
|
...def,
|
|||
|
|
checks: [],
|
|||
|
|
...util_exports.normalizeParams(params),
|
|||
|
|
entries: newEntries
|
|||
|
|
});
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function _enum2(values, params) {
|
|||
|
|
const entries = Array.isArray(values) ? Object.fromEntries(values.map((v) => [v, v])) : values;
|
|||
|
|
return new ZodEnum({
|
|||
|
|
type: "enum",
|
|||
|
|
entries,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function nativeEnum(entries, params) {
|
|||
|
|
return new ZodEnum({
|
|||
|
|
type: "enum",
|
|||
|
|
entries,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodLiteral = $constructor("ZodLiteral", (inst, def) => {
|
|||
|
|
$ZodLiteral.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => literalProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.values = new Set(def.values);
|
|||
|
|
Object.defineProperty(inst, "value", {
|
|||
|
|
get() {
|
|||
|
|
if (def.values.length > 1) {
|
|||
|
|
throw new Error("This schema contains multiple valid literal values. Use `.values` instead.");
|
|||
|
|
}
|
|||
|
|
return def.values[0];
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
});
|
|||
|
|
function literal(value, params) {
|
|||
|
|
return new ZodLiteral({
|
|||
|
|
type: "literal",
|
|||
|
|
values: Array.isArray(value) ? value : [value],
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodFile = $constructor("ZodFile", (inst, def) => {
|
|||
|
|
$ZodFile.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => fileProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.min = (size, params) => inst.check(_minSize(size, params));
|
|||
|
|
inst.max = (size, params) => inst.check(_maxSize(size, params));
|
|||
|
|
inst.mime = (types, params) => inst.check(_mime(Array.isArray(types) ? types : [types], params));
|
|||
|
|
});
|
|||
|
|
function file(params) {
|
|||
|
|
return _file(ZodFile, params);
|
|||
|
|
}
|
|||
|
|
var ZodTransform = $constructor("ZodTransform", (inst, def) => {
|
|||
|
|
$ZodTransform.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => transformProcessor(inst, ctx, json2, params);
|
|||
|
|
inst._zod.parse = (payload, _ctx) => {
|
|||
|
|
if (_ctx.direction === "backward") {
|
|||
|
|
throw new $ZodEncodeError(inst.constructor.name);
|
|||
|
|
}
|
|||
|
|
payload.addIssue = (issue2) => {
|
|||
|
|
if (typeof issue2 === "string") {
|
|||
|
|
payload.issues.push(util_exports.issue(issue2, payload.value, def));
|
|||
|
|
} else {
|
|||
|
|
const _issue = issue2;
|
|||
|
|
if (_issue.fatal)
|
|||
|
|
_issue.continue = false;
|
|||
|
|
_issue.code ?? (_issue.code = "custom");
|
|||
|
|
_issue.input ?? (_issue.input = payload.value);
|
|||
|
|
_issue.inst ?? (_issue.inst = inst);
|
|||
|
|
payload.issues.push(util_exports.issue(_issue));
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
const output = def.transform(payload.value, payload);
|
|||
|
|
if (output instanceof Promise) {
|
|||
|
|
return output.then((output2) => {
|
|||
|
|
payload.value = output2;
|
|||
|
|
return payload;
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
payload.value = output;
|
|||
|
|
return payload;
|
|||
|
|
};
|
|||
|
|
});
|
|||
|
|
function transform(fn) {
|
|||
|
|
return new ZodTransform({
|
|||
|
|
type: "transform",
|
|||
|
|
transform: fn
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodOptional = $constructor("ZodOptional", (inst, def) => {
|
|||
|
|
$ZodOptional.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => optionalProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
});
|
|||
|
|
function optional(innerType) {
|
|||
|
|
return new ZodOptional({
|
|||
|
|
type: "optional",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodExactOptional = $constructor("ZodExactOptional", (inst, def) => {
|
|||
|
|
$ZodExactOptional.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => optionalProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
});
|
|||
|
|
function exactOptional(innerType) {
|
|||
|
|
return new ZodExactOptional({
|
|||
|
|
type: "optional",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodNullable = $constructor("ZodNullable", (inst, def) => {
|
|||
|
|
$ZodNullable.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => nullableProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
});
|
|||
|
|
function nullable(innerType) {
|
|||
|
|
return new ZodNullable({
|
|||
|
|
type: "nullable",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function nullish2(innerType) {
|
|||
|
|
return optional(nullable(innerType));
|
|||
|
|
}
|
|||
|
|
var ZodDefault = $constructor("ZodDefault", (inst, def) => {
|
|||
|
|
$ZodDefault.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => defaultProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
inst.removeDefault = inst.unwrap;
|
|||
|
|
});
|
|||
|
|
function _default2(innerType, defaultValue) {
|
|||
|
|
return new ZodDefault({
|
|||
|
|
type: "default",
|
|||
|
|
innerType,
|
|||
|
|
get defaultValue() {
|
|||
|
|
return typeof defaultValue === "function" ? defaultValue() : util_exports.shallowClone(defaultValue);
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodPrefault = $constructor("ZodPrefault", (inst, def) => {
|
|||
|
|
$ZodPrefault.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => prefaultProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
});
|
|||
|
|
function prefault(innerType, defaultValue) {
|
|||
|
|
return new ZodPrefault({
|
|||
|
|
type: "prefault",
|
|||
|
|
innerType,
|
|||
|
|
get defaultValue() {
|
|||
|
|
return typeof defaultValue === "function" ? defaultValue() : util_exports.shallowClone(defaultValue);
|
|||
|
|
}
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodNonOptional = $constructor("ZodNonOptional", (inst, def) => {
|
|||
|
|
$ZodNonOptional.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => nonoptionalProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
});
|
|||
|
|
function nonoptional(innerType, params) {
|
|||
|
|
return new ZodNonOptional({
|
|||
|
|
type: "nonoptional",
|
|||
|
|
innerType,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodSuccess = $constructor("ZodSuccess", (inst, def) => {
|
|||
|
|
$ZodSuccess.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => successProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
});
|
|||
|
|
function success(innerType) {
|
|||
|
|
return new ZodSuccess({
|
|||
|
|
type: "success",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodCatch = $constructor("ZodCatch", (inst, def) => {
|
|||
|
|
$ZodCatch.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => catchProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
inst.removeCatch = inst.unwrap;
|
|||
|
|
});
|
|||
|
|
function _catch2(innerType, catchValue) {
|
|||
|
|
return new ZodCatch({
|
|||
|
|
type: "catch",
|
|||
|
|
innerType,
|
|||
|
|
catchValue: typeof catchValue === "function" ? catchValue : () => catchValue
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodNaN = $constructor("ZodNaN", (inst, def) => {
|
|||
|
|
$ZodNaN.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => nanProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function nan(params) {
|
|||
|
|
return _nan(ZodNaN, params);
|
|||
|
|
}
|
|||
|
|
var ZodPipe = $constructor("ZodPipe", (inst, def) => {
|
|||
|
|
$ZodPipe.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => pipeProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.in = def.in;
|
|||
|
|
inst.out = def.out;
|
|||
|
|
});
|
|||
|
|
function pipe(in_, out) {
|
|||
|
|
return new ZodPipe({
|
|||
|
|
type: "pipe",
|
|||
|
|
in: in_,
|
|||
|
|
out
|
|||
|
|
// ...util.normalizeParams(params),
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodCodec = $constructor("ZodCodec", (inst, def) => {
|
|||
|
|
ZodPipe.init(inst, def);
|
|||
|
|
$ZodCodec.init(inst, def);
|
|||
|
|
});
|
|||
|
|
function codec(in_, out, params) {
|
|||
|
|
return new ZodCodec({
|
|||
|
|
type: "pipe",
|
|||
|
|
in: in_,
|
|||
|
|
out,
|
|||
|
|
transform: params.decode,
|
|||
|
|
reverseTransform: params.encode
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodReadonly = $constructor("ZodReadonly", (inst, def) => {
|
|||
|
|
$ZodReadonly.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => readonlyProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
});
|
|||
|
|
function readonly(innerType) {
|
|||
|
|
return new ZodReadonly({
|
|||
|
|
type: "readonly",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodTemplateLiteral = $constructor("ZodTemplateLiteral", (inst, def) => {
|
|||
|
|
$ZodTemplateLiteral.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => templateLiteralProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function templateLiteral(parts, params) {
|
|||
|
|
return new ZodTemplateLiteral({
|
|||
|
|
type: "template_literal",
|
|||
|
|
parts,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodLazy = $constructor("ZodLazy", (inst, def) => {
|
|||
|
|
$ZodLazy.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => lazyProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.getter();
|
|||
|
|
});
|
|||
|
|
function lazy(getter) {
|
|||
|
|
return new ZodLazy({
|
|||
|
|
type: "lazy",
|
|||
|
|
getter
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodPromise = $constructor("ZodPromise", (inst, def) => {
|
|||
|
|
$ZodPromise.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => promiseProcessor(inst, ctx, json2, params);
|
|||
|
|
inst.unwrap = () => inst._zod.def.innerType;
|
|||
|
|
});
|
|||
|
|
function promise(innerType) {
|
|||
|
|
return new ZodPromise({
|
|||
|
|
type: "promise",
|
|||
|
|
innerType
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodFunction = $constructor("ZodFunction", (inst, def) => {
|
|||
|
|
$ZodFunction.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => functionProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function _function(params) {
|
|||
|
|
return new ZodFunction({
|
|||
|
|
type: "function",
|
|||
|
|
input: Array.isArray(params?.input) ? tuple(params?.input) : params?.input ?? array(unknown()),
|
|||
|
|
output: params?.output ?? unknown()
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
var ZodCustom = $constructor("ZodCustom", (inst, def) => {
|
|||
|
|
$ZodCustom.init(inst, def);
|
|||
|
|
ZodType.init(inst, def);
|
|||
|
|
inst._zod.processJSONSchema = (ctx, json2, params) => customProcessor(inst, ctx, json2, params);
|
|||
|
|
});
|
|||
|
|
function check(fn) {
|
|||
|
|
const ch = new $ZodCheck({
|
|||
|
|
check: "custom"
|
|||
|
|
// ...util.normalizeParams(params),
|
|||
|
|
});
|
|||
|
|
ch._zod.check = fn;
|
|||
|
|
return ch;
|
|||
|
|
}
|
|||
|
|
function custom(fn, _params) {
|
|||
|
|
return _custom(ZodCustom, fn ?? (() => true), _params);
|
|||
|
|
}
|
|||
|
|
function refine(fn, _params = {}) {
|
|||
|
|
return _refine(ZodCustom, fn, _params);
|
|||
|
|
}
|
|||
|
|
function superRefine(fn) {
|
|||
|
|
return _superRefine(fn);
|
|||
|
|
}
|
|||
|
|
var describe2 = describe;
|
|||
|
|
var meta2 = meta;
|
|||
|
|
function _instanceof(cls, params = {}) {
|
|||
|
|
const inst = new ZodCustom({
|
|||
|
|
type: "custom",
|
|||
|
|
check: "custom",
|
|||
|
|
fn: (data) => data instanceof cls,
|
|||
|
|
abort: true,
|
|||
|
|
...util_exports.normalizeParams(params)
|
|||
|
|
});
|
|||
|
|
inst._zod.bag.Class = cls;
|
|||
|
|
inst._zod.check = (payload) => {
|
|||
|
|
if (!(payload.value instanceof cls)) {
|
|||
|
|
payload.issues.push({
|
|||
|
|
code: "invalid_type",
|
|||
|
|
expected: cls.name,
|
|||
|
|
input: payload.value,
|
|||
|
|
inst,
|
|||
|
|
path: [...inst._zod.def.path ?? []]
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
};
|
|||
|
|
return inst;
|
|||
|
|
}
|
|||
|
|
var stringbool = (...args) => _stringbool({
|
|||
|
|
Codec: ZodCodec,
|
|||
|
|
Boolean: ZodBoolean,
|
|||
|
|
String: ZodString
|
|||
|
|
}, ...args);
|
|||
|
|
function json(params) {
|
|||
|
|
const jsonSchema = lazy(() => {
|
|||
|
|
return union([string2(params), number2(), boolean2(), _null3(), array(jsonSchema), record(string2(), jsonSchema)]);
|
|||
|
|
});
|
|||
|
|
return jsonSchema;
|
|||
|
|
}
|
|||
|
|
function preprocess(fn, schema) {
|
|||
|
|
return pipe(transform(fn), schema);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/compat.js
|
|||
|
|
var ZodIssueCode = {
|
|||
|
|
invalid_type: "invalid_type",
|
|||
|
|
too_big: "too_big",
|
|||
|
|
too_small: "too_small",
|
|||
|
|
invalid_format: "invalid_format",
|
|||
|
|
not_multiple_of: "not_multiple_of",
|
|||
|
|
unrecognized_keys: "unrecognized_keys",
|
|||
|
|
invalid_union: "invalid_union",
|
|||
|
|
invalid_key: "invalid_key",
|
|||
|
|
invalid_element: "invalid_element",
|
|||
|
|
invalid_value: "invalid_value",
|
|||
|
|
custom: "custom"
|
|||
|
|
};
|
|||
|
|
function setErrorMap(map2) {
|
|||
|
|
config({
|
|||
|
|
customError: map2
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
function getErrorMap() {
|
|||
|
|
return config().customError;
|
|||
|
|
}
|
|||
|
|
var ZodFirstPartyTypeKind;
|
|||
|
|
/* @__PURE__ */ (function(ZodFirstPartyTypeKind2) {
|
|||
|
|
})(ZodFirstPartyTypeKind || (ZodFirstPartyTypeKind = {}));
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/from-json-schema.js
|
|||
|
|
var z = {
|
|||
|
|
...schemas_exports2,
|
|||
|
|
...checks_exports2,
|
|||
|
|
iso: iso_exports
|
|||
|
|
};
|
|||
|
|
var RECOGNIZED_KEYS = /* @__PURE__ */ new Set([
|
|||
|
|
// Schema identification
|
|||
|
|
"$schema",
|
|||
|
|
"$ref",
|
|||
|
|
"$defs",
|
|||
|
|
"definitions",
|
|||
|
|
// Core schema keywords
|
|||
|
|
"$id",
|
|||
|
|
"id",
|
|||
|
|
"$comment",
|
|||
|
|
"$anchor",
|
|||
|
|
"$vocabulary",
|
|||
|
|
"$dynamicRef",
|
|||
|
|
"$dynamicAnchor",
|
|||
|
|
// Type
|
|||
|
|
"type",
|
|||
|
|
"enum",
|
|||
|
|
"const",
|
|||
|
|
// Composition
|
|||
|
|
"anyOf",
|
|||
|
|
"oneOf",
|
|||
|
|
"allOf",
|
|||
|
|
"not",
|
|||
|
|
// Object
|
|||
|
|
"properties",
|
|||
|
|
"required",
|
|||
|
|
"additionalProperties",
|
|||
|
|
"patternProperties",
|
|||
|
|
"propertyNames",
|
|||
|
|
"minProperties",
|
|||
|
|
"maxProperties",
|
|||
|
|
// Array
|
|||
|
|
"items",
|
|||
|
|
"prefixItems",
|
|||
|
|
"additionalItems",
|
|||
|
|
"minItems",
|
|||
|
|
"maxItems",
|
|||
|
|
"uniqueItems",
|
|||
|
|
"contains",
|
|||
|
|
"minContains",
|
|||
|
|
"maxContains",
|
|||
|
|
// String
|
|||
|
|
"minLength",
|
|||
|
|
"maxLength",
|
|||
|
|
"pattern",
|
|||
|
|
"format",
|
|||
|
|
// Number
|
|||
|
|
"minimum",
|
|||
|
|
"maximum",
|
|||
|
|
"exclusiveMinimum",
|
|||
|
|
"exclusiveMaximum",
|
|||
|
|
"multipleOf",
|
|||
|
|
// Already handled metadata
|
|||
|
|
"description",
|
|||
|
|
"default",
|
|||
|
|
// Content
|
|||
|
|
"contentEncoding",
|
|||
|
|
"contentMediaType",
|
|||
|
|
"contentSchema",
|
|||
|
|
// Unsupported (error-throwing)
|
|||
|
|
"unevaluatedItems",
|
|||
|
|
"unevaluatedProperties",
|
|||
|
|
"if",
|
|||
|
|
"then",
|
|||
|
|
"else",
|
|||
|
|
"dependentSchemas",
|
|||
|
|
"dependentRequired",
|
|||
|
|
// OpenAPI
|
|||
|
|
"nullable",
|
|||
|
|
"readOnly"
|
|||
|
|
]);
|
|||
|
|
function detectVersion(schema, defaultTarget) {
|
|||
|
|
const $schema = schema.$schema;
|
|||
|
|
if ($schema === "https://json-schema.org/draft/2020-12/schema") {
|
|||
|
|
return "draft-2020-12";
|
|||
|
|
}
|
|||
|
|
if ($schema === "http://json-schema.org/draft-07/schema#") {
|
|||
|
|
return "draft-7";
|
|||
|
|
}
|
|||
|
|
if ($schema === "http://json-schema.org/draft-04/schema#") {
|
|||
|
|
return "draft-4";
|
|||
|
|
}
|
|||
|
|
return defaultTarget ?? "draft-2020-12";
|
|||
|
|
}
|
|||
|
|
function resolveRef(ref, ctx) {
|
|||
|
|
if (!ref.startsWith("#")) {
|
|||
|
|
throw new Error("External $ref is not supported, only local refs (#/...) are allowed");
|
|||
|
|
}
|
|||
|
|
const path = ref.slice(1).split("/").filter(Boolean);
|
|||
|
|
if (path.length === 0) {
|
|||
|
|
return ctx.rootSchema;
|
|||
|
|
}
|
|||
|
|
const defsKey = ctx.version === "draft-2020-12" ? "$defs" : "definitions";
|
|||
|
|
if (path[0] === defsKey) {
|
|||
|
|
const key = path[1];
|
|||
|
|
if (!key || !ctx.defs[key]) {
|
|||
|
|
throw new Error(`Reference not found: ${ref}`);
|
|||
|
|
}
|
|||
|
|
return ctx.defs[key];
|
|||
|
|
}
|
|||
|
|
throw new Error(`Reference not found: ${ref}`);
|
|||
|
|
}
|
|||
|
|
function convertBaseSchema(schema, ctx) {
|
|||
|
|
if (schema.not !== void 0) {
|
|||
|
|
if (typeof schema.not === "object" && Object.keys(schema.not).length === 0) {
|
|||
|
|
return z.never();
|
|||
|
|
}
|
|||
|
|
throw new Error("not is not supported in Zod (except { not: {} } for never)");
|
|||
|
|
}
|
|||
|
|
if (schema.unevaluatedItems !== void 0) {
|
|||
|
|
throw new Error("unevaluatedItems is not supported");
|
|||
|
|
}
|
|||
|
|
if (schema.unevaluatedProperties !== void 0) {
|
|||
|
|
throw new Error("unevaluatedProperties is not supported");
|
|||
|
|
}
|
|||
|
|
if (schema.if !== void 0 || schema.then !== void 0 || schema.else !== void 0) {
|
|||
|
|
throw new Error("Conditional schemas (if/then/else) are not supported");
|
|||
|
|
}
|
|||
|
|
if (schema.dependentSchemas !== void 0 || schema.dependentRequired !== void 0) {
|
|||
|
|
throw new Error("dependentSchemas and dependentRequired are not supported");
|
|||
|
|
}
|
|||
|
|
if (schema.$ref) {
|
|||
|
|
const refPath = schema.$ref;
|
|||
|
|
if (ctx.refs.has(refPath)) {
|
|||
|
|
return ctx.refs.get(refPath);
|
|||
|
|
}
|
|||
|
|
if (ctx.processing.has(refPath)) {
|
|||
|
|
return z.lazy(() => {
|
|||
|
|
if (!ctx.refs.has(refPath)) {
|
|||
|
|
throw new Error(`Circular reference not resolved: ${refPath}`);
|
|||
|
|
}
|
|||
|
|
return ctx.refs.get(refPath);
|
|||
|
|
});
|
|||
|
|
}
|
|||
|
|
ctx.processing.add(refPath);
|
|||
|
|
const resolved = resolveRef(refPath, ctx);
|
|||
|
|
const zodSchema2 = convertSchema(resolved, ctx);
|
|||
|
|
ctx.refs.set(refPath, zodSchema2);
|
|||
|
|
ctx.processing.delete(refPath);
|
|||
|
|
return zodSchema2;
|
|||
|
|
}
|
|||
|
|
if (schema.enum !== void 0) {
|
|||
|
|
const enumValues = schema.enum;
|
|||
|
|
if (ctx.version === "openapi-3.0" && schema.nullable === true && enumValues.length === 1 && enumValues[0] === null) {
|
|||
|
|
return z.null();
|
|||
|
|
}
|
|||
|
|
if (enumValues.length === 0) {
|
|||
|
|
return z.never();
|
|||
|
|
}
|
|||
|
|
if (enumValues.length === 1) {
|
|||
|
|
return z.literal(enumValues[0]);
|
|||
|
|
}
|
|||
|
|
if (enumValues.every((v) => typeof v === "string")) {
|
|||
|
|
return z.enum(enumValues);
|
|||
|
|
}
|
|||
|
|
const literalSchemas = enumValues.map((v) => z.literal(v));
|
|||
|
|
if (literalSchemas.length < 2) {
|
|||
|
|
return literalSchemas[0];
|
|||
|
|
}
|
|||
|
|
return z.union([literalSchemas[0], literalSchemas[1], ...literalSchemas.slice(2)]);
|
|||
|
|
}
|
|||
|
|
if (schema.const !== void 0) {
|
|||
|
|
return z.literal(schema.const);
|
|||
|
|
}
|
|||
|
|
const type = schema.type;
|
|||
|
|
if (Array.isArray(type)) {
|
|||
|
|
const typeSchemas = type.map((t) => {
|
|||
|
|
const typeSchema = { ...schema, type: t };
|
|||
|
|
return convertBaseSchema(typeSchema, ctx);
|
|||
|
|
});
|
|||
|
|
if (typeSchemas.length === 0) {
|
|||
|
|
return z.never();
|
|||
|
|
}
|
|||
|
|
if (typeSchemas.length === 1) {
|
|||
|
|
return typeSchemas[0];
|
|||
|
|
}
|
|||
|
|
return z.union(typeSchemas);
|
|||
|
|
}
|
|||
|
|
if (!type) {
|
|||
|
|
return z.any();
|
|||
|
|
}
|
|||
|
|
let zodSchema;
|
|||
|
|
switch (type) {
|
|||
|
|
case "string": {
|
|||
|
|
let stringSchema = z.string();
|
|||
|
|
if (schema.format) {
|
|||
|
|
const format = schema.format;
|
|||
|
|
if (format === "email") {
|
|||
|
|
stringSchema = stringSchema.check(z.email());
|
|||
|
|
} else if (format === "uri" || format === "uri-reference") {
|
|||
|
|
stringSchema = stringSchema.check(z.url());
|
|||
|
|
} else if (format === "uuid" || format === "guid") {
|
|||
|
|
stringSchema = stringSchema.check(z.uuid());
|
|||
|
|
} else if (format === "date-time") {
|
|||
|
|
stringSchema = stringSchema.check(z.iso.datetime());
|
|||
|
|
} else if (format === "date") {
|
|||
|
|
stringSchema = stringSchema.check(z.iso.date());
|
|||
|
|
} else if (format === "time") {
|
|||
|
|
stringSchema = stringSchema.check(z.iso.time());
|
|||
|
|
} else if (format === "duration") {
|
|||
|
|
stringSchema = stringSchema.check(z.iso.duration());
|
|||
|
|
} else if (format === "ipv4") {
|
|||
|
|
stringSchema = stringSchema.check(z.ipv4());
|
|||
|
|
} else if (format === "ipv6") {
|
|||
|
|
stringSchema = stringSchema.check(z.ipv6());
|
|||
|
|
} else if (format === "mac") {
|
|||
|
|
stringSchema = stringSchema.check(z.mac());
|
|||
|
|
} else if (format === "cidr") {
|
|||
|
|
stringSchema = stringSchema.check(z.cidrv4());
|
|||
|
|
} else if (format === "cidr-v6") {
|
|||
|
|
stringSchema = stringSchema.check(z.cidrv6());
|
|||
|
|
} else if (format === "base64") {
|
|||
|
|
stringSchema = stringSchema.check(z.base64());
|
|||
|
|
} else if (format === "base64url") {
|
|||
|
|
stringSchema = stringSchema.check(z.base64url());
|
|||
|
|
} else if (format === "e164") {
|
|||
|
|
stringSchema = stringSchema.check(z.e164());
|
|||
|
|
} else if (format === "jwt") {
|
|||
|
|
stringSchema = stringSchema.check(z.jwt());
|
|||
|
|
} else if (format === "emoji") {
|
|||
|
|
stringSchema = stringSchema.check(z.emoji());
|
|||
|
|
} else if (format === "nanoid") {
|
|||
|
|
stringSchema = stringSchema.check(z.nanoid());
|
|||
|
|
} else if (format === "cuid") {
|
|||
|
|
stringSchema = stringSchema.check(z.cuid());
|
|||
|
|
} else if (format === "cuid2") {
|
|||
|
|
stringSchema = stringSchema.check(z.cuid2());
|
|||
|
|
} else if (format === "ulid") {
|
|||
|
|
stringSchema = stringSchema.check(z.ulid());
|
|||
|
|
} else if (format === "xid") {
|
|||
|
|
stringSchema = stringSchema.check(z.xid());
|
|||
|
|
} else if (format === "ksuid") {
|
|||
|
|
stringSchema = stringSchema.check(z.ksuid());
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (typeof schema.minLength === "number") {
|
|||
|
|
stringSchema = stringSchema.min(schema.minLength);
|
|||
|
|
}
|
|||
|
|
if (typeof schema.maxLength === "number") {
|
|||
|
|
stringSchema = stringSchema.max(schema.maxLength);
|
|||
|
|
}
|
|||
|
|
if (schema.pattern) {
|
|||
|
|
stringSchema = stringSchema.regex(new RegExp(schema.pattern));
|
|||
|
|
}
|
|||
|
|
zodSchema = stringSchema;
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
case "number":
|
|||
|
|
case "integer": {
|
|||
|
|
let numberSchema = type === "integer" ? z.number().int() : z.number();
|
|||
|
|
if (typeof schema.minimum === "number") {
|
|||
|
|
numberSchema = numberSchema.min(schema.minimum);
|
|||
|
|
}
|
|||
|
|
if (typeof schema.maximum === "number") {
|
|||
|
|
numberSchema = numberSchema.max(schema.maximum);
|
|||
|
|
}
|
|||
|
|
if (typeof schema.exclusiveMinimum === "number") {
|
|||
|
|
numberSchema = numberSchema.gt(schema.exclusiveMinimum);
|
|||
|
|
} else if (schema.exclusiveMinimum === true && typeof schema.minimum === "number") {
|
|||
|
|
numberSchema = numberSchema.gt(schema.minimum);
|
|||
|
|
}
|
|||
|
|
if (typeof schema.exclusiveMaximum === "number") {
|
|||
|
|
numberSchema = numberSchema.lt(schema.exclusiveMaximum);
|
|||
|
|
} else if (schema.exclusiveMaximum === true && typeof schema.maximum === "number") {
|
|||
|
|
numberSchema = numberSchema.lt(schema.maximum);
|
|||
|
|
}
|
|||
|
|
if (typeof schema.multipleOf === "number") {
|
|||
|
|
numberSchema = numberSchema.multipleOf(schema.multipleOf);
|
|||
|
|
}
|
|||
|
|
zodSchema = numberSchema;
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
case "boolean": {
|
|||
|
|
zodSchema = z.boolean();
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
case "null": {
|
|||
|
|
zodSchema = z.null();
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
case "object": {
|
|||
|
|
const shape = {};
|
|||
|
|
const properties = schema.properties || {};
|
|||
|
|
const requiredSet = new Set(schema.required || []);
|
|||
|
|
for (const [key, propSchema] of Object.entries(properties)) {
|
|||
|
|
const propZodSchema = convertSchema(propSchema, ctx);
|
|||
|
|
shape[key] = requiredSet.has(key) ? propZodSchema : propZodSchema.optional();
|
|||
|
|
}
|
|||
|
|
if (schema.propertyNames) {
|
|||
|
|
const keySchema = convertSchema(schema.propertyNames, ctx);
|
|||
|
|
const valueSchema = schema.additionalProperties && typeof schema.additionalProperties === "object" ? convertSchema(schema.additionalProperties, ctx) : z.any();
|
|||
|
|
if (Object.keys(shape).length === 0) {
|
|||
|
|
zodSchema = z.record(keySchema, valueSchema);
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
const objectSchema2 = z.object(shape).passthrough();
|
|||
|
|
const recordSchema = z.looseRecord(keySchema, valueSchema);
|
|||
|
|
zodSchema = z.intersection(objectSchema2, recordSchema);
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
if (schema.patternProperties) {
|
|||
|
|
const patternProps = schema.patternProperties;
|
|||
|
|
const patternKeys = Object.keys(patternProps);
|
|||
|
|
const looseRecords = [];
|
|||
|
|
for (const pattern of patternKeys) {
|
|||
|
|
const patternValue = convertSchema(patternProps[pattern], ctx);
|
|||
|
|
const keySchema = z.string().regex(new RegExp(pattern));
|
|||
|
|
looseRecords.push(z.looseRecord(keySchema, patternValue));
|
|||
|
|
}
|
|||
|
|
const schemasToIntersect = [];
|
|||
|
|
if (Object.keys(shape).length > 0) {
|
|||
|
|
schemasToIntersect.push(z.object(shape).passthrough());
|
|||
|
|
}
|
|||
|
|
schemasToIntersect.push(...looseRecords);
|
|||
|
|
if (schemasToIntersect.length === 0) {
|
|||
|
|
zodSchema = z.object({}).passthrough();
|
|||
|
|
} else if (schemasToIntersect.length === 1) {
|
|||
|
|
zodSchema = schemasToIntersect[0];
|
|||
|
|
} else {
|
|||
|
|
let result = z.intersection(schemasToIntersect[0], schemasToIntersect[1]);
|
|||
|
|
for (let i = 2; i < schemasToIntersect.length; i++) {
|
|||
|
|
result = z.intersection(result, schemasToIntersect[i]);
|
|||
|
|
}
|
|||
|
|
zodSchema = result;
|
|||
|
|
}
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
const objectSchema = z.object(shape);
|
|||
|
|
if (schema.additionalProperties === false) {
|
|||
|
|
zodSchema = objectSchema.strict();
|
|||
|
|
} else if (typeof schema.additionalProperties === "object") {
|
|||
|
|
zodSchema = objectSchema.catchall(convertSchema(schema.additionalProperties, ctx));
|
|||
|
|
} else {
|
|||
|
|
zodSchema = objectSchema.passthrough();
|
|||
|
|
}
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
case "array": {
|
|||
|
|
const prefixItems = schema.prefixItems;
|
|||
|
|
const items = schema.items;
|
|||
|
|
if (prefixItems && Array.isArray(prefixItems)) {
|
|||
|
|
const tupleItems = prefixItems.map((item) => convertSchema(item, ctx));
|
|||
|
|
const rest = items && typeof items === "object" && !Array.isArray(items) ? convertSchema(items, ctx) : void 0;
|
|||
|
|
if (rest) {
|
|||
|
|
zodSchema = z.tuple(tupleItems).rest(rest);
|
|||
|
|
} else {
|
|||
|
|
zodSchema = z.tuple(tupleItems);
|
|||
|
|
}
|
|||
|
|
if (typeof schema.minItems === "number") {
|
|||
|
|
zodSchema = zodSchema.check(z.minLength(schema.minItems));
|
|||
|
|
}
|
|||
|
|
if (typeof schema.maxItems === "number") {
|
|||
|
|
zodSchema = zodSchema.check(z.maxLength(schema.maxItems));
|
|||
|
|
}
|
|||
|
|
} else if (Array.isArray(items)) {
|
|||
|
|
const tupleItems = items.map((item) => convertSchema(item, ctx));
|
|||
|
|
const rest = schema.additionalItems && typeof schema.additionalItems === "object" ? convertSchema(schema.additionalItems, ctx) : void 0;
|
|||
|
|
if (rest) {
|
|||
|
|
zodSchema = z.tuple(tupleItems).rest(rest);
|
|||
|
|
} else {
|
|||
|
|
zodSchema = z.tuple(tupleItems);
|
|||
|
|
}
|
|||
|
|
if (typeof schema.minItems === "number") {
|
|||
|
|
zodSchema = zodSchema.check(z.minLength(schema.minItems));
|
|||
|
|
}
|
|||
|
|
if (typeof schema.maxItems === "number") {
|
|||
|
|
zodSchema = zodSchema.check(z.maxLength(schema.maxItems));
|
|||
|
|
}
|
|||
|
|
} else if (items !== void 0) {
|
|||
|
|
const element = convertSchema(items, ctx);
|
|||
|
|
let arraySchema = z.array(element);
|
|||
|
|
if (typeof schema.minItems === "number") {
|
|||
|
|
arraySchema = arraySchema.min(schema.minItems);
|
|||
|
|
}
|
|||
|
|
if (typeof schema.maxItems === "number") {
|
|||
|
|
arraySchema = arraySchema.max(schema.maxItems);
|
|||
|
|
}
|
|||
|
|
zodSchema = arraySchema;
|
|||
|
|
} else {
|
|||
|
|
zodSchema = z.array(z.any());
|
|||
|
|
}
|
|||
|
|
break;
|
|||
|
|
}
|
|||
|
|
default:
|
|||
|
|
throw new Error(`Unsupported type: ${type}`);
|
|||
|
|
}
|
|||
|
|
if (schema.description) {
|
|||
|
|
zodSchema = zodSchema.describe(schema.description);
|
|||
|
|
}
|
|||
|
|
if (schema.default !== void 0) {
|
|||
|
|
zodSchema = zodSchema.default(schema.default);
|
|||
|
|
}
|
|||
|
|
return zodSchema;
|
|||
|
|
}
|
|||
|
|
function convertSchema(schema, ctx) {
|
|||
|
|
if (typeof schema === "boolean") {
|
|||
|
|
return schema ? z.any() : z.never();
|
|||
|
|
}
|
|||
|
|
let baseSchema = convertBaseSchema(schema, ctx);
|
|||
|
|
const hasExplicitType = schema.type || schema.enum !== void 0 || schema.const !== void 0;
|
|||
|
|
if (schema.anyOf && Array.isArray(schema.anyOf)) {
|
|||
|
|
const options = schema.anyOf.map((s) => convertSchema(s, ctx));
|
|||
|
|
const anyOfUnion = z.union(options);
|
|||
|
|
baseSchema = hasExplicitType ? z.intersection(baseSchema, anyOfUnion) : anyOfUnion;
|
|||
|
|
}
|
|||
|
|
if (schema.oneOf && Array.isArray(schema.oneOf)) {
|
|||
|
|
const options = schema.oneOf.map((s) => convertSchema(s, ctx));
|
|||
|
|
const oneOfUnion = z.xor(options);
|
|||
|
|
baseSchema = hasExplicitType ? z.intersection(baseSchema, oneOfUnion) : oneOfUnion;
|
|||
|
|
}
|
|||
|
|
if (schema.allOf && Array.isArray(schema.allOf)) {
|
|||
|
|
if (schema.allOf.length === 0) {
|
|||
|
|
baseSchema = hasExplicitType ? baseSchema : z.any();
|
|||
|
|
} else {
|
|||
|
|
let result = hasExplicitType ? baseSchema : convertSchema(schema.allOf[0], ctx);
|
|||
|
|
const startIdx = hasExplicitType ? 0 : 1;
|
|||
|
|
for (let i = startIdx; i < schema.allOf.length; i++) {
|
|||
|
|
result = z.intersection(result, convertSchema(schema.allOf[i], ctx));
|
|||
|
|
}
|
|||
|
|
baseSchema = result;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (schema.nullable === true && ctx.version === "openapi-3.0") {
|
|||
|
|
baseSchema = z.nullable(baseSchema);
|
|||
|
|
}
|
|||
|
|
if (schema.readOnly === true) {
|
|||
|
|
baseSchema = z.readonly(baseSchema);
|
|||
|
|
}
|
|||
|
|
const extraMeta = {};
|
|||
|
|
const coreMetadataKeys = ["$id", "id", "$comment", "$anchor", "$vocabulary", "$dynamicRef", "$dynamicAnchor"];
|
|||
|
|
for (const key of coreMetadataKeys) {
|
|||
|
|
if (key in schema) {
|
|||
|
|
extraMeta[key] = schema[key];
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
const contentMetadataKeys = ["contentEncoding", "contentMediaType", "contentSchema"];
|
|||
|
|
for (const key of contentMetadataKeys) {
|
|||
|
|
if (key in schema) {
|
|||
|
|
extraMeta[key] = schema[key];
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
for (const key of Object.keys(schema)) {
|
|||
|
|
if (!RECOGNIZED_KEYS.has(key)) {
|
|||
|
|
extraMeta[key] = schema[key];
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
if (Object.keys(extraMeta).length > 0) {
|
|||
|
|
ctx.registry.add(baseSchema, extraMeta);
|
|||
|
|
}
|
|||
|
|
return baseSchema;
|
|||
|
|
}
|
|||
|
|
function fromJSONSchema(schema, params) {
|
|||
|
|
if (typeof schema === "boolean") {
|
|||
|
|
return schema ? z.any() : z.never();
|
|||
|
|
}
|
|||
|
|
const version2 = detectVersion(schema, params?.defaultTarget);
|
|||
|
|
const defs = schema.$defs || schema.definitions || {};
|
|||
|
|
const ctx = {
|
|||
|
|
version: version2,
|
|||
|
|
defs,
|
|||
|
|
refs: /* @__PURE__ */ new Map(),
|
|||
|
|
processing: /* @__PURE__ */ new Set(),
|
|||
|
|
rootSchema: schema,
|
|||
|
|
registry: params?.registry ?? globalRegistry
|
|||
|
|
};
|
|||
|
|
return convertSchema(schema, ctx);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/coerce.js
|
|||
|
|
var coerce_exports = {};
|
|||
|
|
__export(coerce_exports, {
|
|||
|
|
bigint: () => bigint3,
|
|||
|
|
boolean: () => boolean3,
|
|||
|
|
date: () => date4,
|
|||
|
|
number: () => number3,
|
|||
|
|
string: () => string3
|
|||
|
|
});
|
|||
|
|
function string3(params) {
|
|||
|
|
return _coercedString(ZodString, params);
|
|||
|
|
}
|
|||
|
|
function number3(params) {
|
|||
|
|
return _coercedNumber(ZodNumber, params);
|
|||
|
|
}
|
|||
|
|
function boolean3(params) {
|
|||
|
|
return _coercedBoolean(ZodBoolean, params);
|
|||
|
|
}
|
|||
|
|
function bigint3(params) {
|
|||
|
|
return _coercedBigint(ZodBigInt, params);
|
|||
|
|
}
|
|||
|
|
function date4(params) {
|
|||
|
|
return _coercedDate(ZodDate, params);
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
// node_modules/zod/v4/classic/external.js
|
|||
|
|
config(en_default());
|
|||
|
|
|
|||
|
|
// node_modules/zod/index.js
|
|||
|
|
var zod_default = external_exports;
|
|||
|
|
export {
|
|||
|
|
$brand,
|
|||
|
|
$input,
|
|||
|
|
$output,
|
|||
|
|
NEVER,
|
|||
|
|
TimePrecision,
|
|||
|
|
ZodAny,
|
|||
|
|
ZodArray,
|
|||
|
|
ZodBase64,
|
|||
|
|
ZodBase64URL,
|
|||
|
|
ZodBigInt,
|
|||
|
|
ZodBigIntFormat,
|
|||
|
|
ZodBoolean,
|
|||
|
|
ZodCIDRv4,
|
|||
|
|
ZodCIDRv6,
|
|||
|
|
ZodCUID,
|
|||
|
|
ZodCUID2,
|
|||
|
|
ZodCatch,
|
|||
|
|
ZodCodec,
|
|||
|
|
ZodCustom,
|
|||
|
|
ZodCustomStringFormat,
|
|||
|
|
ZodDate,
|
|||
|
|
ZodDefault,
|
|||
|
|
ZodDiscriminatedUnion,
|
|||
|
|
ZodE164,
|
|||
|
|
ZodEmail,
|
|||
|
|
ZodEmoji,
|
|||
|
|
ZodEnum,
|
|||
|
|
ZodError,
|
|||
|
|
ZodExactOptional,
|
|||
|
|
ZodFile,
|
|||
|
|
ZodFirstPartyTypeKind,
|
|||
|
|
ZodFunction,
|
|||
|
|
ZodGUID,
|
|||
|
|
ZodIPv4,
|
|||
|
|
ZodIPv6,
|
|||
|
|
ZodISODate,
|
|||
|
|
ZodISODateTime,
|
|||
|
|
ZodISODuration,
|
|||
|
|
ZodISOTime,
|
|||
|
|
ZodIntersection,
|
|||
|
|
ZodIssueCode,
|
|||
|
|
ZodJWT,
|
|||
|
|
ZodKSUID,
|
|||
|
|
ZodLazy,
|
|||
|
|
ZodLiteral,
|
|||
|
|
ZodMAC,
|
|||
|
|
ZodMap,
|
|||
|
|
ZodNaN,
|
|||
|
|
ZodNanoID,
|
|||
|
|
ZodNever,
|
|||
|
|
ZodNonOptional,
|
|||
|
|
ZodNull,
|
|||
|
|
ZodNullable,
|
|||
|
|
ZodNumber,
|
|||
|
|
ZodNumberFormat,
|
|||
|
|
ZodObject,
|
|||
|
|
ZodOptional,
|
|||
|
|
ZodPipe,
|
|||
|
|
ZodPrefault,
|
|||
|
|
ZodPromise,
|
|||
|
|
ZodReadonly,
|
|||
|
|
ZodRealError,
|
|||
|
|
ZodRecord,
|
|||
|
|
ZodSet,
|
|||
|
|
ZodString,
|
|||
|
|
ZodStringFormat,
|
|||
|
|
ZodSuccess,
|
|||
|
|
ZodSymbol,
|
|||
|
|
ZodTemplateLiteral,
|
|||
|
|
ZodTransform,
|
|||
|
|
ZodTuple,
|
|||
|
|
ZodType,
|
|||
|
|
ZodULID,
|
|||
|
|
ZodURL,
|
|||
|
|
ZodUUID,
|
|||
|
|
ZodUndefined,
|
|||
|
|
ZodUnion,
|
|||
|
|
ZodUnknown,
|
|||
|
|
ZodVoid,
|
|||
|
|
ZodXID,
|
|||
|
|
ZodXor,
|
|||
|
|
_ZodString,
|
|||
|
|
_default2 as _default,
|
|||
|
|
_function,
|
|||
|
|
any,
|
|||
|
|
array,
|
|||
|
|
base642 as base64,
|
|||
|
|
base64url2 as base64url,
|
|||
|
|
bigint2 as bigint,
|
|||
|
|
boolean2 as boolean,
|
|||
|
|
_catch2 as catch,
|
|||
|
|
check,
|
|||
|
|
cidrv42 as cidrv4,
|
|||
|
|
cidrv62 as cidrv6,
|
|||
|
|
clone,
|
|||
|
|
codec,
|
|||
|
|
coerce_exports as coerce,
|
|||
|
|
config,
|
|||
|
|
core_exports2 as core,
|
|||
|
|
cuid3 as cuid,
|
|||
|
|
cuid22 as cuid2,
|
|||
|
|
custom,
|
|||
|
|
date3 as date,
|
|||
|
|
decode2 as decode,
|
|||
|
|
decodeAsync2 as decodeAsync,
|
|||
|
|
zod_default as default,
|
|||
|
|
describe2 as describe,
|
|||
|
|
discriminatedUnion,
|
|||
|
|
e1642 as e164,
|
|||
|
|
email2 as email,
|
|||
|
|
emoji2 as emoji,
|
|||
|
|
encode2 as encode,
|
|||
|
|
encodeAsync2 as encodeAsync,
|
|||
|
|
_endsWith as endsWith,
|
|||
|
|
_enum2 as enum,
|
|||
|
|
exactOptional,
|
|||
|
|
file,
|
|||
|
|
flattenError,
|
|||
|
|
float32,
|
|||
|
|
float64,
|
|||
|
|
formatError,
|
|||
|
|
fromJSONSchema,
|
|||
|
|
_function as function,
|
|||
|
|
getErrorMap,
|
|||
|
|
globalRegistry,
|
|||
|
|
_gt as gt,
|
|||
|
|
_gte as gte,
|
|||
|
|
guid2 as guid,
|
|||
|
|
hash,
|
|||
|
|
hex2 as hex,
|
|||
|
|
hostname2 as hostname,
|
|||
|
|
httpUrl,
|
|||
|
|
_includes as includes,
|
|||
|
|
_instanceof as instanceof,
|
|||
|
|
int,
|
|||
|
|
int32,
|
|||
|
|
int64,
|
|||
|
|
intersection,
|
|||
|
|
ipv42 as ipv4,
|
|||
|
|
ipv62 as ipv6,
|
|||
|
|
iso_exports as iso,
|
|||
|
|
json,
|
|||
|
|
jwt,
|
|||
|
|
keyof,
|
|||
|
|
ksuid2 as ksuid,
|
|||
|
|
lazy,
|
|||
|
|
_length as length,
|
|||
|
|
literal,
|
|||
|
|
locales_exports as locales,
|
|||
|
|
looseObject,
|
|||
|
|
looseRecord,
|
|||
|
|
_lowercase as lowercase,
|
|||
|
|
_lt as lt,
|
|||
|
|
_lte as lte,
|
|||
|
|
mac2 as mac,
|
|||
|
|
map,
|
|||
|
|
_maxLength as maxLength,
|
|||
|
|
_maxSize as maxSize,
|
|||
|
|
meta2 as meta,
|
|||
|
|
_mime as mime,
|
|||
|
|
_minLength as minLength,
|
|||
|
|
_minSize as minSize,
|
|||
|
|
_multipleOf as multipleOf,
|
|||
|
|
nan,
|
|||
|
|
nanoid2 as nanoid,
|
|||
|
|
nativeEnum,
|
|||
|
|
_negative as negative,
|
|||
|
|
never,
|
|||
|
|
_nonnegative as nonnegative,
|
|||
|
|
nonoptional,
|
|||
|
|
_nonpositive as nonpositive,
|
|||
|
|
_normalize as normalize,
|
|||
|
|
_null3 as null,
|
|||
|
|
nullable,
|
|||
|
|
nullish2 as nullish,
|
|||
|
|
number2 as number,
|
|||
|
|
object,
|
|||
|
|
optional,
|
|||
|
|
_overwrite as overwrite,
|
|||
|
|
parse2 as parse,
|
|||
|
|
parseAsync2 as parseAsync,
|
|||
|
|
partialRecord,
|
|||
|
|
pipe,
|
|||
|
|
_positive as positive,
|
|||
|
|
prefault,
|
|||
|
|
preprocess,
|
|||
|
|
prettifyError,
|
|||
|
|
promise,
|
|||
|
|
_property as property,
|
|||
|
|
readonly,
|
|||
|
|
record,
|
|||
|
|
refine,
|
|||
|
|
_regex as regex,
|
|||
|
|
regexes_exports as regexes,
|
|||
|
|
registry,
|
|||
|
|
safeDecode2 as safeDecode,
|
|||
|
|
safeDecodeAsync2 as safeDecodeAsync,
|
|||
|
|
safeEncode2 as safeEncode,
|
|||
|
|
safeEncodeAsync2 as safeEncodeAsync,
|
|||
|
|
safeParse2 as safeParse,
|
|||
|
|
safeParseAsync2 as safeParseAsync,
|
|||
|
|
set,
|
|||
|
|
setErrorMap,
|
|||
|
|
_size as size,
|
|||
|
|
_slugify as slugify,
|
|||
|
|
_startsWith as startsWith,
|
|||
|
|
strictObject,
|
|||
|
|
string2 as string,
|
|||
|
|
stringFormat,
|
|||
|
|
stringbool,
|
|||
|
|
success,
|
|||
|
|
superRefine,
|
|||
|
|
symbol,
|
|||
|
|
templateLiteral,
|
|||
|
|
toJSONSchema,
|
|||
|
|
_toLowerCase as toLowerCase,
|
|||
|
|
_toUpperCase as toUpperCase,
|
|||
|
|
transform,
|
|||
|
|
treeifyError,
|
|||
|
|
_trim as trim,
|
|||
|
|
tuple,
|
|||
|
|
uint32,
|
|||
|
|
uint64,
|
|||
|
|
ulid2 as ulid,
|
|||
|
|
_undefined3 as undefined,
|
|||
|
|
union,
|
|||
|
|
unknown,
|
|||
|
|
_uppercase as uppercase,
|
|||
|
|
url,
|
|||
|
|
util_exports as util,
|
|||
|
|
uuid2 as uuid,
|
|||
|
|
uuidv4,
|
|||
|
|
uuidv6,
|
|||
|
|
uuidv7,
|
|||
|
|
_void2 as void,
|
|||
|
|
xid2 as xid,
|
|||
|
|
xor,
|
|||
|
|
external_exports as z
|
|||
|
|
};
|
|||
|
|
//# sourceMappingURL=zod.js.map
|