reliant-type 1.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 (345) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +1305 -0
  3. package/dist/cjs/constants/SECURITY_CONSTANTS.js +49 -0
  4. package/dist/cjs/constants/SECURITY_CONSTANTS.js.map +1 -0
  5. package/dist/cjs/constants/VALIDATION_CONSTANTS.js +103 -0
  6. package/dist/cjs/constants/VALIDATION_CONSTANTS.js.map +1 -0
  7. package/dist/cjs/core/schema/extensions/SmartInference.js +200 -0
  8. package/dist/cjs/core/schema/extensions/SmartInference.js.map +1 -0
  9. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/Docs.js +100 -0
  10. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/Docs.js.map +1 -0
  11. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/DocumentationGenerator.js +192 -0
  12. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/DocumentationGenerator.js.map +1 -0
  13. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/InteractiveDocumentationGenerator.js +174 -0
  14. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/InteractiveDocumentationGenerator.js.map +1 -0
  15. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/SchemaAnalyzer.js +54 -0
  16. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/SchemaAnalyzer.js.map +1 -0
  17. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/TypeScriptGenerator.js +50 -0
  18. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/TypeScriptGenerator.js.map +1 -0
  19. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/index.js +15 -0
  20. package/dist/cjs/core/schema/extensions/components/AutoDocumentation/index.js.map +1 -0
  21. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/ConditionalBuilder.js +70 -0
  22. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/ConditionalBuilder.js.map +1 -0
  23. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/ConditionalElse.js +40 -0
  24. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/ConditionalElse.js.map +1 -0
  25. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/ConditionalThen.js +19 -0
  26. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/ConditionalThen.js.map +1 -0
  27. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/MultiConditionalBuilder.js +20 -0
  28. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/MultiConditionalBuilder.js.map +1 -0
  29. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/MultiConditionalThen.js +49 -0
  30. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/MultiConditionalThen.js.map +1 -0
  31. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/index.js +98 -0
  32. package/dist/cjs/core/schema/extensions/components/ConditionalValidation/index.js.map +1 -0
  33. package/dist/cjs/core/schema/extensions/components/RealtimeValidation/FormValidator.js +85 -0
  34. package/dist/cjs/core/schema/extensions/components/RealtimeValidation/FormValidator.js.map +1 -0
  35. package/dist/cjs/core/schema/extensions/components/RealtimeValidation/LiveValidator.js +133 -0
  36. package/dist/cjs/core/schema/extensions/components/RealtimeValidation/LiveValidator.js.map +1 -0
  37. package/dist/cjs/core/schema/extensions/components/RealtimeValidation/StreamValidator.js +351 -0
  38. package/dist/cjs/core/schema/extensions/components/RealtimeValidation/StreamValidator.js.map +1 -0
  39. package/dist/cjs/core/schema/extensions/components/RealtimeValidation/index.js +109 -0
  40. package/dist/cjs/core/schema/extensions/components/RealtimeValidation/index.js.map +1 -0
  41. package/dist/cjs/core/schema/extensions/index.js +61 -0
  42. package/dist/cjs/core/schema/extensions/index.js.map +1 -0
  43. package/dist/cjs/core/schema/extensions/mods/index.js +51 -0
  44. package/dist/cjs/core/schema/extensions/mods/index.js.map +1 -0
  45. package/dist/cjs/core/schema/extensions/mods/openapi-converter.js +227 -0
  46. package/dist/cjs/core/schema/extensions/mods/openapi-converter.js.map +1 -0
  47. package/dist/cjs/core/schema/extensions/mods/typescript-generator.js +287 -0
  48. package/dist/cjs/core/schema/extensions/mods/typescript-generator.js.map +1 -0
  49. package/dist/cjs/core/schema/extensions/mods/validation-engine.js +224 -0
  50. package/dist/cjs/core/schema/extensions/mods/validation-engine.js.map +1 -0
  51. package/dist/cjs/core/schema/mode/interfaces/Interface.js +277 -0
  52. package/dist/cjs/core/schema/mode/interfaces/Interface.js.map +1 -0
  53. package/dist/cjs/core/schema/mode/interfaces/InterfaceSchema.js +1431 -0
  54. package/dist/cjs/core/schema/mode/interfaces/InterfaceSchema.js.map +1 -0
  55. package/dist/cjs/core/schema/mode/interfaces/conditional/evaluator/ConditionalEvaluator.js +520 -0
  56. package/dist/cjs/core/schema/mode/interfaces/conditional/evaluator/ConditionalEvaluator.js.map +1 -0
  57. package/dist/cjs/core/schema/mode/interfaces/conditional/parser/ConditionalAST.js +624 -0
  58. package/dist/cjs/core/schema/mode/interfaces/conditional/parser/ConditionalAST.js.map +1 -0
  59. package/dist/cjs/core/schema/mode/interfaces/conditional/parser/ConditionalLexer.js +811 -0
  60. package/dist/cjs/core/schema/mode/interfaces/conditional/parser/ConditionalLexer.js.map +1 -0
  61. package/dist/cjs/core/schema/mode/interfaces/conditional/parser/ConditionalParser.js +599 -0
  62. package/dist/cjs/core/schema/mode/interfaces/conditional/parser/ConditionalParser.js.map +1 -0
  63. package/dist/cjs/core/schema/mode/interfaces/conditional/types/ConditionalTypes.js +89 -0
  64. package/dist/cjs/core/schema/mode/interfaces/conditional/types/ConditionalTypes.js.map +1 -0
  65. package/dist/cjs/core/schema/mode/interfaces/errors/ErrorHandler.js +356 -0
  66. package/dist/cjs/core/schema/mode/interfaces/errors/ErrorHandler.js.map +1 -0
  67. package/dist/cjs/core/schema/mode/interfaces/errors/types/errors.type.js +80 -0
  68. package/dist/cjs/core/schema/mode/interfaces/errors/types/errors.type.js.map +1 -0
  69. package/dist/cjs/core/schema/mode/interfaces/precompilation/FieldPrecompilers.js +778 -0
  70. package/dist/cjs/core/schema/mode/interfaces/precompilation/FieldPrecompilers.js.map +1 -0
  71. package/dist/cjs/core/schema/mode/interfaces/precompilation/SchemaPrecompiler.js +523 -0
  72. package/dist/cjs/core/schema/mode/interfaces/precompilation/SchemaPrecompiler.js.map +1 -0
  73. package/dist/cjs/core/schema/mode/interfaces/typescript/ConditionalTypes.js +681 -0
  74. package/dist/cjs/core/schema/mode/interfaces/typescript/ConditionalTypes.js.map +1 -0
  75. package/dist/cjs/core/schema/mode/interfaces/typescript/IDESupport.js +430 -0
  76. package/dist/cjs/core/schema/mode/interfaces/typescript/IDESupport.js.map +1 -0
  77. package/dist/cjs/core/schema/mode/interfaces/typescript/TypeInference.js +225 -0
  78. package/dist/cjs/core/schema/mode/interfaces/typescript/TypeInference.js.map +1 -0
  79. package/dist/cjs/core/schema/mode/interfaces/typescript/index.js +44 -0
  80. package/dist/cjs/core/schema/mode/interfaces/typescript/index.js.map +1 -0
  81. package/dist/cjs/core/schema/mode/interfaces/validators/ConstraintParser.js +1134 -0
  82. package/dist/cjs/core/schema/mode/interfaces/validators/ConstraintParser.js.map +1 -0
  83. package/dist/cjs/core/schema/mode/interfaces/validators/TypeGuards.js +256 -0
  84. package/dist/cjs/core/schema/mode/interfaces/validators/TypeGuards.js.map +1 -0
  85. package/dist/cjs/core/schema/mode/interfaces/validators/TypeValidators.js +429 -0
  86. package/dist/cjs/core/schema/mode/interfaces/validators/TypeValidators.js.map +1 -0
  87. package/dist/cjs/core/schema/mode/interfaces/validators/UnionCache.js +404 -0
  88. package/dist/cjs/core/schema/mode/interfaces/validators/UnionCache.js.map +1 -0
  89. package/dist/cjs/core/schema/mode/interfaces/validators/ValidationHelpers.js +851 -0
  90. package/dist/cjs/core/schema/mode/interfaces/validators/ValidationHelpers.js.map +1 -0
  91. package/dist/cjs/core/schema/mode/interfaces/validators/mods/passValidator.js +262 -0
  92. package/dist/cjs/core/schema/mode/interfaces/validators/mods/passValidator.js.map +1 -0
  93. package/dist/cjs/core/schema/mode/interfaces/validators/mods/securityValidator.js +887 -0
  94. package/dist/cjs/core/schema/mode/interfaces/validators/mods/securityValidator.js.map +1 -0
  95. package/dist/cjs/core/schema/mode/interfaces/validators/mods/urlValidation.js +191 -0
  96. package/dist/cjs/core/schema/mode/interfaces/validators/mods/urlValidation.js.map +1 -0
  97. package/dist/cjs/core/schema/optimization/ObjectValidationCache.js +462 -0
  98. package/dist/cjs/core/schema/optimization/ObjectValidationCache.js.map +1 -0
  99. package/dist/cjs/core/schema/optimization/PerformanceMonitor.js +773 -0
  100. package/dist/cjs/core/schema/optimization/PerformanceMonitor.js.map +1 -0
  101. package/dist/cjs/core/schema/optimization/SchemaCompiler.js +600 -0
  102. package/dist/cjs/core/schema/optimization/SchemaCompiler.js.map +1 -0
  103. package/dist/cjs/core/types/ValidatorTypes.js +70 -0
  104. package/dist/cjs/core/types/ValidatorTypes.js.map +1 -0
  105. package/dist/cjs/core/types/parser.type.js +12 -0
  106. package/dist/cjs/core/types/parser.type.js.map +1 -0
  107. package/dist/cjs/core/utils/Make.js +61 -0
  108. package/dist/cjs/core/utils/Make.js.map +1 -0
  109. package/dist/cjs/core/utils/Mod.js +1033 -0
  110. package/dist/cjs/core/utils/Mod.js.map +1 -0
  111. package/dist/cjs/core/utils/UrlArgs.js +102 -0
  112. package/dist/cjs/core/utils/UrlArgs.js.map +1 -0
  113. package/dist/cjs/core/utils/arrayToEnum.js +18 -0
  114. package/dist/cjs/core/utils/arrayToEnum.js.map +1 -0
  115. package/dist/cjs/core/utils/createUrlArgsEnumFArray.js +13 -0
  116. package/dist/cjs/core/utils/createUrlArgsEnumFArray.js.map +1 -0
  117. package/dist/cjs/core/utils/securityHelpers.js +215 -0
  118. package/dist/cjs/core/utils/securityHelpers.js.map +1 -0
  119. package/dist/cjs/core/utils/securityValidatorHelpers.js +65 -0
  120. package/dist/cjs/core/utils/securityValidatorHelpers.js.map +1 -0
  121. package/dist/cjs/index.js +31 -0
  122. package/dist/cjs/index.js.map +1 -0
  123. package/dist/cjs/package.json +3 -0
  124. package/dist/esm/constants/SECURITY_CONSTANTS.js +47 -0
  125. package/dist/esm/constants/SECURITY_CONSTANTS.js.map +1 -0
  126. package/dist/esm/constants/VALIDATION_CONSTANTS.js +98 -0
  127. package/dist/esm/constants/VALIDATION_CONSTANTS.js.map +1 -0
  128. package/dist/esm/core/schema/extensions/SmartInference.js +197 -0
  129. package/dist/esm/core/schema/extensions/SmartInference.js.map +1 -0
  130. package/dist/esm/core/schema/extensions/components/AutoDocumentation/Docs.js +98 -0
  131. package/dist/esm/core/schema/extensions/components/AutoDocumentation/Docs.js.map +1 -0
  132. package/dist/esm/core/schema/extensions/components/AutoDocumentation/DocumentationGenerator.js +190 -0
  133. package/dist/esm/core/schema/extensions/components/AutoDocumentation/DocumentationGenerator.js.map +1 -0
  134. package/dist/esm/core/schema/extensions/components/AutoDocumentation/InteractiveDocumentationGenerator.js +172 -0
  135. package/dist/esm/core/schema/extensions/components/AutoDocumentation/InteractiveDocumentationGenerator.js.map +1 -0
  136. package/dist/esm/core/schema/extensions/components/AutoDocumentation/SchemaAnalyzer.js +52 -0
  137. package/dist/esm/core/schema/extensions/components/AutoDocumentation/SchemaAnalyzer.js.map +1 -0
  138. package/dist/esm/core/schema/extensions/components/AutoDocumentation/TypeScriptGenerator.js +48 -0
  139. package/dist/esm/core/schema/extensions/components/AutoDocumentation/TypeScriptGenerator.js.map +1 -0
  140. package/dist/esm/core/schema/extensions/components/AutoDocumentation/index.js +12 -0
  141. package/dist/esm/core/schema/extensions/components/AutoDocumentation/index.js.map +1 -0
  142. package/dist/esm/core/schema/extensions/components/ConditionalValidation/ConditionalBuilder.js +68 -0
  143. package/dist/esm/core/schema/extensions/components/ConditionalValidation/ConditionalBuilder.js.map +1 -0
  144. package/dist/esm/core/schema/extensions/components/ConditionalValidation/ConditionalElse.js +38 -0
  145. package/dist/esm/core/schema/extensions/components/ConditionalValidation/ConditionalElse.js.map +1 -0
  146. package/dist/esm/core/schema/extensions/components/ConditionalValidation/ConditionalThen.js +17 -0
  147. package/dist/esm/core/schema/extensions/components/ConditionalValidation/ConditionalThen.js.map +1 -0
  148. package/dist/esm/core/schema/extensions/components/ConditionalValidation/MultiConditionalBuilder.js +18 -0
  149. package/dist/esm/core/schema/extensions/components/ConditionalValidation/MultiConditionalBuilder.js.map +1 -0
  150. package/dist/esm/core/schema/extensions/components/ConditionalValidation/MultiConditionalThen.js +45 -0
  151. package/dist/esm/core/schema/extensions/components/ConditionalValidation/MultiConditionalThen.js.map +1 -0
  152. package/dist/esm/core/schema/extensions/components/ConditionalValidation/index.js +92 -0
  153. package/dist/esm/core/schema/extensions/components/ConditionalValidation/index.js.map +1 -0
  154. package/dist/esm/core/schema/extensions/components/RealtimeValidation/FormValidator.js +83 -0
  155. package/dist/esm/core/schema/extensions/components/RealtimeValidation/FormValidator.js.map +1 -0
  156. package/dist/esm/core/schema/extensions/components/RealtimeValidation/LiveValidator.js +131 -0
  157. package/dist/esm/core/schema/extensions/components/RealtimeValidation/LiveValidator.js.map +1 -0
  158. package/dist/esm/core/schema/extensions/components/RealtimeValidation/StreamValidator.js +349 -0
  159. package/dist/esm/core/schema/extensions/components/RealtimeValidation/StreamValidator.js.map +1 -0
  160. package/dist/esm/core/schema/extensions/components/RealtimeValidation/index.js +103 -0
  161. package/dist/esm/core/schema/extensions/components/RealtimeValidation/index.js.map +1 -0
  162. package/dist/esm/core/schema/extensions/index.js +53 -0
  163. package/dist/esm/core/schema/extensions/index.js.map +1 -0
  164. package/dist/esm/core/schema/extensions/mods/index.js +47 -0
  165. package/dist/esm/core/schema/extensions/mods/index.js.map +1 -0
  166. package/dist/esm/core/schema/extensions/mods/openapi-converter.js +225 -0
  167. package/dist/esm/core/schema/extensions/mods/openapi-converter.js.map +1 -0
  168. package/dist/esm/core/schema/extensions/mods/typescript-generator.js +284 -0
  169. package/dist/esm/core/schema/extensions/mods/typescript-generator.js.map +1 -0
  170. package/dist/esm/core/schema/extensions/mods/validation-engine.js +222 -0
  171. package/dist/esm/core/schema/extensions/mods/validation-engine.js.map +1 -0
  172. package/dist/esm/core/schema/mode/interfaces/Interface.js +269 -0
  173. package/dist/esm/core/schema/mode/interfaces/Interface.js.map +1 -0
  174. package/dist/esm/core/schema/mode/interfaces/InterfaceSchema.js +1429 -0
  175. package/dist/esm/core/schema/mode/interfaces/InterfaceSchema.js.map +1 -0
  176. package/dist/esm/core/schema/mode/interfaces/conditional/evaluator/ConditionalEvaluator.js +518 -0
  177. package/dist/esm/core/schema/mode/interfaces/conditional/evaluator/ConditionalEvaluator.js.map +1 -0
  178. package/dist/esm/core/schema/mode/interfaces/conditional/parser/ConditionalAST.js +620 -0
  179. package/dist/esm/core/schema/mode/interfaces/conditional/parser/ConditionalAST.js.map +1 -0
  180. package/dist/esm/core/schema/mode/interfaces/conditional/parser/ConditionalLexer.js +809 -0
  181. package/dist/esm/core/schema/mode/interfaces/conditional/parser/ConditionalLexer.js.map +1 -0
  182. package/dist/esm/core/schema/mode/interfaces/conditional/parser/ConditionalParser.js +597 -0
  183. package/dist/esm/core/schema/mode/interfaces/conditional/parser/ConditionalParser.js.map +1 -0
  184. package/dist/esm/core/schema/mode/interfaces/conditional/types/ConditionalTypes.js +89 -0
  185. package/dist/esm/core/schema/mode/interfaces/conditional/types/ConditionalTypes.js.map +1 -0
  186. package/dist/esm/core/schema/mode/interfaces/errors/ErrorHandler.js +354 -0
  187. package/dist/esm/core/schema/mode/interfaces/errors/ErrorHandler.js.map +1 -0
  188. package/dist/esm/core/schema/mode/interfaces/errors/types/errors.type.js +80 -0
  189. package/dist/esm/core/schema/mode/interfaces/errors/types/errors.type.js.map +1 -0
  190. package/dist/esm/core/schema/mode/interfaces/precompilation/FieldPrecompilers.js +776 -0
  191. package/dist/esm/core/schema/mode/interfaces/precompilation/FieldPrecompilers.js.map +1 -0
  192. package/dist/esm/core/schema/mode/interfaces/precompilation/SchemaPrecompiler.js +521 -0
  193. package/dist/esm/core/schema/mode/interfaces/precompilation/SchemaPrecompiler.js.map +1 -0
  194. package/dist/esm/core/schema/mode/interfaces/typescript/ConditionalTypes.js +681 -0
  195. package/dist/esm/core/schema/mode/interfaces/typescript/ConditionalTypes.js.map +1 -0
  196. package/dist/esm/core/schema/mode/interfaces/typescript/IDESupport.js +428 -0
  197. package/dist/esm/core/schema/mode/interfaces/typescript/IDESupport.js.map +1 -0
  198. package/dist/esm/core/schema/mode/interfaces/typescript/TypeInference.js +223 -0
  199. package/dist/esm/core/schema/mode/interfaces/typescript/TypeInference.js.map +1 -0
  200. package/dist/esm/core/schema/mode/interfaces/typescript/index.js +35 -0
  201. package/dist/esm/core/schema/mode/interfaces/typescript/index.js.map +1 -0
  202. package/dist/esm/core/schema/mode/interfaces/validators/ConstraintParser.js +1132 -0
  203. package/dist/esm/core/schema/mode/interfaces/validators/ConstraintParser.js.map +1 -0
  204. package/dist/esm/core/schema/mode/interfaces/validators/TypeGuards.js +254 -0
  205. package/dist/esm/core/schema/mode/interfaces/validators/TypeGuards.js.map +1 -0
  206. package/dist/esm/core/schema/mode/interfaces/validators/TypeValidators.js +427 -0
  207. package/dist/esm/core/schema/mode/interfaces/validators/TypeValidators.js.map +1 -0
  208. package/dist/esm/core/schema/mode/interfaces/validators/UnionCache.js +400 -0
  209. package/dist/esm/core/schema/mode/interfaces/validators/UnionCache.js.map +1 -0
  210. package/dist/esm/core/schema/mode/interfaces/validators/ValidationHelpers.js +849 -0
  211. package/dist/esm/core/schema/mode/interfaces/validators/ValidationHelpers.js.map +1 -0
  212. package/dist/esm/core/schema/mode/interfaces/validators/mods/passValidator.js +260 -0
  213. package/dist/esm/core/schema/mode/interfaces/validators/mods/passValidator.js.map +1 -0
  214. package/dist/esm/core/schema/mode/interfaces/validators/mods/securityValidator.js +881 -0
  215. package/dist/esm/core/schema/mode/interfaces/validators/mods/securityValidator.js.map +1 -0
  216. package/dist/esm/core/schema/mode/interfaces/validators/mods/urlValidation.js +189 -0
  217. package/dist/esm/core/schema/mode/interfaces/validators/mods/urlValidation.js.map +1 -0
  218. package/dist/esm/core/schema/optimization/ObjectValidationCache.js +460 -0
  219. package/dist/esm/core/schema/optimization/ObjectValidationCache.js.map +1 -0
  220. package/dist/esm/core/schema/optimization/PerformanceMonitor.js +771 -0
  221. package/dist/esm/core/schema/optimization/PerformanceMonitor.js.map +1 -0
  222. package/dist/esm/core/schema/optimization/SchemaCompiler.js +598 -0
  223. package/dist/esm/core/schema/optimization/SchemaCompiler.js.map +1 -0
  224. package/dist/esm/core/types/ValidatorTypes.js +65 -0
  225. package/dist/esm/core/types/ValidatorTypes.js.map +1 -0
  226. package/dist/esm/core/types/parser.type.js +12 -0
  227. package/dist/esm/core/types/parser.type.js.map +1 -0
  228. package/dist/esm/core/utils/Make.js +59 -0
  229. package/dist/esm/core/utils/Make.js.map +1 -0
  230. package/dist/esm/core/utils/Mod.js +1031 -0
  231. package/dist/esm/core/utils/Mod.js.map +1 -0
  232. package/dist/esm/core/utils/UrlArgs.js +98 -0
  233. package/dist/esm/core/utils/UrlArgs.js.map +1 -0
  234. package/dist/esm/core/utils/arrayToEnum.js +16 -0
  235. package/dist/esm/core/utils/arrayToEnum.js.map +1 -0
  236. package/dist/esm/core/utils/createUrlArgsEnumFArray.js +11 -0
  237. package/dist/esm/core/utils/createUrlArgsEnumFArray.js.map +1 -0
  238. package/dist/esm/core/utils/securityHelpers.js +207 -0
  239. package/dist/esm/core/utils/securityHelpers.js.map +1 -0
  240. package/dist/esm/core/utils/securityValidatorHelpers.js +62 -0
  241. package/dist/esm/core/utils/securityValidatorHelpers.js.map +1 -0
  242. package/dist/esm/index.js +12 -0
  243. package/dist/esm/index.js.map +1 -0
  244. package/dist/esm/package.json +3 -0
  245. package/dist/schema.d.ts +2595 -0
  246. package/docs/ALL_TYPES.md +120 -0
  247. package/docs/API-STABILITY.md +336 -0
  248. package/docs/CONDITIONAL-VALIDATION.md +637 -0
  249. package/docs/EXAMPLES.md +876 -0
  250. package/docs/FIELD-TYPES.md +829 -0
  251. package/docs/GETTING-STARTED.md +394 -0
  252. package/docs/LIVE-UTILITY.md +1137 -0
  253. package/docs/QUICK-REFERENCE.md +346 -0
  254. package/docs/README.md +205 -0
  255. package/docs/VSCODE-EXTENSION.md +458 -0
  256. package/package.json +219 -0
  257. package/src/bench/BENCHMARK-RESULTS.md +211 -0
  258. package/src/bench/benchmark-results.json +148 -0
  259. package/src/bench/performance-comparison.ts +218 -0
  260. package/src/bench/precompilation-benchmark.ts +218 -0
  261. package/src/constants/SECURITY_CONSTANTS.ts +44 -0
  262. package/src/constants/VALIDATION_CONSTANTS.ts +176 -0
  263. package/src/core/README.md +395 -0
  264. package/src/core/compiler/SchemaTransformer.ts +279 -0
  265. package/src/core/compiler/TypeAnalyzer.ts +378 -0
  266. package/src/core/compiler/TypeScriptCompilerIntegration.ts +220 -0
  267. package/src/core/compiler/TypeToSchemaConverter.ts +288 -0
  268. package/src/core/index.ts +70 -0
  269. package/src/core/schema/extensions/AutoDocumentation.ts +572 -0
  270. package/src/core/schema/extensions/ConditionalValidation.ts +330 -0
  271. package/src/core/schema/extensions/README.md +171 -0
  272. package/src/core/schema/extensions/RealtimeValidation.ts +656 -0
  273. package/src/core/schema/extensions/SmartInference.ts +224 -0
  274. package/src/core/schema/extensions/components/AutoDocumentation/Docs.ts +98 -0
  275. package/src/core/schema/extensions/components/AutoDocumentation/DocumentationGenerator.ts +201 -0
  276. package/src/core/schema/extensions/components/AutoDocumentation/InteractiveDocumentationGenerator.ts +176 -0
  277. package/src/core/schema/extensions/components/AutoDocumentation/OpenAPIGenerator.ts +175 -0
  278. package/src/core/schema/extensions/components/AutoDocumentation/SchemaAnalyzer.ts +49 -0
  279. package/src/core/schema/extensions/components/AutoDocumentation/TypeScriptGenerator.ts +54 -0
  280. package/src/core/schema/extensions/components/AutoDocumentation/index.ts +17 -0
  281. package/src/core/schema/extensions/components/ConditionalValidation/ConditionalBuilder.ts +101 -0
  282. package/src/core/schema/extensions/components/ConditionalValidation/ConditionalElse.ts +65 -0
  283. package/src/core/schema/extensions/components/ConditionalValidation/ConditionalThen.ts +33 -0
  284. package/src/core/schema/extensions/components/ConditionalValidation/Extend.ts +75 -0
  285. package/src/core/schema/extensions/components/ConditionalValidation/MultiConditionalBuilder.ts +16 -0
  286. package/src/core/schema/extensions/components/ConditionalValidation/MultiConditionalThen.ts +50 -0
  287. package/src/core/schema/extensions/components/ConditionalValidation/index.ts +104 -0
  288. package/src/core/schema/extensions/components/RealtimeValidation/FormValidator.ts +88 -0
  289. package/src/core/schema/extensions/components/RealtimeValidation/LiveValidator.ts +171 -0
  290. package/src/core/schema/extensions/components/RealtimeValidation/StreamValidator.ts +397 -0
  291. package/src/core/schema/extensions/components/RealtimeValidation/index.ts +114 -0
  292. package/src/core/schema/extensions/index.ts +76 -0
  293. package/src/core/schema/extensions/mods/index.ts +131 -0
  294. package/src/core/schema/extensions/mods/openapi-converter.ts +338 -0
  295. package/src/core/schema/extensions/mods/typescript-generator.ts +379 -0
  296. package/src/core/schema/extensions/mods/validation-engine.ts +295 -0
  297. package/src/core/schema/mode/interfaces/Interface.ts +364 -0
  298. package/src/core/schema/mode/interfaces/InterfaceSchema.ts +1838 -0
  299. package/src/core/schema/mode/interfaces/README.md +278 -0
  300. package/src/core/schema/mode/interfaces/conditional/evaluator/ConditionalEvaluator.ts +657 -0
  301. package/src/core/schema/mode/interfaces/conditional/parser/ConditionalAST.ts +826 -0
  302. package/src/core/schema/mode/interfaces/conditional/parser/ConditionalLexer.ts +992 -0
  303. package/src/core/schema/mode/interfaces/conditional/parser/ConditionalParser.ts +803 -0
  304. package/src/core/schema/mode/interfaces/conditional/parser/readme.md +406 -0
  305. package/src/core/schema/mode/interfaces/conditional/types/ConditionalTypes.ts +273 -0
  306. package/src/core/schema/mode/interfaces/errors/ErrorHandler.ts +624 -0
  307. package/src/core/schema/mode/interfaces/errors/types/errors.type.ts +102 -0
  308. package/src/core/schema/mode/interfaces/precompilation/FieldPrecompilers.ts +962 -0
  309. package/src/core/schema/mode/interfaces/precompilation/SchemaPrecompiler.ts +667 -0
  310. package/src/core/schema/mode/interfaces/typescript/ConditionalTypes.ts +1534 -0
  311. package/src/core/schema/mode/interfaces/typescript/IDESupport.ts +534 -0
  312. package/src/core/schema/mode/interfaces/typescript/TypeInference.ts +737 -0
  313. package/src/core/schema/mode/interfaces/typescript/index.ts +92 -0
  314. package/src/core/schema/mode/interfaces/validators/ConstraintParser.ts +1438 -0
  315. package/src/core/schema/mode/interfaces/validators/EnhancedErrorReporting.ts +227 -0
  316. package/src/core/schema/mode/interfaces/validators/TypeGuards.ts +288 -0
  317. package/src/core/schema/mode/interfaces/validators/TypeValidators.ts +660 -0
  318. package/src/core/schema/mode/interfaces/validators/UnionCache.ts +508 -0
  319. package/src/core/schema/mode/interfaces/validators/ValidationHelpers.ts +1257 -0
  320. package/src/core/schema/mode/interfaces/validators/index.ts +21 -0
  321. package/src/core/schema/mode/interfaces/validators/mods/passValidator.ts +424 -0
  322. package/src/core/schema/mode/interfaces/validators/mods/securityValidator.ts +1634 -0
  323. package/src/core/schema/mode/interfaces/validators/mods/urlValidation.ts +333 -0
  324. package/src/core/schema/optimization/ObjectValidationCache.ts +560 -0
  325. package/src/core/schema/optimization/PerformanceInitializer.ts +188 -0
  326. package/src/core/schema/optimization/PerformanceMonitor.ts +898 -0
  327. package/src/core/schema/optimization/SchemaCompiler.ts +730 -0
  328. package/src/core/testing/TestDataGenerator.ts +590 -0
  329. package/src/core/types/SchemaValidator.type.ts +210 -0
  330. package/src/core/types/ValidatorTypes.ts +93 -0
  331. package/src/core/types/extension.type.ts +109 -0
  332. package/src/core/types/objValidationCache.ts +17 -0
  333. package/src/core/types/parser.type.ts +15 -0
  334. package/src/core/types/perfoMonitor.ts +37 -0
  335. package/src/core/types/scompiler.ts +22 -0
  336. package/src/core/types/securityValidator.type.ts +10 -0
  337. package/src/core/types/types.ts +154 -0
  338. package/src/core/utils/Make.ts +97 -0
  339. package/src/core/utils/Mod.ts +1168 -0
  340. package/src/core/utils/UrlArgs.ts +124 -0
  341. package/src/core/utils/arrayToEnum.ts +89 -0
  342. package/src/core/utils/createUrlArgsEnumFArray.ts +11 -0
  343. package/src/core/utils/securityHelpers.ts +341 -0
  344. package/src/core/utils/securityValidatorHelpers.ts +76 -0
  345. package/src/index.ts +124 -0
@@ -0,0 +1,660 @@
1
+ /**
2
+ * Type Validators Module
3
+ *
4
+ * Contains all basic type validation logic extracted from InterfaceSchema
5
+ * to improve maintainability and reduce file size.
6
+ */
7
+
8
+ import {
9
+ SchemaValidationResult,
10
+ ValidationError,
11
+ } from "../../../../types/types";
12
+ import { SchemaOptions } from "../Interface";
13
+ import { ErrorHandler } from "../errors/ErrorHandler";
14
+ import { ErrorCode } from "../errors/types/errors.type";
15
+ import { validatePassword } from "./mods/passValidator";
16
+ import { Security } from "./mods/securityValidator";
17
+ import { UrlValidation } from "./mods/urlValidation";
18
+
19
+ /**
20
+ * Validates basic types with enhanced constraints
21
+ */
22
+ export class TypeValidators {
23
+ // Private constants for validation patterns
24
+ private static readonly UUID_PATTERN =
25
+ /^[0-9a-f]{8}-[0-9a-f]{4}-[1-5][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i;
26
+ private static readonly PHONE_PATTERN = /^[1-9]\d{6,14}$/;
27
+ private static readonly SLUG_PATTERN = /^[a-z0-9]+(?:-[a-z0-9]+)*$/;
28
+ private static readonly USERNAME_PATTERN = /^[a-zA-Z0-9_-]{3,20}$/;
29
+
30
+ // Private constants for loose mode conversion
31
+ private static readonly TRUTHY_VALUES = ["true", "1", "yes", "on"];
32
+ private static readonly FALSY_VALUES = ["false", "0", "no", "off"];
33
+
34
+ // Private utility methods
35
+ private static createResult(
36
+ success: boolean = true,
37
+ data: any = null,
38
+ errors: ValidationError[] = [],
39
+ warnings: string[] = []
40
+ ): SchemaValidationResult {
41
+ return {
42
+ success,
43
+ errors: [...errors],
44
+ warnings: [...warnings],
45
+ data,
46
+ };
47
+ }
48
+
49
+ private static addError(
50
+ result: SchemaValidationResult,
51
+ message: ValidationError
52
+ ): void {
53
+ result.success = false;
54
+ result.errors.push(message);
55
+ }
56
+
57
+ private static addWarning(
58
+ result: SchemaValidationResult,
59
+ message: string
60
+ ): void {
61
+ result.warnings.push(message);
62
+ }
63
+
64
+ private static isValidNumber(value: any): boolean {
65
+ return typeof value === "number" && isFinite(value);
66
+ }
67
+
68
+ private static isValidInteger(value: any): boolean {
69
+ return this.isValidNumber(value) && value % 1 === 0;
70
+ }
71
+
72
+ private static tryParseNumber(value: string): number | null {
73
+ const num = parseFloat(value);
74
+ return isNaN(num) ? null : num;
75
+ }
76
+
77
+ private static tryParseInteger(value: string): number | null {
78
+ const num = parseInt(value, 10);
79
+ return isNaN(num) ? null : num;
80
+ }
81
+
82
+ private static validateNumberConstraints(
83
+ result: SchemaValidationResult,
84
+ value: number,
85
+ constraints: any,
86
+ typeLabel: string = "Number"
87
+ ): void {
88
+ if (constraints.min !== undefined && value < constraints.min) {
89
+ this.addError(
90
+ result,
91
+ ErrorHandler.createNumberError([], "minimum", value)
92
+ );
93
+ }
94
+
95
+ if (constraints.max !== undefined && value > constraints.max) {
96
+ this.addError(
97
+ result,
98
+ ErrorHandler.createNumberError([], "maximum", value)
99
+ );
100
+ }
101
+ }
102
+
103
+ private static handleLooseStringToNumber(
104
+ result: SchemaValidationResult,
105
+ value: string,
106
+ parser: (val: string) => number | null,
107
+ warningMessage: string
108
+ ): boolean {
109
+ const parsed = parser(value);
110
+ if (parsed !== null) {
111
+ result.data = parsed;
112
+ this.addWarning(result, warningMessage);
113
+ return true;
114
+ }
115
+ return false;
116
+ }
117
+
118
+ private static validateStringConstraints(
119
+ result: SchemaValidationResult,
120
+ value: string,
121
+ constraints: any
122
+ ): void {
123
+ if (
124
+ constraints.minLength !== undefined &&
125
+ value.length < constraints.minLength
126
+ ) {
127
+ this.addError(
128
+ result,
129
+ ErrorHandler.createStringError([], "minimumLength", value)
130
+ );
131
+ }
132
+
133
+ if (
134
+ constraints.maxLength !== undefined &&
135
+ value.length > constraints.maxLength
136
+ ) {
137
+ this.addError(
138
+ result,
139
+ ErrorHandler.createStringError([], "maximumLength", value)
140
+ );
141
+ }
142
+
143
+ if (constraints.pattern && !constraints.pattern.test(value)) {
144
+ this.addError(
145
+ result,
146
+ ErrorHandler.createStringError([], "pattern", value)
147
+ );
148
+ }
149
+ }
150
+
151
+ private static handleLooseBooleanConversion(
152
+ result: SchemaValidationResult,
153
+ value: any
154
+ ): boolean {
155
+ if (typeof value === "string") {
156
+ const lower = value.toLowerCase();
157
+ if (this.TRUTHY_VALUES.includes(lower)) {
158
+ result.data = true;
159
+ this.addWarning(result, "String converted to boolean (loose mode)");
160
+ return true;
161
+ } else if (this.FALSY_VALUES.includes(lower)) {
162
+ result.data = false;
163
+ this.addWarning(result, "String converted to boolean (loose mode)");
164
+ return true;
165
+ }
166
+ } else if (typeof value === "number") {
167
+ result.data = Boolean(value);
168
+ this.addWarning(result, "Number converted to boolean (loose mode)");
169
+ return true;
170
+ }
171
+ return false;
172
+ }
173
+
174
+ private static handleLooseDateConversion(
175
+ result: SchemaValidationResult,
176
+ value: any
177
+ ): boolean {
178
+ if (typeof value === "string") {
179
+ const parsedDate = new Date(value);
180
+ if (!isNaN(parsedDate.getTime())) {
181
+ result.data = parsedDate;
182
+ this.addWarning(result, "String converted to Date (loose mode)");
183
+ return true;
184
+ }
185
+ } else if (typeof value === "number") {
186
+ const parsedDate = new Date(value);
187
+ if (!isNaN(parsedDate.getTime())) {
188
+ result.data = parsedDate;
189
+ this.addWarning(result, "Number converted to Date (loose mode)");
190
+ return true;
191
+ }
192
+ }
193
+ return false;
194
+ }
195
+
196
+ private static validatePattern(
197
+ value: string,
198
+ pattern: RegExp,
199
+ typeName: string
200
+ ): SchemaValidationResult {
201
+ const result = this.createResult(true, value);
202
+
203
+ if (typeof value !== "string") {
204
+ this.addError(result, ErrorHandler.createTypeError([], "string", value));
205
+ } else if (!pattern.test(value)) {
206
+ this.addError(
207
+ result,
208
+ ErrorHandler.createValidationError(
209
+ [],
210
+ `Invalid ${typeName} format`,
211
+ value
212
+ )
213
+ // ErrorHandler.createTypeError([], typeName, value)
214
+ );
215
+ }
216
+
217
+ return result;
218
+ }
219
+
220
+ /**
221
+ * Validate required field (non-empty/non-zero)
222
+ */
223
+ private static validateRequired(
224
+ result: SchemaValidationResult,
225
+ value: any,
226
+ type: string
227
+ ): void {
228
+ let isEmpty = false;
229
+
230
+ switch (type) {
231
+ case "string":
232
+ isEmpty = value === "";
233
+ break;
234
+ case "number":
235
+ case "int":
236
+ case "integer":
237
+ case "float":
238
+ case "double":
239
+ case "positive":
240
+ case "negative":
241
+ isEmpty = value === 0;
242
+ break;
243
+ case "boolean":
244
+ isEmpty = false; // Booleans can't be "empty"
245
+ break;
246
+ default:
247
+ // For arrays, objects, etc.
248
+ if (Array.isArray(value)) {
249
+ isEmpty = value.length === 0;
250
+ } else if (value && typeof value === "object") {
251
+ isEmpty = Object.keys(value).length === 0;
252
+ } else {
253
+ isEmpty = value === null || value === undefined;
254
+ }
255
+ break;
256
+ }
257
+
258
+ if (isEmpty) {
259
+ this.addError(
260
+ result,
261
+ ErrorHandler.createValidationError(
262
+ [],
263
+ `Required field cannot be empty (expected non-empty ${type})`,
264
+ value
265
+ )
266
+ );
267
+ }
268
+ }
269
+
270
+ /**
271
+ * Validate string type with constraints
272
+ */
273
+ static validateString(
274
+ value: any,
275
+ options: SchemaOptions,
276
+ constraints: any,
277
+ required: boolean = false
278
+ ): SchemaValidationResult {
279
+ const result = this.createResult(true, value);
280
+
281
+ if (typeof value !== "string") {
282
+ this.addError(result, ErrorHandler.createTypeError([], "string", value));
283
+ return result;
284
+ }
285
+
286
+ // Check required validation (non-empty)
287
+ if (required) {
288
+ this.validateRequired(result, value, "string");
289
+ }
290
+
291
+ this.validateStringConstraints(result, value, constraints);
292
+ return result;
293
+ }
294
+
295
+ /**
296
+ * Validate number type with constraints
297
+ */
298
+ static validateNumber(
299
+ value: any,
300
+ options: SchemaOptions,
301
+ constraints: any,
302
+ required: boolean = false
303
+ ): SchemaValidationResult {
304
+ const result = this.createResult(true, value);
305
+
306
+ if (typeof value === "string" && options.loose) {
307
+ if (
308
+ !this.handleLooseStringToNumber(
309
+ result,
310
+ value,
311
+ this.tryParseNumber,
312
+ "String converted to number (loose mode)"
313
+ )
314
+ ) {
315
+ this.addError(
316
+ result,
317
+ ErrorHandler.createTypeError([], "number", value)
318
+ );
319
+ return result;
320
+ }
321
+ value = result.data;
322
+ } else if (!this.isValidNumber(value)) {
323
+ this.addError(result, ErrorHandler.createTypeError([], "number", value));
324
+ return result;
325
+ }
326
+
327
+ // CRITICAL FIX: Handle positive/negative validation for number types
328
+ if (constraints.type === "positive" && value <= 0) {
329
+ this.addError(
330
+ result,
331
+ ErrorHandler.createNumberError([], "positive", value)
332
+ );
333
+ } else if (constraints.type === "negative" && value >= 0) {
334
+ this.addError(
335
+ result,
336
+ ErrorHandler.createNumberError([], "negative", value)
337
+ );
338
+ }
339
+
340
+ // Check required validation (non-zero)
341
+ if (required) {
342
+ this.validateRequired(result, value, "number");
343
+ }
344
+
345
+ this.validateNumberConstraints(result, value, constraints);
346
+ return result;
347
+ }
348
+
349
+ /**
350
+ * Validate integer types (int, integer, positive, negative)
351
+ */
352
+ static validateInteger(
353
+ value: any,
354
+ options: SchemaOptions,
355
+ constraints: any,
356
+ type: "int" | "integer" | "positive" | "negative"
357
+ ): SchemaValidationResult {
358
+ const result = this.createResult(true, value);
359
+ console.log("test1");
360
+
361
+ if (typeof value === "string" && options.loose) {
362
+ console.log("test2");
363
+
364
+ if (
365
+ !this.handleLooseStringToNumber(
366
+ result,
367
+ value,
368
+ this.tryParseInteger,
369
+ "String converted to integer (loose mode)"
370
+ )
371
+ ) {
372
+ this.addError(
373
+ result,
374
+ ErrorHandler.createTypeError([], "integer", value)
375
+ );
376
+ return result;
377
+ }
378
+ value = result.data;
379
+ } else if (!this.isValidInteger(value)) {
380
+ this.addError(result, ErrorHandler.createTypeError([], "integer", value));
381
+ return result;
382
+ }
383
+
384
+ // Type-specific validation
385
+ if (type === "positive" && value <= 0) {
386
+ console.log("test");
387
+ this.addError(
388
+ result,
389
+ ErrorHandler.createNumberError([], "positive", value)
390
+ );
391
+ } else if (type === "negative" && value >= 0) {
392
+ this.addError(
393
+ result,
394
+ ErrorHandler.createNumberError([], "negative", value)
395
+ );
396
+ }
397
+
398
+ this.validateNumberConstraints(result, value, constraints, "Integer");
399
+ return result;
400
+ }
401
+
402
+ /**
403
+ * Validate float types (float, double)
404
+ */
405
+ static validateFloat(
406
+ value: any,
407
+ options: SchemaOptions,
408
+ constraints: any,
409
+ type: "float" | "double"
410
+ ): SchemaValidationResult {
411
+ const result = this.createResult(true, value);
412
+
413
+ if (typeof value === "string" && options.loose) {
414
+ if (
415
+ !this.handleLooseStringToNumber(
416
+ result,
417
+ value,
418
+ this.tryParseNumber,
419
+ "String converted to float (loose mode)"
420
+ )
421
+ ) {
422
+ this.addError(result, ErrorHandler.createTypeError([], "float", value));
423
+ return result;
424
+ }
425
+ value = result.data;
426
+ } else if (!this.isValidNumber(value)) {
427
+ this.addError(result, ErrorHandler.createTypeError([], "float", value));
428
+ return result;
429
+ }
430
+
431
+ this.validateNumberConstraints(result, value, constraints, "Float");
432
+ return result;
433
+ }
434
+
435
+ /**
436
+ * Validate boolean types (boolean, bool)
437
+ */
438
+ static validateBoolean(
439
+ value: any,
440
+ options: SchemaOptions,
441
+ constraints: any
442
+ ): SchemaValidationResult {
443
+ const result = this.createResult(true, value);
444
+
445
+ if (typeof value === "boolean") {
446
+ result.data = value;
447
+ } else if (options.loose) {
448
+ if (!this.handleLooseBooleanConversion(result, value)) {
449
+ this.addError(
450
+ result,
451
+ ErrorHandler.createTypeError([], "boolean", value)
452
+ );
453
+ }
454
+ } else {
455
+ this.addError(result, ErrorHandler.createTypeError([], "boolean", value));
456
+ }
457
+
458
+ return result;
459
+ }
460
+
461
+ /**
462
+ * Validate date types (date, datetime, timestamp)
463
+ */
464
+ static validateDate(
465
+ value: any,
466
+ options: SchemaOptions,
467
+ constraints: any,
468
+ type: "date" | "datetime" | "timestamp"
469
+ ): SchemaValidationResult {
470
+ const result = this.createResult(true, value);
471
+
472
+ if (value instanceof Date) {
473
+ if (isNaN(value.getTime())) {
474
+ this.addError(result, ErrorHandler.createDateError([], value));
475
+ }
476
+ } else if (typeof value === "string" || typeof value === "number") {
477
+ // Accept date strings and timestamps even in strict mode
478
+ // This is reasonable since they represent valid date values
479
+ const dateValue = new Date(value);
480
+ if (isNaN(dateValue.getTime())) {
481
+ this.addError(
482
+ result,
483
+ ErrorHandler.createError(
484
+ [],
485
+ typeof value === "string"
486
+ ? "Invalid date string"
487
+ : "Invalid timestamp",
488
+ ErrorCode.INVALID_DATE,
489
+ "date",
490
+ value
491
+ )
492
+ );
493
+ } else {
494
+ result.data = dateValue;
495
+ if (!options.loose) {
496
+ // Add a warning in strict mode to indicate conversion
497
+ result.warnings = result.warnings || [];
498
+ result.warnings.push("Date string converted to Date object");
499
+ }
500
+ }
501
+ } else {
502
+ this.addError(result, ErrorHandler.createTypeError([], "date", value));
503
+ }
504
+
505
+ return result;
506
+ }
507
+
508
+ /**
509
+ * Validate email format with comprehensive RFC 5322 compliance and plus addressing support
510
+ */
511
+ static validateEmail(
512
+ ...args: Parameters<typeof Security.validateEmail>
513
+ ): SchemaValidationResult {
514
+ return Security.validateEmail(...args);
515
+ }
516
+
517
+ /**
518
+ * URL validation with comprehensive checks
519
+ */
520
+ static validateUrl(
521
+ ...args: Parameters<typeof UrlValidation>
522
+ ): SchemaValidationResult {
523
+ return UrlValidation(...args);
524
+ }
525
+
526
+ /**
527
+ * Validate UUID/GUID format
528
+ */
529
+ static validateUuid(
530
+ value: any,
531
+ type: "uuid" | "guid" = "uuid"
532
+ ): SchemaValidationResult {
533
+ return this.validatePattern(value, this.UUID_PATTERN, type.toUpperCase());
534
+ }
535
+
536
+ /**
537
+ * Validate phone format
538
+ */
539
+ static validatePhone(value: any): SchemaValidationResult {
540
+ const result = this.createResult(true, value);
541
+
542
+ if (typeof value !== "string") {
543
+ this.addError(result, ErrorHandler.createTypeError([], "phone", value));
544
+ } else {
545
+ const cleanPhone = value.replace(/[\s\-\(\)\.+]/g, "");
546
+ if (!this.PHONE_PATTERN.test(cleanPhone)) {
547
+ this.addError(result, ErrorHandler.createTypeError([], "phone", value));
548
+ }
549
+ }
550
+
551
+ return result;
552
+ }
553
+
554
+ /**
555
+ * Validate slug format
556
+ */
557
+ static validateSlug(value: any): SchemaValidationResult {
558
+ return this.validatePattern(
559
+ value,
560
+ this.SLUG_PATTERN,
561
+ "slug (use lowercase letters, numbers, and hyphens)"
562
+ );
563
+ }
564
+
565
+ /**
566
+ * Validate username format
567
+ */
568
+ static validateUsername(value: any): SchemaValidationResult {
569
+ return this.validatePattern(
570
+ value,
571
+ this.USERNAME_PATTERN,
572
+ "username (3-20 chars, letters, numbers, underscore, hyphen)"
573
+ );
574
+ }
575
+
576
+ /**
577
+ * Validate password format
578
+ */
579
+ static validatePassword(
580
+ ...args: Parameters<typeof validatePassword>
581
+ ): SchemaValidationResult {
582
+ return validatePassword(...args);
583
+ }
584
+
585
+ /**
586
+ * Validate text format (alias for string)
587
+ */
588
+ static validateText(
589
+ ...args: Parameters<typeof Security.validateText>
590
+ ): SchemaValidationResult {
591
+ return Security.validateTextSync(...args);
592
+ }
593
+
594
+ /**
595
+ * Validate JSON format with optional security mode
596
+ */
597
+ static validateJson(
598
+ value: any,
599
+ options?: { securityMode?: "fast" | "secure" }
600
+ ): SchemaValidationResult {
601
+ return Security.validateJsonSync(value, options);
602
+ }
603
+
604
+ /**
605
+ * Validate IP address format (IPv4 and IPv6)
606
+ */
607
+ static validateIp(value: any): SchemaValidationResult {
608
+ return Security.validateIp(value);
609
+ }
610
+
611
+ /**
612
+ * Validate object type
613
+ */
614
+ static validateObject(value: any): SchemaValidationResult {
615
+ return Security.validateObject(value);
616
+ }
617
+
618
+ /**
619
+ * Validate special types (unknown, void, null, undefined, any)
620
+ */
621
+ static validateSpecialType(
622
+ value: any,
623
+ type: "unknown" | "void" | "null" | "undefined" | "any"
624
+ ): SchemaValidationResult {
625
+ const result = this.createResult(true, value);
626
+
627
+ switch (type) {
628
+ case "unknown":
629
+ case "any":
630
+ // Accept any value
631
+ break;
632
+ case "void":
633
+ if (value !== undefined) {
634
+ this.addError(
635
+ result,
636
+ ErrorHandler.createTypeError([], "void", value)
637
+ );
638
+ }
639
+ break;
640
+ case "null":
641
+ if (value !== null) {
642
+ this.addError(
643
+ result,
644
+ ErrorHandler.createTypeError([], "null", value)
645
+ );
646
+ }
647
+ break;
648
+ case "undefined":
649
+ if (value !== undefined) {
650
+ this.addError(
651
+ result,
652
+ ErrorHandler.createTypeError([], "undefined", value)
653
+ );
654
+ }
655
+ break;
656
+ }
657
+
658
+ return result;
659
+ }
660
+ }