@nikovirtala/projen-constructs 0.2.1 → 0.2.2
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/.jsii +3 -2
- package/lib/components/typedoc.js +1 -1
- package/lib/components/vitest.js +1 -1
- package/lib/project-generator.js +1 -1
- package/lib/projects/awscdk-construct-library.generated.js +1 -1
- package/lib/projects/awscdk-typescript-app.generated.js +1 -1
- package/lib/projects/jsii.generated.js +1 -1
- package/lib/projects/typescript.generated.js +1 -1
- package/node_modules/@jsii/spec/LICENSE +202 -0
- package/node_modules/@jsii/spec/NOTICE +2 -0
- package/node_modules/@jsii/spec/README.md +13 -0
- package/node_modules/@jsii/spec/jest.config.mjs +9 -0
- package/node_modules/@jsii/spec/lib/assembly-utils.d.ts +59 -0
- package/node_modules/@jsii/spec/lib/assembly-utils.js +158 -0
- package/node_modules/@jsii/spec/lib/assembly.d.ts +920 -0
- package/node_modules/@jsii/spec/lib/assembly.js +203 -0
- package/node_modules/@jsii/spec/lib/configuration.d.ts +147 -0
- package/node_modules/@jsii/spec/lib/configuration.js +3 -0
- package/node_modules/@jsii/spec/lib/index.d.ts +7 -0
- package/node_modules/@jsii/spec/lib/index.js +23 -0
- package/node_modules/@jsii/spec/lib/name-tree.d.ts +60 -0
- package/node_modules/@jsii/spec/lib/name-tree.js +84 -0
- package/node_modules/@jsii/spec/lib/redirect.d.ts +33 -0
- package/node_modules/@jsii/spec/lib/redirect.js +46 -0
- package/node_modules/@jsii/spec/lib/validate-assembly.d.ts +4 -0
- package/node_modules/@jsii/spec/lib/validate-assembly.js +29 -0
- package/node_modules/@jsii/spec/package.json +41 -0
- package/node_modules/@jsii/spec/schema/assembly-redirect.schema.json +29 -0
- package/node_modules/@jsii/spec/schema/jsii-spec.schema.json +1110 -0
- package/node_modules/@mrgrain/jsii-struct-builder/LICENSE +202 -0
- package/node_modules/@mrgrain/jsii-struct-builder/README.md +387 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/builder/index.d.ts +1 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/builder/index.js +18 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/builder/struct.d.ts +144 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/builder/struct.js +163 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/index.d.ts +3 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/index.js +20 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/private/assembly.d.ts +2 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/private/assembly.js +76 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/private/index.d.ts +2 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/private/index.js +19 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/private/utils.d.ts +2 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/private/utils.js +14 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/projen/index.d.ts +2 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/projen/index.js +19 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/projen/projen-struct.d.ts +90 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/projen/projen-struct.js +112 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/projen/ts-interface.d.ts +15 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/projen/ts-interface.js +18 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/renderer/index.d.ts +1 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/renderer/index.js +18 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/renderer/typescript.d.ts +53 -0
- package/node_modules/@mrgrain/jsii-struct-builder/lib/renderer/typescript.js +194 -0
- package/node_modules/@mrgrain/jsii-struct-builder/package.json +116 -0
- package/node_modules/ajv/.runkit_example.js +23 -0
- package/node_modules/ajv/LICENSE +22 -0
- package/node_modules/ajv/README.md +207 -0
- package/node_modules/ajv/dist/2019.d.ts +19 -0
- package/node_modules/ajv/dist/2019.js +61 -0
- package/node_modules/ajv/dist/2019.js.map +1 -0
- package/node_modules/ajv/dist/2020.d.ts +19 -0
- package/node_modules/ajv/dist/2020.js +55 -0
- package/node_modules/ajv/dist/2020.js.map +1 -0
- package/node_modules/ajv/dist/ajv.d.ts +18 -0
- package/node_modules/ajv/dist/ajv.js +50 -0
- package/node_modules/ajv/dist/ajv.js.map +1 -0
- package/node_modules/ajv/dist/compile/codegen/code.d.ts +40 -0
- package/node_modules/ajv/dist/compile/codegen/code.js +156 -0
- package/node_modules/ajv/dist/compile/codegen/code.js.map +1 -0
- package/node_modules/ajv/dist/compile/codegen/index.d.ts +79 -0
- package/node_modules/ajv/dist/compile/codegen/index.js +697 -0
- package/node_modules/ajv/dist/compile/codegen/index.js.map +1 -0
- package/node_modules/ajv/dist/compile/codegen/scope.d.ts +79 -0
- package/node_modules/ajv/dist/compile/codegen/scope.js +143 -0
- package/node_modules/ajv/dist/compile/codegen/scope.js.map +1 -0
- package/node_modules/ajv/dist/compile/errors.d.ts +13 -0
- package/node_modules/ajv/dist/compile/errors.js +123 -0
- package/node_modules/ajv/dist/compile/errors.js.map +1 -0
- package/node_modules/ajv/dist/compile/index.d.ts +80 -0
- package/node_modules/ajv/dist/compile/index.js +242 -0
- package/node_modules/ajv/dist/compile/index.js.map +1 -0
- package/node_modules/ajv/dist/compile/jtd/parse.d.ts +4 -0
- package/node_modules/ajv/dist/compile/jtd/parse.js +350 -0
- package/node_modules/ajv/dist/compile/jtd/parse.js.map +1 -0
- package/node_modules/ajv/dist/compile/jtd/serialize.d.ts +4 -0
- package/node_modules/ajv/dist/compile/jtd/serialize.js +229 -0
- package/node_modules/ajv/dist/compile/jtd/serialize.js.map +1 -0
- package/node_modules/ajv/dist/compile/jtd/types.d.ts +6 -0
- package/node_modules/ajv/dist/compile/jtd/types.js +14 -0
- package/node_modules/ajv/dist/compile/jtd/types.js.map +1 -0
- package/node_modules/ajv/dist/compile/names.d.ts +20 -0
- package/node_modules/ajv/dist/compile/names.js +28 -0
- package/node_modules/ajv/dist/compile/names.js.map +1 -0
- package/node_modules/ajv/dist/compile/ref_error.d.ts +6 -0
- package/node_modules/ajv/dist/compile/ref_error.js +12 -0
- package/node_modules/ajv/dist/compile/ref_error.js.map +1 -0
- package/node_modules/ajv/dist/compile/resolve.d.ts +12 -0
- package/node_modules/ajv/dist/compile/resolve.js +155 -0
- package/node_modules/ajv/dist/compile/resolve.js.map +1 -0
- package/node_modules/ajv/dist/compile/rules.d.ts +28 -0
- package/node_modules/ajv/dist/compile/rules.js +26 -0
- package/node_modules/ajv/dist/compile/rules.js.map +1 -0
- package/node_modules/ajv/dist/compile/util.d.ts +40 -0
- package/node_modules/ajv/dist/compile/util.js +178 -0
- package/node_modules/ajv/dist/compile/util.js.map +1 -0
- package/node_modules/ajv/dist/compile/validate/applicability.d.ts +6 -0
- package/node_modules/ajv/dist/compile/validate/applicability.js +19 -0
- package/node_modules/ajv/dist/compile/validate/applicability.js.map +1 -0
- package/node_modules/ajv/dist/compile/validate/boolSchema.d.ts +4 -0
- package/node_modules/ajv/dist/compile/validate/boolSchema.js +50 -0
- package/node_modules/ajv/dist/compile/validate/boolSchema.js.map +1 -0
- package/node_modules/ajv/dist/compile/validate/dataType.d.ts +17 -0
- package/node_modules/ajv/dist/compile/validate/dataType.js +203 -0
- package/node_modules/ajv/dist/compile/validate/dataType.js.map +1 -0
- package/node_modules/ajv/dist/compile/validate/defaults.d.ts +2 -0
- package/node_modules/ajv/dist/compile/validate/defaults.js +35 -0
- package/node_modules/ajv/dist/compile/validate/defaults.js.map +1 -0
- package/node_modules/ajv/dist/compile/validate/index.d.ts +42 -0
- package/node_modules/ajv/dist/compile/validate/index.js +520 -0
- package/node_modules/ajv/dist/compile/validate/index.js.map +1 -0
- package/node_modules/ajv/dist/compile/validate/keyword.d.ts +8 -0
- package/node_modules/ajv/dist/compile/validate/keyword.js +124 -0
- package/node_modules/ajv/dist/compile/validate/keyword.js.map +1 -0
- package/node_modules/ajv/dist/compile/validate/subschema.d.ts +47 -0
- package/node_modules/ajv/dist/compile/validate/subschema.js +81 -0
- package/node_modules/ajv/dist/compile/validate/subschema.js.map +1 -0
- package/node_modules/ajv/dist/core.d.ts +173 -0
- package/node_modules/ajv/dist/core.js +618 -0
- package/node_modules/ajv/dist/core.js.map +1 -0
- package/node_modules/ajv/dist/jtd.d.ts +47 -0
- package/node_modules/ajv/dist/jtd.js +72 -0
- package/node_modules/ajv/dist/jtd.js.map +1 -0
- package/node_modules/ajv/dist/refs/data.json +13 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/index.d.ts +2 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/index.js +28 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/index.js.map +1 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/meta/applicator.json +53 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/meta/content.json +17 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/meta/core.json +57 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/meta/format.json +14 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/meta/meta-data.json +37 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/meta/validation.json +90 -0
- package/node_modules/ajv/dist/refs/json-schema-2019-09/schema.json +39 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/index.d.ts +2 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/index.js +30 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/index.js.map +1 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/meta/applicator.json +48 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/meta/content.json +17 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/meta/core.json +51 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/meta/format-annotation.json +14 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/meta/meta-data.json +37 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/meta/unevaluated.json +15 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/meta/validation.json +90 -0
- package/node_modules/ajv/dist/refs/json-schema-2020-12/schema.json +55 -0
- package/node_modules/ajv/dist/refs/json-schema-draft-06.json +137 -0
- package/node_modules/ajv/dist/refs/json-schema-draft-07.json +151 -0
- package/node_modules/ajv/dist/refs/json-schema-secure.json +88 -0
- package/node_modules/ajv/dist/refs/jtd-schema.d.ts +3 -0
- package/node_modules/ajv/dist/refs/jtd-schema.js +118 -0
- package/node_modules/ajv/dist/refs/jtd-schema.js.map +1 -0
- package/node_modules/ajv/dist/runtime/equal.d.ts +6 -0
- package/node_modules/ajv/dist/runtime/equal.js +7 -0
- package/node_modules/ajv/dist/runtime/equal.js.map +1 -0
- package/node_modules/ajv/dist/runtime/parseJson.d.ts +18 -0
- package/node_modules/ajv/dist/runtime/parseJson.js +185 -0
- package/node_modules/ajv/dist/runtime/parseJson.js.map +1 -0
- package/node_modules/ajv/dist/runtime/quote.d.ts +5 -0
- package/node_modules/ajv/dist/runtime/quote.js +30 -0
- package/node_modules/ajv/dist/runtime/quote.js.map +1 -0
- package/node_modules/ajv/dist/runtime/re2.d.ts +6 -0
- package/node_modules/ajv/dist/runtime/re2.js +6 -0
- package/node_modules/ajv/dist/runtime/re2.js.map +1 -0
- package/node_modules/ajv/dist/runtime/timestamp.d.ts +5 -0
- package/node_modules/ajv/dist/runtime/timestamp.js +42 -0
- package/node_modules/ajv/dist/runtime/timestamp.js.map +1 -0
- package/node_modules/ajv/dist/runtime/ucs2length.d.ts +5 -0
- package/node_modules/ajv/dist/runtime/ucs2length.js +24 -0
- package/node_modules/ajv/dist/runtime/ucs2length.js.map +1 -0
- package/node_modules/ajv/dist/runtime/uri.d.ts +6 -0
- package/node_modules/ajv/dist/runtime/uri.js +6 -0
- package/node_modules/ajv/dist/runtime/uri.js.map +1 -0
- package/node_modules/ajv/dist/runtime/validation_error.d.ts +7 -0
- package/node_modules/ajv/dist/runtime/validation_error.js +11 -0
- package/node_modules/ajv/dist/runtime/validation_error.js.map +1 -0
- package/node_modules/ajv/dist/standalone/index.d.ts +6 -0
- package/node_modules/ajv/dist/standalone/index.js +90 -0
- package/node_modules/ajv/dist/standalone/index.js.map +1 -0
- package/node_modules/ajv/dist/standalone/instance.d.ts +12 -0
- package/node_modules/ajv/dist/standalone/instance.js +35 -0
- package/node_modules/ajv/dist/standalone/instance.js.map +1 -0
- package/node_modules/ajv/dist/types/index.d.ts +183 -0
- package/node_modules/ajv/dist/types/index.js +3 -0
- package/node_modules/ajv/dist/types/index.js.map +1 -0
- package/node_modules/ajv/dist/types/json-schema.d.ts +125 -0
- package/node_modules/ajv/dist/types/json-schema.js +3 -0
- package/node_modules/ajv/dist/types/json-schema.js.map +1 -0
- package/node_modules/ajv/dist/types/jtd-schema.d.ts +174 -0
- package/node_modules/ajv/dist/types/jtd-schema.js +3 -0
- package/node_modules/ajv/dist/types/jtd-schema.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/additionalItems.d.ts +8 -0
- package/node_modules/ajv/dist/vocabularies/applicator/additionalItems.js +49 -0
- package/node_modules/ajv/dist/vocabularies/applicator/additionalItems.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/additionalProperties.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/applicator/additionalProperties.js +106 -0
- package/node_modules/ajv/dist/vocabularies/applicator/additionalProperties.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/allOf.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/applicator/allOf.js +23 -0
- package/node_modules/ajv/dist/vocabularies/applicator/allOf.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/anyOf.d.ts +4 -0
- package/node_modules/ajv/dist/vocabularies/applicator/anyOf.js +12 -0
- package/node_modules/ajv/dist/vocabularies/applicator/anyOf.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/contains.d.ts +7 -0
- package/node_modules/ajv/dist/vocabularies/applicator/contains.js +95 -0
- package/node_modules/ajv/dist/vocabularies/applicator/contains.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/dependencies.d.ts +21 -0
- package/node_modules/ajv/dist/vocabularies/applicator/dependencies.js +85 -0
- package/node_modules/ajv/dist/vocabularies/applicator/dependencies.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/dependentSchemas.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/applicator/dependentSchemas.js +11 -0
- package/node_modules/ajv/dist/vocabularies/applicator/dependentSchemas.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/if.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/applicator/if.js +66 -0
- package/node_modules/ajv/dist/vocabularies/applicator/if.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/index.d.ts +13 -0
- package/node_modules/ajv/dist/vocabularies/applicator/index.js +44 -0
- package/node_modules/ajv/dist/vocabularies/applicator/index.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/items.d.ts +5 -0
- package/node_modules/ajv/dist/vocabularies/applicator/items.js +52 -0
- package/node_modules/ajv/dist/vocabularies/applicator/items.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/items2020.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/applicator/items2020.js +30 -0
- package/node_modules/ajv/dist/vocabularies/applicator/items2020.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/not.d.ts +4 -0
- package/node_modules/ajv/dist/vocabularies/applicator/not.js +26 -0
- package/node_modules/ajv/dist/vocabularies/applicator/not.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/oneOf.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/applicator/oneOf.js +60 -0
- package/node_modules/ajv/dist/vocabularies/applicator/oneOf.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/patternProperties.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/applicator/patternProperties.js +75 -0
- package/node_modules/ajv/dist/vocabularies/applicator/patternProperties.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/prefixItems.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/applicator/prefixItems.js +12 -0
- package/node_modules/ajv/dist/vocabularies/applicator/prefixItems.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/properties.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/applicator/properties.js +54 -0
- package/node_modules/ajv/dist/vocabularies/applicator/properties.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/propertyNames.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/applicator/propertyNames.js +38 -0
- package/node_modules/ajv/dist/vocabularies/applicator/propertyNames.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/applicator/thenElse.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/applicator/thenElse.js +13 -0
- package/node_modules/ajv/dist/vocabularies/applicator/thenElse.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/code.d.ts +17 -0
- package/node_modules/ajv/dist/vocabularies/code.js +131 -0
- package/node_modules/ajv/dist/vocabularies/code.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/core/id.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/core/id.js +10 -0
- package/node_modules/ajv/dist/vocabularies/core/id.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/core/index.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/core/index.js +16 -0
- package/node_modules/ajv/dist/vocabularies/core/index.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/core/ref.d.ts +8 -0
- package/node_modules/ajv/dist/vocabularies/core/ref.js +122 -0
- package/node_modules/ajv/dist/vocabularies/core/ref.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/discriminator/index.d.ts +5 -0
- package/node_modules/ajv/dist/vocabularies/discriminator/index.js +104 -0
- package/node_modules/ajv/dist/vocabularies/discriminator/index.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/discriminator/types.d.ts +10 -0
- package/node_modules/ajv/dist/vocabularies/discriminator/types.js +9 -0
- package/node_modules/ajv/dist/vocabularies/discriminator/types.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/draft2020.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/draft2020.js +23 -0
- package/node_modules/ajv/dist/vocabularies/draft2020.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/draft7.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/draft7.js +17 -0
- package/node_modules/ajv/dist/vocabularies/draft7.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/dynamicAnchor.d.ts +5 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/dynamicAnchor.js +30 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/dynamicAnchor.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/dynamicRef.d.ts +5 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/dynamicRef.js +51 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/dynamicRef.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/index.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/index.js +9 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/index.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/recursiveAnchor.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/recursiveAnchor.js +16 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/recursiveAnchor.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/recursiveRef.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/recursiveRef.js +10 -0
- package/node_modules/ajv/dist/vocabularies/dynamic/recursiveRef.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/errors.d.ts +9 -0
- package/node_modules/ajv/dist/vocabularies/errors.js +3 -0
- package/node_modules/ajv/dist/vocabularies/errors.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/format/format.d.ts +8 -0
- package/node_modules/ajv/dist/vocabularies/format/format.js +92 -0
- package/node_modules/ajv/dist/vocabularies/format/format.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/format/index.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/format/index.js +6 -0
- package/node_modules/ajv/dist/vocabularies/format/index.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/discriminator.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/jtd/discriminator.js +71 -0
- package/node_modules/ajv/dist/vocabularies/jtd/discriminator.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/elements.d.ts +5 -0
- package/node_modules/ajv/dist/vocabularies/jtd/elements.js +24 -0
- package/node_modules/ajv/dist/vocabularies/jtd/elements.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/enum.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/jtd/enum.js +43 -0
- package/node_modules/ajv/dist/vocabularies/jtd/enum.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/error.d.ts +9 -0
- package/node_modules/ajv/dist/vocabularies/jtd/error.js +20 -0
- package/node_modules/ajv/dist/vocabularies/jtd/error.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/index.d.ts +10 -0
- package/node_modules/ajv/dist/vocabularies/jtd/index.js +29 -0
- package/node_modules/ajv/dist/vocabularies/jtd/index.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/metadata.d.ts +5 -0
- package/node_modules/ajv/dist/vocabularies/jtd/metadata.js +25 -0
- package/node_modules/ajv/dist/vocabularies/jtd/metadata.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/nullable.d.ts +4 -0
- package/node_modules/ajv/dist/vocabularies/jtd/nullable.js +22 -0
- package/node_modules/ajv/dist/vocabularies/jtd/nullable.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/optionalProperties.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/jtd/optionalProperties.js +15 -0
- package/node_modules/ajv/dist/vocabularies/jtd/optionalProperties.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/properties.d.ts +22 -0
- package/node_modules/ajv/dist/vocabularies/jtd/properties.js +149 -0
- package/node_modules/ajv/dist/vocabularies/jtd/properties.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/ref.d.ts +4 -0
- package/node_modules/ajv/dist/vocabularies/jtd/ref.js +67 -0
- package/node_modules/ajv/dist/vocabularies/jtd/ref.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/type.d.ts +10 -0
- package/node_modules/ajv/dist/vocabularies/jtd/type.js +69 -0
- package/node_modules/ajv/dist/vocabularies/jtd/type.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/union.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/jtd/union.js +12 -0
- package/node_modules/ajv/dist/vocabularies/jtd/union.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/jtd/values.d.ts +5 -0
- package/node_modules/ajv/dist/vocabularies/jtd/values.js +51 -0
- package/node_modules/ajv/dist/vocabularies/jtd/values.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/metadata.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/metadata.js +18 -0
- package/node_modules/ajv/dist/vocabularies/metadata.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/next.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/next.js +8 -0
- package/node_modules/ajv/dist/vocabularies/next.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/unevaluated/index.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/unevaluated/index.js +7 -0
- package/node_modules/ajv/dist/vocabularies/unevaluated/index.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/unevaluated/unevaluatedItems.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/unevaluated/unevaluatedItems.js +40 -0
- package/node_modules/ajv/dist/vocabularies/unevaluated/unevaluatedItems.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/unevaluated/unevaluatedProperties.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/unevaluated/unevaluatedProperties.js +65 -0
- package/node_modules/ajv/dist/vocabularies/unevaluated/unevaluatedProperties.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/const.d.ts +6 -0
- package/node_modules/ajv/dist/vocabularies/validation/const.js +25 -0
- package/node_modules/ajv/dist/vocabularies/validation/const.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/dependentRequired.d.ts +5 -0
- package/node_modules/ajv/dist/vocabularies/validation/dependentRequired.js +12 -0
- package/node_modules/ajv/dist/vocabularies/validation/dependentRequired.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/enum.d.ts +8 -0
- package/node_modules/ajv/dist/vocabularies/validation/enum.js +48 -0
- package/node_modules/ajv/dist/vocabularies/validation/enum.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/index.d.ts +16 -0
- package/node_modules/ajv/dist/vocabularies/validation/index.js +33 -0
- package/node_modules/ajv/dist/vocabularies/validation/index.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitContains.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitContains.js +15 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitContains.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitItems.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitItems.js +24 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitItems.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitLength.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitLength.js +27 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitLength.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitNumber.d.ts +11 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitNumber.js +27 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitNumber.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitProperties.d.ts +3 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitProperties.js +24 -0
- package/node_modules/ajv/dist/vocabularies/validation/limitProperties.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/multipleOf.d.ts +8 -0
- package/node_modules/ajv/dist/vocabularies/validation/multipleOf.js +26 -0
- package/node_modules/ajv/dist/vocabularies/validation/multipleOf.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/pattern.d.ts +8 -0
- package/node_modules/ajv/dist/vocabularies/validation/pattern.js +24 -0
- package/node_modules/ajv/dist/vocabularies/validation/pattern.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/required.d.ts +8 -0
- package/node_modules/ajv/dist/vocabularies/validation/required.js +79 -0
- package/node_modules/ajv/dist/vocabularies/validation/required.js.map +1 -0
- package/node_modules/ajv/dist/vocabularies/validation/uniqueItems.d.ts +9 -0
- package/node_modules/ajv/dist/vocabularies/validation/uniqueItems.js +64 -0
- package/node_modules/ajv/dist/vocabularies/validation/uniqueItems.js.map +1 -0
- package/node_modules/ajv/lib/2019.ts +81 -0
- package/node_modules/ajv/lib/2020.ts +75 -0
- package/node_modules/ajv/lib/ajv.ts +70 -0
- package/node_modules/ajv/lib/compile/codegen/code.ts +169 -0
- package/node_modules/ajv/lib/compile/codegen/index.ts +852 -0
- package/node_modules/ajv/lib/compile/codegen/scope.ts +215 -0
- package/node_modules/ajv/lib/compile/errors.ts +184 -0
- package/node_modules/ajv/lib/compile/index.ts +324 -0
- package/node_modules/ajv/lib/compile/jtd/parse.ts +411 -0
- package/node_modules/ajv/lib/compile/jtd/serialize.ts +266 -0
- package/node_modules/ajv/lib/compile/jtd/types.ts +16 -0
- package/node_modules/ajv/lib/compile/names.ts +27 -0
- package/node_modules/ajv/lib/compile/ref_error.ts +13 -0
- package/node_modules/ajv/lib/compile/resolve.ts +149 -0
- package/node_modules/ajv/lib/compile/rules.ts +50 -0
- package/node_modules/ajv/lib/compile/util.ts +213 -0
- package/node_modules/ajv/lib/compile/validate/applicability.ts +22 -0
- package/node_modules/ajv/lib/compile/validate/boolSchema.ts +47 -0
- package/node_modules/ajv/lib/compile/validate/dataType.ts +230 -0
- package/node_modules/ajv/lib/compile/validate/defaults.ts +32 -0
- package/node_modules/ajv/lib/compile/validate/index.ts +582 -0
- package/node_modules/ajv/lib/compile/validate/keyword.ts +171 -0
- package/node_modules/ajv/lib/compile/validate/subschema.ts +135 -0
- package/node_modules/ajv/lib/core.ts +891 -0
- package/node_modules/ajv/lib/jtd.ts +132 -0
- package/node_modules/ajv/lib/refs/data.json +13 -0
- package/node_modules/ajv/lib/refs/json-schema-2019-09/index.ts +28 -0
- package/node_modules/ajv/lib/refs/json-schema-2019-09/meta/applicator.json +53 -0
- package/node_modules/ajv/lib/refs/json-schema-2019-09/meta/content.json +17 -0
- package/node_modules/ajv/lib/refs/json-schema-2019-09/meta/core.json +57 -0
- package/node_modules/ajv/lib/refs/json-schema-2019-09/meta/format.json +14 -0
- package/node_modules/ajv/lib/refs/json-schema-2019-09/meta/meta-data.json +37 -0
- package/node_modules/ajv/lib/refs/json-schema-2019-09/meta/validation.json +90 -0
- package/node_modules/ajv/lib/refs/json-schema-2019-09/schema.json +39 -0
- package/node_modules/ajv/lib/refs/json-schema-2020-12/index.ts +30 -0
- package/node_modules/ajv/lib/refs/json-schema-2020-12/meta/applicator.json +48 -0
- package/node_modules/ajv/lib/refs/json-schema-2020-12/meta/content.json +17 -0
- package/node_modules/ajv/lib/refs/json-schema-2020-12/meta/core.json +51 -0
- package/node_modules/ajv/lib/refs/json-schema-2020-12/meta/format-annotation.json +14 -0
- package/node_modules/ajv/lib/refs/json-schema-2020-12/meta/meta-data.json +37 -0
- package/node_modules/ajv/lib/refs/json-schema-2020-12/meta/unevaluated.json +15 -0
- package/node_modules/ajv/lib/refs/json-schema-2020-12/meta/validation.json +90 -0
- package/node_modules/ajv/lib/refs/json-schema-2020-12/schema.json +55 -0
- package/node_modules/ajv/lib/refs/json-schema-draft-06.json +137 -0
- package/node_modules/ajv/lib/refs/json-schema-draft-07.json +151 -0
- package/node_modules/ajv/lib/refs/json-schema-secure.json +88 -0
- package/node_modules/ajv/lib/refs/jtd-schema.ts +130 -0
- package/node_modules/ajv/lib/runtime/equal.ts +7 -0
- package/node_modules/ajv/lib/runtime/parseJson.ts +177 -0
- package/node_modules/ajv/lib/runtime/quote.ts +31 -0
- package/node_modules/ajv/lib/runtime/re2.ts +6 -0
- package/node_modules/ajv/lib/runtime/timestamp.ts +46 -0
- package/node_modules/ajv/lib/runtime/ucs2length.ts +20 -0
- package/node_modules/ajv/lib/runtime/uri.ts +6 -0
- package/node_modules/ajv/lib/runtime/validation_error.ts +13 -0
- package/node_modules/ajv/lib/standalone/index.ts +100 -0
- package/node_modules/ajv/lib/standalone/instance.ts +36 -0
- package/node_modules/ajv/lib/types/index.ts +244 -0
- package/node_modules/ajv/lib/types/json-schema.ts +187 -0
- package/node_modules/ajv/lib/types/jtd-schema.ts +273 -0
- package/node_modules/ajv/lib/vocabularies/applicator/additionalItems.ts +56 -0
- package/node_modules/ajv/lib/vocabularies/applicator/additionalProperties.ts +118 -0
- package/node_modules/ajv/lib/vocabularies/applicator/allOf.ts +22 -0
- package/node_modules/ajv/lib/vocabularies/applicator/anyOf.ts +14 -0
- package/node_modules/ajv/lib/vocabularies/applicator/contains.ts +109 -0
- package/node_modules/ajv/lib/vocabularies/applicator/dependencies.ts +112 -0
- package/node_modules/ajv/lib/vocabularies/applicator/dependentSchemas.ts +11 -0
- package/node_modules/ajv/lib/vocabularies/applicator/if.ts +80 -0
- package/node_modules/ajv/lib/vocabularies/applicator/index.ts +53 -0
- package/node_modules/ajv/lib/vocabularies/applicator/items.ts +59 -0
- package/node_modules/ajv/lib/vocabularies/applicator/items2020.ts +36 -0
- package/node_modules/ajv/lib/vocabularies/applicator/not.ts +38 -0
- package/node_modules/ajv/lib/vocabularies/applicator/oneOf.ts +82 -0
- package/node_modules/ajv/lib/vocabularies/applicator/patternProperties.ts +91 -0
- package/node_modules/ajv/lib/vocabularies/applicator/prefixItems.ts +12 -0
- package/node_modules/ajv/lib/vocabularies/applicator/properties.ts +57 -0
- package/node_modules/ajv/lib/vocabularies/applicator/propertyNames.ts +50 -0
- package/node_modules/ajv/lib/vocabularies/applicator/thenElse.ts +13 -0
- package/node_modules/ajv/lib/vocabularies/code.ts +168 -0
- package/node_modules/ajv/lib/vocabularies/core/id.ts +10 -0
- package/node_modules/ajv/lib/vocabularies/core/index.ts +16 -0
- package/node_modules/ajv/lib/vocabularies/core/ref.ts +129 -0
- package/node_modules/ajv/lib/vocabularies/discriminator/index.ts +113 -0
- package/node_modules/ajv/lib/vocabularies/discriminator/types.ts +12 -0
- package/node_modules/ajv/lib/vocabularies/draft2020.ts +23 -0
- package/node_modules/ajv/lib/vocabularies/draft7.ts +17 -0
- package/node_modules/ajv/lib/vocabularies/dynamic/dynamicAnchor.ts +31 -0
- package/node_modules/ajv/lib/vocabularies/dynamic/dynamicRef.ts +51 -0
- package/node_modules/ajv/lib/vocabularies/dynamic/index.ts +9 -0
- package/node_modules/ajv/lib/vocabularies/dynamic/recursiveAnchor.ts +14 -0
- package/node_modules/ajv/lib/vocabularies/dynamic/recursiveRef.ts +10 -0
- package/node_modules/ajv/lib/vocabularies/errors.ts +18 -0
- package/node_modules/ajv/lib/vocabularies/format/format.ts +120 -0
- package/node_modules/ajv/lib/vocabularies/format/index.ts +6 -0
- package/node_modules/ajv/lib/vocabularies/jtd/discriminator.ts +89 -0
- package/node_modules/ajv/lib/vocabularies/jtd/elements.ts +32 -0
- package/node_modules/ajv/lib/vocabularies/jtd/enum.ts +45 -0
- package/node_modules/ajv/lib/vocabularies/jtd/error.ts +23 -0
- package/node_modules/ajv/lib/vocabularies/jtd/index.ts +37 -0
- package/node_modules/ajv/lib/vocabularies/jtd/metadata.ts +24 -0
- package/node_modules/ajv/lib/vocabularies/jtd/nullable.ts +21 -0
- package/node_modules/ajv/lib/vocabularies/jtd/optionalProperties.ts +15 -0
- package/node_modules/ajv/lib/vocabularies/jtd/properties.ts +184 -0
- package/node_modules/ajv/lib/vocabularies/jtd/ref.ts +76 -0
- package/node_modules/ajv/lib/vocabularies/jtd/type.ts +75 -0
- package/node_modules/ajv/lib/vocabularies/jtd/union.ts +12 -0
- package/node_modules/ajv/lib/vocabularies/jtd/values.ts +58 -0
- package/node_modules/ajv/lib/vocabularies/metadata.ts +17 -0
- package/node_modules/ajv/lib/vocabularies/next.ts +8 -0
- package/node_modules/ajv/lib/vocabularies/unevaluated/index.ts +7 -0
- package/node_modules/ajv/lib/vocabularies/unevaluated/unevaluatedItems.ts +47 -0
- package/node_modules/ajv/lib/vocabularies/unevaluated/unevaluatedProperties.ts +85 -0
- package/node_modules/ajv/lib/vocabularies/validation/const.ts +28 -0
- package/node_modules/ajv/lib/vocabularies/validation/dependentRequired.ts +23 -0
- package/node_modules/ajv/lib/vocabularies/validation/enum.ts +54 -0
- package/node_modules/ajv/lib/vocabularies/validation/index.ts +49 -0
- package/node_modules/ajv/lib/vocabularies/validation/limitContains.ts +16 -0
- package/node_modules/ajv/lib/vocabularies/validation/limitItems.ts +26 -0
- package/node_modules/ajv/lib/vocabularies/validation/limitLength.ts +30 -0
- package/node_modules/ajv/lib/vocabularies/validation/limitNumber.ts +42 -0
- package/node_modules/ajv/lib/vocabularies/validation/limitProperties.ts +26 -0
- package/node_modules/ajv/lib/vocabularies/validation/multipleOf.ts +34 -0
- package/node_modules/ajv/lib/vocabularies/validation/pattern.ts +28 -0
- package/node_modules/ajv/lib/vocabularies/validation/required.ts +98 -0
- package/node_modules/ajv/lib/vocabularies/validation/uniqueItems.ts +79 -0
- package/node_modules/ajv/package.json +126 -0
- package/node_modules/fast-deep-equal/LICENSE +21 -0
- package/node_modules/fast-deep-equal/README.md +96 -0
- package/node_modules/fast-deep-equal/es6/index.d.ts +2 -0
- package/node_modules/fast-deep-equal/es6/index.js +72 -0
- package/node_modules/fast-deep-equal/es6/react.d.ts +2 -0
- package/node_modules/fast-deep-equal/es6/react.js +79 -0
- package/node_modules/fast-deep-equal/index.d.ts +4 -0
- package/node_modules/fast-deep-equal/index.js +46 -0
- package/node_modules/fast-deep-equal/package.json +61 -0
- package/node_modules/fast-deep-equal/react.d.ts +2 -0
- package/node_modules/fast-deep-equal/react.js +53 -0
- package/node_modules/fast-uri/.gitattributes +2 -0
- package/node_modules/fast-uri/.github/.stale.yml +21 -0
- package/node_modules/fast-uri/.github/dependabot.yml +13 -0
- package/node_modules/fast-uri/.github/tests_checker.yml +8 -0
- package/node_modules/fast-uri/.github/workflows/ci.yml +101 -0
- package/node_modules/fast-uri/.github/workflows/package-manager-ci.yml +24 -0
- package/node_modules/fast-uri/LICENSE +32 -0
- package/node_modules/fast-uri/README.md +143 -0
- package/node_modules/fast-uri/benchmark/benchmark.mjs +159 -0
- package/node_modules/fast-uri/benchmark/equal.mjs +51 -0
- package/node_modules/fast-uri/benchmark/non-simple-domain.mjs +22 -0
- package/node_modules/fast-uri/benchmark/package.json +17 -0
- package/node_modules/fast-uri/benchmark/string-array-to-hex-stripped.mjs +24 -0
- package/node_modules/fast-uri/benchmark/ws-is-secure.mjs +65 -0
- package/node_modules/fast-uri/eslint.config.js +6 -0
- package/node_modules/fast-uri/index.js +340 -0
- package/node_modules/fast-uri/lib/schemes.js +267 -0
- package/node_modules/fast-uri/lib/utils.js +336 -0
- package/node_modules/fast-uri/package.json +69 -0
- package/node_modules/fast-uri/test/ajv.test.js +43 -0
- package/node_modules/fast-uri/test/equal.test.js +108 -0
- package/node_modules/fast-uri/test/fixtures/uri-js-parse.json +501 -0
- package/node_modules/fast-uri/test/fixtures/uri-js-serialize.json +120 -0
- package/node_modules/fast-uri/test/parse.test.js +318 -0
- package/node_modules/fast-uri/test/resolve.test.js +78 -0
- package/node_modules/fast-uri/test/rfc-3986.test.js +90 -0
- package/node_modules/fast-uri/test/serialize.test.js +151 -0
- package/node_modules/fast-uri/test/uri-js-compatibility.test.js +33 -0
- package/node_modules/fast-uri/test/uri-js.test.js +912 -0
- package/node_modules/fast-uri/test/util.test.js +38 -0
- package/node_modules/fast-uri/tsconfig.json +9 -0
- package/node_modules/fast-uri/types/index.d.ts +60 -0
- package/node_modules/fast-uri/types/index.test-d.ts +17 -0
- package/node_modules/json-schema-traverse/.eslintrc.yml +27 -0
- package/node_modules/json-schema-traverse/.github/FUNDING.yml +2 -0
- package/node_modules/json-schema-traverse/.github/workflows/build.yml +28 -0
- package/node_modules/json-schema-traverse/.github/workflows/publish.yml +27 -0
- package/node_modules/json-schema-traverse/LICENSE +21 -0
- package/node_modules/json-schema-traverse/README.md +95 -0
- package/node_modules/json-schema-traverse/index.d.ts +40 -0
- package/node_modules/json-schema-traverse/index.js +93 -0
- package/node_modules/json-schema-traverse/package.json +43 -0
- package/node_modules/json-schema-traverse/spec/.eslintrc.yml +6 -0
- package/node_modules/json-schema-traverse/spec/fixtures/schema.js +125 -0
- package/node_modules/json-schema-traverse/spec/index.spec.js +171 -0
- package/node_modules/require-from-string/index.js +34 -0
- package/node_modules/require-from-string/license +21 -0
- package/node_modules/require-from-string/package.json +28 -0
- package/node_modules/require-from-string/readme.md +56 -0
- package/package.json +3 -2
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
import type {CodeKeywordDefinition, ErrorNoParams, AnySchema} from "../../types"
|
|
2
|
+
import type {KeywordCxt} from "../../compile/validate"
|
|
3
|
+
import {alwaysValidSchema} from "../../compile/util"
|
|
4
|
+
|
|
5
|
+
export type NotKeywordError = ErrorNoParams<"not", AnySchema>
|
|
6
|
+
|
|
7
|
+
const def: CodeKeywordDefinition = {
|
|
8
|
+
keyword: "not",
|
|
9
|
+
schemaType: ["object", "boolean"],
|
|
10
|
+
trackErrors: true,
|
|
11
|
+
code(cxt: KeywordCxt) {
|
|
12
|
+
const {gen, schema, it} = cxt
|
|
13
|
+
if (alwaysValidSchema(it, schema)) {
|
|
14
|
+
cxt.fail()
|
|
15
|
+
return
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const valid = gen.name("valid")
|
|
19
|
+
cxt.subschema(
|
|
20
|
+
{
|
|
21
|
+
keyword: "not",
|
|
22
|
+
compositeRule: true,
|
|
23
|
+
createErrors: false,
|
|
24
|
+
allErrors: false,
|
|
25
|
+
},
|
|
26
|
+
valid
|
|
27
|
+
)
|
|
28
|
+
|
|
29
|
+
cxt.failResult(
|
|
30
|
+
valid,
|
|
31
|
+
() => cxt.reset(),
|
|
32
|
+
() => cxt.error()
|
|
33
|
+
)
|
|
34
|
+
},
|
|
35
|
+
error: {message: "must NOT be valid"},
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export default def
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
import type {
|
|
2
|
+
CodeKeywordDefinition,
|
|
3
|
+
ErrorObject,
|
|
4
|
+
KeywordErrorDefinition,
|
|
5
|
+
AnySchema,
|
|
6
|
+
} from "../../types"
|
|
7
|
+
import type {KeywordCxt} from "../../compile/validate"
|
|
8
|
+
import {_, Name} from "../../compile/codegen"
|
|
9
|
+
import {alwaysValidSchema} from "../../compile/util"
|
|
10
|
+
import {SchemaCxt} from "../../compile"
|
|
11
|
+
|
|
12
|
+
export type OneOfError = ErrorObject<
|
|
13
|
+
"oneOf",
|
|
14
|
+
{passingSchemas: [number, number] | null},
|
|
15
|
+
AnySchema[]
|
|
16
|
+
>
|
|
17
|
+
|
|
18
|
+
const error: KeywordErrorDefinition = {
|
|
19
|
+
message: "must match exactly one schema in oneOf",
|
|
20
|
+
params: ({params}) => _`{passingSchemas: ${params.passing}}`,
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const def: CodeKeywordDefinition = {
|
|
24
|
+
keyword: "oneOf",
|
|
25
|
+
schemaType: "array",
|
|
26
|
+
trackErrors: true,
|
|
27
|
+
error,
|
|
28
|
+
code(cxt: KeywordCxt) {
|
|
29
|
+
const {gen, schema, parentSchema, it} = cxt
|
|
30
|
+
/* istanbul ignore if */
|
|
31
|
+
if (!Array.isArray(schema)) throw new Error("ajv implementation error")
|
|
32
|
+
if (it.opts.discriminator && parentSchema.discriminator) return
|
|
33
|
+
const schArr: AnySchema[] = schema
|
|
34
|
+
const valid = gen.let("valid", false)
|
|
35
|
+
const passing = gen.let("passing", null)
|
|
36
|
+
const schValid = gen.name("_valid")
|
|
37
|
+
cxt.setParams({passing})
|
|
38
|
+
// TODO possibly fail straight away (with warning or exception) if there are two empty always valid schemas
|
|
39
|
+
|
|
40
|
+
gen.block(validateOneOf)
|
|
41
|
+
|
|
42
|
+
cxt.result(
|
|
43
|
+
valid,
|
|
44
|
+
() => cxt.reset(),
|
|
45
|
+
() => cxt.error(true)
|
|
46
|
+
)
|
|
47
|
+
|
|
48
|
+
function validateOneOf(): void {
|
|
49
|
+
schArr.forEach((sch: AnySchema, i: number) => {
|
|
50
|
+
let schCxt: SchemaCxt | undefined
|
|
51
|
+
if (alwaysValidSchema(it, sch)) {
|
|
52
|
+
gen.var(schValid, true)
|
|
53
|
+
} else {
|
|
54
|
+
schCxt = cxt.subschema(
|
|
55
|
+
{
|
|
56
|
+
keyword: "oneOf",
|
|
57
|
+
schemaProp: i,
|
|
58
|
+
compositeRule: true,
|
|
59
|
+
},
|
|
60
|
+
schValid
|
|
61
|
+
)
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
if (i > 0) {
|
|
65
|
+
gen
|
|
66
|
+
.if(_`${schValid} && ${valid}`)
|
|
67
|
+
.assign(valid, false)
|
|
68
|
+
.assign(passing, _`[${passing}, ${i}]`)
|
|
69
|
+
.else()
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
gen.if(schValid, () => {
|
|
73
|
+
gen.assign(valid, true)
|
|
74
|
+
gen.assign(passing, i)
|
|
75
|
+
if (schCxt) cxt.mergeEvaluated(schCxt, Name)
|
|
76
|
+
})
|
|
77
|
+
})
|
|
78
|
+
}
|
|
79
|
+
},
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
export default def
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import type {CodeKeywordDefinition} from "../../types"
|
|
2
|
+
import type {KeywordCxt} from "../../compile/validate"
|
|
3
|
+
import {allSchemaProperties, usePattern} from "../code"
|
|
4
|
+
import {_, not, Name} from "../../compile/codegen"
|
|
5
|
+
import {alwaysValidSchema, checkStrictMode} from "../../compile/util"
|
|
6
|
+
import {evaluatedPropsToName, Type} from "../../compile/util"
|
|
7
|
+
import {AnySchema} from "../../types"
|
|
8
|
+
|
|
9
|
+
const def: CodeKeywordDefinition = {
|
|
10
|
+
keyword: "patternProperties",
|
|
11
|
+
type: "object",
|
|
12
|
+
schemaType: "object",
|
|
13
|
+
code(cxt: KeywordCxt) {
|
|
14
|
+
const {gen, schema, data, parentSchema, it} = cxt
|
|
15
|
+
const {opts} = it
|
|
16
|
+
const patterns = allSchemaProperties(schema)
|
|
17
|
+
const alwaysValidPatterns = patterns.filter((p) =>
|
|
18
|
+
alwaysValidSchema(it, schema[p] as AnySchema)
|
|
19
|
+
)
|
|
20
|
+
|
|
21
|
+
if (
|
|
22
|
+
patterns.length === 0 ||
|
|
23
|
+
(alwaysValidPatterns.length === patterns.length &&
|
|
24
|
+
(!it.opts.unevaluated || it.props === true))
|
|
25
|
+
) {
|
|
26
|
+
return
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
const checkProperties =
|
|
30
|
+
opts.strictSchema && !opts.allowMatchingProperties && parentSchema.properties
|
|
31
|
+
const valid = gen.name("valid")
|
|
32
|
+
if (it.props !== true && !(it.props instanceof Name)) {
|
|
33
|
+
it.props = evaluatedPropsToName(gen, it.props)
|
|
34
|
+
}
|
|
35
|
+
const {props} = it
|
|
36
|
+
validatePatternProperties()
|
|
37
|
+
|
|
38
|
+
function validatePatternProperties(): void {
|
|
39
|
+
for (const pat of patterns) {
|
|
40
|
+
if (checkProperties) checkMatchingProperties(pat)
|
|
41
|
+
if (it.allErrors) {
|
|
42
|
+
validateProperties(pat)
|
|
43
|
+
} else {
|
|
44
|
+
gen.var(valid, true) // TODO var
|
|
45
|
+
validateProperties(pat)
|
|
46
|
+
gen.if(valid)
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
function checkMatchingProperties(pat: string): void {
|
|
52
|
+
for (const prop in checkProperties) {
|
|
53
|
+
if (new RegExp(pat).test(prop)) {
|
|
54
|
+
checkStrictMode(
|
|
55
|
+
it,
|
|
56
|
+
`property ${prop} matches pattern ${pat} (use allowMatchingProperties)`
|
|
57
|
+
)
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
function validateProperties(pat: string): void {
|
|
63
|
+
gen.forIn("key", data, (key) => {
|
|
64
|
+
gen.if(_`${usePattern(cxt, pat)}.test(${key})`, () => {
|
|
65
|
+
const alwaysValid = alwaysValidPatterns.includes(pat)
|
|
66
|
+
if (!alwaysValid) {
|
|
67
|
+
cxt.subschema(
|
|
68
|
+
{
|
|
69
|
+
keyword: "patternProperties",
|
|
70
|
+
schemaProp: pat,
|
|
71
|
+
dataProp: key,
|
|
72
|
+
dataPropType: Type.Str,
|
|
73
|
+
},
|
|
74
|
+
valid
|
|
75
|
+
)
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
if (it.opts.unevaluated && props !== true) {
|
|
79
|
+
gen.assign(_`${props}[${key}]`, true)
|
|
80
|
+
} else if (!alwaysValid && !it.allErrors) {
|
|
81
|
+
// can short-circuit if `unevaluatedProperties` is not supported (opts.next === false)
|
|
82
|
+
// or if all properties were evaluated (props === true)
|
|
83
|
+
gen.if(not(valid), () => gen.break())
|
|
84
|
+
}
|
|
85
|
+
})
|
|
86
|
+
})
|
|
87
|
+
}
|
|
88
|
+
},
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
export default def
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type {CodeKeywordDefinition} from "../../types"
|
|
2
|
+
import {validateTuple} from "./items"
|
|
3
|
+
|
|
4
|
+
const def: CodeKeywordDefinition = {
|
|
5
|
+
keyword: "prefixItems",
|
|
6
|
+
type: "array",
|
|
7
|
+
schemaType: ["array"],
|
|
8
|
+
before: "uniqueItems",
|
|
9
|
+
code: (cxt) => validateTuple(cxt, "items"),
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
export default def
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import type {CodeKeywordDefinition} from "../../types"
|
|
2
|
+
import {KeywordCxt} from "../../compile/validate"
|
|
3
|
+
import {propertyInData, allSchemaProperties} from "../code"
|
|
4
|
+
import {alwaysValidSchema, toHash, mergeEvaluated} from "../../compile/util"
|
|
5
|
+
import apDef from "./additionalProperties"
|
|
6
|
+
|
|
7
|
+
const def: CodeKeywordDefinition = {
|
|
8
|
+
keyword: "properties",
|
|
9
|
+
type: "object",
|
|
10
|
+
schemaType: "object",
|
|
11
|
+
code(cxt: KeywordCxt) {
|
|
12
|
+
const {gen, schema, parentSchema, data, it} = cxt
|
|
13
|
+
if (it.opts.removeAdditional === "all" && parentSchema.additionalProperties === undefined) {
|
|
14
|
+
apDef.code(new KeywordCxt(it, apDef, "additionalProperties"))
|
|
15
|
+
}
|
|
16
|
+
const allProps = allSchemaProperties(schema)
|
|
17
|
+
for (const prop of allProps) {
|
|
18
|
+
it.definedProperties.add(prop)
|
|
19
|
+
}
|
|
20
|
+
if (it.opts.unevaluated && allProps.length && it.props !== true) {
|
|
21
|
+
it.props = mergeEvaluated.props(gen, toHash(allProps), it.props)
|
|
22
|
+
}
|
|
23
|
+
const properties = allProps.filter((p) => !alwaysValidSchema(it, schema[p]))
|
|
24
|
+
if (properties.length === 0) return
|
|
25
|
+
const valid = gen.name("valid")
|
|
26
|
+
|
|
27
|
+
for (const prop of properties) {
|
|
28
|
+
if (hasDefault(prop)) {
|
|
29
|
+
applyPropertySchema(prop)
|
|
30
|
+
} else {
|
|
31
|
+
gen.if(propertyInData(gen, data, prop, it.opts.ownProperties))
|
|
32
|
+
applyPropertySchema(prop)
|
|
33
|
+
if (!it.allErrors) gen.else().var(valid, true)
|
|
34
|
+
gen.endIf()
|
|
35
|
+
}
|
|
36
|
+
cxt.it.definedProperties.add(prop)
|
|
37
|
+
cxt.ok(valid)
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
function hasDefault(prop: string): boolean | undefined {
|
|
41
|
+
return it.opts.useDefaults && !it.compositeRule && schema[prop].default !== undefined
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
function applyPropertySchema(prop: string): void {
|
|
45
|
+
cxt.subschema(
|
|
46
|
+
{
|
|
47
|
+
keyword: "properties",
|
|
48
|
+
schemaProp: prop,
|
|
49
|
+
dataProp: prop,
|
|
50
|
+
},
|
|
51
|
+
valid
|
|
52
|
+
)
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
}
|
|
56
|
+
|
|
57
|
+
export default def
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import type {
|
|
2
|
+
CodeKeywordDefinition,
|
|
3
|
+
ErrorObject,
|
|
4
|
+
KeywordErrorDefinition,
|
|
5
|
+
AnySchema,
|
|
6
|
+
} from "../../types"
|
|
7
|
+
import type {KeywordCxt} from "../../compile/validate"
|
|
8
|
+
import {_, not} from "../../compile/codegen"
|
|
9
|
+
import {alwaysValidSchema} from "../../compile/util"
|
|
10
|
+
|
|
11
|
+
export type PropertyNamesError = ErrorObject<"propertyNames", {propertyName: string}, AnySchema>
|
|
12
|
+
|
|
13
|
+
const error: KeywordErrorDefinition = {
|
|
14
|
+
message: "property name must be valid",
|
|
15
|
+
params: ({params}) => _`{propertyName: ${params.propertyName}}`,
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const def: CodeKeywordDefinition = {
|
|
19
|
+
keyword: "propertyNames",
|
|
20
|
+
type: "object",
|
|
21
|
+
schemaType: ["object", "boolean"],
|
|
22
|
+
error,
|
|
23
|
+
code(cxt: KeywordCxt) {
|
|
24
|
+
const {gen, schema, data, it} = cxt
|
|
25
|
+
if (alwaysValidSchema(it, schema)) return
|
|
26
|
+
const valid = gen.name("valid")
|
|
27
|
+
|
|
28
|
+
gen.forIn("key", data, (key) => {
|
|
29
|
+
cxt.setParams({propertyName: key})
|
|
30
|
+
cxt.subschema(
|
|
31
|
+
{
|
|
32
|
+
keyword: "propertyNames",
|
|
33
|
+
data: key,
|
|
34
|
+
dataTypes: ["string"],
|
|
35
|
+
propertyName: key,
|
|
36
|
+
compositeRule: true,
|
|
37
|
+
},
|
|
38
|
+
valid
|
|
39
|
+
)
|
|
40
|
+
gen.if(not(valid), () => {
|
|
41
|
+
cxt.error(true)
|
|
42
|
+
if (!it.allErrors) gen.break()
|
|
43
|
+
})
|
|
44
|
+
})
|
|
45
|
+
|
|
46
|
+
cxt.ok(valid)
|
|
47
|
+
},
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
export default def
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import type {CodeKeywordDefinition} from "../../types"
|
|
2
|
+
import type {KeywordCxt} from "../../compile/validate"
|
|
3
|
+
import {checkStrictMode} from "../../compile/util"
|
|
4
|
+
|
|
5
|
+
const def: CodeKeywordDefinition = {
|
|
6
|
+
keyword: ["then", "else"],
|
|
7
|
+
schemaType: ["object", "boolean"],
|
|
8
|
+
code({keyword, parentSchema, it}: KeywordCxt) {
|
|
9
|
+
if (parentSchema.if === undefined) checkStrictMode(it, `"${keyword}" without "if" is ignored`)
|
|
10
|
+
},
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
export default def
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
import type {AnySchema, SchemaMap} from "../types"
|
|
2
|
+
import type {SchemaCxt} from "../compile"
|
|
3
|
+
import type {KeywordCxt} from "../compile/validate"
|
|
4
|
+
import {CodeGen, _, and, or, not, nil, strConcat, getProperty, Code, Name} from "../compile/codegen"
|
|
5
|
+
import {alwaysValidSchema, Type} from "../compile/util"
|
|
6
|
+
import N from "../compile/names"
|
|
7
|
+
import {useFunc} from "../compile/util"
|
|
8
|
+
export function checkReportMissingProp(cxt: KeywordCxt, prop: string): void {
|
|
9
|
+
const {gen, data, it} = cxt
|
|
10
|
+
gen.if(noPropertyInData(gen, data, prop, it.opts.ownProperties), () => {
|
|
11
|
+
cxt.setParams({missingProperty: _`${prop}`}, true)
|
|
12
|
+
cxt.error()
|
|
13
|
+
})
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export function checkMissingProp(
|
|
17
|
+
{gen, data, it: {opts}}: KeywordCxt,
|
|
18
|
+
properties: string[],
|
|
19
|
+
missing: Name
|
|
20
|
+
): Code {
|
|
21
|
+
return or(
|
|
22
|
+
...properties.map((prop) =>
|
|
23
|
+
and(noPropertyInData(gen, data, prop, opts.ownProperties), _`${missing} = ${prop}`)
|
|
24
|
+
)
|
|
25
|
+
)
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export function reportMissingProp(cxt: KeywordCxt, missing: Name): void {
|
|
29
|
+
cxt.setParams({missingProperty: missing}, true)
|
|
30
|
+
cxt.error()
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
export function hasPropFunc(gen: CodeGen): Name {
|
|
34
|
+
return gen.scopeValue("func", {
|
|
35
|
+
// eslint-disable-next-line @typescript-eslint/unbound-method
|
|
36
|
+
ref: Object.prototype.hasOwnProperty,
|
|
37
|
+
code: _`Object.prototype.hasOwnProperty`,
|
|
38
|
+
})
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
export function isOwnProperty(gen: CodeGen, data: Name, property: Name | string): Code {
|
|
42
|
+
return _`${hasPropFunc(gen)}.call(${data}, ${property})`
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
export function propertyInData(
|
|
46
|
+
gen: CodeGen,
|
|
47
|
+
data: Name,
|
|
48
|
+
property: Name | string,
|
|
49
|
+
ownProperties?: boolean
|
|
50
|
+
): Code {
|
|
51
|
+
const cond = _`${data}${getProperty(property)} !== undefined`
|
|
52
|
+
return ownProperties ? _`${cond} && ${isOwnProperty(gen, data, property)}` : cond
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
export function noPropertyInData(
|
|
56
|
+
gen: CodeGen,
|
|
57
|
+
data: Name,
|
|
58
|
+
property: Name | string,
|
|
59
|
+
ownProperties?: boolean
|
|
60
|
+
): Code {
|
|
61
|
+
const cond = _`${data}${getProperty(property)} === undefined`
|
|
62
|
+
return ownProperties ? or(cond, not(isOwnProperty(gen, data, property))) : cond
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
export function allSchemaProperties(schemaMap?: SchemaMap): string[] {
|
|
66
|
+
return schemaMap ? Object.keys(schemaMap).filter((p) => p !== "__proto__") : []
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
export function schemaProperties(it: SchemaCxt, schemaMap: SchemaMap): string[] {
|
|
70
|
+
return allSchemaProperties(schemaMap).filter(
|
|
71
|
+
(p) => !alwaysValidSchema(it, schemaMap[p] as AnySchema)
|
|
72
|
+
)
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
export function callValidateCode(
|
|
76
|
+
{schemaCode, data, it: {gen, topSchemaRef, schemaPath, errorPath}, it}: KeywordCxt,
|
|
77
|
+
func: Code,
|
|
78
|
+
context: Code,
|
|
79
|
+
passSchema?: boolean
|
|
80
|
+
): Code {
|
|
81
|
+
const dataAndSchema = passSchema ? _`${schemaCode}, ${data}, ${topSchemaRef}${schemaPath}` : data
|
|
82
|
+
const valCxt: [Name, Code | number][] = [
|
|
83
|
+
[N.instancePath, strConcat(N.instancePath, errorPath)],
|
|
84
|
+
[N.parentData, it.parentData],
|
|
85
|
+
[N.parentDataProperty, it.parentDataProperty],
|
|
86
|
+
[N.rootData, N.rootData],
|
|
87
|
+
]
|
|
88
|
+
if (it.opts.dynamicRef) valCxt.push([N.dynamicAnchors, N.dynamicAnchors])
|
|
89
|
+
const args = _`${dataAndSchema}, ${gen.object(...valCxt)}`
|
|
90
|
+
return context !== nil ? _`${func}.call(${context}, ${args})` : _`${func}(${args})`
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
const newRegExp = _`new RegExp`
|
|
94
|
+
|
|
95
|
+
export function usePattern({gen, it: {opts}}: KeywordCxt, pattern: string): Name {
|
|
96
|
+
const u = opts.unicodeRegExp ? "u" : ""
|
|
97
|
+
const {regExp} = opts.code
|
|
98
|
+
const rx = regExp(pattern, u)
|
|
99
|
+
|
|
100
|
+
return gen.scopeValue("pattern", {
|
|
101
|
+
key: rx.toString(),
|
|
102
|
+
ref: rx,
|
|
103
|
+
code: _`${regExp.code === "new RegExp" ? newRegExp : useFunc(gen, regExp)}(${pattern}, ${u})`,
|
|
104
|
+
})
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
export function validateArray(cxt: KeywordCxt): Name {
|
|
108
|
+
const {gen, data, keyword, it} = cxt
|
|
109
|
+
const valid = gen.name("valid")
|
|
110
|
+
if (it.allErrors) {
|
|
111
|
+
const validArr = gen.let("valid", true)
|
|
112
|
+
validateItems(() => gen.assign(validArr, false))
|
|
113
|
+
return validArr
|
|
114
|
+
}
|
|
115
|
+
gen.var(valid, true)
|
|
116
|
+
validateItems(() => gen.break())
|
|
117
|
+
return valid
|
|
118
|
+
|
|
119
|
+
function validateItems(notValid: () => void): void {
|
|
120
|
+
const len = gen.const("len", _`${data}.length`)
|
|
121
|
+
gen.forRange("i", 0, len, (i) => {
|
|
122
|
+
cxt.subschema(
|
|
123
|
+
{
|
|
124
|
+
keyword,
|
|
125
|
+
dataProp: i,
|
|
126
|
+
dataPropType: Type.Num,
|
|
127
|
+
},
|
|
128
|
+
valid
|
|
129
|
+
)
|
|
130
|
+
gen.if(not(valid), notValid)
|
|
131
|
+
})
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
export function validateUnion(cxt: KeywordCxt): void {
|
|
136
|
+
const {gen, schema, keyword, it} = cxt
|
|
137
|
+
/* istanbul ignore if */
|
|
138
|
+
if (!Array.isArray(schema)) throw new Error("ajv implementation error")
|
|
139
|
+
const alwaysValid = schema.some((sch: AnySchema) => alwaysValidSchema(it, sch))
|
|
140
|
+
if (alwaysValid && !it.opts.unevaluated) return
|
|
141
|
+
|
|
142
|
+
const valid = gen.let("valid", false)
|
|
143
|
+
const schValid = gen.name("_valid")
|
|
144
|
+
|
|
145
|
+
gen.block(() =>
|
|
146
|
+
schema.forEach((_sch: AnySchema, i: number) => {
|
|
147
|
+
const schCxt = cxt.subschema(
|
|
148
|
+
{
|
|
149
|
+
keyword,
|
|
150
|
+
schemaProp: i,
|
|
151
|
+
compositeRule: true,
|
|
152
|
+
},
|
|
153
|
+
schValid
|
|
154
|
+
)
|
|
155
|
+
gen.assign(valid, _`${valid} || ${schValid}`)
|
|
156
|
+
const merged = cxt.mergeValidEvaluated(schCxt, schValid)
|
|
157
|
+
// can short-circuit if `unevaluatedProperties/Items` not supported (opts.unevaluated !== true)
|
|
158
|
+
// or if all properties and items were evaluated (it.props === true && it.items === true)
|
|
159
|
+
if (!merged) gen.if(not(valid))
|
|
160
|
+
})
|
|
161
|
+
)
|
|
162
|
+
|
|
163
|
+
cxt.result(
|
|
164
|
+
valid,
|
|
165
|
+
() => cxt.reset(),
|
|
166
|
+
() => cxt.error(true)
|
|
167
|
+
)
|
|
168
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import type {Vocabulary} from "../../types"
|
|
2
|
+
import idKeyword from "./id"
|
|
3
|
+
import refKeyword from "./ref"
|
|
4
|
+
|
|
5
|
+
const core: Vocabulary = [
|
|
6
|
+
"$schema",
|
|
7
|
+
"$id",
|
|
8
|
+
"$defs",
|
|
9
|
+
"$vocabulary",
|
|
10
|
+
{keyword: "$comment"},
|
|
11
|
+
"definitions",
|
|
12
|
+
idKeyword,
|
|
13
|
+
refKeyword,
|
|
14
|
+
]
|
|
15
|
+
|
|
16
|
+
export default core
|
|
@@ -0,0 +1,129 @@
|
|
|
1
|
+
import type {CodeKeywordDefinition, AnySchema} from "../../types"
|
|
2
|
+
import type {KeywordCxt} from "../../compile/validate"
|
|
3
|
+
import MissingRefError from "../../compile/ref_error"
|
|
4
|
+
import {callValidateCode} from "../code"
|
|
5
|
+
import {_, nil, stringify, Code, Name} from "../../compile/codegen"
|
|
6
|
+
import N from "../../compile/names"
|
|
7
|
+
import {SchemaEnv, resolveRef} from "../../compile"
|
|
8
|
+
import {mergeEvaluated} from "../../compile/util"
|
|
9
|
+
|
|
10
|
+
const def: CodeKeywordDefinition = {
|
|
11
|
+
keyword: "$ref",
|
|
12
|
+
schemaType: "string",
|
|
13
|
+
code(cxt: KeywordCxt): void {
|
|
14
|
+
const {gen, schema: $ref, it} = cxt
|
|
15
|
+
const {baseId, schemaEnv: env, validateName, opts, self} = it
|
|
16
|
+
const {root} = env
|
|
17
|
+
if (($ref === "#" || $ref === "#/") && baseId === root.baseId) return callRootRef()
|
|
18
|
+
const schOrEnv = resolveRef.call(self, root, baseId, $ref)
|
|
19
|
+
if (schOrEnv === undefined) throw new MissingRefError(it.opts.uriResolver, baseId, $ref)
|
|
20
|
+
if (schOrEnv instanceof SchemaEnv) return callValidate(schOrEnv)
|
|
21
|
+
return inlineRefSchema(schOrEnv)
|
|
22
|
+
|
|
23
|
+
function callRootRef(): void {
|
|
24
|
+
if (env === root) return callRef(cxt, validateName, env, env.$async)
|
|
25
|
+
const rootName = gen.scopeValue("root", {ref: root})
|
|
26
|
+
return callRef(cxt, _`${rootName}.validate`, root, root.$async)
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
function callValidate(sch: SchemaEnv): void {
|
|
30
|
+
const v = getValidate(cxt, sch)
|
|
31
|
+
callRef(cxt, v, sch, sch.$async)
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
function inlineRefSchema(sch: AnySchema): void {
|
|
35
|
+
const schName = gen.scopeValue(
|
|
36
|
+
"schema",
|
|
37
|
+
opts.code.source === true ? {ref: sch, code: stringify(sch)} : {ref: sch}
|
|
38
|
+
)
|
|
39
|
+
const valid = gen.name("valid")
|
|
40
|
+
const schCxt = cxt.subschema(
|
|
41
|
+
{
|
|
42
|
+
schema: sch,
|
|
43
|
+
dataTypes: [],
|
|
44
|
+
schemaPath: nil,
|
|
45
|
+
topSchemaRef: schName,
|
|
46
|
+
errSchemaPath: $ref,
|
|
47
|
+
},
|
|
48
|
+
valid
|
|
49
|
+
)
|
|
50
|
+
cxt.mergeEvaluated(schCxt)
|
|
51
|
+
cxt.ok(valid)
|
|
52
|
+
}
|
|
53
|
+
},
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
export function getValidate(cxt: KeywordCxt, sch: SchemaEnv): Code {
|
|
57
|
+
const {gen} = cxt
|
|
58
|
+
return sch.validate
|
|
59
|
+
? gen.scopeValue("validate", {ref: sch.validate})
|
|
60
|
+
: _`${gen.scopeValue("wrapper", {ref: sch})}.validate`
|
|
61
|
+
}
|
|
62
|
+
|
|
63
|
+
export function callRef(cxt: KeywordCxt, v: Code, sch?: SchemaEnv, $async?: boolean): void {
|
|
64
|
+
const {gen, it} = cxt
|
|
65
|
+
const {allErrors, schemaEnv: env, opts} = it
|
|
66
|
+
const passCxt = opts.passContext ? N.this : nil
|
|
67
|
+
if ($async) callAsyncRef()
|
|
68
|
+
else callSyncRef()
|
|
69
|
+
|
|
70
|
+
function callAsyncRef(): void {
|
|
71
|
+
if (!env.$async) throw new Error("async schema referenced by sync schema")
|
|
72
|
+
const valid = gen.let("valid")
|
|
73
|
+
gen.try(
|
|
74
|
+
() => {
|
|
75
|
+
gen.code(_`await ${callValidateCode(cxt, v, passCxt)}`)
|
|
76
|
+
addEvaluatedFrom(v) // TODO will not work with async, it has to be returned with the result
|
|
77
|
+
if (!allErrors) gen.assign(valid, true)
|
|
78
|
+
},
|
|
79
|
+
(e) => {
|
|
80
|
+
gen.if(_`!(${e} instanceof ${it.ValidationError as Name})`, () => gen.throw(e))
|
|
81
|
+
addErrorsFrom(e)
|
|
82
|
+
if (!allErrors) gen.assign(valid, false)
|
|
83
|
+
}
|
|
84
|
+
)
|
|
85
|
+
cxt.ok(valid)
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
function callSyncRef(): void {
|
|
89
|
+
cxt.result(
|
|
90
|
+
callValidateCode(cxt, v, passCxt),
|
|
91
|
+
() => addEvaluatedFrom(v),
|
|
92
|
+
() => addErrorsFrom(v)
|
|
93
|
+
)
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
function addErrorsFrom(source: Code): void {
|
|
97
|
+
const errs = _`${source}.errors`
|
|
98
|
+
gen.assign(N.vErrors, _`${N.vErrors} === null ? ${errs} : ${N.vErrors}.concat(${errs})`) // TODO tagged
|
|
99
|
+
gen.assign(N.errors, _`${N.vErrors}.length`)
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
function addEvaluatedFrom(source: Code): void {
|
|
103
|
+
if (!it.opts.unevaluated) return
|
|
104
|
+
const schEvaluated = sch?.validate?.evaluated
|
|
105
|
+
// TODO refactor
|
|
106
|
+
if (it.props !== true) {
|
|
107
|
+
if (schEvaluated && !schEvaluated.dynamicProps) {
|
|
108
|
+
if (schEvaluated.props !== undefined) {
|
|
109
|
+
it.props = mergeEvaluated.props(gen, schEvaluated.props, it.props)
|
|
110
|
+
}
|
|
111
|
+
} else {
|
|
112
|
+
const props = gen.var("props", _`${source}.evaluated.props`)
|
|
113
|
+
it.props = mergeEvaluated.props(gen, props, it.props, Name)
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
if (it.items !== true) {
|
|
117
|
+
if (schEvaluated && !schEvaluated.dynamicItems) {
|
|
118
|
+
if (schEvaluated.items !== undefined) {
|
|
119
|
+
it.items = mergeEvaluated.items(gen, schEvaluated.items, it.items)
|
|
120
|
+
}
|
|
121
|
+
} else {
|
|
122
|
+
const items = gen.var("items", _`${source}.evaluated.items`)
|
|
123
|
+
it.items = mergeEvaluated.items(gen, items, it.items, Name)
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
export default def
|