typia 9.3.0-dev.20250511 → 9.3.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 (521) hide show
  1. package/LICENSE +21 -21
  2. package/README.md +149 -149
  3. package/lib/executable/setup/PluginConfigurator.js +3 -3
  4. package/lib/executable/setup/PluginConfigurator.mjs +3 -3
  5. package/lib/executable/typia.js +15 -15
  6. package/lib/executable/typia.mjs +15 -15
  7. package/lib/llm.d.mts +179 -31
  8. package/lib/llm.d.ts +179 -31
  9. package/lib/llm.js.map +1 -1
  10. package/lib/schemas/json/IJsonApplication.d.mts +5 -1
  11. package/lib/schemas/json/IJsonApplication.d.ts +5 -1
  12. package/lib/schemas/json/IJsonApplication.js.map +1 -1
  13. package/lib/transformers/features/llm/LlmControllerTransformer.js +3 -3
  14. package/lib/transformers/features/llm/LlmControllerTransformer.js.map +1 -1
  15. package/lib/transformers/features/llm/LlmControllerTransformer.mjs +3 -3
  16. package/package.json +3 -3
  17. package/src/AssertionGuard.ts +1 -1
  18. package/src/CamelCase.ts +75 -75
  19. package/src/IRandomGenerator.ts +49 -49
  20. package/src/IReadableURLSearchParams.ts +9 -9
  21. package/src/IValidation.ts +1 -1
  22. package/src/PascalCase.ts +71 -71
  23. package/src/Primitive.ts +92 -92
  24. package/src/Resolved.ts +74 -74
  25. package/src/SnakeCase.ts +126 -126
  26. package/src/TypeGuardError.ts +37 -37
  27. package/src/executable/TypiaGenerateWizard.ts +83 -83
  28. package/src/executable/TypiaPatchWizard.ts +45 -45
  29. package/src/executable/TypiaSetupWizard.ts +171 -171
  30. package/src/executable/setup/ArgumentParser.ts +42 -42
  31. package/src/executable/setup/CommandExecutor.ts +8 -8
  32. package/src/executable/setup/FileRetriever.ts +19 -19
  33. package/src/executable/setup/PackageManager.ts +87 -87
  34. package/src/executable/setup/PluginConfigurator.ts +69 -69
  35. package/src/executable/typia.ts +55 -55
  36. package/src/factories/CommentFactory.ts +79 -79
  37. package/src/factories/ExpressionFactory.ts +219 -219
  38. package/src/factories/IdentifierFactory.ts +89 -89
  39. package/src/factories/JsonMetadataFactory.ts +83 -83
  40. package/src/factories/LiteralFactory.ts +52 -52
  41. package/src/factories/MetadataCollection.ts +278 -278
  42. package/src/factories/MetadataCommentTagFactory.ts +648 -648
  43. package/src/factories/MetadataFactory.ts +404 -404
  44. package/src/factories/MetadataTypeTagFactory.ts +413 -413
  45. package/src/factories/MetadataTypeTagSchemaFactory.ts +82 -82
  46. package/src/factories/NumericRangeFactory.ts +72 -72
  47. package/src/factories/ProtobufFactory.ts +875 -875
  48. package/src/factories/StatementFactory.ts +90 -90
  49. package/src/factories/TemplateFactory.ts +64 -64
  50. package/src/factories/TypeFactory.ts +140 -140
  51. package/src/factories/ValueFactory.ts +12 -12
  52. package/src/factories/internal/metadata/IMetadataIteratorProps.ts +17 -17
  53. package/src/factories/internal/metadata/MetadataHelper.ts +21 -21
  54. package/src/factories/internal/metadata/emend_metadata_atomics.ts +45 -45
  55. package/src/factories/internal/metadata/emplace_metadata_alias.ts +33 -33
  56. package/src/factories/internal/metadata/emplace_metadata_array_type.ts +39 -39
  57. package/src/factories/internal/metadata/emplace_metadata_object.ts +212 -212
  58. package/src/factories/internal/metadata/emplace_metadata_tuple.ts +57 -57
  59. package/src/factories/internal/metadata/explore_metadata.ts +31 -31
  60. package/src/factories/internal/metadata/iterate_metadata.ts +54 -54
  61. package/src/factories/internal/metadata/iterate_metadata_alias.ts +33 -33
  62. package/src/factories/internal/metadata/iterate_metadata_array.ts +63 -63
  63. package/src/factories/internal/metadata/iterate_metadata_atomic.ts +62 -62
  64. package/src/factories/internal/metadata/iterate_metadata_coalesce.ts +28 -28
  65. package/src/factories/internal/metadata/iterate_metadata_collection.ts +146 -146
  66. package/src/factories/internal/metadata/iterate_metadata_comment_tags.ts +32 -32
  67. package/src/factories/internal/metadata/iterate_metadata_constant.ts +76 -76
  68. package/src/factories/internal/metadata/iterate_metadata_escape.ts +49 -49
  69. package/src/factories/internal/metadata/iterate_metadata_function.ts +91 -91
  70. package/src/factories/internal/metadata/iterate_metadata_intersection.ts +212 -212
  71. package/src/factories/internal/metadata/iterate_metadata_map.ts +57 -57
  72. package/src/factories/internal/metadata/iterate_metadata_native.ts +264 -264
  73. package/src/factories/internal/metadata/iterate_metadata_object.ts +35 -35
  74. package/src/factories/internal/metadata/iterate_metadata_set.ts +57 -57
  75. package/src/factories/internal/metadata/iterate_metadata_sort.ts +87 -87
  76. package/src/factories/internal/metadata/iterate_metadata_template.ts +41 -41
  77. package/src/factories/internal/metadata/iterate_metadata_tuple.ts +26 -26
  78. package/src/factories/internal/metadata/iterate_metadata_union.ts +19 -19
  79. package/src/functional.ts +740 -740
  80. package/src/http.ts +1040 -1040
  81. package/src/index.ts +4 -4
  82. package/src/internal/_IProtobufWriter.ts +18 -18
  83. package/src/internal/_ProtobufReader.ts +194 -194
  84. package/src/internal/_ProtobufSizer.ts +145 -145
  85. package/src/internal/_ProtobufWriter.ts +145 -145
  86. package/src/internal/_accessExpressionAsString.ts +46 -46
  87. package/src/internal/_assertGuard.ts +13 -13
  88. package/src/internal/_createStandardSchema.ts +134 -134
  89. package/src/internal/_functionalTypeGuardErrorFactory.ts +4 -4
  90. package/src/internal/_httpFormDataReadArray.ts +4 -4
  91. package/src/internal/_httpFormDataReadBigint.ts +18 -18
  92. package/src/internal/_httpFormDataReadBlob.ts +10 -10
  93. package/src/internal/_httpFormDataReadBoolean.ts +16 -16
  94. package/src/internal/_httpFormDataReadFile.ts +10 -10
  95. package/src/internal/_httpFormDataReadNumber.ts +15 -15
  96. package/src/internal/_httpFormDataReadString.ts +10 -10
  97. package/src/internal/_httpHeaderReadBigint.ts +10 -10
  98. package/src/internal/_httpHeaderReadBoolean.ts +8 -8
  99. package/src/internal/_httpHeaderReadNumber.ts +7 -7
  100. package/src/internal/_httpParameterReadBigint.ts +10 -10
  101. package/src/internal/_httpParameterReadBoolean.ts +8 -8
  102. package/src/internal/_httpParameterReadNumber.ts +7 -7
  103. package/src/internal/_httpParameterReadString.ts +2 -2
  104. package/src/internal/_httpQueryParseURLSearchParams.ts +12 -12
  105. package/src/internal/_httpQueryReadArray.ts +4 -4
  106. package/src/internal/_httpQueryReadBigint.ts +12 -12
  107. package/src/internal/_httpQueryReadBoolean.ts +14 -14
  108. package/src/internal/_httpQueryReadNumber.ts +9 -9
  109. package/src/internal/_httpQueryReadString.ts +4 -4
  110. package/src/internal/_isBetween.ts +2 -2
  111. package/src/internal/_isBigintString.ts +8 -8
  112. package/src/internal/_isFormatByte.ts +7 -7
  113. package/src/internal/_isFormatDate.ts +3 -3
  114. package/src/internal/_isFormatDateTime.ts +4 -4
  115. package/src/internal/_isFormatDuration.ts +4 -4
  116. package/src/internal/_isFormatEmail.ts +4 -4
  117. package/src/internal/_isFormatHostname.ts +4 -4
  118. package/src/internal/_isFormatIdnEmail.ts +4 -4
  119. package/src/internal/_isFormatIdnHostname.ts +4 -4
  120. package/src/internal/_isFormatIpv4.ts +4 -4
  121. package/src/internal/_isFormatIpv6.ts +4 -4
  122. package/src/internal/_isFormatIri.ts +3 -3
  123. package/src/internal/_isFormatIriReference.ts +4 -4
  124. package/src/internal/_isFormatJsonPointer.ts +3 -3
  125. package/src/internal/_isFormatPassword.ts +1 -1
  126. package/src/internal/_isFormatRegex.ts +8 -8
  127. package/src/internal/_isFormatRelativeJsonPointer.ts +4 -4
  128. package/src/internal/_isFormatTime.ts +4 -4
  129. package/src/internal/_isFormatUri.ts +6 -6
  130. package/src/internal/_isFormatUriReference.ts +5 -5
  131. package/src/internal/_isFormatUriTemplate.ts +4 -4
  132. package/src/internal/_isFormatUrl.ts +4 -4
  133. package/src/internal/_isFormatUuid.ts +3 -3
  134. package/src/internal/_isTypeFloat.ts +5 -5
  135. package/src/internal/_isTypeInt32.ts +5 -5
  136. package/src/internal/_isTypeInt64.ts +5 -5
  137. package/src/internal/_isTypeUint32.ts +5 -5
  138. package/src/internal/_isTypeUint64.ts +5 -5
  139. package/src/internal/_isUniqueItems.ts +159 -159
  140. package/src/internal/_jsonStringifyNumber.ts +12 -12
  141. package/src/internal/_jsonStringifyRest.ts +3 -3
  142. package/src/internal/_jsonStringifyString.ts +42 -42
  143. package/src/internal/_jsonStringifyTail.ts +2 -2
  144. package/src/internal/_llmApplicationFinalize.ts +20 -20
  145. package/src/internal/_miscCloneAny.ts +46 -46
  146. package/src/internal/_notationAny.ts +37 -37
  147. package/src/internal/_notationCamel.ts +13 -13
  148. package/src/internal/_notationPascal.ts +8 -8
  149. package/src/internal/_notationSnake.ts +43 -43
  150. package/src/internal/_randomArray.ts +21 -21
  151. package/src/internal/_randomBigint.ts +6 -6
  152. package/src/internal/_randomBoolean.ts +1 -1
  153. package/src/internal/_randomFormatByte.ts +3 -3
  154. package/src/internal/_randomFormatDate.ts +18 -18
  155. package/src/internal/_randomFormatDatetime.ts +16 -16
  156. package/src/internal/_randomFormatDuration.ts +27 -27
  157. package/src/internal/_randomFormatEmail.ts +11 -11
  158. package/src/internal/_randomFormatHostname.ts +6 -6
  159. package/src/internal/_randomFormatIdnEmail.ts +3 -3
  160. package/src/internal/_randomFormatIdnHostname.ts +3 -3
  161. package/src/internal/_randomFormatIpv4.ts +11 -11
  162. package/src/internal/_randomFormatIpv6.ts +11 -11
  163. package/src/internal/_randomFormatIri.ts +3 -3
  164. package/src/internal/_randomFormatIriReference.ts +3 -3
  165. package/src/internal/_randomFormatJsonPointer.ts +7 -7
  166. package/src/internal/_randomFormatPassword.ts +8 -8
  167. package/src/internal/_randomFormatRegex.ts +4 -4
  168. package/src/internal/_randomFormatRelativeJsonPointer.ts +8 -8
  169. package/src/internal/_randomFormatTime.ts +14 -14
  170. package/src/internal/_randomFormatUri.ts +3 -3
  171. package/src/internal/_randomFormatUriReference.ts +3 -3
  172. package/src/internal/_randomFormatUriTemplate.ts +3 -3
  173. package/src/internal/_randomFormatUrl.ts +11 -11
  174. package/src/internal/_randomFormatUuid.ts +6 -6
  175. package/src/internal/_randomInteger.ts +53 -53
  176. package/src/internal/_randomNumber.ts +80 -80
  177. package/src/internal/_randomPattern.ts +10 -10
  178. package/src/internal/_randomPick.ts +9 -9
  179. package/src/internal/_randomString.ts +24 -24
  180. package/src/internal/_throwTypeGuardError.ts +5 -5
  181. package/src/internal/_validateReport.ts +13 -13
  182. package/src/internal/private/__notationCapitalize.ts +2 -2
  183. package/src/internal/private/__notationUnsnake.ts +24 -24
  184. package/src/json.ts +696 -696
  185. package/src/llm.ts +506 -358
  186. package/src/misc.ts +651 -651
  187. package/src/module.ts +936 -936
  188. package/src/notations.ts +820 -820
  189. package/src/programmers/AssertProgrammer.ts +454 -454
  190. package/src/programmers/CheckerProgrammer.ts +1617 -1617
  191. package/src/programmers/FeatureProgrammer.ts +627 -627
  192. package/src/programmers/ImportProgrammer.ts +185 -185
  193. package/src/programmers/IsProgrammer.ts +273 -273
  194. package/src/programmers/RandomProgrammer.ts +1190 -1190
  195. package/src/programmers/TypiaProgrammer.ts +175 -175
  196. package/src/programmers/ValidateProgrammer.ts +448 -448
  197. package/src/programmers/functional/FunctionalAssertFunctionProgrammer.ts +153 -153
  198. package/src/programmers/functional/FunctionalAssertParametersProgrammer.ts +125 -125
  199. package/src/programmers/functional/FunctionalAssertReturnProgrammer.ts +115 -115
  200. package/src/programmers/functional/FunctionalIsFunctionProgrammer.ts +72 -72
  201. package/src/programmers/functional/FunctionalIsParametersProgrammer.ts +113 -113
  202. package/src/programmers/functional/FunctionalIsReturnProgrammer.ts +116 -116
  203. package/src/programmers/functional/FunctionalValidateFunctionProgrammer.ts +119 -119
  204. package/src/programmers/functional/FunctionalValidateParametersProgrammer.ts +274 -274
  205. package/src/programmers/functional/FunctionalValidateReturnProgrammer.ts +135 -135
  206. package/src/programmers/functional/internal/FunctionalGeneralProgrammer.ts +34 -34
  207. package/src/programmers/helpers/AtomicPredicator.ts +35 -35
  208. package/src/programmers/helpers/CloneJoiner.ts +143 -143
  209. package/src/programmers/helpers/FunctionProgrammer.ts +67 -67
  210. package/src/programmers/helpers/HttpMetadataUtil.ts +21 -21
  211. package/src/programmers/helpers/ICheckEntry.ts +13 -13
  212. package/src/programmers/helpers/IExpressionEntry.ts +12 -12
  213. package/src/programmers/helpers/NotationJoiner.ts +144 -144
  214. package/src/programmers/helpers/OptionPredicator.ts +15 -15
  215. package/src/programmers/helpers/ProtobufUtil.ts +228 -228
  216. package/src/programmers/helpers/ProtobufWire.ts +34 -34
  217. package/src/programmers/helpers/PruneJoiner.ts +148 -148
  218. package/src/programmers/helpers/RandomJoiner.ts +168 -168
  219. package/src/programmers/helpers/StringifyJoinder.ts +115 -115
  220. package/src/programmers/helpers/StringifyPredicator.ts +13 -13
  221. package/src/programmers/helpers/UnionExplorer.ts +372 -372
  222. package/src/programmers/helpers/UnionPredicator.ts +79 -79
  223. package/src/programmers/helpers/disable_function_programmer_declare.ts +32 -32
  224. package/src/programmers/http/HttpAssertFormDataProgrammer.ts +99 -99
  225. package/src/programmers/http/HttpAssertHeadersProgrammer.ts +99 -99
  226. package/src/programmers/http/HttpAssertQueryProgrammer.ts +105 -105
  227. package/src/programmers/http/HttpFormDataProgrammer.ts +308 -308
  228. package/src/programmers/http/HttpHeadersProgrammer.ts +400 -400
  229. package/src/programmers/http/HttpIsFormDataProgrammer.ts +108 -108
  230. package/src/programmers/http/HttpIsHeadersProgrammer.ts +108 -108
  231. package/src/programmers/http/HttpIsQueryProgrammer.ts +114 -114
  232. package/src/programmers/http/HttpParameterProgrammer.ts +115 -115
  233. package/src/programmers/http/HttpQueryProgrammer.ts +336 -336
  234. package/src/programmers/http/HttpValidateFormDataProgrammer.ts +92 -92
  235. package/src/programmers/http/HttpValidateHeadersProgrammer.ts +92 -92
  236. package/src/programmers/http/HttpValidateQueryProgrammer.ts +98 -98
  237. package/src/programmers/internal/check_array_length.ts +47 -47
  238. package/src/programmers/internal/check_bigint.ts +50 -50
  239. package/src/programmers/internal/check_dynamic_key.ts +201 -201
  240. package/src/programmers/internal/check_dynamic_properties.ts +208 -208
  241. package/src/programmers/internal/check_everything.ts +23 -23
  242. package/src/programmers/internal/check_native.ts +27 -27
  243. package/src/programmers/internal/check_number.ts +112 -112
  244. package/src/programmers/internal/check_object.ts +75 -75
  245. package/src/programmers/internal/check_string.ts +50 -50
  246. package/src/programmers/internal/check_template.ts +48 -48
  247. package/src/programmers/internal/check_union_array_like.ts +335 -335
  248. package/src/programmers/internal/decode_union_object.ts +116 -116
  249. package/src/programmers/internal/feature_object_entries.ts +61 -61
  250. package/src/programmers/internal/json_schema_alias.ts +47 -47
  251. package/src/programmers/internal/json_schema_array.ts +45 -45
  252. package/src/programmers/internal/json_schema_bigint.ts +15 -15
  253. package/src/programmers/internal/json_schema_boolean.ts +15 -15
  254. package/src/programmers/internal/json_schema_constant.ts +26 -26
  255. package/src/programmers/internal/json_schema_description.ts +12 -12
  256. package/src/programmers/internal/json_schema_discriminator.ts +35 -35
  257. package/src/programmers/internal/json_schema_escaped.ts +82 -82
  258. package/src/programmers/internal/json_schema_native.ts +33 -33
  259. package/src/programmers/internal/json_schema_number.ts +15 -15
  260. package/src/programmers/internal/json_schema_object.ts +158 -158
  261. package/src/programmers/internal/json_schema_plugin.ts +18 -18
  262. package/src/programmers/internal/json_schema_station.ts +185 -185
  263. package/src/programmers/internal/json_schema_string.ts +15 -15
  264. package/src/programmers/internal/json_schema_template.ts +55 -55
  265. package/src/programmers/internal/json_schema_title.ts +20 -20
  266. package/src/programmers/internal/json_schema_tuple.ts +35 -35
  267. package/src/programmers/internal/metadata_to_pattern.ts +42 -42
  268. package/src/programmers/internal/postfix_of_tuple.ts +5 -5
  269. package/src/programmers/internal/prune_object_properties.ts +71 -71
  270. package/src/programmers/internal/stringify_dynamic_properties.ts +162 -162
  271. package/src/programmers/internal/stringify_native.ts +7 -7
  272. package/src/programmers/internal/stringify_regular_properties.ts +81 -81
  273. package/src/programmers/internal/template_to_pattern.ts +23 -23
  274. package/src/programmers/internal/wrap_metadata_rest_tuple.ts +23 -23
  275. package/src/programmers/json/JsonApplicationProgrammer.ts +266 -266
  276. package/src/programmers/json/JsonAssertParseProgrammer.ts +113 -113
  277. package/src/programmers/json/JsonAssertStringifyProgrammer.ts +115 -115
  278. package/src/programmers/json/JsonIsParseProgrammer.ts +114 -114
  279. package/src/programmers/json/JsonIsStringifyProgrammer.ts +108 -108
  280. package/src/programmers/json/JsonSchemaProgrammer.ts +26 -26
  281. package/src/programmers/json/JsonSchemasProgrammer.ts +91 -91
  282. package/src/programmers/json/JsonStringifyProgrammer.ts +1124 -1124
  283. package/src/programmers/json/JsonValidateParseProgrammer.ts +105 -105
  284. package/src/programmers/json/JsonValidateStringifyProgrammer.ts +124 -124
  285. package/src/programmers/llm/LlmApplicationProgrammer.ts +401 -401
  286. package/src/programmers/llm/LlmModelPredicator.ts +127 -127
  287. package/src/programmers/llm/LlmParametersProgrammer.ts +93 -93
  288. package/src/programmers/llm/LlmSchemaProgrammer.ts +192 -192
  289. package/src/programmers/misc/MiscAssertCloneProgrammer.ts +95 -95
  290. package/src/programmers/misc/MiscAssertPruneProgrammer.ts +116 -116
  291. package/src/programmers/misc/MiscCloneProgrammer.ts +1032 -1032
  292. package/src/programmers/misc/MiscIsCloneProgrammer.ts +99 -99
  293. package/src/programmers/misc/MiscIsPruneProgrammer.ts +97 -97
  294. package/src/programmers/misc/MiscLiteralsProgrammer.ts +80 -80
  295. package/src/programmers/misc/MiscPruneProgrammer.ts +728 -728
  296. package/src/programmers/misc/MiscValidateCloneProgrammer.ts +111 -111
  297. package/src/programmers/misc/MiscValidatePruneProgrammer.ts +113 -113
  298. package/src/programmers/notations/NotationAssertGeneralProgrammer.ts +101 -101
  299. package/src/programmers/notations/NotationGeneralProgrammer.ts +984 -984
  300. package/src/programmers/notations/NotationIsGeneralProgrammer.ts +105 -105
  301. package/src/programmers/notations/NotationValidateGeneralProgrammer.ts +119 -119
  302. package/src/programmers/protobuf/ProtobufAssertDecodeProgrammer.ts +98 -98
  303. package/src/programmers/protobuf/ProtobufAssertEncodeProgrammer.ts +102 -102
  304. package/src/programmers/protobuf/ProtobufDecodeProgrammer.ts +654 -654
  305. package/src/programmers/protobuf/ProtobufEncodeProgrammer.ts +945 -945
  306. package/src/programmers/protobuf/ProtobufIsDecodeProgrammer.ts +109 -109
  307. package/src/programmers/protobuf/ProtobufIsEncodeProgrammer.ts +98 -98
  308. package/src/programmers/protobuf/ProtobufMessageProgrammer.ts +179 -179
  309. package/src/programmers/protobuf/ProtobufValidateDecodeProgrammer.ts +92 -92
  310. package/src/programmers/protobuf/ProtobufValidateEncodeProgrammer.ts +119 -119
  311. package/src/protobuf.ts +861 -861
  312. package/src/reflect.ts +50 -50
  313. package/src/schemas/json/IJsonApplication.ts +77 -73
  314. package/src/schemas/json/IJsonSchemaCollection.ts +29 -29
  315. package/src/schemas/json/IJsonSchemaUnit.ts +32 -32
  316. package/src/schemas/json/__IJsonApplication.ts +63 -63
  317. package/src/schemas/metadata/IJsDocTagInfo.ts +10 -10
  318. package/src/schemas/metadata/IMetadata.ts +35 -35
  319. package/src/schemas/metadata/IMetadataAlias.ts +6 -6
  320. package/src/schemas/metadata/IMetadataAliasType.ts +12 -12
  321. package/src/schemas/metadata/IMetadataApplication.ts +7 -7
  322. package/src/schemas/metadata/IMetadataArray.ts +6 -6
  323. package/src/schemas/metadata/IMetadataArrayType.ts +10 -10
  324. package/src/schemas/metadata/IMetadataAtomic.ts +6 -6
  325. package/src/schemas/metadata/IMetadataComponents.ts +11 -11
  326. package/src/schemas/metadata/IMetadataConstant.ts +18 -18
  327. package/src/schemas/metadata/IMetadataConstantValue.ts +11 -11
  328. package/src/schemas/metadata/IMetadataDictionary.ts +11 -11
  329. package/src/schemas/metadata/IMetadataEscaped.ts +6 -6
  330. package/src/schemas/metadata/IMetadataFunction.ts +8 -8
  331. package/src/schemas/metadata/IMetadataMap.ts +8 -8
  332. package/src/schemas/metadata/IMetadataNative.ts +6 -6
  333. package/src/schemas/metadata/IMetadataObject.ts +6 -6
  334. package/src/schemas/metadata/IMetadataObjectType.ts +13 -13
  335. package/src/schemas/metadata/IMetadataParameter.ts +9 -9
  336. package/src/schemas/metadata/IMetadataProperty.ts +9 -9
  337. package/src/schemas/metadata/IMetadataSet.ts +7 -7
  338. package/src/schemas/metadata/IMetadataTemplate.ts +7 -7
  339. package/src/schemas/metadata/IMetadataTuple.ts +6 -6
  340. package/src/schemas/metadata/IMetadataTupleType.ts +10 -10
  341. package/src/schemas/metadata/IMetadataTypeTag.ts +16 -16
  342. package/src/schemas/metadata/Metadata.ts +687 -687
  343. package/src/schemas/metadata/MetadataAlias.ts +46 -46
  344. package/src/schemas/metadata/MetadataAliasType.ts +63 -63
  345. package/src/schemas/metadata/MetadataApplication.ts +44 -44
  346. package/src/schemas/metadata/MetadataArray.ts +49 -49
  347. package/src/schemas/metadata/MetadataArrayType.ts +57 -57
  348. package/src/schemas/metadata/MetadataAtomic.ts +87 -87
  349. package/src/schemas/metadata/MetadataComponents.ts +98 -98
  350. package/src/schemas/metadata/MetadataConstant.ts +34 -34
  351. package/src/schemas/metadata/MetadataConstantValue.ts +62 -62
  352. package/src/schemas/metadata/MetadataEscaped.ts +51 -51
  353. package/src/schemas/metadata/MetadataFunction.ts +49 -49
  354. package/src/schemas/metadata/MetadataMap.ts +48 -48
  355. package/src/schemas/metadata/MetadataNative.ts +44 -44
  356. package/src/schemas/metadata/MetadataObject.ts +48 -48
  357. package/src/schemas/metadata/MetadataObjectType.ts +149 -149
  358. package/src/schemas/metadata/MetadataParameter.ts +54 -54
  359. package/src/schemas/metadata/MetadataProperty.ts +59 -59
  360. package/src/schemas/metadata/MetadataSet.ts +45 -45
  361. package/src/schemas/metadata/MetadataTemplate.ts +80 -80
  362. package/src/schemas/metadata/MetadataTuple.ts +32 -32
  363. package/src/schemas/metadata/MetadataTupleType.ts +67 -67
  364. package/src/schemas/protobuf/IProtobufProperty.ts +6 -6
  365. package/src/schemas/protobuf/IProtobufPropertyType.ts +37 -37
  366. package/src/schemas/protobuf/IProtobufSchema.ts +50 -50
  367. package/src/tags/Constant.ts +15 -15
  368. package/src/tags/ContentMediaType.ts +10 -10
  369. package/src/tags/Default.ts +22 -22
  370. package/src/tags/Example.ts +24 -24
  371. package/src/tags/Examples.ts +16 -16
  372. package/src/tags/ExclusiveMaximum.ts +23 -23
  373. package/src/tags/ExclusiveMinimum.ts +23 -23
  374. package/src/tags/Format.ts +50 -50
  375. package/src/tags/JsonSchemaPlugin.ts +8 -8
  376. package/src/tags/MaxItems.ts +12 -12
  377. package/src/tags/MaxLength.ts +12 -12
  378. package/src/tags/Maximum.ts +19 -19
  379. package/src/tags/MinItems.ts +12 -12
  380. package/src/tags/MinLength.ts +12 -12
  381. package/src/tags/Minimum.ts +19 -19
  382. package/src/tags/MultipleOf.ts +21 -21
  383. package/src/tags/Pattern.ts +31 -31
  384. package/src/tags/Sequence.ts +10 -10
  385. package/src/tags/TagBase.ts +82 -82
  386. package/src/tags/Type.ts +37 -37
  387. package/src/tags/UniqueItems.ts +14 -14
  388. package/src/tags/index.ts +21 -21
  389. package/src/tags/internal/FormatCheatSheet.ts +73 -73
  390. package/src/transform.ts +35 -35
  391. package/src/transformers/CallExpressionTransformer.ts +554 -554
  392. package/src/transformers/FileTransformer.ts +136 -136
  393. package/src/transformers/IProgrammerProps.ts +11 -11
  394. package/src/transformers/ITransformOptions.ts +62 -62
  395. package/src/transformers/ITransformProps.ts +9 -9
  396. package/src/transformers/ITypiaContext.ts +18 -18
  397. package/src/transformers/ImportTransformer.ts +81 -81
  398. package/src/transformers/NoTransformConfigurationError.ts +18 -18
  399. package/src/transformers/NodeTransformer.ts +17 -17
  400. package/src/transformers/TransformerError.ts +60 -60
  401. package/src/transformers/features/AssertTransformer.ts +24 -24
  402. package/src/transformers/features/CreateAssertTransformer.ts +24 -24
  403. package/src/transformers/features/CreateIsTransformer.ts +18 -18
  404. package/src/transformers/features/CreateRandomTransformer.ts +43 -43
  405. package/src/transformers/features/CreateValidateTransformer.ts +18 -18
  406. package/src/transformers/features/IsTransformer.ts +18 -18
  407. package/src/transformers/features/RandomTransformer.ts +41 -41
  408. package/src/transformers/features/ValidateTransformer.ts +18 -18
  409. package/src/transformers/features/functional/FunctionalGenericTransformer.ts +57 -57
  410. package/src/transformers/features/http/CreateHttpAssertFormDataTransformer.ts +13 -13
  411. package/src/transformers/features/http/CreateHttpAssertHeadersTransformer.ts +13 -13
  412. package/src/transformers/features/http/CreateHttpAssertQueryTransformer.ts +13 -13
  413. package/src/transformers/features/http/CreateHttpFormDataTransformer.ts +13 -13
  414. package/src/transformers/features/http/CreateHttpHeadersTransformer.ts +13 -13
  415. package/src/transformers/features/http/CreateHttpIsFormDataTransformer.ts +13 -13
  416. package/src/transformers/features/http/CreateHttpIsHeadersTransformer.ts +13 -13
  417. package/src/transformers/features/http/CreateHttpIsQueryTransformer.ts +13 -13
  418. package/src/transformers/features/http/CreateHttpParameterTransformer.ts +13 -13
  419. package/src/transformers/features/http/CreateHttpQueryTransformer.ts +13 -13
  420. package/src/transformers/features/http/CreateHttpValidateFormDataTransformer.ts +13 -13
  421. package/src/transformers/features/http/CreateHttpValidateHeadersTransformer.ts +13 -13
  422. package/src/transformers/features/http/CreateHttpValidateQueryTransformer.ts +13 -13
  423. package/src/transformers/features/http/HttpAssertFormDataTransformer.ts +13 -13
  424. package/src/transformers/features/http/HttpAssertHeadersTransformer.ts +13 -13
  425. package/src/transformers/features/http/HttpAssertQueryTransformer.ts +13 -13
  426. package/src/transformers/features/http/HttpFormDataTransformer.ts +13 -13
  427. package/src/transformers/features/http/HttpHeadersTransformer.ts +13 -13
  428. package/src/transformers/features/http/HttpIsFormDataTransformer.ts +13 -13
  429. package/src/transformers/features/http/HttpIsHeadersTransformer.ts +13 -13
  430. package/src/transformers/features/http/HttpIsQueryTransformer.ts +13 -13
  431. package/src/transformers/features/http/HttpParameterTransformer.ts +13 -13
  432. package/src/transformers/features/http/HttpQueryTransformer.ts +13 -13
  433. package/src/transformers/features/http/HttpValidateFormDataTransformer.ts +13 -13
  434. package/src/transformers/features/http/HttpValidateHeadersTransformer.ts +13 -13
  435. package/src/transformers/features/http/HttpValidateQueryTransformer.ts +13 -13
  436. package/src/transformers/features/json/JsonApplicationTransformer.ts +105 -105
  437. package/src/transformers/features/json/JsonAssertParseTransformer.ts +13 -13
  438. package/src/transformers/features/json/JsonAssertStringifyTransformer.ts +13 -13
  439. package/src/transformers/features/json/JsonCreateAssertParseTransformer.ts +13 -13
  440. package/src/transformers/features/json/JsonCreateAssertStringifyTransformer.ts +13 -13
  441. package/src/transformers/features/json/JsonCreateIsParseTransformer.ts +13 -13
  442. package/src/transformers/features/json/JsonCreateIsStringifyTransformer.ts +13 -13
  443. package/src/transformers/features/json/JsonCreateStringifyTransformer.ts +13 -13
  444. package/src/transformers/features/json/JsonCreateValidateParseTransformer.ts +13 -13
  445. package/src/transformers/features/json/JsonCreateValidateStringifyProgrammer.ts +13 -13
  446. package/src/transformers/features/json/JsonIsParseTransformer.ts +13 -13
  447. package/src/transformers/features/json/JsonIsStringifyTransformer.ts +13 -13
  448. package/src/transformers/features/json/JsonSchemaTransformer.ts +135 -135
  449. package/src/transformers/features/json/JsonSchemasTransformer.ts +145 -145
  450. package/src/transformers/features/json/JsonStringifyTransformer.ts +13 -13
  451. package/src/transformers/features/json/JsonValidateParseTransformer.ts +13 -13
  452. package/src/transformers/features/json/JsonValidateStringifyTransformer.ts +13 -13
  453. package/src/transformers/features/llm/LlmApplicationTransformer.ts +145 -145
  454. package/src/transformers/features/llm/LlmControllerTransformer.ts +93 -93
  455. package/src/transformers/features/llm/LlmParametersTransformer.ts +102 -102
  456. package/src/transformers/features/llm/LlmSchemaTransformer.ts +170 -170
  457. package/src/transformers/features/misc/MiscAssertCloneTransformer.ts +13 -13
  458. package/src/transformers/features/misc/MiscAssertPruneTransformer.ts +13 -13
  459. package/src/transformers/features/misc/MiscCloneTransformer.ts +13 -13
  460. package/src/transformers/features/misc/MiscCreateAssertCloneTransformer.ts +13 -13
  461. package/src/transformers/features/misc/MiscCreateAssertPruneTransformer.ts +13 -13
  462. package/src/transformers/features/misc/MiscCreateCloneTransformer.ts +13 -13
  463. package/src/transformers/features/misc/MiscCreateIsCloneTransformer.ts +13 -13
  464. package/src/transformers/features/misc/MiscCreateIsPruneTransformer.ts +13 -13
  465. package/src/transformers/features/misc/MiscCreatePruneTransformer.ts +13 -13
  466. package/src/transformers/features/misc/MiscCreateValidateCloneTransformer.ts +13 -13
  467. package/src/transformers/features/misc/MiscCreateValidatePruneTransformer.ts +13 -13
  468. package/src/transformers/features/misc/MiscIsCloneTransformer.ts +13 -13
  469. package/src/transformers/features/misc/MiscIsPruneTransformer.ts +13 -13
  470. package/src/transformers/features/misc/MiscLiteralsTransformer.ts +35 -35
  471. package/src/transformers/features/misc/MiscPruneTransformer.ts +13 -13
  472. package/src/transformers/features/misc/MiscValidateCloneTransformer.ts +13 -13
  473. package/src/transformers/features/misc/MiscValidatePruneTransformer.ts +13 -13
  474. package/src/transformers/features/notations/NotationAssertGeneralTransformer.ts +20 -20
  475. package/src/transformers/features/notations/NotationCreateAssertGeneralTransformer.ts +20 -20
  476. package/src/transformers/features/notations/NotationCreateGeneralTransformer.ts +20 -20
  477. package/src/transformers/features/notations/NotationCreateIsGeneralTransformer.ts +20 -20
  478. package/src/transformers/features/notations/NotationCreateValidateGeneralTransformer.ts +20 -20
  479. package/src/transformers/features/notations/NotationGeneralTransformer.ts +18 -18
  480. package/src/transformers/features/notations/NotationIsGeneralTransformer.ts +20 -20
  481. package/src/transformers/features/notations/NotationValidateGeneralTransformer.ts +20 -20
  482. package/src/transformers/features/protobuf/ProtobufAssertDecodeTransformer.ts +13 -13
  483. package/src/transformers/features/protobuf/ProtobufAssertEncodeTransformer.ts +13 -13
  484. package/src/transformers/features/protobuf/ProtobufCreateAssertDecodeTransformer.ts +13 -13
  485. package/src/transformers/features/protobuf/ProtobufCreateAssertEncodeTransformer.ts +13 -13
  486. package/src/transformers/features/protobuf/ProtobufCreateDecodeTransformer.ts +13 -13
  487. package/src/transformers/features/protobuf/ProtobufCreateEncodeTransformer.ts +13 -13
  488. package/src/transformers/features/protobuf/ProtobufCreateIsDecodeTransformer.ts +13 -13
  489. package/src/transformers/features/protobuf/ProtobufCreateIsEncodeTransformer.ts +13 -13
  490. package/src/transformers/features/protobuf/ProtobufCreateValidateDecodeTransformer.ts +13 -13
  491. package/src/transformers/features/protobuf/ProtobufCreateValidateEncodeTransformer.ts +13 -13
  492. package/src/transformers/features/protobuf/ProtobufDecodeTransformer.ts +13 -13
  493. package/src/transformers/features/protobuf/ProtobufEncodeTransformer.ts +13 -13
  494. package/src/transformers/features/protobuf/ProtobufIsDecodeTransformer.ts +13 -13
  495. package/src/transformers/features/protobuf/ProtobufIsEncodeTransformer.ts +13 -13
  496. package/src/transformers/features/protobuf/ProtobufMessageTransformer.ts +35 -35
  497. package/src/transformers/features/protobuf/ProtobufValidateDecodeTransformer.ts +13 -13
  498. package/src/transformers/features/protobuf/ProtobufValidateEncodeTransformer.ts +13 -13
  499. package/src/transformers/features/reflect/ReflectMetadataTransformer.ts +69 -69
  500. package/src/transformers/features/reflect/ReflectNameTransformer.ts +82 -82
  501. package/src/transformers/internal/GenericTransformer.ts +101 -101
  502. package/src/typings/Atomic.ts +13 -13
  503. package/src/typings/ClassProperties.ts +5 -5
  504. package/src/typings/Customizable.ts +5 -5
  505. package/src/typings/Equal.ts +18 -18
  506. package/src/typings/IsTuple.ts +9 -9
  507. package/src/typings/NativeClass.ts +23 -23
  508. package/src/typings/OmitNever.ts +3 -3
  509. package/src/typings/ProtobufAtomic.ts +19 -19
  510. package/src/typings/SpecialFields.ts +3 -3
  511. package/src/typings/ValidationPipe.ts +9 -9
  512. package/src/typings/ValueOf.ts +20 -20
  513. package/src/typings/Writable.ts +11 -11
  514. package/src/utils/ArrayUtil.ts +41 -41
  515. package/src/utils/Escaper.ts +50 -50
  516. package/src/utils/MapUtil.ts +14 -14
  517. package/src/utils/NamingConvention.ts +94 -94
  518. package/src/utils/PatternUtil.ts +29 -29
  519. package/src/utils/ProtobufNameEncoder.ts +32 -32
  520. package/src/utils/Singleton.ts +16 -16
  521. package/src/utils/StringUtil.ts +16 -16
@@ -1,401 +1,401 @@
1
- import {
2
- ILlmApplication,
3
- ILlmSchema,
4
- IOpenApiSchemaError,
5
- IResult,
6
- OpenApi,
7
- } from "@samchon/openapi";
8
- import { LlmSchemaComposer } from "@samchon/openapi/lib/composers/LlmSchemaComposer";
9
- import { ILlmFunction } from "@samchon/openapi/lib/structures/ILlmFunction";
10
- import ts from "typescript";
11
-
12
- import { MetadataFactory } from "../../factories/MetadataFactory";
13
- import { TypeFactory } from "../../factories/TypeFactory";
14
-
15
- import { __IJsonApplication } from "../../schemas/json/__IJsonApplication";
16
- import { Metadata } from "../../schemas/metadata/Metadata";
17
- import { MetadataFunction } from "../../schemas/metadata/MetadataFunction";
18
- import { MetadataObjectType } from "../../schemas/metadata/MetadataObjectType";
19
- import { MetadataParameter } from "../../schemas/metadata/MetadataParameter";
20
-
21
- import { ITypiaContext } from "../../transformers/ITypiaContext";
22
-
23
- import { IValidation } from "../../IValidation";
24
- import { ValidateProgrammer } from "../ValidateProgrammer";
25
- import { JsonApplicationProgrammer } from "../json/JsonApplicationProgrammer";
26
- import { LlmSchemaProgrammer } from "./LlmSchemaProgrammer";
27
-
28
- export namespace LlmApplicationProgrammer {
29
- export const validate = <Model extends ILlmSchema.Model>(props: {
30
- model: Model;
31
- config?: Partial<ILlmSchema.ModelConfig[Model]>;
32
- }) => {
33
- let top: Metadata | undefined;
34
- return (
35
- metadata: Metadata,
36
- explore: MetadataFactory.IExplore,
37
- ): string[] => {
38
- top ??= metadata;
39
- if (explore.top === false)
40
- if (
41
- explore.object === top?.objects[0]?.type &&
42
- typeof explore.property === "string" &&
43
- metadata.size() === 1 &&
44
- metadata.nullable === false &&
45
- metadata.isRequired() === true &&
46
- metadata.functions.length === 1
47
- )
48
- return validateFunction(explore.property, metadata.functions[0]!);
49
- else return LlmSchemaProgrammer.validate(props)(metadata);
50
-
51
- const output: string[] = [];
52
- const validity: boolean =
53
- metadata.size() === 1 &&
54
- metadata.objects.length === 1 &&
55
- metadata.isRequired() === true &&
56
- metadata.nullable === false;
57
- if (validity === false)
58
- output.push(
59
- "LLM application's generic argument must be a class/interface type.",
60
- );
61
-
62
- const object: MetadataObjectType | undefined = metadata.objects[0]?.type;
63
- if (object !== undefined) {
64
- if (object.properties.some((p) => p.key.isSoleLiteral() === false))
65
- output.push(
66
- "LLM application does not allow dynamic keys on class/interface type.",
67
- );
68
- let least: boolean = false;
69
- for (const p of object.properties) {
70
- const name: string = JSON.stringify(p.key.getSoleLiteral()!);
71
- const value: Metadata = p.value;
72
- if (value.functions.length) {
73
- least ||= true;
74
- if (validity === false) {
75
- if (value.functions.length !== 1 || value.size() !== 1)
76
- output.push(
77
- `LLM application's function (${name}) type does not allow union type.`,
78
- );
79
- if (value.isRequired() === false)
80
- output.push(
81
- `LLM application's function (${name}) type must be required.`,
82
- );
83
- if (value.nullable === true)
84
- output.push(
85
- `LLM application's function (${name}) type must not be nullable.`,
86
- );
87
- }
88
-
89
- const description: string | undefined = concatDescription(
90
- JsonApplicationProgrammer.writeDescription({
91
- description:
92
- p.description ??
93
- p.jsDocTags.find((tag) => tag.name === "description")
94
- ?.text?.[0]?.text ??
95
- null,
96
- jsDocTags: p.jsDocTags,
97
- kind: "summary",
98
- }),
99
- );
100
- if (description !== undefined && description.length > 1_024)
101
- output.push(
102
- `LLM application's function (${name}) description must not exceed 1,024 characters.`,
103
- );
104
- }
105
- }
106
- if (least === false)
107
- output.push(
108
- "LLM application's target type must have at least a function type.",
109
- );
110
- }
111
- return output;
112
- };
113
- };
114
-
115
- const validateFunction = (name: string, func: MetadataFunction): string[] => {
116
- const output: string[] = [];
117
- const prefix: string = `LLM application's function (${JSON.stringify(name)})`;
118
- if (func.output.size() && func.output.isRequired() === false)
119
- output.push(
120
- `${prefix}'s return type must not be union type with undefined.`,
121
- );
122
- if (/^[0-9]/.test(name[0] ?? "") === true)
123
- output.push(`${prefix} name must not start with a number.`);
124
- if (/^[a-zA-Z0-9_-]+$/.test(name) === false)
125
- output.push(
126
- `${prefix} name must be alphanumeric with underscore or hyphen.`,
127
- );
128
- if (name.length > 64)
129
- output.push(`${prefix} name must not exceed 64 characters.`);
130
- if (func.parameters.length !== 0 && func.parameters.length !== 1)
131
- output.push(`${prefix} must have a single parameter.`);
132
- if (func.parameters.length !== 0) {
133
- const type: Metadata = func.parameters[0]!.type;
134
- if (type.size() !== 1 || type.objects.length !== 1)
135
- output.push(`${prefix}'s parameter must be an object type.`);
136
- else {
137
- if (
138
- type.objects[0]!.type.properties.some(
139
- (p) => p.key.isSoleLiteral() === false,
140
- )
141
- )
142
- output.push(`${prefix}'s parameter must not have dynamic keys.`);
143
- if (type.isRequired() === false)
144
- output.push(
145
- `${prefix}'s parameter must not be union type with undefined.`,
146
- );
147
- if (type.nullable === true)
148
- output.push(`${prefix}'s parameter must not be nullable.`);
149
- }
150
- }
151
- return output;
152
- };
153
-
154
- export const write = <Model extends ILlmSchema.Model>(props: {
155
- model: Model;
156
- context: ITypiaContext;
157
- modulo: ts.LeftHandSideExpression;
158
- metadata: Metadata;
159
- config?: Partial<ILlmSchema.ModelConfig[Model]>;
160
- name?: string;
161
- }): ILlmApplication<Model> => {
162
- const metadata: Metadata = Metadata.unalias(props.metadata);
163
- const functionParameters: Record<string, MetadataParameter> =
164
- Object.fromEntries(
165
- metadata.objects[0]!.type.properties.filter(
166
- (p) =>
167
- p.key.isSoleLiteral() &&
168
- p.value.size() === 1 &&
169
- p.value.nullable === false &&
170
- p.value.isRequired() === true &&
171
- Metadata.unalias(p.value).functions.length === 1,
172
- )
173
- .filter(
174
- (p) =>
175
- p.jsDocTags.find(
176
- (tag) => tag.name === "hidden" || tag.name === "internal",
177
- ) === undefined,
178
- )
179
- .map((p) => [
180
- p.key.getSoleLiteral()!,
181
- Metadata.unalias(p.value).functions[0]!.parameters[0]!,
182
- ]),
183
- );
184
-
185
- const errorMessages: string[] = [];
186
- const application: __IJsonApplication<"3.1"> =
187
- JsonApplicationProgrammer.write({
188
- version: "3.1",
189
- metadata,
190
- filter: (p) =>
191
- p.jsDocTags.some((tag) => tag.name === "human") === false,
192
- });
193
- const functions: Array<ILlmFunction<Model> | null> =
194
- application.functions.map((func) =>
195
- writeFunction({
196
- model: props.model,
197
- context: props.context,
198
- modulo: props.modulo,
199
- className: props.name,
200
- components: application.components,
201
- function: func,
202
- errors: errorMessages,
203
- parameter: functionParameters[func.name] ?? null,
204
- }),
205
- );
206
- if (functions.some((func) => func === null))
207
- throw new Error(
208
- "Failed to write LLM application:\n\n" +
209
- errorMessages.map((str) => ` - ${str}`).join("\n"),
210
- );
211
- return {
212
- model: props.model,
213
- options: {
214
- ...LlmSchemaComposer.defaultConfig(props.model),
215
- ...props.config,
216
- separate: null,
217
- },
218
- functions: functions as ILlmFunction<Model>[],
219
- };
220
- };
221
-
222
- const writeFunction = <Model extends ILlmSchema.Model>(props: {
223
- model: Model;
224
- context: ITypiaContext;
225
- modulo: ts.LeftHandSideExpression;
226
- components: OpenApi.IComponents;
227
- function: __IJsonApplication.IFunction<OpenApi.IJsonSchema>;
228
- parameter: MetadataParameter | null;
229
- errors: string[];
230
- className?: string;
231
- }): ILlmFunction<Model> | null => {
232
- const parameters: ILlmSchema.ModelParameters[Model] | null =
233
- writeParameters({
234
- ...props,
235
- accessor: `$input.${props.function.name}.parameters`,
236
- });
237
- if (parameters === null) return null;
238
- const output: ILlmSchema.ModelSchema[Model] | null | undefined =
239
- writeOutput({
240
- model: props.model,
241
- parameters,
242
- components: props.components,
243
- schema: props.function.output?.schema ?? null,
244
- errors: props.errors,
245
- accessor: `$input.${props.function.name}.output`,
246
- });
247
- if (output === null) return null;
248
- else if (
249
- output &&
250
- output.description === undefined &&
251
- !!props.function.output?.description?.length
252
- )
253
- output.description = props.function.output.description;
254
- return {
255
- name: props.function.name,
256
- parameters,
257
- output: (output ?? undefined) as
258
- | ILlmSchema.ModelSchema[Model]
259
- | undefined,
260
- description: (() => {
261
- if (
262
- !props.function.summary?.length ||
263
- !props.function.description?.length
264
- )
265
- return props.function.summary || props.function.description;
266
- const summary: string = props.function.summary.endsWith(".")
267
- ? props.function.summary.slice(0, -1)
268
- : props.function.summary;
269
- return props.function.description.startsWith(summary)
270
- ? props.function.description
271
- : summary + ".\n\n" + props.function.description;
272
- })(),
273
- deprecated: props.function.deprecated,
274
- tags: props.function.tags,
275
- validate: writeValidadtor({
276
- context: props.context,
277
- modulo: props.modulo,
278
- parameter: props.parameter,
279
- name: props.function.name,
280
- className: props.className,
281
- }),
282
- };
283
- };
284
-
285
- const writeParameters = <Model extends ILlmSchema.Model>(props: {
286
- model: Model;
287
- components: OpenApi.IComponents;
288
- function: __IJsonApplication.IFunction<OpenApi.IJsonSchema>;
289
- errors: string[];
290
- accessor: string;
291
- }): ILlmSchema.ModelParameters[Model] | null => {
292
- const schema = props.function.parameters[0]?.schema ?? {
293
- type: "object",
294
- properties: {},
295
- additionalProperties: false,
296
- required: [],
297
- };
298
- const result: IResult<
299
- ILlmSchema.ModelParameters[Model],
300
- IOpenApiSchemaError
301
- > = LlmSchemaComposer.parameters(props.model)({
302
- config: LlmSchemaComposer.defaultConfig(props.model) as any,
303
- components: props.components,
304
- schema: {
305
- ...(schema as
306
- | OpenApi.IJsonSchema.IObject
307
- | OpenApi.IJsonSchema.IReference),
308
- title: schema.title ?? props.function.parameters[0]?.title,
309
- description:
310
- schema.description ?? props.function.parameters[0]?.description,
311
- },
312
- accessor: props.accessor,
313
- }) as IResult<ILlmSchema.ModelParameters[Model], IOpenApiSchemaError>;
314
- if (result.success === false) {
315
- props.errors.push(
316
- ...result.error.reasons.map((r) => ` - ${r.accessor}: ${r.message}`),
317
- );
318
- return null;
319
- }
320
- return result.value;
321
- };
322
-
323
- const writeOutput = <Model extends ILlmSchema.Model>(props: {
324
- model: Model;
325
- parameters: ILlmSchema.ModelParameters[Model];
326
- components: OpenApi.IComponents;
327
- schema: OpenApi.IJsonSchema | null;
328
- errors: string[];
329
- accessor: string;
330
- }): ILlmSchema.ModelSchema[Model] | null | undefined => {
331
- if (props.schema === null) return undefined;
332
- const result: IResult<ILlmSchema.ModelSchema[Model], IOpenApiSchemaError> =
333
- LlmSchemaComposer.schema(props.model)({
334
- config: LlmSchemaComposer.defaultConfig(props.model) as any,
335
- components: props.components,
336
- schema: props.schema,
337
- $defs: (props.parameters as any).$defs,
338
- accessor: props.accessor,
339
- }) as IResult<ILlmSchema.ModelSchema[Model], IOpenApiSchemaError>;
340
- if (result.success === false) {
341
- props.errors.push(
342
- ...result.error.reasons.map((r) => ` - ${r.accessor}: ${r.message}`),
343
- );
344
- return null;
345
- }
346
- return result.value;
347
- };
348
-
349
- const writeValidadtor = (props: {
350
- context: ITypiaContext;
351
- modulo: ts.LeftHandSideExpression;
352
- parameter: MetadataParameter | null;
353
- name: string;
354
- className?: string;
355
- }): ((props: unknown) => IValidation<unknown>) => {
356
- if (props.parameter === null)
357
- return ValidateProgrammer.write({
358
- ...props,
359
- type: props.context.checker.getTypeFromTypeNode(
360
- TypeFactory.keyword("any"),
361
- ),
362
- config: {
363
- equals: false,
364
- },
365
- name: undefined,
366
- }) as any;
367
-
368
- const type: ts.Type | undefined = props.parameter.tsType;
369
- if (type === undefined)
370
- // unreachable
371
- throw new Error(
372
- "Failed to write LLM application's function validator. You don't have to call `LlmApplicationOfValidator.write()` function by yourself, but only by the `typia.llm.applicationOfValidate()` function.",
373
- );
374
- return ValidateProgrammer.write({
375
- ...props,
376
- type: props.parameter.tsType!,
377
- config: {
378
- equals: false,
379
- },
380
- name: props.className
381
- ? `Parameters<${props.className}[${JSON.stringify(props.name)}]>[0]`
382
- : undefined,
383
- }) satisfies ts.CallExpression as any as (
384
- props: unknown,
385
- ) => IValidation<unknown>;
386
- };
387
- }
388
-
389
- const concatDescription = (p: {
390
- summary?: string | undefined;
391
- description?: string | undefined;
392
- }): string | undefined => {
393
- if (!p.summary?.length || !p.description?.length)
394
- return p.summary ?? p.description;
395
- const summary: string = p.summary.endsWith(".")
396
- ? p.summary.slice(0, -1)
397
- : p.summary;
398
- return p.description.startsWith(summary)
399
- ? p.description
400
- : summary + ".\n\n" + p.description;
401
- };
1
+ import {
2
+ ILlmApplication,
3
+ ILlmSchema,
4
+ IOpenApiSchemaError,
5
+ IResult,
6
+ OpenApi,
7
+ } from "@samchon/openapi";
8
+ import { LlmSchemaComposer } from "@samchon/openapi/lib/composers/LlmSchemaComposer";
9
+ import { ILlmFunction } from "@samchon/openapi/lib/structures/ILlmFunction";
10
+ import ts from "typescript";
11
+
12
+ import { MetadataFactory } from "../../factories/MetadataFactory";
13
+ import { TypeFactory } from "../../factories/TypeFactory";
14
+
15
+ import { __IJsonApplication } from "../../schemas/json/__IJsonApplication";
16
+ import { Metadata } from "../../schemas/metadata/Metadata";
17
+ import { MetadataFunction } from "../../schemas/metadata/MetadataFunction";
18
+ import { MetadataObjectType } from "../../schemas/metadata/MetadataObjectType";
19
+ import { MetadataParameter } from "../../schemas/metadata/MetadataParameter";
20
+
21
+ import { ITypiaContext } from "../../transformers/ITypiaContext";
22
+
23
+ import { IValidation } from "../../IValidation";
24
+ import { ValidateProgrammer } from "../ValidateProgrammer";
25
+ import { JsonApplicationProgrammer } from "../json/JsonApplicationProgrammer";
26
+ import { LlmSchemaProgrammer } from "./LlmSchemaProgrammer";
27
+
28
+ export namespace LlmApplicationProgrammer {
29
+ export const validate = <Model extends ILlmSchema.Model>(props: {
30
+ model: Model;
31
+ config?: Partial<ILlmSchema.ModelConfig[Model]>;
32
+ }) => {
33
+ let top: Metadata | undefined;
34
+ return (
35
+ metadata: Metadata,
36
+ explore: MetadataFactory.IExplore,
37
+ ): string[] => {
38
+ top ??= metadata;
39
+ if (explore.top === false)
40
+ if (
41
+ explore.object === top?.objects[0]?.type &&
42
+ typeof explore.property === "string" &&
43
+ metadata.size() === 1 &&
44
+ metadata.nullable === false &&
45
+ metadata.isRequired() === true &&
46
+ metadata.functions.length === 1
47
+ )
48
+ return validateFunction(explore.property, metadata.functions[0]!);
49
+ else return LlmSchemaProgrammer.validate(props)(metadata);
50
+
51
+ const output: string[] = [];
52
+ const validity: boolean =
53
+ metadata.size() === 1 &&
54
+ metadata.objects.length === 1 &&
55
+ metadata.isRequired() === true &&
56
+ metadata.nullable === false;
57
+ if (validity === false)
58
+ output.push(
59
+ "LLM application's generic argument must be a class/interface type.",
60
+ );
61
+
62
+ const object: MetadataObjectType | undefined = metadata.objects[0]?.type;
63
+ if (object !== undefined) {
64
+ if (object.properties.some((p) => p.key.isSoleLiteral() === false))
65
+ output.push(
66
+ "LLM application does not allow dynamic keys on class/interface type.",
67
+ );
68
+ let least: boolean = false;
69
+ for (const p of object.properties) {
70
+ const name: string = JSON.stringify(p.key.getSoleLiteral()!);
71
+ const value: Metadata = p.value;
72
+ if (value.functions.length) {
73
+ least ||= true;
74
+ if (validity === false) {
75
+ if (value.functions.length !== 1 || value.size() !== 1)
76
+ output.push(
77
+ `LLM application's function (${name}) type does not allow union type.`,
78
+ );
79
+ if (value.isRequired() === false)
80
+ output.push(
81
+ `LLM application's function (${name}) type must be required.`,
82
+ );
83
+ if (value.nullable === true)
84
+ output.push(
85
+ `LLM application's function (${name}) type must not be nullable.`,
86
+ );
87
+ }
88
+
89
+ const description: string | undefined = concatDescription(
90
+ JsonApplicationProgrammer.writeDescription({
91
+ description:
92
+ p.description ??
93
+ p.jsDocTags.find((tag) => tag.name === "description")
94
+ ?.text?.[0]?.text ??
95
+ null,
96
+ jsDocTags: p.jsDocTags,
97
+ kind: "summary",
98
+ }),
99
+ );
100
+ if (description !== undefined && description.length > 1_024)
101
+ output.push(
102
+ `LLM application's function (${name}) description must not exceed 1,024 characters.`,
103
+ );
104
+ }
105
+ }
106
+ if (least === false)
107
+ output.push(
108
+ "LLM application's target type must have at least a function type.",
109
+ );
110
+ }
111
+ return output;
112
+ };
113
+ };
114
+
115
+ const validateFunction = (name: string, func: MetadataFunction): string[] => {
116
+ const output: string[] = [];
117
+ const prefix: string = `LLM application's function (${JSON.stringify(name)})`;
118
+ if (func.output.size() && func.output.isRequired() === false)
119
+ output.push(
120
+ `${prefix}'s return type must not be union type with undefined.`,
121
+ );
122
+ if (/^[0-9]/.test(name[0] ?? "") === true)
123
+ output.push(`${prefix} name must not start with a number.`);
124
+ if (/^[a-zA-Z0-9_-]+$/.test(name) === false)
125
+ output.push(
126
+ `${prefix} name must be alphanumeric with underscore or hyphen.`,
127
+ );
128
+ if (name.length > 64)
129
+ output.push(`${prefix} name must not exceed 64 characters.`);
130
+ if (func.parameters.length !== 0 && func.parameters.length !== 1)
131
+ output.push(`${prefix} must have a single parameter.`);
132
+ if (func.parameters.length !== 0) {
133
+ const type: Metadata = func.parameters[0]!.type;
134
+ if (type.size() !== 1 || type.objects.length !== 1)
135
+ output.push(`${prefix}'s parameter must be an object type.`);
136
+ else {
137
+ if (
138
+ type.objects[0]!.type.properties.some(
139
+ (p) => p.key.isSoleLiteral() === false,
140
+ )
141
+ )
142
+ output.push(`${prefix}'s parameter must not have dynamic keys.`);
143
+ if (type.isRequired() === false)
144
+ output.push(
145
+ `${prefix}'s parameter must not be union type with undefined.`,
146
+ );
147
+ if (type.nullable === true)
148
+ output.push(`${prefix}'s parameter must not be nullable.`);
149
+ }
150
+ }
151
+ return output;
152
+ };
153
+
154
+ export const write = <Model extends ILlmSchema.Model>(props: {
155
+ model: Model;
156
+ context: ITypiaContext;
157
+ modulo: ts.LeftHandSideExpression;
158
+ metadata: Metadata;
159
+ config?: Partial<ILlmSchema.ModelConfig[Model]>;
160
+ name?: string;
161
+ }): ILlmApplication<Model> => {
162
+ const metadata: Metadata = Metadata.unalias(props.metadata);
163
+ const functionParameters: Record<string, MetadataParameter> =
164
+ Object.fromEntries(
165
+ metadata.objects[0]!.type.properties.filter(
166
+ (p) =>
167
+ p.key.isSoleLiteral() &&
168
+ p.value.size() === 1 &&
169
+ p.value.nullable === false &&
170
+ p.value.isRequired() === true &&
171
+ Metadata.unalias(p.value).functions.length === 1,
172
+ )
173
+ .filter(
174
+ (p) =>
175
+ p.jsDocTags.find(
176
+ (tag) => tag.name === "hidden" || tag.name === "internal",
177
+ ) === undefined,
178
+ )
179
+ .map((p) => [
180
+ p.key.getSoleLiteral()!,
181
+ Metadata.unalias(p.value).functions[0]!.parameters[0]!,
182
+ ]),
183
+ );
184
+
185
+ const errorMessages: string[] = [];
186
+ const application: __IJsonApplication<"3.1"> =
187
+ JsonApplicationProgrammer.write({
188
+ version: "3.1",
189
+ metadata,
190
+ filter: (p) =>
191
+ p.jsDocTags.some((tag) => tag.name === "human") === false,
192
+ });
193
+ const functions: Array<ILlmFunction<Model> | null> =
194
+ application.functions.map((func) =>
195
+ writeFunction({
196
+ model: props.model,
197
+ context: props.context,
198
+ modulo: props.modulo,
199
+ className: props.name,
200
+ components: application.components,
201
+ function: func,
202
+ errors: errorMessages,
203
+ parameter: functionParameters[func.name] ?? null,
204
+ }),
205
+ );
206
+ if (functions.some((func) => func === null))
207
+ throw new Error(
208
+ "Failed to write LLM application:\n\n" +
209
+ errorMessages.map((str) => ` - ${str}`).join("\n"),
210
+ );
211
+ return {
212
+ model: props.model,
213
+ options: {
214
+ ...LlmSchemaComposer.defaultConfig(props.model),
215
+ ...props.config,
216
+ separate: null,
217
+ },
218
+ functions: functions as ILlmFunction<Model>[],
219
+ };
220
+ };
221
+
222
+ const writeFunction = <Model extends ILlmSchema.Model>(props: {
223
+ model: Model;
224
+ context: ITypiaContext;
225
+ modulo: ts.LeftHandSideExpression;
226
+ components: OpenApi.IComponents;
227
+ function: __IJsonApplication.IFunction<OpenApi.IJsonSchema>;
228
+ parameter: MetadataParameter | null;
229
+ errors: string[];
230
+ className?: string;
231
+ }): ILlmFunction<Model> | null => {
232
+ const parameters: ILlmSchema.ModelParameters[Model] | null =
233
+ writeParameters({
234
+ ...props,
235
+ accessor: `$input.${props.function.name}.parameters`,
236
+ });
237
+ if (parameters === null) return null;
238
+ const output: ILlmSchema.ModelSchema[Model] | null | undefined =
239
+ writeOutput({
240
+ model: props.model,
241
+ parameters,
242
+ components: props.components,
243
+ schema: props.function.output?.schema ?? null,
244
+ errors: props.errors,
245
+ accessor: `$input.${props.function.name}.output`,
246
+ });
247
+ if (output === null) return null;
248
+ else if (
249
+ output &&
250
+ output.description === undefined &&
251
+ !!props.function.output?.description?.length
252
+ )
253
+ output.description = props.function.output.description;
254
+ return {
255
+ name: props.function.name,
256
+ parameters,
257
+ output: (output ?? undefined) as
258
+ | ILlmSchema.ModelSchema[Model]
259
+ | undefined,
260
+ description: (() => {
261
+ if (
262
+ !props.function.summary?.length ||
263
+ !props.function.description?.length
264
+ )
265
+ return props.function.summary || props.function.description;
266
+ const summary: string = props.function.summary.endsWith(".")
267
+ ? props.function.summary.slice(0, -1)
268
+ : props.function.summary;
269
+ return props.function.description.startsWith(summary)
270
+ ? props.function.description
271
+ : summary + ".\n\n" + props.function.description;
272
+ })(),
273
+ deprecated: props.function.deprecated,
274
+ tags: props.function.tags,
275
+ validate: writeValidadtor({
276
+ context: props.context,
277
+ modulo: props.modulo,
278
+ parameter: props.parameter,
279
+ name: props.function.name,
280
+ className: props.className,
281
+ }),
282
+ };
283
+ };
284
+
285
+ const writeParameters = <Model extends ILlmSchema.Model>(props: {
286
+ model: Model;
287
+ components: OpenApi.IComponents;
288
+ function: __IJsonApplication.IFunction<OpenApi.IJsonSchema>;
289
+ errors: string[];
290
+ accessor: string;
291
+ }): ILlmSchema.ModelParameters[Model] | null => {
292
+ const schema = props.function.parameters[0]?.schema ?? {
293
+ type: "object",
294
+ properties: {},
295
+ additionalProperties: false,
296
+ required: [],
297
+ };
298
+ const result: IResult<
299
+ ILlmSchema.ModelParameters[Model],
300
+ IOpenApiSchemaError
301
+ > = LlmSchemaComposer.parameters(props.model)({
302
+ config: LlmSchemaComposer.defaultConfig(props.model) as any,
303
+ components: props.components,
304
+ schema: {
305
+ ...(schema as
306
+ | OpenApi.IJsonSchema.IObject
307
+ | OpenApi.IJsonSchema.IReference),
308
+ title: schema.title ?? props.function.parameters[0]?.title,
309
+ description:
310
+ schema.description ?? props.function.parameters[0]?.description,
311
+ },
312
+ accessor: props.accessor,
313
+ }) as IResult<ILlmSchema.ModelParameters[Model], IOpenApiSchemaError>;
314
+ if (result.success === false) {
315
+ props.errors.push(
316
+ ...result.error.reasons.map((r) => ` - ${r.accessor}: ${r.message}`),
317
+ );
318
+ return null;
319
+ }
320
+ return result.value;
321
+ };
322
+
323
+ const writeOutput = <Model extends ILlmSchema.Model>(props: {
324
+ model: Model;
325
+ parameters: ILlmSchema.ModelParameters[Model];
326
+ components: OpenApi.IComponents;
327
+ schema: OpenApi.IJsonSchema | null;
328
+ errors: string[];
329
+ accessor: string;
330
+ }): ILlmSchema.ModelSchema[Model] | null | undefined => {
331
+ if (props.schema === null) return undefined;
332
+ const result: IResult<ILlmSchema.ModelSchema[Model], IOpenApiSchemaError> =
333
+ LlmSchemaComposer.schema(props.model)({
334
+ config: LlmSchemaComposer.defaultConfig(props.model) as any,
335
+ components: props.components,
336
+ schema: props.schema,
337
+ $defs: (props.parameters as any).$defs,
338
+ accessor: props.accessor,
339
+ }) as IResult<ILlmSchema.ModelSchema[Model], IOpenApiSchemaError>;
340
+ if (result.success === false) {
341
+ props.errors.push(
342
+ ...result.error.reasons.map((r) => ` - ${r.accessor}: ${r.message}`),
343
+ );
344
+ return null;
345
+ }
346
+ return result.value;
347
+ };
348
+
349
+ const writeValidadtor = (props: {
350
+ context: ITypiaContext;
351
+ modulo: ts.LeftHandSideExpression;
352
+ parameter: MetadataParameter | null;
353
+ name: string;
354
+ className?: string;
355
+ }): ((props: unknown) => IValidation<unknown>) => {
356
+ if (props.parameter === null)
357
+ return ValidateProgrammer.write({
358
+ ...props,
359
+ type: props.context.checker.getTypeFromTypeNode(
360
+ TypeFactory.keyword("any"),
361
+ ),
362
+ config: {
363
+ equals: false,
364
+ },
365
+ name: undefined,
366
+ }) as any;
367
+
368
+ const type: ts.Type | undefined = props.parameter.tsType;
369
+ if (type === undefined)
370
+ // unreachable
371
+ throw new Error(
372
+ "Failed to write LLM application's function validator. You don't have to call `LlmApplicationOfValidator.write()` function by yourself, but only by the `typia.llm.applicationOfValidate()` function.",
373
+ );
374
+ return ValidateProgrammer.write({
375
+ ...props,
376
+ type: props.parameter.tsType!,
377
+ config: {
378
+ equals: false,
379
+ },
380
+ name: props.className
381
+ ? `Parameters<${props.className}[${JSON.stringify(props.name)}]>[0]`
382
+ : undefined,
383
+ }) satisfies ts.CallExpression as any as (
384
+ props: unknown,
385
+ ) => IValidation<unknown>;
386
+ };
387
+ }
388
+
389
+ const concatDescription = (p: {
390
+ summary?: string | undefined;
391
+ description?: string | undefined;
392
+ }): string | undefined => {
393
+ if (!p.summary?.length || !p.description?.length)
394
+ return p.summary ?? p.description;
395
+ const summary: string = p.summary.endsWith(".")
396
+ ? p.summary.slice(0, -1)
397
+ : p.summary;
398
+ return p.description.startsWith(summary)
399
+ ? p.description
400
+ : summary + ".\n\n" + p.description;
401
+ };