@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.
- package/README.md +25 -0
- package/__tests__/utils.ts +86 -0
- package/lib/benchmark/benches/lint-with-many-rules.bench.d.ts +3 -0
- package/lib/benchmark/benches/lint-with-many-rules.bench.js +34 -0
- package/lib/benchmark/benches/lint-with-nested-rule.bench.d.ts +3 -0
- package/lib/benchmark/benches/lint-with-nested-rule.bench.js +40 -0
- package/lib/benchmark/benches/lint-with-no-rules.bench.d.ts +3 -0
- package/lib/benchmark/benches/lint-with-no-rules.bench.js +21 -0
- package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.d.ts +3 -0
- package/lib/benchmark/benches/lint-with-top-level-rule-report.bench.js +34 -0
- package/lib/benchmark/benches/lint-with-top-level-rule.bench.d.ts +3 -0
- package/lib/benchmark/benches/lint-with-top-level-rule.bench.js +32 -0
- package/lib/benchmark/benches/recommended-oas3.bench.d.ts +3 -0
- package/lib/benchmark/benches/recommended-oas3.bench.js +21 -0
- package/lib/benchmark/benches/resolve-with-no-external.bench.d.ts +3 -0
- package/lib/benchmark/benches/resolve-with-no-external.bench.js +22 -0
- package/lib/benchmark/utils.d.ts +6 -0
- package/lib/benchmark/utils.js +31 -0
- package/lib/bundle.d.ts +47 -0
- package/lib/bundle.js +291 -0
- package/lib/config/all.d.ts +3 -0
- package/lib/config/all.js +65 -0
- package/lib/config/builtIn.d.ts +3 -0
- package/lib/config/builtIn.js +36 -0
- package/lib/config/config-resolvers.d.ts +16 -0
- package/lib/config/config-resolvers.js +242 -0
- package/lib/config/config.d.ts +64 -0
- package/lib/config/config.js +244 -0
- package/lib/config/index.d.ts +7 -0
- package/lib/config/index.js +19 -0
- package/lib/config/load.d.ts +6 -0
- package/lib/config/load.js +93 -0
- package/lib/config/minimal.d.ts +3 -0
- package/lib/config/minimal.js +58 -0
- package/lib/config/recommended.d.ts +3 -0
- package/lib/config/recommended.js +58 -0
- package/lib/config/rules.d.ts +7 -0
- package/lib/config/rules.js +34 -0
- package/lib/config/types.d.ts +113 -0
- package/lib/config/types.js +2 -0
- package/lib/config/utils.d.ts +13 -0
- package/lib/config/utils.js +160 -0
- package/lib/decorators/common/info-description-override.d.ts +2 -0
- package/lib/decorators/common/info-description-override.js +24 -0
- package/lib/decorators/common/operation-description-override.d.ts +2 -0
- package/lib/decorators/common/operation-description-override.js +29 -0
- package/lib/decorators/common/registry-dependencies.d.ts +2 -0
- package/lib/decorators/common/registry-dependencies.js +24 -0
- package/lib/decorators/common/remove-x-internal.d.ts +2 -0
- package/lib/decorators/common/remove-x-internal.js +58 -0
- package/lib/decorators/common/tag-description-override.d.ts +2 -0
- package/lib/decorators/common/tag-description-override.js +25 -0
- package/lib/decorators/oas2/index.d.ts +8 -0
- package/lib/decorators/oas2/index.js +15 -0
- package/lib/decorators/oas3/index.d.ts +8 -0
- package/lib/decorators/oas3/index.js +15 -0
- package/lib/format/codeframes.d.ts +22 -0
- package/lib/format/codeframes.js +177 -0
- package/lib/format/format.d.ts +20 -0
- package/lib/format/format.js +236 -0
- package/lib/index.d.ts +22 -0
- package/lib/index.js +69 -0
- package/lib/js-yaml/index.d.ts +3 -0
- package/lib/js-yaml/index.js +19 -0
- package/lib/lint.d.ts +23 -0
- package/lib/lint.js +99 -0
- package/lib/oas-types.d.ts +19 -0
- package/lib/oas-types.js +45 -0
- package/lib/redocly/index.d.ts +30 -0
- package/lib/redocly/index.js +153 -0
- package/lib/redocly/redocly-client-types.d.ts +8 -0
- package/lib/redocly/redocly-client-types.js +2 -0
- package/lib/redocly/registry-api-types.d.ts +29 -0
- package/lib/redocly/registry-api-types.js +2 -0
- package/lib/redocly/registry-api.d.ts +17 -0
- package/lib/redocly/registry-api.js +106 -0
- package/lib/ref-utils.d.ts +25 -0
- package/lib/ref-utils.js +75 -0
- package/lib/resolve.d.ts +66 -0
- package/lib/resolve.js +311 -0
- package/lib/rules/ajv.d.ts +10 -0
- package/lib/rules/ajv.js +80 -0
- package/lib/rules/common/assertions/asserts.d.ts +5 -0
- package/lib/rules/common/assertions/asserts.js +143 -0
- package/lib/rules/common/assertions/index.d.ts +2 -0
- package/lib/rules/common/assertions/index.js +52 -0
- package/lib/rules/common/assertions/utils.d.ts +20 -0
- package/lib/rules/common/assertions/utils.js +127 -0
- package/lib/rules/common/info-contact.d.ts +2 -0
- package/lib/rules/common/info-contact.js +17 -0
- package/lib/rules/common/info-description.d.ts +2 -0
- package/lib/rules/common/info-description.js +12 -0
- package/lib/rules/common/info-license-url.d.ts +2 -0
- package/lib/rules/common/info-license-url.js +17 -0
- package/lib/rules/common/license-url.d.ts +2 -0
- package/lib/rules/common/license-url.js +12 -0
- package/lib/rules/common/no-ambiguous-paths.d.ts +2 -0
- package/lib/rules/common/no-ambiguous-paths.js +45 -0
- package/lib/rules/common/no-enum-type-mismatch.d.ts +2 -0
- package/lib/rules/common/no-enum-type-mismatch.js +43 -0
- package/lib/rules/common/no-http-verbs-in-paths.d.ts +2 -0
- package/lib/rules/common/no-http-verbs-in-paths.js +33 -0
- package/lib/rules/common/no-identical-paths.d.ts +2 -0
- package/lib/rules/common/no-identical-paths.js +24 -0
- package/lib/rules/common/no-invalid-parameter-examples.d.ts +1 -0
- package/lib/rules/common/no-invalid-parameter-examples.js +25 -0
- package/lib/rules/common/no-invalid-schema-examples.d.ts +1 -0
- package/lib/rules/common/no-invalid-schema-examples.js +23 -0
- package/lib/rules/common/no-path-trailing-slash.d.ts +2 -0
- package/lib/rules/common/no-path-trailing-slash.js +16 -0
- package/lib/rules/common/operation-2xx-response.d.ts +2 -0
- package/lib/rules/common/operation-2xx-response.js +17 -0
- package/lib/rules/common/operation-4xx-response.d.ts +2 -0
- package/lib/rules/common/operation-4xx-response.js +17 -0
- package/lib/rules/common/operation-description.d.ts +2 -0
- package/lib/rules/common/operation-description.js +12 -0
- package/lib/rules/common/operation-operationId-unique.d.ts +2 -0
- package/lib/rules/common/operation-operationId-unique.js +20 -0
- package/lib/rules/common/operation-operationId-url-safe.d.ts +2 -0
- package/lib/rules/common/operation-operationId-url-safe.js +17 -0
- package/lib/rules/common/operation-operationId.d.ts +2 -0
- package/lib/rules/common/operation-operationId.js +16 -0
- package/lib/rules/common/operation-parameters-unique.d.ts +2 -0
- package/lib/rules/common/operation-parameters-unique.js +40 -0
- package/lib/rules/common/operation-security-defined.d.ts +2 -0
- package/lib/rules/common/operation-security-defined.js +38 -0
- package/lib/rules/common/operation-singular-tag.d.ts +2 -0
- package/lib/rules/common/operation-singular-tag.js +16 -0
- package/lib/rules/common/operation-summary.d.ts +2 -0
- package/lib/rules/common/operation-summary.js +12 -0
- package/lib/rules/common/operation-tag-defined.d.ts +2 -0
- package/lib/rules/common/operation-tag-defined.js +25 -0
- package/lib/rules/common/parameter-description.d.ts +2 -0
- package/lib/rules/common/parameter-description.js +22 -0
- package/lib/rules/common/path-declaration-must-exist.d.ts +2 -0
- package/lib/rules/common/path-declaration-must-exist.js +16 -0
- package/lib/rules/common/path-excludes-patterns.d.ts +2 -0
- package/lib/rules/common/path-excludes-patterns.js +22 -0
- package/lib/rules/common/path-http-verbs-order.d.ts +2 -0
- package/lib/rules/common/path-http-verbs-order.js +26 -0
- package/lib/rules/common/path-not-include-query.d.ts +2 -0
- package/lib/rules/common/path-not-include-query.js +18 -0
- package/lib/rules/common/path-params-defined.d.ts +2 -0
- package/lib/rules/common/path-params-defined.js +53 -0
- package/lib/rules/common/path-segment-plural.d.ts +2 -0
- package/lib/rules/common/path-segment-plural.js +32 -0
- package/lib/rules/common/paths-kebab-case.d.ts +2 -0
- package/lib/rules/common/paths-kebab-case.js +17 -0
- package/lib/rules/common/response-contains-header.d.ts +2 -0
- package/lib/rules/common/response-contains-header.js +29 -0
- package/lib/rules/common/scalar-property-missing-example.d.ts +2 -0
- package/lib/rules/common/scalar-property-missing-example.js +42 -0
- package/lib/rules/common/spec.d.ts +2 -0
- package/lib/rules/common/spec.js +136 -0
- package/lib/rules/common/tag-description.d.ts +2 -0
- package/lib/rules/common/tag-description.js +12 -0
- package/lib/rules/common/tags-alphabetical.d.ts +2 -0
- package/lib/rules/common/tags-alphabetical.js +20 -0
- package/lib/rules/no-unresolved-refs.d.ts +5 -0
- package/lib/rules/no-unresolved-refs.js +47 -0
- package/lib/rules/oas2/boolean-parameter-prefixes.d.ts +5 -0
- package/lib/rules/oas2/boolean-parameter-prefixes.js +22 -0
- package/lib/rules/oas2/index.d.ts +46 -0
- package/lib/rules/oas2/index.js +89 -0
- package/lib/rules/oas2/remove-unused-components.d.ts +2 -0
- package/lib/rules/oas2/remove-unused-components.js +73 -0
- package/lib/rules/oas2/request-mime-type.d.ts +2 -0
- package/lib/rules/oas2/request-mime-type.js +17 -0
- package/lib/rules/oas2/response-contains-property.d.ts +2 -0
- package/lib/rules/oas2/response-contains-property.js +38 -0
- package/lib/rules/oas2/response-mime-type.d.ts +2 -0
- package/lib/rules/oas2/response-mime-type.js +17 -0
- package/lib/rules/oas3/boolean-parameter-prefixes.d.ts +5 -0
- package/lib/rules/oas3/boolean-parameter-prefixes.js +24 -0
- package/lib/rules/oas3/index.d.ts +3 -0
- package/lib/rules/oas3/index.js +105 -0
- package/lib/rules/oas3/no-empty-servers.d.ts +2 -0
- package/lib/rules/oas3/no-empty-servers.js +23 -0
- package/lib/rules/oas3/no-example-value-and-externalValue.d.ts +2 -0
- package/lib/rules/oas3/no-example-value-and-externalValue.js +16 -0
- package/lib/rules/oas3/no-invalid-media-type-examples.d.ts +2 -0
- package/lib/rules/oas3/no-invalid-media-type-examples.js +37 -0
- package/lib/rules/oas3/no-server-example.com.d.ts +2 -0
- package/lib/rules/oas3/no-server-example.com.js +16 -0
- package/lib/rules/oas3/no-server-trailing-slash.d.ts +2 -0
- package/lib/rules/oas3/no-server-trailing-slash.js +18 -0
- package/lib/rules/oas3/no-servers-empty-enum.d.ts +2 -0
- package/lib/rules/oas3/no-servers-empty-enum.js +67 -0
- package/lib/rules/oas3/no-undefined-server-variable.d.ts +2 -0
- package/lib/rules/oas3/no-undefined-server-variable.js +32 -0
- package/lib/rules/oas3/no-unused-components.d.ts +2 -0
- package/lib/rules/oas3/no-unused-components.js +74 -0
- package/lib/rules/oas3/remove-unused-components.d.ts +2 -0
- package/lib/rules/oas3/remove-unused-components.js +83 -0
- package/lib/rules/oas3/request-mime-type.d.ts +2 -0
- package/lib/rules/oas3/request-mime-type.js +31 -0
- package/lib/rules/oas3/response-contains-property.d.ts +2 -0
- package/lib/rules/oas3/response-contains-property.js +40 -0
- package/lib/rules/oas3/response-mime-type.d.ts +2 -0
- package/lib/rules/oas3/response-mime-type.js +31 -0
- package/lib/rules/other/stats.d.ts +41 -0
- package/lib/rules/other/stats.js +44 -0
- package/lib/rules/utils.d.ts +17 -0
- package/lib/rules/utils.js +107 -0
- package/lib/types/index.d.ts +56 -0
- package/lib/types/index.js +77 -0
- package/lib/types/oas2.d.ts +2 -0
- package/lib/types/oas2.js +380 -0
- package/lib/types/oas3.d.ts +2 -0
- package/lib/types/oas3.js +479 -0
- package/lib/types/oas3_1.d.ts +2 -0
- package/lib/types/oas3_1.js +247 -0
- package/lib/types/redocly-yaml.d.ts +2 -0
- package/lib/types/redocly-yaml.js +533 -0
- package/lib/typings/common.d.ts +8 -0
- package/lib/typings/common.js +2 -0
- package/lib/typings/openapi.d.ts +299 -0
- package/lib/typings/openapi.js +2 -0
- package/lib/typings/swagger.d.ts +217 -0
- package/lib/typings/swagger.js +2 -0
- package/lib/utils.d.ts +41 -0
- package/lib/utils.js +177 -0
- package/lib/visitors.d.ts +175 -0
- package/lib/visitors.js +140 -0
- package/lib/walk.d.ts +87 -0
- package/lib/walk.js +253 -0
- package/package.json +56 -0
- package/src/__tests__/__snapshots__/bundle.test.ts.snap +255 -0
- package/src/__tests__/bundle.test.ts +156 -0
- package/src/__tests__/codeframes.test.ts +531 -0
- package/src/__tests__/fixtures/extension.js +24 -0
- package/src/__tests__/fixtures/refs/definitions.yaml +3 -0
- package/src/__tests__/fixtures/refs/examples.yaml +8 -0
- package/src/__tests__/fixtures/refs/external-request-body.yaml +13 -0
- package/src/__tests__/fixtures/refs/externalref.yaml +35 -0
- package/src/__tests__/fixtures/refs/hosted.yaml +35 -0
- package/src/__tests__/fixtures/refs/openapi-with-external-refs-conflicting-names.yaml +21 -0
- package/src/__tests__/fixtures/refs/openapi-with-external-refs.yaml +33 -0
- package/src/__tests__/fixtures/refs/openapi-with-url-refs.yaml +18 -0
- package/src/__tests__/fixtures/refs/param-b.yaml +1 -0
- package/src/__tests__/fixtures/refs/param-c.yaml +1 -0
- package/src/__tests__/fixtures/refs/rename.yaml +1 -0
- package/src/__tests__/fixtures/refs/requestBody.yaml +9 -0
- package/src/__tests__/fixtures/refs/schema-a.yaml +1 -0
- package/src/__tests__/fixtures/refs/simple.yaml +1 -0
- package/src/__tests__/fixtures/refs/vendor.schema.yaml +20 -0
- package/src/__tests__/fixtures/resolve/External.yaml +10 -0
- package/src/__tests__/fixtures/resolve/External2.yaml +4 -0
- package/src/__tests__/fixtures/resolve/description.md +3 -0
- package/src/__tests__/fixtures/resolve/externalInfo.yaml +4 -0
- package/src/__tests__/fixtures/resolve/externalLicense.yaml +1 -0
- package/src/__tests__/fixtures/resolve/openapi-with-back.yaml +13 -0
- package/src/__tests__/fixtures/resolve/openapi-with-md-description.yaml +5 -0
- package/src/__tests__/fixtures/resolve/openapi.yaml +28 -0
- package/src/__tests__/fixtures/resolve/schemas/type-a.yaml +10 -0
- package/src/__tests__/fixtures/resolve/schemas/type-b.yaml +6 -0
- package/src/__tests__/fixtures/resolve/transitive/a.yaml +1 -0
- package/src/__tests__/fixtures/resolve/transitive/components.yaml +5 -0
- package/src/__tests__/fixtures/resolve/transitive/schemas.yaml +3 -0
- package/src/__tests__/js-yaml.test.ts +71 -0
- package/src/__tests__/lint.test.ts +232 -0
- package/src/__tests__/login.test.ts +17 -0
- package/src/__tests__/normalizeVisitors.test.ts +151 -0
- package/src/__tests__/ref-utils.test.ts +120 -0
- package/src/__tests__/resolve-http.test.ts +77 -0
- package/src/__tests__/resolve.test.ts +405 -0
- package/src/__tests__/utils.test.ts +85 -0
- package/src/__tests__/walk.test.ts +1485 -0
- package/src/benchmark/benches/lint-with-many-rules.bench.ts +35 -0
- package/src/benchmark/benches/lint-with-nested-rule.bench.ts +39 -0
- package/src/benchmark/benches/lint-with-no-rules.bench.ts +20 -0
- package/src/benchmark/benches/lint-with-top-level-rule-report.bench.ts +36 -0
- package/src/benchmark/benches/lint-with-top-level-rule.bench.ts +32 -0
- package/src/benchmark/benches/rebilly.yaml +32267 -0
- package/src/benchmark/benches/recommended-oas3.bench.ts +22 -0
- package/src/benchmark/benches/resolve-with-no-external.bench.ts +23 -0
- package/src/benchmark/benchmark.js +307 -0
- package/src/benchmark/colors.js +29 -0
- package/src/benchmark/fork.js +83 -0
- package/src/benchmark/utils.ts +36 -0
- package/src/bundle.ts +386 -0
- package/src/config/__tests__/__snapshots__/config-resolvers.test.ts.snap +157 -0
- package/src/config/__tests__/config-resolvers.test.ts +429 -0
- package/src/config/__tests__/config.test.ts +244 -0
- package/src/config/__tests__/fixtures/plugin-config.yaml +3 -0
- package/src/config/__tests__/fixtures/plugin.js +56 -0
- package/src/config/__tests__/fixtures/resolve-config/api/nested-config.yaml +12 -0
- package/src/config/__tests__/fixtures/resolve-config/api/plugin.js +67 -0
- package/src/config/__tests__/fixtures/resolve-config/local-config-with-circular.yaml +8 -0
- package/src/config/__tests__/fixtures/resolve-config/local-config-with-file.yaml +19 -0
- package/src/config/__tests__/fixtures/resolve-config/local-config.yaml +10 -0
- package/src/config/__tests__/fixtures/resolve-config/plugin.js +66 -0
- package/src/config/__tests__/fixtures/resolve-remote-configs/nested-remote-config.yaml +4 -0
- package/src/config/__tests__/fixtures/resolve-remote-configs/remote-config.yaml +5 -0
- package/src/config/__tests__/load.test.ts +83 -0
- package/src/config/__tests__/resolve-plugins.test.ts +27 -0
- package/src/config/all.ts +66 -0
- package/src/config/builtIn.ts +37 -0
- package/src/config/config-resolvers.ts +359 -0
- package/src/config/config.ts +312 -0
- package/src/config/index.ts +7 -0
- package/src/config/load.ts +84 -0
- package/src/config/minimal.ts +58 -0
- package/src/config/recommended.ts +58 -0
- package/src/config/rules.ts +46 -0
- package/src/config/types.ts +168 -0
- package/src/config/utils.ts +208 -0
- package/src/decorators/__tests__/remove-x-internal.test.ts +316 -0
- package/src/decorators/common/info-description-override.ts +24 -0
- package/src/decorators/common/operation-description-override.ts +30 -0
- package/src/decorators/common/registry-dependencies.ts +25 -0
- package/src/decorators/common/remove-x-internal.ts +59 -0
- package/src/decorators/common/tag-description-override.ts +25 -0
- package/src/decorators/oas2/index.ts +14 -0
- package/src/decorators/oas3/index.ts +14 -0
- package/src/format/codeframes.ts +210 -0
- package/src/format/format.ts +339 -0
- package/src/index.ts +68 -0
- package/src/js-yaml/index.ts +18 -0
- package/src/lint.ts +125 -0
- package/src/oas-types.ts +62 -0
- package/src/redocly/__tests__/redocly-client.test.ts +140 -0
- package/src/redocly/index.ts +182 -0
- package/src/redocly/redocly-client-types.ts +10 -0
- package/src/redocly/registry-api-types.ts +32 -0
- package/src/redocly/registry-api.ts +134 -0
- package/src/ref-utils.ts +80 -0
- package/src/resolve.ts +378 -0
- package/src/rules/__tests__/fixtures/invalid-yaml.yaml +1 -0
- package/src/rules/__tests__/fixtures/ref.yaml +1 -0
- package/src/rules/__tests__/no-unresolved-refs.test.ts +168 -0
- package/src/rules/ajv.ts +103 -0
- package/src/rules/common/__tests__/info-description.test.ts +102 -0
- package/src/rules/common/__tests__/info-license.test.ts +62 -0
- package/src/rules/common/__tests__/license-url.test.ts +63 -0
- package/src/rules/common/__tests__/no-ambiguous-paths.test.ts +96 -0
- package/src/rules/common/__tests__/no-enum-type-mismatch.test.ts +209 -0
- package/src/rules/common/__tests__/no-identical-paths.test.ts +58 -0
- package/src/rules/common/__tests__/no-path-trailing-slash.test.ts +85 -0
- package/src/rules/common/__tests__/operation-2xx-response.test.ts +91 -0
- package/src/rules/common/__tests__/operation-4xx-response.test.ts +107 -0
- package/src/rules/common/__tests__/operation-operationId-unique.test.ts +76 -0
- package/src/rules/common/__tests__/operation-operationId-url-safe.test.ts +45 -0
- package/src/rules/common/__tests__/operation-parameters-unique.test.ts +167 -0
- package/src/rules/common/__tests__/operation-security-defined.test.ts +69 -0
- package/src/rules/common/__tests__/operation-singular-tag.test.ts +72 -0
- package/src/rules/common/__tests__/path-http-verbs-order.test.ts +95 -0
- package/src/rules/common/__tests__/path-not-include-query.test.ts +64 -0
- package/src/rules/common/__tests__/path-params-defined.test.ts +133 -0
- package/src/rules/common/__tests__/paths-kebab-case.test.ts +108 -0
- package/src/rules/common/__tests__/scalar-property-missing-example.test.ts +264 -0
- package/src/rules/common/__tests__/spec.test.ts +62 -0
- package/src/rules/common/__tests__/tag-description.test.ts +65 -0
- package/src/rules/common/__tests__/tags-alphabetical.test.ts +64 -0
- package/src/rules/common/assertions/__tests__/asserts.test.ts +231 -0
- package/src/rules/common/assertions/__tests__/index.test.ts +65 -0
- package/src/rules/common/assertions/__tests__/utils.test.ts +89 -0
- package/src/rules/common/assertions/asserts.ts +137 -0
- package/src/rules/common/assertions/index.ts +75 -0
- package/src/rules/common/assertions/utils.ts +167 -0
- package/src/rules/common/info-contact.ts +15 -0
- package/src/rules/common/info-description.ts +10 -0
- package/src/rules/common/info-license-url.ts +15 -0
- package/src/rules/common/license-url.ts +10 -0
- package/src/rules/common/no-ambiguous-paths.ts +50 -0
- package/src/rules/common/no-enum-type-mismatch.ts +49 -0
- package/src/rules/common/no-http-verbs-in-paths.ts +36 -0
- package/src/rules/common/no-identical-paths.ts +24 -0
- package/src/rules/common/no-invalid-parameter-examples.ts +36 -0
- package/src/rules/common/no-invalid-schema-examples.ts +27 -0
- package/src/rules/common/no-path-trailing-slash.ts +15 -0
- package/src/rules/common/operation-2xx-response.ts +16 -0
- package/src/rules/common/operation-4xx-response.ts +17 -0
- package/src/rules/common/operation-description.ts +13 -0
- package/src/rules/common/operation-operationId-unique.ts +21 -0
- package/src/rules/common/operation-operationId-url-safe.ts +19 -0
- package/src/rules/common/operation-operationId.ts +17 -0
- package/src/rules/common/operation-parameters-unique.ts +48 -0
- package/src/rules/common/operation-security-defined.ts +45 -0
- package/src/rules/common/operation-singular-tag.ts +17 -0
- package/src/rules/common/operation-summary.ts +13 -0
- package/src/rules/common/operation-tag-defined.ts +26 -0
- package/src/rules/common/parameter-description.ts +22 -0
- package/src/rules/common/path-declaration-must-exist.ts +15 -0
- package/src/rules/common/path-excludes-patterns.ts +23 -0
- package/src/rules/common/path-http-verbs-order.ts +30 -0
- package/src/rules/common/path-not-include-query.ts +17 -0
- package/src/rules/common/path-params-defined.ts +58 -0
- package/src/rules/common/path-segment-plural.ts +31 -0
- package/src/rules/common/paths-kebab-case.ts +16 -0
- package/src/rules/common/response-contains-header.ts +30 -0
- package/src/rules/common/scalar-property-missing-example.ts +58 -0
- package/src/rules/common/spec.ts +143 -0
- package/src/rules/common/tag-description.ts +10 -0
- package/src/rules/common/tags-alphabetical.ts +20 -0
- package/src/rules/no-unresolved-refs.ts +51 -0
- package/src/rules/oas2/__tests__/boolean-parameter-prefixes.test.ts +110 -0
- package/src/rules/oas2/__tests__/response-contains-header.test.ts +174 -0
- package/src/rules/oas2/__tests__/response-contains-property.test.ts +155 -0
- package/src/rules/oas2/__tests__/spec/fixtures/description.md +1 -0
- package/src/rules/oas2/__tests__/spec/info.test.ts +355 -0
- package/src/rules/oas2/__tests__/spec/operation.test.ts +123 -0
- package/src/rules/oas2/__tests__/spec/paths.test.ts +245 -0
- package/src/rules/oas2/__tests__/spec/referenceableScalars.test.ts +31 -0
- package/src/rules/oas2/__tests__/spec/utils.ts +32 -0
- package/src/rules/oas2/boolean-parameter-prefixes.ts +26 -0
- package/src/rules/oas2/index.ts +89 -0
- package/src/rules/oas2/remove-unused-components.ts +76 -0
- package/src/rules/oas2/request-mime-type.ts +17 -0
- package/src/rules/oas2/response-contains-property.ts +36 -0
- package/src/rules/oas2/response-mime-type.ts +17 -0
- package/src/rules/oas3/__tests__/boolean-parameter-prefixes.test.ts +111 -0
- package/src/rules/oas3/__tests__/fixtures/common.yaml +11 -0
- package/src/rules/oas3/__tests__/no-empty-enum-servers.com.test.ts +205 -0
- package/src/rules/oas3/__tests__/no-example-value-and-externalValue.test.ts +65 -0
- package/src/rules/oas3/__tests__/no-invalid-media-type-examples.test.ts +392 -0
- package/src/rules/oas3/__tests__/no-server-example.com.test.ts +60 -0
- package/src/rules/oas3/__tests__/no-server-trailing-slash.test.ts +79 -0
- package/src/rules/oas3/__tests__/no-unused-components.test.ts +131 -0
- package/src/rules/oas3/__tests__/response-contains-header.test.ts +273 -0
- package/src/rules/oas3/__tests__/response-contains-property.test.ts +403 -0
- package/src/rules/oas3/__tests__/spec/callbacks.test.ts +41 -0
- package/src/rules/oas3/__tests__/spec/fixtures/description.md +1 -0
- package/src/rules/oas3/__tests__/spec/info.test.ts +391 -0
- package/src/rules/oas3/__tests__/spec/operation.test.ts +253 -0
- package/src/rules/oas3/__tests__/spec/paths.test.ts +284 -0
- package/src/rules/oas3/__tests__/spec/referenceableScalars.test.ts +77 -0
- package/src/rules/oas3/__tests__/spec/servers.test.ts +499 -0
- package/src/rules/oas3/__tests__/spec/spec.test.ts +288 -0
- package/src/rules/oas3/__tests__/spec/utils.ts +32 -0
- package/src/rules/oas3/boolean-parameter-prefixes.ts +28 -0
- package/src/rules/oas3/index.ts +105 -0
- package/src/rules/oas3/no-empty-servers.ts +22 -0
- package/src/rules/oas3/no-example-value-and-externalValue.ts +14 -0
- package/src/rules/oas3/no-invalid-media-type-examples.ts +41 -0
- package/src/rules/oas3/no-server-example.com.ts +14 -0
- package/src/rules/oas3/no-server-trailing-slash.ts +15 -0
- package/src/rules/oas3/no-servers-empty-enum.ts +67 -0
- package/src/rules/oas3/no-undefined-server-variable.ts +30 -0
- package/src/rules/oas3/no-unused-components.ts +75 -0
- package/src/rules/oas3/remove-unused-components.ts +84 -0
- package/src/rules/oas3/request-mime-type.ts +31 -0
- package/src/rules/oas3/response-contains-property.ts +38 -0
- package/src/rules/oas3/response-mime-type.ts +31 -0
- package/src/rules/other/stats.ts +44 -0
- package/src/rules/utils.ts +123 -0
- package/src/types/index.ts +138 -0
- package/src/types/oas2.ts +397 -0
- package/src/types/oas3.ts +510 -0
- package/src/types/oas3_1.ts +253 -0
- package/src/types/redocly-yaml.ts +647 -0
- package/src/typings/common.ts +9 -0
- package/src/typings/openapi.ts +298 -0
- package/src/typings/swagger.ts +236 -0
- package/src/utils.ts +193 -0
- package/src/visitors.ts +448 -0
- package/src/walk.ts +416 -0
- package/tsconfig.json +8 -0
- 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 {};
|
package/lib/visitors.js
ADDED
|
@@ -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 {};
|