@redocly/openapi-core 1.34.4 → 2.0.0-next.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 (1011) hide show
  1. package/README.md +42 -4
  2. package/lib/bundle.d.ts +16 -15
  3. package/lib/bundle.d.ts.map +1 -0
  4. package/lib/bundle.js +88 -109
  5. package/lib/bundle.js.map +1 -0
  6. package/lib/config/all.d.ts +3 -2
  7. package/lib/config/all.d.ts.map +1 -0
  8. package/lib/config/all.js +5 -3
  9. package/lib/config/all.js.map +1 -0
  10. package/lib/config/builtIn.d.ts +3 -2
  11. package/lib/config/builtIn.d.ts.map +1 -0
  12. package/lib/config/builtIn.js +44 -49
  13. package/lib/config/builtIn.js.map +1 -0
  14. package/lib/config/bundle-extends.d.ts +8 -0
  15. package/lib/config/bundle-extends.d.ts.map +1 -0
  16. package/lib/config/bundle-extends.js +27 -0
  17. package/lib/config/bundle-extends.js.map +1 -0
  18. package/lib/config/config-resolvers.d.ts +15 -27
  19. package/lib/config/config-resolvers.d.ts.map +1 -0
  20. package/lib/config/config-resolvers.js +259 -373
  21. package/lib/config/config-resolvers.js.map +1 -0
  22. package/lib/config/config.d.ts +22 -26
  23. package/lib/config/config.d.ts.map +1 -0
  24. package/lib/config/config.js +104 -112
  25. package/lib/config/config.js.map +1 -0
  26. package/lib/config/index.d.ts +8 -7
  27. package/lib/config/index.d.ts.map +1 -0
  28. package/lib/config/index.js +8 -23
  29. package/lib/config/index.js.map +1 -0
  30. package/lib/config/load.d.ts +8 -19
  31. package/lib/config/load.d.ts.map +1 -0
  32. package/lib/config/load.js +62 -107
  33. package/lib/config/load.js.map +1 -0
  34. package/lib/config/minimal.d.ts +3 -2
  35. package/lib/config/minimal.d.ts.map +1 -0
  36. package/lib/config/minimal.js +5 -3
  37. package/lib/config/minimal.js.map +1 -0
  38. package/lib/config/recommended-strict.d.ts +3 -2
  39. package/lib/config/recommended-strict.d.ts.map +1 -0
  40. package/lib/config/recommended-strict.js +5 -3
  41. package/lib/config/recommended-strict.js.map +1 -0
  42. package/lib/config/recommended.d.ts +3 -2
  43. package/lib/config/recommended.d.ts.map +1 -0
  44. package/lib/config/recommended.js +5 -3
  45. package/lib/config/recommended.js.map +1 -0
  46. package/lib/config/rules.d.ts +5 -4
  47. package/lib/config/rules.d.ts.map +1 -0
  48. package/lib/config/rules.js +4 -6
  49. package/lib/config/rules.js.map +1 -0
  50. package/lib/config/spec.d.ts +3 -2
  51. package/lib/config/spec.d.ts.map +1 -0
  52. package/lib/config/spec.js +6 -4
  53. package/lib/config/spec.js.map +1 -0
  54. package/lib/config/types.d.ts +19 -62
  55. package/lib/config/types.d.ts.map +1 -0
  56. package/lib/config/types.js +2 -2
  57. package/lib/config/types.js.map +1 -0
  58. package/lib/config/utils.d.ts +5 -9
  59. package/lib/config/utils.d.ts.map +1 -0
  60. package/lib/config/utils.js +56 -258
  61. package/lib/config/utils.js.map +1 -0
  62. package/lib/config/visitors.d.ts +36 -0
  63. package/lib/config/visitors.d.ts.map +1 -0
  64. package/lib/config/visitors.js +88 -0
  65. package/lib/config/visitors.js.map +1 -0
  66. package/lib/decorators/arazzo/index.d.ts +1 -0
  67. package/lib/decorators/arazzo/index.d.ts.map +1 -0
  68. package/lib/decorators/arazzo/index.js +2 -4
  69. package/lib/decorators/arazzo/index.js.map +1 -0
  70. package/lib/decorators/async2/index.d.ts +1 -0
  71. package/lib/decorators/async2/index.d.ts.map +1 -0
  72. package/lib/decorators/async2/index.js +2 -4
  73. package/lib/decorators/async2/index.js.map +1 -0
  74. package/lib/decorators/async3/index.d.ts +1 -0
  75. package/lib/decorators/async3/index.d.ts.map +1 -0
  76. package/lib/decorators/async3/index.js +2 -4
  77. package/lib/decorators/async3/index.js.map +1 -0
  78. package/lib/decorators/common/filters/filter-helper.d.ts +2 -1
  79. package/lib/decorators/common/filters/filter-helper.d.ts.map +1 -0
  80. package/lib/decorators/common/filters/filter-helper.js +9 -12
  81. package/lib/decorators/common/filters/filter-helper.js.map +1 -0
  82. package/lib/decorators/common/filters/filter-in.d.ts +2 -1
  83. package/lib/decorators/common/filters/filter-in.d.ts.map +1 -0
  84. package/lib/decorators/common/filters/filter-in.js +5 -8
  85. package/lib/decorators/common/filters/filter-in.js.map +1 -0
  86. package/lib/decorators/common/filters/filter-out.d.ts +2 -1
  87. package/lib/decorators/common/filters/filter-out.d.ts.map +1 -0
  88. package/lib/decorators/common/filters/filter-out.js +5 -8
  89. package/lib/decorators/common/filters/filter-out.js.map +1 -0
  90. package/lib/decorators/common/info-description-override.d.ts +2 -1
  91. package/lib/decorators/common/info-description-override.d.ts.map +1 -0
  92. package/lib/decorators/common/info-description-override.js +4 -7
  93. package/lib/decorators/common/info-description-override.js.map +1 -0
  94. package/lib/decorators/common/info-override.d.ts +2 -1
  95. package/lib/decorators/common/info-override.d.ts.map +1 -0
  96. package/lib/decorators/common/info-override.js +2 -5
  97. package/lib/decorators/common/info-override.js.map +1 -0
  98. package/lib/decorators/common/media-type-examples-override.d.ts +2 -1
  99. package/lib/decorators/common/media-type-examples-override.d.ts.map +1 -0
  100. package/lib/decorators/common/media-type-examples-override.js +7 -10
  101. package/lib/decorators/common/media-type-examples-override.js.map +1 -0
  102. package/lib/decorators/common/operation-description-override.d.ts +2 -1
  103. package/lib/decorators/common/operation-description-override.d.ts.map +1 -0
  104. package/lib/decorators/common/operation-description-override.js +4 -7
  105. package/lib/decorators/common/operation-description-override.js.map +1 -0
  106. package/lib/decorators/common/remove-x-internal.d.ts +2 -1
  107. package/lib/decorators/common/remove-x-internal.d.ts.map +1 -0
  108. package/lib/decorators/common/remove-x-internal.js +11 -14
  109. package/lib/decorators/common/remove-x-internal.js.map +1 -0
  110. package/lib/decorators/common/tag-description-override.d.ts +2 -1
  111. package/lib/decorators/common/tag-description-override.d.ts.map +1 -0
  112. package/lib/decorators/common/tag-description-override.js +4 -7
  113. package/lib/decorators/common/tag-description-override.js.map +1 -0
  114. package/lib/decorators/oas2/index.d.ts +2 -2
  115. package/lib/decorators/oas2/index.d.ts.map +1 -0
  116. package/lib/decorators/oas2/index.js +16 -20
  117. package/lib/decorators/oas2/index.js.map +1 -0
  118. package/lib/decorators/oas2/remove-unused-components.d.ts +2 -1
  119. package/lib/decorators/oas2/remove-unused-components.d.ts.map +1 -0
  120. package/lib/decorators/oas2/remove-unused-components.js +4 -7
  121. package/lib/decorators/oas2/remove-unused-components.js.map +1 -0
  122. package/lib/decorators/oas3/index.d.ts +2 -2
  123. package/lib/decorators/oas3/index.d.ts.map +1 -0
  124. package/lib/decorators/oas3/index.js +18 -22
  125. package/lib/decorators/oas3/index.js.map +1 -0
  126. package/lib/decorators/oas3/remove-unused-components.d.ts +2 -1
  127. package/lib/decorators/oas3/remove-unused-components.d.ts.map +1 -0
  128. package/lib/decorators/oas3/remove-unused-components.js +5 -8
  129. package/lib/decorators/oas3/remove-unused-components.js.map +1 -0
  130. package/lib/decorators/overlay1/index.d.ts +1 -0
  131. package/lib/decorators/overlay1/index.d.ts.map +1 -0
  132. package/lib/decorators/overlay1/index.js +2 -4
  133. package/lib/decorators/overlay1/index.js.map +1 -0
  134. package/lib/env.d.ts +1 -0
  135. package/lib/env.d.ts.map +1 -0
  136. package/lib/env.js +3 -5
  137. package/lib/env.js.map +1 -0
  138. package/lib/format/codeframes.d.ts +2 -1
  139. package/lib/format/codeframes.d.ts.map +1 -0
  140. package/lib/format/codeframes.js +15 -19
  141. package/lib/format/codeframes.js.map +1 -0
  142. package/lib/format/format.d.ts +2 -1
  143. package/lib/format/format.d.ts.map +1 -0
  144. package/lib/format/format.js +57 -62
  145. package/lib/format/format.js.map +1 -0
  146. package/lib/index.d.ts +31 -26
  147. package/lib/index.d.ts.map +1 -0
  148. package/lib/index.js +25 -98
  149. package/lib/index.js.map +1 -0
  150. package/lib/js-yaml/index.d.ts +1 -0
  151. package/lib/js-yaml/index.d.ts.map +1 -0
  152. package/lib/js-yaml/index.js +7 -11
  153. package/lib/js-yaml/index.js.map +1 -0
  154. package/lib/lint.d.ts +12 -13
  155. package/lib/lint.d.ts.map +1 -0
  156. package/lib/lint.js +46 -50
  157. package/lib/lint.js.map +1 -0
  158. package/lib/logger.d.ts +2 -1
  159. package/lib/logger.d.ts.map +1 -0
  160. package/lib/logger.js +15 -17
  161. package/lib/logger.js.map +1 -0
  162. package/lib/oas-types.d.ts +395 -3
  163. package/lib/oas-types.d.ts.map +1 -0
  164. package/lib/oas-types.js +28 -32
  165. package/lib/oas-types.js.map +1 -0
  166. package/lib/ref-utils.d.ts +5 -2
  167. package/lib/ref-utils.d.ts.map +1 -0
  168. package/lib/ref-utils.js +30 -33
  169. package/lib/ref-utils.js.map +1 -0
  170. package/lib/resolve.d.ts +7 -9
  171. package/lib/resolve.d.ts.map +1 -0
  172. package/lib/resolve.js +40 -47
  173. package/lib/resolve.js.map +1 -0
  174. package/lib/rules/ajv.d.ts +4 -3
  175. package/lib/rules/ajv.d.ts.map +1 -0
  176. package/lib/rules/ajv.js +7 -10
  177. package/lib/rules/ajv.js.map +1 -0
  178. package/lib/rules/arazzo/criteria-unique.d.ts +2 -1
  179. package/lib/rules/arazzo/criteria-unique.d.ts.map +1 -0
  180. package/lib/rules/arazzo/criteria-unique.js +2 -5
  181. package/lib/rules/arazzo/criteria-unique.js.map +1 -0
  182. package/lib/rules/arazzo/index.d.ts +2 -1
  183. package/lib/rules/arazzo/index.d.ts.map +1 -0
  184. package/lib/rules/arazzo/index.js +39 -35
  185. package/lib/rules/arazzo/index.js.map +1 -0
  186. package/lib/rules/arazzo/parameters-unique.d.ts +2 -1
  187. package/lib/rules/arazzo/parameters-unique.d.ts.map +1 -0
  188. package/lib/rules/arazzo/parameters-unique.js +2 -5
  189. package/lib/rules/arazzo/parameters-unique.js.map +1 -0
  190. package/lib/rules/arazzo/requestBody-replacements-unique.d.ts +2 -1
  191. package/lib/rules/arazzo/requestBody-replacements-unique.d.ts.map +1 -0
  192. package/lib/rules/arazzo/requestBody-replacements-unique.js +2 -5
  193. package/lib/rules/arazzo/requestBody-replacements-unique.js.map +1 -0
  194. package/lib/rules/arazzo/sourceDescription-type.d.ts +2 -1
  195. package/lib/rules/arazzo/sourceDescription-type.d.ts.map +1 -0
  196. package/lib/rules/arazzo/sourceDescription-type.js +2 -5
  197. package/lib/rules/arazzo/sourceDescription-type.js.map +1 -0
  198. package/lib/rules/arazzo/sourceDescriptions-name-unique.d.ts +2 -1
  199. package/lib/rules/arazzo/sourceDescriptions-name-unique.d.ts.map +1 -0
  200. package/lib/rules/arazzo/sourceDescriptions-name-unique.js +2 -5
  201. package/lib/rules/arazzo/sourceDescriptions-name-unique.js.map +1 -0
  202. package/lib/rules/arazzo/sourceDescriptions-not-empty.d.ts +2 -1
  203. package/lib/rules/arazzo/sourceDescriptions-not-empty.d.ts.map +1 -0
  204. package/lib/rules/arazzo/sourceDescriptions-not-empty.js +2 -5
  205. package/lib/rules/arazzo/sourceDescriptions-not-empty.js.map +1 -0
  206. package/lib/rules/arazzo/step-onFailure-unique.d.ts +2 -1
  207. package/lib/rules/arazzo/step-onFailure-unique.d.ts.map +1 -0
  208. package/lib/rules/arazzo/step-onFailure-unique.js +2 -5
  209. package/lib/rules/arazzo/step-onFailure-unique.js.map +1 -0
  210. package/lib/rules/arazzo/step-onSuccess-unique.d.ts +2 -1
  211. package/lib/rules/arazzo/step-onSuccess-unique.d.ts.map +1 -0
  212. package/lib/rules/arazzo/step-onSuccess-unique.js +2 -5
  213. package/lib/rules/arazzo/step-onSuccess-unique.js.map +1 -0
  214. package/lib/rules/arazzo/stepId-unique.d.ts +2 -1
  215. package/lib/rules/arazzo/stepId-unique.d.ts.map +1 -0
  216. package/lib/rules/arazzo/stepId-unique.js +2 -5
  217. package/lib/rules/arazzo/stepId-unique.js.map +1 -0
  218. package/lib/rules/arazzo/workflow-dependsOn.d.ts +2 -1
  219. package/lib/rules/arazzo/workflow-dependsOn.d.ts.map +1 -0
  220. package/lib/rules/arazzo/workflow-dependsOn.js +2 -5
  221. package/lib/rules/arazzo/workflow-dependsOn.js.map +1 -0
  222. package/lib/rules/arazzo/workflowId-unique.d.ts +2 -1
  223. package/lib/rules/arazzo/workflowId-unique.d.ts.map +1 -0
  224. package/lib/rules/arazzo/workflowId-unique.js +2 -5
  225. package/lib/rules/arazzo/workflowId-unique.js.map +1 -0
  226. package/lib/rules/async2/channels-kebab-case.d.ts +2 -1
  227. package/lib/rules/async2/channels-kebab-case.d.ts.map +1 -0
  228. package/lib/rules/async2/channels-kebab-case.js +2 -5
  229. package/lib/rules/async2/channels-kebab-case.js.map +1 -0
  230. package/lib/rules/async2/index.d.ts +2 -1
  231. package/lib/rules/async2/index.d.ts.map +1 -0
  232. package/lib/rules/async2/index.js +21 -26
  233. package/lib/rules/async2/index.js.map +1 -0
  234. package/lib/rules/async2/no-channel-trailing-slash.d.ts +2 -1
  235. package/lib/rules/async2/no-channel-trailing-slash.d.ts.map +1 -0
  236. package/lib/rules/async2/no-channel-trailing-slash.js +2 -5
  237. package/lib/rules/async2/no-channel-trailing-slash.js.map +1 -0
  238. package/lib/rules/async3/channels-kebab-case.d.ts +2 -1
  239. package/lib/rules/async3/channels-kebab-case.d.ts.map +1 -0
  240. package/lib/rules/async3/channels-kebab-case.js +2 -5
  241. package/lib/rules/async3/channels-kebab-case.js.map +1 -0
  242. package/lib/rules/async3/index.d.ts +2 -1
  243. package/lib/rules/async3/index.d.ts.map +1 -0
  244. package/lib/rules/async3/index.js +21 -26
  245. package/lib/rules/async3/index.js.map +1 -0
  246. package/lib/rules/async3/no-channel-trailing-slash.d.ts +2 -1
  247. package/lib/rules/async3/no-channel-trailing-slash.d.ts.map +1 -0
  248. package/lib/rules/async3/no-channel-trailing-slash.js +3 -6
  249. package/lib/rules/async3/no-channel-trailing-slash.js.map +1 -0
  250. package/lib/rules/common/assertions/asserts.d.ts +3 -3
  251. package/lib/rules/common/assertions/asserts.d.ts.map +1 -0
  252. package/lib/rules/common/assertions/asserts.js +35 -51
  253. package/lib/rules/common/assertions/asserts.js.map +1 -0
  254. package/lib/rules/common/assertions/index.d.ts +4 -3
  255. package/lib/rules/common/assertions/index.d.ts.map +1 -0
  256. package/lib/rules/common/assertions/index.js +7 -10
  257. package/lib/rules/common/assertions/index.js.map +1 -0
  258. package/lib/rules/common/assertions/utils.d.ts +5 -4
  259. package/lib/rules/common/assertions/utils.d.ts.map +1 -0
  260. package/lib/rules/common/assertions/utils.js +21 -29
  261. package/lib/rules/common/assertions/utils.js.map +1 -0
  262. package/lib/rules/common/info-contact.d.ts +2 -1
  263. package/lib/rules/common/info-contact.d.ts.map +1 -0
  264. package/lib/rules/common/info-contact.js +4 -7
  265. package/lib/rules/common/info-contact.js.map +1 -0
  266. package/lib/rules/common/info-license-strict.d.ts +2 -1
  267. package/lib/rules/common/info-license-strict.d.ts.map +1 -0
  268. package/lib/rules/common/info-license-strict.js +7 -10
  269. package/lib/rules/common/info-license-strict.js.map +1 -0
  270. package/lib/rules/common/info-license-url.d.ts +2 -1
  271. package/lib/rules/common/info-license-url.d.ts.map +1 -0
  272. package/lib/rules/common/info-license-url.js +4 -7
  273. package/lib/rules/common/info-license-url.js.map +1 -0
  274. package/lib/rules/common/info-license.d.ts +2 -1
  275. package/lib/rules/common/info-license.d.ts.map +1 -0
  276. package/lib/rules/common/info-license.js +4 -7
  277. package/lib/rules/common/info-license.js.map +1 -0
  278. package/lib/rules/common/no-ambiguous-paths.d.ts +2 -1
  279. package/lib/rules/common/no-ambiguous-paths.d.ts.map +1 -0
  280. package/lib/rules/common/no-ambiguous-paths.js +2 -5
  281. package/lib/rules/common/no-ambiguous-paths.js.map +1 -0
  282. package/lib/rules/common/no-enum-type-mismatch.d.ts +2 -1
  283. package/lib/rules/common/no-enum-type-mismatch.d.ts.map +1 -0
  284. package/lib/rules/common/no-enum-type-mismatch.js +6 -9
  285. package/lib/rules/common/no-enum-type-mismatch.js.map +1 -0
  286. package/lib/rules/common/no-http-verbs-in-paths.d.ts +2 -1
  287. package/lib/rules/common/no-http-verbs-in-paths.d.ts.map +1 -0
  288. package/lib/rules/common/no-http-verbs-in-paths.js +5 -8
  289. package/lib/rules/common/no-http-verbs-in-paths.js.map +1 -0
  290. package/lib/rules/common/no-identical-paths.d.ts +2 -1
  291. package/lib/rules/common/no-identical-paths.d.ts.map +1 -0
  292. package/lib/rules/common/no-identical-paths.js +2 -5
  293. package/lib/rules/common/no-identical-paths.js.map +1 -0
  294. package/lib/rules/common/no-invalid-parameter-examples.d.ts +1 -0
  295. package/lib/rules/common/no-invalid-parameter-examples.d.ts.map +1 -0
  296. package/lib/rules/common/no-invalid-parameter-examples.js +5 -9
  297. package/lib/rules/common/no-invalid-parameter-examples.js.map +1 -0
  298. package/lib/rules/common/no-invalid-schema-examples.d.ts +2 -1
  299. package/lib/rules/common/no-invalid-schema-examples.d.ts.map +1 -0
  300. package/lib/rules/common/no-invalid-schema-examples.js +5 -9
  301. package/lib/rules/common/no-invalid-schema-examples.js.map +1 -0
  302. package/lib/rules/common/no-path-trailing-slash.d.ts +2 -1
  303. package/lib/rules/common/no-path-trailing-slash.d.ts.map +1 -0
  304. package/lib/rules/common/no-path-trailing-slash.js +2 -5
  305. package/lib/rules/common/no-path-trailing-slash.js.map +1 -0
  306. package/lib/rules/common/no-required-schema-properties-undefined.d.ts +2 -1
  307. package/lib/rules/common/no-required-schema-properties-undefined.d.ts.map +1 -0
  308. package/lib/rules/common/no-required-schema-properties-undefined.js +6 -8
  309. package/lib/rules/common/no-required-schema-properties-undefined.js.map +1 -0
  310. package/lib/rules/common/no-schema-type-mismatch.d.ts +2 -1
  311. package/lib/rules/common/no-schema-type-mismatch.d.ts.map +1 -0
  312. package/lib/rules/common/no-schema-type-mismatch.js +2 -5
  313. package/lib/rules/common/no-schema-type-mismatch.js.map +1 -0
  314. package/lib/rules/common/operation-2xx-response.d.ts +2 -1
  315. package/lib/rules/common/operation-2xx-response.d.ts.map +1 -0
  316. package/lib/rules/common/operation-2xx-response.js +5 -8
  317. package/lib/rules/common/operation-2xx-response.js.map +1 -0
  318. package/lib/rules/common/operation-4xx-response.d.ts +2 -1
  319. package/lib/rules/common/operation-4xx-response.d.ts.map +1 -0
  320. package/lib/rules/common/operation-4xx-response.js +5 -8
  321. package/lib/rules/common/operation-4xx-response.js.map +1 -0
  322. package/lib/rules/common/operation-description.d.ts +2 -1
  323. package/lib/rules/common/operation-description.d.ts.map +1 -0
  324. package/lib/rules/common/operation-description.js +4 -7
  325. package/lib/rules/common/operation-description.js.map +1 -0
  326. package/lib/rules/common/operation-operationId-unique.d.ts +2 -1
  327. package/lib/rules/common/operation-operationId-unique.d.ts.map +1 -0
  328. package/lib/rules/common/operation-operationId-unique.js +2 -5
  329. package/lib/rules/common/operation-operationId-unique.js.map +1 -0
  330. package/lib/rules/common/operation-operationId-url-safe.d.ts +2 -1
  331. package/lib/rules/common/operation-operationId-url-safe.d.ts.map +1 -0
  332. package/lib/rules/common/operation-operationId-url-safe.js +2 -5
  333. package/lib/rules/common/operation-operationId-url-safe.js.map +1 -0
  334. package/lib/rules/common/operation-operationId.d.ts +2 -1
  335. package/lib/rules/common/operation-operationId.d.ts.map +1 -0
  336. package/lib/rules/common/operation-operationId.js +4 -7
  337. package/lib/rules/common/operation-operationId.js.map +1 -0
  338. package/lib/rules/common/operation-parameters-unique.d.ts +2 -1
  339. package/lib/rules/common/operation-parameters-unique.d.ts.map +1 -0
  340. package/lib/rules/common/operation-parameters-unique.js +2 -5
  341. package/lib/rules/common/operation-parameters-unique.js.map +1 -0
  342. package/lib/rules/common/operation-singular-tag.d.ts +2 -1
  343. package/lib/rules/common/operation-singular-tag.d.ts.map +1 -0
  344. package/lib/rules/common/operation-singular-tag.js +2 -5
  345. package/lib/rules/common/operation-singular-tag.js.map +1 -0
  346. package/lib/rules/common/operation-summary.d.ts +2 -1
  347. package/lib/rules/common/operation-summary.d.ts.map +1 -0
  348. package/lib/rules/common/operation-summary.js +4 -7
  349. package/lib/rules/common/operation-summary.js.map +1 -0
  350. package/lib/rules/common/operation-tag-defined.d.ts +2 -1
  351. package/lib/rules/common/operation-tag-defined.d.ts.map +1 -0
  352. package/lib/rules/common/operation-tag-defined.js +2 -5
  353. package/lib/rules/common/operation-tag-defined.js.map +1 -0
  354. package/lib/rules/common/parameter-description.d.ts +2 -1
  355. package/lib/rules/common/parameter-description.d.ts.map +1 -0
  356. package/lib/rules/common/parameter-description.js +2 -5
  357. package/lib/rules/common/parameter-description.js.map +1 -0
  358. package/lib/rules/common/path-declaration-must-exist.d.ts +2 -1
  359. package/lib/rules/common/path-declaration-must-exist.d.ts.map +1 -0
  360. package/lib/rules/common/path-declaration-must-exist.js +2 -5
  361. package/lib/rules/common/path-declaration-must-exist.js.map +1 -0
  362. package/lib/rules/common/path-excludes-patterns.d.ts +2 -1
  363. package/lib/rules/common/path-excludes-patterns.d.ts.map +1 -0
  364. package/lib/rules/common/path-excludes-patterns.js +2 -5
  365. package/lib/rules/common/path-excludes-patterns.js.map +1 -0
  366. package/lib/rules/common/path-http-verbs-order.d.ts +2 -1
  367. package/lib/rules/common/path-http-verbs-order.d.ts.map +1 -0
  368. package/lib/rules/common/path-http-verbs-order.js +2 -5
  369. package/lib/rules/common/path-http-verbs-order.js.map +1 -0
  370. package/lib/rules/common/path-not-include-query.d.ts +2 -1
  371. package/lib/rules/common/path-not-include-query.d.ts.map +1 -0
  372. package/lib/rules/common/path-not-include-query.js +2 -5
  373. package/lib/rules/common/path-not-include-query.js.map +1 -0
  374. package/lib/rules/common/path-params-defined.d.ts +2 -1
  375. package/lib/rules/common/path-params-defined.d.ts.map +1 -0
  376. package/lib/rules/common/path-params-defined.js +2 -5
  377. package/lib/rules/common/path-params-defined.js.map +1 -0
  378. package/lib/rules/common/path-segment-plural.d.ts +2 -1
  379. package/lib/rules/common/path-segment-plural.d.ts.map +1 -0
  380. package/lib/rules/common/path-segment-plural.js +6 -9
  381. package/lib/rules/common/path-segment-plural.js.map +1 -0
  382. package/lib/rules/common/paths-kebab-case.d.ts +2 -1
  383. package/lib/rules/common/paths-kebab-case.d.ts.map +1 -0
  384. package/lib/rules/common/paths-kebab-case.js +2 -5
  385. package/lib/rules/common/paths-kebab-case.js.map +1 -0
  386. package/lib/rules/common/required-string-property-missing-min-length.d.ts +2 -1
  387. package/lib/rules/common/required-string-property-missing-min-length.d.ts.map +1 -0
  388. package/lib/rules/common/required-string-property-missing-min-length.js +2 -5
  389. package/lib/rules/common/required-string-property-missing-min-length.js.map +1 -0
  390. package/lib/rules/common/response-contains-header.d.ts +2 -1
  391. package/lib/rules/common/response-contains-header.d.ts.map +1 -0
  392. package/lib/rules/common/response-contains-header.js +5 -8
  393. package/lib/rules/common/response-contains-header.js.map +1 -0
  394. package/lib/rules/common/scalar-property-missing-example.d.ts +2 -1
  395. package/lib/rules/common/scalar-property-missing-example.d.ts.map +1 -0
  396. package/lib/rules/common/scalar-property-missing-example.js +6 -8
  397. package/lib/rules/common/scalar-property-missing-example.js.map +1 -0
  398. package/lib/rules/common/security-defined.d.ts +2 -1
  399. package/lib/rules/common/security-defined.d.ts.map +1 -0
  400. package/lib/rules/common/security-defined.js +2 -5
  401. package/lib/rules/common/security-defined.js.map +1 -0
  402. package/lib/rules/common/spec-strict-refs.d.ts +2 -1
  403. package/lib/rules/common/spec-strict-refs.d.ts.map +1 -0
  404. package/lib/rules/common/spec-strict-refs.js +4 -7
  405. package/lib/rules/common/spec-strict-refs.js.map +1 -0
  406. package/lib/rules/common/struct.d.ts +2 -1
  407. package/lib/rules/common/struct.d.ts.map +1 -0
  408. package/lib/rules/common/struct.js +19 -22
  409. package/lib/rules/common/struct.js.map +1 -0
  410. package/lib/rules/common/tag-description.d.ts +2 -1
  411. package/lib/rules/common/tag-description.d.ts.map +1 -0
  412. package/lib/rules/common/tag-description.js +4 -7
  413. package/lib/rules/common/tag-description.js.map +1 -0
  414. package/lib/rules/common/tags-alphabetical.d.ts +2 -1
  415. package/lib/rules/common/tags-alphabetical.d.ts.map +1 -0
  416. package/lib/rules/common/tags-alphabetical.js +2 -5
  417. package/lib/rules/common/tags-alphabetical.js.map +1 -0
  418. package/lib/rules/no-unresolved-refs.d.ts +4 -3
  419. package/lib/rules/no-unresolved-refs.d.ts.map +1 -0
  420. package/lib/rules/no-unresolved-refs.js +5 -9
  421. package/lib/rules/no-unresolved-refs.js.map +1 -0
  422. package/lib/rules/oas2/boolean-parameter-prefixes.d.ts +2 -1
  423. package/lib/rules/oas2/boolean-parameter-prefixes.d.ts.map +1 -0
  424. package/lib/rules/oas2/boolean-parameter-prefixes.js +2 -5
  425. package/lib/rules/oas2/boolean-parameter-prefixes.js.map +1 -0
  426. package/lib/rules/oas2/index.d.ts +2 -1
  427. package/lib/rules/oas2/index.d.ts.map +1 -0
  428. package/lib/rules/oas2/index.js +94 -99
  429. package/lib/rules/oas2/index.js.map +1 -0
  430. package/lib/rules/oas2/request-mime-type.d.ts +2 -1
  431. package/lib/rules/oas2/request-mime-type.d.ts.map +1 -0
  432. package/lib/rules/oas2/request-mime-type.js +5 -8
  433. package/lib/rules/oas2/request-mime-type.js.map +1 -0
  434. package/lib/rules/oas2/response-contains-property.d.ts +2 -1
  435. package/lib/rules/oas2/response-contains-property.d.ts.map +1 -0
  436. package/lib/rules/oas2/response-contains-property.js +5 -8
  437. package/lib/rules/oas2/response-contains-property.js.map +1 -0
  438. package/lib/rules/oas2/response-mime-type.d.ts +2 -1
  439. package/lib/rules/oas2/response-mime-type.d.ts.map +1 -0
  440. package/lib/rules/oas2/response-mime-type.js +5 -8
  441. package/lib/rules/oas2/response-mime-type.js.map +1 -0
  442. package/lib/rules/oas3/array-parameter-serialization.d.ts +2 -1
  443. package/lib/rules/oas3/array-parameter-serialization.d.ts.map +1 -0
  444. package/lib/rules/oas3/array-parameter-serialization.js +4 -7
  445. package/lib/rules/oas3/array-parameter-serialization.js.map +1 -0
  446. package/lib/rules/oas3/boolean-parameter-prefixes.d.ts +2 -1
  447. package/lib/rules/oas3/boolean-parameter-prefixes.d.ts.map +1 -0
  448. package/lib/rules/oas3/boolean-parameter-prefixes.js +2 -5
  449. package/lib/rules/oas3/boolean-parameter-prefixes.js.map +1 -0
  450. package/lib/rules/oas3/component-name-unique.d.ts +2 -1
  451. package/lib/rules/oas3/component-name-unique.d.ts.map +1 -0
  452. package/lib/rules/oas3/component-name-unique.js +2 -5
  453. package/lib/rules/oas3/component-name-unique.js.map +1 -0
  454. package/lib/rules/oas3/index.d.ts +2 -1
  455. package/lib/rules/oas3/index.d.ts.map +1 -0
  456. package/lib/rules/oas3/index.js +118 -123
  457. package/lib/rules/oas3/index.js.map +1 -0
  458. package/lib/rules/oas3/no-empty-servers.d.ts +2 -1
  459. package/lib/rules/oas3/no-empty-servers.d.ts.map +1 -0
  460. package/lib/rules/oas3/no-empty-servers.js +2 -5
  461. package/lib/rules/oas3/no-empty-servers.js.map +1 -0
  462. package/lib/rules/oas3/no-example-value-and-externalValue.d.ts +2 -1
  463. package/lib/rules/oas3/no-example-value-and-externalValue.d.ts.map +1 -0
  464. package/lib/rules/oas3/no-example-value-and-externalValue.js +2 -5
  465. package/lib/rules/oas3/no-example-value-and-externalValue.js.map +1 -0
  466. package/lib/rules/oas3/no-invalid-media-type-examples.d.ts +2 -1
  467. package/lib/rules/oas3/no-invalid-media-type-examples.d.ts.map +1 -0
  468. package/lib/rules/oas3/no-invalid-media-type-examples.js +6 -10
  469. package/lib/rules/oas3/no-invalid-media-type-examples.js.map +1 -0
  470. package/lib/rules/oas3/no-server-example.com.d.ts +2 -1
  471. package/lib/rules/oas3/no-server-example.com.d.ts.map +1 -0
  472. package/lib/rules/oas3/no-server-example.com.js +2 -5
  473. package/lib/rules/oas3/no-server-example.com.js.map +1 -0
  474. package/lib/rules/oas3/no-server-trailing-slash.d.ts +2 -1
  475. package/lib/rules/oas3/no-server-trailing-slash.d.ts.map +1 -0
  476. package/lib/rules/oas3/no-server-trailing-slash.js +2 -5
  477. package/lib/rules/oas3/no-server-trailing-slash.js.map +1 -0
  478. package/lib/rules/oas3/no-server-variables-empty-enum.d.ts +2 -1
  479. package/lib/rules/oas3/no-server-variables-empty-enum.d.ts.map +1 -0
  480. package/lib/rules/oas3/no-server-variables-empty-enum.js +2 -5
  481. package/lib/rules/oas3/no-server-variables-empty-enum.js.map +1 -0
  482. package/lib/rules/oas3/no-undefined-server-variable.d.ts +2 -1
  483. package/lib/rules/oas3/no-undefined-server-variable.d.ts.map +1 -0
  484. package/lib/rules/oas3/no-undefined-server-variable.js +3 -6
  485. package/lib/rules/oas3/no-undefined-server-variable.js.map +1 -0
  486. package/lib/rules/oas3/no-unused-components.d.ts +2 -1
  487. package/lib/rules/oas3/no-unused-components.d.ts.map +1 -0
  488. package/lib/rules/oas3/no-unused-components.js +2 -5
  489. package/lib/rules/oas3/no-unused-components.js.map +1 -0
  490. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.d.ts +2 -1
  491. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.d.ts.map +1 -0
  492. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.js +6 -9
  493. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.js.map +1 -0
  494. package/lib/rules/oas3/request-mime-type.d.ts +2 -1
  495. package/lib/rules/oas3/request-mime-type.d.ts.map +1 -0
  496. package/lib/rules/oas3/request-mime-type.js +6 -9
  497. package/lib/rules/oas3/request-mime-type.js.map +1 -0
  498. package/lib/rules/oas3/response-contains-property.d.ts +2 -1
  499. package/lib/rules/oas3/response-contains-property.d.ts.map +1 -0
  500. package/lib/rules/oas3/response-contains-property.js +5 -8
  501. package/lib/rules/oas3/response-contains-property.js.map +1 -0
  502. package/lib/rules/oas3/response-mime-type.d.ts +2 -1
  503. package/lib/rules/oas3/response-mime-type.d.ts.map +1 -0
  504. package/lib/rules/oas3/response-mime-type.js +6 -9
  505. package/lib/rules/oas3/response-mime-type.js.map +1 -0
  506. package/lib/rules/oas3/spec-components-invalid-map-name.d.ts +2 -1
  507. package/lib/rules/oas3/spec-components-invalid-map-name.d.ts.map +1 -0
  508. package/lib/rules/oas3/spec-components-invalid-map-name.js +2 -5
  509. package/lib/rules/oas3/spec-components-invalid-map-name.js.map +1 -0
  510. package/lib/rules/other/stats.d.ts +4 -3
  511. package/lib/rules/other/stats.d.ts.map +1 -0
  512. package/lib/rules/other/stats.js +2 -5
  513. package/lib/rules/other/stats.js.map +1 -0
  514. package/lib/rules/overlay1/index.d.ts +2 -1
  515. package/lib/rules/overlay1/index.d.ts.map +1 -0
  516. package/lib/rules/overlay1/index.js +9 -11
  517. package/lib/rules/overlay1/index.js.map +1 -0
  518. package/lib/rules/respect/no-criteria-xpath.d.ts +2 -1
  519. package/lib/rules/respect/no-criteria-xpath.d.ts.map +1 -0
  520. package/lib/rules/respect/no-criteria-xpath.js +2 -5
  521. package/lib/rules/respect/no-criteria-xpath.js.map +1 -0
  522. package/lib/rules/respect/no-x-security-scheme-name-in-workflow.d.ts +3 -0
  523. package/lib/rules/respect/no-x-security-scheme-name-in-workflow.d.ts.map +1 -0
  524. package/lib/rules/respect/no-x-security-scheme-name-in-workflow.js +21 -0
  525. package/lib/rules/respect/no-x-security-scheme-name-in-workflow.js.map +1 -0
  526. package/lib/rules/respect/no-x-security-scheme-name-without-openapi.d.ts +3 -0
  527. package/lib/rules/respect/no-x-security-scheme-name-without-openapi.d.ts.map +1 -0
  528. package/lib/rules/respect/no-x-security-scheme-name-without-openapi.js +25 -0
  529. package/lib/rules/respect/no-x-security-scheme-name-without-openapi.js.map +1 -0
  530. package/lib/rules/respect/respect-supported-versions.d.ts +2 -1
  531. package/lib/rules/respect/respect-supported-versions.d.ts.map +1 -0
  532. package/lib/rules/respect/respect-supported-versions.js +7 -10
  533. package/lib/rules/respect/respect-supported-versions.js.map +1 -0
  534. package/lib/rules/respect/x-security-scheme-required-values.d.ts +3 -0
  535. package/lib/rules/respect/x-security-scheme-required-values.d.ts.map +1 -0
  536. package/lib/rules/respect/x-security-scheme-required-values.js +60 -0
  537. package/lib/rules/respect/x-security-scheme-required-values.js.map +1 -0
  538. package/lib/rules/utils.d.ts +4 -4
  539. package/lib/rules/utils.d.ts.map +1 -0
  540. package/lib/rules/utils.js +20 -43
  541. package/lib/rules/utils.js.map +1 -0
  542. package/lib/types/arazzo.d.ts +2 -1
  543. package/lib/types/arazzo.d.ts.map +1 -0
  544. package/lib/types/arazzo.js +40 -23
  545. package/lib/types/arazzo.js.map +1 -0
  546. package/lib/types/asyncapi2.d.ts +2 -1
  547. package/lib/types/asyncapi2.d.ts.map +1 -0
  548. package/lib/types/asyncapi2.js +54 -56
  549. package/lib/types/asyncapi2.js.map +1 -0
  550. package/lib/types/asyncapi3.d.ts +2 -1
  551. package/lib/types/asyncapi3.d.ts.map +1 -0
  552. package/lib/types/asyncapi3.js +41 -43
  553. package/lib/types/asyncapi3.js.map +1 -0
  554. package/lib/types/index.d.ts +2 -0
  555. package/lib/types/index.d.ts.map +1 -0
  556. package/lib/types/index.js +7 -13
  557. package/lib/types/index.js.map +1 -0
  558. package/lib/types/json-schema-adapter.d.ts +2 -1
  559. package/lib/types/json-schema-adapter.d.ts.map +1 -0
  560. package/lib/types/json-schema-adapter.js +15 -17
  561. package/lib/types/json-schema-adapter.js.map +1 -0
  562. package/lib/types/oas2.d.ts +85 -3
  563. package/lib/types/oas2.d.ts.map +1 -0
  564. package/lib/types/oas2.js +17 -19
  565. package/lib/types/oas2.js.map +1 -0
  566. package/lib/types/oas3.d.ts +159 -3
  567. package/lib/types/oas3.d.ts.map +1 -0
  568. package/lib/types/oas3.js +44 -46
  569. package/lib/types/oas3.js.map +1 -0
  570. package/lib/types/oas3_1.d.ts +162 -3
  571. package/lib/types/oas3_1.d.ts.map +1 -0
  572. package/lib/types/oas3_1.js +19 -21
  573. package/lib/types/oas3_1.js.map +1 -0
  574. package/lib/types/overlay.d.ts +2 -1
  575. package/lib/types/overlay.d.ts.map +1 -0
  576. package/lib/types/overlay.js +4 -6
  577. package/lib/types/overlay.js.map +1 -0
  578. package/lib/types/redocly-yaml.d.ts +6 -10
  579. package/lib/types/redocly-yaml.d.ts.map +1 -0
  580. package/lib/types/redocly-yaml.js +74 -813
  581. package/lib/types/redocly-yaml.js.map +1 -0
  582. package/lib/typings/arazzo.d.ts +41 -0
  583. package/lib/typings/arazzo.d.ts.map +1 -0
  584. package/lib/typings/arazzo.js +3 -5
  585. package/lib/typings/arazzo.js.map +1 -0
  586. package/lib/typings/asyncapi.d.ts +1 -0
  587. package/lib/typings/asyncapi.d.ts.map +1 -0
  588. package/lib/typings/asyncapi.js +2 -2
  589. package/lib/typings/asyncapi.js.map +1 -0
  590. package/lib/typings/asyncapi3.d.ts +1 -0
  591. package/lib/typings/asyncapi3.d.ts.map +1 -0
  592. package/lib/typings/asyncapi3.js +2 -2
  593. package/lib/typings/asyncapi3.js.map +1 -0
  594. package/lib/typings/common.d.ts +1 -0
  595. package/lib/typings/common.d.ts.map +1 -0
  596. package/lib/typings/common.js +2 -2
  597. package/lib/typings/common.js.map +1 -0
  598. package/lib/typings/openapi.d.ts +45 -15
  599. package/lib/typings/openapi.d.ts.map +1 -0
  600. package/lib/typings/openapi.js +2 -2
  601. package/lib/typings/openapi.js.map +1 -0
  602. package/lib/typings/overlay.d.ts +1 -0
  603. package/lib/typings/overlay.d.ts.map +1 -0
  604. package/lib/typings/overlay.js +2 -4
  605. package/lib/typings/overlay.js.map +1 -0
  606. package/lib/typings/swagger.d.ts +2 -1
  607. package/lib/typings/swagger.d.ts.map +1 -0
  608. package/lib/typings/swagger.js +2 -2
  609. package/lib/typings/swagger.js.map +1 -0
  610. package/lib/utils/error.d.ts +3 -0
  611. package/lib/utils/error.d.ts.map +1 -0
  612. package/lib/utils/error.js +3 -0
  613. package/lib/utils/error.js.map +1 -0
  614. package/lib/utils.d.ts +6 -11
  615. package/lib/utils.d.ts.map +1 -0
  616. package/lib/utils.js +50 -123
  617. package/lib/utils.js.map +1 -0
  618. package/lib/visitors.d.ts +16 -15
  619. package/lib/visitors.d.ts.map +1 -0
  620. package/lib/visitors.js +4 -6
  621. package/lib/visitors.js.map +1 -0
  622. package/lib/walk.d.ts +9 -8
  623. package/lib/walk.d.ts.map +1 -0
  624. package/lib/walk.js +31 -28
  625. package/lib/walk.js.map +1 -0
  626. package/package.json +31 -10
  627. package/CHANGELOG.md +0 -563
  628. package/__tests__/utils.ts +0 -92
  629. package/lib/benchmark/benches/lint-with-many-rules.bench.d.ts +0 -4
  630. package/lib/benchmark/benches/lint-with-many-rules.bench.js +0 -38
  631. package/lib/benchmark/benches/lint-with-nested-rule.bench.d.ts +0 -4
  632. package/lib/benchmark/benches/lint-with-nested-rule.bench.js +0 -44
  633. package/lib/benchmark/benches/lint-with-no-rules.bench.d.ts +0 -4
  634. package/lib/benchmark/benches/lint-with-no-rules.bench.js +0 -25
  635. package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.d.ts +0 -4
  636. package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.js +0 -37
  637. package/lib/benchmark/benches/lint-with-top-level-rule.bench.d.ts +0 -4
  638. package/lib/benchmark/benches/lint-with-top-level-rule.bench.js +0 -36
  639. package/lib/benchmark/benches/recommended-oas3.bench.d.ts +0 -3
  640. package/lib/benchmark/benches/recommended-oas3.bench.js +0 -21
  641. package/lib/benchmark/benches/resolve-with-no-external.bench.d.ts +0 -3
  642. package/lib/benchmark/benches/resolve-with-no-external.bench.js +0 -22
  643. package/lib/benchmark/utils.d.ts +0 -6
  644. package/lib/benchmark/utils.js +0 -34
  645. package/lib/decorators/common/registry-dependencies.d.ts +0 -2
  646. package/lib/decorators/common/registry-dependencies.js +0 -24
  647. package/lib/output.d.ts +0 -3
  648. package/lib/output.js +0 -9
  649. package/lib/redocly/domains.d.ts +0 -14
  650. package/lib/redocly/domains.js +0 -41
  651. package/lib/redocly/index.d.ts +0 -30
  652. package/lib/redocly/index.js +0 -131
  653. package/lib/redocly/redocly-client-types.d.ts +0 -8
  654. package/lib/redocly/redocly-client-types.js +0 -2
  655. package/lib/redocly/registry-api-types.d.ts +0 -29
  656. package/lib/redocly/registry-api-types.js +0 -2
  657. package/lib/redocly/registry-api.d.ts +0 -17
  658. package/lib/redocly/registry-api.js +0 -100
  659. package/src/__tests__/__snapshots__/bundle.test.ts.snap +0 -461
  660. package/src/__tests__/bundle.test.ts +0 -478
  661. package/src/__tests__/codeframes.test.ts +0 -530
  662. package/src/__tests__/fixtures/.redocly.lint-ignore.yaml +0 -5
  663. package/src/__tests__/fixtures/extension.js +0 -24
  664. package/src/__tests__/fixtures/lint/openapi.yaml +0 -10
  665. package/src/__tests__/fixtures/redocly.yaml +0 -2
  666. package/src/__tests__/fixtures/refs/definitions.yaml +0 -3
  667. package/src/__tests__/fixtures/refs/examples.yaml +0 -8
  668. package/src/__tests__/fixtures/refs/external-request-body.yaml +0 -13
  669. package/src/__tests__/fixtures/refs/externalref.yaml +0 -35
  670. package/src/__tests__/fixtures/refs/hosted.yaml +0 -35
  671. package/src/__tests__/fixtures/refs/openapi-with-external-refs-conflicting-names.yaml +0 -21
  672. package/src/__tests__/fixtures/refs/openapi-with-external-refs.yaml +0 -33
  673. package/src/__tests__/fixtures/refs/openapi-with-special-names-in-props.yaml +0 -19
  674. package/src/__tests__/fixtures/refs/openapi-with-url-refs.yaml +0 -18
  675. package/src/__tests__/fixtures/refs/param-b.yaml +0 -1
  676. package/src/__tests__/fixtures/refs/param-c.yaml +0 -1
  677. package/src/__tests__/fixtures/refs/rename.yaml +0 -1
  678. package/src/__tests__/fixtures/refs/requestBody.yaml +0 -9
  679. package/src/__tests__/fixtures/refs/schema-a.yaml +0 -1
  680. package/src/__tests__/fixtures/refs/simple.yaml +0 -1
  681. package/src/__tests__/fixtures/refs/vendor.schema.yaml +0 -20
  682. package/src/__tests__/fixtures/resolve/External.yaml +0 -10
  683. package/src/__tests__/fixtures/resolve/External2.yaml +0 -4
  684. package/src/__tests__/fixtures/resolve/description.md +0 -3
  685. package/src/__tests__/fixtures/resolve/externalInfo.yaml +0 -4
  686. package/src/__tests__/fixtures/resolve/externalLicense.yaml +0 -1
  687. package/src/__tests__/fixtures/resolve/openapi-with-back.yaml +0 -13
  688. package/src/__tests__/fixtures/resolve/openapi-with-md-description.yaml +0 -5
  689. package/src/__tests__/fixtures/resolve/openapi.yaml +0 -28
  690. package/src/__tests__/fixtures/resolve/schemas/type-a.yaml +0 -10
  691. package/src/__tests__/fixtures/resolve/schemas/type-b.yaml +0 -6
  692. package/src/__tests__/fixtures/resolve/transitive/a.yaml +0 -1
  693. package/src/__tests__/fixtures/resolve/transitive/components.yaml +0 -5
  694. package/src/__tests__/fixtures/resolve/transitive/schemas.yaml +0 -3
  695. package/src/__tests__/format.test.ts +0 -147
  696. package/src/__tests__/js-yaml.test.ts +0 -73
  697. package/src/__tests__/lint.test.ts +0 -1772
  698. package/src/__tests__/logger-browser.test.ts +0 -53
  699. package/src/__tests__/logger.test.ts +0 -47
  700. package/src/__tests__/login.test.ts +0 -17
  701. package/src/__tests__/normalizeVisitors.test.ts +0 -169
  702. package/src/__tests__/output-browser.test.ts +0 -18
  703. package/src/__tests__/output.test.ts +0 -15
  704. package/src/__tests__/ref-utils.test.ts +0 -142
  705. package/src/__tests__/resolve-http.test.ts +0 -77
  706. package/src/__tests__/resolve.test.ts +0 -431
  707. package/src/__tests__/utils-browser.test.ts +0 -11
  708. package/src/__tests__/utils.test.ts +0 -144
  709. package/src/__tests__/walk.test.ts +0 -1596
  710. package/src/benchmark/benches/lint-with-many-rules.bench.ts +0 -41
  711. package/src/benchmark/benches/lint-with-nested-rule.bench.ts +0 -45
  712. package/src/benchmark/benches/lint-with-no-rules.bench.ts +0 -27
  713. package/src/benchmark/benches/lint-with-top-level-rule-report.bench.ts +0 -40
  714. package/src/benchmark/benches/lint-with-top-level-rule.bench.ts +0 -38
  715. package/src/benchmark/benches/rebilly.yaml +0 -32272
  716. package/src/benchmark/benches/recommended-oas3.bench.ts +0 -22
  717. package/src/benchmark/benches/resolve-with-no-external.bench.ts +0 -23
  718. package/src/benchmark/benchmark.js +0 -311
  719. package/src/benchmark/colors.js +0 -29
  720. package/src/benchmark/fork.js +0 -87
  721. package/src/benchmark/utils.ts +0 -37
  722. package/src/bundle.ts +0 -531
  723. package/src/config/__tests__/__snapshots__/config-resolvers.test.ts.snap +0 -485
  724. package/src/config/__tests__/__snapshots__/config.test.ts.snap +0 -232
  725. package/src/config/__tests__/config-resolvers.test.ts +0 -668
  726. package/src/config/__tests__/config.test.ts +0 -356
  727. package/src/config/__tests__/fixtures/ingore-file.ts +0 -8
  728. package/src/config/__tests__/fixtures/load-external.yaml +0 -2
  729. package/src/config/__tests__/fixtures/load-redocly.yaml +0 -2
  730. package/src/config/__tests__/fixtures/plugin-config.yaml +0 -2
  731. package/src/config/__tests__/fixtures/plugin.js +0 -56
  732. package/src/config/__tests__/fixtures/resolve-config/api/nested-config.yaml +0 -11
  733. package/src/config/__tests__/fixtures/resolve-config/api/plugin.js +0 -69
  734. package/src/config/__tests__/fixtures/resolve-config/local-config-with-circular.yaml +0 -7
  735. package/src/config/__tests__/fixtures/resolve-config/local-config-with-commonjs-export-function.yaml +0 -2
  736. package/src/config/__tests__/fixtures/resolve-config/local-config-with-custom-function.yaml +0 -17
  737. package/src/config/__tests__/fixtures/resolve-config/local-config-with-esm.yaml +0 -2
  738. package/src/config/__tests__/fixtures/resolve-config/local-config-with-file.yaml +0 -18
  739. package/src/config/__tests__/fixtures/resolve-config/local-config-with-plugin-init.yaml +0 -2
  740. package/src/config/__tests__/fixtures/resolve-config/local-config-with-realm-plugin.yaml +0 -2
  741. package/src/config/__tests__/fixtures/resolve-config/local-config-with-wrong-custom-function.yaml +0 -15
  742. package/src/config/__tests__/fixtures/resolve-config/local-config.yaml +0 -9
  743. package/src/config/__tests__/fixtures/resolve-config/plugin-esm.mjs +0 -10
  744. package/src/config/__tests__/fixtures/resolve-config/plugin-with-export-function.cjs +0 -10
  745. package/src/config/__tests__/fixtures/resolve-config/plugin-with-init-logic.js +0 -9
  746. package/src/config/__tests__/fixtures/resolve-config/plugin.js +0 -80
  747. package/src/config/__tests__/fixtures/resolve-config/realm-plugin.js +0 -12
  748. package/src/config/__tests__/fixtures/resolve-refs-in-config/config-with-refs.yaml +0 -8
  749. package/src/config/__tests__/fixtures/resolve-refs-in-config/rules.yaml +0 -2
  750. package/src/config/__tests__/fixtures/resolve-refs-in-config/seo.yaml +0 -1
  751. package/src/config/__tests__/fixtures/resolve-remote-configs/nested-remote-config.yaml +0 -3
  752. package/src/config/__tests__/fixtures/resolve-remote-configs/remote-config.yaml +0 -4
  753. package/src/config/__tests__/load.test.ts +0 -320
  754. package/src/config/__tests__/resolve-plugins.test.ts +0 -30
  755. package/src/config/__tests__/utils.test.ts +0 -225
  756. package/src/config/all.ts +0 -234
  757. package/src/config/builtIn.ts +0 -59
  758. package/src/config/config-resolvers.ts +0 -657
  759. package/src/config/config.ts +0 -423
  760. package/src/config/index.ts +0 -7
  761. package/src/config/load.ts +0 -213
  762. package/src/config/minimal.ts +0 -210
  763. package/src/config/recommended-strict.ts +0 -210
  764. package/src/config/recommended.ts +0 -210
  765. package/src/config/rules.ts +0 -72
  766. package/src/config/spec.ts +0 -33
  767. package/src/config/types.ts +0 -306
  768. package/src/config/utils.ts +0 -439
  769. package/src/decorators/__tests__/filter-in.test.ts +0 -313
  770. package/src/decorators/__tests__/filter-out.test.ts +0 -344
  771. package/src/decorators/__tests__/media-type-examples-override.test.ts +0 -665
  772. package/src/decorators/__tests__/remove-x-internal.test.ts +0 -416
  773. package/src/decorators/__tests__/resources/request.yaml +0 -3
  774. package/src/decorators/__tests__/resources/response.yaml +0 -3
  775. package/src/decorators/arazzo/index.ts +0 -1
  776. package/src/decorators/async2/index.ts +0 -1
  777. package/src/decorators/async3/index.ts +0 -1
  778. package/src/decorators/common/filters/filter-helper.ts +0 -73
  779. package/src/decorators/common/filters/filter-in.ts +0 -19
  780. package/src/decorators/common/filters/filter-out.ts +0 -19
  781. package/src/decorators/common/info-description-override.ts +0 -25
  782. package/src/decorators/common/info-override.ts +0 -15
  783. package/src/decorators/common/media-type-examples-override.ts +0 -80
  784. package/src/decorators/common/operation-description-override.ts +0 -31
  785. package/src/decorators/common/registry-dependencies.ts +0 -25
  786. package/src/decorators/common/remove-x-internal.ts +0 -77
  787. package/src/decorators/common/tag-description-override.ts +0 -26
  788. package/src/decorators/oas2/__tests__/remove-unused-components.test.ts +0 -228
  789. package/src/decorators/oas2/index.ts +0 -21
  790. package/src/decorators/oas2/remove-unused-components.ts +0 -109
  791. package/src/decorators/oas3/__tests__/remove-unused-components.test.ts +0 -313
  792. package/src/decorators/oas3/index.ts +0 -23
  793. package/src/decorators/oas3/remove-unused-components.ts +0 -138
  794. package/src/decorators/overlay1/index.ts +0 -1
  795. package/src/env.ts +0 -5
  796. package/src/format/codeframes.ts +0 -217
  797. package/src/format/format.ts +0 -479
  798. package/src/index.ts +0 -91
  799. package/src/js-yaml/index.ts +0 -16
  800. package/src/lint.ts +0 -190
  801. package/src/logger.ts +0 -36
  802. package/src/oas-types.ts +0 -178
  803. package/src/output.ts +0 -7
  804. package/src/redocly/__tests__/domains.test.ts +0 -52
  805. package/src/redocly/__tests__/redocly-client.test.ts +0 -156
  806. package/src/redocly/domains.ts +0 -48
  807. package/src/redocly/index.ts +0 -177
  808. package/src/redocly/redocly-client-types.ts +0 -10
  809. package/src/redocly/registry-api-types.ts +0 -32
  810. package/src/redocly/registry-api.ts +0 -147
  811. package/src/ref-utils.ts +0 -91
  812. package/src/resolve.ts +0 -461
  813. package/src/rules/__tests__/fixtures/code-sample.php +0 -9
  814. package/src/rules/__tests__/fixtures/invalid-yaml.yaml +0 -1
  815. package/src/rules/__tests__/fixtures/ref.yaml +0 -1
  816. package/src/rules/__tests__/no-unresolved-refs.test.ts +0 -271
  817. package/src/rules/__tests__/utils.test.ts +0 -160
  818. package/src/rules/ajv.ts +0 -105
  819. package/src/rules/arazzo/__tests__/criteria-unique.test.ts +0 -160
  820. package/src/rules/arazzo/__tests__/no-criteria-xpath.test.ts +0 -126
  821. package/src/rules/arazzo/__tests__/parameters-unique.test.ts +0 -113
  822. package/src/rules/arazzo/__tests__/requestBody-replacements-unique.test.ts +0 -108
  823. package/src/rules/arazzo/__tests__/respect-supported-versions.test.ts +0 -116
  824. package/src/rules/arazzo/__tests__/source-description-type.test.ts +0 -78
  825. package/src/rules/arazzo/__tests__/sourceDescription-name-unique.test.ts +0 -78
  826. package/src/rules/arazzo/__tests__/sourceDescriptions-not-empty.test.ts +0 -104
  827. package/src/rules/arazzo/__tests__/step-onFailure-unique.test.ts +0 -110
  828. package/src/rules/arazzo/__tests__/step-onSuccess-unique.test.ts +0 -110
  829. package/src/rules/arazzo/__tests__/stepId-unique.test.ts +0 -94
  830. package/src/rules/arazzo/__tests__/workflow-dependsOn.test.ts +0 -209
  831. package/src/rules/arazzo/__tests__/workflowId-unique.test.ts +0 -88
  832. package/src/rules/arazzo/criteria-unique.ts +0 -70
  833. package/src/rules/arazzo/index.ts +0 -38
  834. package/src/rules/arazzo/parameters-unique.ts +0 -33
  835. package/src/rules/arazzo/requestBody-replacements-unique.ts +0 -33
  836. package/src/rules/arazzo/sourceDescription-type.ts +0 -21
  837. package/src/rules/arazzo/sourceDescriptions-name-unique.ts +0 -23
  838. package/src/rules/arazzo/sourceDescriptions-not-empty.ts +0 -17
  839. package/src/rules/arazzo/step-onFailure-unique.ts +0 -33
  840. package/src/rules/arazzo/step-onSuccess-unique.ts +0 -33
  841. package/src/rules/arazzo/stepId-unique.ts +0 -24
  842. package/src/rules/arazzo/workflow-dependsOn.ts +0 -56
  843. package/src/rules/arazzo/workflowId-unique.ts +0 -21
  844. package/src/rules/async2/__tests__/channels-kebab-case.test.ts +0 -145
  845. package/src/rules/async2/__tests__/no-channel-trailing-slash.test.ts +0 -97
  846. package/src/rules/async2/channels-kebab-case.ts +0 -18
  847. package/src/rules/async2/index.ts +0 -29
  848. package/src/rules/async2/no-channel-trailing-slash.ts +0 -15
  849. package/src/rules/async3/__tests__/channels-kebab-case.test.ts +0 -145
  850. package/src/rules/async3/__tests__/no-channel-trailing-slash.test.ts +0 -96
  851. package/src/rules/async3/channels-kebab-case.ts +0 -19
  852. package/src/rules/async3/index.ts +0 -29
  853. package/src/rules/async3/no-channel-trailing-slash.ts +0 -16
  854. package/src/rules/common/__tests__/info-license-strict.test.ts +0 -141
  855. package/src/rules/common/__tests__/info-license.test.ts +0 -62
  856. package/src/rules/common/__tests__/license-url.test.ts +0 -63
  857. package/src/rules/common/__tests__/no-ambiguous-paths.test.ts +0 -96
  858. package/src/rules/common/__tests__/no-enum-type-mismatch.test.ts +0 -210
  859. package/src/rules/common/__tests__/no-identical-paths.test.ts +0 -58
  860. package/src/rules/common/__tests__/no-invalid-parameter-examples.test.ts +0 -53
  861. package/src/rules/common/__tests__/no-invalid-schema-examples.test.ts +0 -86
  862. package/src/rules/common/__tests__/no-path-trailing-slash.test.ts +0 -126
  863. package/src/rules/common/__tests__/no-required-schema-properties-undefined.test.ts +0 -550
  864. package/src/rules/common/__tests__/no-schema-type-mismatch.test.ts +0 -126
  865. package/src/rules/common/__tests__/operation-2xx-response.test.ts +0 -194
  866. package/src/rules/common/__tests__/operation-4xx-response.test.ts +0 -233
  867. package/src/rules/common/__tests__/operation-operationId-unique.test.ts +0 -76
  868. package/src/rules/common/__tests__/operation-operationId-url-safe.test.ts +0 -45
  869. package/src/rules/common/__tests__/operation-parameters-unique.test.ts +0 -167
  870. package/src/rules/common/__tests__/operation-singular-tag.test.ts +0 -72
  871. package/src/rules/common/__tests__/operation-tag-defined.test.ts +0 -68
  872. package/src/rules/common/__tests__/path-http-verbs-order.test.ts +0 -95
  873. package/src/rules/common/__tests__/path-not-include-query.test.ts +0 -64
  874. package/src/rules/common/__tests__/path-params-defined.test.ts +0 -202
  875. package/src/rules/common/__tests__/paths-kebab-case.test.ts +0 -110
  876. package/src/rules/common/__tests__/scalar-property-missing-example.test.ts +0 -264
  877. package/src/rules/common/__tests__/security-defined.test.ts +0 -284
  878. package/src/rules/common/__tests__/spec-strict-refs.test.ts +0 -69
  879. package/src/rules/common/__tests__/struct.test.ts +0 -657
  880. package/src/rules/common/__tests__/tag-description.test.ts +0 -65
  881. package/src/rules/common/__tests__/tags-alphabetical.test.ts +0 -124
  882. package/src/rules/common/assertions/__tests__/asserts.test.ts +0 -877
  883. package/src/rules/common/assertions/__tests__/index.test.ts +0 -100
  884. package/src/rules/common/assertions/__tests__/utils.test.ts +0 -236
  885. package/src/rules/common/assertions/asserts.ts +0 -365
  886. package/src/rules/common/assertions/index.ts +0 -68
  887. package/src/rules/common/assertions/utils.ts +0 -333
  888. package/src/rules/common/info-contact.ts +0 -16
  889. package/src/rules/common/info-license-strict.ts +0 -24
  890. package/src/rules/common/info-license-url.ts +0 -11
  891. package/src/rules/common/info-license.ts +0 -16
  892. package/src/rules/common/no-ambiguous-paths.ts +0 -50
  893. package/src/rules/common/no-enum-type-mismatch.ts +0 -53
  894. package/src/rules/common/no-http-verbs-in-paths.ts +0 -37
  895. package/src/rules/common/no-identical-paths.ts +0 -24
  896. package/src/rules/common/no-invalid-parameter-examples.ts +0 -37
  897. package/src/rules/common/no-invalid-schema-examples.ts +0 -40
  898. package/src/rules/common/no-path-trailing-slash.ts +0 -15
  899. package/src/rules/common/no-required-schema-properties-undefined.ts +0 -54
  900. package/src/rules/common/no-schema-type-mismatch.ts +0 -24
  901. package/src/rules/common/operation-2xx-response.ts +0 -25
  902. package/src/rules/common/operation-4xx-response.ts +0 -25
  903. package/src/rules/common/operation-description.ts +0 -14
  904. package/src/rules/common/operation-operationId-unique.ts +0 -21
  905. package/src/rules/common/operation-operationId-url-safe.ts +0 -20
  906. package/src/rules/common/operation-operationId.ts +0 -18
  907. package/src/rules/common/operation-parameters-unique.ts +0 -48
  908. package/src/rules/common/operation-singular-tag.ts +0 -17
  909. package/src/rules/common/operation-summary.ts +0 -14
  910. package/src/rules/common/operation-tag-defined.ts +0 -31
  911. package/src/rules/common/parameter-description.ts +0 -22
  912. package/src/rules/common/path-declaration-must-exist.ts +0 -15
  913. package/src/rules/common/path-excludes-patterns.ts +0 -23
  914. package/src/rules/common/path-http-verbs-order.ts +0 -30
  915. package/src/rules/common/path-not-include-query.ts +0 -17
  916. package/src/rules/common/path-params-defined.ts +0 -65
  917. package/src/rules/common/path-segment-plural.ts +0 -33
  918. package/src/rules/common/paths-kebab-case.ts +0 -19
  919. package/src/rules/common/required-string-property-missing-min-length.ts +0 -44
  920. package/src/rules/common/response-contains-header.ts +0 -36
  921. package/src/rules/common/scalar-property-missing-example.ts +0 -59
  922. package/src/rules/common/security-defined.ts +0 -89
  923. package/src/rules/common/spec-strict-refs.ts +0 -31
  924. package/src/rules/common/struct.ts +0 -189
  925. package/src/rules/common/tag-description.ts +0 -11
  926. package/src/rules/common/tags-alphabetical.ts +0 -27
  927. package/src/rules/no-unresolved-refs.ts +0 -52
  928. package/src/rules/oas2/__tests__/boolean-parameter-prefixes.test.ts +0 -112
  929. package/src/rules/oas2/__tests__/response-contains-header.test.ts +0 -180
  930. package/src/rules/oas2/__tests__/response-contains-property.test.ts +0 -161
  931. package/src/rules/oas2/__tests__/spec/fixtures/description.md +0 -1
  932. package/src/rules/oas2/__tests__/spec/info.test.ts +0 -355
  933. package/src/rules/oas2/__tests__/spec/operation.test.ts +0 -123
  934. package/src/rules/oas2/__tests__/spec/paths.test.ts +0 -245
  935. package/src/rules/oas2/__tests__/spec/referenceableScalars.test.ts +0 -37
  936. package/src/rules/oas2/__tests__/spec/utils.ts +0 -32
  937. package/src/rules/oas2/boolean-parameter-prefixes.ts +0 -26
  938. package/src/rules/oas2/index.ts +0 -102
  939. package/src/rules/oas2/request-mime-type.ts +0 -17
  940. package/src/rules/oas2/response-contains-property.ts +0 -37
  941. package/src/rules/oas2/response-mime-type.ts +0 -17
  942. package/src/rules/oas3/__tests__/array-parameter-serialization.test.ts +0 -275
  943. package/src/rules/oas3/__tests__/boolean-parameter-prefixes.test.ts +0 -113
  944. package/src/rules/oas3/__tests__/component-name-unique.test.ts +0 -966
  945. package/src/rules/oas3/__tests__/fixtures/common.yaml +0 -11
  946. package/src/rules/oas3/__tests__/fixtures/external-value.yaml +0 -2
  947. package/src/rules/oas3/__tests__/no-empty-enum-servers.com.test.ts +0 -205
  948. package/src/rules/oas3/__tests__/no-example-value-and-externalValue.test.ts +0 -65
  949. package/src/rules/oas3/__tests__/no-invalid-media-type-examples.test.ts +0 -732
  950. package/src/rules/oas3/__tests__/no-server-example.com.test.ts +0 -95
  951. package/src/rules/oas3/__tests__/no-server-trailing-slash.test.ts +0 -79
  952. package/src/rules/oas3/__tests__/no-unused-components.test.ts +0 -131
  953. package/src/rules/oas3/__tests__/operation-4xx-problem-details-rfc7807.test.ts +0 -145
  954. package/src/rules/oas3/__tests__/response-contains-header.test.ts +0 -401
  955. package/src/rules/oas3/__tests__/response-contains-property.test.ts +0 -417
  956. package/src/rules/oas3/__tests__/spec/callbacks.test.ts +0 -41
  957. package/src/rules/oas3/__tests__/spec/fixtures/description.md +0 -1
  958. package/src/rules/oas3/__tests__/spec/info.test.ts +0 -391
  959. package/src/rules/oas3/__tests__/spec/operation.test.ts +0 -253
  960. package/src/rules/oas3/__tests__/spec/paths.test.ts +0 -284
  961. package/src/rules/oas3/__tests__/spec/referenceableScalars.test.ts +0 -77
  962. package/src/rules/oas3/__tests__/spec/servers.test.ts +0 -505
  963. package/src/rules/oas3/__tests__/spec/spec.test.ts +0 -307
  964. package/src/rules/oas3/__tests__/spec/utils.ts +0 -32
  965. package/src/rules/oas3/__tests__/spec-components-invalid-map-name.test.ts +0 -282
  966. package/src/rules/oas3/__tests__/utils/lint-document-for-test.ts +0 -23
  967. package/src/rules/oas3/array-parameter-serialization.ts +0 -47
  968. package/src/rules/oas3/boolean-parameter-prefixes.ts +0 -28
  969. package/src/rules/oas3/component-name-unique.ts +0 -162
  970. package/src/rules/oas3/index.ts +0 -126
  971. package/src/rules/oas3/no-empty-servers.ts +0 -22
  972. package/src/rules/oas3/no-example-value-and-externalValue.ts +0 -14
  973. package/src/rules/oas3/no-invalid-media-type-examples.ts +0 -54
  974. package/src/rules/oas3/no-server-example.com.ts +0 -16
  975. package/src/rules/oas3/no-server-trailing-slash.ts +0 -15
  976. package/src/rules/oas3/no-server-variables-empty-enum.ts +0 -66
  977. package/src/rules/oas3/no-undefined-server-variable.ts +0 -30
  978. package/src/rules/oas3/no-unused-components.ts +0 -75
  979. package/src/rules/oas3/operation-4xx-problem-details-rfc7807.ts +0 -36
  980. package/src/rules/oas3/request-mime-type.ts +0 -31
  981. package/src/rules/oas3/response-contains-property.ts +0 -39
  982. package/src/rules/oas3/response-mime-type.ts +0 -31
  983. package/src/rules/oas3/spec-components-invalid-map-name.ts +0 -69
  984. package/src/rules/other/stats.ts +0 -75
  985. package/src/rules/overlay1/__tests__/info-contact.test.ts +0 -112
  986. package/src/rules/overlay1/index.ts +0 -14
  987. package/src/rules/respect/no-criteria-xpath.ts +0 -20
  988. package/src/rules/respect/respect-supported-versions.ts +0 -24
  989. package/src/rules/utils.ts +0 -230
  990. package/src/types/arazzo.ts +0 -305
  991. package/src/types/asyncapi2.ts +0 -1121
  992. package/src/types/asyncapi3.ts +0 -383
  993. package/src/types/index.ts +0 -144
  994. package/src/types/json-schema-adapter.ts +0 -217
  995. package/src/types/oas2.ts +0 -481
  996. package/src/types/oas3.ts +0 -594
  997. package/src/types/oas3_1.ts +0 -290
  998. package/src/types/overlay.ts +0 -40
  999. package/src/types/redocly-yaml.ts +0 -1226
  1000. package/src/typings/arazzo.ts +0 -172
  1001. package/src/typings/asyncapi.ts +0 -26
  1002. package/src/typings/asyncapi3.ts +0 -61
  1003. package/src/typings/common.ts +0 -18
  1004. package/src/typings/openapi.ts +0 -347
  1005. package/src/typings/overlay.ts +0 -19
  1006. package/src/typings/swagger.ts +0 -236
  1007. package/src/utils.ts +0 -357
  1008. package/src/visitors.ts +0 -598
  1009. package/src/walk.ts +0 -467
  1010. package/tsconfig.json +0 -8
  1011. package/tsconfig.tsbuildinfo +0 -1
@@ -1,100 +0,0 @@
1
- import { Assertions } from '../.';
2
-
3
- const opts = {
4
- '0': {
5
- subject: {
6
- type: 'Operation',
7
- property: 'summary',
8
- },
9
- description: 'example warn text',
10
- severity: 'warn',
11
- assertions: { pattern: '/example/' },
12
- },
13
- '1': {
14
- subject: {
15
- type: 'PathItem',
16
- },
17
- where: [
18
- {
19
- subject: { type: 'Operation', filterInParentKeys: ['post'], property: 'responses' },
20
- assertions: { defined: true },
21
- },
22
- ],
23
- description: 'example warn text',
24
- severity: 'warn',
25
- assertions: { mutuallyExclusive: ['summary', 'security'] },
26
- },
27
- '2': {
28
- subject: { type: 'PathItem', property: 'tags' },
29
- where: [
30
- { subject: { type: 'Operation', property: 'responses' }, assertions: { defined: true } },
31
- ],
32
- description: 'example warn text',
33
- severity: 'warn',
34
- assertions: { sortOrder: 'desc' },
35
- },
36
- '3': {
37
- subject: { type: 'Foo', property: 'test' },
38
- where: [
39
- { subject: { type: 'Bar' }, assertions: {} },
40
- { subject: { type: 'Baz' }, assertions: {} },
41
- ],
42
- description: 'example warn text',
43
- severity: 'warn',
44
- assertions: { sortOrder: 'desc' },
45
- },
46
- '4': {
47
- subject: {
48
- type: 'any',
49
- property: 'description',
50
- },
51
- description: 'example warn text',
52
- severity: 'warn',
53
- assertions: { notPattern: '/example/' },
54
- },
55
- };
56
-
57
- describe('Oas3 assertions', () => {
58
- it('should return the right visitor structure', () => {
59
- const visitors = Assertions(opts as any);
60
- expect(visitors).toMatchInlineSnapshot(`
61
- [
62
- {
63
- "Operation": {
64
- "enter": [Function],
65
- },
66
- },
67
- {
68
- "Operation": {
69
- "PathItem": {
70
- "enter": [Function],
71
- },
72
- "skip": [Function],
73
- },
74
- },
75
- {
76
- "Operation": {
77
- "PathItem": {
78
- "enter": [Function],
79
- },
80
- "skip": [Function],
81
- },
82
- },
83
- {
84
- "Bar": {
85
- "Baz": {
86
- "Foo": {
87
- "enter": [Function],
88
- },
89
- },
90
- },
91
- },
92
- {
93
- "any": {
94
- "enter": [Function],
95
- },
96
- },
97
- ]
98
- `);
99
- });
100
- });
@@ -1,236 +0,0 @@
1
- import { Assertion, AssertionDefinition } from '..';
2
- import { AssertionContext } from '../../../../config';
3
- import { Location } from '../../../../ref-utils';
4
- import { Source } from '../../../../resolve';
5
- import { isOrdered, buildVisitorObject, getIntersectionLength, runAssertion } from '../utils';
6
-
7
- describe('Oas3 assertions', () => {
8
- describe('Utils', () => {
9
- describe('getCounts', () => {
10
- it('should return the right counts', () => {
11
- const arr = ['foo', 'bar', 'baz'];
12
- expect(getIntersectionLength(arr, ['foo'])).toBe(1);
13
- expect(getIntersectionLength(arr, ['foo', 'bar', 'baz'])).toBe(3);
14
- expect(getIntersectionLength(arr, ['foo', 'test', 'baz'])).toBe(2);
15
- expect(getIntersectionLength(arr, ['example', 'test'])).toBe(0);
16
- });
17
- });
18
-
19
- describe('isOrdered', () => {
20
- it('should say if array is ordered or not in specific direction', () => {
21
- expect(isOrdered(['example', 'foo', 'test'], 'asc')).toBeTruthy();
22
- expect(isOrdered(['example'], 'asc')).toBeTruthy();
23
- expect(isOrdered(['test', 'foo', 'example'], 'desc')).toBeTruthy();
24
- expect(isOrdered(['example'], 'desc')).toBeTruthy();
25
- expect(isOrdered(['example', 'test', 'foo'], 'asc')).toBeFalsy();
26
- expect(isOrdered(['example', 'foo', 'test'], 'desc')).toBeFalsy();
27
- });
28
- });
29
-
30
- describe('buildVisitorObject', () => {
31
- it('should return a consistent visitor structure', () => {
32
- const where: AssertionDefinition[] = [
33
- {
34
- subject: {
35
- type: 'Foo',
36
- filterInParentKeys: ['test'],
37
- },
38
- assertions: {},
39
- },
40
- {
41
- subject: {
42
- type: 'Bar',
43
- filterInParentKeys: ['test'],
44
- },
45
- assertions: {},
46
- },
47
- {
48
- subject: {
49
- type: 'Roof',
50
- filterInParentKeys: ['test'],
51
- },
52
- assertions: {},
53
- },
54
- ] as AssertionDefinition[];
55
-
56
- const visitors = buildVisitorObject(
57
- { subject: { type: 'Bar' }, where, assertions: {} } as Assertion,
58
- () => {}
59
- );
60
-
61
- expect(visitors).toMatchInlineSnapshot(`
62
- {
63
- "Foo": {
64
- "Bar": {
65
- "Roof": {
66
- "Bar": {
67
- "enter": [Function],
68
- },
69
- "skip": [Function],
70
- },
71
- "skip": [Function],
72
- },
73
- "skip": [Function],
74
- },
75
- }
76
- `);
77
- });
78
-
79
- it('should return the right visitor structure', () => {
80
- const where = [
81
- {
82
- subject: {
83
- type: 'Operation',
84
- filterInParentKeys: ['put'],
85
- },
86
- assertions: {},
87
- },
88
- {
89
- subject: {
90
- type: 'Responses',
91
- filterInParentKeys: [201, 200],
92
- },
93
- assertions: {},
94
- },
95
- ];
96
-
97
- const visitors = buildVisitorObject(
98
- { subject: { type: 'MediaTypesMap' }, where, assertions: {} } as Assertion,
99
- () => {}
100
- );
101
-
102
- expect(visitors).toMatchInlineSnapshot(`
103
- {
104
- "Operation": {
105
- "Responses": {
106
- "MediaTypesMap": {
107
- "enter": [Function],
108
- },
109
- "skip": [Function],
110
- },
111
- "skip": [Function],
112
- },
113
- }
114
- `);
115
- });
116
- });
117
-
118
- describe('runAssertion', () => {
119
- const baseLocation = new Location(jest.fn() as any as Source, 'pointer');
120
- const rawLocation = new Location(jest.fn() as any as Source, 'raw-pointer');
121
- // { $ref: 'text' }, true, {...assertionProperties, rawValue: { $ref: 'text' }}
122
-
123
- const ctxStub = {
124
- location: baseLocation,
125
- node: {
126
- property: 'test',
127
- },
128
- rawNode: {
129
- property: 'test',
130
- },
131
- rawLocation: rawLocation,
132
- } as AssertionContext;
133
-
134
- it('should catch error cause property should be not defined with assertionProperty', () => {
135
- const result = runAssertion({
136
- assert: {
137
- name: 'defined',
138
- conditions: false,
139
- runsOnKeys: true,
140
- runsOnValues: false,
141
- },
142
- ctx: ctxStub,
143
- assertionProperty: 'property',
144
- });
145
-
146
- const expectedLocation = new Location(jest.fn() as any as Source, 'pointer/property');
147
-
148
- expect(JSON.stringify(result)).toEqual(
149
- JSON.stringify([
150
- {
151
- message: 'Should be not defined',
152
- location: expectedLocation,
153
- },
154
- ])
155
- );
156
- });
157
-
158
- it('should pass cause property defined', () => {
159
- const result = runAssertion({
160
- assert: {
161
- name: 'defined',
162
- conditions: true,
163
- runsOnKeys: true,
164
- runsOnValues: false,
165
- },
166
- ctx: ctxStub,
167
- assertionProperty: 'property',
168
- });
169
-
170
- expect(result).toEqual([]);
171
- });
172
-
173
- it('should failure cause property does not passed', () => {
174
- const result = runAssertion({
175
- assert: {
176
- name: 'defined',
177
- conditions: false,
178
- runsOnKeys: true,
179
- runsOnValues: false,
180
- },
181
- ctx: ctxStub,
182
- });
183
-
184
- expect(result).toEqual([
185
- {
186
- message: 'Should be not defined',
187
- location: baseLocation,
188
- },
189
- ]);
190
- });
191
-
192
- it('should pass with ref assertion cause it is defined', () => {
193
- const result = runAssertion({
194
- assert: {
195
- name: 'ref',
196
- conditions: true,
197
- runsOnKeys: true,
198
- runsOnValues: false,
199
- },
200
- ctx: {
201
- ...ctxStub,
202
- rawNode: {
203
- $ref: 'test',
204
- },
205
- },
206
- });
207
-
208
- expect(result).toEqual([]);
209
- });
210
-
211
- it('should failure with ref assertion cause it is defined', () => {
212
- const result = runAssertion({
213
- assert: {
214
- name: 'ref',
215
- conditions: false,
216
- runsOnKeys: true,
217
- runsOnValues: false,
218
- },
219
- ctx: {
220
- ...ctxStub,
221
- rawNode: {
222
- $ref: 'test',
223
- },
224
- },
225
- });
226
-
227
- expect(result).toEqual([
228
- {
229
- message: 'should not use $ref',
230
- location: rawLocation,
231
- },
232
- ]);
233
- });
234
- });
235
- });
236
- });
@@ -1,365 +0,0 @@
1
- import { isPlainObject, isString as runOnValue, isTruthy } from '../../../utils';
2
- import { isOrdered, getIntersectionLength, regexFromString } from './utils';
3
-
4
- import type { AssertionContext, AssertResult, CustomFunction } from '../../../config/types';
5
- import type { Location } from '../../../ref-utils';
6
- import type { OrderOptions, OrderDirection } from './utils';
7
-
8
- export type AssertionFnContext = AssertionContext & { baseLocation: Location; rawValue?: any };
9
-
10
- export type AssertionFn = (value: any, condition: any, ctx: AssertionFnContext) => AssertResult[];
11
-
12
- export type Asserts = {
13
- pattern: AssertionFn;
14
- notPattern: AssertionFn;
15
- enum: AssertionFn;
16
- defined: AssertionFn;
17
- required: AssertionFn;
18
- disallowed: AssertionFn;
19
- undefined: AssertionFn;
20
- nonEmpty: AssertionFn;
21
- minLength: AssertionFn;
22
- maxLength: AssertionFn;
23
- casing: AssertionFn;
24
- sortOrder: AssertionFn;
25
- mutuallyExclusive: AssertionFn;
26
- mutuallyRequired: AssertionFn;
27
- requireAny: AssertionFn;
28
- ref: AssertionFn;
29
- const: AssertionFn;
30
- };
31
-
32
- export const runOnKeysSet = new Set<keyof Asserts>([
33
- 'mutuallyExclusive',
34
- 'mutuallyRequired',
35
- 'enum',
36
- 'pattern',
37
- 'notPattern',
38
- 'minLength',
39
- 'maxLength',
40
- 'casing',
41
- 'sortOrder',
42
- 'disallowed',
43
- 'required',
44
- 'requireAny',
45
- 'ref',
46
- 'const',
47
- 'defined', // In case if `property` for assertions is not added
48
- ]);
49
- export const runOnValuesSet = new Set<keyof Asserts>([
50
- 'pattern',
51
- 'notPattern',
52
- 'enum',
53
- 'defined',
54
- 'undefined',
55
- 'nonEmpty',
56
- 'minLength',
57
- 'maxLength',
58
- 'casing',
59
- 'sortOrder',
60
- 'ref',
61
- 'const',
62
- ]);
63
-
64
- export const asserts: Asserts = {
65
- pattern: (
66
- value: string | string[],
67
- condition: string,
68
- { baseLocation, rawValue }: AssertionFnContext
69
- ) => {
70
- if (typeof value === 'undefined' || isPlainObject(value)) return []; // property doesn't exist or is an object, no need to lint it with this assert
71
- const values = Array.isArray(value) ? value : [value];
72
- const regex = regexFromString(condition);
73
-
74
- return values
75
- .map(
76
- (_val) =>
77
- !regex?.test(_val) && {
78
- message: `"${_val}" should match a regex ${condition}`,
79
- location: runOnValue(value)
80
- ? baseLocation
81
- : isPlainObject(rawValue)
82
- ? baseLocation.child(_val).key()
83
- : baseLocation.key(),
84
- }
85
- )
86
- .filter(isTruthy);
87
- },
88
- notPattern: (
89
- value: string | string[],
90
- condition: string,
91
- { baseLocation, rawValue }: AssertionFnContext
92
- ) => {
93
- if (typeof value === 'undefined' || isPlainObject(value)) return []; // property doesn't exist or is an object, no need to lint it with this assert
94
- const values = Array.isArray(value) ? value : [value];
95
- const regex = regexFromString(condition);
96
-
97
- return values
98
- .map(
99
- (_val) =>
100
- regex?.test(_val) && {
101
- message: `"${_val}" should not match a regex ${condition}`,
102
- location: runOnValue(value)
103
- ? baseLocation
104
- : isPlainObject(rawValue)
105
- ? baseLocation.child(_val).key()
106
- : baseLocation.key(),
107
- }
108
- )
109
- .filter(isTruthy);
110
- },
111
- enum: (value: string | string[], condition: string[], { baseLocation }: AssertionFnContext) => {
112
- if (typeof value === 'undefined' || isPlainObject(value)) return []; // property doesn't exist or is an object, no need to lint it with this assert
113
- const values = Array.isArray(value) ? value : [value];
114
- return values
115
- .map(
116
- (_val) =>
117
- !condition.includes(_val) && {
118
- message: `"${_val}" should be one of the predefined values`,
119
- location: runOnValue(value) ? baseLocation : baseLocation.child(_val).key(),
120
- }
121
- )
122
- .filter(isTruthy);
123
- },
124
- defined: (
125
- value: string | undefined,
126
- condition: boolean = true,
127
- { baseLocation }: AssertionFnContext
128
- ) => {
129
- const isDefined = typeof value !== 'undefined';
130
- const isValid = condition ? isDefined : !isDefined;
131
- return isValid
132
- ? []
133
- : [
134
- {
135
- message: condition ? `Should be defined` : 'Should be not defined',
136
- location: baseLocation,
137
- },
138
- ];
139
- },
140
- required: (value: string[], keys: string[], { baseLocation }: AssertionFnContext) => {
141
- return keys
142
- .map(
143
- (requiredKey) =>
144
- !value.includes(requiredKey) && {
145
- message: `${requiredKey} is required`,
146
- location: baseLocation.key(),
147
- }
148
- )
149
- .filter(isTruthy);
150
- },
151
- disallowed: (
152
- value: string | string[],
153
- condition: string[],
154
- { baseLocation }: AssertionFnContext
155
- ) => {
156
- if (typeof value === 'undefined' || isPlainObject(value)) return []; // property doesn't exist or is an object, no need to lint it with this assert
157
- const values = Array.isArray(value) ? value : [value];
158
- return values
159
- .map(
160
- (_val) =>
161
- condition.includes(_val) && {
162
- message: `"${_val}" is disallowed`,
163
- location: runOnValue(value) ? baseLocation : baseLocation.child(_val).key(),
164
- }
165
- )
166
- .filter(isTruthy);
167
- },
168
- const: (
169
- value: string | number | boolean | string[] | number[],
170
- condition: string | number | boolean,
171
- { baseLocation }: AssertionFnContext
172
- ) => {
173
- if (typeof value === 'undefined') return [];
174
-
175
- if (Array.isArray(value)) {
176
- return value
177
- .map(
178
- (_val) =>
179
- condition !== _val && {
180
- message: `"${_val}" should be equal ${condition} `,
181
- location: runOnValue(value) ? baseLocation : baseLocation.child(_val).key(),
182
- }
183
- )
184
- .filter(isTruthy);
185
- } else {
186
- return value !== condition
187
- ? [
188
- {
189
- message: `${value} should be equal ${condition}`,
190
- location: baseLocation,
191
- },
192
- ]
193
- : [];
194
- }
195
- },
196
- undefined: (value: unknown, condition: boolean = true, { baseLocation }: AssertionFnContext) => {
197
- const isUndefined = typeof value === 'undefined';
198
- const isValid = condition ? isUndefined : !isUndefined;
199
- return isValid
200
- ? []
201
- : [
202
- {
203
- message: condition ? `Should not be defined` : 'Should be defined',
204
- location: baseLocation,
205
- },
206
- ];
207
- },
208
- nonEmpty: (
209
- value: string | undefined | null,
210
- condition: boolean = true,
211
- { baseLocation }: AssertionFnContext
212
- ) => {
213
- const isEmpty = typeof value === 'undefined' || value === null || value === '';
214
- const isValid = condition ? !isEmpty : isEmpty;
215
- return isValid
216
- ? []
217
- : [
218
- {
219
- message: condition ? `Should not be empty` : 'Should be empty',
220
- location: baseLocation,
221
- },
222
- ];
223
- },
224
- minLength: (value: string | any[], condition: number, { baseLocation }: AssertionFnContext) => {
225
- if (typeof value === 'undefined' || value.length >= condition) return []; // property doesn't exist, no need to lint it with this assert
226
- return [
227
- {
228
- message: `Should have at least ${condition} characters`,
229
- location: baseLocation,
230
- },
231
- ];
232
- },
233
- maxLength: (value: string | any[], condition: number, { baseLocation }: AssertionFnContext) => {
234
- if (typeof value === 'undefined' || value.length <= condition) return []; // property doesn't exist, no need to lint it with this assert
235
- return [
236
- {
237
- message: `Should have at most ${condition} characters`,
238
- location: baseLocation,
239
- },
240
- ];
241
- },
242
- casing: (value: string | string[], condition: string, { baseLocation }: AssertionFnContext) => {
243
- if (typeof value === 'undefined' || isPlainObject(value)) return []; // property doesn't exist or is an object, no need to lint it with this assert
244
- const values = Array.isArray(value) ? value : [value];
245
- const casingRegexes: Record<string, RegExp> = {
246
- camelCase: /^[a-z][a-zA-Z0-9]*$/g,
247
- 'kebab-case': /^([a-z][a-z0-9]*)(-[a-z0-9]+)*$/g,
248
- snake_case: /^([a-z][a-z0-9]*)(_[a-z0-9]+)*$/g,
249
- PascalCase: /^[A-Z][a-zA-Z0-9]+$/g,
250
- MACRO_CASE: /^([A-Z][A-Z0-9]*)(_[A-Z0-9]+)*$/g,
251
- 'COBOL-CASE': /^([A-Z][A-Z0-9]*)(-[A-Z0-9]+)*$/g,
252
- flatcase: /^[a-z][a-z0-9]+$/g,
253
- };
254
- return values
255
- .map(
256
- (_val) =>
257
- !_val.match(casingRegexes[condition]) && {
258
- message: `"${_val}" should use ${condition}`,
259
- location: runOnValue(value) ? baseLocation : baseLocation.child(_val).key(),
260
- }
261
- )
262
- .filter(isTruthy);
263
- },
264
- sortOrder: (
265
- value: unknown[],
266
- condition: OrderOptions | OrderDirection,
267
- { baseLocation }: AssertionFnContext
268
- ) => {
269
- const direction = (condition as OrderOptions).direction || (condition as OrderDirection);
270
- const property = (condition as OrderOptions).property;
271
- if (Array.isArray(value) && value.length > 0 && typeof value[0] === 'object' && !property) {
272
- return [
273
- {
274
- message: `Please define a property to sort objects by`,
275
- location: baseLocation,
276
- },
277
- ];
278
- }
279
- if (typeof value === 'undefined' || isOrdered(value, condition)) return [];
280
-
281
- return [
282
- {
283
- message: `Should be sorted in ${
284
- direction === 'asc' ? 'an ascending' : 'a descending'
285
- } order${property ? ` by property ${property}` : ''}`,
286
- location: baseLocation,
287
- },
288
- ];
289
- },
290
- mutuallyExclusive: (
291
- value: string[],
292
- condition: string[],
293
- { baseLocation }: AssertionFnContext
294
- ) => {
295
- if (getIntersectionLength(value, condition) < 2) return [];
296
- return [
297
- {
298
- message: `${condition.join(', ')} keys should be mutually exclusive`,
299
- location: baseLocation.key(),
300
- },
301
- ];
302
- },
303
- mutuallyRequired: (
304
- value: string[],
305
- condition: string[],
306
- { baseLocation }: AssertionFnContext
307
- ) => {
308
- const isValid =
309
- getIntersectionLength(value, condition) > 0
310
- ? getIntersectionLength(value, condition) === condition.length
311
- : true;
312
- return isValid
313
- ? []
314
- : [
315
- {
316
- message: `Properties ${condition.join(', ')} are mutually required`,
317
- location: baseLocation.key(),
318
- },
319
- ];
320
- },
321
- requireAny: (value: string[], condition: string[], { baseLocation }: AssertionFnContext) => {
322
- return getIntersectionLength(value, condition) >= 1
323
- ? []
324
- : [
325
- {
326
- message: `Should have any of ${condition.join(', ')}`,
327
- location: baseLocation.key(),
328
- },
329
- ];
330
- },
331
- ref: (
332
- _value: unknown,
333
- condition: string | boolean,
334
- { baseLocation, rawValue }: AssertionFnContext
335
- ) => {
336
- if (typeof rawValue === 'undefined') return []; // property doesn't exist, no need to lint it with this assert
337
- const hasRef = rawValue.hasOwnProperty('$ref');
338
- if (typeof condition === 'boolean') {
339
- const isValid = condition ? hasRef : !hasRef;
340
- return isValid
341
- ? []
342
- : [
343
- {
344
- message: condition ? `should use $ref` : 'should not use $ref',
345
- location: hasRef ? baseLocation : baseLocation.key(),
346
- },
347
- ];
348
- }
349
- const regex = regexFromString(condition);
350
- const isValid = hasRef && regex?.test(rawValue['$ref']);
351
- return isValid
352
- ? []
353
- : [
354
- {
355
- message: `$ref value should match ${condition}`,
356
- location: hasRef ? baseLocation : baseLocation.key(),
357
- },
358
- ];
359
- },
360
- };
361
-
362
- export function buildAssertCustomFunction(fn: CustomFunction): AssertionFn {
363
- return (value: string[], options: any, ctx: AssertionFnContext) =>
364
- fn.call(null, value, options, ctx);
365
- }