ts-openapi-codegen 2.0.0 → 2.1.0-beta.10

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 (715) hide show
  1. package/README.md +28 -846
  2. package/README.rus.md +28 -846
  3. package/dist/cli/analyzeDiff/__tests__/analyzeDiff.cli.test.d.ts +2 -0
  4. package/dist/cli/analyzeDiff/__tests__/analyzeDiff.cli.test.d.ts.map +1 -0
  5. package/dist/cli/analyzeDiff/__tests__/analyzeDiff.cli.test.js +381 -0
  6. package/dist/cli/analyzeDiff/__tests__/analyzeDiffLomMiracles.test.d.ts +2 -0
  7. package/dist/cli/analyzeDiff/__tests__/analyzeDiffLomMiracles.test.d.ts.map +1 -0
  8. package/dist/cli/analyzeDiff/__tests__/analyzeDiffLomMiracles.test.js +47 -0
  9. package/dist/cli/analyzeDiff/__tests__/analyzeDiffRenameAndInvalidRegex.test.d.ts +2 -0
  10. package/dist/cli/analyzeDiff/__tests__/analyzeDiffRenameAndInvalidRegex.test.d.ts.map +1 -0
  11. package/dist/cli/analyzeDiff/__tests__/analyzeDiffRenameAndInvalidRegex.test.js +152 -0
  12. package/dist/cli/analyzeDiff/__tests__/analyzeDiffTypeCoercion.test.d.ts +2 -0
  13. package/dist/cli/analyzeDiff/__tests__/analyzeDiffTypeCoercion.test.d.ts.map +1 -0
  14. package/dist/cli/analyzeDiff/__tests__/analyzeDiffTypeCoercion.test.js +147 -0
  15. package/dist/cli/analyzeDiff/analyzeDiff.d.ts +29 -0
  16. package/dist/cli/analyzeDiff/analyzeDiff.d.ts.map +1 -0
  17. package/dist/cli/analyzeDiff/analyzeDiff.js +148 -0
  18. package/dist/cli/analyzeDiff/ciSummary.d.ts +9 -0
  19. package/dist/cli/analyzeDiff/ciSummary.d.ts.map +1 -0
  20. package/dist/cli/analyzeDiff/ciSummary.js +24 -0
  21. package/dist/cli/analyzeDiff/ignoreRules.d.ts +11 -0
  22. package/dist/cli/analyzeDiff/ignoreRules.d.ts.map +1 -0
  23. package/dist/cli/analyzeDiff/ignoreRules.js +71 -0
  24. package/dist/cli/analyzeDiff/ignoreSemanticChanges.d.ts +10 -0
  25. package/dist/cli/analyzeDiff/ignoreSemanticChanges.d.ts.map +1 -0
  26. package/dist/cli/analyzeDiff/ignoreSemanticChanges.js +84 -0
  27. package/dist/cli/analyzeDiff/miracles.d.ts +35 -0
  28. package/dist/cli/analyzeDiff/miracles.d.ts.map +1 -0
  29. package/dist/cli/analyzeDiff/miracles.js +107 -0
  30. package/dist/cli/analyzeDiff/pluginPaths.d.ts +5 -0
  31. package/dist/cli/analyzeDiff/pluginPaths.d.ts.map +1 -0
  32. package/dist/cli/analyzeDiff/pluginPaths.js +13 -0
  33. package/dist/cli/analyzeDiff/semanticDiffContext.d.ts +6 -0
  34. package/dist/cli/analyzeDiff/semanticDiffContext.d.ts.map +1 -0
  35. package/dist/cli/analyzeDiff/semanticDiffContext.js +16 -0
  36. package/dist/cli/analyzeDiff/specParser.d.ts +9 -0
  37. package/dist/cli/analyzeDiff/specParser.d.ts.map +1 -0
  38. package/dist/cli/analyzeDiff/specParser.js +59 -0
  39. package/dist/cli/analyzeDiff/types.d.ts +19 -0
  40. package/dist/cli/analyzeDiff/types.d.ts.map +1 -0
  41. package/dist/cli/analyzeDiff/types.js +2 -0
  42. package/dist/cli/analyzeUsage/analyzeUsage.d.ts +4 -0
  43. package/dist/cli/analyzeUsage/analyzeUsage.d.ts.map +1 -0
  44. package/dist/cli/analyzeUsage/analyzeUsage.js +60 -0
  45. package/dist/cli/analyzeUsage/core/Analyzer.d.ts +9 -0
  46. package/dist/cli/analyzeUsage/core/Analyzer.d.ts.map +1 -0
  47. package/dist/cli/analyzeUsage/core/Analyzer.js +29 -0
  48. package/dist/cli/analyzeUsage/core/ProjectContext.d.ts +10 -0
  49. package/dist/cli/analyzeUsage/core/ProjectContext.d.ts.map +1 -0
  50. package/dist/cli/analyzeUsage/core/ProjectContext.js +58 -0
  51. package/dist/cli/analyzeUsage/core/Scanner.d.ts +23 -0
  52. package/dist/cli/analyzeUsage/core/Scanner.d.ts.map +1 -0
  53. package/dist/cli/analyzeUsage/core/Scanner.js +125 -0
  54. package/dist/cli/analyzeUsage/rules/ClientRule.d.ts +14 -0
  55. package/dist/cli/analyzeUsage/rules/ClientRule.d.ts.map +1 -0
  56. package/dist/cli/analyzeUsage/rules/ClientRule.js +86 -0
  57. package/dist/cli/analyzeUsage/rules/CoverageRule.d.ts +7 -0
  58. package/dist/cli/analyzeUsage/rules/CoverageRule.d.ts.map +1 -0
  59. package/dist/cli/analyzeUsage/rules/CoverageRule.js +55 -0
  60. package/dist/cli/analyzeUsage/rules/DiagnosticsRule.d.ts +6 -0
  61. package/dist/cli/analyzeUsage/rules/DiagnosticsRule.d.ts.map +1 -0
  62. package/dist/cli/analyzeUsage/rules/DiagnosticsRule.js +63 -0
  63. package/dist/cli/analyzeUsage/rules/ImportRule.d.ts +6 -0
  64. package/dist/cli/analyzeUsage/rules/ImportRule.d.ts.map +1 -0
  65. package/dist/cli/analyzeUsage/rules/ImportRule.js +50 -0
  66. package/dist/cli/analyzeUsage/rules/ModelRule.d.ts +6 -0
  67. package/dist/cli/analyzeUsage/rules/ModelRule.d.ts.map +1 -0
  68. package/dist/cli/analyzeUsage/rules/ModelRule.js +34 -0
  69. package/dist/cli/analyzeUsage/rules/SchemaRule.d.ts +6 -0
  70. package/dist/cli/analyzeUsage/rules/SchemaRule.d.ts.map +1 -0
  71. package/dist/cli/analyzeUsage/rules/SchemaRule.js +46 -0
  72. package/dist/cli/analyzeUsage/rules/ServiceRule.d.ts +15 -0
  73. package/dist/cli/analyzeUsage/rules/ServiceRule.d.ts.map +1 -0
  74. package/dist/cli/analyzeUsage/rules/ServiceRule.js +96 -0
  75. package/dist/cli/analyzeUsage/types.d.ts +52 -0
  76. package/dist/cli/analyzeUsage/types.d.ts.map +1 -0
  77. package/dist/cli/analyzeUsage/types.js +2 -0
  78. package/dist/cli/analyzeUsage/utils/fuzzy.d.ts +5 -0
  79. package/dist/cli/analyzeUsage/utils/fuzzy.d.ts.map +1 -0
  80. package/dist/cli/analyzeUsage/utils/fuzzy.js +38 -0
  81. package/dist/cli/analyzeUsage/utils/report.d.ts +16 -0
  82. package/dist/cli/analyzeUsage/utils/report.d.ts.map +1 -0
  83. package/dist/cli/analyzeUsage/utils/report.js +85 -0
  84. package/dist/cli/checkAndUpdateConfig/__tests__/checkConfig.test.d.ts +2 -0
  85. package/dist/cli/checkAndUpdateConfig/__tests__/checkConfig.test.d.ts.map +1 -0
  86. package/dist/cli/checkAndUpdateConfig/__tests__/checkConfig.test.js +53 -0
  87. package/dist/cli/checkAndUpdateConfig/__tests__/updateConfig.test.d.ts +2 -0
  88. package/dist/cli/checkAndUpdateConfig/__tests__/updateConfig.test.d.ts.map +1 -0
  89. package/dist/cli/checkAndUpdateConfig/__tests__/updateConfig.test.js +52 -0
  90. package/dist/cli/checkAndUpdateConfig/checkConfig.d.ts +2 -1
  91. package/dist/cli/checkAndUpdateConfig/checkConfig.d.ts.map +1 -1
  92. package/dist/cli/checkAndUpdateConfig/checkConfig.js +26 -12
  93. package/dist/cli/checkAndUpdateConfig/constants.d.ts +0 -9
  94. package/dist/cli/checkAndUpdateConfig/constants.d.ts.map +1 -1
  95. package/dist/cli/checkAndUpdateConfig/constants.js +1 -10
  96. package/dist/cli/checkAndUpdateConfig/updateConfig.d.ts +2 -1
  97. package/dist/cli/checkAndUpdateConfig/updateConfig.d.ts.map +1 -1
  98. package/dist/cli/checkAndUpdateConfig/updateConfig.js +17 -10
  99. package/dist/cli/checkAndUpdateConfig/utils/__tests__/prepareConfigData.test.d.ts +2 -0
  100. package/dist/cli/checkAndUpdateConfig/utils/__tests__/prepareConfigData.test.d.ts.map +1 -0
  101. package/dist/cli/checkAndUpdateConfig/utils/__tests__/prepareConfigData.test.js +20 -0
  102. package/dist/cli/checkAndUpdateConfig/utils/__tests__/removeDefaultConfigValues.test.d.ts +2 -0
  103. package/dist/cli/checkAndUpdateConfig/utils/__tests__/removeDefaultConfigValues.test.d.ts.map +1 -0
  104. package/dist/cli/checkAndUpdateConfig/utils/__tests__/removeDefaultConfigValues.test.js +35 -0
  105. package/dist/cli/checkAndUpdateConfig/utils/__tests__/validateAndMigrateConfigData.test.d.ts +2 -0
  106. package/dist/cli/checkAndUpdateConfig/utils/__tests__/validateAndMigrateConfigData.test.d.ts.map +1 -0
  107. package/dist/cli/checkAndUpdateConfig/utils/__tests__/validateAndMigrateConfigData.test.js +59 -0
  108. package/dist/cli/checkAndUpdateConfig/utils/removeDefaultConfigValues.d.ts.map +1 -1
  109. package/dist/cli/checkAndUpdateConfig/utils/selectConfigAction.d.ts.map +1 -1
  110. package/dist/cli/checkAndUpdateConfig/utils/selectConfigAction.js +6 -3
  111. package/dist/cli/checkAndUpdateConfig/utils/updateExistingConfigFile.d.ts.map +1 -1
  112. package/dist/cli/checkAndUpdateConfig/utils/updateExistingConfigFile.js +3 -2
  113. package/dist/cli/checkAndUpdateConfig/utils/validateAndMigrateConfigData.d.ts.map +1 -1
  114. package/dist/cli/checkAndUpdateConfig/utils/validateAndMigrateConfigData.js +19 -1
  115. package/dist/cli/checkAndUpdateConfig/utils/validateExecutorSetup.d.ts +6 -0
  116. package/dist/cli/checkAndUpdateConfig/utils/validateExecutorSetup.d.ts.map +1 -0
  117. package/dist/cli/checkAndUpdateConfig/utils/validateExecutorSetup.js +55 -0
  118. package/dist/cli/checkAndUpdateConfig/utils/writeConfigFile.d.ts +1 -1
  119. package/dist/cli/checkAndUpdateConfig/utils/writeConfigFile.d.ts.map +1 -1
  120. package/dist/cli/checkAndUpdateConfig/utils/writeConfigFile.js +1 -1
  121. package/dist/cli/checkAndUpdateConfig/utils/writeExampleConfigFile.d.ts.map +1 -1
  122. package/dist/cli/checkAndUpdateConfig/utils/writeExampleConfigFile.js +2 -2
  123. package/dist/cli/generateOpenApiClient/__tests__/generateOpenApiClient.strict.test.d.ts +2 -0
  124. package/dist/cli/generateOpenApiClient/__tests__/generateOpenApiClient.strict.test.d.ts.map +1 -0
  125. package/dist/cli/generateOpenApiClient/__tests__/generateOpenApiClient.strict.test.js +161 -0
  126. package/dist/cli/generateOpenApiClient/generateOpenApiClient.d.ts +4 -3
  127. package/dist/cli/generateOpenApiClient/generateOpenApiClient.d.ts.map +1 -1
  128. package/dist/cli/generateOpenApiClient/generateOpenApiClient.js +61 -21
  129. package/dist/cli/index.js +98 -7
  130. package/dist/cli/initOpenApiConfig/Types.d.ts +2 -0
  131. package/dist/cli/initOpenApiConfig/Types.d.ts.map +1 -1
  132. package/dist/cli/initOpenApiConfig/__tests__/init.test.d.ts +2 -0
  133. package/dist/cli/initOpenApiConfig/__tests__/init.test.d.ts.map +1 -0
  134. package/dist/cli/initOpenApiConfig/__tests__/init.test.js +20 -0
  135. package/dist/cli/initOpenApiConfig/__tests__/initConfig.test.d.ts +2 -0
  136. package/dist/cli/initOpenApiConfig/__tests__/initConfig.test.d.ts.map +1 -0
  137. package/dist/cli/initOpenApiConfig/__tests__/initConfig.test.js +49 -0
  138. package/dist/cli/initOpenApiConfig/init.d.ts +2 -1
  139. package/dist/cli/initOpenApiConfig/init.d.ts.map +1 -1
  140. package/dist/cli/initOpenApiConfig/init.js +59 -14
  141. package/dist/cli/initOpenApiConfig/initConfig.d.ts +6 -0
  142. package/dist/cli/initOpenApiConfig/initConfig.d.ts.map +1 -1
  143. package/dist/cli/initOpenApiConfig/initConfig.js +53 -26
  144. package/dist/cli/initOpenApiConfig/initCustomRequest.d.ts +10 -2
  145. package/dist/cli/initOpenApiConfig/initCustomRequest.d.ts.map +1 -1
  146. package/dist/cli/initOpenApiConfig/initCustomRequest.js +67 -9
  147. package/dist/cli/initOpenApiConfig/utils/__tests__/buildConfig.test.d.ts +2 -0
  148. package/dist/cli/initOpenApiConfig/utils/__tests__/buildConfig.test.d.ts.map +1 -0
  149. package/dist/cli/initOpenApiConfig/utils/__tests__/buildConfig.test.js +93 -0
  150. package/dist/cli/initOpenApiConfig/utils/__tests__/findSpecFiles.test.d.ts +2 -0
  151. package/dist/cli/initOpenApiConfig/utils/__tests__/findSpecFiles.test.d.ts.map +1 -0
  152. package/dist/cli/initOpenApiConfig/utils/__tests__/findSpecFiles.test.js +45 -0
  153. package/dist/cli/initOpenApiConfig/utils/__tests__/validateSpecFiles.test.d.ts +2 -0
  154. package/dist/cli/initOpenApiConfig/utils/__tests__/validateSpecFiles.test.d.ts.map +1 -0
  155. package/dist/cli/initOpenApiConfig/utils/__tests__/validateSpecFiles.test.js +61 -0
  156. package/dist/cli/initOpenApiConfig/utils/buildConfig.d.ts +6 -12
  157. package/dist/cli/initOpenApiConfig/utils/buildConfig.d.ts.map +1 -1
  158. package/dist/cli/initOpenApiConfig/utils/buildConfig.js +84 -19
  159. package/dist/cli/initOpenApiConfig/utils/registerHandlebarTemplates.d.ts.map +1 -1
  160. package/dist/cli/initOpenApiConfig/utils/registerHandlebarTemplates.js +2 -0
  161. package/dist/cli/initOpenApiConfig/utils/validateSpecFile.d.ts.map +1 -1
  162. package/dist/cli/initOpenApiConfig/utils/validateSpecFile.js +2 -1
  163. package/dist/cli/initOpenApiConfig/utils/writeConfigFile.d.ts.map +1 -1
  164. package/dist/cli/initOpenApiConfig/utils/writeConfigFile.js +2 -1
  165. package/dist/cli/interactive/confirmDialog.d.ts.map +1 -1
  166. package/dist/cli/interactive/confirmDialog.js +3 -2
  167. package/dist/cli/interactive/constants.d.ts +0 -4
  168. package/dist/cli/interactive/constants.d.ts.map +1 -1
  169. package/dist/cli/interactive/constants.js +7 -11
  170. package/dist/cli/interactive/selectDialog.d.ts.map +1 -1
  171. package/dist/cli/interactive/selectDialog.js +11 -6
  172. package/dist/cli/previewChanges/previewChanges.d.ts +2 -1
  173. package/dist/cli/previewChanges/previewChanges.d.ts.map +1 -1
  174. package/dist/cli/previewChanges/previewChanges.js +49 -21
  175. package/dist/cli/previewChanges/utils/__tests__/compareFiles.test.d.ts +2 -0
  176. package/dist/cli/previewChanges/utils/__tests__/compareFiles.test.d.ts.map +1 -0
  177. package/dist/cli/previewChanges/utils/__tests__/compareFiles.test.js +52 -0
  178. package/dist/cli/previewChanges/utils/__tests__/isDirectoryEmpty.test.d.ts +2 -0
  179. package/dist/cli/previewChanges/utils/__tests__/isDirectoryEmpty.test.d.ts.map +1 -0
  180. package/dist/cli/previewChanges/utils/__tests__/isDirectoryEmpty.test.js +43 -0
  181. package/dist/cli/previewChanges/utils/__tests__/readDirectoryRecursive.test.d.ts +2 -0
  182. package/dist/cli/previewChanges/utils/__tests__/readDirectoryRecursive.test.d.ts.map +1 -0
  183. package/dist/cli/previewChanges/utils/__tests__/readDirectoryRecursive.test.js +32 -0
  184. package/dist/cli/previewChanges/utils/__tests__/updateOutputPaths.test.d.ts +2 -0
  185. package/dist/cli/previewChanges/utils/__tests__/updateOutputPaths.test.d.ts.map +1 -0
  186. package/dist/cli/previewChanges/utils/__tests__/updateOutputPaths.test.js +68 -0
  187. package/dist/cli/previewChanges/utils/formatDiff.d.ts.map +1 -1
  188. package/dist/cli/previewChanges/utils/updateOutputPaths.d.ts.map +1 -1
  189. package/dist/cli/previewChanges/utils/updateOutputPaths.js +5 -12
  190. package/dist/cli/schemas/__tests__/checkConfigAndUpdate.test.d.ts +2 -0
  191. package/dist/cli/schemas/__tests__/checkConfigAndUpdate.test.d.ts.map +1 -0
  192. package/dist/cli/schemas/__tests__/checkConfigAndUpdate.test.js +36 -0
  193. package/dist/cli/schemas/__tests__/generateOptionsSchema.test.d.ts +2 -0
  194. package/dist/cli/schemas/__tests__/generateOptionsSchema.test.d.ts.map +1 -0
  195. package/dist/cli/schemas/__tests__/generateOptionsSchema.test.js +59 -0
  196. package/dist/cli/schemas/__tests__/initOptionsSchema.test.d.ts +2 -0
  197. package/dist/cli/schemas/__tests__/initOptionsSchema.test.d.ts.map +1 -0
  198. package/dist/cli/schemas/__tests__/initOptionsSchema.test.js +43 -0
  199. package/dist/cli/schemas/__tests__/previewChangesSchema.test.d.ts +2 -0
  200. package/dist/cli/schemas/__tests__/previewChangesSchema.test.d.ts.map +1 -0
  201. package/dist/cli/schemas/__tests__/previewChangesSchema.test.js +31 -0
  202. package/dist/cli/schemas/analyzeDiff.d.ts +14 -0
  203. package/dist/cli/schemas/analyzeDiff.d.ts.map +1 -0
  204. package/dist/cli/schemas/analyzeDiff.js +28 -0
  205. package/dist/cli/schemas/analyzeUsage.d.ts +13 -0
  206. package/dist/cli/schemas/analyzeUsage.d.ts.map +1 -0
  207. package/dist/cli/schemas/analyzeUsage.js +41 -0
  208. package/dist/cli/schemas/generate.d.ts +17 -0
  209. package/dist/cli/schemas/generate.d.ts.map +1 -1
  210. package/dist/cli/schemas/generate.js +14 -0
  211. package/dist/cli/schemas/index.d.ts +3 -1
  212. package/dist/cli/schemas/index.d.ts.map +1 -1
  213. package/dist/cli/schemas/index.js +2 -0
  214. package/dist/cli/schemas/init.d.ts +10 -0
  215. package/dist/cli/schemas/init.d.ts.map +1 -1
  216. package/dist/cli/schemas/init.js +3 -1
  217. package/dist/cli/types.d.ts +6 -0
  218. package/dist/cli/types.d.ts.map +1 -0
  219. package/dist/cli/types.js +2 -0
  220. package/dist/common/Consts.d.ts +2 -0
  221. package/dist/common/Consts.d.ts.map +1 -1
  222. package/dist/common/Consts.js +19 -1
  223. package/dist/common/Logger.d.ts +20 -1
  224. package/dist/common/Logger.d.ts.map +1 -1
  225. package/dist/common/Logger.js +70 -9
  226. package/dist/common/LoggerMessages.d.ts +194 -33
  227. package/dist/common/LoggerMessages.d.ts.map +1 -1
  228. package/dist/common/LoggerMessages.js +176 -45
  229. package/dist/common/TEslintFixOptions.d.ts +20 -0
  230. package/dist/common/TEslintFixOptions.d.ts.map +1 -0
  231. package/dist/common/TEslintFixOptions.js +15 -0
  232. package/dist/common/TRawOptions.d.ts.map +1 -1
  233. package/dist/common/VersionedSchema/AllVersionedSchemas/AllMigrationPlans.d.ts.map +1 -1
  234. package/dist/common/VersionedSchema/AllVersionedSchemas/AllMigrationPlans.js +7 -3
  235. package/dist/common/VersionedSchema/AllVersionedSchemas/AllVersionedSchemas.d.ts.map +1 -1
  236. package/dist/common/VersionedSchema/AllVersionedSchemas/AllVersionedSchemas.js +1 -1
  237. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedBase.d.ts +4 -0
  238. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedBase.d.ts.map +1 -1
  239. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedBase.js +1 -2
  240. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV1.d.ts +8 -0
  241. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV1.d.ts.map +1 -1
  242. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV1.js +1 -1
  243. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV2.d.ts +8 -0
  244. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV2.d.ts.map +1 -1
  245. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV2.js +1 -1
  246. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV3.d.ts +8 -0
  247. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV3.d.ts.map +1 -1
  248. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV4.d.ts +35 -0
  249. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV4.d.ts.map +1 -1
  250. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV4.js +4 -1
  251. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV5.d.ts +87 -0
  252. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV5.d.ts.map +1 -0
  253. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedOptionsSchemaV5.js +29 -0
  254. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedVersionedSchemas.d.ts +185 -0
  255. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedVersionedSchemas.d.ts.map +1 -1
  256. package/dist/common/VersionedSchema/AllVersionedSchemas/UnifiedVersionedSchemas.js +9 -1
  257. package/dist/common/VersionedSchema/CommonSchemas.d.ts +40 -0
  258. package/dist/common/VersionedSchema/CommonSchemas.d.ts.map +1 -1
  259. package/dist/common/VersionedSchema/CommonSchemas.js +36 -1
  260. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV1.d.ts +4 -0
  261. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV1.d.ts.map +1 -1
  262. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV2.d.ts +4 -0
  263. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV2.d.ts.map +1 -1
  264. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV2.js +1 -1
  265. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV3.d.ts +4 -0
  266. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV3.d.ts.map +1 -1
  267. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV3.js +1 -1
  268. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV4.d.ts +4 -0
  269. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV4.d.ts.map +1 -1
  270. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV4.js +1 -1
  271. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV5.d.ts +4 -0
  272. package/dist/common/VersionedSchema/MultiOptionsVersioned/MultiOptionsSchemaV5.d.ts.map +1 -1
  273. package/dist/common/VersionedSchema/OptionsVersioned/OptionsMigrationPlans.d.ts.map +1 -1
  274. package/dist/common/VersionedSchema/OptionsVersioned/OptionsSchemaV1.d.ts +6 -2
  275. package/dist/common/VersionedSchema/OptionsVersioned/OptionsSchemaV1.d.ts.map +1 -1
  276. package/dist/common/VersionedSchema/OptionsVersioned/OptionsSchemaV2.d.ts +6 -2
  277. package/dist/common/VersionedSchema/OptionsVersioned/OptionsSchemaV2.d.ts.map +1 -1
  278. package/dist/common/VersionedSchema/OptionsVersioned/OptionsSchemaV3.d.ts +4 -0
  279. package/dist/common/VersionedSchema/OptionsVersioned/OptionsSchemaV3.d.ts.map +1 -1
  280. package/dist/common/VersionedSchema/OptionsVersioned/OptionsSchemaV3.js +1 -1
  281. package/dist/common/VersionedSchema/OptionsVersioned/OptionsSchemaV4.d.ts +5 -1
  282. package/dist/common/VersionedSchema/OptionsVersioned/OptionsSchemaV4.d.ts.map +1 -1
  283. package/dist/common/VersionedSchema/Utils/__mocks__/compatibilityCases.d.ts.map +1 -1
  284. package/dist/common/VersionedSchema/Utils/__mocks__/compatibilityCases.js +29 -3
  285. package/dist/common/VersionedSchema/Utils/__tests__/allUtils.test.js +4 -16
  286. package/dist/common/VersionedSchema/Utils/__tests__/migrateDataToLatestSchemaVersion.test.js +2 -2
  287. package/dist/common/VersionedSchema/Utils/buildVersionedSchema.d.ts.map +1 -1
  288. package/dist/common/VersionedSchema/Utils/createDefaultFieldsMigration.d.ts +1 -1
  289. package/dist/common/VersionedSchema/Utils/createDefaultFieldsMigration.d.ts.map +1 -1
  290. package/dist/common/VersionedSchema/Utils/createDefaultFieldsMigration.js +1 -1
  291. package/dist/common/VersionedSchema/Utils/createTrivialMigration.d.ts.map +1 -1
  292. package/dist/common/VersionedSchema/Utils/createTrivialMigration.js +1 -1
  293. package/dist/common/VersionedSchema/Utils/determineBestMatchingSchemaVersion.d.ts.map +1 -1
  294. package/dist/common/VersionedSchema/Utils/determineBestMatchingSchemaVersion.js +4 -6
  295. package/dist/common/VersionedSchema/Utils/getLatestVersionFromMigrationPlans.d.ts.map +1 -1
  296. package/dist/common/VersionedSchema/Utils/migrateDataToLatestSchemaVersion.d.ts.map +1 -1
  297. package/dist/common/VersionedSchema/Utils/migrateDataToLatestSchemaVersion.js +7 -8
  298. package/dist/common/VersionedSchema/Utils/replaceInvalidKeysWithMappedNames.d.ts.map +1 -1
  299. package/dist/common/VersionedSchema/Utils/replaceInvalidKeysWithMappedNames.js +1 -1
  300. package/dist/common/VersionedSchema/Utils/validateAndSuggestKeyCorrections.d.ts.map +1 -1
  301. package/dist/common/VersionedSchema/refinements/dependentOptionsRefinement.d.ts +1 -1
  302. package/dist/common/VersionedSchema/refinements/dependentOptionsRefinement.d.ts.map +1 -1
  303. package/dist/common/__tests__/Logger.test.d.ts +2 -0
  304. package/dist/common/__tests__/Logger.test.d.ts.map +1 -0
  305. package/dist/common/__tests__/Logger.test.js +100 -0
  306. package/dist/common/utils/__tests__/convertArrayToObject.test.js +3 -0
  307. package/dist/common/utils/__tests__/eslintFix.test.d.ts +2 -0
  308. package/dist/common/utils/__tests__/eslintFix.test.d.ts.map +1 -0
  309. package/dist/common/utils/__tests__/eslintFix.test.js +92 -0
  310. package/dist/common/utils/__tests__/extractEslintFixOptions.test.d.ts +2 -0
  311. package/dist/common/utils/__tests__/extractEslintFixOptions.test.d.ts.map +1 -0
  312. package/dist/common/utils/__tests__/extractEslintFixOptions.test.js +28 -0
  313. package/dist/common/utils/__tests__/format.test.d.ts +2 -0
  314. package/dist/common/utils/__tests__/format.test.d.ts.map +1 -0
  315. package/dist/common/utils/__tests__/format.test.js +99 -0
  316. package/dist/common/utils/__tests__/prepareTempTsConfig.test.d.ts +2 -0
  317. package/dist/common/utils/__tests__/prepareTempTsConfig.test.d.ts.map +1 -0
  318. package/dist/common/utils/__tests__/prepareTempTsConfig.test.js +78 -0
  319. package/dist/common/utils/codegenTempDir.d.ts +20 -0
  320. package/dist/common/utils/codegenTempDir.d.ts.map +1 -0
  321. package/dist/common/utils/codegenTempDir.js +42 -0
  322. package/dist/common/utils/convertArrayToObject.d.ts.map +1 -1
  323. package/dist/common/utils/convertArrayToObject.js +6 -8
  324. package/dist/common/utils/eslintFix.d.ts +51 -0
  325. package/dist/common/utils/eslintFix.d.ts.map +1 -0
  326. package/dist/common/utils/eslintFix.js +184 -0
  327. package/dist/common/utils/format.d.ts +1 -1
  328. package/dist/common/utils/format.d.ts.map +1 -1
  329. package/dist/common/utils/format.js +51 -15
  330. package/dist/common/utils/jsonPath.d.ts +5 -0
  331. package/dist/common/utils/jsonPath.d.ts.map +1 -0
  332. package/dist/common/utils/jsonPath.js +27 -0
  333. package/dist/common/utils/prepareTempEslintConfig.d.ts +18 -0
  334. package/dist/common/utils/prepareTempEslintConfig.d.ts.map +1 -0
  335. package/dist/common/utils/prepareTempEslintConfig.js +55 -0
  336. package/dist/common/utils/prepareTempTsConfig.d.ts +23 -0
  337. package/dist/common/utils/prepareTempTsConfig.d.ts.map +1 -0
  338. package/dist/common/utils/prepareTempTsConfig.js +105 -0
  339. package/dist/core/Context.d.ts +8 -1
  340. package/dist/core/Context.d.ts.map +1 -1
  341. package/dist/core/Context.js +25 -10
  342. package/dist/core/OpenApiClient.d.ts +29 -1
  343. package/dist/core/OpenApiClient.d.ts.map +1 -1
  344. package/dist/core/OpenApiClient.js +365 -15
  345. package/dist/core/WriteClient.d.ts +86 -15
  346. package/dist/core/WriteClient.d.ts.map +1 -1
  347. package/dist/core/WriteClient.js +117 -9
  348. package/dist/core/__tests__/WriteClient.test.js +5 -1
  349. package/dist/core/api/v2/parser/__tests__/getModel.test.d.ts +2 -0
  350. package/dist/core/api/v2/parser/__tests__/getModel.test.d.ts.map +1 -0
  351. package/dist/core/api/v2/parser/__tests__/getModel.test.js +34 -0
  352. package/dist/core/api/v2/parser/getModel.d.ts.map +1 -1
  353. package/dist/core/api/v2/parser/getModel.js +6 -1
  354. package/dist/core/api/v2/parser/getOperation.d.ts.map +1 -1
  355. package/dist/core/api/v2/parser/getOperation.js +2 -0
  356. package/dist/core/api/v2/parser/getOperationResponses.d.ts.map +1 -1
  357. package/dist/core/api/v2/parser/getOperationResponses.js +7 -1
  358. package/dist/core/api/v2/parser/getServiceName.d.ts +1 -1
  359. package/dist/core/api/v2/types/OpenApiSchema.model.d.ts +2 -0
  360. package/dist/core/api/v2/types/OpenApiSchema.model.d.ts.map +1 -1
  361. package/dist/core/api/v3/parser/__tests__/getContent.test.d.ts +2 -0
  362. package/dist/core/api/v3/parser/__tests__/getContent.test.d.ts.map +1 -0
  363. package/dist/core/api/v3/parser/__tests__/getContent.test.js +65 -0
  364. package/dist/core/api/v3/parser/__tests__/getModel.test.d.ts +2 -0
  365. package/dist/core/api/v3/parser/__tests__/getModel.test.d.ts.map +1 -0
  366. package/dist/core/api/v3/parser/__tests__/getModel.test.js +34 -0
  367. package/dist/core/api/v3/parser/getContent.d.ts.map +1 -1
  368. package/dist/core/api/v3/parser/getContent.js +21 -11
  369. package/dist/core/api/v3/parser/getModel.d.ts.map +1 -1
  370. package/dist/core/api/v3/parser/getModel.js +6 -1
  371. package/dist/core/api/v3/parser/getOperation.d.ts.map +1 -1
  372. package/dist/core/api/v3/parser/getOperation.js +2 -0
  373. package/dist/core/api/v3/parser/getOperationParameters.d.ts.map +1 -1
  374. package/dist/core/api/v3/parser/getOperationResponses.d.ts.map +1 -1
  375. package/dist/core/api/v3/parser/getOperationResponses.js +7 -1
  376. package/dist/core/api/v3/parser/getServiceName.d.ts +1 -1
  377. package/dist/core/api/v3/types/OpenApiSchema.model.d.ts +2 -0
  378. package/dist/core/api/v3/types/OpenApiSchema.model.d.ts.map +1 -1
  379. package/dist/core/governance/__tests__/evaluateGovernanceRules.test.d.ts +2 -0
  380. package/dist/core/governance/__tests__/evaluateGovernanceRules.test.d.ts.map +1 -0
  381. package/dist/core/governance/__tests__/evaluateGovernanceRules.test.js +100 -0
  382. package/dist/core/governance/__tests__/loadGovernanceConfig.test.d.ts +2 -0
  383. package/dist/core/governance/__tests__/loadGovernanceConfig.test.d.ts.map +1 -0
  384. package/dist/core/governance/__tests__/loadGovernanceConfig.test.js +71 -0
  385. package/dist/core/governance/evaluateGovernanceRules.d.ts +42 -0
  386. package/dist/core/governance/evaluateGovernanceRules.d.ts.map +1 -0
  387. package/dist/core/governance/evaluateGovernanceRules.js +132 -0
  388. package/dist/core/governance/governanceConfigSchema.d.ts +4 -0
  389. package/dist/core/governance/governanceConfigSchema.d.ts.map +1 -0
  390. package/dist/core/governance/governanceConfigSchema.js +39 -0
  391. package/dist/core/governance/loadGovernanceConfig.d.ts +7 -0
  392. package/dist/core/governance/loadGovernanceConfig.d.ts.map +1 -0
  393. package/dist/core/governance/loadGovernanceConfig.js +58 -0
  394. package/dist/core/index.d.ts +3 -0
  395. package/dist/core/index.d.ts.map +1 -1
  396. package/dist/core/index.js +4 -2
  397. package/dist/core/plugins/GeneratorPlugin.model.d.ts +42 -0
  398. package/dist/core/plugins/GeneratorPlugin.model.d.ts.map +1 -0
  399. package/dist/core/plugins/GeneratorPlugin.model.js +2 -0
  400. package/dist/core/plugins/__tests__/applySemanticDiffPluginHooks.test.d.ts +2 -0
  401. package/dist/core/plugins/__tests__/applySemanticDiffPluginHooks.test.d.ts.map +1 -0
  402. package/dist/core/plugins/__tests__/applySemanticDiffPluginHooks.test.js +115 -0
  403. package/dist/core/plugins/__tests__/loadGeneratorPlugins.test.d.ts +2 -0
  404. package/dist/core/plugins/__tests__/loadGeneratorPlugins.test.d.ts.map +1 -0
  405. package/dist/core/plugins/__tests__/loadGeneratorPlugins.test.js +62 -0
  406. package/dist/core/plugins/applySemanticDiffPluginHooks.d.ts +28 -0
  407. package/dist/core/plugins/applySemanticDiffPluginHooks.d.ts.map +1 -0
  408. package/dist/core/plugins/applySemanticDiffPluginHooks.js +160 -0
  409. package/dist/core/plugins/builtins/xTypescriptTypePlugin.d.ts +6 -0
  410. package/dist/core/plugins/builtins/xTypescriptTypePlugin.d.ts.map +1 -0
  411. package/dist/core/plugins/builtins/xTypescriptTypePlugin.js +13 -0
  412. package/dist/core/plugins/getBuiltinPlugins.d.ts +6 -0
  413. package/dist/core/plugins/getBuiltinPlugins.d.ts.map +1 -0
  414. package/dist/core/plugins/getBuiltinPlugins.js +10 -0
  415. package/dist/core/plugins/index.d.ts +4 -0
  416. package/dist/core/plugins/index.d.ts.map +1 -0
  417. package/dist/core/plugins/index.js +5 -0
  418. package/dist/core/plugins/loadGeneratorPlugins.d.ts +6 -0
  419. package/dist/core/plugins/loadGeneratorPlugins.d.ts.map +1 -0
  420. package/dist/core/plugins/loadGeneratorPlugins.js +94 -0
  421. package/dist/core/semanticDiff/__tests__/analyzeOpenApiDiff.test.d.ts +2 -0
  422. package/dist/core/semanticDiff/__tests__/analyzeOpenApiDiff.test.d.ts.map +1 -0
  423. package/dist/core/semanticDiff/__tests__/analyzeOpenApiDiff.test.js +595 -0
  424. package/dist/core/semanticDiff/__tests__/semanticDiffReportSchema.test.d.ts +2 -0
  425. package/dist/core/semanticDiff/__tests__/semanticDiffReportSchema.test.d.ts.map +1 -0
  426. package/dist/core/semanticDiff/__tests__/semanticDiffReportSchema.test.js +85 -0
  427. package/dist/core/semanticDiff/analyzeOpenApiDiff.d.ts +97 -0
  428. package/dist/core/semanticDiff/analyzeOpenApiDiff.d.ts.map +1 -0
  429. package/dist/core/semanticDiff/analyzeOpenApiDiff.js +668 -0
  430. package/dist/core/semanticDiff/semanticDiffReportSchema.d.ts +16 -0
  431. package/dist/core/semanticDiff/semanticDiffReportSchema.d.ts.map +1 -0
  432. package/dist/core/semanticDiff/semanticDiffReportSchema.js +215 -0
  433. package/dist/core/strict/__tests__/validateOpenApiStrict.test.d.ts +2 -0
  434. package/dist/core/strict/__tests__/validateOpenApiStrict.test.d.ts.map +1 -0
  435. package/dist/core/strict/__tests__/validateOpenApiStrict.test.js +156 -0
  436. package/dist/core/strict/validateOpenApiStrict.d.ts +43 -0
  437. package/dist/core/strict/validateOpenApiStrict.d.ts.map +1 -0
  438. package/dist/core/strict/validateOpenApiStrict.js +253 -0
  439. package/dist/core/types/Consts.js +1 -1
  440. package/dist/core/types/DiffReport.model.d.ts +101 -0
  441. package/dist/core/types/DiffReport.model.d.ts.map +1 -0
  442. package/dist/core/types/DiffReport.model.js +5 -0
  443. package/dist/core/types/base/ClientArtifacts.model.d.ts +5 -3
  444. package/dist/core/types/base/ClientArtifacts.model.d.ts.map +1 -1
  445. package/dist/core/types/base/ExportedModel.model.d.ts +1 -1
  446. package/dist/core/types/base/ExportedModel.model.d.ts.map +1 -1
  447. package/dist/core/types/base/ExportedService.model.d.ts.map +1 -1
  448. package/dist/core/types/base/OutputPaths.model.d.ts.map +1 -1
  449. package/dist/core/types/base/PrefixArtifacts.model.d.ts.map +1 -1
  450. package/dist/core/types/base/PropertyGroup.model.d.ts +1 -1
  451. package/dist/core/types/base/SimpleClientArtifacts.model.d.ts +1 -1
  452. package/dist/core/types/base/SimpleClientArtifacts.model.d.ts.map +1 -1
  453. package/dist/core/types/base/Templates.model.d.ts +4 -0
  454. package/dist/core/types/base/Templates.model.d.ts.map +1 -1
  455. package/dist/core/types/enums/ModelsMode.enum.d.ts +5 -0
  456. package/dist/core/types/enums/ModelsMode.enum.d.ts.map +1 -0
  457. package/dist/core/types/enums/ModelsMode.enum.js +8 -0
  458. package/dist/core/types/shared/Client.model.d.ts +2 -0
  459. package/dist/core/types/shared/Client.model.d.ts.map +1 -1
  460. package/dist/core/types/shared/DiffInfo.model.d.ts +13 -0
  461. package/dist/core/types/shared/DiffInfo.model.d.ts.map +1 -0
  462. package/dist/core/types/shared/DiffInfo.model.js +2 -0
  463. package/dist/core/types/shared/Miracle.model.d.ts +13 -0
  464. package/dist/core/types/shared/Miracle.model.d.ts.map +1 -0
  465. package/dist/core/types/shared/Miracle.model.js +2 -0
  466. package/dist/core/types/shared/Model.model.d.ts +59 -0
  467. package/dist/core/types/shared/Model.model.d.ts.map +1 -1
  468. package/dist/core/types/shared/Operation.model.d.ts +5 -0
  469. package/dist/core/types/shared/Operation.model.d.ts.map +1 -1
  470. package/dist/core/utils/GenerationCache.d.ts +18 -0
  471. package/dist/core/utils/GenerationCache.d.ts.map +1 -0
  472. package/dist/core/utils/GenerationCache.js +41 -0
  473. package/dist/core/utils/__mocks__/templates.d.ts.map +1 -1
  474. package/dist/core/utils/__mocks__/templates.js +10 -0
  475. package/dist/core/utils/__tests__/GenerationCache.test.d.ts +2 -0
  476. package/dist/core/utils/__tests__/GenerationCache.test.d.ts.map +1 -0
  477. package/dist/core/utils/__tests__/GenerationCache.test.js +37 -0
  478. package/dist/core/utils/__tests__/applyDiffReportToClient.test.d.ts +2 -0
  479. package/dist/core/utils/__tests__/applyDiffReportToClient.test.d.ts.map +1 -0
  480. package/dist/core/utils/__tests__/applyDiffReportToClient.test.js +290 -0
  481. package/dist/core/utils/__tests__/buildMiraclesFromSemanticChanges.test.d.ts +2 -0
  482. package/dist/core/utils/__tests__/buildMiraclesFromSemanticChanges.test.d.ts.map +1 -0
  483. package/dist/core/utils/__tests__/buildMiraclesFromSemanticChanges.test.js +77 -0
  484. package/dist/core/utils/__tests__/expandOpenApiRefsForSemanticDiff.test.d.ts +2 -0
  485. package/dist/core/utils/__tests__/expandOpenApiRefsForSemanticDiff.test.d.ts.map +1 -0
  486. package/dist/core/utils/__tests__/expandOpenApiRefsForSemanticDiff.test.js +159 -0
  487. package/dist/core/utils/__tests__/getMappedType.test.js +2 -0
  488. package/dist/core/utils/__tests__/getOperationResponseCode.test.js +7 -2
  489. package/dist/core/utils/__tests__/getOperationResults.test.d.ts +2 -0
  490. package/dist/core/utils/__tests__/getOperationResults.test.d.ts.map +1 -0
  491. package/dist/core/utils/__tests__/getOperationResults.test.js +43 -0
  492. package/dist/core/utils/__tests__/loadDiffReport.test.d.ts +2 -0
  493. package/dist/core/utils/__tests__/loadDiffReport.test.d.ts.map +1 -0
  494. package/dist/core/utils/__tests__/loadDiffReport.test.js +246 -0
  495. package/dist/core/utils/__tests__/modelHelpers.test.js +27 -9
  496. package/dist/core/utils/__tests__/postProcessModelImports.test.js +1 -4
  497. package/dist/core/utils/__tests__/postProcessServiceImports.test.js +1 -4
  498. package/dist/core/utils/__tests__/prepareDtoModels.test.d.ts +2 -0
  499. package/dist/core/utils/__tests__/prepareDtoModels.test.d.ts.map +1 -0
  500. package/dist/core/utils/__tests__/prepareDtoModels.test.js +283 -0
  501. package/dist/core/utils/__tests__/registerHandlebarHelpers.test.js +27 -0
  502. package/dist/core/utils/__tests__/resolveClassesModeTypes.test.d.ts +2 -0
  503. package/dist/core/utils/__tests__/resolveClassesModeTypes.test.d.ts.map +1 -0
  504. package/dist/core/utils/__tests__/resolveClassesModeTypes.test.js +111 -0
  505. package/dist/core/utils/__tests__/semanticChangesToDiffEntries.test.d.ts +2 -0
  506. package/dist/core/utils/__tests__/semanticChangesToDiffEntries.test.d.ts.map +1 -0
  507. package/dist/core/utils/__tests__/semanticChangesToDiffEntries.test.js +68 -0
  508. package/dist/core/utils/__tests__/serviceHelpers.test.js +11 -11
  509. package/dist/core/utils/__tests__/sortByRequiredExtended.test.js +10 -27
  510. package/dist/core/utils/__tests__/templateRendering.test.d.ts +2 -0
  511. package/dist/core/utils/__tests__/templateRendering.test.d.ts.map +1 -0
  512. package/dist/core/utils/__tests__/templateRendering.test.js +190 -0
  513. package/dist/core/utils/__tests__/writeClientModels.test.js +50 -0
  514. package/dist/core/utils/__tests__/writeFileIfChanged.test.d.ts +2 -0
  515. package/dist/core/utils/__tests__/writeFileIfChanged.test.d.ts.map +1 -0
  516. package/dist/core/utils/__tests__/writeFileIfChanged.test.js +30 -0
  517. package/dist/core/utils/adapters/__tests__/semanticToStructural.test.d.ts +2 -0
  518. package/dist/core/utils/adapters/__tests__/semanticToStructural.test.d.ts.map +1 -0
  519. package/dist/core/utils/adapters/__tests__/semanticToStructural.test.js +63 -0
  520. package/dist/core/utils/adapters/extractMiraclesFromSemantic.d.ts +10 -0
  521. package/dist/core/utils/adapters/extractMiraclesFromSemantic.d.ts.map +1 -0
  522. package/dist/core/utils/adapters/extractMiraclesFromSemantic.js +13 -0
  523. package/dist/core/utils/adapters/index.d.ts +3 -0
  524. package/dist/core/utils/adapters/index.d.ts.map +1 -0
  525. package/dist/core/utils/adapters/index.js +6 -0
  526. package/dist/core/utils/adapters/semanticToStructural.d.ts +12 -0
  527. package/dist/core/utils/adapters/semanticToStructural.d.ts.map +1 -0
  528. package/dist/core/utils/adapters/semanticToStructural.js +36 -0
  529. package/dist/core/utils/applyDiffReportToClient.d.ts +26 -0
  530. package/dist/core/utils/applyDiffReportToClient.d.ts.map +1 -0
  531. package/dist/core/utils/applyDiffReportToClient.js +447 -0
  532. package/dist/core/utils/areEqual.d.ts +1 -1
  533. package/dist/core/utils/buildMiraclesFromSemanticChanges.d.ts +25 -0
  534. package/dist/core/utils/buildMiraclesFromSemanticChanges.d.ts.map +1 -0
  535. package/dist/core/utils/buildMiraclesFromSemanticChanges.js +146 -0
  536. package/dist/core/utils/expandOpenApiRefsForSemanticDiff.d.ts +23 -0
  537. package/dist/core/utils/expandOpenApiRefsForSemanticDiff.d.ts.map +1 -0
  538. package/dist/core/utils/expandOpenApiRefsForSemanticDiff.js +163 -0
  539. package/dist/core/utils/getMappedType.d.ts.map +1 -1
  540. package/dist/core/utils/getMappedType.js +2 -0
  541. package/dist/core/utils/getOpenApiSpec.d.ts +6 -0
  542. package/dist/core/utils/getOpenApiSpec.d.ts.map +1 -1
  543. package/dist/core/utils/getOpenApiSpec.js +7 -14
  544. package/dist/core/utils/getOperationErrors.d.ts +2 -2
  545. package/dist/core/utils/getOperationErrors.d.ts.map +1 -1
  546. package/dist/core/utils/getOperationResponseCode.d.ts.map +1 -1
  547. package/dist/core/utils/getOperationResponseCode.js +10 -8
  548. package/dist/core/utils/getOperationResults.d.ts +1 -1
  549. package/dist/core/utils/getPropertyGroupSimple.d.ts.map +1 -1
  550. package/dist/core/utils/getPropertyGroupSimple.js +1 -3
  551. package/dist/core/utils/isSubdirectory.d.ts.map +1 -1
  552. package/dist/core/utils/loadDiffReport.d.ts +20 -0
  553. package/dist/core/utils/loadDiffReport.d.ts.map +1 -0
  554. package/dist/core/utils/loadDiffReport.js +117 -0
  555. package/dist/core/utils/loadSemanticOpenApiSpec.d.ts +15 -0
  556. package/dist/core/utils/loadSemanticOpenApiSpec.d.ts.map +1 -0
  557. package/dist/core/utils/loadSemanticOpenApiSpec.js +61 -0
  558. package/dist/core/utils/modelHelpers.d.ts +13 -5
  559. package/dist/core/utils/modelHelpers.d.ts.map +1 -1
  560. package/dist/core/utils/modelHelpers.js +28 -23
  561. package/dist/core/utils/normalizeString.d.ts.map +1 -1
  562. package/dist/core/utils/normalizeString.js +1 -5
  563. package/dist/core/utils/postProcessServiceImports.d.ts.map +1 -1
  564. package/dist/core/utils/postProcessServiceImports.js +1 -3
  565. package/dist/core/utils/precompileTemplates.js +4 -2
  566. package/dist/core/utils/prepareAlias.d.ts +1 -1
  567. package/dist/core/utils/prepareDtoModels.d.ts +8 -0
  568. package/dist/core/utils/prepareDtoModels.d.ts.map +1 -0
  569. package/dist/core/utils/prepareDtoModels.js +226 -0
  570. package/dist/core/utils/registerHandlebarHelpers.d.ts +1 -0
  571. package/dist/core/utils/registerHandlebarHelpers.d.ts.map +1 -1
  572. package/dist/core/utils/registerHandlebarHelpers.js +7 -1
  573. package/dist/core/utils/registerHandlebarTemplates.d.ts +1 -0
  574. package/dist/core/utils/registerHandlebarTemplates.d.ts.map +1 -1
  575. package/dist/core/utils/registerHandlebarTemplates.js +8 -0
  576. package/dist/core/utils/resolveClassesModeTypes.d.ts +8 -0
  577. package/dist/core/utils/resolveClassesModeTypes.d.ts.map +1 -0
  578. package/dist/core/utils/resolveClassesModeTypes.js +77 -0
  579. package/dist/core/utils/semanticChangesToDiffEntries.d.ts +28 -0
  580. package/dist/core/utils/semanticChangesToDiffEntries.d.ts.map +1 -0
  581. package/dist/core/utils/semanticChangesToDiffEntries.js +98 -0
  582. package/dist/core/utils/semanticPointerToJsonPath.d.ts +7 -0
  583. package/dist/core/utils/semanticPointerToJsonPath.d.ts.map +1 -0
  584. package/dist/core/utils/semanticPointerToJsonPath.js +67 -0
  585. package/dist/core/utils/serviceHelpers.d.ts +6 -7
  586. package/dist/core/utils/serviceHelpers.d.ts.map +1 -1
  587. package/dist/core/utils/serviceHelpers.js +8 -25
  588. package/dist/core/utils/sortModelByName.d.ts +1 -1
  589. package/dist/core/utils/validateRawOptions.d.ts +1 -1
  590. package/dist/core/utils/validateRawOptions.d.ts.map +1 -1
  591. package/dist/core/utils/validateRawOptions.js +6 -4
  592. package/dist/core/utils/writeClientCore.d.ts +4 -0
  593. package/dist/core/utils/writeClientCore.d.ts.map +1 -1
  594. package/dist/core/utils/writeClientCore.js +44 -17
  595. package/dist/core/utils/writeClientCoreIndex.d.ts +1 -0
  596. package/dist/core/utils/writeClientCoreIndex.d.ts.map +1 -1
  597. package/dist/core/utils/writeClientCoreIndex.js +16 -6
  598. package/dist/core/utils/writeClientExecutor.d.ts +1 -1
  599. package/dist/core/utils/writeClientExecutor.d.ts.map +1 -1
  600. package/dist/core/utils/writeClientExecutor.js +6 -7
  601. package/dist/core/utils/writeClientFullIndex.d.ts.map +1 -1
  602. package/dist/core/utils/writeClientFullIndex.js +7 -5
  603. package/dist/core/utils/writeClientModels.d.ts +5 -0
  604. package/dist/core/utils/writeClientModels.d.ts.map +1 -1
  605. package/dist/core/utils/writeClientModels.js +29 -10
  606. package/dist/core/utils/writeClientModelsIndex.d.ts +2 -0
  607. package/dist/core/utils/writeClientModelsIndex.d.ts.map +1 -1
  608. package/dist/core/utils/writeClientModelsIndex.js +16 -6
  609. package/dist/core/utils/writeClientSchemas.d.ts +1 -1
  610. package/dist/core/utils/writeClientSchemas.d.ts.map +1 -1
  611. package/dist/core/utils/writeClientSchemas.js +9 -10
  612. package/dist/core/utils/writeClientSchemasIndex.d.ts.map +1 -1
  613. package/dist/core/utils/writeClientSchemasIndex.js +14 -4
  614. package/dist/core/utils/writeClientServices.d.ts +15 -14
  615. package/dist/core/utils/writeClientServices.d.ts.map +1 -1
  616. package/dist/core/utils/writeClientServices.js +12 -15
  617. package/dist/core/utils/writeClientServicesIndex.d.ts.map +1 -1
  618. package/dist/core/utils/writeClientServicesIndex.js +14 -4
  619. package/dist/core/utils/writeClientSimpleIndex.js +4 -4
  620. package/dist/core/utils/writeFileIfChanged.d.ts +3 -0
  621. package/dist/core/utils/writeFileIfChanged.d.ts.map +1 -0
  622. package/dist/core/utils/writeFileIfChanged.js +22 -0
  623. package/dist/templatesCompiled/cli/customCreateExecutorAdapter.d.ts +8 -0
  624. package/dist/templatesCompiled/cli/customCreateExecutorAdapter.d.ts.map +1 -0
  625. package/dist/templatesCompiled/cli/customCreateExecutorAdapter.js +18 -0
  626. package/dist/templatesCompiled/cli/customRequest.js +7 -7
  627. package/dist/templatesCompiled/cli/customRequestExecutor.js +7 -7
  628. package/dist/templatesCompiled/cli/openApiConfig.d.ts +4 -1
  629. package/dist/templatesCompiled/cli/openApiConfig.d.ts.map +1 -1
  630. package/dist/templatesCompiled/cli/openApiConfig.js +88 -37
  631. package/dist/templatesCompiled/client/core/ApiError.js +1 -1
  632. package/dist/templatesCompiled/client/core/ApiRequestOptions.js +1 -1
  633. package/dist/templatesCompiled/client/core/BaseDto.d.ts +8 -0
  634. package/dist/templatesCompiled/client/core/BaseDto.d.ts.map +1 -0
  635. package/dist/templatesCompiled/client/core/BaseDto.js +18 -0
  636. package/dist/templatesCompiled/client/core/axios/getResponseBody.js +1 -1
  637. package/dist/templatesCompiled/client/core/axios/request.js +2 -2
  638. package/dist/templatesCompiled/client/core/axios/sendRequest.js +4 -4
  639. package/dist/templatesCompiled/client/core/dtoUtils.d.ts +8 -0
  640. package/dist/templatesCompiled/client/core/dtoUtils.d.ts.map +1 -0
  641. package/dist/templatesCompiled/client/core/dtoUtils.js +18 -0
  642. package/dist/templatesCompiled/client/core/executor/createExecutorAdapter.d.ts +0 -6
  643. package/dist/templatesCompiled/client/core/executor/createExecutorAdapter.d.ts.map +1 -1
  644. package/dist/templatesCompiled/client/core/executor/createExecutorAdapter.js +3 -22
  645. package/dist/templatesCompiled/client/core/executor/legacyRequestAdapter.d.ts +11 -0
  646. package/dist/templatesCompiled/client/core/executor/legacyRequestAdapter.d.ts.map +1 -0
  647. package/dist/templatesCompiled/client/core/executor/legacyRequestAdapter.js +28 -0
  648. package/dist/templatesCompiled/client/core/executor/requestExecutor.d.ts +2 -0
  649. package/dist/templatesCompiled/client/core/executor/requestExecutor.d.ts.map +1 -1
  650. package/dist/templatesCompiled/client/core/executor/requestExecutor.js +8 -2
  651. package/dist/templatesCompiled/client/core/fetch/getResponseBody.js +1 -1
  652. package/dist/templatesCompiled/client/core/fetch/request.js +2 -2
  653. package/dist/templatesCompiled/client/core/functions/catchErrors.js +1 -1
  654. package/dist/templatesCompiled/client/core/functions/isBinary.js +1 -1
  655. package/dist/templatesCompiled/client/core/interceptors/apiErrorInterceptor.js +1 -1
  656. package/dist/templatesCompiled/client/core/interceptors/interceptors.js +1 -1
  657. package/dist/templatesCompiled/client/core/interceptors/withInterceptors.js +1 -1
  658. package/dist/templatesCompiled/client/core/node/getResponseBody.js +1 -1
  659. package/dist/templatesCompiled/client/core/node/request.js +2 -2
  660. package/dist/templatesCompiled/client/core/xhr/getResponseBody.js +1 -1
  661. package/dist/templatesCompiled/client/core/xhr/request.js +2 -2
  662. package/dist/templatesCompiled/client/core/xhr/sendRequest.js +4 -4
  663. package/dist/templatesCompiled/client/exportClient.d.ts +0 -4
  664. package/dist/templatesCompiled/client/exportClient.d.ts.map +1 -1
  665. package/dist/templatesCompiled/client/exportClient.js +9 -45
  666. package/dist/templatesCompiled/client/exportModels.d.ts +40 -0
  667. package/dist/templatesCompiled/client/exportModels.d.ts.map +1 -0
  668. package/dist/templatesCompiled/client/exportModels.js +327 -0
  669. package/dist/templatesCompiled/client/exportService.d.ts +13 -7
  670. package/dist/templatesCompiled/client/exportService.d.ts.map +1 -1
  671. package/dist/templatesCompiled/client/exportService.js +109 -62
  672. package/dist/templatesCompiled/client/indexCore.d.ts +3 -1
  673. package/dist/templatesCompiled/client/indexCore.d.ts.map +1 -1
  674. package/dist/templatesCompiled/client/indexCore.js +14 -3
  675. package/dist/templatesCompiled/client/indexFull.d.ts +9 -7
  676. package/dist/templatesCompiled/client/indexFull.d.ts.map +1 -1
  677. package/dist/templatesCompiled/client/indexFull.js +59 -41
  678. package/dist/templatesCompiled/client/indexModels.d.ts +7 -5
  679. package/dist/templatesCompiled/client/indexModels.d.ts.map +1 -1
  680. package/dist/templatesCompiled/client/indexModels.js +27 -18
  681. package/dist/templatesCompiled/client/indexSimple.js +2 -2
  682. package/dist/templatesCompiled/client/joi/partials/joiSchemaGeneric.d.ts +27 -19
  683. package/dist/templatesCompiled/client/joi/partials/joiSchemaGeneric.d.ts.map +1 -1
  684. package/dist/templatesCompiled/client/joi/partials/joiSchemaGeneric.js +144 -63
  685. package/dist/templatesCompiled/client/jsonschema/exportSchema.d.ts +1 -0
  686. package/dist/templatesCompiled/client/jsonschema/exportSchema.d.ts.map +1 -1
  687. package/dist/templatesCompiled/client/jsonschema/exportSchema.js +17 -13
  688. package/dist/templatesCompiled/client/partials/exportInterface.d.ts +13 -5
  689. package/dist/templatesCompiled/client/partials/exportInterface.d.ts.map +1 -1
  690. package/dist/templatesCompiled/client/partials/exportInterface.js +91 -21
  691. package/dist/templatesCompiled/client/partials/header.d.ts +1 -0
  692. package/dist/templatesCompiled/client/partials/header.d.ts.map +1 -1
  693. package/dist/templatesCompiled/client/partials/header.js +11 -2
  694. package/dist/templatesCompiled/client/partials/result.d.ts +6 -4
  695. package/dist/templatesCompiled/client/partials/result.d.ts.map +1 -1
  696. package/dist/templatesCompiled/client/partials/result.js +16 -6
  697. package/dist/templatesCompiled/client/partials/serviceOption.d.ts +1 -0
  698. package/dist/templatesCompiled/client/partials/serviceOption.d.ts.map +1 -1
  699. package/dist/templatesCompiled/client/partials/serviceOption.js +11 -4
  700. package/dist/templatesCompiled/client/yup/partials/yupSchemaGeneric.d.ts +22 -16
  701. package/dist/templatesCompiled/client/yup/partials/yupSchemaGeneric.d.ts.map +1 -1
  702. package/dist/templatesCompiled/client/yup/partials/yupSchemaGeneric.js +72 -60
  703. package/dist/templatesCompiled/client/zod/partials/zodSchemaGeneric.d.ts +27 -19
  704. package/dist/templatesCompiled/client/zod/partials/zodSchemaGeneric.d.ts.map +1 -1
  705. package/dist/templatesCompiled/client/zod/partials/zodSchemaGeneric.js +77 -61
  706. package/dist/test/helpers/silenceLoggers.d.ts +11 -0
  707. package/dist/test/helpers/silenceLoggers.d.ts.map +1 -0
  708. package/dist/test/helpers/silenceLoggers.js +88 -0
  709. package/package.json +132 -134
  710. package/dist/common/VersionedSchema/refinements/singleOrMultiRefinement.d.ts +0 -4
  711. package/dist/common/VersionedSchema/refinements/singleOrMultiRefinement.d.ts.map +0 -1
  712. package/dist/common/VersionedSchema/refinements/singleOrMultiRefinement.js +0 -21
  713. package/dist/core/utils/appendUniqueLinesToFile.d.ts +0 -2
  714. package/dist/core/utils/appendUniqueLinesToFile.d.ts.map +0 -1
  715. package/dist/core/utils/appendUniqueLinesToFile.js +0 -24
@@ -0,0 +1,668 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.SEMANTIC_DIFF_REPORT_SCHEMA_VERSION = void 0;
7
+ exports.analyzeOpenApiDiff = analyzeOpenApiDiff;
8
+ exports.writeSemanticDiffReport = writeSemanticDiffReport;
9
+ const path_1 = __importDefault(require("path"));
10
+ const fileSystemHelpers_1 = require("../../common/utils/fileSystemHelpers");
11
+ const format_1 = require("../../common/utils/format");
12
+ const pathHelpers_1 = require("../../common/utils/pathHelpers");
13
+ const evaluateGovernanceRules_1 = require("../governance/evaluateGovernanceRules");
14
+ /** Версия схемы семантического diff-отчёта. */
15
+ exports.SEMANTIC_DIFF_REPORT_SCHEMA_VERSION = '1.1.0';
16
+ const HTTP_METHODS = ['get', 'put', 'post', 'delete', 'options', 'head', 'patch', 'trace'];
17
+ /**
18
+ * Extracts OpenAPI v2/v3 schema container from a loaded spec.
19
+ */
20
+ function getSchemaContainer(spec) {
21
+ const specRecord = spec;
22
+ const components = specRecord.components;
23
+ const schemas = components?.schemas;
24
+ const definitions = specRecord.definitions;
25
+ if (schemas && typeof schemas === 'object') {
26
+ return schemas;
27
+ }
28
+ if (definitions && typeof definitions === 'object') {
29
+ return definitions;
30
+ }
31
+ return {};
32
+ }
33
+ /**
34
+ * Normalizes schema into a comparable type descriptor.
35
+ */
36
+ function getSchemaType(schema) {
37
+ if (!schema || typeof schema !== 'object') {
38
+ return 'unknown';
39
+ }
40
+ const schemaRecord = schema;
41
+ const schemaRef = schemaRecord.$ref;
42
+ if (typeof schemaRef === 'string') {
43
+ return `ref:${schemaRef}`;
44
+ }
45
+ const enumValues = schemaRecord.enum;
46
+ if (Array.isArray(enumValues)) {
47
+ const values = enumValues.map(item => String(item)).sort();
48
+ return `enum(${values.join('|')})`;
49
+ }
50
+ const schemaType = schemaRecord.type;
51
+ if (schemaType === 'array') {
52
+ return `array<${getSchemaType(schemaRecord.items)}>`;
53
+ }
54
+ if (Array.isArray(schemaRecord.oneOf)) {
55
+ const unionTypes = schemaRecord.oneOf.map(item => getSchemaType(item)).sort();
56
+ return `oneOf(${unionTypes.join('|')})`;
57
+ }
58
+ if (Array.isArray(schemaRecord.anyOf)) {
59
+ const unionTypes = schemaRecord.anyOf.map(item => getSchemaType(item)).sort();
60
+ return `anyOf(${unionTypes.join('|')})`;
61
+ }
62
+ if (Array.isArray(schemaRecord.allOf)) {
63
+ const intersectionTypes = schemaRecord.allOf.map(item => getSchemaType(item)).sort();
64
+ return `allOf(${intersectionTypes.join('&')})`;
65
+ }
66
+ if (typeof schemaType === 'string') {
67
+ const schemaFormat = schemaRecord.format;
68
+ if (typeof schemaFormat === 'string' && schemaFormat.trim()) {
69
+ return `${schemaType}:${schemaFormat}`;
70
+ }
71
+ return schemaType;
72
+ }
73
+ const properties = schemaRecord.properties;
74
+ if (properties && typeof properties === 'object') {
75
+ return 'object';
76
+ }
77
+ return 'unknown';
78
+ }
79
+ /**
80
+ * Classifies a type transition by severity for semantic diff.
81
+ */
82
+ function classifyTypeTransition(fromType, toType) {
83
+ if (fromType === toType) {
84
+ return 'informational';
85
+ }
86
+ if (isTypeAssignable(fromType, toType)) {
87
+ return 'non-breaking';
88
+ }
89
+ return 'breaking';
90
+ }
91
+ /**
92
+ * Splits descriptor content by top-level delimiter while preserving nested blocks.
93
+ */
94
+ function splitTopLevel(input, delimiter) {
95
+ const result = [];
96
+ let buffer = '';
97
+ let depth = 0;
98
+ for (const char of input) {
99
+ if (char === '(' || char === '<') {
100
+ depth += 1;
101
+ buffer += char;
102
+ continue;
103
+ }
104
+ if (char === ')' || char === '>') {
105
+ depth = Math.max(0, depth - 1);
106
+ buffer += char;
107
+ continue;
108
+ }
109
+ if (char === delimiter && depth === 0) {
110
+ if (buffer.trim()) {
111
+ result.push(buffer.trim());
112
+ }
113
+ buffer = '';
114
+ continue;
115
+ }
116
+ buffer += char;
117
+ }
118
+ if (buffer.trim()) {
119
+ result.push(buffer.trim());
120
+ }
121
+ return result;
122
+ }
123
+ /**
124
+ * Extracts descriptor arguments for pattern prefix(...)
125
+ */
126
+ function extractDescriptorArgs(descriptor, prefix) {
127
+ if (!descriptor.startsWith(`${prefix}(`) || !descriptor.endsWith(')')) {
128
+ return null;
129
+ }
130
+ const inner = descriptor.slice(prefix.length + 1, -1);
131
+ if (!inner.trim()) {
132
+ return [];
133
+ }
134
+ const separator = prefix === 'allOf' ? '&' : '|';
135
+ return splitTopLevel(inner, separator);
136
+ }
137
+ /**
138
+ * Parses array descriptor array<...>.
139
+ */
140
+ function extractArrayItemType(descriptor) {
141
+ if (!descriptor.startsWith('array<') || !descriptor.endsWith('>')) {
142
+ return null;
143
+ }
144
+ return descriptor.slice('array<'.length, -1);
145
+ }
146
+ /**
147
+ * Parses scalar descriptor into base and format parts.
148
+ */
149
+ function parseScalarDescriptor(descriptor) {
150
+ const [base, ...formatParts] = descriptor.split(':');
151
+ if (!base) {
152
+ return { base: descriptor, format: null };
153
+ }
154
+ if (formatParts.length === 0) {
155
+ return { base, format: null };
156
+ }
157
+ return {
158
+ base,
159
+ format: formatParts.join(':'),
160
+ };
161
+ }
162
+ /**
163
+ * Checks whether format transition is widening for a given base type.
164
+ */
165
+ function isFormatAssignable(baseType, fromFormat, toFormat) {
166
+ if (fromFormat === toFormat) {
167
+ return true;
168
+ }
169
+ if (fromFormat && !toFormat) {
170
+ return true;
171
+ }
172
+ if (!fromFormat && toFormat) {
173
+ return false;
174
+ }
175
+ if (!fromFormat || !toFormat) {
176
+ return true;
177
+ }
178
+ if (baseType === 'integer') {
179
+ if (fromFormat === 'int32' && toFormat === 'int64') {
180
+ return true;
181
+ }
182
+ if (fromFormat === 'int64' && toFormat === 'int32') {
183
+ return false;
184
+ }
185
+ }
186
+ if (baseType === 'number') {
187
+ if (fromFormat === 'float' && toFormat === 'double') {
188
+ return true;
189
+ }
190
+ if (fromFormat === 'double' && toFormat === 'float') {
191
+ return false;
192
+ }
193
+ }
194
+ return false;
195
+ }
196
+ /**
197
+ * Compares two scalar type descriptors without composite wrappers.
198
+ */
199
+ function isScalarTypeAssignable(fromType, toType) {
200
+ if (fromType === toType) {
201
+ return true;
202
+ }
203
+ if (toType === 'any' || toType === 'unknown') {
204
+ return true;
205
+ }
206
+ if (fromType === 'any' || fromType === 'unknown') {
207
+ return false;
208
+ }
209
+ const fromRef = fromType.startsWith('ref:');
210
+ const toRef = toType.startsWith('ref:');
211
+ if (fromRef || toRef) {
212
+ if (!fromRef || !toRef) {
213
+ return false;
214
+ }
215
+ return fromType === toType;
216
+ }
217
+ const { base: fromBase, format: fromFormat } = parseScalarDescriptor(fromType);
218
+ const { base: toBase, format: toFormat } = parseScalarDescriptor(toType);
219
+ if (fromBase === toBase) {
220
+ return isFormatAssignable(fromBase, fromFormat, toFormat);
221
+ }
222
+ if (fromBase === 'integer' && toBase === 'number') {
223
+ return true;
224
+ }
225
+ return false;
226
+ }
227
+ /**
228
+ * Checks assignability: true means change from -> to is widening or neutral.
229
+ */
230
+ function isTypeAssignable(fromType, toType) {
231
+ if (fromType === toType) {
232
+ return true;
233
+ }
234
+ const fromArrayItem = extractArrayItemType(fromType);
235
+ const toArrayItem = extractArrayItemType(toType);
236
+ if (fromArrayItem !== null || toArrayItem !== null) {
237
+ if (fromArrayItem === null || toArrayItem === null) {
238
+ return false;
239
+ }
240
+ return isTypeAssignable(fromArrayItem, toArrayItem);
241
+ }
242
+ const fromEnum = extractDescriptorArgs(fromType, 'enum');
243
+ const toEnum = extractDescriptorArgs(toType, 'enum');
244
+ if (fromEnum !== null || toEnum !== null) {
245
+ if (fromEnum === null || toEnum === null) {
246
+ return false;
247
+ }
248
+ return fromEnum.every(value => toEnum.includes(value));
249
+ }
250
+ const fromOneOf = extractDescriptorArgs(fromType, 'oneOf') ?? extractDescriptorArgs(fromType, 'anyOf');
251
+ if (fromOneOf !== null) {
252
+ return fromOneOf.every(option => isTypeAssignable(option, toType));
253
+ }
254
+ const toOneOf = extractDescriptorArgs(toType, 'oneOf') ?? extractDescriptorArgs(toType, 'anyOf');
255
+ if (toOneOf !== null) {
256
+ return toOneOf.some(option => isTypeAssignable(fromType, option));
257
+ }
258
+ const fromAllOf = extractDescriptorArgs(fromType, 'allOf');
259
+ if (fromAllOf !== null) {
260
+ return fromAllOf.some(option => isTypeAssignable(option, toType));
261
+ }
262
+ const toAllOf = extractDescriptorArgs(toType, 'allOf');
263
+ if (toAllOf !== null) {
264
+ return toAllOf.every(option => isTypeAssignable(fromType, option));
265
+ }
266
+ return isScalarTypeAssignable(fromType, toType);
267
+ }
268
+ /**
269
+ * Builds canonical model map from v2/v3 schema section.
270
+ */
271
+ function buildCanonicalModels(spec) {
272
+ const models = new Map();
273
+ const schemas = getSchemaContainer(spec);
274
+ for (const [name, schema] of Object.entries(schemas)) {
275
+ const propertiesMap = new Map();
276
+ const schemaProperties = schema.properties;
277
+ if (schemaProperties && typeof schemaProperties === 'object') {
278
+ for (const [propertyName, propertySchema] of Object.entries(schemaProperties)) {
279
+ propertiesMap.set(propertyName, getSchemaType(propertySchema));
280
+ }
281
+ }
282
+ const requiredRaw = schema.required;
283
+ const required = Array.isArray(requiredRaw) ? new Set(requiredRaw.map(value => String(value))) : new Set();
284
+ const modelEnumRaw = schema.enum;
285
+ const modelEnum = Array.isArray(modelEnumRaw) ? new Set(modelEnumRaw.map(value => String(value))) : new Set();
286
+ models.set(name, {
287
+ properties: propertiesMap,
288
+ required,
289
+ enumValues: modelEnum,
290
+ });
291
+ }
292
+ return models;
293
+ }
294
+ /**
295
+ * Checks whether response key is an explicit successful HTTP status key.
296
+ */
297
+ function isSuccessResponseKey(value) {
298
+ return /^\s*2\d\d\s*$/.test(value) || /^\s*2xx\s*$/i.test(value);
299
+ }
300
+ /**
301
+ * Resolves response payload schema type for OpenAPI v2/v3 response object.
302
+ */
303
+ function getResponsePayloadType(response) {
304
+ if (!response || typeof response !== 'object') {
305
+ return 'unknown';
306
+ }
307
+ const responseRecord = response;
308
+ const content = responseRecord.content;
309
+ if (content && typeof content === 'object') {
310
+ const jsonContent = content['application/json'];
311
+ if (jsonContent && typeof jsonContent === 'object') {
312
+ const jsonSchema = jsonContent.schema;
313
+ if (jsonSchema) {
314
+ return getSchemaType(jsonSchema);
315
+ }
316
+ }
317
+ for (const mediaTypeObject of Object.values(content)) {
318
+ if (!mediaTypeObject || typeof mediaTypeObject !== 'object') {
319
+ continue;
320
+ }
321
+ const mediaSchema = mediaTypeObject.schema;
322
+ if (mediaSchema) {
323
+ return getSchemaType(mediaSchema);
324
+ }
325
+ }
326
+ }
327
+ return getSchemaType(responseRecord.schema);
328
+ }
329
+ /**
330
+ * Builds canonical operation map from OpenAPI paths.
331
+ */
332
+ function buildCanonicalOperations(spec) {
333
+ const operations = new Map();
334
+ const specRecord = spec;
335
+ const paths = specRecord.paths ?? {};
336
+ for (const [routePath, pathItemRaw] of Object.entries(paths)) {
337
+ const pathItem = pathItemRaw ?? {};
338
+ const pathParametersRaw = pathItem.parameters;
339
+ const pathParameters = Array.isArray(pathParametersRaw) ? pathParametersRaw : [];
340
+ for (const method of HTTP_METHODS) {
341
+ const operationRaw = pathItem[method];
342
+ if (!operationRaw || typeof operationRaw !== 'object') {
343
+ continue;
344
+ }
345
+ const operation = operationRaw;
346
+ const operationKey = `${method.toUpperCase()} ${routePath}`;
347
+ const operationParametersRaw = operation.parameters;
348
+ const operationParameters = Array.isArray(operationParametersRaw) ? operationParametersRaw : [];
349
+ const mergedParameters = [...pathParameters, ...operationParameters];
350
+ const parameters = new Map();
351
+ for (const parameterRaw of mergedParameters) {
352
+ if (!parameterRaw || typeof parameterRaw !== 'object') {
353
+ continue;
354
+ }
355
+ const parameter = parameterRaw;
356
+ const parameterName = typeof parameter.name === 'string' ? parameter.name : '';
357
+ const parameterIn = typeof parameter.in === 'string' ? parameter.in : 'unknown';
358
+ if (!parameterName) {
359
+ continue;
360
+ }
361
+ const schema = parameter.schema ?? parameter;
362
+ const type = getSchemaType(schema);
363
+ const required = parameter.required === true;
364
+ parameters.set(`${parameterIn}:${parameterName}`, { required, type });
365
+ }
366
+ const requestBody = operation.requestBody;
367
+ const requestBodyRequired = requestBody?.required === true;
368
+ const successResponses = new Map();
369
+ const responses = operation.responses;
370
+ if (responses && typeof responses === 'object') {
371
+ for (const [responseCode, responseValue] of Object.entries(responses)) {
372
+ if (isSuccessResponseKey(responseCode)) {
373
+ successResponses.set(responseCode, getResponsePayloadType(responseValue));
374
+ }
375
+ }
376
+ }
377
+ const operationId = typeof operation.operationId === 'string' ? operation.operationId : undefined;
378
+ const summary = typeof operation.summary === 'string' ? operation.summary : undefined;
379
+ const description = typeof operation.description === 'string' ? operation.description : undefined;
380
+ const tagsRaw = operation.tags;
381
+ const tags = Array.isArray(tagsRaw) ? tagsRaw.map(tag => String(tag)) : undefined;
382
+ operations.set(operationKey, {
383
+ parameters,
384
+ requestBodyRequired,
385
+ successResponses,
386
+ operationId,
387
+ summary,
388
+ description,
389
+ tags,
390
+ });
391
+ }
392
+ }
393
+ return operations;
394
+ }
395
+ /**
396
+ * Pushes change entry to report collection.
397
+ */
398
+ function pushChange(changes, severity, type, path, message, extras) {
399
+ changes.push({ severity, type, path, message, ...extras });
400
+ }
401
+ /**
402
+ * Normalizes, deduplicates and sorts changes for stable CI output.
403
+ */
404
+ function normalizeAndDedupeChanges(changes) {
405
+ const unique = new Map();
406
+ for (const change of changes) {
407
+ const normalizedPath = change.path.replace(/\s+/g, ' ').trim();
408
+ const normalizedMessage = change.message.replace(/\s+/g, ' ').trim();
409
+ const normalizedChange = {
410
+ ...change,
411
+ path: normalizedPath,
412
+ message: normalizedMessage,
413
+ };
414
+ const key = [normalizedChange.severity, normalizedChange.type, normalizedChange.path, normalizedChange.message].join('|');
415
+ if (!unique.has(key)) {
416
+ unique.set(key, normalizedChange);
417
+ }
418
+ }
419
+ return [...unique.values()].sort((left, right) => {
420
+ if (left.path !== right.path) {
421
+ return left.path.localeCompare(right.path);
422
+ }
423
+ if (left.type !== right.type) {
424
+ return left.type.localeCompare(right.type);
425
+ }
426
+ if (left.severity !== right.severity) {
427
+ return left.severity.localeCompare(right.severity);
428
+ }
429
+ return left.message.localeCompare(right.message);
430
+ });
431
+ }
432
+ /**
433
+ * Diffs canonical models and appends semantic changes.
434
+ */
435
+ function diffModels(oldModels, newModels, changes) {
436
+ for (const oldModelName of oldModels.keys()) {
437
+ if (!newModels.has(oldModelName)) {
438
+ pushChange(changes, 'breaking', 'model.removed', `#/components/schemas/${oldModelName}`, `Model "${oldModelName}" was removed.`);
439
+ }
440
+ }
441
+ for (const newModelName of newModels.keys()) {
442
+ if (!oldModels.has(newModelName)) {
443
+ pushChange(changes, 'non-breaking', 'model.added', `#/components/schemas/${newModelName}`, `Model "${newModelName}" was added.`);
444
+ }
445
+ }
446
+ for (const [modelName, oldModel] of oldModels.entries()) {
447
+ const newModel = newModels.get(modelName);
448
+ if (!newModel) {
449
+ continue;
450
+ }
451
+ for (const oldPropertyName of oldModel.properties.keys()) {
452
+ if (!newModel.properties.has(oldPropertyName)) {
453
+ pushChange(changes, 'breaking', 'model.property.removed', `#/components/schemas/${modelName}/properties/${oldPropertyName}`, `Property "${oldPropertyName}" was removed from model "${modelName}".`, { from: { type: oldModel.properties.get(oldPropertyName) } });
454
+ }
455
+ }
456
+ for (const [newPropertyName, newPropertyType] of newModel.properties.entries()) {
457
+ if (!oldModel.properties.has(newPropertyName)) {
458
+ const isRequired = newModel.required.has(newPropertyName);
459
+ pushChange(changes, isRequired ? 'breaking' : 'non-breaking', 'model.property.added', `#/components/schemas/${modelName}/properties/${newPropertyName}`, `Property "${newPropertyName}" was added to model "${modelName}".`, { to: { type: newPropertyType } });
460
+ }
461
+ }
462
+ for (const [propertyName, oldPropertyType] of oldModel.properties.entries()) {
463
+ const newPropertyType = newModel.properties.get(propertyName);
464
+ if (!newPropertyType) {
465
+ continue;
466
+ }
467
+ if (oldPropertyType !== newPropertyType) {
468
+ const severity = classifyTypeTransition(oldPropertyType, newPropertyType);
469
+ pushChange(changes, severity, 'model.property.type.changed', `#/components/schemas/${modelName}/properties/${propertyName}`, `Property "${propertyName}" type changed in model "${modelName}" from "${oldPropertyType}" to "${newPropertyType}".`, { from: oldPropertyType, to: newPropertyType });
470
+ }
471
+ const wasRequired = oldModel.required.has(propertyName);
472
+ const isRequired = newModel.required.has(propertyName);
473
+ if (wasRequired !== isRequired) {
474
+ pushChange(changes, isRequired ? 'breaking' : 'non-breaking', 'model.property.required.changed', `#/components/schemas/${modelName}/required/${propertyName}`, `Property "${propertyName}" required flag changed in model "${modelName}" from "${wasRequired}" to "${isRequired}".`, { fromRequired: wasRequired, toRequired: isRequired });
475
+ }
476
+ }
477
+ for (const oldEnumValue of oldModel.enumValues) {
478
+ if (!newModel.enumValues.has(oldEnumValue)) {
479
+ pushChange(changes, 'breaking', 'model.enum.value.removed', `#/components/schemas/${modelName}/enum`, `Enum value "${oldEnumValue}" was removed from model "${modelName}".`, {
480
+ from: oldEnumValue,
481
+ });
482
+ }
483
+ }
484
+ for (const newEnumValue of newModel.enumValues) {
485
+ if (!oldModel.enumValues.has(newEnumValue)) {
486
+ pushChange(changes, 'non-breaking', 'model.enum.value.added', `#/components/schemas/${modelName}/enum`, `Enum value "${newEnumValue}" was added to model "${modelName}".`, {
487
+ to: newEnumValue,
488
+ });
489
+ }
490
+ }
491
+ }
492
+ }
493
+ /**
494
+ * Diffs canonical operations and appends semantic changes.
495
+ */
496
+ function diffOperations(oldOperations, newOperations, changes) {
497
+ for (const [oldOperationKey, oldOperation] of oldOperations.entries()) {
498
+ if (!newOperations.has(oldOperationKey)) {
499
+ pushChange(changes, 'breaking', 'operation.removed', `#/paths/${oldOperationKey}`, `Operation "${oldOperationKey}" was removed.`, {
500
+ from: {
501
+ operationId: oldOperation.operationId,
502
+ summary: oldOperation.summary,
503
+ description: oldOperation.description,
504
+ tags: oldOperation.tags,
505
+ },
506
+ });
507
+ }
508
+ }
509
+ for (const newOperationKey of newOperations.keys()) {
510
+ if (!oldOperations.has(newOperationKey)) {
511
+ pushChange(changes, 'non-breaking', 'operation.added', `#/paths/${newOperationKey}`, `Operation "${newOperationKey}" was added.`);
512
+ }
513
+ }
514
+ for (const [operationKey, oldOperation] of oldOperations.entries()) {
515
+ const newOperation = newOperations.get(operationKey);
516
+ if (!newOperation) {
517
+ continue;
518
+ }
519
+ for (const oldParameterName of oldOperation.parameters.keys()) {
520
+ if (!newOperation.parameters.has(oldParameterName)) {
521
+ pushChange(changes, 'breaking', 'operation.parameter.removed', `#/paths/${operationKey}/parameters/${oldParameterName}`, `Parameter "${oldParameterName}" was removed from operation "${operationKey}".`, { from: { type: oldOperation.parameters.get(oldParameterName)?.type } });
522
+ }
523
+ }
524
+ for (const [newParameterName, newParameter] of newOperation.parameters.entries()) {
525
+ if (!oldOperation.parameters.has(newParameterName)) {
526
+ pushChange(changes, newParameter.required ? 'breaking' : 'non-breaking', 'operation.parameter.added', `#/paths/${operationKey}/parameters/${newParameterName}`, `Parameter "${newParameterName}" was added to operation "${operationKey}".`, { to: { type: newParameter.type, required: newParameter.required } });
527
+ }
528
+ }
529
+ for (const [parameterName, oldParameter] of oldOperation.parameters.entries()) {
530
+ const newParameter = newOperation.parameters.get(parameterName);
531
+ if (!newParameter) {
532
+ continue;
533
+ }
534
+ if (oldParameter.required !== newParameter.required) {
535
+ pushChange(changes, newParameter.required ? 'breaking' : 'non-breaking', 'operation.parameter.required.changed', `#/paths/${operationKey}/parameters/${parameterName}/required`, `Required flag for parameter "${parameterName}" changed in operation "${operationKey}".`, { fromRequired: oldParameter.required, toRequired: newParameter.required });
536
+ }
537
+ if (oldParameter.type !== newParameter.type) {
538
+ const severity = classifyTypeTransition(oldParameter.type, newParameter.type);
539
+ pushChange(changes, severity, 'operation.parameter.type.changed', `#/paths/${operationKey}/parameters/${parameterName}/schema`, `Type for parameter "${parameterName}" changed in operation "${operationKey}" from "${oldParameter.type}" to "${newParameter.type}".`, { from: oldParameter.type, to: newParameter.type });
540
+ }
541
+ }
542
+ if (oldOperation.requestBodyRequired !== newOperation.requestBodyRequired) {
543
+ pushChange(changes, newOperation.requestBodyRequired ? 'breaking' : 'non-breaking', 'operation.requestBody.required.changed', `#/paths/${operationKey}/requestBody/required`, `requestBody.required changed in operation "${operationKey}" from "${oldOperation.requestBodyRequired}" to "${newOperation.requestBodyRequired}".`, { from: oldOperation.requestBodyRequired, to: newOperation.requestBodyRequired });
544
+ }
545
+ for (const oldResponseCode of oldOperation.successResponses.keys()) {
546
+ if (!newOperation.successResponses.has(oldResponseCode)) {
547
+ pushChange(changes, 'breaking', 'operation.response.success.removed', `#/paths/${operationKey}/responses/${oldResponseCode}`, `Successful response "${oldResponseCode}" was removed from operation "${operationKey}".`);
548
+ }
549
+ }
550
+ for (const newResponseCode of newOperation.successResponses.keys()) {
551
+ if (!oldOperation.successResponses.has(newResponseCode)) {
552
+ pushChange(changes, 'non-breaking', 'operation.response.success.added', `#/paths/${operationKey}/responses/${newResponseCode}`, `Successful response "${newResponseCode}" was added to operation "${operationKey}".`);
553
+ }
554
+ }
555
+ for (const [responseCode, oldResponseType] of oldOperation.successResponses.entries()) {
556
+ const newResponseType = newOperation.successResponses.get(responseCode);
557
+ if (!newResponseType || oldResponseType === newResponseType) {
558
+ continue;
559
+ }
560
+ const severity = classifyTypeTransition(oldResponseType, newResponseType);
561
+ pushChange(changes, severity, 'operation.response.success.type.changed', `#/paths/${operationKey}/responses/${responseCode}/content`, `Successful response "${responseCode}" payload type changed in operation "${operationKey}" from "${oldResponseType}" to "${newResponseType}".`, { from: oldResponseType, to: newResponseType });
562
+ }
563
+ }
564
+ }
565
+ /**
566
+ * Calculates summary counters from semantic changes list.
567
+ */
568
+ function buildSummary(changes) {
569
+ return changes.reduce((summary, change) => {
570
+ if (change.severity === 'breaking') {
571
+ summary.breaking += 1;
572
+ }
573
+ else if (change.severity === 'non-breaking') {
574
+ summary.nonBreaking += 1;
575
+ }
576
+ else {
577
+ summary.informational += 1;
578
+ }
579
+ return summary;
580
+ }, {
581
+ breaking: 0,
582
+ nonBreaking: 0,
583
+ informational: 0,
584
+ });
585
+ }
586
+ /**
587
+ * Builds semver recommendation from semantic diff summary.
588
+ */
589
+ function buildSemverRecommendation(summary) {
590
+ if (summary.breaking > 0) {
591
+ return {
592
+ semver: 'major',
593
+ confidence: summary.breaking >= 3 ? 'high' : 'medium',
594
+ reason: 'Breaking changes detected.',
595
+ reasons: ['HAS_BREAKING_CHANGES'],
596
+ };
597
+ }
598
+ if (summary.nonBreaking > 0) {
599
+ return {
600
+ semver: 'minor',
601
+ confidence: summary.nonBreaking >= 3 ? 'high' : 'medium',
602
+ reason: 'Backward-compatible feature changes detected.',
603
+ reasons: ['HAS_BACKWARD_COMPATIBLE_CHANGES'],
604
+ };
605
+ }
606
+ if (summary.informational > 0) {
607
+ return {
608
+ semver: 'patch',
609
+ confidence: 'medium',
610
+ reason: 'Only informational changes detected.',
611
+ reasons: ['HAS_INFORMATIONAL_ONLY_CHANGES'],
612
+ };
613
+ }
614
+ return {
615
+ semver: 'patch',
616
+ confidence: 'high',
617
+ reason: 'No breaking or feature-level changes detected.',
618
+ reasons: ['NO_API_SURFACE_CHANGES'],
619
+ };
620
+ }
621
+ /**
622
+ * Формирует семантический diff-отчёт между двумя OpenAPI-спецификациями.
623
+ * @param oldSpec базовая спецификация
624
+ * @param newSpec целевая спецификация
625
+ * @param [options] опции анализа, включая governance и разрешение breaking-изменений
626
+ * @returns семантический diff-отчёт
627
+ */
628
+ function analyzeOpenApiDiff(oldSpec, newSpec, options = {}) {
629
+ const oldModels = buildCanonicalModels(oldSpec);
630
+ const newModels = buildCanonicalModels(newSpec);
631
+ const oldOperations = buildCanonicalOperations(oldSpec);
632
+ const newOperations = buildCanonicalOperations(newSpec);
633
+ const changes = [];
634
+ diffModels(oldModels, newModels, changes);
635
+ diffOperations(oldOperations, newOperations, changes);
636
+ const normalizedChanges = normalizeAndDedupeChanges(changes);
637
+ const summary = buildSummary(normalizedChanges);
638
+ const governance = (0, evaluateGovernanceRules_1.evaluateGovernanceRules)({
639
+ openApi: newSpec,
640
+ breakingChangesCount: summary.breaking,
641
+ allowBreaking: options.allowBreaking ?? false,
642
+ governanceConfig: options.governanceConfig,
643
+ });
644
+ return {
645
+ schemaVersion: exports.SEMANTIC_DIFF_REPORT_SCHEMA_VERSION,
646
+ summary,
647
+ recommendation: buildSemverRecommendation(summary),
648
+ governance,
649
+ changes: normalizedChanges,
650
+ };
651
+ }
652
+ /**
653
+ * Записывает семантический или унифицированный diff-отчёт в JSON-файл.
654
+ * @param report отчёт для сохранения
655
+ * @param reportFilePath путь к файлу отчёта
656
+ * @returns абсолютный путь к сохранённому файлу
657
+ */
658
+ async function writeSemanticDiffReport(report, reportFilePath) {
659
+ const resolvedPath = (0, pathHelpers_1.resolveHelper)(process.cwd(), reportFilePath);
660
+ const directory = path_1.default.dirname(resolvedPath);
661
+ const directoryExists = await fileSystemHelpers_1.fileSystemHelpers.exists(directory);
662
+ if (!directoryExists) {
663
+ await fileSystemHelpers_1.fileSystemHelpers.mkdir(directory);
664
+ }
665
+ const reportContent = await (0, format_1.format)(JSON.stringify(report), 'json');
666
+ await fileSystemHelpers_1.fileSystemHelpers.writeFile(resolvedPath, reportContent);
667
+ return resolvedPath;
668
+ }
@@ -0,0 +1,16 @@
1
+ /**
2
+ * Результат валидации diff-отчёта по JSON Schema.
3
+ * @property valid признак успешной валидации
4
+ * @property errors список ошибок валидации
5
+ */
6
+ export type SemanticDiffReportSchemaValidationResult = {
7
+ valid: boolean;
8
+ errors: string[];
9
+ };
10
+ /**
11
+ * Валидирует payload diff-отчёта по JSON Schema контракту.
12
+ * @param report проверяемый отчёт
13
+ * @returns результат валидации с перечнем ошибок
14
+ */
15
+ export declare function validateSemanticDiffReportSchema(report: unknown): SemanticDiffReportSchemaValidationResult;
16
+ //# sourceMappingURL=semanticDiffReportSchema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"semanticDiffReportSchema.d.ts","sourceRoot":"","sources":["../../../src/core/semanticDiff/semanticDiffReportSchema.ts"],"names":[],"mappings":"AAKA;;;;GAIG;AACH,MAAM,MAAM,wCAAwC,GAAG;IACnD,KAAK,EAAE,OAAO,CAAC;IACf,MAAM,EAAE,MAAM,EAAE,CAAC;CACpB,CAAC;AAmMF;;;;GAIG;AACH,wBAAgB,gCAAgC,CAAC,MAAM,EAAE,OAAO,GAAG,wCAAwC,CAc1G"}