@redocly/openapi-core 1.18.1 → 1.20.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 (411) hide show
  1. package/CHANGELOG.md +22 -0
  2. package/__tests__/utils.ts +14 -7
  3. package/lib/benchmark/benches/lint-with-many-rules.bench.d.ts +1 -0
  4. package/lib/benchmark/benches/lint-with-many-rules.bench.js +7 -3
  5. package/lib/benchmark/benches/lint-with-nested-rule.bench.d.ts +1 -0
  6. package/lib/benchmark/benches/lint-with-nested-rule.bench.js +7 -3
  7. package/lib/benchmark/benches/lint-with-no-rules.bench.d.ts +1 -0
  8. package/lib/benchmark/benches/lint-with-no-rules.bench.js +7 -3
  9. package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.d.ts +1 -0
  10. package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.js +19 -15
  11. package/lib/benchmark/benches/lint-with-top-level-rule.bench.d.ts +1 -0
  12. package/lib/benchmark/benches/lint-with-top-level-rule.bench.js +18 -14
  13. package/lib/benchmark/benches/recommended-oas3.bench.js +2 -2
  14. package/lib/benchmark/benches/resolve-with-no-external.bench.js +2 -2
  15. package/lib/benchmark/utils.d.ts +3 -3
  16. package/lib/benchmark/utils.js +10 -7
  17. package/lib/bundle.d.ts +2 -2
  18. package/lib/bundle.js +127 -120
  19. package/lib/config/all.js +13 -1
  20. package/lib/config/builtIn.js +18 -17
  21. package/lib/config/config-resolvers.d.ts +1 -1
  22. package/lib/config/config-resolvers.js +241 -158
  23. package/lib/config/config.d.ts +4 -3
  24. package/lib/config/config.js +53 -34
  25. package/lib/config/load.d.ts +1 -1
  26. package/lib/config/load.js +105 -117
  27. package/lib/config/minimal.js +13 -0
  28. package/lib/config/recommended-strict.js +14 -1
  29. package/lib/config/recommended.js +14 -1
  30. package/lib/config/rules.d.ts +3 -3
  31. package/lib/config/rules.js +1 -2
  32. package/lib/config/types.d.ts +17 -4
  33. package/lib/config/utils.d.ts +3 -1
  34. package/lib/config/utils.js +78 -49
  35. package/lib/decorators/async3/index.d.ts +1 -0
  36. package/lib/decorators/async3/index.js +4 -0
  37. package/lib/decorators/common/filters/filter-helper.d.ts +1 -1
  38. package/lib/decorators/common/filters/filter-helper.js +2 -3
  39. package/lib/decorators/common/filters/filter-in.d.ts +1 -1
  40. package/lib/decorators/common/filters/filter-in.js +1 -1
  41. package/lib/decorators/common/filters/filter-out.d.ts +1 -1
  42. package/lib/decorators/common/filters/filter-out.js +1 -1
  43. package/lib/decorators/common/info-description-override.d.ts +1 -1
  44. package/lib/decorators/common/info-override.d.ts +1 -1
  45. package/lib/decorators/common/info-override.js +1 -12
  46. package/lib/decorators/common/media-type-examples-override.d.ts +1 -1
  47. package/lib/decorators/common/media-type-examples-override.js +8 -2
  48. package/lib/decorators/common/operation-description-override.d.ts +1 -1
  49. package/lib/decorators/common/registry-dependencies.d.ts +1 -1
  50. package/lib/decorators/common/remove-x-internal.d.ts +1 -1
  51. package/lib/decorators/common/remove-x-internal.js +4 -5
  52. package/lib/decorators/common/tag-description-override.d.ts +1 -1
  53. package/lib/decorators/oas2/index.d.ts +1 -1
  54. package/lib/decorators/oas2/remove-unused-components.js +1 -2
  55. package/lib/decorators/oas3/index.d.ts +1 -1
  56. package/lib/decorators/oas3/remove-unused-components.js +1 -2
  57. package/lib/env.d.ts +0 -1
  58. package/lib/env.js +1 -1
  59. package/lib/format/codeframes.d.ts +1 -1
  60. package/lib/format/codeframes.js +10 -8
  61. package/lib/format/format.d.ts +1 -1
  62. package/lib/format/format.js +24 -16
  63. package/lib/index.d.ts +2 -1
  64. package/lib/index.js +6 -4
  65. package/lib/js-yaml/index.d.ts +1 -1
  66. package/lib/js-yaml/index.js +1 -1
  67. package/lib/lint.d.ts +3 -1
  68. package/lib/lint.js +92 -99
  69. package/lib/logger.js +2 -2
  70. package/lib/oas-types.d.ts +9 -5
  71. package/lib/oas-types.js +22 -12
  72. package/lib/redocly/domains.d.ts +1 -1
  73. package/lib/redocly/domains.js +6 -6
  74. package/lib/redocly/index.d.ts +1 -1
  75. package/lib/redocly/index.js +60 -73
  76. package/lib/redocly/registry-api.js +64 -82
  77. package/lib/ref-utils.d.ts +2 -2
  78. package/lib/ref-utils.js +14 -13
  79. package/lib/resolve.d.ts +2 -2
  80. package/lib/resolve.js +186 -205
  81. package/lib/rules/ajv.d.ts +1 -1
  82. package/lib/rules/ajv.js +10 -8
  83. package/lib/rules/arazzo/index.js +2 -0
  84. package/lib/rules/async2/channels-kebab-case.d.ts +1 -1
  85. package/lib/rules/async2/index.js +2 -0
  86. package/lib/rules/async2/no-channel-trailing-slash.d.ts +1 -1
  87. package/lib/rules/async3/channels-kebab-case.d.ts +2 -0
  88. package/lib/rules/async3/channels-kebab-case.js +19 -0
  89. package/lib/rules/async3/index.d.ts +3 -0
  90. package/lib/rules/async3/index.js +24 -0
  91. package/lib/rules/async3/no-channel-trailing-slash.d.ts +2 -0
  92. package/lib/rules/async3/no-channel-trailing-slash.js +16 -0
  93. package/lib/rules/common/assertions/asserts.d.ts +2 -2
  94. package/lib/rules/common/assertions/asserts.js +5 -5
  95. package/lib/rules/common/assertions/index.d.ts +4 -4
  96. package/lib/rules/common/assertions/utils.d.ts +1 -1
  97. package/lib/rules/common/assertions/utils.js +43 -28
  98. package/lib/rules/common/info-contact.d.ts +1 -1
  99. package/lib/rules/common/info-license-strict.d.ts +2 -0
  100. package/lib/rules/common/info-license-strict.js +26 -0
  101. package/lib/rules/common/info-license-url.d.ts +1 -1
  102. package/lib/rules/common/info-license.d.ts +1 -1
  103. package/lib/rules/common/no-ambiguous-paths.d.ts +1 -1
  104. package/lib/rules/common/no-enum-type-mismatch.d.ts +1 -1
  105. package/lib/rules/common/no-http-verbs-in-paths.d.ts +1 -1
  106. package/lib/rules/common/no-identical-paths.d.ts +1 -1
  107. package/lib/rules/common/no-invalid-parameter-examples.js +1 -2
  108. package/lib/rules/common/no-invalid-schema-examples.js +1 -2
  109. package/lib/rules/common/no-path-trailing-slash.d.ts +1 -1
  110. package/lib/rules/common/no-required-schema-properties-undefined.d.ts +1 -1
  111. package/lib/rules/common/no-required-schema-properties-undefined.js +1 -2
  112. package/lib/rules/common/operation-2xx-response.d.ts +1 -1
  113. package/lib/rules/common/operation-4xx-response.d.ts +1 -1
  114. package/lib/rules/common/operation-description.d.ts +1 -1
  115. package/lib/rules/common/operation-operationId-unique.d.ts +1 -1
  116. package/lib/rules/common/operation-operationId-url-safe.d.ts +1 -1
  117. package/lib/rules/common/operation-operationId-url-safe.js +1 -0
  118. package/lib/rules/common/operation-operationId.d.ts +1 -1
  119. package/lib/rules/common/operation-parameters-unique.d.ts +1 -1
  120. package/lib/rules/common/operation-singular-tag.d.ts +1 -1
  121. package/lib/rules/common/operation-summary.d.ts +1 -1
  122. package/lib/rules/common/operation-tag-defined.d.ts +1 -1
  123. package/lib/rules/common/operation-tag-defined.js +1 -2
  124. package/lib/rules/common/parameter-description.d.ts +1 -1
  125. package/lib/rules/common/path-declaration-must-exist.d.ts +1 -1
  126. package/lib/rules/common/path-excludes-patterns.d.ts +1 -1
  127. package/lib/rules/common/path-http-verbs-order.d.ts +1 -1
  128. package/lib/rules/common/path-http-verbs-order.js +1 -1
  129. package/lib/rules/common/path-not-include-query.d.ts +1 -1
  130. package/lib/rules/common/path-params-defined.d.ts +1 -1
  131. package/lib/rules/common/path-segment-plural.d.ts +1 -1
  132. package/lib/rules/common/paths-kebab-case.d.ts +1 -1
  133. package/lib/rules/common/required-string-property-missing-min-length.d.ts +1 -1
  134. package/lib/rules/common/required-string-property-missing-min-length.js +2 -2
  135. package/lib/rules/common/response-contains-header.d.ts +1 -1
  136. package/lib/rules/common/response-contains-header.js +2 -2
  137. package/lib/rules/common/security-defined.d.ts +1 -1
  138. package/lib/rules/common/security-defined.js +3 -7
  139. package/lib/rules/common/spec-strict-refs.d.ts +1 -1
  140. package/lib/rules/common/spec.d.ts +2 -2
  141. package/lib/rules/common/spec.js +6 -7
  142. package/lib/rules/common/tag-description.d.ts +1 -1
  143. package/lib/rules/common/tags-alphabetical.d.ts +1 -1
  144. package/lib/rules/no-unresolved-refs.d.ts +3 -3
  145. package/lib/rules/no-unresolved-refs.js +3 -4
  146. package/lib/rules/oas2/boolean-parameter-prefixes.d.ts +1 -1
  147. package/lib/rules/oas2/index.d.ts +1 -1
  148. package/lib/rules/oas2/index.js +2 -0
  149. package/lib/rules/oas2/response-contains-property.d.ts +1 -1
  150. package/lib/rules/oas2/response-contains-property.js +1 -2
  151. package/lib/rules/oas3/array-parameter-serialization.d.ts +1 -1
  152. package/lib/rules/oas3/array-parameter-serialization.js +1 -2
  153. package/lib/rules/oas3/boolean-parameter-prefixes.d.ts +1 -1
  154. package/lib/rules/oas3/component-name-unique.d.ts +1 -1
  155. package/lib/rules/oas3/component-name-unique.js +2 -4
  156. package/lib/rules/oas3/index.d.ts +1 -1
  157. package/lib/rules/oas3/index.js +2 -0
  158. package/lib/rules/oas3/no-empty-servers.d.ts +1 -1
  159. package/lib/rules/oas3/no-example-value-and-externalValue.d.ts +1 -1
  160. package/lib/rules/oas3/no-invalid-media-type-examples.d.ts +1 -1
  161. package/lib/rules/oas3/no-invalid-media-type-examples.js +1 -2
  162. package/lib/rules/oas3/no-server-example.com.d.ts +1 -1
  163. package/lib/rules/oas3/no-server-example.com.js +1 -0
  164. package/lib/rules/oas3/no-server-trailing-slash.d.ts +1 -1
  165. package/lib/rules/oas3/no-server-variables-empty-enum.d.ts +1 -1
  166. package/lib/rules/oas3/no-server-variables-empty-enum.js +1 -2
  167. package/lib/rules/oas3/no-undefined-server-variable.d.ts +1 -1
  168. package/lib/rules/oas3/no-undefined-server-variable.js +2 -3
  169. package/lib/rules/oas3/no-unused-components.d.ts +1 -1
  170. package/lib/rules/oas3/no-unused-components.js +1 -2
  171. package/lib/rules/oas3/response-contains-property.d.ts +1 -1
  172. package/lib/rules/oas3/response-contains-property.js +1 -2
  173. package/lib/rules/oas3/spec-components-invalid-map-name.d.ts +1 -1
  174. package/lib/rules/other/stats.d.ts +3 -3
  175. package/lib/rules/other/stats.js +5 -3
  176. package/lib/rules/spot/parameters-no-body-inside-in.d.ts +2 -0
  177. package/lib/rules/spot/parameters-no-body-inside-in.js +18 -0
  178. package/lib/rules/utils.d.ts +4 -2
  179. package/lib/rules/utils.js +41 -13
  180. package/lib/types/arazzo.d.ts +1 -2275
  181. package/lib/types/arazzo.js +246 -309
  182. package/lib/types/asyncapi2.d.ts +17 -0
  183. package/lib/types/{asyncapi.js → asyncapi2.js} +59 -53
  184. package/lib/types/asyncapi3.d.ts +2 -0
  185. package/lib/types/asyncapi3.js +347 -0
  186. package/lib/types/index.js +19 -10
  187. package/lib/types/json-schema-adapter.d.ts +1 -1
  188. package/lib/types/json-schema-adapter.js +4 -18
  189. package/lib/types/oas2.js +6 -6
  190. package/lib/types/oas3.d.ts +4 -0
  191. package/lib/types/oas3.js +19 -19
  192. package/lib/types/oas3_1.d.ts +3 -0
  193. package/lib/types/oas3_1.js +20 -14
  194. package/lib/types/redocly-yaml.d.ts +8 -6
  195. package/lib/types/redocly-yaml.js +135 -36
  196. package/lib/typings/arazzo.d.ts +145 -27
  197. package/lib/typings/asyncapi3.d.ts +53 -0
  198. package/lib/typings/asyncapi3.js +2 -0
  199. package/lib/typings/common.d.ts +1 -1
  200. package/lib/typings/swagger.d.ts +2 -2
  201. package/lib/utils.d.ts +4 -3
  202. package/lib/utils.js +55 -72
  203. package/lib/visitors.d.ts +29 -1
  204. package/lib/visitors.js +21 -8
  205. package/lib/walk.d.ts +3 -3
  206. package/lib/walk.js +30 -23
  207. package/package.json +3 -3
  208. package/src/__tests__/bundle.test.ts +144 -2
  209. package/src/__tests__/lint.test.ts +29 -21
  210. package/src/__tests__/walk.test.ts +25 -25
  211. package/src/benchmark/benches/lint-with-many-rules.bench.ts +7 -1
  212. package/src/benchmark/benches/lint-with-nested-rule.bench.ts +7 -1
  213. package/src/benchmark/benches/lint-with-no-rules.bench.ts +8 -1
  214. package/src/benchmark/benches/lint-with-top-level-rule-report.bench.ts +18 -13
  215. package/src/benchmark/benches/lint-with-top-level-rule.bench.ts +17 -11
  216. package/src/benchmark/fork.js +4 -0
  217. package/src/benchmark/utils.ts +6 -5
  218. package/src/bundle.ts +19 -4
  219. package/src/config/__tests__/__snapshots__/config-resolvers.test.ts.snap +32 -2
  220. package/src/config/__tests__/__snapshots__/config.test.ts.snap +24 -0
  221. package/src/config/__tests__/config-resolvers.test.ts +82 -0
  222. package/src/config/__tests__/config.test.ts +11 -0
  223. package/src/config/__tests__/fixtures/resolve-config/local-config-with-commonjs-export-function.yaml +2 -0
  224. package/src/config/__tests__/fixtures/resolve-config/local-config-with-esm.yaml +2 -0
  225. package/src/config/__tests__/fixtures/resolve-config/plugin-esm.mjs +10 -0
  226. package/src/config/__tests__/fixtures/resolve-config/plugin-with-export-function.cjs +10 -0
  227. package/src/config/__tests__/resolve-plugins.test.ts +4 -1
  228. package/src/config/all.ts +13 -1
  229. package/src/config/builtIn.ts +9 -8
  230. package/src/config/config-resolvers.ts +92 -21
  231. package/src/config/config.ts +31 -13
  232. package/src/config/load.ts +2 -2
  233. package/src/config/minimal.ts +13 -0
  234. package/src/config/recommended-strict.ts +14 -1
  235. package/src/config/recommended.ts +14 -1
  236. package/src/config/rules.ts +12 -4
  237. package/src/config/types.ts +34 -5
  238. package/src/config/utils.ts +28 -2
  239. package/src/decorators/__tests__/filter-in.test.ts +29 -26
  240. package/src/decorators/__tests__/filter-out.test.ts +32 -23
  241. package/src/decorators/__tests__/media-type-examples-override.test.ts +45 -45
  242. package/src/decorators/__tests__/remove-x-internal.test.ts +8 -5
  243. package/src/decorators/async3/index.ts +1 -0
  244. package/src/decorators/common/filters/filter-helper.ts +2 -1
  245. package/src/decorators/common/filters/filter-in.ts +2 -1
  246. package/src/decorators/common/filters/filter-out.ts +2 -1
  247. package/src/decorators/common/info-description-override.ts +3 -2
  248. package/src/decorators/common/info-override.ts +1 -1
  249. package/src/decorators/common/media-type-examples-override.ts +4 -3
  250. package/src/decorators/common/operation-description-override.ts +5 -4
  251. package/src/decorators/common/registry-dependencies.ts +2 -2
  252. package/src/decorators/common/remove-x-internal.ts +5 -4
  253. package/src/decorators/common/tag-description-override.ts +3 -2
  254. package/src/decorators/oas2/__tests__/remove-unused-components.test.ts +3 -3
  255. package/src/decorators/oas2/index.ts +2 -1
  256. package/src/decorators/oas2/remove-unused-components.ts +1 -1
  257. package/src/decorators/oas3/__tests__/remove-unused-components.test.ts +4 -4
  258. package/src/decorators/oas3/index.ts +2 -1
  259. package/src/decorators/oas3/remove-unused-components.ts +1 -1
  260. package/src/format/codeframes.ts +2 -1
  261. package/src/format/format.ts +9 -4
  262. package/src/index.ts +2 -1
  263. package/src/js-yaml/index.ts +3 -1
  264. package/src/lint.ts +28 -4
  265. package/src/logger.ts +2 -2
  266. package/src/oas-types.ts +41 -22
  267. package/src/redocly/domains.ts +1 -1
  268. package/src/redocly/index.ts +3 -3
  269. package/src/redocly/registry-api.ts +5 -3
  270. package/src/ref-utils.ts +4 -2
  271. package/src/resolve.ts +6 -4
  272. package/src/rules/__tests__/no-unresolved-refs.test.ts +21 -7
  273. package/src/rules/ajv.ts +2 -1
  274. package/src/rules/arazzo/__tests__/parameters-no-body-inside-in.test.ts +76 -0
  275. package/src/rules/arazzo/index.ts +6 -3
  276. package/src/rules/async2/__tests__/channels-kebab-case.test.ts +9 -5
  277. package/src/rules/async2/__tests__/no-channel-trailing-slash.test.ts +3 -3
  278. package/src/rules/async2/channels-kebab-case.ts +2 -2
  279. package/src/rules/async2/index.ts +9 -6
  280. package/src/rules/async2/no-channel-trailing-slash.ts +2 -2
  281. package/src/rules/async3/__tests__/channels-kebab-case.test.ts +145 -0
  282. package/src/rules/async3/__tests__/no-channel-trailing-slash.test.ts +96 -0
  283. package/src/rules/async3/channels-kebab-case.ts +19 -0
  284. package/src/rules/async3/index.ts +26 -0
  285. package/src/rules/async3/no-channel-trailing-slash.ts +16 -0
  286. package/src/rules/common/__tests__/info-license-strict.test.ts +141 -0
  287. package/src/rules/common/__tests__/info-license.test.ts +2 -2
  288. package/src/rules/common/__tests__/license-url.test.ts +2 -2
  289. package/src/rules/common/__tests__/no-ambiguous-paths.test.ts +1 -1
  290. package/src/rules/common/__tests__/no-enum-type-mismatch.test.ts +5 -5
  291. package/src/rules/common/__tests__/no-identical-paths.test.ts +1 -1
  292. package/src/rules/common/__tests__/no-invalid-parameter-examples.test.ts +1 -1
  293. package/src/rules/common/__tests__/no-invalid-schema-examples.test.ts +1 -1
  294. package/src/rules/common/__tests__/no-path-trailing-slash.test.ts +4 -4
  295. package/src/rules/common/__tests__/no-required-schema-properties-undefined.test.ts +11 -11
  296. package/src/rules/common/__tests__/operation-2xx-response.test.ts +8 -6
  297. package/src/rules/common/__tests__/operation-4xx-response.test.ts +9 -7
  298. package/src/rules/common/__tests__/operation-operationId-unique.test.ts +2 -2
  299. package/src/rules/common/__tests__/operation-operationId-url-safe.test.ts +1 -1
  300. package/src/rules/common/__tests__/operation-parameters-unique.test.ts +4 -4
  301. package/src/rules/common/__tests__/operation-singular-tag.test.ts +2 -2
  302. package/src/rules/common/__tests__/path-http-verbs-order.test.ts +2 -2
  303. package/src/rules/common/__tests__/path-not-include-query.test.ts +2 -2
  304. package/src/rules/common/__tests__/path-params-defined.test.ts +5 -5
  305. package/src/rules/common/__tests__/paths-kebab-case.test.ts +6 -4
  306. package/src/rules/common/__tests__/scalar-property-missing-example.test.ts +8 -8
  307. package/src/rules/common/__tests__/security-defined.test.ts +14 -8
  308. package/src/rules/common/__tests__/spec-strict-refs.test.ts +1 -1
  309. package/src/rules/common/__tests__/spec.test.ts +10 -10
  310. package/src/rules/common/__tests__/tag-description.test.ts +2 -2
  311. package/src/rules/common/__tests__/tags-alphabetical.test.ts +6 -4
  312. package/src/rules/common/assertions/asserts.ts +5 -9
  313. package/src/rules/common/assertions/index.ts +12 -4
  314. package/src/rules/common/assertions/utils.ts +4 -2
  315. package/src/rules/common/info-contact.ts +2 -1
  316. package/src/rules/common/info-license-strict.ts +24 -0
  317. package/src/rules/common/info-license-url.ts +2 -1
  318. package/src/rules/common/info-license.ts +2 -1
  319. package/src/rules/common/no-ambiguous-paths.ts +4 -4
  320. package/src/rules/common/no-enum-type-mismatch.ts +5 -4
  321. package/src/rules/common/no-http-verbs-in-paths.ts +5 -4
  322. package/src/rules/common/no-identical-paths.ts +4 -4
  323. package/src/rules/common/no-invalid-parameter-examples.ts +3 -2
  324. package/src/rules/common/no-path-trailing-slash.ts +2 -2
  325. package/src/rules/common/no-required-schema-properties-undefined.ts +5 -4
  326. package/src/rules/common/operation-2xx-response.ts +3 -2
  327. package/src/rules/common/operation-4xx-response.ts +3 -2
  328. package/src/rules/common/operation-description.ts +5 -4
  329. package/src/rules/common/operation-operationId-unique.ts +4 -4
  330. package/src/rules/common/operation-operationId-url-safe.ts +5 -4
  331. package/src/rules/common/operation-operationId.ts +5 -4
  332. package/src/rules/common/operation-parameters-unique.ts +4 -4
  333. package/src/rules/common/operation-singular-tag.ts +4 -4
  334. package/src/rules/common/operation-summary.ts +5 -4
  335. package/src/rules/common/operation-tag-defined.ts +4 -4
  336. package/src/rules/common/parameter-description.ts +4 -4
  337. package/src/rules/common/path-declaration-must-exist.ts +2 -2
  338. package/src/rules/common/path-excludes-patterns.ts +4 -4
  339. package/src/rules/common/path-http-verbs-order.ts +4 -4
  340. package/src/rules/common/path-not-include-query.ts +2 -2
  341. package/src/rules/common/path-params-defined.ts +4 -4
  342. package/src/rules/common/path-segment-plural.ts +3 -2
  343. package/src/rules/common/paths-kebab-case.ts +2 -2
  344. package/src/rules/common/required-string-property-missing-min-length.ts +4 -4
  345. package/src/rules/common/response-contains-header.ts +5 -4
  346. package/src/rules/common/scalar-property-missing-example.ts +2 -1
  347. package/src/rules/common/security-defined.ts +5 -5
  348. package/src/rules/common/spec-strict-refs.ts +2 -1
  349. package/src/rules/common/spec.ts +4 -3
  350. package/src/rules/common/tag-description.ts +2 -1
  351. package/src/rules/common/tags-alphabetical.ts +4 -4
  352. package/src/rules/no-unresolved-refs.ts +4 -3
  353. package/src/rules/oas2/__tests__/boolean-parameter-prefixes.test.ts +7 -5
  354. package/src/rules/oas2/__tests__/response-contains-header.test.ts +14 -8
  355. package/src/rules/oas2/__tests__/response-contains-property.test.ts +14 -8
  356. package/src/rules/oas2/__tests__/spec/referenceableScalars.test.ts +3 -1
  357. package/src/rules/oas2/boolean-parameter-prefixes.ts +1 -1
  358. package/src/rules/oas2/index.ts +8 -6
  359. package/src/rules/oas2/request-mime-type.ts +2 -1
  360. package/src/rules/oas2/response-contains-property.ts +3 -2
  361. package/src/rules/oas2/response-mime-type.ts +2 -1
  362. package/src/rules/oas3/__tests__/array-parameter-serialization.test.ts +18 -6
  363. package/src/rules/oas3/__tests__/boolean-parameter-prefixes.test.ts +7 -5
  364. package/src/rules/oas3/__tests__/no-empty-enum-servers.com.test.ts +6 -6
  365. package/src/rules/oas3/__tests__/no-example-value-and-externalValue.test.ts +2 -2
  366. package/src/rules/oas3/__tests__/no-invalid-media-type-examples.test.ts +34 -24
  367. package/src/rules/oas3/__tests__/no-server-example.com.test.ts +3 -3
  368. package/src/rules/oas3/__tests__/no-server-trailing-slash.test.ts +3 -3
  369. package/src/rules/oas3/__tests__/no-unused-components.test.ts +1 -1
  370. package/src/rules/oas3/__tests__/operation-4xx-problem-details-rfc7807.test.ts +3 -3
  371. package/src/rules/oas3/__tests__/response-contains-header.test.ts +34 -22
  372. package/src/rules/oas3/__tests__/response-contains-property.test.ts +34 -20
  373. package/src/rules/oas3/__tests__/spec/spec.test.ts +12 -3
  374. package/src/rules/oas3/__tests__/spec-components-invalid-map-name.test.ts +9 -3
  375. package/src/rules/oas3/__tests__/utils/lint-document-for-test.ts +1 -1
  376. package/src/rules/oas3/array-parameter-serialization.ts +3 -2
  377. package/src/rules/oas3/boolean-parameter-prefixes.ts +1 -1
  378. package/src/rules/oas3/component-name-unique.ts +3 -3
  379. package/src/rules/oas3/index.ts +42 -38
  380. package/src/rules/oas3/no-empty-servers.ts +1 -1
  381. package/src/rules/oas3/no-example-value-and-externalValue.ts +1 -1
  382. package/src/rules/oas3/no-invalid-media-type-examples.ts +6 -4
  383. package/src/rules/oas3/no-server-example.com.ts +2 -1
  384. package/src/rules/oas3/no-server-trailing-slash.ts +1 -1
  385. package/src/rules/oas3/no-server-variables-empty-enum.ts +2 -2
  386. package/src/rules/oas3/no-undefined-server-variable.ts +1 -1
  387. package/src/rules/oas3/no-unused-components.ts +2 -2
  388. package/src/rules/oas3/operation-4xx-problem-details-rfc7807.ts +2 -1
  389. package/src/rules/oas3/request-mime-type.ts +2 -1
  390. package/src/rules/oas3/response-contains-property.ts +3 -2
  391. package/src/rules/oas3/response-mime-type.ts +2 -1
  392. package/src/rules/oas3/spec-components-invalid-map-name.ts +3 -3
  393. package/src/rules/other/stats.ts +8 -6
  394. package/src/rules/spot/parameters-no-body-inside-in.ts +17 -0
  395. package/src/rules/utils.ts +41 -4
  396. package/src/types/arazzo.ts +257 -334
  397. package/src/types/{asyncapi.ts → asyncapi2.ts} +41 -35
  398. package/src/types/asyncapi3.ts +383 -0
  399. package/src/types/json-schema-adapter.ts +2 -2
  400. package/src/types/oas3.ts +4 -4
  401. package/src/types/oas3_1.ts +5 -4
  402. package/src/types/redocly-yaml.ts +21 -4
  403. package/src/typings/arazzo.ts +169 -41
  404. package/src/typings/asyncapi3.ts +61 -0
  405. package/src/typings/common.ts +1 -0
  406. package/src/typings/swagger.ts +2 -2
  407. package/src/utils.ts +5 -3
  408. package/src/visitors.ts +58 -1
  409. package/src/walk.ts +3 -3
  410. package/tsconfig.tsbuildinfo +1 -1
  411. package/lib/types/asyncapi.d.ts +0 -2
package/src/bundle.ts CHANGED
@@ -9,7 +9,7 @@ import {
9
9
  SpecMajorVersion,
10
10
  SpecVersion,
11
11
  } from './oas-types';
12
- import { isAbsoluteUrl, isRef, Location, refBaseName } from './ref-utils';
12
+ import { isAbsoluteUrl, isRef, refBaseName } from './ref-utils';
13
13
  import { initRules } from './config/rules';
14
14
  import { reportUnresolvedRef } from './rules/no-unresolved-refs';
15
15
  import { dequal, isPlainObject, isTruthy } from './utils';
@@ -18,14 +18,14 @@ import { RemoveUnusedComponents as RemoveUnusedComponentsOas2 } from './decorato
18
18
  import { RemoveUnusedComponents as RemoveUnusedComponentsOas3 } from './decorators/oas3/remove-unused-components';
19
19
  import { ConfigTypes } from './types/redocly-yaml';
20
20
 
21
- import type { Oas3Rule, Oas3Visitor, Oas2Visitor } from './visitors';
21
+ import type { Location } from './ref-utils';
22
+ import type { Oas3Visitor, Oas2Visitor } from './visitors';
22
23
  import type { NormalizedNodeType, NodeType } from './types';
23
24
  import type { WalkContext, UserContext, ResolveResult, NormalizedProblem } from './walk';
24
25
  import type { Config, StyleguideConfig } from './config';
25
26
  import type { OasRef } from './typings/openapi';
26
27
  import type { Document, ResolvedRefMap } from './resolve';
27
-
28
- export type Oas3RuleSet = Record<string, Oas3Rule>;
28
+ import type { CollectFn } from './utils';
29
29
 
30
30
  export enum OasVersion {
31
31
  Version2 = 'oas2',
@@ -84,6 +84,7 @@ export async function bundle(
84
84
  opts: {
85
85
  ref?: string;
86
86
  doc?: Document;
87
+ collectSpecData?: CollectFn;
87
88
  } & BundleOptions
88
89
  ) {
89
90
  const {
@@ -102,6 +103,7 @@ export async function bundle(
102
103
  if (document instanceof Error) {
103
104
  throw document;
104
105
  }
106
+ opts.collectSpecData?.(document.parsed);
105
107
 
106
108
  return bundleDocument({
107
109
  document,
@@ -292,6 +294,15 @@ export function mapTypeToComponent(typeName: string, version: SpecMajorVersion)
292
294
  default:
293
295
  return null;
294
296
  }
297
+ case SpecMajorVersion.Async3:
298
+ switch (typeName) {
299
+ case 'Schema':
300
+ return 'schemas';
301
+ case 'Parameter':
302
+ return 'parameters';
303
+ default:
304
+ return null;
305
+ }
295
306
  case SpecMajorVersion.Arazzo:
296
307
  switch (typeName) {
297
308
  case 'Root.x-parameters_items':
@@ -377,6 +388,8 @@ function makeBundleVisitor(
377
388
  components = root;
378
389
  } else if (version === SpecMajorVersion.Async2) {
379
390
  components = root.components = root.components || {};
391
+ } else if (version === SpecMajorVersion.Async3) {
392
+ components = root.components = root.components || {};
380
393
  } else if (version === SpecMajorVersion.Arazzo) {
381
394
  components = root.components = root.components || {};
382
395
  }
@@ -427,6 +440,8 @@ function makeBundleVisitor(
427
440
  components[componentType][name] = target.node;
428
441
  if (version === SpecMajorVersion.OAS3) {
429
442
  return `#/components/${componentType}/${name}`;
443
+ } else if (version === SpecMajorVersion.Async2 || version === SpecMajorVersion.Async3) {
444
+ return `#/components/${componentType}/${name}`;
430
445
  } else {
431
446
  return `#/${componentType}/${name}`;
432
447
  }
@@ -5,6 +5,7 @@ exports[`resolveConfig should ignore minimal from the root and read local file 1
5
5
  "arazzoDecorators": {},
6
6
  "arazzoPreprocessors": {},
7
7
  "arazzoRules": {
8
+ "parameters-no-body-inside-in": "off",
8
9
  "spec": "error",
9
10
  },
10
11
  "async2Decorators": {},
@@ -12,6 +13,19 @@ exports[`resolveConfig should ignore minimal from the root and read local file 1
12
13
  "async2Rules": {
13
14
  "channels-kebab-case": "off",
14
15
  "info-contact": "off",
16
+ "info-license-strict": "warn",
17
+ "no-channel-trailing-slash": "off",
18
+ "operation-operationId": "warn",
19
+ "spec": "error",
20
+ "tag-description": "warn",
21
+ "tags-alphabetical": "off",
22
+ },
23
+ "async3Decorators": {},
24
+ "async3Preprocessors": {},
25
+ "async3Rules": {
26
+ "channels-kebab-case": "off",
27
+ "info-contact": "off",
28
+ "info-license-strict": "warn",
15
29
  "no-channel-trailing-slash": "off",
16
30
  "operation-operationId": "warn",
17
31
  "spec": "error",
@@ -74,7 +88,8 @@ exports[`resolveConfig should ignore minimal from the root and read local file 1
74
88
  "boolean-parameter-prefixes": "error",
75
89
  "info-contact": "off",
76
90
  "info-license": "warn",
77
- "info-license-url": "warn",
91
+ "info-license-strict": "warn",
92
+ "info-license-url": "off",
78
93
  "local/operation-id-not-test": "error",
79
94
  "no-ambiguous-paths": "warn",
80
95
  "no-enum-type-mismatch": "error",
@@ -122,6 +137,7 @@ exports[`resolveStyleguideConfig should resolve extends with local file config w
122
137
  "arazzoDecorators": {},
123
138
  "arazzoPreprocessors": {},
124
139
  "arazzoRules": {
140
+ "parameters-no-body-inside-in": "off",
125
141
  "spec": "error",
126
142
  },
127
143
  "async2Decorators": {},
@@ -129,6 +145,19 @@ exports[`resolveStyleguideConfig should resolve extends with local file config w
129
145
  "async2Rules": {
130
146
  "channels-kebab-case": "off",
131
147
  "info-contact": "off",
148
+ "info-license-strict": "warn",
149
+ "no-channel-trailing-slash": "off",
150
+ "operation-operationId": "warn",
151
+ "spec": "error",
152
+ "tag-description": "warn",
153
+ "tags-alphabetical": "off",
154
+ },
155
+ "async3Decorators": {},
156
+ "async3Preprocessors": {},
157
+ "async3Rules": {
158
+ "channels-kebab-case": "off",
159
+ "info-contact": "off",
160
+ "info-license-strict": "warn",
132
161
  "no-channel-trailing-slash": "off",
133
162
  "operation-operationId": "warn",
134
163
  "spec": "error",
@@ -209,7 +238,8 @@ exports[`resolveStyleguideConfig should resolve extends with local file config w
209
238
  "boolean-parameter-prefixes": "error",
210
239
  "info-contact": "off",
211
240
  "info-license": "warn",
212
- "info-license-url": "warn",
241
+ "info-license-strict": "warn",
242
+ "info-license-url": "off",
213
243
  "local/operation-id-not-test": "error",
214
244
  "no-ambiguous-paths": "warn",
215
245
  "no-enum-type-mismatch": "error",
@@ -12,6 +12,11 @@ StyleguideConfig {
12
12
  "oas3_0": {},
13
13
  "oas3_1": {},
14
14
  },
15
+ "async3": {
16
+ "oas2": {},
17
+ "oas3_0": {},
18
+ "oas3_1": {},
19
+ },
15
20
  "oas2": {
16
21
  "oas2": {},
17
22
  "oas3_0": {},
@@ -51,6 +56,11 @@ StyleguideConfig {
51
56
  "oas3_0": {},
52
57
  "oas3_1": {},
53
58
  },
59
+ "async3": {
60
+ "oas2": {},
61
+ "oas3_0": {},
62
+ "oas3_1": {},
63
+ },
54
64
  "oas2": {
55
65
  "oas2": {},
56
66
  "oas3_0": {},
@@ -124,6 +134,20 @@ StyleguideConfig {
124
134
  "operation-summary": "error",
125
135
  },
126
136
  },
137
+ "async3": {
138
+ "oas2": {
139
+ "no-empty-servers": "error",
140
+ "operation-summary": "error",
141
+ },
142
+ "oas3_0": {
143
+ "no-empty-servers": "error",
144
+ "operation-summary": "error",
145
+ },
146
+ "oas3_1": {
147
+ "no-empty-servers": "error",
148
+ "operation-summary": "error",
149
+ },
150
+ },
127
151
  "oas2": {
128
152
  "oas2": {
129
153
  "no-empty-servers": "error",
@@ -91,6 +91,88 @@ describe('resolveStyleguideConfig', () => {
91
91
  });
92
92
  });
93
93
 
94
+ it('should resolve local file config with esm plugin', async () => {
95
+ const config = {
96
+ ...baseStyleguideConfig,
97
+ extends: ['local-config-with-esm.yaml'],
98
+ };
99
+
100
+ const { plugins, ...styleguide } = await resolveStyleguideConfig({
101
+ styleguideConfig: config,
102
+ configPath,
103
+ });
104
+
105
+ expect(styleguide?.rules?.['operation-2xx-response']).toEqual('warn');
106
+ expect(plugins).toBeDefined();
107
+ expect(plugins?.length).toBe(2);
108
+
109
+ const localPlugin = plugins?.find((p) => p.id === 'test-plugin');
110
+ expect(localPlugin).toBeDefined();
111
+
112
+ expect(localPlugin).toMatchObject({
113
+ id: 'test-plugin',
114
+ rules: {
115
+ oas3: {
116
+ 'test-plugin/oas3-rule-name': 'oas3-rule-stub',
117
+ },
118
+ },
119
+ });
120
+
121
+ expect(styleguide.extendPaths!.map(removeAbsolutePath)).toEqual([
122
+ 'resolve-config/redocly.yaml',
123
+ 'resolve-config/local-config-with-esm.yaml',
124
+ 'resolve-config/redocly.yaml',
125
+ ]);
126
+ expect(styleguide.pluginPaths!.map(removeAbsolutePath)).toEqual([
127
+ 'resolve-config/plugin-esm.mjs',
128
+ ]);
129
+
130
+ expect(styleguide.rules).toEqual({
131
+ 'operation-2xx-response': 'warn',
132
+ });
133
+ });
134
+
135
+ it('should resolve local file config with commonjs plugin with a default export function', async () => {
136
+ const config = {
137
+ ...baseStyleguideConfig,
138
+ extends: ['local-config-with-commonjs-export-function.yaml'],
139
+ };
140
+
141
+ const { plugins, ...styleguide } = await resolveStyleguideConfig({
142
+ styleguideConfig: config,
143
+ configPath,
144
+ });
145
+
146
+ expect(styleguide?.rules?.['operation-2xx-response']).toEqual('warn');
147
+ expect(plugins).toBeDefined();
148
+ expect(plugins?.length).toBe(2);
149
+
150
+ const localPlugin = plugins?.find((p) => p.id === 'test-plugin');
151
+ expect(localPlugin).toBeDefined();
152
+
153
+ expect(localPlugin).toMatchObject({
154
+ id: 'test-plugin',
155
+ rules: {
156
+ oas3: {
157
+ 'test-plugin/oas3-rule-name': 'oas3-rule-stub',
158
+ },
159
+ },
160
+ });
161
+
162
+ expect(styleguide.extendPaths!.map(removeAbsolutePath)).toEqual([
163
+ 'resolve-config/redocly.yaml',
164
+ 'resolve-config/local-config-with-commonjs-export-function.yaml',
165
+ 'resolve-config/redocly.yaml',
166
+ ]);
167
+ expect(styleguide.pluginPaths!.map(removeAbsolutePath)).toEqual([
168
+ 'resolve-config/plugin-with-export-function.cjs',
169
+ ]);
170
+
171
+ expect(styleguide.rules).toEqual({
172
+ 'operation-2xx-response': 'warn',
173
+ });
174
+ });
175
+
94
176
  // TODO: fix circular test
95
177
  it.skip('should throw circular error', () => {
96
178
  const config = {
@@ -119,6 +119,7 @@ describe('getMergedConfig', () => {
119
119
  "decorators": {
120
120
  "arazzo": {},
121
121
  "async2": {},
122
+ "async3": {},
122
123
  "oas2": {},
123
124
  "oas3_0": {},
124
125
  "oas3_1": {},
@@ -131,6 +132,7 @@ describe('getMergedConfig', () => {
131
132
  "preprocessors": {
132
133
  "arazzo": {},
133
134
  "async2": {},
135
+ "async3": {},
134
136
  "oas2": {},
135
137
  "oas3_0": {},
136
138
  "oas3_1": {},
@@ -148,6 +150,9 @@ describe('getMergedConfig', () => {
148
150
  "async2": {
149
151
  "operation-summary": "warn",
150
152
  },
153
+ "async3": {
154
+ "operation-summary": "warn",
155
+ },
151
156
  "oas2": {
152
157
  "operation-summary": "warn",
153
158
  },
@@ -227,6 +232,7 @@ describe('getMergedConfig', () => {
227
232
  "decorators": {
228
233
  "arazzo": {},
229
234
  "async2": {},
235
+ "async3": {},
230
236
  "oas2": {},
231
237
  "oas3_0": {},
232
238
  "oas3_1": {},
@@ -239,6 +245,7 @@ describe('getMergedConfig', () => {
239
245
  "preprocessors": {
240
246
  "arazzo": {},
241
247
  "async2": {},
248
+ "async3": {},
242
249
  "oas2": {},
243
250
  "oas3_0": {},
244
251
  "oas3_1": {},
@@ -259,6 +266,10 @@ describe('getMergedConfig', () => {
259
266
  "no-empty-servers": "error",
260
267
  "operation-summary": "error",
261
268
  },
269
+ "async3": {
270
+ "no-empty-servers": "error",
271
+ "operation-summary": "error",
272
+ },
262
273
  "oas2": {
263
274
  "no-empty-servers": "error",
264
275
  "operation-summary": "error",
@@ -0,0 +1,2 @@
1
+ plugins:
2
+ - plugin-with-export-function.cjs
@@ -0,0 +1,2 @@
1
+ plugins:
2
+ - plugin-esm.mjs
@@ -0,0 +1,10 @@
1
+ export default async function () {
2
+ return {
3
+ id: 'test-plugin',
4
+ rules: {
5
+ oas3: {
6
+ 'oas3-rule-name': 'oas3-rule-stub',
7
+ },
8
+ },
9
+ };
10
+ }
@@ -0,0 +1,10 @@
1
+ module.exports = async function () {
2
+ return {
3
+ id: 'test-plugin',
4
+ rules: {
5
+ oas3: {
6
+ 'oas3-rule-name': 'oas3-rule-stub',
7
+ },
8
+ },
9
+ };
10
+ };
@@ -1,7 +1,10 @@
1
1
  import * as path from 'path';
2
2
  import { loadConfig } from '../load';
3
3
 
4
- describe('resolving a plugin', () => {
4
+ // FIXME: skipping due to the 'Test environment has been torn down' Jest error.
5
+ // Covered the below in the `miscellaneous/resolve-plugins` e2e tests.
6
+ // Unskip when Jest gets this fixed.
7
+ describe.skip('resolving a plugin', () => {
5
8
  const configPath = path.join(__dirname, 'fixtures/plugin-config.yaml');
6
9
 
7
10
  it('should prefix rule names with the plugin id', async () => {
package/src/config/all.ts CHANGED
@@ -5,6 +5,7 @@ const all: PluginStyleguideConfig<'built-in'> = {
5
5
  'info-contact': 'error',
6
6
  'info-license': 'error',
7
7
  'info-license-url': 'error',
8
+ 'info-license-strict': 'error',
8
9
  'tag-description': 'error',
9
10
  'tags-alphabetical': 'error',
10
11
  'parameter-description': 'error',
@@ -108,13 +109,24 @@ const all: PluginStyleguideConfig<'built-in'> = {
108
109
  async2Rules: {
109
110
  spec: 'error',
110
111
  'info-contact': 'error',
112
+ 'info-license-strict': 'error',
111
113
  'operation-operationId': 'error',
112
114
  'tag-description': 'error',
113
115
  'tags-alphabetical': 'error',
114
116
  'channels-kebab-case': 'error',
115
117
  'no-channel-trailing-slash': 'error',
116
118
  },
117
- arazzoRules: { spec: 'error' },
119
+ async3Rules: {
120
+ spec: 'error',
121
+ 'info-contact': 'error',
122
+ 'info-license-strict': 'error',
123
+ 'operation-operationId': 'error',
124
+ 'tag-description': 'error',
125
+ 'tags-alphabetical': 'error',
126
+ 'channels-kebab-case': 'error',
127
+ 'no-channel-trailing-slash': 'error',
128
+ },
129
+ arazzoRules: { spec: 'error', 'parameters-no-body-inside-in': 'off' },
118
130
  };
119
131
 
120
132
  export default all;
@@ -2,17 +2,15 @@ import recommended from './recommended';
2
2
  import recommendedStrict from './recommended-strict';
3
3
  import all from './all';
4
4
  import minimal from './minimal';
5
- import { rules as oas3Rules } from '../rules/oas3';
6
- import { rules as oas2Rules } from '../rules/oas2';
7
- import { rules as async2Rules } from '../rules/async2';
8
- import { rules as arazzoRules } from '../rules/arazzo';
9
- import { preprocessors as oas3Preprocessors } from '../rules/oas3';
10
- import { preprocessors as oas2Preprocessors } from '../rules/oas2';
11
- import { preprocessors as async2Preprocessors } from '../rules/async2';
12
- import { preprocessors as arazzoPreprocessors } from '../rules/arazzo';
5
+ import { rules as oas3Rules, preprocessors as oas3Preprocessors } from '../rules/oas3';
6
+ import { rules as oas2Rules, preprocessors as oas2Preprocessors } from '../rules/oas2';
7
+ import { rules as async2Rules, preprocessors as async2Preprocessors } from '../rules/async2';
8
+ import { rules as async3Rules, preprocessors as async3Preprocessors } from '../rules/async3';
9
+ import { rules as arazzoRules, preprocessors as arazzoPreprocessors } from '../rules/arazzo';
13
10
  import { decorators as oas3Decorators } from '../decorators/oas3';
14
11
  import { decorators as oas2Decorators } from '../decorators/oas2';
15
12
  import { decorators as async2Decorators } from '../decorators/async2';
13
+ import { decorators as async3Decorators } from '../decorators/async3';
16
14
  import { decorators as arazzoDecorators } from '../decorators/arazzo';
17
15
 
18
16
  import type { CustomRulesConfig, StyleguideRawConfig, Plugin } from './types';
@@ -33,18 +31,21 @@ export const defaultPlugin: Plugin = {
33
31
  oas3: oas3Rules,
34
32
  oas2: oas2Rules,
35
33
  async2: async2Rules,
34
+ async3: async3Rules,
36
35
  arazzo: arazzoRules,
37
36
  } as CustomRulesConfig,
38
37
  preprocessors: {
39
38
  oas3: oas3Preprocessors,
40
39
  oas2: oas2Preprocessors,
41
40
  async2: async2Preprocessors,
41
+ async3: async3Preprocessors,
42
42
  arazzo: arazzoPreprocessors,
43
43
  },
44
44
  decorators: {
45
45
  oas3: oas3Decorators,
46
46
  oas2: oas2Decorators,
47
47
  async2: async2Decorators,
48
+ async3: async3Decorators,
48
49
  arazzo: arazzoDecorators,
49
50
  },
50
51
  configs: builtInConfigs,