zod 4.0.0-beta.20250505T195954 → 4.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (618) hide show
  1. package/README.md +208 -0
  2. package/index.cjs +33 -0
  3. package/index.d.cts +4 -0
  4. package/index.d.ts +4 -0
  5. package/index.js +4 -0
  6. package/locales/index.cjs +17 -0
  7. package/locales/index.d.cts +1 -0
  8. package/locales/index.d.ts +1 -0
  9. package/locales/index.js +1 -0
  10. package/mini/index.cjs +17 -0
  11. package/mini/index.d.cts +1 -0
  12. package/mini/index.d.ts +1 -0
  13. package/mini/index.js +1 -0
  14. package/package.json +87 -40
  15. package/src/index.ts +2 -3
  16. package/src/locales/index.ts +1 -0
  17. package/src/mini/index.ts +1 -0
  18. package/src/v3/ZodError.ts +330 -0
  19. package/src/v3/benchmarks/datetime.ts +58 -0
  20. package/src/v3/benchmarks/discriminatedUnion.ts +80 -0
  21. package/src/v3/benchmarks/index.ts +59 -0
  22. package/src/v3/benchmarks/ipv4.ts +57 -0
  23. package/src/v3/benchmarks/object.ts +69 -0
  24. package/src/v3/benchmarks/primitives.ts +162 -0
  25. package/src/v3/benchmarks/realworld.ts +63 -0
  26. package/src/v3/benchmarks/string.ts +55 -0
  27. package/src/v3/benchmarks/union.ts +80 -0
  28. package/src/v3/errors.ts +13 -0
  29. package/src/v3/external.ts +6 -0
  30. package/src/v3/helpers/enumUtil.ts +17 -0
  31. package/src/v3/helpers/errorUtil.ts +8 -0
  32. package/src/v3/helpers/parseUtil.ts +176 -0
  33. package/src/v3/helpers/partialUtil.ts +34 -0
  34. package/src/v3/helpers/typeAliases.ts +2 -0
  35. package/src/v3/helpers/util.ts +224 -0
  36. package/src/v3/index.ts +4 -0
  37. package/src/v3/locales/en.ts +124 -0
  38. package/src/v3/standard-schema.ts +113 -0
  39. package/src/v3/tests/Mocker.ts +54 -0
  40. package/src/v3/tests/all-errors.test.ts +157 -0
  41. package/src/v3/tests/anyunknown.test.ts +28 -0
  42. package/src/v3/tests/array.test.ts +71 -0
  43. package/src/v3/tests/async-parsing.test.ts +388 -0
  44. package/src/v3/tests/async-refinements.test.ts +46 -0
  45. package/src/v3/tests/base.test.ts +29 -0
  46. package/src/v3/tests/bigint.test.ts +55 -0
  47. package/src/v3/tests/branded.test.ts +53 -0
  48. package/src/v3/tests/catch.test.ts +220 -0
  49. package/src/v3/tests/coerce.test.ts +133 -0
  50. package/src/v3/tests/complex.test.ts +56 -0
  51. package/src/v3/tests/custom.test.ts +31 -0
  52. package/src/v3/tests/date.test.ts +32 -0
  53. package/src/v3/tests/deepmasking.test.ts +186 -0
  54. package/src/v3/tests/default.test.ts +112 -0
  55. package/src/v3/tests/description.test.ts +33 -0
  56. package/src/v3/tests/discriminated-unions.test.ts +315 -0
  57. package/src/v3/tests/enum.test.ts +80 -0
  58. package/src/v3/tests/error.test.ts +551 -0
  59. package/src/v3/tests/firstparty.test.ts +87 -0
  60. package/src/v3/tests/firstpartyschematypes.test.ts +21 -0
  61. package/src/v3/tests/function.test.ts +257 -0
  62. package/src/v3/tests/generics.test.ts +48 -0
  63. package/src/v3/tests/instanceof.test.ts +37 -0
  64. package/src/v3/tests/intersection.test.ts +110 -0
  65. package/src/v3/tests/language-server.source.ts +76 -0
  66. package/src/v3/tests/language-server.test.ts +207 -0
  67. package/src/v3/tests/literal.test.ts +36 -0
  68. package/src/v3/tests/map.test.ts +110 -0
  69. package/src/v3/tests/masking.test.ts +4 -0
  70. package/src/v3/tests/mocker.test.ts +19 -0
  71. package/src/v3/tests/nan.test.ts +21 -0
  72. package/src/v3/tests/nativeEnum.test.ts +87 -0
  73. package/src/v3/tests/nullable.test.ts +42 -0
  74. package/src/v3/tests/number.test.ts +176 -0
  75. package/src/v3/tests/object-augmentation.test.ts +29 -0
  76. package/src/v3/tests/object-in-es5-env.test.ts +29 -0
  77. package/src/v3/tests/object.test.ts +434 -0
  78. package/src/v3/tests/optional.test.ts +42 -0
  79. package/src/v3/tests/parseUtil.test.ts +23 -0
  80. package/src/v3/tests/parser.test.ts +41 -0
  81. package/src/v3/tests/partials.test.ts +243 -0
  82. package/src/v3/tests/pickomit.test.ts +111 -0
  83. package/src/v3/tests/pipeline.test.ts +29 -0
  84. package/src/v3/tests/preprocess.test.ts +186 -0
  85. package/src/v3/tests/primitive.test.ts +440 -0
  86. package/src/v3/tests/promise.test.ts +90 -0
  87. package/src/v3/tests/readonly.test.ts +194 -0
  88. package/src/v3/tests/record.test.ts +171 -0
  89. package/src/v3/tests/recursive.test.ts +197 -0
  90. package/src/v3/tests/refine.test.ts +313 -0
  91. package/src/v3/tests/safeparse.test.ts +27 -0
  92. package/src/v3/tests/set.test.ts +142 -0
  93. package/src/v3/tests/standard-schema.test.ts +83 -0
  94. package/src/v3/tests/string.test.ts +916 -0
  95. package/src/v3/tests/transformer.test.ts +233 -0
  96. package/src/v3/tests/tuple.test.ts +90 -0
  97. package/src/v3/tests/unions.test.ts +57 -0
  98. package/src/v3/tests/validations.test.ts +133 -0
  99. package/src/v3/tests/void.test.ts +15 -0
  100. package/src/v3/types.ts +5136 -0
  101. package/src/{checks.ts → v4/classic/checks.ts} +1 -1
  102. package/src/v4/classic/coerce.ts +27 -0
  103. package/src/{compat.ts → v4/classic/compat.ts} +3 -13
  104. package/src/v4/classic/errors.ts +75 -0
  105. package/src/v4/classic/external.ts +50 -0
  106. package/src/v4/classic/index.ts +5 -0
  107. package/src/{iso.ts → v4/classic/iso.ts} +1 -1
  108. package/src/{parse.ts → v4/classic/parse.ts} +13 -12
  109. package/src/{schemas.ts → v4/classic/schemas.ts} +430 -417
  110. package/src/v4/classic/tests/anyunknown.test.ts +26 -0
  111. package/src/v4/classic/tests/array.test.ts +264 -0
  112. package/src/v4/classic/tests/assignability.test.ts +210 -0
  113. package/src/v4/classic/tests/async-parsing.test.ts +381 -0
  114. package/src/v4/classic/tests/async-refinements.test.ts +68 -0
  115. package/src/v4/classic/tests/base.test.ts +7 -0
  116. package/src/v4/classic/tests/bigint.test.ts +54 -0
  117. package/src/v4/classic/tests/brand.test.ts +63 -0
  118. package/src/v4/classic/tests/catch.test.ts +252 -0
  119. package/src/v4/classic/tests/coalesce.test.ts +20 -0
  120. package/src/v4/classic/tests/coerce.test.ts +160 -0
  121. package/src/v4/classic/tests/continuability.test.ts +352 -0
  122. package/src/v4/classic/tests/custom.test.ts +40 -0
  123. package/src/v4/classic/tests/date.test.ts +31 -0
  124. package/src/v4/classic/tests/datetime.test.ts +296 -0
  125. package/src/v4/classic/tests/default.test.ts +313 -0
  126. package/src/v4/classic/tests/description.test.ts +32 -0
  127. package/src/v4/classic/tests/discriminated-unions.test.ts +619 -0
  128. package/src/v4/classic/tests/enum.test.ts +285 -0
  129. package/src/v4/classic/tests/error-utils.test.ts +552 -0
  130. package/src/v4/classic/tests/error.test.ts +711 -0
  131. package/src/v4/classic/tests/file.test.ts +91 -0
  132. package/src/v4/classic/tests/firstparty.test.ts +175 -0
  133. package/src/v4/classic/tests/function.test.ts +268 -0
  134. package/src/v4/classic/tests/generics.test.ts +72 -0
  135. package/src/v4/classic/tests/index.test.ts +829 -0
  136. package/src/v4/classic/tests/instanceof.test.ts +34 -0
  137. package/src/v4/classic/tests/intersection.test.ts +171 -0
  138. package/src/v4/classic/tests/json.test.ts +108 -0
  139. package/src/v4/classic/tests/lazy.test.ts +227 -0
  140. package/src/v4/classic/tests/literal.test.ts +92 -0
  141. package/src/v4/classic/tests/map.test.ts +196 -0
  142. package/src/v4/classic/tests/nan.test.ts +21 -0
  143. package/src/v4/classic/tests/nested-refine.test.ts +168 -0
  144. package/src/v4/classic/tests/nonoptional.test.ts +86 -0
  145. package/src/v4/classic/tests/nullable.test.ts +22 -0
  146. package/src/v4/classic/tests/number.test.ts +247 -0
  147. package/src/v4/classic/tests/object.test.ts +563 -0
  148. package/src/v4/classic/tests/optional.test.ts +123 -0
  149. package/src/v4/classic/tests/partial.test.ts +147 -0
  150. package/src/v4/classic/tests/pickomit.test.ts +127 -0
  151. package/src/v4/classic/tests/pipe.test.ts +81 -0
  152. package/src/v4/classic/tests/prefault.test.ts +37 -0
  153. package/src/v4/classic/tests/preprocess.test.ts +298 -0
  154. package/src/v4/classic/tests/primitive.test.ts +175 -0
  155. package/src/v4/classic/tests/promise.test.ts +81 -0
  156. package/src/v4/classic/tests/prototypes.test.ts +23 -0
  157. package/src/v4/classic/tests/readonly.test.ts +252 -0
  158. package/src/v4/classic/tests/record.test.ts +342 -0
  159. package/src/v4/classic/tests/recursive-types.test.ts +356 -0
  160. package/src/v4/classic/tests/refine.test.ts +532 -0
  161. package/src/v4/classic/tests/registries.test.ts +204 -0
  162. package/src/v4/classic/tests/set.test.ts +179 -0
  163. package/src/v4/classic/tests/standard-schema.test.ts +57 -0
  164. package/src/v4/classic/tests/string-formats.test.ts +109 -0
  165. package/src/v4/classic/tests/string.test.ts +881 -0
  166. package/src/v4/classic/tests/stringbool.test.ts +66 -0
  167. package/src/v4/classic/tests/template-literal.test.ts +758 -0
  168. package/src/v4/classic/tests/to-json-schema.test.ts +2314 -0
  169. package/src/v4/classic/tests/transform.test.ts +250 -0
  170. package/src/v4/classic/tests/tuple.test.ts +163 -0
  171. package/src/v4/classic/tests/union.test.ts +94 -0
  172. package/src/v4/classic/tests/validations.test.ts +283 -0
  173. package/src/v4/classic/tests/void.test.ts +12 -0
  174. package/src/v4/core/api.ts +1594 -0
  175. package/src/v4/core/checks.ts +1283 -0
  176. package/src/v4/core/config.ts +15 -0
  177. package/src/v4/core/core.ts +134 -0
  178. package/src/v4/core/doc.ts +44 -0
  179. package/src/v4/core/errors.ts +426 -0
  180. package/src/v4/core/function.ts +176 -0
  181. package/src/v4/core/index.ts +15 -0
  182. package/src/v4/core/json-schema.ts +143 -0
  183. package/src/v4/core/parse.ts +94 -0
  184. package/src/v4/core/regexes.ts +135 -0
  185. package/src/v4/core/registries.ts +96 -0
  186. package/src/v4/core/schemas.ts +3842 -0
  187. package/src/v4/core/standard-schema.ts +64 -0
  188. package/src/v4/core/tests/index.test.ts +46 -0
  189. package/src/v4/core/tests/locales/be.test.ts +124 -0
  190. package/src/v4/core/tests/locales/en.test.ts +22 -0
  191. package/src/v4/core/tests/locales/ru.test.ts +128 -0
  192. package/src/v4/core/tests/locales/tr.test.ts +69 -0
  193. package/src/v4/core/to-json-schema.ts +977 -0
  194. package/src/v4/core/util.ts +775 -0
  195. package/src/v4/core/versions.ts +5 -0
  196. package/src/v4/core/zsf.ts +323 -0
  197. package/src/v4/index.ts +4 -0
  198. package/src/v4/locales/ar.ts +125 -0
  199. package/src/v4/locales/az.ts +121 -0
  200. package/src/v4/locales/be.ts +184 -0
  201. package/src/v4/locales/ca.ts +127 -0
  202. package/src/v4/locales/cs.ts +142 -0
  203. package/src/v4/locales/de.ts +124 -0
  204. package/src/v4/locales/en.ts +127 -0
  205. package/src/v4/locales/eo.ts +125 -0
  206. package/src/v4/locales/es.ts +125 -0
  207. package/src/v4/locales/fa.ts +134 -0
  208. package/src/v4/locales/fi.ts +131 -0
  209. package/src/v4/locales/fr-CA.ts +126 -0
  210. package/src/v4/locales/fr.ts +124 -0
  211. package/src/v4/locales/he.ts +125 -0
  212. package/src/v4/locales/hu.ts +126 -0
  213. package/src/v4/locales/id.ts +125 -0
  214. package/src/v4/locales/index.ts +39 -0
  215. package/src/v4/locales/it.ts +125 -0
  216. package/src/v4/locales/ja.ts +122 -0
  217. package/src/v4/locales/kh.ts +126 -0
  218. package/src/v4/locales/ko.ts +131 -0
  219. package/src/v4/locales/mk.ts +127 -0
  220. package/src/v4/locales/ms.ts +124 -0
  221. package/src/v4/locales/nl.ts +126 -0
  222. package/src/v4/locales/no.ts +124 -0
  223. package/src/v4/locales/ota.ts +125 -0
  224. package/src/v4/locales/pl.ts +126 -0
  225. package/src/v4/locales/ps.ts +133 -0
  226. package/src/v4/locales/pt.ts +123 -0
  227. package/src/v4/locales/ru.ts +184 -0
  228. package/src/v4/locales/sl.ts +126 -0
  229. package/src/v4/locales/sv.ts +127 -0
  230. package/src/v4/locales/ta.ts +125 -0
  231. package/src/v4/locales/th.ts +126 -0
  232. package/src/v4/locales/tr.ts +121 -0
  233. package/src/v4/locales/ua.ts +126 -0
  234. package/src/v4/locales/ur.ts +126 -0
  235. package/src/v4/locales/vi.ts +125 -0
  236. package/src/v4/locales/zh-CN.ts +123 -0
  237. package/src/v4/locales/zh-TW.ts +125 -0
  238. package/src/v4/mini/checks.ts +32 -0
  239. package/src/v4/mini/coerce.ts +22 -0
  240. package/src/v4/mini/external.ts +40 -0
  241. package/src/v4/mini/index.ts +3 -0
  242. package/src/v4/mini/iso.ts +62 -0
  243. package/src/v4/mini/parse.ts +1 -0
  244. package/src/v4/mini/schemas.ts +1579 -0
  245. package/src/v4/mini/tests/assignability.test.ts +129 -0
  246. package/src/v4/mini/tests/brand.test.ts +51 -0
  247. package/src/v4/mini/tests/checks.test.ts +144 -0
  248. package/src/v4/mini/tests/computed.test.ts +36 -0
  249. package/src/v4/mini/tests/error.test.ts +22 -0
  250. package/src/v4/mini/tests/functions.test.ts +43 -0
  251. package/src/v4/mini/tests/index.test.ts +871 -0
  252. package/src/v4/mini/tests/number.test.ts +95 -0
  253. package/src/v4/mini/tests/object.test.ts +185 -0
  254. package/src/v4/mini/tests/prototypes.test.ts +43 -0
  255. package/src/v4/mini/tests/recursive-types.test.ts +275 -0
  256. package/src/v4/mini/tests/string.test.ts +299 -0
  257. package/src/v4-mini/index.ts +1 -0
  258. package/v3/ZodError.cjs +138 -0
  259. package/v3/ZodError.d.cts +164 -0
  260. package/v3/ZodError.d.ts +164 -0
  261. package/v3/ZodError.js +133 -0
  262. package/v3/errors.cjs +17 -0
  263. package/v3/errors.d.cts +5 -0
  264. package/v3/errors.d.ts +5 -0
  265. package/v3/errors.js +9 -0
  266. package/v3/external.cjs +22 -0
  267. package/v3/external.d.cts +6 -0
  268. package/v3/external.d.ts +6 -0
  269. package/v3/external.js +6 -0
  270. package/v3/helpers/enumUtil.cjs +2 -0
  271. package/v3/helpers/enumUtil.d.cts +8 -0
  272. package/v3/helpers/enumUtil.d.ts +8 -0
  273. package/v3/helpers/enumUtil.js +1 -0
  274. package/v3/helpers/errorUtil.cjs +9 -0
  275. package/v3/helpers/errorUtil.d.cts +9 -0
  276. package/v3/helpers/errorUtil.d.ts +9 -0
  277. package/v3/helpers/errorUtil.js +6 -0
  278. package/v3/helpers/parseUtil.cjs +124 -0
  279. package/v3/helpers/parseUtil.d.cts +78 -0
  280. package/v3/helpers/parseUtil.d.ts +78 -0
  281. package/v3/helpers/parseUtil.js +109 -0
  282. package/v3/helpers/partialUtil.cjs +2 -0
  283. package/v3/helpers/partialUtil.d.cts +8 -0
  284. package/v3/helpers/partialUtil.d.ts +8 -0
  285. package/v3/helpers/partialUtil.js +1 -0
  286. package/v3/helpers/typeAliases.cjs +2 -0
  287. package/v3/helpers/typeAliases.d.cts +2 -0
  288. package/v3/helpers/typeAliases.d.ts +2 -0
  289. package/v3/helpers/typeAliases.js +1 -0
  290. package/v3/helpers/util.cjs +137 -0
  291. package/v3/helpers/util.d.cts +85 -0
  292. package/v3/helpers/util.d.ts +85 -0
  293. package/v3/helpers/util.js +133 -0
  294. package/{dist/commonjs/index.js → v3/index.cjs} +2 -2
  295. package/v3/index.d.cts +4 -0
  296. package/v3/index.js +4 -0
  297. package/v3/locales/en.cjs +111 -0
  298. package/v3/locales/en.d.cts +3 -0
  299. package/v3/locales/en.d.ts +3 -0
  300. package/v3/locales/en.js +109 -0
  301. package/v3/standard-schema.cjs +2 -0
  302. package/v3/standard-schema.d.cts +102 -0
  303. package/v3/standard-schema.d.ts +102 -0
  304. package/v3/standard-schema.js +1 -0
  305. package/v3/types.cjs +3775 -0
  306. package/v3/types.d.cts +1031 -0
  307. package/v3/types.d.ts +1031 -0
  308. package/v3/types.js +3693 -0
  309. package/{dist/commonjs/checks.js → v4/classic/checks.cjs} +29 -29
  310. package/{dist/esm/checks.d.ts → v4/classic/checks.d.cts} +1 -1
  311. package/{dist/commonjs → v4/classic}/checks.d.ts +1 -1
  312. package/{dist/esm → v4/classic}/checks.js +1 -1
  313. package/{dist/commonjs/coerce.js → v4/classic/coerce.cjs} +2 -2
  314. package/v4/classic/coerce.d.cts +17 -0
  315. package/v4/classic/coerce.d.ts +17 -0
  316. package/{dist/esm → v4/classic}/coerce.js +1 -1
  317. package/{dist/commonjs/compat.js → v4/classic/compat.cjs} +5 -11
  318. package/{dist/esm/compat.d.ts → v4/classic/compat.d.cts} +4 -6
  319. package/{dist/commonjs → v4/classic}/compat.d.ts +3 -5
  320. package/{dist/esm → v4/classic}/compat.js +2 -8
  321. package/v4/classic/errors.cjs +67 -0
  322. package/{dist/commonjs/errors.d.ts → v4/classic/errors.d.cts} +8 -7
  323. package/{dist/esm → v4/classic}/errors.d.ts +8 -7
  324. package/v4/classic/errors.js +41 -0
  325. package/v4/classic/external.cjs +70 -0
  326. package/v4/classic/external.d.cts +13 -0
  327. package/v4/classic/external.d.ts +13 -0
  328. package/v4/classic/external.js +18 -0
  329. package/v4/classic/index.cjs +33 -0
  330. package/v4/classic/index.d.cts +4 -0
  331. package/{dist/commonjs/iso.js → v4/classic/iso.cjs} +2 -2
  332. package/{dist/esm/iso.d.ts → v4/classic/iso.d.cts} +2 -2
  333. package/{dist/commonjs → v4/classic}/iso.d.ts +1 -1
  334. package/{dist/esm → v4/classic}/iso.js +1 -1
  335. package/{dist/commonjs/parse.js → v4/classic/parse.cjs} +7 -9
  336. package/{dist/commonjs/parse.d.ts → v4/classic/parse.d.cts} +10 -4
  337. package/{dist/esm → v4/classic}/parse.d.ts +10 -4
  338. package/v4/classic/parse.js +6 -0
  339. package/{dist/commonjs/schemas.js → v4/classic/schemas.cjs} +167 -138
  340. package/{dist/esm/schemas.d.ts → v4/classic/schemas.d.cts} +176 -196
  341. package/{dist/commonjs → v4/classic}/schemas.d.ts +175 -195
  342. package/{dist/esm → v4/classic}/schemas.js +128 -102
  343. package/v4/core/api.cjs +1039 -0
  344. package/v4/core/api.d.cts +284 -0
  345. package/v4/core/api.d.ts +284 -0
  346. package/v4/core/api.js +906 -0
  347. package/v4/core/checks.cjs +591 -0
  348. package/v4/core/checks.d.cts +278 -0
  349. package/v4/core/checks.d.ts +278 -0
  350. package/v4/core/checks.js +565 -0
  351. package/v4/core/core.cjs +67 -0
  352. package/v4/core/core.d.cts +49 -0
  353. package/v4/core/core.d.ts +49 -0
  354. package/v4/core/core.js +61 -0
  355. package/v4/core/doc.cjs +39 -0
  356. package/v4/core/doc.d.cts +14 -0
  357. package/v4/core/doc.d.ts +14 -0
  358. package/v4/core/doc.js +35 -0
  359. package/v4/core/errors.cjs +226 -0
  360. package/v4/core/errors.d.cts +210 -0
  361. package/v4/core/errors.d.ts +210 -0
  362. package/v4/core/errors.js +195 -0
  363. package/v4/core/function.cjs +102 -0
  364. package/v4/core/function.d.cts +52 -0
  365. package/v4/core/function.d.ts +52 -0
  366. package/v4/core/function.js +75 -0
  367. package/v4/core/index.cjs +44 -0
  368. package/v4/core/index.d.cts +15 -0
  369. package/v4/core/index.d.ts +15 -0
  370. package/v4/core/index.js +15 -0
  371. package/v4/core/json-schema.cjs +2 -0
  372. package/v4/core/json-schema.d.cts +87 -0
  373. package/v4/core/json-schema.d.ts +87 -0
  374. package/v4/core/json-schema.js +1 -0
  375. package/v4/core/parse.cjs +87 -0
  376. package/v4/core/parse.d.cts +25 -0
  377. package/v4/core/parse.d.ts +25 -0
  378. package/v4/core/parse.js +57 -0
  379. package/v4/core/regexes.cjs +103 -0
  380. package/v4/core/regexes.d.cts +61 -0
  381. package/v4/core/regexes.d.ts +61 -0
  382. package/v4/core/regexes.js +95 -0
  383. package/v4/core/registries.cjs +56 -0
  384. package/v4/core/registries.d.cts +35 -0
  385. package/v4/core/registries.d.ts +35 -0
  386. package/v4/core/registries.js +51 -0
  387. package/v4/core/schemas.cjs +1748 -0
  388. package/v4/core/schemas.d.cts +1041 -0
  389. package/v4/core/schemas.d.ts +1041 -0
  390. package/v4/core/schemas.js +1717 -0
  391. package/v4/core/standard-schema.cjs +2 -0
  392. package/v4/core/standard-schema.d.cts +55 -0
  393. package/v4/core/standard-schema.d.ts +55 -0
  394. package/v4/core/standard-schema.js +1 -0
  395. package/v4/core/to-json-schema.cjs +854 -0
  396. package/v4/core/to-json-schema.d.cts +88 -0
  397. package/v4/core/to-json-schema.d.ts +88 -0
  398. package/v4/core/to-json-schema.js +849 -0
  399. package/v4/core/util.cjs +539 -0
  400. package/v4/core/util.d.cts +183 -0
  401. package/v4/core/util.d.ts +183 -0
  402. package/v4/core/util.js +493 -0
  403. package/v4/core/versions.cjs +8 -0
  404. package/v4/core/versions.d.cts +5 -0
  405. package/v4/core/versions.d.ts +5 -0
  406. package/v4/core/versions.js +5 -0
  407. package/v4/index.cjs +22 -0
  408. package/v4/index.d.cts +3 -0
  409. package/v4/index.d.ts +3 -0
  410. package/v4/index.js +3 -0
  411. package/v4/locales/ar.cjs +142 -0
  412. package/v4/locales/ar.d.cts +4 -0
  413. package/v4/locales/ar.d.ts +4 -0
  414. package/v4/locales/ar.js +116 -0
  415. package/v4/locales/az.cjs +141 -0
  416. package/v4/locales/az.d.cts +4 -0
  417. package/v4/locales/az.d.ts +4 -0
  418. package/v4/locales/az.js +115 -0
  419. package/v4/locales/be.cjs +190 -0
  420. package/v4/locales/be.d.cts +4 -0
  421. package/v4/locales/be.d.ts +4 -0
  422. package/v4/locales/be.js +164 -0
  423. package/v4/locales/ca.cjs +144 -0
  424. package/v4/locales/ca.d.cts +4 -0
  425. package/v4/locales/ca.d.ts +4 -0
  426. package/v4/locales/ca.js +118 -0
  427. package/v4/locales/cs.cjs +161 -0
  428. package/v4/locales/cs.d.cts +4 -0
  429. package/v4/locales/cs.d.ts +4 -0
  430. package/v4/locales/cs.js +135 -0
  431. package/v4/locales/de.cjs +142 -0
  432. package/v4/locales/de.d.cts +4 -0
  433. package/v4/locales/de.d.ts +4 -0
  434. package/v4/locales/de.js +116 -0
  435. package/v4/locales/en.cjs +145 -0
  436. package/v4/locales/en.d.cts +5 -0
  437. package/v4/locales/en.d.ts +5 -0
  438. package/v4/locales/en.js +117 -0
  439. package/v4/locales/eo.cjs +144 -0
  440. package/v4/locales/eo.d.cts +5 -0
  441. package/v4/locales/eo.d.ts +5 -0
  442. package/v4/locales/eo.js +116 -0
  443. package/v4/locales/es.cjs +143 -0
  444. package/v4/locales/es.d.cts +4 -0
  445. package/v4/locales/es.d.ts +4 -0
  446. package/v4/locales/es.js +117 -0
  447. package/v4/locales/fa.cjs +148 -0
  448. package/v4/locales/fa.d.cts +4 -0
  449. package/v4/locales/fa.d.ts +4 -0
  450. package/v4/locales/fa.js +122 -0
  451. package/v4/locales/fi.cjs +148 -0
  452. package/v4/locales/fi.d.cts +4 -0
  453. package/v4/locales/fi.d.ts +4 -0
  454. package/v4/locales/fi.js +122 -0
  455. package/v4/locales/fr-CA.cjs +143 -0
  456. package/v4/locales/fr-CA.d.cts +4 -0
  457. package/v4/locales/fr-CA.d.ts +4 -0
  458. package/v4/locales/fr-CA.js +117 -0
  459. package/v4/locales/fr.cjs +142 -0
  460. package/v4/locales/fr.d.cts +4 -0
  461. package/v4/locales/fr.d.ts +4 -0
  462. package/v4/locales/fr.js +116 -0
  463. package/v4/locales/he.cjs +143 -0
  464. package/v4/locales/he.d.cts +4 -0
  465. package/v4/locales/he.d.ts +4 -0
  466. package/v4/locales/he.js +117 -0
  467. package/v4/locales/hu.cjs +143 -0
  468. package/v4/locales/hu.d.cts +4 -0
  469. package/v4/locales/hu.d.ts +4 -0
  470. package/v4/locales/hu.js +117 -0
  471. package/v4/locales/id.cjs +142 -0
  472. package/v4/locales/id.d.cts +4 -0
  473. package/v4/locales/id.d.ts +4 -0
  474. package/v4/locales/id.js +116 -0
  475. package/v4/locales/index.cjs +84 -0
  476. package/v4/locales/index.d.cts +39 -0
  477. package/v4/locales/index.d.ts +39 -0
  478. package/v4/locales/index.js +39 -0
  479. package/v4/locales/it.cjs +143 -0
  480. package/v4/locales/it.d.cts +4 -0
  481. package/v4/locales/it.d.ts +4 -0
  482. package/v4/locales/it.js +117 -0
  483. package/v4/locales/ja.cjs +141 -0
  484. package/v4/locales/ja.d.cts +4 -0
  485. package/v4/locales/ja.d.ts +4 -0
  486. package/v4/locales/ja.js +115 -0
  487. package/v4/locales/kh.cjs +143 -0
  488. package/v4/locales/kh.d.cts +4 -0
  489. package/v4/locales/kh.d.ts +4 -0
  490. package/v4/locales/kh.js +117 -0
  491. package/v4/locales/ko.cjs +147 -0
  492. package/v4/locales/ko.d.cts +4 -0
  493. package/v4/locales/ko.d.ts +4 -0
  494. package/v4/locales/ko.js +121 -0
  495. package/v4/locales/mk.cjs +144 -0
  496. package/v4/locales/mk.d.cts +4 -0
  497. package/v4/locales/mk.d.ts +4 -0
  498. package/v4/locales/mk.js +118 -0
  499. package/v4/locales/ms.cjs +142 -0
  500. package/v4/locales/ms.d.cts +4 -0
  501. package/v4/locales/ms.d.ts +4 -0
  502. package/v4/locales/ms.js +116 -0
  503. package/v4/locales/nl.cjs +143 -0
  504. package/v4/locales/nl.d.cts +4 -0
  505. package/v4/locales/nl.d.ts +4 -0
  506. package/v4/locales/nl.js +117 -0
  507. package/v4/locales/no.cjs +142 -0
  508. package/v4/locales/no.d.cts +4 -0
  509. package/v4/locales/no.d.ts +4 -0
  510. package/v4/locales/no.js +116 -0
  511. package/v4/locales/ota.cjs +143 -0
  512. package/v4/locales/ota.d.cts +4 -0
  513. package/v4/locales/ota.d.ts +4 -0
  514. package/v4/locales/ota.js +117 -0
  515. package/v4/locales/pl.cjs +143 -0
  516. package/v4/locales/pl.d.cts +4 -0
  517. package/v4/locales/pl.d.ts +4 -0
  518. package/v4/locales/pl.js +117 -0
  519. package/v4/locales/ps.cjs +148 -0
  520. package/v4/locales/ps.d.cts +4 -0
  521. package/v4/locales/ps.d.ts +4 -0
  522. package/v4/locales/ps.js +122 -0
  523. package/v4/locales/pt.cjs +142 -0
  524. package/v4/locales/pt.d.cts +4 -0
  525. package/v4/locales/pt.d.ts +4 -0
  526. package/v4/locales/pt.js +116 -0
  527. package/v4/locales/ru.cjs +190 -0
  528. package/v4/locales/ru.d.cts +4 -0
  529. package/v4/locales/ru.d.ts +4 -0
  530. package/v4/locales/ru.js +164 -0
  531. package/v4/locales/sl.cjs +143 -0
  532. package/v4/locales/sl.d.cts +4 -0
  533. package/v4/locales/sl.d.ts +4 -0
  534. package/v4/locales/sl.js +117 -0
  535. package/v4/locales/sv.cjs +144 -0
  536. package/v4/locales/sv.d.cts +4 -0
  537. package/v4/locales/sv.d.ts +4 -0
  538. package/v4/locales/sv.js +118 -0
  539. package/v4/locales/ta.cjs +143 -0
  540. package/v4/locales/ta.d.cts +4 -0
  541. package/v4/locales/ta.d.ts +4 -0
  542. package/v4/locales/ta.js +117 -0
  543. package/v4/locales/th.cjs +143 -0
  544. package/v4/locales/th.d.cts +4 -0
  545. package/v4/locales/th.d.ts +4 -0
  546. package/v4/locales/th.js +117 -0
  547. package/v4/locales/tr.cjs +143 -0
  548. package/v4/locales/tr.d.cts +5 -0
  549. package/v4/locales/tr.d.ts +5 -0
  550. package/v4/locales/tr.js +115 -0
  551. package/v4/locales/ua.cjs +143 -0
  552. package/v4/locales/ua.d.cts +4 -0
  553. package/v4/locales/ua.d.ts +4 -0
  554. package/v4/locales/ua.js +117 -0
  555. package/v4/locales/ur.cjs +143 -0
  556. package/v4/locales/ur.d.cts +4 -0
  557. package/v4/locales/ur.d.ts +4 -0
  558. package/v4/locales/ur.js +117 -0
  559. package/v4/locales/vi.cjs +142 -0
  560. package/v4/locales/vi.d.cts +4 -0
  561. package/v4/locales/vi.d.ts +4 -0
  562. package/v4/locales/vi.js +116 -0
  563. package/v4/locales/zh-CN.cjs +142 -0
  564. package/v4/locales/zh-CN.d.cts +4 -0
  565. package/v4/locales/zh-CN.d.ts +4 -0
  566. package/v4/locales/zh-CN.js +116 -0
  567. package/v4/locales/zh-TW.cjs +143 -0
  568. package/v4/locales/zh-TW.d.cts +4 -0
  569. package/v4/locales/zh-TW.d.ts +4 -0
  570. package/v4/locales/zh-TW.js +117 -0
  571. package/v4/mini/checks.cjs +34 -0
  572. package/v4/mini/checks.d.cts +1 -0
  573. package/v4/mini/checks.d.ts +1 -0
  574. package/v4/mini/checks.js +1 -0
  575. package/{dist/commonjs/errors.js → v4/mini/coerce.cjs} +21 -25
  576. package/v4/mini/coerce.d.cts +7 -0
  577. package/v4/mini/coerce.d.ts +7 -0
  578. package/v4/mini/coerce.js +17 -0
  579. package/v4/mini/external.cjs +62 -0
  580. package/v4/mini/external.d.cts +11 -0
  581. package/v4/mini/external.d.ts +11 -0
  582. package/v4/mini/external.js +13 -0
  583. package/v4/mini/index.cjs +32 -0
  584. package/v4/mini/index.d.cts +3 -0
  585. package/v4/mini/index.d.ts +3 -0
  586. package/v4/mini/index.js +3 -0
  587. package/v4/mini/iso.cjs +60 -0
  588. package/v4/mini/iso.d.cts +22 -0
  589. package/v4/mini/iso.d.ts +22 -0
  590. package/v4/mini/iso.js +30 -0
  591. package/v4/mini/parse.cjs +8 -0
  592. package/v4/mini/parse.d.cts +1 -0
  593. package/v4/mini/parse.d.ts +1 -0
  594. package/v4/mini/parse.js +1 -0
  595. package/v4/mini/schemas.cjs +839 -0
  596. package/v4/mini/schemas.d.cts +356 -0
  597. package/v4/mini/schemas.d.ts +356 -0
  598. package/v4/mini/schemas.js +732 -0
  599. package/v4-mini/index.cjs +17 -0
  600. package/v4-mini/index.d.cts +1 -0
  601. package/v4-mini/index.d.ts +1 -0
  602. package/v4-mini/index.js +1 -0
  603. package/dist/commonjs/coerce.d.ts +0 -17
  604. package/dist/commonjs/external.d.ts +0 -8
  605. package/dist/commonjs/external.js +0 -58
  606. package/dist/commonjs/package.json +0 -3
  607. package/dist/esm/coerce.d.ts +0 -17
  608. package/dist/esm/errors.js +0 -24
  609. package/dist/esm/external.d.ts +0 -8
  610. package/dist/esm/external.js +0 -14
  611. package/dist/esm/package.json +0 -3
  612. package/dist/esm/parse.js +0 -8
  613. package/src/coerce.ts +0 -27
  614. package/src/errors.ts +0 -50
  615. package/src/external.ts +0 -30
  616. package/{dist/esm → v3}/index.d.ts +1 -1
  617. /package/{dist/commonjs → v4/classic}/index.d.ts +0 -0
  618. /package/{dist/esm → v4/classic}/index.js +0 -0
@@ -0,0 +1,15 @@
1
+ import type * as errors from "./errors.js";
2
+
3
+ export interface $ZodConfig {
4
+ /** Custom error map. Overrides `config().localeError`. */
5
+ customError?: errors.$ZodErrorMap | undefined;
6
+ /** Localized error map. Lowest priority. */
7
+ localeError?: errors.$ZodErrorMap | undefined;
8
+ }
9
+
10
+ export const globalConfig: $ZodConfig = {};
11
+
12
+ export function config(config?: Partial<$ZodConfig>): $ZodConfig {
13
+ if (config) Object.assign(globalConfig, config);
14
+ return globalConfig;
15
+ }
@@ -0,0 +1,134 @@
1
+ import type * as errors from "./errors.js";
2
+ import type * as schemas from "./schemas.js";
3
+ import type { Class } from "./util.js";
4
+ ////////////////////////////// CONSTRUCTORS ///////////////////////////////////////
5
+
6
+ type ZodTrait = { _zod: { def: any; [k: string]: any } };
7
+ export interface $constructor<T extends ZodTrait, D = T["_zod"]["def"]> {
8
+ new (def: D): T;
9
+ init(inst: T, def: D): asserts inst is T;
10
+ }
11
+
12
+ /** A special constant with type `never` */
13
+ export const NEVER: never = Object.freeze({
14
+ status: "aborted",
15
+ }) as never;
16
+
17
+ export /*@__NO_SIDE_EFFECTS__*/ function $constructor<T extends ZodTrait, D = T["_zod"]["def"]>(
18
+ name: string,
19
+ initializer: (inst: T, def: D) => void,
20
+ params?: { Parent?: typeof Class }
21
+ ): $constructor<T, D> {
22
+ function init(inst: T, def: D) {
23
+ Object.defineProperty(inst, "_zod", {
24
+ value: inst._zod ?? {},
25
+ enumerable: false,
26
+ });
27
+
28
+ inst._zod.traits ??= new Set();
29
+
30
+ inst._zod.traits.add(name);
31
+ initializer(inst, def);
32
+ // support prototype modifications
33
+ for (const k in _.prototype) {
34
+ if (!(k in inst)) Object.defineProperty(inst, k, { value: _.prototype[k].bind(inst) });
35
+ }
36
+ inst._zod.constr = _;
37
+ inst._zod.def = def;
38
+ }
39
+
40
+ // doesn't work if Parent has a constructor with arguments
41
+ const Parent = params?.Parent ?? Object;
42
+ class Definition extends Parent {}
43
+ Object.defineProperty(Definition, "name", { value: name });
44
+
45
+ function _(this: any, def: D) {
46
+ const inst = params?.Parent ? new Definition() : this;
47
+ init(inst, def);
48
+ inst._zod.deferred ??= [];
49
+ for (const fn of inst._zod.deferred) {
50
+ fn();
51
+ }
52
+ return inst;
53
+ }
54
+
55
+ Object.defineProperty(_, "init", { value: init });
56
+ Object.defineProperty(_, Symbol.hasInstance, {
57
+ value: (inst: any) => {
58
+ if (params?.Parent && inst instanceof params.Parent) return true;
59
+ return inst?._zod?.traits?.has(name);
60
+ },
61
+ });
62
+ Object.defineProperty(_, "name", { value: name });
63
+ return _ as any;
64
+ }
65
+
66
+ ////////////////////////////// UTILITIES ///////////////////////////////////////
67
+ export const $brand: unique symbol = Symbol("zod_brand");
68
+ export type $brand<T extends string | number | symbol = string | number | symbol> = {
69
+ [$brand]: { [k in T]: true };
70
+ };
71
+
72
+ export type $ZodBranded<T extends schemas.SomeType, Brand extends string | number | symbol> = T &
73
+ Record<"_zod", Record<"output", output<T> & $brand<Brand>>>;
74
+
75
+ export class $ZodAsyncError extends Error {
76
+ constructor() {
77
+ super(`Encountered Promise during synchronous parse. Use .parseAsync() instead.`);
78
+ }
79
+ }
80
+
81
+ //////////////////////////// TYPE HELPERS ///////////////////////////////////
82
+
83
+ // export type input<T extends schemas.$ZodType> = T["_zod"]["input"];
84
+ // export type output<T extends schemas.$ZodType> = T["_zod"]["output"];
85
+ // export type input<T extends schemas.$ZodType> = T["_zod"]["input"];
86
+ // export type output<T extends schemas.$ZodType> = T["_zod"]["output"];
87
+ export type input<T> = T extends { _zod: { input: any } } ? Required<T["_zod"]>["input"] : unknown;
88
+ export type output<T> = T extends { _zod: { output: any } } ? Required<T["_zod"]>["output"] : unknown;
89
+
90
+ // Mk2
91
+ // export type input<T> = T extends { _zod: { "~input": any } }
92
+ // ? T["_zod"]["~input"]
93
+ // : T extends { _zod: { input: any } }
94
+ // ? T["_zod"]["input"]
95
+ // : never;
96
+ // export type output<T> = T extends { _zod: { "~output": any } }
97
+ // ? T["_zod"]["~output"]
98
+ // : T extends { _zod: { output: any } }
99
+ // ? T["_zod"]["output"]
100
+ // : never;
101
+ // Mk 3
102
+ // export type input<T extends schemas.$ZodType> = T["_zod"]["input"];
103
+ // export type output<T extends schemas.$ZodType> = T["_zod"]["output"];
104
+ // Mk 4
105
+ // export type input<T extends schemas.$ZodType> = T[] extends { _zod: { "~input": any } }
106
+ // ? T["_zod"]["~input"]
107
+ // : T extends { _zod: { input: any } }
108
+ // ? T["_zod"]["input"]
109
+ // : never;
110
+ // export type output<T extends schemas.$ZodType> = T extends { _zod: { "~output": any } }
111
+ // ? T["_zod"]["~output"]
112
+ // : T extends { _zod: { output: any } }
113
+ // ? T["_zod"]["output"]
114
+ // : never;
115
+
116
+ export type { output as infer };
117
+
118
+ ////////////////////////////// CONFIG ///////////////////////////////////////
119
+
120
+ export interface $ZodConfig {
121
+ /** Custom error map. Overrides `config().localeError`. */
122
+ customError?: errors.$ZodErrorMap | undefined;
123
+ /** Localized error map. Lowest priority. */
124
+ localeError?: errors.$ZodErrorMap | undefined;
125
+ /** Disable JIT schema compilation. Useful in environments that disallow `eval`. */
126
+ jitless?: boolean | undefined;
127
+ }
128
+
129
+ export const globalConfig: $ZodConfig = {};
130
+
131
+ export function config(newConfig?: Partial<$ZodConfig>): $ZodConfig {
132
+ if (newConfig) Object.assign(globalConfig, newConfig);
133
+ return globalConfig;
134
+ }
@@ -0,0 +1,44 @@
1
+ type ModeWriter = (doc: Doc, modes: { execution: "sync" | "async" }) => void;
2
+
3
+ export class Doc {
4
+ args!: string[];
5
+ content: string[] = [];
6
+ indent = 0;
7
+
8
+ constructor(args: string[] = []) {
9
+ if (this) this.args = args;
10
+ }
11
+
12
+ indented(fn: (doc: Doc) => void) {
13
+ this.indent += 1;
14
+ fn(this);
15
+ this.indent -= 1;
16
+ }
17
+
18
+ write(fn: ModeWriter): void;
19
+ write(line: string): void;
20
+ write(arg: any) {
21
+ if (typeof arg === "function") {
22
+ (arg as ModeWriter)(this, { execution: "sync" });
23
+ (arg as ModeWriter)(this, { execution: "async" });
24
+ return;
25
+ }
26
+
27
+ const content = arg as string;
28
+ const lines = content.split("\n").filter((x) => x);
29
+ const minIndent = Math.min(...lines.map((x) => x.length - x.trimStart().length));
30
+ const dedented = lines.map((x) => x.slice(minIndent)).map((x) => " ".repeat(this.indent * 2) + x);
31
+ for (const line of dedented) {
32
+ this.content.push(line);
33
+ }
34
+ }
35
+
36
+ compile(): any {
37
+ const F = Function;
38
+ const args = this?.args;
39
+ const content = this?.content ?? [``];
40
+ const lines = [...content.map((x) => ` ${x}`)];
41
+ // console.log(lines.join("\n"));
42
+ return new F(...args, lines.join("\n")) as any;
43
+ }
44
+ }
@@ -0,0 +1,426 @@
1
+ import type { $ZodCheck, $ZodStringFormats } from "./checks.js";
2
+ import { $constructor } from "./core.js";
3
+ import type { $ZodType } from "./schemas.js";
4
+ import * as util from "./util.js";
5
+
6
+ ///////////////////////////
7
+ //// base type ////
8
+ ///////////////////////////
9
+ export interface $ZodIssueBase {
10
+ readonly code?: string;
11
+ readonly input?: unknown;
12
+ readonly path: PropertyKey[];
13
+ readonly message: string;
14
+ // [k: string]: unknown;
15
+ }
16
+
17
+ ////////////////////////////////
18
+ //// issue subtypes ////
19
+ ////////////////////////////////
20
+ export interface $ZodIssueInvalidType<Input = unknown> extends $ZodIssueBase {
21
+ readonly code: "invalid_type";
22
+ readonly expected: $ZodType["_zod"]["def"]["type"];
23
+ readonly input: Input;
24
+ }
25
+
26
+ export interface $ZodIssueTooBig<Input = unknown> extends $ZodIssueBase {
27
+ readonly code: "too_big";
28
+ readonly origin: "number" | "int" | "bigint" | "date" | "string" | "array" | "set" | "file" | (string & {});
29
+ readonly maximum: number | bigint;
30
+ readonly inclusive?: boolean;
31
+ readonly exact?: boolean;
32
+ readonly input: Input;
33
+ }
34
+
35
+ export interface $ZodIssueTooSmall<Input = unknown> extends $ZodIssueBase {
36
+ readonly code: "too_small";
37
+ readonly origin: "number" | "int" | "bigint" | "date" | "string" | "array" | "set" | "file" | (string & {});
38
+ readonly minimum: number | bigint;
39
+ /** True if the allowable range includes the minimum */
40
+ readonly inclusive?: boolean;
41
+ /** True if the allowed value is fixed (e.g.` z.length(5)`), not a range (`z.minLength(5)`) */
42
+ readonly exact?: boolean;
43
+ readonly input: Input;
44
+ }
45
+
46
+ export interface $ZodIssueInvalidStringFormat extends $ZodIssueBase {
47
+ readonly code: "invalid_format";
48
+ readonly format: $ZodStringFormats | (string & {});
49
+ readonly pattern?: string;
50
+ readonly input: string;
51
+ }
52
+
53
+ export interface $ZodIssueNotMultipleOf<Input extends number | bigint = number | bigint> extends $ZodIssueBase {
54
+ readonly code: "not_multiple_of";
55
+ readonly divisor: number;
56
+ readonly input: Input;
57
+ }
58
+
59
+ export interface $ZodIssueUnrecognizedKeys extends $ZodIssueBase {
60
+ readonly code: "unrecognized_keys";
61
+ readonly keys: string[];
62
+ readonly input: Record<string, unknown>;
63
+ }
64
+
65
+ export interface $ZodIssueInvalidUnion extends $ZodIssueBase {
66
+ readonly code: "invalid_union";
67
+ readonly errors: $ZodIssue[][];
68
+ readonly input: unknown;
69
+ }
70
+
71
+ export interface $ZodIssueInvalidKey<Input = unknown> extends $ZodIssueBase {
72
+ readonly code: "invalid_key";
73
+ readonly origin: "map" | "record";
74
+ readonly issues: $ZodIssue[];
75
+ readonly input: Input;
76
+ }
77
+
78
+ export interface $ZodIssueInvalidElement<Input = unknown> extends $ZodIssueBase {
79
+ readonly code: "invalid_element";
80
+ readonly origin: "map" | "set";
81
+ readonly key: unknown;
82
+ readonly issues: $ZodIssue[];
83
+ readonly input: Input;
84
+ }
85
+
86
+ export interface $ZodIssueInvalidValue<Input = unknown> extends $ZodIssueBase {
87
+ readonly code: "invalid_value";
88
+ readonly values: util.Primitive[];
89
+ readonly input: Input;
90
+ }
91
+
92
+ export interface $ZodIssueCustom extends $ZodIssueBase {
93
+ readonly code: "custom";
94
+ readonly params?: Record<string, any> | undefined;
95
+ readonly input: unknown;
96
+ }
97
+
98
+ ////////////////////////////////////////////
99
+ //// first-party string formats ////
100
+ ////////////////////////////////////////////
101
+
102
+ export interface $ZodIssueStringCommonFormats extends $ZodIssueInvalidStringFormat {
103
+ format: Exclude<$ZodStringFormats, "regex" | "jwt" | "starts_with" | "ends_with" | "includes">;
104
+ }
105
+
106
+ export interface $ZodIssueStringInvalidRegex extends $ZodIssueInvalidStringFormat {
107
+ format: "regex";
108
+ pattern: string;
109
+ }
110
+
111
+ export interface $ZodIssueStringInvalidJWT extends $ZodIssueInvalidStringFormat {
112
+ format: "jwt";
113
+ algorithm?: string;
114
+ }
115
+
116
+ export interface $ZodIssueStringStartsWith extends $ZodIssueInvalidStringFormat {
117
+ format: "starts_with";
118
+ prefix: string;
119
+ }
120
+
121
+ export interface $ZodIssueStringEndsWith extends $ZodIssueInvalidStringFormat {
122
+ format: "ends_with";
123
+ suffix: string;
124
+ }
125
+
126
+ export interface $ZodIssueStringIncludes extends $ZodIssueInvalidStringFormat {
127
+ format: "includes";
128
+ includes: string;
129
+ }
130
+
131
+ export type $ZodStringFormatIssues =
132
+ | $ZodIssueStringCommonFormats
133
+ | $ZodIssueStringInvalidRegex
134
+ | $ZodIssueStringInvalidJWT
135
+ | $ZodIssueStringStartsWith
136
+ | $ZodIssueStringEndsWith
137
+ | $ZodIssueStringIncludes;
138
+
139
+ ////////////////////////
140
+ //// utils /////
141
+ ////////////////////////
142
+
143
+ export type $ZodIssue =
144
+ | $ZodIssueInvalidType
145
+ | $ZodIssueTooBig
146
+ | $ZodIssueTooSmall
147
+ | $ZodIssueInvalidStringFormat
148
+ | $ZodIssueNotMultipleOf
149
+ | $ZodIssueUnrecognizedKeys
150
+ | $ZodIssueInvalidUnion
151
+ | $ZodIssueInvalidKey
152
+ | $ZodIssueInvalidElement
153
+ | $ZodIssueInvalidValue
154
+ | $ZodIssueCustom;
155
+
156
+ export type $ZodIssueCode = $ZodIssue["code"];
157
+
158
+ export type $ZodRawIssue<T extends $ZodIssueBase = $ZodIssue> = T extends any ? RawIssue<T> : never;
159
+ type RawIssue<T extends $ZodIssueBase> = util.Flatten<
160
+ util.MakePartial<T, "message" | "path"> & {
161
+ /** The input data */
162
+ readonly input?: unknown;
163
+ /** The schema or check that originated this issue. */
164
+ readonly inst?: $ZodType | $ZodCheck;
165
+ /** @deprecated Internal use only. If `true`, Zod will continue executing validation despite this issue. */
166
+ readonly continue?: boolean | undefined;
167
+ } & Record<string, any>
168
+ >;
169
+
170
+ export interface $ZodErrorMap<T extends $ZodIssueBase = $ZodIssue> {
171
+ // biome-ignore lint:
172
+ (issue: $ZodRawIssue<T>): { message: string } | string | undefined | null;
173
+ }
174
+
175
+ //////////////////////// ERROR CLASS ////////////////////////
176
+
177
+ // const ZOD_ERROR: symbol = Symbol.for("{{zod.error}}");
178
+ export interface $ZodError<T = unknown> extends Error {
179
+ type: T;
180
+ issues: $ZodIssue[];
181
+ _zod: {
182
+ output: T;
183
+ def: $ZodIssue[];
184
+ };
185
+ stack?: string;
186
+ name: string;
187
+ }
188
+
189
+ const initializer = (inst: $ZodError, def: $ZodIssue[]): void => {
190
+ inst.name = "$ZodError";
191
+ Object.defineProperty(inst, "_zod", {
192
+ value: inst._zod,
193
+ enumerable: false,
194
+ });
195
+ Object.defineProperty(inst, "issues", {
196
+ value: def,
197
+ enumerable: false,
198
+ });
199
+ Object.defineProperty(inst, "message", {
200
+ get() {
201
+ return JSON.stringify(def, util.jsonStringifyReplacer, 2);
202
+ },
203
+ enumerable: true,
204
+ // configurable: false,
205
+ });
206
+ Object.defineProperty(inst, "toString", {
207
+ value: () => inst.message,
208
+ enumerable: false,
209
+ });
210
+ };
211
+
212
+ export const $ZodError: $constructor<$ZodError> = $constructor("$ZodError", initializer);
213
+ interface $ZodRealError<T = any> extends $ZodError<T> {}
214
+ export const $ZodRealError: $constructor<$ZodRealError> = $constructor("$ZodError", initializer, { Parent: Error });
215
+
216
+ /////////////////// ERROR UTILITIES ////////////////////////
217
+
218
+ // flatten
219
+ export type $ZodFlattenedError<T, U = string> = _FlattenedError<T, U>;
220
+ type _FlattenedError<T, U = string> = {
221
+ formErrors: U[];
222
+ fieldErrors: {
223
+ [P in keyof T]?: U[];
224
+ };
225
+ };
226
+
227
+ export function flattenError<T>(error: $ZodError<T>): _FlattenedError<T>;
228
+ export function flattenError<T, U>(error: $ZodError<T>, mapper?: (issue: $ZodIssue) => U): _FlattenedError<T, U>;
229
+ export function flattenError(error: $ZodError, mapper = (issue: $ZodIssue) => issue.message): any {
230
+ const fieldErrors: any = {};
231
+ const formErrors: any[] = [];
232
+ for (const sub of error.issues) {
233
+ if (sub.path.length > 0) {
234
+ fieldErrors[sub.path[0]!] = fieldErrors[sub.path[0]!] || [];
235
+ fieldErrors[sub.path[0]!].push(mapper(sub));
236
+ } else {
237
+ formErrors.push(mapper(sub));
238
+ }
239
+ }
240
+ return { formErrors, fieldErrors };
241
+ }
242
+
243
+ type _ZodFormattedError<T, U = string> = T extends [any, ...any[]]
244
+ ? { [K in keyof T]?: $ZodFormattedError<T[K], U> }
245
+ : T extends any[]
246
+ ? { [k: number]: $ZodFormattedError<T[number], U> }
247
+ : T extends object
248
+ ? util.Flatten<{ [K in keyof T]?: $ZodFormattedError<T[K], U> }>
249
+ : any;
250
+
251
+ export type $ZodFormattedError<T, U = string> = {
252
+ _errors: U[];
253
+ } & util.Flatten<_ZodFormattedError<T, U>>;
254
+
255
+ export function formatError<T>(error: $ZodError<T>): $ZodFormattedError<T>;
256
+ export function formatError<T, U>(error: $ZodError<T>, mapper?: (issue: $ZodIssue) => U): $ZodFormattedError<T, U>;
257
+ export function formatError<T>(error: $ZodError, _mapper?: any) {
258
+ const mapper: (issue: $ZodIssue) => any =
259
+ _mapper ||
260
+ function (issue: $ZodIssue) {
261
+ return issue.message;
262
+ };
263
+ const fieldErrors: $ZodFormattedError<T> = { _errors: [] } as any;
264
+ const processError = (error: { issues: $ZodIssue[] }) => {
265
+ for (const issue of error.issues) {
266
+ if (issue.code === "invalid_union" && issue.errors.length) {
267
+ issue.errors.map((issues) => processError({ issues }));
268
+ } else if (issue.code === "invalid_key") {
269
+ processError({ issues: issue.issues });
270
+ } else if (issue.code === "invalid_element") {
271
+ processError({ issues: issue.issues });
272
+ } else if (issue.path.length === 0) {
273
+ (fieldErrors as any)._errors.push(mapper(issue));
274
+ } else {
275
+ let curr: any = fieldErrors;
276
+ let i = 0;
277
+ while (i < issue.path.length) {
278
+ const el = issue.path[i]!;
279
+ const terminal = i === issue.path.length - 1;
280
+
281
+ if (!terminal) {
282
+ curr[el] = curr[el] || { _errors: [] };
283
+ } else {
284
+ curr[el] = curr[el] || { _errors: [] };
285
+ curr[el]._errors.push(mapper(issue));
286
+ }
287
+
288
+ curr = curr[el];
289
+ i++;
290
+ }
291
+ }
292
+ }
293
+ };
294
+ processError(error);
295
+ return fieldErrors;
296
+ }
297
+
298
+ export type $ZodErrorTree<T, U = string> = T extends util.Primitive
299
+ ? { errors: U[] }
300
+ : T extends [any, ...any[]]
301
+ ? { errors: U[]; items?: { [K in keyof T]?: $ZodErrorTree<T[K], U> } }
302
+ : T extends any[]
303
+ ? { errors: U[]; items?: Array<$ZodErrorTree<T[number], U>> }
304
+ : T extends object
305
+ ? { errors: U[]; properties?: { [K in keyof T]?: $ZodErrorTree<T[K], U> } }
306
+ : { errors: U[] };
307
+
308
+ export function treeifyError<T>(error: $ZodError<T>): $ZodErrorTree<T>;
309
+ export function treeifyError<T, U>(error: $ZodError<T>, mapper?: (issue: $ZodIssue) => U): $ZodErrorTree<T, U>;
310
+ export function treeifyError<T>(error: $ZodError, _mapper?: any) {
311
+ const mapper: (issue: $ZodIssue) => any =
312
+ _mapper ||
313
+ function (issue: $ZodIssue) {
314
+ return issue.message;
315
+ };
316
+ const result: $ZodErrorTree<T> = { errors: [] } as any;
317
+ const processError = (error: { issues: $ZodIssue[] }, path: PropertyKey[] = []) => {
318
+ for (const issue of error.issues) {
319
+ if (issue.code === "invalid_union" && issue.errors.length) {
320
+ // regular union error
321
+ issue.errors.map((issues) => processError({ issues }, issue.path));
322
+ } else if (issue.code === "invalid_key") {
323
+ processError({ issues: issue.issues }, issue.path);
324
+ } else if (issue.code === "invalid_element") {
325
+ processError({ issues: issue.issues }, issue.path);
326
+ } else {
327
+ const fullpath = [...path, ...issue.path];
328
+ if (fullpath.length === 0) {
329
+ result.errors.push(mapper(issue));
330
+ continue;
331
+ }
332
+
333
+ let curr: any = result;
334
+ let i = 0;
335
+ while (i < fullpath.length) {
336
+ const el = fullpath[i]!;
337
+
338
+ const terminal = i === fullpath.length - 1;
339
+ if (typeof el === "string") {
340
+ curr.properties ??= {};
341
+ curr.properties[el] ??= { errors: [] };
342
+ curr = curr.properties[el];
343
+ } else {
344
+ curr.items ??= [];
345
+ curr.items[el] ??= { errors: [] };
346
+ curr = curr.items[el];
347
+ }
348
+
349
+ if (terminal) {
350
+ curr.errors.push(mapper(issue));
351
+ }
352
+
353
+ i++;
354
+ }
355
+ }
356
+ }
357
+ };
358
+ processError(error);
359
+ return result;
360
+ }
361
+
362
+ /** Format a ZodError as a human-readable string in the following form.
363
+ *
364
+ * From
365
+ *
366
+ * ```ts
367
+ * ZodError {
368
+ * issues: [
369
+ * {
370
+ * expected: 'string',
371
+ * code: 'invalid_type',
372
+ * path: [ 'username' ],
373
+ * message: 'Invalid input: expected string'
374
+ * },
375
+ * {
376
+ * expected: 'number',
377
+ * code: 'invalid_type',
378
+ * path: [ 'favoriteNumbers', 1 ],
379
+ * message: 'Invalid input: expected number'
380
+ * }
381
+ * ];
382
+ * }
383
+ * ```
384
+ *
385
+ * to
386
+ *
387
+ * ```
388
+ * username
389
+ * ✖ Expected number, received string at "username
390
+ * favoriteNumbers[0]
391
+ * ✖ Invalid input: expected number
392
+ * ```
393
+ */
394
+ export function toDotPath(path: (string | number | symbol)[]): string {
395
+ const segs: string[] = [];
396
+ for (const seg of path) {
397
+ if (typeof seg === "number") segs.push(`[${seg}]`);
398
+ else if (typeof seg === "symbol") segs.push(`[${JSON.stringify(String(seg))}]`);
399
+ else if (/[^\w$]/.test(seg)) segs.push(`[${JSON.stringify(seg)}]`);
400
+ else {
401
+ if (segs.length) segs.push(".");
402
+ segs.push(seg);
403
+ }
404
+ }
405
+
406
+ return segs.join("");
407
+ }
408
+
409
+ interface BaseError {
410
+ issues: $ZodIssueBase[];
411
+ }
412
+
413
+ export function prettifyError(error: BaseError): string {
414
+ const lines: string[] = [];
415
+ // sort by path length
416
+ const issues = [...error.issues].sort((a, b) => a.path.length - b.path.length);
417
+
418
+ // Process each issue
419
+ for (const issue of issues) {
420
+ lines.push(`✖ ${issue.message}`);
421
+ if (issue.path?.length) lines.push(` → at ${toDotPath(issue.path)}`);
422
+ }
423
+
424
+ // Convert Map to formatted string
425
+ return lines.join("\n");
426
+ }