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

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 (275) hide show
  1. package/lib/bundle.js +5 -2
  2. package/lib/rules/common/spec.js +1 -0
  3. package/lib/rules/oas2/request-mime-type.d.ts +1 -1
  4. package/lib/rules/oas2/response-mime-type.d.ts +1 -1
  5. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.d.ts +2 -2
  6. package/lib/rules/oas3/operation-4xx-problem-details-rfc7807.js +3 -3
  7. package/lib/rules/oas3/request-mime-type.d.ts +1 -1
  8. package/lib/rules/oas3/response-mime-type.d.ts +1 -1
  9. package/lib/walk.d.ts +6 -5
  10. package/lib/walk.js +23 -27
  11. package/package.json +1 -1
  12. package/__tests__/utils.ts +0 -88
  13. package/src/__tests__/__snapshots__/bundle.test.ts.snap +0 -437
  14. package/src/__tests__/bundle.test.ts +0 -236
  15. package/src/__tests__/codeframes.test.ts +0 -530
  16. package/src/__tests__/fixtures/.redocly.lint-ignore.yaml +0 -5
  17. package/src/__tests__/fixtures/extension.js +0 -24
  18. package/src/__tests__/fixtures/refs/definitions.yaml +0 -3
  19. package/src/__tests__/fixtures/refs/examples.yaml +0 -8
  20. package/src/__tests__/fixtures/refs/external-request-body.yaml +0 -13
  21. package/src/__tests__/fixtures/refs/externalref.yaml +0 -35
  22. package/src/__tests__/fixtures/refs/hosted.yaml +0 -35
  23. package/src/__tests__/fixtures/refs/openapi-with-external-refs-conflicting-names.yaml +0 -21
  24. package/src/__tests__/fixtures/refs/openapi-with-external-refs.yaml +0 -33
  25. package/src/__tests__/fixtures/refs/openapi-with-url-refs.yaml +0 -18
  26. package/src/__tests__/fixtures/refs/param-b.yaml +0 -1
  27. package/src/__tests__/fixtures/refs/param-c.yaml +0 -1
  28. package/src/__tests__/fixtures/refs/rename.yaml +0 -1
  29. package/src/__tests__/fixtures/refs/requestBody.yaml +0 -9
  30. package/src/__tests__/fixtures/refs/schema-a.yaml +0 -1
  31. package/src/__tests__/fixtures/refs/simple.yaml +0 -1
  32. package/src/__tests__/fixtures/refs/vendor.schema.yaml +0 -20
  33. package/src/__tests__/fixtures/resolve/External.yaml +0 -10
  34. package/src/__tests__/fixtures/resolve/External2.yaml +0 -4
  35. package/src/__tests__/fixtures/resolve/description.md +0 -3
  36. package/src/__tests__/fixtures/resolve/externalInfo.yaml +0 -4
  37. package/src/__tests__/fixtures/resolve/externalLicense.yaml +0 -1
  38. package/src/__tests__/fixtures/resolve/openapi-with-back.yaml +0 -13
  39. package/src/__tests__/fixtures/resolve/openapi-with-md-description.yaml +0 -5
  40. package/src/__tests__/fixtures/resolve/openapi.yaml +0 -28
  41. package/src/__tests__/fixtures/resolve/schemas/type-a.yaml +0 -10
  42. package/src/__tests__/fixtures/resolve/schemas/type-b.yaml +0 -6
  43. package/src/__tests__/fixtures/resolve/transitive/a.yaml +0 -1
  44. package/src/__tests__/fixtures/resolve/transitive/components.yaml +0 -5
  45. package/src/__tests__/fixtures/resolve/transitive/schemas.yaml +0 -3
  46. package/src/__tests__/format.test.ts +0 -76
  47. package/src/__tests__/js-yaml.test.ts +0 -73
  48. package/src/__tests__/lint.test.ts +0 -388
  49. package/src/__tests__/logger-browser.test.ts +0 -53
  50. package/src/__tests__/logger.test.ts +0 -47
  51. package/src/__tests__/login.test.ts +0 -17
  52. package/src/__tests__/normalizeVisitors.test.ts +0 -151
  53. package/src/__tests__/output-browser.test.ts +0 -18
  54. package/src/__tests__/output.test.ts +0 -15
  55. package/src/__tests__/ref-utils.test.ts +0 -120
  56. package/src/__tests__/resolve-http.test.ts +0 -77
  57. package/src/__tests__/resolve.test.ts +0 -430
  58. package/src/__tests__/utils-browser.test.ts +0 -11
  59. package/src/__tests__/utils.test.ts +0 -144
  60. package/src/__tests__/walk.test.ts +0 -1545
  61. package/src/benchmark/benches/lint-with-many-rules.bench.ts +0 -35
  62. package/src/benchmark/benches/lint-with-nested-rule.bench.ts +0 -39
  63. package/src/benchmark/benches/lint-with-no-rules.bench.ts +0 -20
  64. package/src/benchmark/benches/lint-with-top-level-rule-report.bench.ts +0 -35
  65. package/src/benchmark/benches/lint-with-top-level-rule.bench.ts +0 -32
  66. package/src/benchmark/benches/rebilly.yaml +0 -32275
  67. package/src/benchmark/benches/recommended-oas3.bench.ts +0 -22
  68. package/src/benchmark/benches/resolve-with-no-external.bench.ts +0 -23
  69. package/src/benchmark/benchmark.js +0 -311
  70. package/src/benchmark/colors.js +0 -29
  71. package/src/benchmark/fork.js +0 -83
  72. package/src/benchmark/utils.ts +0 -36
  73. package/src/bundle.ts +0 -399
  74. package/src/config/__tests__/__snapshots__/config-resolvers.test.ts.snap +0 -161
  75. package/src/config/__tests__/__snapshots__/config.test.ts.snap +0 -144
  76. package/src/config/__tests__/config-resolvers.test.ts +0 -491
  77. package/src/config/__tests__/config.test.ts +0 -307
  78. package/src/config/__tests__/fixtures/ingore-file.ts +0 -8
  79. package/src/config/__tests__/fixtures/load-redocly.yaml +0 -2
  80. package/src/config/__tests__/fixtures/plugin-config.yaml +0 -2
  81. package/src/config/__tests__/fixtures/plugin.js +0 -56
  82. package/src/config/__tests__/fixtures/resolve-config/api/nested-config.yaml +0 -11
  83. package/src/config/__tests__/fixtures/resolve-config/api/plugin.js +0 -69
  84. package/src/config/__tests__/fixtures/resolve-config/local-config-with-circular.yaml +0 -7
  85. package/src/config/__tests__/fixtures/resolve-config/local-config-with-custom-function.yaml +0 -17
  86. package/src/config/__tests__/fixtures/resolve-config/local-config-with-file.yaml +0 -18
  87. package/src/config/__tests__/fixtures/resolve-config/local-config-with-wrong-custom-function.yaml +0 -15
  88. package/src/config/__tests__/fixtures/resolve-config/local-config.yaml +0 -9
  89. package/src/config/__tests__/fixtures/resolve-config/plugin.js +0 -80
  90. package/src/config/__tests__/fixtures/resolve-remote-configs/nested-remote-config.yaml +0 -3
  91. package/src/config/__tests__/fixtures/resolve-remote-configs/remote-config.yaml +0 -4
  92. package/src/config/__tests__/load.test.ts +0 -167
  93. package/src/config/__tests__/resolve-plugins.test.ts +0 -27
  94. package/src/config/__tests__/utils.test.ts +0 -204
  95. package/src/config/all.ts +0 -73
  96. package/src/config/builtIn.ts +0 -37
  97. package/src/config/config-resolvers.ts +0 -465
  98. package/src/config/config.ts +0 -330
  99. package/src/config/index.ts +0 -7
  100. package/src/config/load.ts +0 -144
  101. package/src/config/minimal.ts +0 -60
  102. package/src/config/recommended.ts +0 -60
  103. package/src/config/rules.ts +0 -54
  104. package/src/config/types.ts +0 -216
  105. package/src/config/utils.ts +0 -333
  106. package/src/decorators/__tests__/filter-in.test.ts +0 -310
  107. package/src/decorators/__tests__/filter-out.test.ts +0 -335
  108. package/src/decorators/__tests__/media-type-examples-override.test.ts +0 -665
  109. package/src/decorators/__tests__/remove-x-internal.test.ts +0 -316
  110. package/src/decorators/__tests__/resources/request.yaml +0 -3
  111. package/src/decorators/__tests__/resources/response.yaml +0 -3
  112. package/src/decorators/common/filters/filter-helper.ts +0 -72
  113. package/src/decorators/common/filters/filter-in.ts +0 -18
  114. package/src/decorators/common/filters/filter-out.ts +0 -18
  115. package/src/decorators/common/info-description-override.ts +0 -24
  116. package/src/decorators/common/info-override.ts +0 -15
  117. package/src/decorators/common/media-type-examples-override.ts +0 -79
  118. package/src/decorators/common/operation-description-override.ts +0 -30
  119. package/src/decorators/common/registry-dependencies.ts +0 -25
  120. package/src/decorators/common/remove-x-internal.ts +0 -59
  121. package/src/decorators/common/tag-description-override.ts +0 -25
  122. package/src/decorators/oas2/index.ts +0 -20
  123. package/src/decorators/oas3/index.ts +0 -22
  124. package/src/env.ts +0 -5
  125. package/src/format/codeframes.ts +0 -216
  126. package/src/format/format.ts +0 -375
  127. package/src/index.ts +0 -71
  128. package/src/js-yaml/index.ts +0 -14
  129. package/src/lint.ts +0 -130
  130. package/src/logger.ts +0 -34
  131. package/src/oas-types.ts +0 -57
  132. package/src/output.ts +0 -7
  133. package/src/redocly/__tests__/redocly-client.test.ts +0 -146
  134. package/src/redocly/index.ts +0 -187
  135. package/src/redocly/redocly-client-types.ts +0 -10
  136. package/src/redocly/registry-api-types.ts +0 -32
  137. package/src/redocly/registry-api.ts +0 -149
  138. package/src/ref-utils.ts +0 -85
  139. package/src/resolve.ts +0 -417
  140. package/src/rules/__tests__/fixtures/code-sample.php +0 -9
  141. package/src/rules/__tests__/fixtures/invalid-yaml.yaml +0 -1
  142. package/src/rules/__tests__/fixtures/ref.yaml +0 -1
  143. package/src/rules/__tests__/no-unresolved-refs.test.ts +0 -257
  144. package/src/rules/__tests__/utils.test.ts +0 -160
  145. package/src/rules/ajv.ts +0 -102
  146. package/src/rules/common/__tests__/info-license.test.ts +0 -62
  147. package/src/rules/common/__tests__/license-url.test.ts +0 -63
  148. package/src/rules/common/__tests__/no-ambiguous-paths.test.ts +0 -96
  149. package/src/rules/common/__tests__/no-enum-type-mismatch.test.ts +0 -210
  150. package/src/rules/common/__tests__/no-identical-paths.test.ts +0 -58
  151. package/src/rules/common/__tests__/no-path-trailing-slash.test.ts +0 -85
  152. package/src/rules/common/__tests__/operation-2xx-response.test.ts +0 -192
  153. package/src/rules/common/__tests__/operation-4xx-response.test.ts +0 -231
  154. package/src/rules/common/__tests__/operation-operationId-unique.test.ts +0 -76
  155. package/src/rules/common/__tests__/operation-operationId-url-safe.test.ts +0 -45
  156. package/src/rules/common/__tests__/operation-parameters-unique.test.ts +0 -167
  157. package/src/rules/common/__tests__/operation-singular-tag.test.ts +0 -72
  158. package/src/rules/common/__tests__/path-http-verbs-order.test.ts +0 -95
  159. package/src/rules/common/__tests__/path-not-include-query.test.ts +0 -64
  160. package/src/rules/common/__tests__/path-params-defined.test.ts +0 -202
  161. package/src/rules/common/__tests__/paths-kebab-case.test.ts +0 -108
  162. package/src/rules/common/__tests__/scalar-property-missing-example.test.ts +0 -264
  163. package/src/rules/common/__tests__/security-defined.test.ts +0 -175
  164. package/src/rules/common/__tests__/spec.test.ts +0 -555
  165. package/src/rules/common/__tests__/tag-description.test.ts +0 -65
  166. package/src/rules/common/__tests__/tags-alphabetical.test.ts +0 -64
  167. package/src/rules/common/assertions/__tests__/asserts.test.ts +0 -869
  168. package/src/rules/common/assertions/__tests__/index.test.ts +0 -100
  169. package/src/rules/common/assertions/__tests__/utils.test.ts +0 -236
  170. package/src/rules/common/assertions/asserts.ts +0 -357
  171. package/src/rules/common/assertions/index.ts +0 -56
  172. package/src/rules/common/assertions/utils.ts +0 -331
  173. package/src/rules/common/info-contact.ts +0 -15
  174. package/src/rules/common/info-license-url.ts +0 -10
  175. package/src/rules/common/info-license.ts +0 -15
  176. package/src/rules/common/no-ambiguous-paths.ts +0 -50
  177. package/src/rules/common/no-enum-type-mismatch.ts +0 -52
  178. package/src/rules/common/no-http-verbs-in-paths.ts +0 -36
  179. package/src/rules/common/no-identical-paths.ts +0 -24
  180. package/src/rules/common/no-invalid-parameter-examples.ts +0 -36
  181. package/src/rules/common/no-invalid-schema-examples.ts +0 -27
  182. package/src/rules/common/no-path-trailing-slash.ts +0 -15
  183. package/src/rules/common/operation-2xx-response.ts +0 -24
  184. package/src/rules/common/operation-4xx-response.ts +0 -24
  185. package/src/rules/common/operation-description.ts +0 -13
  186. package/src/rules/common/operation-operationId-unique.ts +0 -21
  187. package/src/rules/common/operation-operationId-url-safe.ts +0 -19
  188. package/src/rules/common/operation-operationId.ts +0 -17
  189. package/src/rules/common/operation-parameters-unique.ts +0 -48
  190. package/src/rules/common/operation-singular-tag.ts +0 -17
  191. package/src/rules/common/operation-summary.ts +0 -13
  192. package/src/rules/common/operation-tag-defined.ts +0 -26
  193. package/src/rules/common/parameter-description.ts +0 -22
  194. package/src/rules/common/path-declaration-must-exist.ts +0 -15
  195. package/src/rules/common/path-excludes-patterns.ts +0 -23
  196. package/src/rules/common/path-http-verbs-order.ts +0 -30
  197. package/src/rules/common/path-not-include-query.ts +0 -17
  198. package/src/rules/common/path-params-defined.ts +0 -65
  199. package/src/rules/common/path-segment-plural.ts +0 -31
  200. package/src/rules/common/paths-kebab-case.ts +0 -19
  201. package/src/rules/common/required-string-property-missing-min-length.ts +0 -44
  202. package/src/rules/common/response-contains-header.ts +0 -35
  203. package/src/rules/common/scalar-property-missing-example.ts +0 -58
  204. package/src/rules/common/security-defined.ts +0 -65
  205. package/src/rules/common/spec.ts +0 -174
  206. package/src/rules/common/tag-description.ts +0 -10
  207. package/src/rules/common/tags-alphabetical.ts +0 -20
  208. package/src/rules/no-unresolved-refs.ts +0 -51
  209. package/src/rules/oas2/__tests__/boolean-parameter-prefixes.test.ts +0 -110
  210. package/src/rules/oas2/__tests__/response-contains-header.test.ts +0 -174
  211. package/src/rules/oas2/__tests__/response-contains-property.test.ts +0 -155
  212. package/src/rules/oas2/__tests__/spec/fixtures/description.md +0 -1
  213. package/src/rules/oas2/__tests__/spec/info.test.ts +0 -355
  214. package/src/rules/oas2/__tests__/spec/operation.test.ts +0 -123
  215. package/src/rules/oas2/__tests__/spec/paths.test.ts +0 -245
  216. package/src/rules/oas2/__tests__/spec/referenceableScalars.test.ts +0 -35
  217. package/src/rules/oas2/__tests__/spec/utils.ts +0 -32
  218. package/src/rules/oas2/boolean-parameter-prefixes.ts +0 -26
  219. package/src/rules/oas2/index.ts +0 -89
  220. package/src/rules/oas2/remove-unused-components.ts +0 -81
  221. package/src/rules/oas2/request-mime-type.ts +0 -17
  222. package/src/rules/oas2/response-contains-property.ts +0 -36
  223. package/src/rules/oas2/response-mime-type.ts +0 -17
  224. package/src/rules/oas3/__tests__/boolean-parameter-prefixes.test.ts +0 -111
  225. package/src/rules/oas3/__tests__/fixtures/common.yaml +0 -11
  226. package/src/rules/oas3/__tests__/no-empty-enum-servers.com.test.ts +0 -205
  227. package/src/rules/oas3/__tests__/no-example-value-and-externalValue.test.ts +0 -65
  228. package/src/rules/oas3/__tests__/no-invalid-media-type-examples.test.ts +0 -473
  229. package/src/rules/oas3/__tests__/no-server-example.com.test.ts +0 -60
  230. package/src/rules/oas3/__tests__/no-server-trailing-slash.test.ts +0 -79
  231. package/src/rules/oas3/__tests__/no-unused-components.test.ts +0 -131
  232. package/src/rules/oas3/__tests__/operation-4xx-problem-details-rfc7807.test.ts +0 -145
  233. package/src/rules/oas3/__tests__/response-contains-header.test.ts +0 -389
  234. package/src/rules/oas3/__tests__/response-contains-property.test.ts +0 -403
  235. package/src/rules/oas3/__tests__/spec/callbacks.test.ts +0 -41
  236. package/src/rules/oas3/__tests__/spec/fixtures/description.md +0 -1
  237. package/src/rules/oas3/__tests__/spec/info.test.ts +0 -391
  238. package/src/rules/oas3/__tests__/spec/operation.test.ts +0 -253
  239. package/src/rules/oas3/__tests__/spec/paths.test.ts +0 -284
  240. package/src/rules/oas3/__tests__/spec/referenceableScalars.test.ts +0 -77
  241. package/src/rules/oas3/__tests__/spec/servers.test.ts +0 -505
  242. package/src/rules/oas3/__tests__/spec/spec.test.ts +0 -298
  243. package/src/rules/oas3/__tests__/spec/utils.ts +0 -32
  244. package/src/rules/oas3/__tests__/spec-components-invalid-map-name.test.ts +0 -305
  245. package/src/rules/oas3/boolean-parameter-prefixes.ts +0 -28
  246. package/src/rules/oas3/index.ts +0 -109
  247. package/src/rules/oas3/no-empty-servers.ts +0 -22
  248. package/src/rules/oas3/no-example-value-and-externalValue.ts +0 -14
  249. package/src/rules/oas3/no-invalid-media-type-examples.ts +0 -49
  250. package/src/rules/oas3/no-server-example.com.ts +0 -14
  251. package/src/rules/oas3/no-server-trailing-slash.ts +0 -15
  252. package/src/rules/oas3/no-server-variables-empty-enum.ts +0 -66
  253. package/src/rules/oas3/no-undefined-server-variable.ts +0 -30
  254. package/src/rules/oas3/no-unused-components.ts +0 -75
  255. package/src/rules/oas3/operation-4xx-problem-details-rfc7807.ts +0 -36
  256. package/src/rules/oas3/remove-unused-components.ts +0 -95
  257. package/src/rules/oas3/request-mime-type.ts +0 -31
  258. package/src/rules/oas3/response-contains-property.ts +0 -38
  259. package/src/rules/oas3/response-mime-type.ts +0 -31
  260. package/src/rules/oas3/spec-components-invalid-map-name.ts +0 -74
  261. package/src/rules/other/stats.ts +0 -73
  262. package/src/rules/utils.ts +0 -191
  263. package/src/types/index.ts +0 -149
  264. package/src/types/oas2.ts +0 -478
  265. package/src/types/oas3.ts +0 -597
  266. package/src/types/oas3_1.ts +0 -258
  267. package/src/types/redocly-yaml.ts +0 -1010
  268. package/src/typings/common.ts +0 -17
  269. package/src/typings/openapi.ts +0 -298
  270. package/src/typings/swagger.ts +0 -236
  271. package/src/utils.ts +0 -276
  272. package/src/visitors.ts +0 -491
  273. package/src/walk.ts +0 -453
  274. package/tsconfig.json +0 -8
  275. 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
- }