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,854 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.JSONSchemaGenerator = void 0;
4
+ exports.toJSONSchema = toJSONSchema;
5
+ const registries_js_1 = require("./registries.cjs");
6
+ const util_js_1 = require("./util.cjs");
7
+ class JSONSchemaGenerator {
8
+ constructor(params) {
9
+ this.counter = 0;
10
+ this.metadataRegistry = params?.metadata ?? registries_js_1.globalRegistry;
11
+ this.target = params?.target ?? "draft-2020-12";
12
+ this.unrepresentable = params?.unrepresentable ?? "throw";
13
+ this.override = params?.override ?? (() => { });
14
+ this.io = params?.io ?? "output";
15
+ this.seen = new Map();
16
+ }
17
+ process(schema, _params = { path: [], schemaPath: [] }) {
18
+ var _a;
19
+ const def = schema._zod.def;
20
+ const formatMap = {
21
+ guid: "uuid",
22
+ url: "uri",
23
+ datetime: "date-time",
24
+ json_string: "json-string",
25
+ regex: "", // do not set
26
+ };
27
+ // check for schema in seens
28
+ const seen = this.seen.get(schema);
29
+ if (seen) {
30
+ seen.count++;
31
+ // check if cycle
32
+ const isCycle = _params.schemaPath.includes(schema);
33
+ if (isCycle) {
34
+ seen.cycle = _params.path;
35
+ }
36
+ return seen.schema;
37
+ }
38
+ // initialize
39
+ const result = { schema: {}, count: 1, cycle: undefined, path: _params.path };
40
+ this.seen.set(schema, result);
41
+ // custom method overrides default behavior
42
+ const overrideSchema = schema._zod.toJSONSchema?.();
43
+ if (overrideSchema) {
44
+ result.schema = overrideSchema;
45
+ }
46
+ else {
47
+ const params = {
48
+ ..._params,
49
+ schemaPath: [..._params.schemaPath, schema],
50
+ path: _params.path,
51
+ };
52
+ const parent = schema._zod.parent;
53
+ if (parent) {
54
+ // schema was cloned from another schema
55
+ result.ref = parent;
56
+ this.process(parent, params);
57
+ this.seen.get(parent).isParent = true;
58
+ }
59
+ else {
60
+ const _json = result.schema;
61
+ switch (def.type) {
62
+ case "string": {
63
+ const json = _json;
64
+ json.type = "string";
65
+ const { minimum, maximum, format, patterns, contentEncoding } = schema._zod
66
+ .bag;
67
+ if (typeof minimum === "number")
68
+ json.minLength = minimum;
69
+ if (typeof maximum === "number")
70
+ json.maxLength = maximum;
71
+ // custom pattern overrides format
72
+ if (format) {
73
+ json.format = formatMap[format] ?? format;
74
+ if (json.format === "")
75
+ delete json.format; // empty format is not valid
76
+ }
77
+ if (contentEncoding)
78
+ json.contentEncoding = contentEncoding;
79
+ if (patterns && patterns.size > 0) {
80
+ const regexes = [...patterns];
81
+ if (regexes.length === 1)
82
+ json.pattern = regexes[0].source;
83
+ else if (regexes.length > 1) {
84
+ result.schema.allOf = [
85
+ ...regexes.map((regex) => ({
86
+ ...(this.target === "draft-7" ? { type: "string" } : {}),
87
+ pattern: regex.source,
88
+ })),
89
+ ];
90
+ }
91
+ }
92
+ break;
93
+ }
94
+ case "number": {
95
+ const json = _json;
96
+ const { minimum, maximum, format, multipleOf, exclusiveMaximum, exclusiveMinimum } = schema._zod.bag;
97
+ if (typeof format === "string" && format.includes("int"))
98
+ json.type = "integer";
99
+ else
100
+ json.type = "number";
101
+ if (typeof exclusiveMinimum === "number")
102
+ json.exclusiveMinimum = exclusiveMinimum;
103
+ if (typeof minimum === "number") {
104
+ json.minimum = minimum;
105
+ if (typeof exclusiveMinimum === "number") {
106
+ if (exclusiveMinimum >= minimum)
107
+ delete json.minimum;
108
+ else
109
+ delete json.exclusiveMinimum;
110
+ }
111
+ }
112
+ if (typeof exclusiveMaximum === "number")
113
+ json.exclusiveMaximum = exclusiveMaximum;
114
+ if (typeof maximum === "number") {
115
+ json.maximum = maximum;
116
+ if (typeof exclusiveMaximum === "number") {
117
+ if (exclusiveMaximum <= maximum)
118
+ delete json.maximum;
119
+ else
120
+ delete json.exclusiveMaximum;
121
+ }
122
+ }
123
+ if (typeof multipleOf === "number")
124
+ json.multipleOf = multipleOf;
125
+ break;
126
+ }
127
+ case "boolean": {
128
+ const json = _json;
129
+ json.type = "boolean";
130
+ break;
131
+ }
132
+ case "bigint": {
133
+ if (this.unrepresentable === "throw") {
134
+ throw new Error("BigInt cannot be represented in JSON Schema");
135
+ }
136
+ break;
137
+ }
138
+ case "symbol": {
139
+ if (this.unrepresentable === "throw") {
140
+ throw new Error("Symbols cannot be represented in JSON Schema");
141
+ }
142
+ break;
143
+ }
144
+ case "null": {
145
+ _json.type = "null";
146
+ break;
147
+ }
148
+ case "any": {
149
+ break;
150
+ }
151
+ case "unknown": {
152
+ break;
153
+ }
154
+ case "undefined": {
155
+ if (this.unrepresentable === "throw") {
156
+ throw new Error("Undefined cannot be represented in JSON Schema");
157
+ }
158
+ break;
159
+ }
160
+ case "void": {
161
+ if (this.unrepresentable === "throw") {
162
+ throw new Error("Void cannot be represented in JSON Schema");
163
+ }
164
+ break;
165
+ }
166
+ case "never": {
167
+ _json.not = {};
168
+ break;
169
+ }
170
+ case "date": {
171
+ if (this.unrepresentable === "throw") {
172
+ throw new Error("Date cannot be represented in JSON Schema");
173
+ }
174
+ break;
175
+ }
176
+ case "array": {
177
+ const json = _json;
178
+ const { minimum, maximum } = schema._zod.bag;
179
+ if (typeof minimum === "number")
180
+ json.minItems = minimum;
181
+ if (typeof maximum === "number")
182
+ json.maxItems = maximum;
183
+ json.type = "array";
184
+ json.items = this.process(def.element, { ...params, path: [...params.path, "items"] });
185
+ break;
186
+ }
187
+ case "object": {
188
+ const json = _json;
189
+ json.type = "object";
190
+ json.properties = {};
191
+ const shape = def.shape; // params.shapeCache.get(schema)!;
192
+ for (const key in shape) {
193
+ json.properties[key] = this.process(shape[key], {
194
+ ...params,
195
+ path: [...params.path, "properties", key],
196
+ });
197
+ }
198
+ // required keys
199
+ const allKeys = new Set(Object.keys(shape));
200
+ // const optionalKeys = new Set(def.optional);
201
+ const requiredKeys = new Set([...allKeys].filter((key) => {
202
+ const v = def.shape[key]._zod;
203
+ if (this.io === "input") {
204
+ return v.optin === undefined;
205
+ }
206
+ else {
207
+ return v.optout === undefined;
208
+ }
209
+ }));
210
+ if (requiredKeys.size > 0) {
211
+ json.required = Array.from(requiredKeys);
212
+ }
213
+ // catchall
214
+ if (def.catchall?._zod.def.type === "never") {
215
+ // strict
216
+ json.additionalProperties = false;
217
+ }
218
+ else if (!def.catchall) {
219
+ // regular
220
+ if (this.io === "output")
221
+ json.additionalProperties = false;
222
+ }
223
+ else if (def.catchall) {
224
+ json.additionalProperties = this.process(def.catchall, {
225
+ ...params,
226
+ path: [...params.path, "additionalProperties"],
227
+ });
228
+ }
229
+ break;
230
+ }
231
+ case "union": {
232
+ const json = _json;
233
+ json.anyOf = def.options.map((x, i) => this.process(x, {
234
+ ...params,
235
+ path: [...params.path, "anyOf", i],
236
+ }));
237
+ break;
238
+ }
239
+ case "intersection": {
240
+ const json = _json;
241
+ const a = this.process(def.left, {
242
+ ...params,
243
+ path: [...params.path, "allOf", 0],
244
+ });
245
+ const b = this.process(def.right, {
246
+ ...params,
247
+ path: [...params.path, "allOf", 1],
248
+ });
249
+ const isSimpleIntersection = (val) => "allOf" in val && Object.keys(val).length === 1;
250
+ const allOf = [
251
+ ...(isSimpleIntersection(a) ? a.allOf : [a]),
252
+ ...(isSimpleIntersection(b) ? b.allOf : [b]),
253
+ ];
254
+ json.allOf = allOf;
255
+ break;
256
+ }
257
+ case "tuple": {
258
+ const json = _json;
259
+ json.type = "array";
260
+ const prefixItems = def.items.map((x, i) => this.process(x, { ...params, path: [...params.path, "prefixItems", i] }));
261
+ if (this.target === "draft-2020-12") {
262
+ json.prefixItems = prefixItems;
263
+ }
264
+ else {
265
+ json.items = prefixItems;
266
+ }
267
+ if (def.rest) {
268
+ const rest = this.process(def.rest, {
269
+ ...params,
270
+ path: [...params.path, "items"],
271
+ });
272
+ if (this.target === "draft-2020-12") {
273
+ json.items = rest;
274
+ }
275
+ else {
276
+ json.additionalItems = rest;
277
+ }
278
+ }
279
+ // additionalItems
280
+ if (def.rest) {
281
+ json.items = this.process(def.rest, {
282
+ ...params,
283
+ path: [...params.path, "items"],
284
+ });
285
+ }
286
+ // length
287
+ const { minimum, maximum } = schema._zod.bag;
288
+ if (typeof minimum === "number")
289
+ json.minItems = minimum;
290
+ if (typeof maximum === "number")
291
+ json.maxItems = maximum;
292
+ break;
293
+ }
294
+ case "record": {
295
+ const json = _json;
296
+ json.type = "object";
297
+ json.propertyNames = this.process(def.keyType, { ...params, path: [...params.path, "propertyNames"] });
298
+ json.additionalProperties = this.process(def.valueType, {
299
+ ...params,
300
+ path: [...params.path, "additionalProperties"],
301
+ });
302
+ break;
303
+ }
304
+ case "map": {
305
+ if (this.unrepresentable === "throw") {
306
+ throw new Error("Map cannot be represented in JSON Schema");
307
+ }
308
+ break;
309
+ }
310
+ case "set": {
311
+ if (this.unrepresentable === "throw") {
312
+ throw new Error("Set cannot be represented in JSON Schema");
313
+ }
314
+ break;
315
+ }
316
+ case "enum": {
317
+ const json = _json;
318
+ const values = (0, util_js_1.getEnumValues)(def.entries);
319
+ // Number enums can have both string and number values
320
+ if (values.every((v) => typeof v === "number"))
321
+ json.type = "number";
322
+ if (values.every((v) => typeof v === "string"))
323
+ json.type = "string";
324
+ json.enum = values;
325
+ break;
326
+ }
327
+ case "literal": {
328
+ const json = _json;
329
+ const vals = [];
330
+ for (const val of def.values) {
331
+ if (val === undefined) {
332
+ if (this.unrepresentable === "throw") {
333
+ throw new Error("Literal `undefined` cannot be represented in JSON Schema");
334
+ }
335
+ else {
336
+ // do not add to vals
337
+ }
338
+ }
339
+ else if (typeof val === "bigint") {
340
+ if (this.unrepresentable === "throw") {
341
+ throw new Error("BigInt literals cannot be represented in JSON Schema");
342
+ }
343
+ else {
344
+ vals.push(Number(val));
345
+ }
346
+ }
347
+ else {
348
+ vals.push(val);
349
+ }
350
+ }
351
+ if (vals.length === 0) {
352
+ // do nothing (an undefined literal was stripped)
353
+ }
354
+ else if (vals.length === 1) {
355
+ const val = vals[0];
356
+ json.type = val === null ? "null" : typeof val;
357
+ json.const = val;
358
+ }
359
+ else {
360
+ if (vals.every((v) => typeof v === "number"))
361
+ json.type = "number";
362
+ if (vals.every((v) => typeof v === "string"))
363
+ json.type = "string";
364
+ if (vals.every((v) => typeof v === "boolean"))
365
+ json.type = "string";
366
+ if (vals.every((v) => v === null))
367
+ json.type = "null";
368
+ json.enum = vals;
369
+ }
370
+ break;
371
+ }
372
+ case "file": {
373
+ const json = _json;
374
+ const file = {
375
+ type: "string",
376
+ format: "binary",
377
+ contentEncoding: "binary",
378
+ };
379
+ const { minimum, maximum, mime } = schema._zod.bag;
380
+ if (minimum !== undefined)
381
+ file.minLength = minimum;
382
+ if (maximum !== undefined)
383
+ file.maxLength = maximum;
384
+ if (mime) {
385
+ if (mime.length === 1) {
386
+ file.contentMediaType = mime[0];
387
+ Object.assign(json, file);
388
+ }
389
+ else {
390
+ json.anyOf = mime.map((m) => {
391
+ const mFile = { ...file, contentMediaType: m };
392
+ return mFile;
393
+ });
394
+ }
395
+ }
396
+ else {
397
+ Object.assign(json, file);
398
+ }
399
+ // if (this.unrepresentable === "throw") {
400
+ // throw new Error("File cannot be represented in JSON Schema");
401
+ // }
402
+ break;
403
+ }
404
+ case "transform": {
405
+ if (this.unrepresentable === "throw") {
406
+ throw new Error("Transforms cannot be represented in JSON Schema");
407
+ }
408
+ break;
409
+ }
410
+ case "nullable": {
411
+ const inner = this.process(def.innerType, params);
412
+ _json.anyOf = [inner, { type: "null" }];
413
+ break;
414
+ }
415
+ case "nonoptional": {
416
+ this.process(def.innerType, params);
417
+ result.ref = def.innerType;
418
+ break;
419
+ }
420
+ case "success": {
421
+ const json = _json;
422
+ json.type = "boolean";
423
+ break;
424
+ }
425
+ case "default": {
426
+ this.process(def.innerType, params);
427
+ result.ref = def.innerType;
428
+ _json.default = JSON.parse(JSON.stringify(def.defaultValue));
429
+ break;
430
+ }
431
+ case "prefault": {
432
+ this.process(def.innerType, params);
433
+ result.ref = def.innerType;
434
+ if (this.io === "input")
435
+ _json._prefault = JSON.parse(JSON.stringify(def.defaultValue));
436
+ break;
437
+ }
438
+ case "catch": {
439
+ // use conditionals
440
+ this.process(def.innerType, params);
441
+ result.ref = def.innerType;
442
+ let catchValue;
443
+ try {
444
+ catchValue = def.catchValue(undefined);
445
+ }
446
+ catch {
447
+ throw new Error("Dynamic catch values are not supported in JSON Schema");
448
+ }
449
+ _json.default = catchValue;
450
+ break;
451
+ }
452
+ case "nan": {
453
+ if (this.unrepresentable === "throw") {
454
+ throw new Error("NaN cannot be represented in JSON Schema");
455
+ }
456
+ break;
457
+ }
458
+ case "template_literal": {
459
+ const json = _json;
460
+ const pattern = schema._zod.pattern;
461
+ if (!pattern)
462
+ throw new Error("Pattern not found in template literal");
463
+ json.type = "string";
464
+ json.pattern = pattern.source;
465
+ break;
466
+ }
467
+ case "pipe": {
468
+ const innerType = this.io === "input" ? (def.in._zod.def.type === "transform" ? def.out : def.in) : def.out;
469
+ this.process(innerType, params);
470
+ result.ref = innerType;
471
+ break;
472
+ }
473
+ case "readonly": {
474
+ this.process(def.innerType, params);
475
+ result.ref = def.innerType;
476
+ _json.readOnly = true;
477
+ break;
478
+ }
479
+ // passthrough types
480
+ case "promise": {
481
+ this.process(def.innerType, params);
482
+ result.ref = def.innerType;
483
+ break;
484
+ }
485
+ case "optional": {
486
+ this.process(def.innerType, params);
487
+ result.ref = def.innerType;
488
+ break;
489
+ }
490
+ case "lazy": {
491
+ const innerType = schema._zod.innerType;
492
+ this.process(innerType, params);
493
+ result.ref = innerType;
494
+ break;
495
+ }
496
+ case "custom": {
497
+ if (this.unrepresentable === "throw") {
498
+ throw new Error("Custom types cannot be represented in JSON Schema");
499
+ }
500
+ break;
501
+ }
502
+ default: {
503
+ def;
504
+ }
505
+ }
506
+ }
507
+ }
508
+ // metadata
509
+ const meta = this.metadataRegistry.get(schema);
510
+ if (meta)
511
+ Object.assign(result.schema, meta);
512
+ if (this.io === "input" && isTransforming(schema)) {
513
+ // examples/defaults only apply to output type of pipe
514
+ delete result.schema.examples;
515
+ delete result.schema.default;
516
+ }
517
+ // set prefault as default
518
+ if (this.io === "input" && result.schema._prefault)
519
+ (_a = result.schema).default ?? (_a.default = result.schema._prefault);
520
+ delete result.schema._prefault;
521
+ // pulling fresh from this.seen in case it was overwritten
522
+ const _result = this.seen.get(schema);
523
+ return _result.schema;
524
+ }
525
+ emit(schema, _params) {
526
+ const params = {
527
+ cycles: _params?.cycles ?? "ref",
528
+ reused: _params?.reused ?? "inline",
529
+ // unrepresentable: _params?.unrepresentable ?? "throw",
530
+ // uri: _params?.uri ?? ((id) => `${id}`),
531
+ external: _params?.external ?? undefined,
532
+ };
533
+ // iterate over seen map;
534
+ const root = this.seen.get(schema);
535
+ if (!root)
536
+ throw new Error("Unprocessed schema. This is a bug in Zod.");
537
+ // initialize result with root schema fields
538
+ // Object.assign(result, seen.cached);
539
+ // returns a ref to the schema
540
+ // defId will be empty if the ref points to an external schema (or #)
541
+ const makeURI = (entry) => {
542
+ // comparing the seen objects because sometimes
543
+ // multiple schemas map to the same seen object.
544
+ // e.g. lazy
545
+ // external is configured
546
+ const defsSegment = this.target === "draft-2020-12" ? "$defs" : "definitions";
547
+ if (params.external) {
548
+ const externalId = params.external.registry.get(entry[0])?.id; // ?? "__shared";// `__schema${this.counter++}`;
549
+ // check if schema is in the external registry
550
+ const uriGenerator = params.external.uri ?? ((id) => id);
551
+ if (externalId) {
552
+ return { ref: uriGenerator(externalId) };
553
+ }
554
+ // otherwise, add to __shared
555
+ const id = entry[1].defId ?? entry[1].schema.id ?? `schema${this.counter++}`;
556
+ entry[1].defId = id; // set defId so it will be reused if needed
557
+ return { defId: id, ref: `${uriGenerator("__shared")}#/${defsSegment}/${id}` };
558
+ }
559
+ if (entry[1] === root) {
560
+ return { ref: "#" };
561
+ }
562
+ // self-contained schema
563
+ const uriPrefix = `#`;
564
+ const defUriPrefix = `${uriPrefix}/${defsSegment}/`;
565
+ const defId = entry[1].schema.id ?? `__schema${this.counter++}`;
566
+ return { defId, ref: defUriPrefix + defId };
567
+ };
568
+ // stored cached version in `def` property
569
+ // remove all properties, set $ref
570
+ const extractToDef = (entry) => {
571
+ // if the schema is already a reference, do not extract it
572
+ if (entry[1].schema.$ref) {
573
+ return;
574
+ }
575
+ const seen = entry[1];
576
+ const { ref, defId } = makeURI(entry);
577
+ seen.def = { ...seen.schema };
578
+ // defId won't be set if the schema is a reference to an external schema
579
+ if (defId)
580
+ seen.defId = defId;
581
+ // wipe away all properties except $ref
582
+ const schema = seen.schema;
583
+ for (const key in schema) {
584
+ delete schema[key];
585
+ }
586
+ schema.$ref = ref;
587
+ };
588
+ // throw on cycles
589
+ // break cycles
590
+ if (params.cycles === "throw") {
591
+ for (const entry of this.seen.entries()) {
592
+ const seen = entry[1];
593
+ if (seen.cycle) {
594
+ throw new Error("Cycle detected: " +
595
+ `#/${seen.cycle?.join("/")}/<root>` +
596
+ '\n\nSet the `cycles` parameter to `"ref"` to resolve cyclical schemas with defs.');
597
+ }
598
+ }
599
+ }
600
+ // extract schemas into $defs
601
+ for (const entry of this.seen.entries()) {
602
+ const seen = entry[1];
603
+ // convert root schema to # $ref
604
+ if (schema === entry[0]) {
605
+ extractToDef(entry); // this has special handling for the root schema
606
+ continue;
607
+ }
608
+ // extract schemas that are in the external registry
609
+ if (params.external) {
610
+ const ext = params.external.registry.get(entry[0])?.id;
611
+ if (schema !== entry[0] && ext) {
612
+ extractToDef(entry);
613
+ continue;
614
+ }
615
+ }
616
+ // extract schemas with `id` meta
617
+ const id = this.metadataRegistry.get(entry[0])?.id;
618
+ if (id) {
619
+ extractToDef(entry);
620
+ continue;
621
+ }
622
+ // break cycles
623
+ if (seen.cycle) {
624
+ // any
625
+ extractToDef(entry);
626
+ continue;
627
+ }
628
+ // extract reused schemas
629
+ if (seen.count > 1) {
630
+ if (params.reused === "ref") {
631
+ extractToDef(entry);
632
+ // biome-ignore lint:
633
+ continue;
634
+ }
635
+ }
636
+ }
637
+ // flatten _refs
638
+ const flattenRef = (zodSchema, params) => {
639
+ const seen = this.seen.get(zodSchema);
640
+ const schema = seen.def ?? seen.schema;
641
+ const _cached = { ...schema };
642
+ // already seen
643
+ if (seen.ref === null) {
644
+ return;
645
+ }
646
+ // flatten ref if defined
647
+ const ref = seen.ref;
648
+ seen.ref = null; // prevent recursion
649
+ if (ref) {
650
+ flattenRef(ref, params);
651
+ // merge referenced schema into current
652
+ const refSchema = this.seen.get(ref).schema;
653
+ if (refSchema.$ref && params.target === "draft-7") {
654
+ schema.allOf = schema.allOf ?? [];
655
+ schema.allOf.push(refSchema);
656
+ }
657
+ else {
658
+ Object.assign(schema, refSchema);
659
+ Object.assign(schema, _cached); // prevent overwriting any fields in the original schema
660
+ }
661
+ }
662
+ // execute overrides
663
+ if (!seen.isParent)
664
+ this.override({
665
+ zodSchema: zodSchema,
666
+ jsonSchema: schema,
667
+ path: seen.path ?? [],
668
+ });
669
+ };
670
+ for (const entry of [...this.seen.entries()].reverse()) {
671
+ flattenRef(entry[0], { target: this.target });
672
+ }
673
+ const result = {};
674
+ if (this.target === "draft-2020-12") {
675
+ result.$schema = "https://json-schema.org/draft/2020-12/schema";
676
+ }
677
+ else if (this.target === "draft-7") {
678
+ result.$schema = "http://json-schema.org/draft-07/schema#";
679
+ }
680
+ else {
681
+ console.warn(`Invalid target: ${this.target}`);
682
+ }
683
+ if (params.external?.uri) {
684
+ const id = params.external.registry.get(schema)?.id;
685
+ if (!id)
686
+ throw new Error("Schema is missing an `id` property");
687
+ result.$id = params.external.uri(id);
688
+ }
689
+ Object.assign(result, root.def);
690
+ // build defs object
691
+ const defs = params.external?.defs ?? {};
692
+ for (const entry of this.seen.entries()) {
693
+ const seen = entry[1];
694
+ if (seen.def && seen.defId) {
695
+ defs[seen.defId] = seen.def;
696
+ }
697
+ }
698
+ // set definitions in result
699
+ if (params.external) {
700
+ }
701
+ else {
702
+ if (Object.keys(defs).length > 0) {
703
+ if (this.target === "draft-2020-12") {
704
+ result.$defs = defs;
705
+ }
706
+ else {
707
+ result.definitions = defs;
708
+ }
709
+ }
710
+ }
711
+ try {
712
+ // this "finalizes" this schema and ensures all cycles are removed
713
+ // each call to .emit() is functionally independent
714
+ // though the seen map is shared
715
+ return JSON.parse(JSON.stringify(result));
716
+ }
717
+ catch (_err) {
718
+ throw new Error("Error converting schema to JSON.");
719
+ }
720
+ }
721
+ }
722
+ exports.JSONSchemaGenerator = JSONSchemaGenerator;
723
+ function toJSONSchema(input, _params) {
724
+ if (input instanceof registries_js_1.$ZodRegistry) {
725
+ const gen = new JSONSchemaGenerator(_params);
726
+ const defs = {};
727
+ for (const entry of input._idmap.entries()) {
728
+ const [_, schema] = entry;
729
+ gen.process(schema);
730
+ }
731
+ const schemas = {};
732
+ const external = {
733
+ registry: input,
734
+ uri: _params?.uri,
735
+ defs,
736
+ };
737
+ for (const entry of input._idmap.entries()) {
738
+ const [key, schema] = entry;
739
+ schemas[key] = gen.emit(schema, {
740
+ ..._params,
741
+ external,
742
+ });
743
+ }
744
+ if (Object.keys(defs).length > 0) {
745
+ const defsSegment = gen.target === "draft-2020-12" ? "$defs" : "definitions";
746
+ schemas.__shared = {
747
+ [defsSegment]: defs,
748
+ };
749
+ }
750
+ return { schemas };
751
+ }
752
+ const gen = new JSONSchemaGenerator(_params);
753
+ gen.process(input);
754
+ return gen.emit(input, _params);
755
+ }
756
+ function isTransforming(_schema, _ctx) {
757
+ const ctx = _ctx ?? { seen: new Set() };
758
+ if (ctx.seen.has(_schema))
759
+ return false;
760
+ ctx.seen.add(_schema);
761
+ const schema = _schema;
762
+ const def = schema._zod.def;
763
+ switch (def.type) {
764
+ case "string":
765
+ case "number":
766
+ case "bigint":
767
+ case "boolean":
768
+ case "date":
769
+ case "symbol":
770
+ case "undefined":
771
+ case "null":
772
+ case "any":
773
+ case "unknown":
774
+ case "never":
775
+ case "void":
776
+ case "literal":
777
+ case "enum":
778
+ case "nan":
779
+ case "file":
780
+ case "template_literal":
781
+ return false;
782
+ case "array": {
783
+ return isTransforming(def.element, ctx);
784
+ }
785
+ case "object": {
786
+ for (const key in def.shape) {
787
+ if (isTransforming(def.shape[key], ctx))
788
+ return true;
789
+ }
790
+ return false;
791
+ }
792
+ case "union": {
793
+ for (const option of def.options) {
794
+ if (isTransforming(option, ctx))
795
+ return true;
796
+ }
797
+ return false;
798
+ }
799
+ case "intersection": {
800
+ return isTransforming(def.left, ctx) || isTransforming(def.right, ctx);
801
+ }
802
+ case "tuple": {
803
+ for (const item of def.items) {
804
+ if (isTransforming(item, ctx))
805
+ return true;
806
+ }
807
+ if (def.rest && isTransforming(def.rest, ctx))
808
+ return true;
809
+ return false;
810
+ }
811
+ case "record": {
812
+ return isTransforming(def.keyType, ctx) || isTransforming(def.valueType, ctx);
813
+ }
814
+ case "map": {
815
+ return isTransforming(def.keyType, ctx) || isTransforming(def.valueType, ctx);
816
+ }
817
+ case "set": {
818
+ return isTransforming(def.valueType, ctx);
819
+ }
820
+ // inner types
821
+ case "promise":
822
+ case "optional":
823
+ case "nonoptional":
824
+ case "nullable":
825
+ case "readonly":
826
+ return isTransforming(def.innerType, ctx);
827
+ case "lazy":
828
+ return isTransforming(def.getter(), ctx);
829
+ case "default": {
830
+ return isTransforming(def.innerType, ctx);
831
+ }
832
+ case "prefault": {
833
+ return isTransforming(def.innerType, ctx);
834
+ }
835
+ case "custom": {
836
+ return false;
837
+ }
838
+ case "transform": {
839
+ return true;
840
+ }
841
+ case "pipe": {
842
+ return isTransforming(def.in, ctx) || isTransforming(def.out, ctx);
843
+ }
844
+ case "success": {
845
+ return false;
846
+ }
847
+ case "catch": {
848
+ return false;
849
+ }
850
+ default:
851
+ def;
852
+ }
853
+ throw new Error(`Unknown schema type: ${def.type}`);
854
+ }