@redocly/openapi-core 1.0.0-beta.126 → 1.0.0-beta.128

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 (289) hide show
  1. package/lib/bundle.js +21 -4
  2. package/lib/config/all.js +1 -0
  3. package/lib/config/config-resolvers.js +8 -2
  4. package/lib/config/minimal.js +1 -0
  5. package/lib/config/recommended.js +1 -0
  6. package/lib/config/types.d.ts +1 -1
  7. package/lib/config/utils.js +15 -1
  8. package/lib/lint.js +17 -2
  9. package/lib/rules/common/spec-strict-refs.d.ts +2 -0
  10. package/lib/rules/common/spec-strict-refs.js +30 -0
  11. package/lib/rules/common/spec.js +1 -0
  12. package/lib/rules/oas2/index.d.ts +1 -0
  13. package/lib/rules/oas2/index.js +2 -0
  14. package/lib/rules/oas2/request-mime-type.d.ts +1 -1
  15. package/lib/rules/oas2/response-mime-type.d.ts +1 -1
  16. package/lib/rules/oas3/index.js +2 -0
  17. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.d.ts +2 -2
  18. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.js +3 -3
  19. package/lib/rules/oas3/request-mime-type.d.ts +1 -1
  20. package/lib/rules/oas3/response-mime-type.d.ts +1 -1
  21. package/lib/rules/oas3/spec-components-invalid-map-name.js +0 -5
  22. package/lib/types/redocly-yaml.js +6 -1
  23. package/lib/walk.d.ts +6 -5
  24. package/lib/walk.js +26 -31
  25. package/package.json +1 -1
  26. package/__tests__/utils.ts +0 -88
  27. package/src/__tests__/__snapshots__/bundle.test.ts.snap +0 -437
  28. package/src/__tests__/bundle.test.ts +0 -236
  29. package/src/__tests__/codeframes.test.ts +0 -530
  30. package/src/__tests__/fixtures/.redocly.lint-ignore.yaml +0 -5
  31. package/src/__tests__/fixtures/extension.js +0 -24
  32. package/src/__tests__/fixtures/refs/definitions.yaml +0 -3
  33. package/src/__tests__/fixtures/refs/examples.yaml +0 -8
  34. package/src/__tests__/fixtures/refs/external-request-body.yaml +0 -13
  35. package/src/__tests__/fixtures/refs/externalref.yaml +0 -35
  36. package/src/__tests__/fixtures/refs/hosted.yaml +0 -35
  37. package/src/__tests__/fixtures/refs/openapi-with-external-refs-conflicting-names.yaml +0 -21
  38. package/src/__tests__/fixtures/refs/openapi-with-external-refs.yaml +0 -33
  39. package/src/__tests__/fixtures/refs/openapi-with-url-refs.yaml +0 -18
  40. package/src/__tests__/fixtures/refs/param-b.yaml +0 -1
  41. package/src/__tests__/fixtures/refs/param-c.yaml +0 -1
  42. package/src/__tests__/fixtures/refs/rename.yaml +0 -1
  43. package/src/__tests__/fixtures/refs/requestBody.yaml +0 -9
  44. package/src/__tests__/fixtures/refs/schema-a.yaml +0 -1
  45. package/src/__tests__/fixtures/refs/simple.yaml +0 -1
  46. package/src/__tests__/fixtures/refs/vendor.schema.yaml +0 -20
  47. package/src/__tests__/fixtures/resolve/External.yaml +0 -10
  48. package/src/__tests__/fixtures/resolve/External2.yaml +0 -4
  49. package/src/__tests__/fixtures/resolve/description.md +0 -3
  50. package/src/__tests__/fixtures/resolve/externalInfo.yaml +0 -4
  51. package/src/__tests__/fixtures/resolve/externalLicense.yaml +0 -1
  52. package/src/__tests__/fixtures/resolve/openapi-with-back.yaml +0 -13
  53. package/src/__tests__/fixtures/resolve/openapi-with-md-description.yaml +0 -5
  54. package/src/__tests__/fixtures/resolve/openapi.yaml +0 -28
  55. package/src/__tests__/fixtures/resolve/schemas/type-a.yaml +0 -10
  56. package/src/__tests__/fixtures/resolve/schemas/type-b.yaml +0 -6
  57. package/src/__tests__/fixtures/resolve/transitive/a.yaml +0 -1
  58. package/src/__tests__/fixtures/resolve/transitive/components.yaml +0 -5
  59. package/src/__tests__/fixtures/resolve/transitive/schemas.yaml +0 -3
  60. package/src/__tests__/format.test.ts +0 -76
  61. package/src/__tests__/js-yaml.test.ts +0 -73
  62. package/src/__tests__/lint.test.ts +0 -388
  63. package/src/__tests__/logger-browser.test.ts +0 -53
  64. package/src/__tests__/logger.test.ts +0 -47
  65. package/src/__tests__/login.test.ts +0 -17
  66. package/src/__tests__/normalizeVisitors.test.ts +0 -151
  67. package/src/__tests__/output-browser.test.ts +0 -18
  68. package/src/__tests__/output.test.ts +0 -15
  69. package/src/__tests__/ref-utils.test.ts +0 -120
  70. package/src/__tests__/resolve-http.test.ts +0 -77
  71. package/src/__tests__/resolve.test.ts +0 -430
  72. package/src/__tests__/utils-browser.test.ts +0 -11
  73. package/src/__tests__/utils.test.ts +0 -144
  74. package/src/__tests__/walk.test.ts +0 -1545
  75. package/src/benchmark/benches/lint-with-many-rules.bench.ts +0 -35
  76. package/src/benchmark/benches/lint-with-nested-rule.bench.ts +0 -39
  77. package/src/benchmark/benches/lint-with-no-rules.bench.ts +0 -20
  78. package/src/benchmark/benches/lint-with-top-level-rule-report.bench.ts +0 -35
  79. package/src/benchmark/benches/lint-with-top-level-rule.bench.ts +0 -32
  80. package/src/benchmark/benches/rebilly.yaml +0 -32275
  81. package/src/benchmark/benches/recommended-oas3.bench.ts +0 -22
  82. package/src/benchmark/benches/resolve-with-no-external.bench.ts +0 -23
  83. package/src/benchmark/benchmark.js +0 -311
  84. package/src/benchmark/colors.js +0 -29
  85. package/src/benchmark/fork.js +0 -83
  86. package/src/benchmark/utils.ts +0 -36
  87. package/src/bundle.ts +0 -399
  88. package/src/config/__tests__/__snapshots__/config-resolvers.test.ts.snap +0 -161
  89. package/src/config/__tests__/__snapshots__/config.test.ts.snap +0 -144
  90. package/src/config/__tests__/config-resolvers.test.ts +0 -491
  91. package/src/config/__tests__/config.test.ts +0 -307
  92. package/src/config/__tests__/fixtures/ingore-file.ts +0 -8
  93. package/src/config/__tests__/fixtures/load-redocly.yaml +0 -2
  94. package/src/config/__tests__/fixtures/plugin-config.yaml +0 -2
  95. package/src/config/__tests__/fixtures/plugin.js +0 -56
  96. package/src/config/__tests__/fixtures/resolve-config/api/nested-config.yaml +0 -11
  97. package/src/config/__tests__/fixtures/resolve-config/api/plugin.js +0 -69
  98. package/src/config/__tests__/fixtures/resolve-config/local-config-with-circular.yaml +0 -7
  99. package/src/config/__tests__/fixtures/resolve-config/local-config-with-custom-function.yaml +0 -17
  100. package/src/config/__tests__/fixtures/resolve-config/local-config-with-file.yaml +0 -18
  101. package/src/config/__tests__/fixtures/resolve-config/local-config-with-wrong-custom-function.yaml +0 -15
  102. package/src/config/__tests__/fixtures/resolve-config/local-config.yaml +0 -9
  103. package/src/config/__tests__/fixtures/resolve-config/plugin.js +0 -80
  104. package/src/config/__tests__/fixtures/resolve-remote-configs/nested-remote-config.yaml +0 -3
  105. package/src/config/__tests__/fixtures/resolve-remote-configs/remote-config.yaml +0 -4
  106. package/src/config/__tests__/load.test.ts +0 -167
  107. package/src/config/__tests__/resolve-plugins.test.ts +0 -27
  108. package/src/config/__tests__/utils.test.ts +0 -204
  109. package/src/config/all.ts +0 -73
  110. package/src/config/builtIn.ts +0 -37
  111. package/src/config/config-resolvers.ts +0 -465
  112. package/src/config/config.ts +0 -330
  113. package/src/config/index.ts +0 -7
  114. package/src/config/load.ts +0 -144
  115. package/src/config/minimal.ts +0 -60
  116. package/src/config/recommended.ts +0 -60
  117. package/src/config/rules.ts +0 -54
  118. package/src/config/types.ts +0 -216
  119. package/src/config/utils.ts +0 -333
  120. package/src/decorators/__tests__/filter-in.test.ts +0 -310
  121. package/src/decorators/__tests__/filter-out.test.ts +0 -335
  122. package/src/decorators/__tests__/media-type-examples-override.test.ts +0 -665
  123. package/src/decorators/__tests__/remove-x-internal.test.ts +0 -316
  124. package/src/decorators/__tests__/resources/request.yaml +0 -3
  125. package/src/decorators/__tests__/resources/response.yaml +0 -3
  126. package/src/decorators/common/filters/filter-helper.ts +0 -72
  127. package/src/decorators/common/filters/filter-in.ts +0 -18
  128. package/src/decorators/common/filters/filter-out.ts +0 -18
  129. package/src/decorators/common/info-description-override.ts +0 -24
  130. package/src/decorators/common/info-override.ts +0 -15
  131. package/src/decorators/common/media-type-examples-override.ts +0 -79
  132. package/src/decorators/common/operation-description-override.ts +0 -30
  133. package/src/decorators/common/registry-dependencies.ts +0 -25
  134. package/src/decorators/common/remove-x-internal.ts +0 -59
  135. package/src/decorators/common/tag-description-override.ts +0 -25
  136. package/src/decorators/oas2/index.ts +0 -20
  137. package/src/decorators/oas3/index.ts +0 -22
  138. package/src/env.ts +0 -5
  139. package/src/format/codeframes.ts +0 -216
  140. package/src/format/format.ts +0 -375
  141. package/src/index.ts +0 -71
  142. package/src/js-yaml/index.ts +0 -14
  143. package/src/lint.ts +0 -130
  144. package/src/logger.ts +0 -34
  145. package/src/oas-types.ts +0 -57
  146. package/src/output.ts +0 -7
  147. package/src/redocly/__tests__/redocly-client.test.ts +0 -146
  148. package/src/redocly/index.ts +0 -187
  149. package/src/redocly/redocly-client-types.ts +0 -10
  150. package/src/redocly/registry-api-types.ts +0 -32
  151. package/src/redocly/registry-api.ts +0 -149
  152. package/src/ref-utils.ts +0 -85
  153. package/src/resolve.ts +0 -417
  154. package/src/rules/__tests__/fixtures/code-sample.php +0 -9
  155. package/src/rules/__tests__/fixtures/invalid-yaml.yaml +0 -1
  156. package/src/rules/__tests__/fixtures/ref.yaml +0 -1
  157. package/src/rules/__tests__/no-unresolved-refs.test.ts +0 -257
  158. package/src/rules/__tests__/utils.test.ts +0 -160
  159. package/src/rules/ajv.ts +0 -102
  160. package/src/rules/common/__tests__/info-license.test.ts +0 -62
  161. package/src/rules/common/__tests__/license-url.test.ts +0 -63
  162. package/src/rules/common/__tests__/no-ambiguous-paths.test.ts +0 -96
  163. package/src/rules/common/__tests__/no-enum-type-mismatch.test.ts +0 -210
  164. package/src/rules/common/__tests__/no-identical-paths.test.ts +0 -58
  165. package/src/rules/common/__tests__/no-path-trailing-slash.test.ts +0 -85
  166. package/src/rules/common/__tests__/operation-2xx-response.test.ts +0 -192
  167. package/src/rules/common/__tests__/operation-4xx-response.test.ts +0 -231
  168. package/src/rules/common/__tests__/operation-operationId-unique.test.ts +0 -76
  169. package/src/rules/common/__tests__/operation-operationId-url-safe.test.ts +0 -45
  170. package/src/rules/common/__tests__/operation-parameters-unique.test.ts +0 -167
  171. package/src/rules/common/__tests__/operation-singular-tag.test.ts +0 -72
  172. package/src/rules/common/__tests__/path-http-verbs-order.test.ts +0 -95
  173. package/src/rules/common/__tests__/path-not-include-query.test.ts +0 -64
  174. package/src/rules/common/__tests__/path-params-defined.test.ts +0 -202
  175. package/src/rules/common/__tests__/paths-kebab-case.test.ts +0 -108
  176. package/src/rules/common/__tests__/scalar-property-missing-example.test.ts +0 -264
  177. package/src/rules/common/__tests__/security-defined.test.ts +0 -175
  178. package/src/rules/common/__tests__/spec.test.ts +0 -555
  179. package/src/rules/common/__tests__/tag-description.test.ts +0 -65
  180. package/src/rules/common/__tests__/tags-alphabetical.test.ts +0 -64
  181. package/src/rules/common/assertions/__tests__/asserts.test.ts +0 -869
  182. package/src/rules/common/assertions/__tests__/index.test.ts +0 -100
  183. package/src/rules/common/assertions/__tests__/utils.test.ts +0 -236
  184. package/src/rules/common/assertions/asserts.ts +0 -357
  185. package/src/rules/common/assertions/index.ts +0 -56
  186. package/src/rules/common/assertions/utils.ts +0 -331
  187. package/src/rules/common/info-contact.ts +0 -15
  188. package/src/rules/common/info-license-url.ts +0 -10
  189. package/src/rules/common/info-license.ts +0 -15
  190. package/src/rules/common/no-ambiguous-paths.ts +0 -50
  191. package/src/rules/common/no-enum-type-mismatch.ts +0 -52
  192. package/src/rules/common/no-http-verbs-in-paths.ts +0 -36
  193. package/src/rules/common/no-identical-paths.ts +0 -24
  194. package/src/rules/common/no-invalid-parameter-examples.ts +0 -36
  195. package/src/rules/common/no-invalid-schema-examples.ts +0 -27
  196. package/src/rules/common/no-path-trailing-slash.ts +0 -15
  197. package/src/rules/common/operation-2xx-response.ts +0 -24
  198. package/src/rules/common/operation-4xx-response.ts +0 -24
  199. package/src/rules/common/operation-description.ts +0 -13
  200. package/src/rules/common/operation-operationId-unique.ts +0 -21
  201. package/src/rules/common/operation-operationId-url-safe.ts +0 -19
  202. package/src/rules/common/operation-operationId.ts +0 -17
  203. package/src/rules/common/operation-parameters-unique.ts +0 -48
  204. package/src/rules/common/operation-singular-tag.ts +0 -17
  205. package/src/rules/common/operation-summary.ts +0 -13
  206. package/src/rules/common/operation-tag-defined.ts +0 -26
  207. package/src/rules/common/parameter-description.ts +0 -22
  208. package/src/rules/common/path-declaration-must-exist.ts +0 -15
  209. package/src/rules/common/path-excludes-patterns.ts +0 -23
  210. package/src/rules/common/path-http-verbs-order.ts +0 -30
  211. package/src/rules/common/path-not-include-query.ts +0 -17
  212. package/src/rules/common/path-params-defined.ts +0 -65
  213. package/src/rules/common/path-segment-plural.ts +0 -31
  214. package/src/rules/common/paths-kebab-case.ts +0 -19
  215. package/src/rules/common/required-string-property-missing-min-length.ts +0 -44
  216. package/src/rules/common/response-contains-header.ts +0 -35
  217. package/src/rules/common/scalar-property-missing-example.ts +0 -58
  218. package/src/rules/common/security-defined.ts +0 -65
  219. package/src/rules/common/spec.ts +0 -174
  220. package/src/rules/common/tag-description.ts +0 -10
  221. package/src/rules/common/tags-alphabetical.ts +0 -20
  222. package/src/rules/no-unresolved-refs.ts +0 -51
  223. package/src/rules/oas2/__tests__/boolean-parameter-prefixes.test.ts +0 -110
  224. package/src/rules/oas2/__tests__/response-contains-header.test.ts +0 -174
  225. package/src/rules/oas2/__tests__/response-contains-property.test.ts +0 -155
  226. package/src/rules/oas2/__tests__/spec/fixtures/description.md +0 -1
  227. package/src/rules/oas2/__tests__/spec/info.test.ts +0 -355
  228. package/src/rules/oas2/__tests__/spec/operation.test.ts +0 -123
  229. package/src/rules/oas2/__tests__/spec/paths.test.ts +0 -245
  230. package/src/rules/oas2/__tests__/spec/referenceableScalars.test.ts +0 -35
  231. package/src/rules/oas2/__tests__/spec/utils.ts +0 -32
  232. package/src/rules/oas2/boolean-parameter-prefixes.ts +0 -26
  233. package/src/rules/oas2/index.ts +0 -89
  234. package/src/rules/oas2/remove-unused-components.ts +0 -81
  235. package/src/rules/oas2/request-mime-type.ts +0 -17
  236. package/src/rules/oas2/response-contains-property.ts +0 -36
  237. package/src/rules/oas2/response-mime-type.ts +0 -17
  238. package/src/rules/oas3/__tests__/boolean-parameter-prefixes.test.ts +0 -111
  239. package/src/rules/oas3/__tests__/fixtures/common.yaml +0 -11
  240. package/src/rules/oas3/__tests__/no-empty-enum-servers.com.test.ts +0 -205
  241. package/src/rules/oas3/__tests__/no-example-value-and-externalValue.test.ts +0 -65
  242. package/src/rules/oas3/__tests__/no-invalid-media-type-examples.test.ts +0 -473
  243. package/src/rules/oas3/__tests__/no-server-example.com.test.ts +0 -60
  244. package/src/rules/oas3/__tests__/no-server-trailing-slash.test.ts +0 -79
  245. package/src/rules/oas3/__tests__/no-unused-components.test.ts +0 -131
  246. package/src/rules/oas3/__tests__/operation-4xx-problem-details-rfc7807.test.ts +0 -145
  247. package/src/rules/oas3/__tests__/response-contains-header.test.ts +0 -389
  248. package/src/rules/oas3/__tests__/response-contains-property.test.ts +0 -403
  249. package/src/rules/oas3/__tests__/spec/callbacks.test.ts +0 -41
  250. package/src/rules/oas3/__tests__/spec/fixtures/description.md +0 -1
  251. package/src/rules/oas3/__tests__/spec/info.test.ts +0 -391
  252. package/src/rules/oas3/__tests__/spec/operation.test.ts +0 -253
  253. package/src/rules/oas3/__tests__/spec/paths.test.ts +0 -284
  254. package/src/rules/oas3/__tests__/spec/referenceableScalars.test.ts +0 -77
  255. package/src/rules/oas3/__tests__/spec/servers.test.ts +0 -505
  256. package/src/rules/oas3/__tests__/spec/spec.test.ts +0 -298
  257. package/src/rules/oas3/__tests__/spec/utils.ts +0 -32
  258. package/src/rules/oas3/__tests__/spec-components-invalid-map-name.test.ts +0 -305
  259. package/src/rules/oas3/boolean-parameter-prefixes.ts +0 -28
  260. package/src/rules/oas3/index.ts +0 -109
  261. package/src/rules/oas3/no-empty-servers.ts +0 -22
  262. package/src/rules/oas3/no-example-value-and-externalValue.ts +0 -14
  263. package/src/rules/oas3/no-invalid-media-type-examples.ts +0 -49
  264. package/src/rules/oas3/no-server-example.com.ts +0 -14
  265. package/src/rules/oas3/no-server-trailing-slash.ts +0 -15
  266. package/src/rules/oas3/no-server-variables-empty-enum.ts +0 -66
  267. package/src/rules/oas3/no-undefined-server-variable.ts +0 -30
  268. package/src/rules/oas3/no-unused-components.ts +0 -75
  269. package/src/rules/oas3/operation-4xx-problem-details-rfc7807.ts +0 -36
  270. package/src/rules/oas3/remove-unused-components.ts +0 -95
  271. package/src/rules/oas3/request-mime-type.ts +0 -31
  272. package/src/rules/oas3/response-contains-property.ts +0 -38
  273. package/src/rules/oas3/response-mime-type.ts +0 -31
  274. package/src/rules/oas3/spec-components-invalid-map-name.ts +0 -74
  275. package/src/rules/other/stats.ts +0 -73
  276. package/src/rules/utils.ts +0 -191
  277. package/src/types/index.ts +0 -149
  278. package/src/types/oas2.ts +0 -478
  279. package/src/types/oas3.ts +0 -597
  280. package/src/types/oas3_1.ts +0 -258
  281. package/src/types/redocly-yaml.ts +0 -1010
  282. package/src/typings/common.ts +0 -17
  283. package/src/typings/openapi.ts +0 -298
  284. package/src/typings/swagger.ts +0 -236
  285. package/src/utils.ts +0 -276
  286. package/src/visitors.ts +0 -491
  287. package/src/walk.ts +0 -453
  288. package/tsconfig.json +0 -8
  289. package/tsconfig.tsbuildinfo +0 -1
@@ -1,20 +0,0 @@
1
- import { Oas2Decorator } from '../../visitors';
2
- import { RegistryDependencies } from '../common/registry-dependencies';
3
- import { OperationDescriptionOverride } from '../common/operation-description-override';
4
- import { TagDescriptionOverride } from '../common/tag-description-override';
5
- import { InfoDescriptionOverride } from '../common/info-description-override';
6
- import { InfoOverride } from '../common/info-override';
7
- import { RemoveXInternal } from '../common/remove-x-internal';
8
- import { FilterIn } from '../common/filters/filter-in';
9
- import { FilterOut } from '../common/filters/filter-out';
10
-
11
- export const decorators = {
12
- 'registry-dependencies': RegistryDependencies as Oas2Decorator,
13
- 'operation-description-override': OperationDescriptionOverride as Oas2Decorator,
14
- 'tag-description-override': TagDescriptionOverride as Oas2Decorator,
15
- 'info-description-override': InfoDescriptionOverride as Oas2Decorator,
16
- 'info-override': InfoOverride as Oas2Decorator,
17
- 'remove-x-internal': RemoveXInternal as Oas2Decorator,
18
- 'filter-in': FilterIn as Oas2Decorator,
19
- 'filter-out': FilterOut as Oas2Decorator,
20
- };
@@ -1,22 +0,0 @@
1
- import { Oas3Decorator } from '../../visitors';
2
- import { RegistryDependencies } from '../common/registry-dependencies';
3
- import { OperationDescriptionOverride } from '../common/operation-description-override';
4
- import { TagDescriptionOverride } from '../common/tag-description-override';
5
- import { InfoDescriptionOverride } from '../common/info-description-override';
6
- import { InfoOverride } from '../common/info-override';
7
- import { RemoveXInternal } from '../common/remove-x-internal';
8
- import { FilterIn } from '../common/filters/filter-in';
9
- import { FilterOut } from '../common/filters/filter-out';
10
- import { MediaTypeExamplesOverride } from '../common/media-type-examples-override';
11
-
12
- export const decorators = {
13
- 'registry-dependencies': RegistryDependencies as Oas3Decorator,
14
- 'operation-description-override': OperationDescriptionOverride as Oas3Decorator,
15
- 'tag-description-override': TagDescriptionOverride as Oas3Decorator,
16
- 'info-description-override': InfoDescriptionOverride as Oas3Decorator,
17
- 'info-override': InfoOverride as Oas3Decorator,
18
- 'remove-x-internal': RemoveXInternal as Oas3Decorator,
19
- 'filter-in': FilterIn as Oas3Decorator,
20
- 'filter-out': FilterOut as Oas3Decorator,
21
- 'media-type-examples-override': MediaTypeExamplesOverride as Oas3Decorator,
22
- };
package/src/env.ts DELETED
@@ -1,5 +0,0 @@
1
- export const isBrowser =
2
- // eslint-disable-next-line @typescript-eslint/ban-ts-comment
3
- // @ts-ignore
4
- typeof window !== 'undefined' || typeof self !== 'undefined' || typeof process === 'undefined'; // main and worker thread
5
- export const env = isBrowser ? {} : process.env || {};
@@ -1,216 +0,0 @@
1
- import * as yamlAst from 'yaml-ast-parser';
2
- import { unescapePointer } from '../ref-utils';
3
- import { LineColLocationObject, Loc, LocationObject } from '../walk';
4
- import { colorize, colorOptions } from '../logger';
5
-
6
- type YAMLMapping = yamlAst.YAMLMapping & { kind: yamlAst.Kind.MAPPING };
7
- type YAMLMap = yamlAst.YamlMap & { kind: yamlAst.Kind.MAP };
8
- type YAMLAnchorReference = yamlAst.YAMLAnchorReference & { kind: yamlAst.Kind.ANCHOR_REF };
9
- type YAMLSequence = yamlAst.YAMLSequence & { kind: yamlAst.Kind.SEQ };
10
- type YAMLScalar = yamlAst.YAMLScalar & { kind: yamlAst.Kind.SCALAR };
11
- type YAMLNode = YAMLMapping | YAMLMap | YAMLAnchorReference | YAMLSequence | YAMLScalar;
12
-
13
- const MAX_LINE_LENGTH = 150;
14
- const MAX_CODEFRAME_LINES = 3;
15
-
16
- // TODO: temporary
17
- function parsePointer(pointer: string) {
18
- return pointer.substr(2).split('/').map(unescapePointer);
19
- }
20
-
21
- export function getCodeframe(location: LineColLocationObject, color: boolean) {
22
- colorOptions.enabled = color;
23
- const { start, end = { line: start.line, col: start.col + 1 }, source } = location;
24
- const lines = source.getLines();
25
- const startLineNum = start.line;
26
- const endLineNum = Math.max(Math.min(end.line, lines.length), start.line);
27
- let skipLines = Math.max(endLineNum - startLineNum - MAX_CODEFRAME_LINES + 1, 0);
28
- if (skipLines < 2) skipLines = 0; // do not skip one line
29
-
30
- // Lines specified like this: ["prefix", "string"],
31
- const prefixedLines: [string, string][] = [];
32
-
33
- let currentPad = 0;
34
-
35
- for (let i = startLineNum; i <= endLineNum; i++) {
36
- if (skipLines > 0 && i >= endLineNum - skipLines) break;
37
- const line = lines[i - 1] || '';
38
- if (line !== '') currentPad = padSize(line);
39
- const startIdx = i === startLineNum ? start.col - 1 : currentPad;
40
- const endIdx = i === endLineNum ? end.col - 1 : line.length;
41
-
42
- prefixedLines.push([`${i}`, markLine(line, startIdx, endIdx, colorize.red)]);
43
- if (!color) prefixedLines.push(['', underlineLine(line, startIdx, endIdx)]);
44
- }
45
-
46
- if (skipLines > 0) {
47
- prefixedLines.push([
48
- `…`,
49
- `${whitespace(currentPad)}${colorize.gray(`< ${skipLines} more lines >`)}`,
50
- ]);
51
- // print last line
52
- prefixedLines.push([
53
- `${endLineNum}`,
54
- markLine(lines[endLineNum - 1], -1, end.col - 1, colorize.red),
55
- ]);
56
-
57
- if (!color) prefixedLines.push(['', underlineLine(lines[endLineNum - 1], -1, end.col - 1)]);
58
- }
59
-
60
- return printPrefixedLines([
61
- [`${startLineNum - 2}`, markLine(lines[startLineNum - 1 - 2])],
62
- [`${startLineNum - 1}`, markLine(lines[startLineNum - 1 - 1])],
63
- ...prefixedLines,
64
- [`${endLineNum + 1}`, markLine(lines[endLineNum - 1 + 1])],
65
- [`${endLineNum + 2}`, markLine(lines[endLineNum - 1 + 2])],
66
- ]);
67
-
68
- function markLine(
69
- line: string,
70
- startIdx: number = -1,
71
- endIdx: number = +Infinity,
72
- variant = colorize.gray
73
- ) {
74
- if (!color) return line;
75
- if (!line) return line;
76
-
77
- if (startIdx === -1) {
78
- startIdx = padSize(line);
79
- }
80
-
81
- endIdx = Math.min(endIdx, line.length);
82
- return (
83
- line.substr(0, startIdx) + variant(line.substring(startIdx, endIdx)) + line.substr(endIdx)
84
- );
85
- }
86
- }
87
-
88
- function printPrefixedLines(lines: [string, string][]): string {
89
- const existingLines = lines.filter(([_, line]) => line !== undefined);
90
-
91
- const padLen = Math.max(...existingLines.map(([prefix]) => prefix.length));
92
- const dedentLen = Math.min(
93
- ...existingLines.map(([_, line]) => (line === '' ? Infinity : padSize(line)))
94
- );
95
-
96
- return existingLines
97
- .map(
98
- ([prefix, line]) =>
99
- colorize.gray(leftPad(padLen, prefix) + ' |') +
100
- (line ? ' ' + limitLineLength(line.substring(dedentLen)) : '')
101
- )
102
- .join('\n');
103
- }
104
-
105
- function limitLineLength(line: string, maxLen: number = MAX_LINE_LENGTH) {
106
- const overflowLen = line.length - maxLen;
107
- if (overflowLen > 0) {
108
- const charsMoreText = colorize.gray(`...<${overflowLen} chars>`);
109
- return line.substring(0, maxLen - charsMoreText.length) + charsMoreText;
110
- } else {
111
- return line;
112
- }
113
- }
114
-
115
- function underlineLine(line: string, startIdx: number = -1, endIdx: number = +Infinity) {
116
- if (startIdx === -1) {
117
- startIdx = padSize(line);
118
- }
119
-
120
- endIdx = Math.min(endIdx, line.length);
121
- return whitespace(startIdx) + '^'.repeat(Math.max(endIdx - startIdx, 1));
122
- }
123
-
124
- function whitespace(len: number): string {
125
- return ' '.repeat(len);
126
- }
127
-
128
- function leftPad(len: number, str: string): string {
129
- return whitespace(len - str.length) + str;
130
- }
131
-
132
- function padSize(line: string): number {
133
- for (let i = 0; i < line.length; i++) {
134
- if (line[i] !== ' ') return i;
135
- }
136
- return line.length;
137
- }
138
-
139
- export function getLineColLocation(location: LocationObject): LineColLocationObject {
140
- if (location.pointer === undefined) return location;
141
-
142
- const { source, pointer, reportOnKey } = location;
143
- const ast = source.getAst(yamlAst.safeLoad) as YAMLNode;
144
- const astNode = getAstNodeByPointer(ast, pointer, !!reportOnKey);
145
- return {
146
- ...location,
147
- pointer: undefined,
148
- ...positionsToLoc(source.body, astNode?.startPosition ?? 1, astNode?.endPosition ?? 1),
149
- };
150
- }
151
-
152
- function positionsToLoc(
153
- source: string,
154
- startPos: number,
155
- endPos: number
156
- ): { start: Loc; end: Loc } {
157
- let currentLine = 1;
158
- let currentCol = 1;
159
- let start: Loc = { line: 1, col: 1 };
160
-
161
- for (let i = 0; i < endPos - 1; i++) {
162
- if (i === startPos - 1) {
163
- start = { line: currentLine, col: currentCol + 1 };
164
- }
165
- if (source[i] === '\n') {
166
- currentLine++;
167
- currentCol = 1;
168
- if (i === startPos - 1) {
169
- start = { line: currentLine, col: currentCol };
170
- }
171
-
172
- if (source[i + 1] === '\r') i++; // TODO: test it
173
- continue;
174
- }
175
- currentCol++;
176
- }
177
-
178
- const end = startPos === endPos ? { ...start } : { line: currentLine, col: currentCol + 1 };
179
- return { start, end };
180
- }
181
-
182
- export function getAstNodeByPointer(root: YAMLNode, pointer: string, reportOnKey: boolean) {
183
- const pointerSegments = parsePointer(pointer);
184
- if (root === undefined) {
185
- return undefined;
186
- }
187
-
188
- let currentNode = root;
189
- for (const key of pointerSegments) {
190
- if (currentNode.kind === yamlAst.Kind.MAP) {
191
- const mapping = currentNode.mappings.find((m) => m.key.value === key);
192
- if (!mapping) break;
193
- currentNode = mapping as YAMLNode;
194
- if (!mapping?.value) break; // If node has value - return value, if not - return node itself
195
- currentNode = mapping.value as YAMLNode;
196
- } else if (currentNode.kind === yamlAst.Kind.SEQ) {
197
- const elem = currentNode.items[parseInt(key, 10)] as YAMLNode;
198
- if (!elem) break;
199
- currentNode = elem as YAMLNode;
200
- }
201
- }
202
-
203
- if (!reportOnKey) {
204
- return currentNode;
205
- } else {
206
- const parent = currentNode.parent as YAMLNode;
207
- if (!parent) return currentNode;
208
- if (parent.kind === yamlAst.Kind.SEQ) {
209
- return currentNode;
210
- } else if (parent.kind === yamlAst.Kind.MAPPING) {
211
- return parent.key;
212
- } else {
213
- return currentNode;
214
- }
215
- }
216
- }
@@ -1,375 +0,0 @@
1
- import * as path from 'path';
2
- import { colorOptions, colorize, logger } from '../logger';
3
- import { output } from '../output';
4
-
5
- const coreVersion = require('../../package.json').version;
6
-
7
- import { NormalizedProblem, ProblemSeverity, LineColLocationObject, LocationObject } from '../walk';
8
- import { getCodeframe, getLineColLocation } from './codeframes';
9
- import { env } from '../env';
10
- import { isAbsoluteUrl } from '../ref-utils';
11
-
12
- export type Totals = {
13
- errors: number;
14
- warnings: number;
15
- ignored: number;
16
- };
17
-
18
- const ERROR_MESSAGE = {
19
- INVALID_SEVERITY_LEVEL: 'Invalid severity level; accepted values: error or warn',
20
- };
21
-
22
- const BG_COLORS = {
23
- warn: (str: string) => colorize.bgYellow(colorize.black(str)),
24
- error: colorize.bgRed,
25
- };
26
-
27
- const COLORS = {
28
- warn: colorize.yellow,
29
- error: colorize.red,
30
- };
31
-
32
- const SEVERITY_NAMES = {
33
- warn: 'Warning',
34
- error: 'Error',
35
- };
36
-
37
- const CODECLIMATE_SEVERITY_MAPPING = {
38
- error: 'critical',
39
- warn: 'minor',
40
- };
41
-
42
- const MAX_SUGGEST = 5;
43
-
44
- function severityToNumber(severity: ProblemSeverity) {
45
- return severity === 'error' ? 1 : 2;
46
- }
47
-
48
- export type OutputFormat =
49
- | 'codeframe'
50
- | 'stylish'
51
- | 'json'
52
- | 'checkstyle'
53
- | 'codeclimate'
54
- | 'summary';
55
-
56
- export function getTotals(problems: (NormalizedProblem & { ignored?: boolean })[]): Totals {
57
- let errors = 0;
58
- let warnings = 0;
59
- let ignored = 0;
60
-
61
- for (const m of problems) {
62
- if (m.ignored) {
63
- ignored++;
64
- continue;
65
- }
66
- if (m.severity === 'error') errors++;
67
- if (m.severity === 'warn') warnings++;
68
- }
69
-
70
- return {
71
- errors,
72
- warnings,
73
- ignored,
74
- };
75
- }
76
-
77
- export function formatProblems(
78
- problems: (NormalizedProblem & { ignored?: boolean })[],
79
- opts: {
80
- maxProblems?: number;
81
- cwd?: string;
82
- format?: OutputFormat;
83
- color?: boolean;
84
- totals: Totals;
85
- version: string;
86
- }
87
- ) {
88
- const {
89
- maxProblems = 100,
90
- cwd = process.cwd(),
91
- format = 'codeframe',
92
- color = colorOptions.enabled,
93
- totals = getTotals(problems),
94
- version = coreVersion,
95
- } = opts;
96
-
97
- colorOptions.enabled = color; // force colors if specified
98
-
99
- const totalProblems = problems.length;
100
- problems = problems.filter((m) => !m.ignored);
101
- const ignoredProblems = totalProblems - problems.length;
102
-
103
- problems = problems
104
- .sort((a, b) => severityToNumber(a.severity) - severityToNumber(b.severity))
105
- .slice(0, maxProblems);
106
-
107
- if (!totalProblems && format !== 'json') return;
108
-
109
- switch (format) {
110
- case 'json':
111
- outputJSON();
112
- break;
113
- case 'codeframe':
114
- for (let i = 0; i < problems.length; i++) {
115
- const problem = problems[i];
116
- logger.info(`${formatCodeframe(problem, i)}\n`);
117
- }
118
- break;
119
- case 'stylish': {
120
- const groupedByFile = groupByFiles(problems);
121
- for (const [file, { ruleIdPad, locationPad: positionPad, fileProblems }] of Object.entries(
122
- groupedByFile
123
- )) {
124
- logger.info(`${colorize.blue(isAbsoluteUrl(file) ? file : path.relative(cwd, file))}:\n`);
125
-
126
- for (let i = 0; i < fileProblems.length; i++) {
127
- const problem = fileProblems[i];
128
- logger.info(`${formatStylish(problem, positionPad, ruleIdPad)}\n`);
129
- }
130
-
131
- logger.info('\n');
132
- }
133
- break;
134
- }
135
- case 'checkstyle': {
136
- const groupedByFile = groupByFiles(problems);
137
-
138
- output.write('<?xml version="1.0" encoding="UTF-8"?>\n');
139
- output.write('<checkstyle version="4.3">\n');
140
-
141
- for (const [file, { fileProblems }] of Object.entries(groupedByFile)) {
142
- output.write(
143
- `<file name="${xmlEscape(isAbsoluteUrl(file) ? file : path.relative(cwd, file))}">\n`
144
- );
145
- fileProblems.forEach(formatCheckstyle);
146
- output.write(`</file>\n`);
147
- }
148
-
149
- output.write(`</checkstyle>\n`);
150
- break;
151
- }
152
- case 'codeclimate':
153
- outputForCodeClimate();
154
- break;
155
- case 'summary':
156
- formatSummary(problems);
157
- break;
158
- }
159
-
160
- if (totalProblems - ignoredProblems > maxProblems) {
161
- logger.info(
162
- `< ... ${totalProblems - maxProblems} more problems hidden > ${colorize.gray(
163
- 'increase with `--max-problems N`'
164
- )}\n`
165
- );
166
- }
167
-
168
- function outputForCodeClimate() {
169
- const issues = problems.map((p) => {
170
- const location = p.location[0]; // TODO: support multiple location
171
- const lineCol = getLineColLocation(location);
172
- return {
173
- description: p.message,
174
- location: {
175
- path: isAbsoluteUrl(location.source.absoluteRef)
176
- ? location.source.absoluteRef
177
- : path.relative(cwd, location.source.absoluteRef),
178
- lines: {
179
- begin: lineCol.start.line,
180
- },
181
- },
182
- severity: CODECLIMATE_SEVERITY_MAPPING[p.severity],
183
- fingerprint: `${p.ruleId}${p.location.length > 0 ? '-' + p.location[0].pointer : ''}`,
184
- };
185
- });
186
- output.write(JSON.stringify(issues, null, 2));
187
- }
188
-
189
- function outputJSON() {
190
- const resultObject = {
191
- totals,
192
- version,
193
- problems: problems.map((p) => {
194
- const problem = {
195
- ...p,
196
- location: p.location.map((location: any) => ({
197
- ...location,
198
- source: {
199
- ref: isAbsoluteUrl(location.source.absoluteRef)
200
- ? location.source.absoluteRef
201
- : path.relative(cwd, location.source.absoluteRef),
202
- },
203
- })),
204
- from: p.from
205
- ? {
206
- ...p.from,
207
- source: {
208
- ref: isAbsoluteUrl(p.from?.source.absoluteRef)
209
- ? p.from?.source.absoluteRef
210
- : path.relative(cwd, p.from?.source.absoluteRef || cwd),
211
- },
212
- }
213
- : undefined,
214
- };
215
-
216
- if (env.FORMAT_JSON_WITH_CODEFRAMES) {
217
- const location = p.location[0]; // TODO: support multiple locations
218
- const loc = getLineColLocation(location);
219
- (problem as any).codeframe = getCodeframe(loc, color);
220
- }
221
- return problem;
222
- }),
223
- };
224
- output.write(JSON.stringify(resultObject, null, 2));
225
- }
226
-
227
- function getBgColor(problem: NormalizedProblem) {
228
- const { severity } = problem;
229
- if (!BG_COLORS[severity]) {
230
- throw new Error(ERROR_MESSAGE.INVALID_SEVERITY_LEVEL);
231
- }
232
- return BG_COLORS[severity];
233
- }
234
-
235
- function formatCodeframe(problem: NormalizedProblem, idx: number) {
236
- const bgColor = getBgColor(problem);
237
- const location = problem.location[0]; // TODO: support multiple locations
238
- const relativePath = isAbsoluteUrl(location.source.absoluteRef)
239
- ? location.source.absoluteRef
240
- : path.relative(cwd, location.source.absoluteRef);
241
- const loc = getLineColLocation(location);
242
- const atPointer = location.pointer ? colorize.gray(`at ${location.pointer}`) : '';
243
- const fileWithLoc = `${relativePath}:${loc.start.line}:${loc.start.col}`;
244
- return (
245
- `[${idx + 1}] ${bgColor(fileWithLoc)} ${atPointer}\n\n` +
246
- `${problem.message}\n\n` +
247
- formatDidYouMean(problem) +
248
- getCodeframe(loc, color) +
249
- '\n\n' +
250
- formatFrom(cwd, problem.from) +
251
- `${SEVERITY_NAMES[problem.severity]} was generated by the ${colorize.blue(
252
- problem.ruleId
253
- )} rule.\n\n`
254
- );
255
- }
256
-
257
- function formatStylish(problem: OnlyLineColProblem, locationPad: number, ruleIdPad: number) {
258
- const color = COLORS[problem.severity];
259
- if (!SEVERITY_NAMES[problem.severity]) {
260
- return 'Error not found severity. Please check your config file. Allowed values: `warn,error,off`';
261
- }
262
- const severityName = color(SEVERITY_NAMES[problem.severity].toLowerCase().padEnd(7));
263
- const { start } = problem.location[0];
264
- return ` ${`${start.line}:${start.col}`.padEnd(
265
- locationPad
266
- )} ${severityName} ${problem.ruleId.padEnd(ruleIdPad)} ${problem.message}`;
267
- }
268
-
269
- function formatCheckstyle(problem: OnlyLineColProblem) {
270
- const { line, col } = problem.location[0].start;
271
- const severity = problem.severity == 'warn' ? 'warning' : 'error';
272
- const message = xmlEscape(problem.message);
273
- const source = xmlEscape(problem.ruleId);
274
- output.write(
275
- `<error line="${line}" column="${col}" severity="${severity}" message="${message}" source="${source}" />\n`
276
- );
277
- }
278
- }
279
-
280
- function formatSummary(problems: NormalizedProblem[]): void {
281
- const counts: Record<string, { count: number; severity: ProblemSeverity }> = {};
282
- for (const problem of problems) {
283
- counts[problem.ruleId] = counts[problem.ruleId] || { count: 0, severity: problem.severity };
284
- counts[problem.ruleId].count++;
285
- }
286
- const sorted = Object.entries(counts).sort(([, a], [, b]) => {
287
- const severityDiff = severityToNumber(a.severity) - severityToNumber(b.severity);
288
- return severityDiff || b.count - a.count;
289
- });
290
-
291
- for (const [ruleId, info] of sorted) {
292
- const color = COLORS[info.severity];
293
- const severityName = color(SEVERITY_NAMES[info.severity].toLowerCase().padEnd(7));
294
- logger.info(`${severityName} ${ruleId}: ${info.count}\n`);
295
- }
296
-
297
- logger.info('\n');
298
- }
299
-
300
- function formatFrom(cwd: string, location?: LocationObject) {
301
- if (!location) return '';
302
- const relativePath = path.relative(cwd, location.source.absoluteRef);
303
- const loc = getLineColLocation(location);
304
- const fileWithLoc = `${relativePath}:${loc.start.line}:${loc.start.col}`;
305
- const atPointer = location.pointer ? colorize.gray(`at ${location.pointer}`) : '';
306
-
307
- return `referenced from ${colorize.blue(fileWithLoc)} ${atPointer} \n\n`;
308
- }
309
-
310
- function formatDidYouMean(problem: NormalizedProblem) {
311
- if (problem.suggest.length === 0) return '';
312
-
313
- if (problem.suggest.length === 1) {
314
- return `Did you mean: ${problem.suggest[0]} ?\n\n`;
315
- } else {
316
- return `Did you mean:\n - ${problem.suggest.slice(0, MAX_SUGGEST).join('\n - ')}\n\n`;
317
- }
318
- }
319
-
320
- type OnlyLineColProblem = Omit<NormalizedProblem, 'location'> & {
321
- location: LineColLocationObject[];
322
- };
323
-
324
- const groupByFiles = (problems: NormalizedProblem[]) => {
325
- const fileGroups: Record<
326
- string,
327
- {
328
- locationPad: number;
329
- ruleIdPad: number;
330
- fileProblems: OnlyLineColProblem[];
331
- }
332
- > = {};
333
- for (const problem of problems) {
334
- const absoluteRef = problem.location[0].source.absoluteRef; // TODO: multiple errors
335
- fileGroups[absoluteRef] = fileGroups[absoluteRef] || {
336
- fileProblems: [],
337
- ruleIdPad: 0,
338
- locationPad: 0,
339
- };
340
-
341
- const mappedProblem = { ...problem, location: problem.location.map(getLineColLocation) };
342
- fileGroups[absoluteRef].fileProblems.push(mappedProblem);
343
- fileGroups[absoluteRef].ruleIdPad = Math.max(
344
- problem.ruleId.length,
345
- fileGroups[absoluteRef].ruleIdPad
346
- );
347
-
348
- fileGroups[absoluteRef].locationPad = Math.max(
349
- Math.max(...mappedProblem.location.map((loc) => `${loc.start.line}:${loc.start.col}`.length)),
350
- fileGroups[absoluteRef].locationPad
351
- );
352
- }
353
-
354
- return fileGroups;
355
- };
356
-
357
- function xmlEscape(s: string): string {
358
- // eslint-disable-next-line no-control-regex
359
- return s.replace(/[<>&"'\x00-\x1F\x7F\u0080-\uFFFF]/gu, (char) => {
360
- switch (char) {
361
- case '<':
362
- return '&lt;';
363
- case '>':
364
- return '&gt;';
365
- case '&':
366
- return '&amp;';
367
- case '"':
368
- return '&quot;';
369
- case "'":
370
- return '&apos;';
371
- default:
372
- return `&#${char.charCodeAt(0)};`;
373
- }
374
- });
375
- }