Skip to content

Commit 7a9f143

Browse files
committed
Restore src/* and tests/schema/* files
1 parent 815732d commit 7a9f143

27 files changed

+6116
-0
lines changed

src/oas.md

Lines changed: 4626 additions & 0 deletions
Large diffs are not rendered by default.

src/schemas/validation/README.md

Lines changed: 69 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,69 @@
1+
# OpenAPI 3.X.Y JSON Schema
2+
3+
This directory contains the YAML sources for generating the JSON Schemas for validating OpenAPI definitions of versions 3.X.Y, which are published on [https://spec.openapis.org](https://spec.openapis.org).
4+
5+
Due to limitations of GitHub pages, the schemas on the spec site are served with `Content-Type: application/octet-stream`, but should be interpreted as `application/schema+json`.
6+
7+
The sources in this directory, which have `WORK-IN-PROGRESS` in their `$id`s, are _not intended for direct use_.
8+
9+
## Schema `$id` dates
10+
11+
The published schemas on the spec site have an _iteration date_ in their `id`s.
12+
This allows the schemas for a release line to be updated independent of the spec patch release cycle.
13+
14+
The iteration version of the JSON Schema can be found in the `$id` field.
15+
For example, the value of `$id: https://spec.openapis.org/oas/3.1/schema/2021-03-02` means this iteration was created on March 2nd, 2021.
16+
17+
We are [working on](https://github.com/OAI/OpenAPI-Specification/issues/4152) how to best provide programmatic access for determining the latest date for each schema.
18+
19+
## Choosing which schema to use
20+
21+
There are two schemas to choose from for versions 3.1 and greater, both of which have an `$id` that starts with `https://spec.openapis.org/oas/3.X/` and ends with the iteration date:
22+
23+
* `https://spec.openapis.org/oas/3.X/schema/{date}`, source: `schema.yaml` — A self-contained schema that _does not_ validate Schema Objects beyond `type: [object, boolean]`
24+
* `https://spec.openapis.org/oas/3.1/schema-base/{date}`, source: `schema-base.yaml` — A schema that combines the self-contained schema and the "base" dialect schema to validate Schema Objects with the dialect; this schema does not allow changing `$schema` or `jsonSchemaDialect` to other dialects
25+
26+
Two metaschemas define the OAS "base" dialect:
27+
28+
* `https://spec.openapis.org/oas/3.X/meta/{date}`, source: `meta.yaml` — The vocabulary metaschema for OAS 3.X's extensions to draft 2020-12
29+
* `https://spec.openapis.org/oas/3.X/dialect/{date}`, source: `dialect.yaml` — The dialect metaschema that extends the standard `draft/2020-12` metaschema by adding the OAS "base" vocabulary
30+
31+
The name "base" for the dialect was intended to indicate that the OAS dialect could be further extended.
32+
33+
~~~mermaid
34+
flowchart LR
35+
schema_base
36+
schema
37+
dialect
38+
meta
39+
schema --> |default| dialect
40+
schema_base --> |$ref| schema
41+
schema_base --> |$ref| dialect
42+
dialect --> |$ref| meta
43+
~~~
44+
45+
An additional schema that validates the Schema Object with the OAS 3.X dialect but does not restrict changing `$schema` is [under consideration](https://github.com/OAI/OpenAPI-Specification/issues/4147).
46+
47+
## Improving the schemas
48+
49+
As a reminder, the JSON Schema is not the source of truth for the Specification. In cases of conflicts between the Specification itself and the JSON Schema, the Specification wins. Also, some Specification constraints cannot be represented with the JSON Schema so it's highly recommended to employ other methods to ensure compliance.
50+
51+
The schema only validates the mandatory aspects of the OAS.
52+
Validating requirements that are optional, or field usage that has undefined or ignored behavior are not within the scope of this schema.
53+
Schemas to perform additional optional validation are [under consideration](https://github.com/OAI/OpenAPI-Specification/issues/4141).
54+
55+
Improvements can be submitted by opening a PR against the `vX.Y-dev` branch of the respective specification version.
56+
57+
Modify the `schema.yaml` file and add test cases for your changes.
58+
59+
The TSC will then:
60+
- Run tests on the updated schema
61+
- Update the iteration version
62+
- Publish the new version
63+
64+
The [test suite](../../../tests/schema) is part of this package.
65+
66+
```bash
67+
npm install
68+
npm test
69+
```
Lines changed: 21 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
$id: https://spec.openapis.org/oas/3.1/dialect/WORK-IN-PROGRESS
2+
$schema: https://json-schema.org/draft/2020-12/schema
3+
4+
title: OpenAPI 3.1 Schema Object Dialect
5+
description: A JSON Schema dialect describing schemas found in OpenAPI v3.1 Descriptions
6+
7+
$dynamicAnchor: meta
8+
9+
$vocabulary:
10+
https://json-schema.org/draft/2020-12/vocab/applicator: true
11+
https://json-schema.org/draft/2020-12/vocab/content: true
12+
https://json-schema.org/draft/2020-12/vocab/core: true
13+
https://json-schema.org/draft/2020-12/vocab/format-annotation: true
14+
https://json-schema.org/draft/2020-12/vocab/meta-data: true
15+
https://json-schema.org/draft/2020-12/vocab/unevaluated: true
16+
https://json-schema.org/draft/2020-12/vocab/validation: true
17+
https://spec.openapis.org/oas/3.1/vocab/base: false
18+
19+
allOf:
20+
- $ref: https://json-schema.org/draft/2020-12/schema
21+
- $ref: https://spec.openapis.org/oas/3.1/meta/WORK-IN-PROGRESS

src/schemas/validation/meta.yaml

Lines changed: 70 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,70 @@
1+
$id: https://spec.openapis.org/oas/3.1/meta/WORK-IN-PROGRESS
2+
$schema: https://json-schema.org/draft/2020-12/schema
3+
4+
title: OAS Base Vocabulary
5+
description: A JSON Schema Vocabulary used in the OpenAPI Schema Dialect
6+
7+
$dynamicAnchor: meta
8+
9+
$vocabulary:
10+
https://spec.openapis.org/oas/3.1/vocab/base: true
11+
12+
type:
13+
- object
14+
- boolean
15+
properties:
16+
discriminator:
17+
$ref: '#/$defs/discriminator'
18+
example: true
19+
externalDocs:
20+
$ref: '#/$defs/external-docs'
21+
xml:
22+
$ref: '#/$defs/xml'
23+
24+
$defs:
25+
discriminator:
26+
$ref: '#/$defs/extensible'
27+
properties:
28+
mapping:
29+
additionalProperties:
30+
type: string
31+
type: object
32+
propertyName:
33+
type: string
34+
required:
35+
- propertyName
36+
type: object
37+
unevaluatedProperties: false
38+
39+
extensible:
40+
patternProperties:
41+
^x-: true
42+
external-docs:
43+
$ref: '#/$defs/extensible'
44+
properties:
45+
description:
46+
type: string
47+
url:
48+
format: uri-reference
49+
type: string
50+
required:
51+
- url
52+
type: object
53+
unevaluatedProperties: false
54+
55+
xml:
56+
$ref: '#/$defs/extensible'
57+
properties:
58+
attribute:
59+
type: boolean
60+
name:
61+
type: string
62+
namespace:
63+
format: uri
64+
type: string
65+
prefix:
66+
type: string
67+
wrapped:
68+
type: boolean
69+
type: object
70+
unevaluatedProperties: false
Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
$id: 'https://spec.openapis.org/oas/3.1/schema-base/WORK-IN-PROGRESS'
2+
$schema: 'https://json-schema.org/draft/2020-12/schema'
3+
4+
description: The description of OpenAPI v3.1.x Documents using the OpenAPI JSON Schema dialect
5+
6+
$ref: 'https://spec.openapis.org/oas/3.1/schema/WORK-IN-PROGRESS'
7+
properties:
8+
jsonSchemaDialect:
9+
$ref: '#/$defs/dialect'
10+
11+
$defs:
12+
dialect:
13+
const: 'https://spec.openapis.org/oas/3.1/dialect/WORK-IN-PROGRESS'
14+
15+
schema:
16+
$dynamicAnchor: meta
17+
$ref: 'https://spec.openapis.org/oas/3.1/dialect/WORK-IN-PROGRESS'
18+
properties:
19+
$schema:
20+
$ref: '#/$defs/dialect'

0 commit comments

Comments
 (0)