@redocly/openapi-core 1.0.0-beta.100

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 (459) hide show
  1. package/README.md +25 -0
  2. package/__tests__/utils.ts +86 -0
  3. package/lib/benchmark/benches/lint-with-many-rules.bench.d.ts +3 -0
  4. package/lib/benchmark/benches/lint-with-many-rules.bench.js +34 -0
  5. package/lib/benchmark/benches/lint-with-nested-rule.bench.d.ts +3 -0
  6. package/lib/benchmark/benches/lint-with-nested-rule.bench.js +40 -0
  7. package/lib/benchmark/benches/lint-with-no-rules.bench.d.ts +3 -0
  8. package/lib/benchmark/benches/lint-with-no-rules.bench.js +21 -0
  9. package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.d.ts +3 -0
  10. package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.js +34 -0
  11. package/lib/benchmark/benches/lint-with-top-level-rule.bench.d.ts +3 -0
  12. package/lib/benchmark/benches/lint-with-top-level-rule.bench.js +32 -0
  13. package/lib/benchmark/benches/recommended-oas3.bench.d.ts +3 -0
  14. package/lib/benchmark/benches/recommended-oas3.bench.js +21 -0
  15. package/lib/benchmark/benches/resolve-with-no-external.bench.d.ts +3 -0
  16. package/lib/benchmark/benches/resolve-with-no-external.bench.js +22 -0
  17. package/lib/benchmark/utils.d.ts +6 -0
  18. package/lib/benchmark/utils.js +31 -0
  19. package/lib/bundle.d.ts +47 -0
  20. package/lib/bundle.js +291 -0
  21. package/lib/config/all.d.ts +3 -0
  22. package/lib/config/all.js +65 -0
  23. package/lib/config/builtIn.d.ts +3 -0
  24. package/lib/config/builtIn.js +36 -0
  25. package/lib/config/config-resolvers.d.ts +16 -0
  26. package/lib/config/config-resolvers.js +242 -0
  27. package/lib/config/config.d.ts +64 -0
  28. package/lib/config/config.js +244 -0
  29. package/lib/config/index.d.ts +7 -0
  30. package/lib/config/index.js +19 -0
  31. package/lib/config/load.d.ts +6 -0
  32. package/lib/config/load.js +93 -0
  33. package/lib/config/minimal.d.ts +3 -0
  34. package/lib/config/minimal.js +58 -0
  35. package/lib/config/recommended.d.ts +3 -0
  36. package/lib/config/recommended.js +58 -0
  37. package/lib/config/rules.d.ts +7 -0
  38. package/lib/config/rules.js +34 -0
  39. package/lib/config/types.d.ts +113 -0
  40. package/lib/config/types.js +2 -0
  41. package/lib/config/utils.d.ts +13 -0
  42. package/lib/config/utils.js +160 -0
  43. package/lib/decorators/common/info-description-override.d.ts +2 -0
  44. package/lib/decorators/common/info-description-override.js +24 -0
  45. package/lib/decorators/common/operation-description-override.d.ts +2 -0
  46. package/lib/decorators/common/operation-description-override.js +29 -0
  47. package/lib/decorators/common/registry-dependencies.d.ts +2 -0
  48. package/lib/decorators/common/registry-dependencies.js +24 -0
  49. package/lib/decorators/common/remove-x-internal.d.ts +2 -0
  50. package/lib/decorators/common/remove-x-internal.js +58 -0
  51. package/lib/decorators/common/tag-description-override.d.ts +2 -0
  52. package/lib/decorators/common/tag-description-override.js +25 -0
  53. package/lib/decorators/oas2/index.d.ts +8 -0
  54. package/lib/decorators/oas2/index.js +15 -0
  55. package/lib/decorators/oas3/index.d.ts +8 -0
  56. package/lib/decorators/oas3/index.js +15 -0
  57. package/lib/format/codeframes.d.ts +22 -0
  58. package/lib/format/codeframes.js +177 -0
  59. package/lib/format/format.d.ts +20 -0
  60. package/lib/format/format.js +236 -0
  61. package/lib/index.d.ts +22 -0
  62. package/lib/index.js +69 -0
  63. package/lib/js-yaml/index.d.ts +3 -0
  64. package/lib/js-yaml/index.js +19 -0
  65. package/lib/lint.d.ts +23 -0
  66. package/lib/lint.js +99 -0
  67. package/lib/oas-types.d.ts +19 -0
  68. package/lib/oas-types.js +45 -0
  69. package/lib/redocly/index.d.ts +30 -0
  70. package/lib/redocly/index.js +153 -0
  71. package/lib/redocly/redocly-client-types.d.ts +8 -0
  72. package/lib/redocly/redocly-client-types.js +2 -0
  73. package/lib/redocly/registry-api-types.d.ts +29 -0
  74. package/lib/redocly/registry-api-types.js +2 -0
  75. package/lib/redocly/registry-api.d.ts +17 -0
  76. package/lib/redocly/registry-api.js +106 -0
  77. package/lib/ref-utils.d.ts +25 -0
  78. package/lib/ref-utils.js +75 -0
  79. package/lib/resolve.d.ts +66 -0
  80. package/lib/resolve.js +311 -0
  81. package/lib/rules/ajv.d.ts +10 -0
  82. package/lib/rules/ajv.js +80 -0
  83. package/lib/rules/common/assertions/asserts.d.ts +5 -0
  84. package/lib/rules/common/assertions/asserts.js +143 -0
  85. package/lib/rules/common/assertions/index.d.ts +2 -0
  86. package/lib/rules/common/assertions/index.js +52 -0
  87. package/lib/rules/common/assertions/utils.d.ts +20 -0
  88. package/lib/rules/common/assertions/utils.js +127 -0
  89. package/lib/rules/common/info-contact.d.ts +2 -0
  90. package/lib/rules/common/info-contact.js +17 -0
  91. package/lib/rules/common/info-description.d.ts +2 -0
  92. package/lib/rules/common/info-description.js +12 -0
  93. package/lib/rules/common/info-license-url.d.ts +2 -0
  94. package/lib/rules/common/info-license-url.js +17 -0
  95. package/lib/rules/common/license-url.d.ts +2 -0
  96. package/lib/rules/common/license-url.js +12 -0
  97. package/lib/rules/common/no-ambiguous-paths.d.ts +2 -0
  98. package/lib/rules/common/no-ambiguous-paths.js +45 -0
  99. package/lib/rules/common/no-enum-type-mismatch.d.ts +2 -0
  100. package/lib/rules/common/no-enum-type-mismatch.js +43 -0
  101. package/lib/rules/common/no-http-verbs-in-paths.d.ts +2 -0
  102. package/lib/rules/common/no-http-verbs-in-paths.js +33 -0
  103. package/lib/rules/common/no-identical-paths.d.ts +2 -0
  104. package/lib/rules/common/no-identical-paths.js +24 -0
  105. package/lib/rules/common/no-invalid-parameter-examples.d.ts +1 -0
  106. package/lib/rules/common/no-invalid-parameter-examples.js +25 -0
  107. package/lib/rules/common/no-invalid-schema-examples.d.ts +1 -0
  108. package/lib/rules/common/no-invalid-schema-examples.js +23 -0
  109. package/lib/rules/common/no-path-trailing-slash.d.ts +2 -0
  110. package/lib/rules/common/no-path-trailing-slash.js +16 -0
  111. package/lib/rules/common/operation-2xx-response.d.ts +2 -0
  112. package/lib/rules/common/operation-2xx-response.js +17 -0
  113. package/lib/rules/common/operation-4xx-response.d.ts +2 -0
  114. package/lib/rules/common/operation-4xx-response.js +17 -0
  115. package/lib/rules/common/operation-description.d.ts +2 -0
  116. package/lib/rules/common/operation-description.js +12 -0
  117. package/lib/rules/common/operation-operationId-unique.d.ts +2 -0
  118. package/lib/rules/common/operation-operationId-unique.js +20 -0
  119. package/lib/rules/common/operation-operationId-url-safe.d.ts +2 -0
  120. package/lib/rules/common/operation-operationId-url-safe.js +17 -0
  121. package/lib/rules/common/operation-operationId.d.ts +2 -0
  122. package/lib/rules/common/operation-operationId.js +16 -0
  123. package/lib/rules/common/operation-parameters-unique.d.ts +2 -0
  124. package/lib/rules/common/operation-parameters-unique.js +40 -0
  125. package/lib/rules/common/operation-security-defined.d.ts +2 -0
  126. package/lib/rules/common/operation-security-defined.js +38 -0
  127. package/lib/rules/common/operation-singular-tag.d.ts +2 -0
  128. package/lib/rules/common/operation-singular-tag.js +16 -0
  129. package/lib/rules/common/operation-summary.d.ts +2 -0
  130. package/lib/rules/common/operation-summary.js +12 -0
  131. package/lib/rules/common/operation-tag-defined.d.ts +2 -0
  132. package/lib/rules/common/operation-tag-defined.js +25 -0
  133. package/lib/rules/common/parameter-description.d.ts +2 -0
  134. package/lib/rules/common/parameter-description.js +22 -0
  135. package/lib/rules/common/path-declaration-must-exist.d.ts +2 -0
  136. package/lib/rules/common/path-declaration-must-exist.js +16 -0
  137. package/lib/rules/common/path-excludes-patterns.d.ts +2 -0
  138. package/lib/rules/common/path-excludes-patterns.js +22 -0
  139. package/lib/rules/common/path-http-verbs-order.d.ts +2 -0
  140. package/lib/rules/common/path-http-verbs-order.js +26 -0
  141. package/lib/rules/common/path-not-include-query.d.ts +2 -0
  142. package/lib/rules/common/path-not-include-query.js +18 -0
  143. package/lib/rules/common/path-params-defined.d.ts +2 -0
  144. package/lib/rules/common/path-params-defined.js +53 -0
  145. package/lib/rules/common/path-segment-plural.d.ts +2 -0
  146. package/lib/rules/common/path-segment-plural.js +32 -0
  147. package/lib/rules/common/paths-kebab-case.d.ts +2 -0
  148. package/lib/rules/common/paths-kebab-case.js +17 -0
  149. package/lib/rules/common/response-contains-header.d.ts +2 -0
  150. package/lib/rules/common/response-contains-header.js +29 -0
  151. package/lib/rules/common/scalar-property-missing-example.d.ts +2 -0
  152. package/lib/rules/common/scalar-property-missing-example.js +42 -0
  153. package/lib/rules/common/spec.d.ts +2 -0
  154. package/lib/rules/common/spec.js +136 -0
  155. package/lib/rules/common/tag-description.d.ts +2 -0
  156. package/lib/rules/common/tag-description.js +12 -0
  157. package/lib/rules/common/tags-alphabetical.d.ts +2 -0
  158. package/lib/rules/common/tags-alphabetical.js +20 -0
  159. package/lib/rules/no-unresolved-refs.d.ts +5 -0
  160. package/lib/rules/no-unresolved-refs.js +47 -0
  161. package/lib/rules/oas2/boolean-parameter-prefixes.d.ts +5 -0
  162. package/lib/rules/oas2/boolean-parameter-prefixes.js +22 -0
  163. package/lib/rules/oas2/index.d.ts +46 -0
  164. package/lib/rules/oas2/index.js +89 -0
  165. package/lib/rules/oas2/remove-unused-components.d.ts +2 -0
  166. package/lib/rules/oas2/remove-unused-components.js +73 -0
  167. package/lib/rules/oas2/request-mime-type.d.ts +2 -0
  168. package/lib/rules/oas2/request-mime-type.js +17 -0
  169. package/lib/rules/oas2/response-contains-property.d.ts +2 -0
  170. package/lib/rules/oas2/response-contains-property.js +38 -0
  171. package/lib/rules/oas2/response-mime-type.d.ts +2 -0
  172. package/lib/rules/oas2/response-mime-type.js +17 -0
  173. package/lib/rules/oas3/boolean-parameter-prefixes.d.ts +5 -0
  174. package/lib/rules/oas3/boolean-parameter-prefixes.js +24 -0
  175. package/lib/rules/oas3/index.d.ts +3 -0
  176. package/lib/rules/oas3/index.js +105 -0
  177. package/lib/rules/oas3/no-empty-servers.d.ts +2 -0
  178. package/lib/rules/oas3/no-empty-servers.js +23 -0
  179. package/lib/rules/oas3/no-example-value-and-externalValue.d.ts +2 -0
  180. package/lib/rules/oas3/no-example-value-and-externalValue.js +16 -0
  181. package/lib/rules/oas3/no-invalid-media-type-examples.d.ts +2 -0
  182. package/lib/rules/oas3/no-invalid-media-type-examples.js +37 -0
  183. package/lib/rules/oas3/no-server-example.com.d.ts +2 -0
  184. package/lib/rules/oas3/no-server-example.com.js +16 -0
  185. package/lib/rules/oas3/no-server-trailing-slash.d.ts +2 -0
  186. package/lib/rules/oas3/no-server-trailing-slash.js +18 -0
  187. package/lib/rules/oas3/no-servers-empty-enum.d.ts +2 -0
  188. package/lib/rules/oas3/no-servers-empty-enum.js +67 -0
  189. package/lib/rules/oas3/no-undefined-server-variable.d.ts +2 -0
  190. package/lib/rules/oas3/no-undefined-server-variable.js +32 -0
  191. package/lib/rules/oas3/no-unused-components.d.ts +2 -0
  192. package/lib/rules/oas3/no-unused-components.js +74 -0
  193. package/lib/rules/oas3/remove-unused-components.d.ts +2 -0
  194. package/lib/rules/oas3/remove-unused-components.js +83 -0
  195. package/lib/rules/oas3/request-mime-type.d.ts +2 -0
  196. package/lib/rules/oas3/request-mime-type.js +31 -0
  197. package/lib/rules/oas3/response-contains-property.d.ts +2 -0
  198. package/lib/rules/oas3/response-contains-property.js +40 -0
  199. package/lib/rules/oas3/response-mime-type.d.ts +2 -0
  200. package/lib/rules/oas3/response-mime-type.js +31 -0
  201. package/lib/rules/other/stats.d.ts +41 -0
  202. package/lib/rules/other/stats.js +44 -0
  203. package/lib/rules/utils.d.ts +17 -0
  204. package/lib/rules/utils.js +107 -0
  205. package/lib/types/index.d.ts +56 -0
  206. package/lib/types/index.js +77 -0
  207. package/lib/types/oas2.d.ts +2 -0
  208. package/lib/types/oas2.js +380 -0
  209. package/lib/types/oas3.d.ts +2 -0
  210. package/lib/types/oas3.js +479 -0
  211. package/lib/types/oas3_1.d.ts +2 -0
  212. package/lib/types/oas3_1.js +247 -0
  213. package/lib/types/redocly-yaml.d.ts +2 -0
  214. package/lib/types/redocly-yaml.js +533 -0
  215. package/lib/typings/common.d.ts +8 -0
  216. package/lib/typings/common.js +2 -0
  217. package/lib/typings/openapi.d.ts +299 -0
  218. package/lib/typings/openapi.js +2 -0
  219. package/lib/typings/swagger.d.ts +217 -0
  220. package/lib/typings/swagger.js +2 -0
  221. package/lib/utils.d.ts +41 -0
  222. package/lib/utils.js +177 -0
  223. package/lib/visitors.d.ts +175 -0
  224. package/lib/visitors.js +140 -0
  225. package/lib/walk.d.ts +87 -0
  226. package/lib/walk.js +253 -0
  227. package/package.json +56 -0
  228. package/src/__tests__/__snapshots__/bundle.test.ts.snap +255 -0
  229. package/src/__tests__/bundle.test.ts +156 -0
  230. package/src/__tests__/codeframes.test.ts +531 -0
  231. package/src/__tests__/fixtures/extension.js +24 -0
  232. package/src/__tests__/fixtures/refs/definitions.yaml +3 -0
  233. package/src/__tests__/fixtures/refs/examples.yaml +8 -0
  234. package/src/__tests__/fixtures/refs/external-request-body.yaml +13 -0
  235. package/src/__tests__/fixtures/refs/externalref.yaml +35 -0
  236. package/src/__tests__/fixtures/refs/hosted.yaml +35 -0
  237. package/src/__tests__/fixtures/refs/openapi-with-external-refs-conflicting-names.yaml +21 -0
  238. package/src/__tests__/fixtures/refs/openapi-with-external-refs.yaml +33 -0
  239. package/src/__tests__/fixtures/refs/openapi-with-url-refs.yaml +18 -0
  240. package/src/__tests__/fixtures/refs/param-b.yaml +1 -0
  241. package/src/__tests__/fixtures/refs/param-c.yaml +1 -0
  242. package/src/__tests__/fixtures/refs/rename.yaml +1 -0
  243. package/src/__tests__/fixtures/refs/requestBody.yaml +9 -0
  244. package/src/__tests__/fixtures/refs/schema-a.yaml +1 -0
  245. package/src/__tests__/fixtures/refs/simple.yaml +1 -0
  246. package/src/__tests__/fixtures/refs/vendor.schema.yaml +20 -0
  247. package/src/__tests__/fixtures/resolve/External.yaml +10 -0
  248. package/src/__tests__/fixtures/resolve/External2.yaml +4 -0
  249. package/src/__tests__/fixtures/resolve/description.md +3 -0
  250. package/src/__tests__/fixtures/resolve/externalInfo.yaml +4 -0
  251. package/src/__tests__/fixtures/resolve/externalLicense.yaml +1 -0
  252. package/src/__tests__/fixtures/resolve/openapi-with-back.yaml +13 -0
  253. package/src/__tests__/fixtures/resolve/openapi-with-md-description.yaml +5 -0
  254. package/src/__tests__/fixtures/resolve/openapi.yaml +28 -0
  255. package/src/__tests__/fixtures/resolve/schemas/type-a.yaml +10 -0
  256. package/src/__tests__/fixtures/resolve/schemas/type-b.yaml +6 -0
  257. package/src/__tests__/fixtures/resolve/transitive/a.yaml +1 -0
  258. package/src/__tests__/fixtures/resolve/transitive/components.yaml +5 -0
  259. package/src/__tests__/fixtures/resolve/transitive/schemas.yaml +3 -0
  260. package/src/__tests__/js-yaml.test.ts +71 -0
  261. package/src/__tests__/lint.test.ts +232 -0
  262. package/src/__tests__/login.test.ts +17 -0
  263. package/src/__tests__/normalizeVisitors.test.ts +151 -0
  264. package/src/__tests__/ref-utils.test.ts +120 -0
  265. package/src/__tests__/resolve-http.test.ts +77 -0
  266. package/src/__tests__/resolve.test.ts +405 -0
  267. package/src/__tests__/utils.test.ts +85 -0
  268. package/src/__tests__/walk.test.ts +1485 -0
  269. package/src/benchmark/benches/lint-with-many-rules.bench.ts +35 -0
  270. package/src/benchmark/benches/lint-with-nested-rule.bench.ts +39 -0
  271. package/src/benchmark/benches/lint-with-no-rules.bench.ts +20 -0
  272. package/src/benchmark/benches/lint-with-top-level-rule-report.bench.ts +36 -0
  273. package/src/benchmark/benches/lint-with-top-level-rule.bench.ts +32 -0
  274. package/src/benchmark/benches/rebilly.yaml +32267 -0
  275. package/src/benchmark/benches/recommended-oas3.bench.ts +22 -0
  276. package/src/benchmark/benches/resolve-with-no-external.bench.ts +23 -0
  277. package/src/benchmark/benchmark.js +307 -0
  278. package/src/benchmark/colors.js +29 -0
  279. package/src/benchmark/fork.js +83 -0
  280. package/src/benchmark/utils.ts +36 -0
  281. package/src/bundle.ts +386 -0
  282. package/src/config/__tests__/__snapshots__/config-resolvers.test.ts.snap +157 -0
  283. package/src/config/__tests__/config-resolvers.test.ts +429 -0
  284. package/src/config/__tests__/config.test.ts +244 -0
  285. package/src/config/__tests__/fixtures/plugin-config.yaml +3 -0
  286. package/src/config/__tests__/fixtures/plugin.js +56 -0
  287. package/src/config/__tests__/fixtures/resolve-config/api/nested-config.yaml +12 -0
  288. package/src/config/__tests__/fixtures/resolve-config/api/plugin.js +67 -0
  289. package/src/config/__tests__/fixtures/resolve-config/local-config-with-circular.yaml +8 -0
  290. package/src/config/__tests__/fixtures/resolve-config/local-config-with-file.yaml +19 -0
  291. package/src/config/__tests__/fixtures/resolve-config/local-config.yaml +10 -0
  292. package/src/config/__tests__/fixtures/resolve-config/plugin.js +66 -0
  293. package/src/config/__tests__/fixtures/resolve-remote-configs/nested-remote-config.yaml +4 -0
  294. package/src/config/__tests__/fixtures/resolve-remote-configs/remote-config.yaml +5 -0
  295. package/src/config/__tests__/load.test.ts +83 -0
  296. package/src/config/__tests__/resolve-plugins.test.ts +27 -0
  297. package/src/config/all.ts +66 -0
  298. package/src/config/builtIn.ts +37 -0
  299. package/src/config/config-resolvers.ts +359 -0
  300. package/src/config/config.ts +312 -0
  301. package/src/config/index.ts +7 -0
  302. package/src/config/load.ts +84 -0
  303. package/src/config/minimal.ts +58 -0
  304. package/src/config/recommended.ts +58 -0
  305. package/src/config/rules.ts +46 -0
  306. package/src/config/types.ts +168 -0
  307. package/src/config/utils.ts +208 -0
  308. package/src/decorators/__tests__/remove-x-internal.test.ts +316 -0
  309. package/src/decorators/common/info-description-override.ts +24 -0
  310. package/src/decorators/common/operation-description-override.ts +30 -0
  311. package/src/decorators/common/registry-dependencies.ts +25 -0
  312. package/src/decorators/common/remove-x-internal.ts +59 -0
  313. package/src/decorators/common/tag-description-override.ts +25 -0
  314. package/src/decorators/oas2/index.ts +14 -0
  315. package/src/decorators/oas3/index.ts +14 -0
  316. package/src/format/codeframes.ts +210 -0
  317. package/src/format/format.ts +339 -0
  318. package/src/index.ts +68 -0
  319. package/src/js-yaml/index.ts +18 -0
  320. package/src/lint.ts +125 -0
  321. package/src/oas-types.ts +62 -0
  322. package/src/redocly/__tests__/redocly-client.test.ts +140 -0
  323. package/src/redocly/index.ts +182 -0
  324. package/src/redocly/redocly-client-types.ts +10 -0
  325. package/src/redocly/registry-api-types.ts +32 -0
  326. package/src/redocly/registry-api.ts +134 -0
  327. package/src/ref-utils.ts +80 -0
  328. package/src/resolve.ts +378 -0
  329. package/src/rules/__tests__/fixtures/invalid-yaml.yaml +1 -0
  330. package/src/rules/__tests__/fixtures/ref.yaml +1 -0
  331. package/src/rules/__tests__/no-unresolved-refs.test.ts +168 -0
  332. package/src/rules/ajv.ts +103 -0
  333. package/src/rules/common/__tests__/info-description.test.ts +102 -0
  334. package/src/rules/common/__tests__/info-license.test.ts +62 -0
  335. package/src/rules/common/__tests__/license-url.test.ts +63 -0
  336. package/src/rules/common/__tests__/no-ambiguous-paths.test.ts +96 -0
  337. package/src/rules/common/__tests__/no-enum-type-mismatch.test.ts +209 -0
  338. package/src/rules/common/__tests__/no-identical-paths.test.ts +58 -0
  339. package/src/rules/common/__tests__/no-path-trailing-slash.test.ts +85 -0
  340. package/src/rules/common/__tests__/operation-2xx-response.test.ts +91 -0
  341. package/src/rules/common/__tests__/operation-4xx-response.test.ts +107 -0
  342. package/src/rules/common/__tests__/operation-operationId-unique.test.ts +76 -0
  343. package/src/rules/common/__tests__/operation-operationId-url-safe.test.ts +45 -0
  344. package/src/rules/common/__tests__/operation-parameters-unique.test.ts +167 -0
  345. package/src/rules/common/__tests__/operation-security-defined.test.ts +69 -0
  346. package/src/rules/common/__tests__/operation-singular-tag.test.ts +72 -0
  347. package/src/rules/common/__tests__/path-http-verbs-order.test.ts +95 -0
  348. package/src/rules/common/__tests__/path-not-include-query.test.ts +64 -0
  349. package/src/rules/common/__tests__/path-params-defined.test.ts +133 -0
  350. package/src/rules/common/__tests__/paths-kebab-case.test.ts +108 -0
  351. package/src/rules/common/__tests__/scalar-property-missing-example.test.ts +264 -0
  352. package/src/rules/common/__tests__/spec.test.ts +62 -0
  353. package/src/rules/common/__tests__/tag-description.test.ts +65 -0
  354. package/src/rules/common/__tests__/tags-alphabetical.test.ts +64 -0
  355. package/src/rules/common/assertions/__tests__/asserts.test.ts +231 -0
  356. package/src/rules/common/assertions/__tests__/index.test.ts +65 -0
  357. package/src/rules/common/assertions/__tests__/utils.test.ts +89 -0
  358. package/src/rules/common/assertions/asserts.ts +137 -0
  359. package/src/rules/common/assertions/index.ts +75 -0
  360. package/src/rules/common/assertions/utils.ts +167 -0
  361. package/src/rules/common/info-contact.ts +15 -0
  362. package/src/rules/common/info-description.ts +10 -0
  363. package/src/rules/common/info-license-url.ts +15 -0
  364. package/src/rules/common/license-url.ts +10 -0
  365. package/src/rules/common/no-ambiguous-paths.ts +50 -0
  366. package/src/rules/common/no-enum-type-mismatch.ts +49 -0
  367. package/src/rules/common/no-http-verbs-in-paths.ts +36 -0
  368. package/src/rules/common/no-identical-paths.ts +24 -0
  369. package/src/rules/common/no-invalid-parameter-examples.ts +36 -0
  370. package/src/rules/common/no-invalid-schema-examples.ts +27 -0
  371. package/src/rules/common/no-path-trailing-slash.ts +15 -0
  372. package/src/rules/common/operation-2xx-response.ts +16 -0
  373. package/src/rules/common/operation-4xx-response.ts +17 -0
  374. package/src/rules/common/operation-description.ts +13 -0
  375. package/src/rules/common/operation-operationId-unique.ts +21 -0
  376. package/src/rules/common/operation-operationId-url-safe.ts +19 -0
  377. package/src/rules/common/operation-operationId.ts +17 -0
  378. package/src/rules/common/operation-parameters-unique.ts +48 -0
  379. package/src/rules/common/operation-security-defined.ts +45 -0
  380. package/src/rules/common/operation-singular-tag.ts +17 -0
  381. package/src/rules/common/operation-summary.ts +13 -0
  382. package/src/rules/common/operation-tag-defined.ts +26 -0
  383. package/src/rules/common/parameter-description.ts +22 -0
  384. package/src/rules/common/path-declaration-must-exist.ts +15 -0
  385. package/src/rules/common/path-excludes-patterns.ts +23 -0
  386. package/src/rules/common/path-http-verbs-order.ts +30 -0
  387. package/src/rules/common/path-not-include-query.ts +17 -0
  388. package/src/rules/common/path-params-defined.ts +58 -0
  389. package/src/rules/common/path-segment-plural.ts +31 -0
  390. package/src/rules/common/paths-kebab-case.ts +16 -0
  391. package/src/rules/common/response-contains-header.ts +30 -0
  392. package/src/rules/common/scalar-property-missing-example.ts +58 -0
  393. package/src/rules/common/spec.ts +143 -0
  394. package/src/rules/common/tag-description.ts +10 -0
  395. package/src/rules/common/tags-alphabetical.ts +20 -0
  396. package/src/rules/no-unresolved-refs.ts +51 -0
  397. package/src/rules/oas2/__tests__/boolean-parameter-prefixes.test.ts +110 -0
  398. package/src/rules/oas2/__tests__/response-contains-header.test.ts +174 -0
  399. package/src/rules/oas2/__tests__/response-contains-property.test.ts +155 -0
  400. package/src/rules/oas2/__tests__/spec/fixtures/description.md +1 -0
  401. package/src/rules/oas2/__tests__/spec/info.test.ts +355 -0
  402. package/src/rules/oas2/__tests__/spec/operation.test.ts +123 -0
  403. package/src/rules/oas2/__tests__/spec/paths.test.ts +245 -0
  404. package/src/rules/oas2/__tests__/spec/referenceableScalars.test.ts +31 -0
  405. package/src/rules/oas2/__tests__/spec/utils.ts +32 -0
  406. package/src/rules/oas2/boolean-parameter-prefixes.ts +26 -0
  407. package/src/rules/oas2/index.ts +89 -0
  408. package/src/rules/oas2/remove-unused-components.ts +76 -0
  409. package/src/rules/oas2/request-mime-type.ts +17 -0
  410. package/src/rules/oas2/response-contains-property.ts +36 -0
  411. package/src/rules/oas2/response-mime-type.ts +17 -0
  412. package/src/rules/oas3/__tests__/boolean-parameter-prefixes.test.ts +111 -0
  413. package/src/rules/oas3/__tests__/fixtures/common.yaml +11 -0
  414. package/src/rules/oas3/__tests__/no-empty-enum-servers.com.test.ts +205 -0
  415. package/src/rules/oas3/__tests__/no-example-value-and-externalValue.test.ts +65 -0
  416. package/src/rules/oas3/__tests__/no-invalid-media-type-examples.test.ts +392 -0
  417. package/src/rules/oas3/__tests__/no-server-example.com.test.ts +60 -0
  418. package/src/rules/oas3/__tests__/no-server-trailing-slash.test.ts +79 -0
  419. package/src/rules/oas3/__tests__/no-unused-components.test.ts +131 -0
  420. package/src/rules/oas3/__tests__/response-contains-header.test.ts +273 -0
  421. package/src/rules/oas3/__tests__/response-contains-property.test.ts +403 -0
  422. package/src/rules/oas3/__tests__/spec/callbacks.test.ts +41 -0
  423. package/src/rules/oas3/__tests__/spec/fixtures/description.md +1 -0
  424. package/src/rules/oas3/__tests__/spec/info.test.ts +391 -0
  425. package/src/rules/oas3/__tests__/spec/operation.test.ts +253 -0
  426. package/src/rules/oas3/__tests__/spec/paths.test.ts +284 -0
  427. package/src/rules/oas3/__tests__/spec/referenceableScalars.test.ts +77 -0
  428. package/src/rules/oas3/__tests__/spec/servers.test.ts +499 -0
  429. package/src/rules/oas3/__tests__/spec/spec.test.ts +288 -0
  430. package/src/rules/oas3/__tests__/spec/utils.ts +32 -0
  431. package/src/rules/oas3/boolean-parameter-prefixes.ts +28 -0
  432. package/src/rules/oas3/index.ts +105 -0
  433. package/src/rules/oas3/no-empty-servers.ts +22 -0
  434. package/src/rules/oas3/no-example-value-and-externalValue.ts +14 -0
  435. package/src/rules/oas3/no-invalid-media-type-examples.ts +41 -0
  436. package/src/rules/oas3/no-server-example.com.ts +14 -0
  437. package/src/rules/oas3/no-server-trailing-slash.ts +15 -0
  438. package/src/rules/oas3/no-servers-empty-enum.ts +67 -0
  439. package/src/rules/oas3/no-undefined-server-variable.ts +30 -0
  440. package/src/rules/oas3/no-unused-components.ts +75 -0
  441. package/src/rules/oas3/remove-unused-components.ts +84 -0
  442. package/src/rules/oas3/request-mime-type.ts +31 -0
  443. package/src/rules/oas3/response-contains-property.ts +38 -0
  444. package/src/rules/oas3/response-mime-type.ts +31 -0
  445. package/src/rules/other/stats.ts +44 -0
  446. package/src/rules/utils.ts +123 -0
  447. package/src/types/index.ts +138 -0
  448. package/src/types/oas2.ts +397 -0
  449. package/src/types/oas3.ts +510 -0
  450. package/src/types/oas3_1.ts +253 -0
  451. package/src/types/redocly-yaml.ts +647 -0
  452. package/src/typings/common.ts +9 -0
  453. package/src/typings/openapi.ts +298 -0
  454. package/src/typings/swagger.ts +236 -0
  455. package/src/utils.ts +193 -0
  456. package/src/visitors.ts +448 -0
  457. package/src/walk.ts +416 -0
  458. package/tsconfig.json +8 -0
  459. package/tsconfig.tsbuildinfo +1 -0
package/lib/utils.js ADDED
@@ -0,0 +1,177 @@
1
+ "use strict";
2
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
+ return new (P || (P = Promise))(function (resolve, reject) {
5
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
9
+ });
10
+ };
11
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.getMatchingStatusCodeRange = exports.assignExisting = exports.isNotString = exports.isString = exports.isNotEmptyObject = exports.slash = exports.isPathParameter = exports.readFileAsStringSync = exports.isSingular = exports.validateMimeTypeOAS3 = exports.validateMimeType = exports.splitCamelCaseIntoWords = exports.omitObjectProps = exports.pickObjectProps = exports.readFileFromUrl = exports.isEmptyArray = exports.isEmptyObject = exports.isPlainObject = exports.notUndefined = exports.loadYaml = exports.popStack = exports.pushStack = exports.stringifyYaml = exports.parseYaml = void 0;
13
+ const fs = require("fs");
14
+ const minimatch = require("minimatch");
15
+ const node_fetch_1 = require("node-fetch");
16
+ const pluralize = require("pluralize");
17
+ const js_yaml_1 = require("./js-yaml");
18
+ const config_1 = require("./config");
19
+ var js_yaml_2 = require("./js-yaml");
20
+ Object.defineProperty(exports, "parseYaml", { enumerable: true, get: function () { return js_yaml_2.parseYaml; } });
21
+ Object.defineProperty(exports, "stringifyYaml", { enumerable: true, get: function () { return js_yaml_2.stringifyYaml; } });
22
+ function pushStack(head, value) {
23
+ return { prev: head, value };
24
+ }
25
+ exports.pushStack = pushStack;
26
+ function popStack(head) {
27
+ var _a;
28
+ return (_a = head === null || head === void 0 ? void 0 : head.prev) !== null && _a !== void 0 ? _a : null;
29
+ }
30
+ exports.popStack = popStack;
31
+ function loadYaml(filename) {
32
+ return __awaiter(this, void 0, void 0, function* () {
33
+ const contents = yield fs.promises.readFile(filename, 'utf-8');
34
+ return js_yaml_1.parseYaml(contents);
35
+ });
36
+ }
37
+ exports.loadYaml = loadYaml;
38
+ function notUndefined(x) {
39
+ return x !== undefined;
40
+ }
41
+ exports.notUndefined = notUndefined;
42
+ function isPlainObject(value) {
43
+ return value !== null && typeof value === 'object' && !Array.isArray(value);
44
+ }
45
+ exports.isPlainObject = isPlainObject;
46
+ function isEmptyObject(value) {
47
+ return isPlainObject(value) && Object.keys(value).length === 0;
48
+ }
49
+ exports.isEmptyObject = isEmptyObject;
50
+ function isEmptyArray(value) {
51
+ return Array.isArray(value) && value.length === 0;
52
+ }
53
+ exports.isEmptyArray = isEmptyArray;
54
+ function readFileFromUrl(url, config) {
55
+ return __awaiter(this, void 0, void 0, function* () {
56
+ const headers = {};
57
+ for (const header of config.headers) {
58
+ if (match(url, header.matches)) {
59
+ headers[header.name] =
60
+ header.envVariable !== undefined ? config_1.env[header.envVariable] || '' : header.value;
61
+ }
62
+ }
63
+ const req = yield (config.customFetch || node_fetch_1.default)(url, {
64
+ headers: headers,
65
+ });
66
+ if (!req.ok) {
67
+ throw new Error(`Failed to load ${url}: ${req.status} ${req.statusText}`);
68
+ }
69
+ return { body: yield req.text(), mimeType: req.headers.get('content-type') };
70
+ });
71
+ }
72
+ exports.readFileFromUrl = readFileFromUrl;
73
+ function match(url, pattern) {
74
+ if (!pattern.match(/^https?:\/\//)) {
75
+ // if pattern doesn't specify protocol directly, do not match against it
76
+ url = url.replace(/^https?:\/\//, '');
77
+ }
78
+ return minimatch(url, pattern);
79
+ }
80
+ function pickObjectProps(object, keys) {
81
+ return Object.fromEntries(keys.filter((key) => key in object).map((key) => [key, object[key]]));
82
+ }
83
+ exports.pickObjectProps = pickObjectProps;
84
+ function omitObjectProps(object, keys) {
85
+ return Object.fromEntries(Object.entries(object).filter(([key]) => !keys.includes(key)));
86
+ }
87
+ exports.omitObjectProps = omitObjectProps;
88
+ function splitCamelCaseIntoWords(str) {
89
+ const camel = str
90
+ .split(/(?:[-._])|([A-Z][a-z]+)/)
91
+ .filter(Boolean)
92
+ .map((item) => item.toLocaleLowerCase());
93
+ const caps = str
94
+ .split(/([A-Z]{2,})/)
95
+ .filter((e) => e && e === e.toUpperCase())
96
+ .map((item) => item.toLocaleLowerCase());
97
+ return new Set([...camel, ...caps]);
98
+ }
99
+ exports.splitCamelCaseIntoWords = splitCamelCaseIntoWords;
100
+ function validateMimeType({ type, value }, { report, location }, allowedValues) {
101
+ const ruleType = type === 'consumes' ? 'request' : 'response';
102
+ if (!allowedValues)
103
+ throw new Error(`Parameter "allowedValues" is not provided for "${ruleType}-mime-type" rule`);
104
+ if (!value[type])
105
+ return;
106
+ for (const mime of value[type]) {
107
+ if (!allowedValues.includes(mime)) {
108
+ report({
109
+ message: `Mime type "${mime}" is not allowed`,
110
+ location: location.child(value[type].indexOf(mime)).key(),
111
+ });
112
+ }
113
+ }
114
+ }
115
+ exports.validateMimeType = validateMimeType;
116
+ function validateMimeTypeOAS3({ type, value }, { report, location }, allowedValues) {
117
+ const ruleType = type === 'consumes' ? 'request' : 'response';
118
+ if (!allowedValues)
119
+ throw new Error(`Parameter "allowedValues" is not provided for "${ruleType}-mime-type" rule`);
120
+ if (!value.content)
121
+ return;
122
+ for (const mime of Object.keys(value.content)) {
123
+ if (!allowedValues.includes(mime)) {
124
+ report({
125
+ message: `Mime type "${mime}" is not allowed`,
126
+ location: location.child('content').child(mime).key(),
127
+ });
128
+ }
129
+ }
130
+ }
131
+ exports.validateMimeTypeOAS3 = validateMimeTypeOAS3;
132
+ function isSingular(path) {
133
+ return pluralize.isSingular(path);
134
+ }
135
+ exports.isSingular = isSingular;
136
+ function readFileAsStringSync(filePath) {
137
+ return fs.readFileSync(filePath, 'utf-8');
138
+ }
139
+ exports.readFileAsStringSync = readFileAsStringSync;
140
+ function isPathParameter(pathSegment) {
141
+ return pathSegment.startsWith('{') && pathSegment.endsWith('}');
142
+ }
143
+ exports.isPathParameter = isPathParameter;
144
+ /**
145
+ * Convert Windows backslash paths to slash paths: foo\\bar ➔ foo/bar
146
+ */
147
+ function slash(path) {
148
+ const isExtendedLengthPath = /^\\\\\?\\/.test(path);
149
+ if (isExtendedLengthPath) {
150
+ return path;
151
+ }
152
+ return path.replace(/\\/g, '/');
153
+ }
154
+ exports.slash = slash;
155
+ function isNotEmptyObject(obj) {
156
+ return !!obj && Object.keys(obj).length > 0;
157
+ }
158
+ exports.isNotEmptyObject = isNotEmptyObject;
159
+ // TODO: use it everywhere
160
+ function isString(value) {
161
+ return typeof value === 'string';
162
+ }
163
+ exports.isString = isString;
164
+ function isNotString(value) {
165
+ return !isString(value);
166
+ }
167
+ exports.isNotString = isNotString;
168
+ function assignExisting(target, obj) {
169
+ for (let k of Object.keys(obj)) {
170
+ if (target.hasOwnProperty(k)) {
171
+ target[k] = obj[k];
172
+ }
173
+ }
174
+ }
175
+ exports.assignExisting = assignExisting;
176
+ const getMatchingStatusCodeRange = (code) => `${code}`.replace(/^(\d)\d\d$/, (_, firstDigit) => `${firstDigit}XX`);
177
+ exports.getMatchingStatusCodeRange = getMatchingStatusCodeRange;
@@ -0,0 +1,175 @@
1
+ import type { Oas3Definition, Oas3ExternalDocs, Oas3Info, Oas3Contact, Oas3Components, Oas3License, Oas3Schema, Oas3Header, Oas3Parameter, Oas3Operation, Oas3PathItem, Oas3ServerVariable, Oas3Server, Oas3MediaType, Oas3Response, Oas3Example, Oas3RequestBody, Oas3Tag, OasRef, Oas3SecurityScheme, Oas3SecurityRequirement, Oas3Encoding, Oas3Link, Oas3Xml, Oas3Discriminator, Oas3Callback } from './typings/openapi';
2
+ import { Oas2Definition, Oas2Tag, Oas2ExternalDocs, Oas2SecurityRequirement, Oas2Info, Oas2Contact, Oas2License, Oas2PathItem, Oas2Operation, Oas2Header, Oas2Response, Oas2Schema, Oas2Xml, Oas2Parameter, Oas2SecurityScheme } from './typings/swagger';
3
+ import { NormalizedNodeType } from './types';
4
+ import { Stack } from './utils';
5
+ import { UserContext, ResolveResult, ProblemSeverity } from './walk';
6
+ import { Location } from './ref-utils';
7
+ export declare type VisitFunction<T> = (node: T, ctx: UserContext & {
8
+ ignoreNextVisitorsOnNode: () => void;
9
+ }, parents?: any, context?: any) => void;
10
+ declare type VisitRefFunction = (node: OasRef, ctx: UserContext, resolved: ResolveResult<any>) => void;
11
+ declare type SkipFunction<T> = (node: T, key: string | number) => boolean;
12
+ declare type VisitObject<T> = {
13
+ enter?: VisitFunction<T>;
14
+ leave?: VisitFunction<T>;
15
+ skip?: SkipFunction<T>;
16
+ };
17
+ declare type NestedVisitObject<T, P> = VisitObject<T> & NestedVisitor<P>;
18
+ declare type VisitFunctionOrObject<T> = VisitFunction<T> | VisitObject<T>;
19
+ declare type VisitorNode<T extends any> = {
20
+ ruleId: string;
21
+ severity: ProblemSeverity;
22
+ context: VisitorLevelContext | VisitorSkippedLevelContext;
23
+ depth: number;
24
+ visit: VisitFunction<T>;
25
+ skip?: SkipFunction<T>;
26
+ };
27
+ declare type VisitorRefNode = {
28
+ ruleId: string;
29
+ severity: ProblemSeverity;
30
+ context: VisitorLevelContext;
31
+ depth: number;
32
+ visit: VisitRefFunction;
33
+ };
34
+ export declare type VisitorLevelContext = {
35
+ isSkippedLevel: false;
36
+ type: NormalizedNodeType;
37
+ parent: VisitorLevelContext | null;
38
+ activatedOn: Stack<{
39
+ node?: any;
40
+ withParentNode?: any;
41
+ skipped: boolean;
42
+ nextLevelTypeActivated: Stack<NormalizedNodeType>;
43
+ location?: Location;
44
+ }>;
45
+ };
46
+ export declare type VisitorSkippedLevelContext = {
47
+ isSkippedLevel: true;
48
+ parent: VisitorLevelContext;
49
+ seen: Set<any>;
50
+ };
51
+ declare type NormalizeVisitor<Fn> = Fn extends VisitFunction<infer T> ? VisitorNode<T> : never;
52
+ export declare type BaseVisitor = {
53
+ any?: {
54
+ enter?: VisitFunction<any>;
55
+ leave?: VisitFunction<any>;
56
+ skip?: SkipFunction<any>;
57
+ } | VisitFunction<any>;
58
+ ref?: {
59
+ enter?: VisitRefFunction;
60
+ leave?: VisitRefFunction;
61
+ } | VisitRefFunction;
62
+ };
63
+ declare type Oas3FlatVisitor = {
64
+ DefinitionRoot?: VisitFunctionOrObject<Oas3Definition>;
65
+ Tag?: VisitFunctionOrObject<Oas3Tag>;
66
+ ExternalDocs?: VisitFunctionOrObject<Oas3ExternalDocs>;
67
+ Server?: VisitFunctionOrObject<Oas3Server>;
68
+ ServerVariable?: VisitFunctionOrObject<Oas3ServerVariable>;
69
+ SecurityRequirement?: VisitFunctionOrObject<Oas3SecurityRequirement>;
70
+ Info?: VisitFunctionOrObject<Oas3Info>;
71
+ Contact?: VisitFunctionOrObject<Oas3Contact>;
72
+ License?: VisitFunctionOrObject<Oas3License>;
73
+ PathMap?: VisitFunctionOrObject<Record<string, Oas3PathItem>>;
74
+ PathItem?: VisitFunctionOrObject<Oas3PathItem>;
75
+ Callback?: VisitFunctionOrObject<Record<string, Oas3PathItem>>;
76
+ Parameter?: VisitFunctionOrObject<Oas3Parameter>;
77
+ Operation?: VisitFunctionOrObject<Oas3Operation>;
78
+ RequestBody?: VisitFunctionOrObject<Oas3RequestBody>;
79
+ MediaTypeMap?: VisitFunctionOrObject<Record<string, Oas3MediaType>>;
80
+ MediaType?: VisitFunctionOrObject<Oas3MediaType>;
81
+ Example?: VisitFunctionOrObject<Oas3Example>;
82
+ Encoding?: VisitFunctionOrObject<Oas3Encoding>;
83
+ Header?: VisitFunctionOrObject<Oas3Header>;
84
+ ResponsesMap?: VisitFunctionOrObject<Record<string, Oas3Response>>;
85
+ Response?: VisitFunctionOrObject<Oas3Response>;
86
+ Link?: VisitFunctionOrObject<Oas3Link>;
87
+ Schema?: VisitFunctionOrObject<Oas3Schema>;
88
+ Xml?: VisitFunctionOrObject<Oas3Xml>;
89
+ SchemaProperties?: VisitFunctionOrObject<Record<string, Oas3Schema>>;
90
+ DiscriminatorMapping?: VisitFunctionOrObject<Record<string, string>>;
91
+ Discriminator?: VisitFunctionOrObject<Oas3Discriminator>;
92
+ Components?: VisitFunctionOrObject<Oas3Components>;
93
+ NamedSchemas?: VisitFunctionOrObject<Record<string, Oas3Schema>>;
94
+ NamedResponses?: VisitFunctionOrObject<Record<string, Oas3Response>>;
95
+ NamedParameters?: VisitFunctionOrObject<Record<string, Oas3Parameter>>;
96
+ NamedExamples?: VisitFunctionOrObject<Record<string, Oas3Example>>;
97
+ NamedRequestBodies?: VisitFunctionOrObject<Record<string, Oas3RequestBody>>;
98
+ NamedHeaders?: VisitFunctionOrObject<Record<string, Oas3Header>>;
99
+ NamedSecuritySchemes?: VisitFunctionOrObject<Record<string, Oas3SecurityScheme>>;
100
+ NamedLinks?: VisitFunctionOrObject<Record<string, Oas3Link>>;
101
+ NamedCallbacks?: VisitFunctionOrObject<Record<string, Oas3Callback>>;
102
+ ImplicitFlow?: VisitFunctionOrObject<Oas3SecurityScheme['flows']['implicit']>;
103
+ PasswordFlow?: VisitFunctionOrObject<Oas3SecurityScheme['flows']['password']>;
104
+ ClientCredentials?: VisitFunctionOrObject<Oas3SecurityScheme['flows']['clientCredentials']>;
105
+ AuthorizationCode?: VisitFunctionOrObject<Oas3SecurityScheme['flows']['authorizationCode']>;
106
+ SecuritySchemeFlows?: VisitFunctionOrObject<Oas3SecurityScheme['flows']>;
107
+ SecurityScheme?: VisitFunctionOrObject<Oas3SecurityScheme>;
108
+ };
109
+ declare type Oas2FlatVisitor = {
110
+ DefinitionRoot?: VisitFunctionOrObject<Oas2Definition>;
111
+ Tag?: VisitFunctionOrObject<Oas2Tag>;
112
+ ExternalDocs?: VisitFunctionOrObject<Oas2ExternalDocs>;
113
+ SecurityRequirement?: VisitFunctionOrObject<Oas2SecurityRequirement>;
114
+ Info?: VisitFunctionOrObject<Oas2Info>;
115
+ Contact?: VisitFunctionOrObject<Oas2Contact>;
116
+ License?: VisitFunctionOrObject<Oas2License>;
117
+ PathMap?: VisitFunctionOrObject<Record<string, Oas2PathItem>>;
118
+ PathItem?: VisitFunctionOrObject<Oas2PathItem>;
119
+ Parameter?: VisitFunctionOrObject<any>;
120
+ Operation?: VisitFunctionOrObject<Oas2Operation>;
121
+ Examples?: VisitFunctionOrObject<Record<string, any>>;
122
+ Header?: VisitFunctionOrObject<Oas2Header>;
123
+ ResponsesMap?: VisitFunctionOrObject<Record<string, Oas2Response>>;
124
+ Response?: VisitFunctionOrObject<Oas2Response>;
125
+ Schema?: VisitFunctionOrObject<Oas2Schema>;
126
+ Xml?: VisitFunctionOrObject<Oas2Xml>;
127
+ SchemaProperties?: VisitFunctionOrObject<Record<string, Oas2Schema>>;
128
+ NamedSchemas?: VisitFunctionOrObject<Record<string, Oas2Schema>>;
129
+ NamedResponses?: VisitFunctionOrObject<Record<string, Oas2Response>>;
130
+ NamedParameters?: VisitFunctionOrObject<Record<string, Oas2Parameter>>;
131
+ SecurityScheme?: VisitFunctionOrObject<Oas2SecurityScheme>;
132
+ };
133
+ declare type Oas3NestedVisitor = {
134
+ [T in keyof Oas3FlatVisitor]: Oas3FlatVisitor[T] extends Function ? Oas3FlatVisitor[T] : Oas3FlatVisitor[T] & NestedVisitor<Oas3NestedVisitor>;
135
+ };
136
+ declare type Oas2NestedVisitor = {
137
+ [T in keyof Oas2FlatVisitor]: Oas2FlatVisitor[T] extends Function ? Oas2FlatVisitor[T] : Oas2FlatVisitor[T] & NestedVisitor<Oas2NestedVisitor>;
138
+ };
139
+ export declare type Oas3Visitor = BaseVisitor & Oas3NestedVisitor & Record<string, VisitFunction<any> | NestedVisitObject<any, Oas3NestedVisitor>>;
140
+ export declare type Oas2Visitor = BaseVisitor & Oas2NestedVisitor & Record<string, VisitFunction<any> | NestedVisitObject<any, Oas2NestedVisitor>>;
141
+ export declare type Oas3TransformVisitor = BaseVisitor & Oas3FlatVisitor & Record<string, VisitFunction<any> | VisitObject<any>>;
142
+ export declare type Oas2TransformVisitor = BaseVisitor & Oas2FlatVisitor & Record<string, VisitFunction<any> | VisitObject<any>>;
143
+ export declare type NestedVisitor<T> = Exclude<T, 'any' | 'ref' | 'DefinitionRoot'>;
144
+ export declare type NormalizedOasVisitors<T extends BaseVisitor> = {
145
+ [V in keyof T]-?: {
146
+ enter: Array<NormalizeVisitor<T[V]>>;
147
+ leave: Array<NormalizeVisitor<T[V]>>;
148
+ };
149
+ } & {
150
+ ref: {
151
+ enter: Array<VisitorRefNode>;
152
+ leave: Array<VisitorRefNode>;
153
+ };
154
+ [k: string]: {
155
+ enter: Array<VisitorNode<any>>;
156
+ leave: Array<VisitorNode<any>>;
157
+ };
158
+ };
159
+ export declare type Oas3Rule = (options: Record<string, any>) => Oas3Visitor | Oas3Visitor[];
160
+ export declare type Oas2Rule = (options: Record<string, any>) => Oas2Visitor | Oas2Visitor[];
161
+ export declare type Oas3Preprocessor = (options: Record<string, any>) => Oas3TransformVisitor;
162
+ export declare type Oas2Preprocessor = (options: Record<string, any>) => Oas2TransformVisitor;
163
+ export declare type Oas3Decorator = (options: Record<string, any>) => Oas3TransformVisitor;
164
+ export declare type Oas2Decorator = (options: Record<string, any>) => Oas2TransformVisitor;
165
+ export declare type OasRule = Oas3Rule;
166
+ export declare type OasPreprocessor = Oas3Preprocessor;
167
+ export declare type OasDecorator = Oas3Decorator;
168
+ export declare type RuleInstanceConfig = {
169
+ ruleId: string;
170
+ severity: ProblemSeverity;
171
+ };
172
+ export declare function normalizeVisitors<T extends BaseVisitor>(visitorsConfig: (RuleInstanceConfig & {
173
+ visitor: NestedVisitObject<any, T>;
174
+ })[], types: Record<keyof T, NormalizedNodeType>): NormalizedOasVisitors<T>;
175
+ export {};
@@ -0,0 +1,140 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.normalizeVisitors = void 0;
4
+ function normalizeVisitors(visitorsConfig, types) {
5
+ const normalizedVisitors = {};
6
+ normalizedVisitors.any = {
7
+ enter: [],
8
+ leave: [],
9
+ };
10
+ for (const typeName of Object.keys(types)) {
11
+ normalizedVisitors[typeName] = {
12
+ enter: [],
13
+ leave: [],
14
+ };
15
+ }
16
+ normalizedVisitors.ref = {
17
+ enter: [],
18
+ leave: [],
19
+ };
20
+ for (const { ruleId, severity, visitor } of visitorsConfig) {
21
+ normalizeVisitorLevel({ ruleId, severity }, visitor, null);
22
+ }
23
+ for (const v of Object.keys(normalizedVisitors)) {
24
+ normalizedVisitors[v].enter.sort((a, b) => b.depth - a.depth);
25
+ normalizedVisitors[v].leave.sort((a, b) => a.depth - b.depth);
26
+ }
27
+ return normalizedVisitors;
28
+ function addWeakNodes(ruleConf, from, to, parentContext, stack = []) {
29
+ if (stack.includes(from))
30
+ return;
31
+ stack = [...stack, from];
32
+ const possibleChildren = new Set();
33
+ for (let type of Object.values(from.properties)) {
34
+ if (type === to) {
35
+ addWeakFromStack(ruleConf, stack);
36
+ continue;
37
+ }
38
+ if (typeof type === 'object' && type !== null && type.name) {
39
+ possibleChildren.add(type);
40
+ }
41
+ }
42
+ if (from.additionalProperties && typeof from.additionalProperties !== 'function') {
43
+ if (from.additionalProperties === to) {
44
+ addWeakFromStack(ruleConf, stack);
45
+ }
46
+ else if (from.additionalProperties.name !== undefined) {
47
+ possibleChildren.add(from.additionalProperties);
48
+ }
49
+ }
50
+ if (from.items) {
51
+ if (from.items === to) {
52
+ addWeakFromStack(ruleConf, stack);
53
+ }
54
+ else if (from.items.name !== undefined) {
55
+ possibleChildren.add(from.items);
56
+ }
57
+ }
58
+ for (let fromType of Array.from(possibleChildren.values())) {
59
+ addWeakNodes(ruleConf, fromType, to, parentContext, stack);
60
+ }
61
+ function addWeakFromStack(ruleConf, stack) {
62
+ for (const interType of stack.slice(1)) {
63
+ normalizedVisitors[interType.name] =
64
+ normalizedVisitors[interType.name] ||
65
+ {
66
+ enter: [],
67
+ leave: [],
68
+ };
69
+ normalizedVisitors[interType.name].enter.push(Object.assign(Object.assign({}, ruleConf), { visit: () => undefined, depth: 0, context: {
70
+ isSkippedLevel: true,
71
+ seen: new Set(),
72
+ parent: parentContext,
73
+ } }));
74
+ }
75
+ }
76
+ }
77
+ function normalizeVisitorLevel(ruleConf, visitor, parentContext, depth = 0) {
78
+ const visitorKeys = Object.keys(types);
79
+ if (depth === 0) {
80
+ visitorKeys.push('any');
81
+ visitorKeys.push('ref');
82
+ }
83
+ else {
84
+ if (visitor.any) {
85
+ throw new Error('any() is allowed only on top level');
86
+ }
87
+ if (visitor.ref) {
88
+ throw new Error('ref() is allowed only on top level');
89
+ }
90
+ }
91
+ for (const typeName of visitorKeys) {
92
+ const typeVisitor = visitor[typeName];
93
+ const normalizedTypeVisitor = normalizedVisitors[typeName];
94
+ if (!typeVisitor)
95
+ continue;
96
+ let visitorEnter;
97
+ let visitorLeave;
98
+ let visitorSkip;
99
+ const isObjectVisitor = typeof typeVisitor === 'object';
100
+ if (typeName === 'ref' && isObjectVisitor && typeVisitor.skip) {
101
+ throw new Error('ref() visitor does not support skip');
102
+ }
103
+ if (typeof typeVisitor === 'function') {
104
+ visitorEnter = typeVisitor;
105
+ }
106
+ else if (isObjectVisitor) {
107
+ visitorEnter = typeVisitor.enter;
108
+ visitorLeave = typeVisitor.leave;
109
+ visitorSkip = typeVisitor.skip;
110
+ }
111
+ const context = {
112
+ activatedOn: null,
113
+ type: types[typeName],
114
+ parent: parentContext,
115
+ isSkippedLevel: false,
116
+ };
117
+ if (typeof typeVisitor === 'object') {
118
+ normalizeVisitorLevel(ruleConf, typeVisitor, context, depth + 1);
119
+ }
120
+ if (parentContext) {
121
+ addWeakNodes(ruleConf, parentContext.type, types[typeName], parentContext);
122
+ }
123
+ if (visitorEnter || isObjectVisitor) {
124
+ if (visitorEnter && typeof visitorEnter !== 'function') {
125
+ throw new Error('DEV: should be function');
126
+ }
127
+ normalizedTypeVisitor.enter.push(Object.assign(Object.assign({}, ruleConf), { visit: visitorEnter || (() => undefined), skip: visitorSkip, depth,
128
+ context }));
129
+ }
130
+ if (visitorLeave) {
131
+ if (typeof visitorLeave !== 'function') {
132
+ throw new Error('DEV: should be function');
133
+ }
134
+ normalizedTypeVisitor.leave.push(Object.assign(Object.assign({}, ruleConf), { visit: visitorLeave, depth,
135
+ context }));
136
+ }
137
+ }
138
+ }
139
+ }
140
+ exports.normalizeVisitors = normalizeVisitors;
package/lib/walk.d.ts ADDED
@@ -0,0 +1,87 @@
1
+ import { Referenced } from './typings/openapi';
2
+ import { Location } from './ref-utils';
3
+ import { NormalizedOasVisitors } from './visitors';
4
+ import { ResolvedRefMap, Document, ResolveError, YamlParseError, Source } from './resolve';
5
+ import { OasVersion } from './oas-types';
6
+ import { NormalizedNodeType } from './types';
7
+ declare type NonUndefined = string | number | boolean | symbol | bigint | object | Record<string, any>;
8
+ export declare type ResolveResult<T extends NonUndefined> = {
9
+ node: T;
10
+ location: Location;
11
+ error?: ResolveError | YamlParseError;
12
+ } | {
13
+ node: undefined;
14
+ location: undefined;
15
+ error?: ResolveError | YamlParseError;
16
+ };
17
+ export declare type ResolveFn<T> = (node: Referenced<T>, from?: string) => {
18
+ location: Location;
19
+ node: T;
20
+ } | {
21
+ location: undefined;
22
+ node: undefined;
23
+ };
24
+ export declare type UserContext = {
25
+ report(problem: Problem): void;
26
+ location: Location;
27
+ resolve<T>(node: Referenced<T>): {
28
+ location: Location;
29
+ node: T;
30
+ } | {
31
+ location: undefined;
32
+ node: undefined;
33
+ };
34
+ parentLocations: Record<string, Location>;
35
+ type: NormalizedNodeType;
36
+ key: string | number;
37
+ parent: any;
38
+ oasVersion: OasVersion;
39
+ getVisitorData: () => Record<string, unknown>;
40
+ };
41
+ export declare type Loc = {
42
+ line: number;
43
+ col: number;
44
+ };
45
+ export declare type PointerLocationObject = {
46
+ source: Source;
47
+ reportOnKey?: boolean;
48
+ pointer: string;
49
+ };
50
+ export declare type LineColLocationObject = Omit<PointerLocationObject, 'pointer'> & {
51
+ pointer: undefined;
52
+ start: Loc;
53
+ end?: Loc;
54
+ };
55
+ export declare type LocationObject = LineColLocationObject | PointerLocationObject;
56
+ export declare type ProblemSeverity = 'error' | 'warn';
57
+ export declare type Problem = {
58
+ message: string;
59
+ suggest?: string[];
60
+ location?: Partial<LocationObject> | Array<Partial<LocationObject>>;
61
+ from?: LocationObject;
62
+ forceSeverity?: ProblemSeverity;
63
+ ruleId?: string;
64
+ };
65
+ export declare type NormalizedProblem = {
66
+ message: string;
67
+ ruleId: string;
68
+ severity: ProblemSeverity;
69
+ location: LocationObject[];
70
+ from?: LocationObject;
71
+ suggest: string[];
72
+ ignored?: boolean;
73
+ };
74
+ export declare type WalkContext = {
75
+ problems: NormalizedProblem[];
76
+ oasVersion: OasVersion;
77
+ visitorsData: Record<string, Record<string, unknown>>;
78
+ refTypes?: Map<string, NormalizedNodeType>;
79
+ };
80
+ export declare function walkDocument<T>(opts: {
81
+ document: Document;
82
+ rootType: NormalizedNodeType;
83
+ normalizedVisitors: NormalizedOasVisitors<T>;
84
+ resolvedRefMap: ResolvedRefMap;
85
+ ctx: WalkContext;
86
+ }): void;
87
+ export {};