-
Notifications
You must be signed in to change notification settings - Fork 155
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
feat(typings): update OpenAPI 3.0 and 3.1 typing declarations #1795
base: main
Are you sure you want to change the base?
Conversation
🦋 Changeset detectedLatest commit: 5428993 The changes in this PR will be included in the next version bump. This PR includes changesets to release 2 packages
Not sure what this means? Click here to learn what changesets are. Click here if you're a maintainer who wants to add another changeset to this PR |
0ba50f7
to
7463f90
Compare
ok, i think i'm done with this. missed a few keywords for Oas3_1 schemas. ready for review. thanks |
packages/core/src/typings/openapi.ts
Outdated
@@ -112,13 +112,10 @@ export interface Oas3Xml { | |||
} | |||
|
|||
// common fields for OpenAPI Schema v3.x | |||
interface Oas3XSchemaBase<T> { | |||
interface Oas3XSchemaBase { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I prefer using the generic interface because it's less likely for the common properties to diverge. Not sure which approach would be cleaner though. Why did you decide to change the approach?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
the keywords which utilized the generic interface were moved into the Oas3Schema
and Oas3_1Schema
. So it was unused.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, but what was the reason for moving the keywords from Oas3XSchemaBase
? Was there an issue with leaving them as they were?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, they have different behavior between 30 asd 31. So the extension of Oas3XSchemaBase was incorrect and the keywords should be assigned to each version
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok. I'll test that once I have time. Thank you for contributing!
331b109
to
498f6b7
Compare
I added a few extra JSON Schema 2020-12 keywords that were missed |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's make it reuse the common props slightly more.
Otherwise looks good!
packages/core/src/typings/openapi.ts
Outdated
@@ -112,32 +112,22 @@ export interface Oas3Xml { | |||
} | |||
|
|||
// common fields for OpenAPI Schema v3.x | |||
interface Oas3XSchemaBase<T> { | |||
interface Oas3XSchemaBase { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
interface Oas3XSchemaBase { | |
interface Oas3XSchemaBase<T extends Oas3Schema | Oas3_1Schema> { |
packages/core/src/typings/openapi.ts
Outdated
properties?: { [name: string]: Referenced<Oas3Schema> }; | ||
additionalProperties?: boolean | Oas3Schema; | ||
items?: Oas3Schema; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
properties?: { [name: string]: Referenced<Oas3Schema> }; | |
additionalProperties?: boolean | Oas3Schema; | |
items?: Oas3Schema; |
packages/core/src/typings/openapi.ts
Outdated
oneOf?: Oas3Schema[]; | ||
anyOf?: Oas3Schema[]; | ||
allOf?: Oas3Schema[]; | ||
not?: Oas3Schema; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
oneOf?: Oas3Schema[]; | |
anyOf?: Oas3Schema[]; | |
allOf?: Oas3Schema[]; | |
not?: Oas3Schema; |
packages/core/src/typings/openapi.ts
Outdated
|
||
xml?: Oas3Xml; | ||
'x-tags'?: string[]; | ||
} | ||
|
||
export interface Oas3Schema extends Oas3XSchemaBase<Oas3Schema> { | ||
export interface Oas3Schema extends Oas3XSchemaBase { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
export interface Oas3Schema extends Oas3XSchemaBase { | |
export interface Oas3Schema extends Oas3XSchemaBase<Oas3Schema> { |
packages/core/src/typings/openapi.ts
Outdated
} | ||
|
||
export interface Oas3_1Schema extends Oas3XSchemaBase<Oas3_1Schema> { | ||
export interface Oas3_1Schema extends Oas3XSchemaBase { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
export interface Oas3_1Schema extends Oas3XSchemaBase { | |
export interface Oas3_1Schema extends Oas3XSchemaBase<Oas3_1Schema> { |
packages/core/src/typings/openapi.ts
Outdated
properties?: { [name: string]: Referenced<Oas3_1Schema> }; | ||
additionalProperties?: boolean | Oas3_1Schema; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
properties?: { [name: string]: Referenced<Oas3_1Schema> }; | |
additionalProperties?: boolean | Oas3_1Schema; |
packages/core/src/typings/openapi.ts
Outdated
items?: Oas3_1Schema; | ||
oneOf?: Oas3_1Schema[]; | ||
anyOf?: Oas3_1Schema[]; | ||
allOf?: Oas3_1Schema[]; | ||
not?: Oas3_1Schema; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
items?: Oas3_1Schema; | |
oneOf?: Oas3_1Schema[]; | |
anyOf?: Oas3_1Schema[]; | |
allOf?: Oas3_1Schema[]; | |
not?: Oas3_1Schema; |
498f6b7
to
99dbb67
Compare
i'm stuck on the visitors.ts and custom rule files. Any help appreciated. i will run prettier after the fixes |
Added missing keywords for OAS 3.1.x (JSON Schema 2020-12). Co-authored-by: Andrew Tatomyr <[email protected]>
e27090b
to
c03175a
Compare
c03175a
to
5428993
Compare
|
||
export interface Oas3_1Components extends Oas3ComponentsBase<Oas3Schema> { | ||
pathItems?: { [name: string]: Referenced<Oas3PathItem<Oas3Schema | Oas3_1Schema>> }; | ||
} |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd add a separate Oas3Components
to follow the same pattern as in other types, and slightly improve the Oas3_1Components
type to use Oas3_1Schema
only:
export interface Oas3_1Components extends Oas3ComponentsBase<Oas3Schema> { | |
pathItems?: { [name: string]: Referenced<Oas3PathItem<Oas3Schema | Oas3_1Schema>> }; | |
} | |
export interface Oas3_1Components extends Oas3ComponentsBase<Oas3_1Schema> { | |
pathItems?: { [name: string]: Referenced<Oas3PathItem<Oas3_1Schema>> }; | |
} | |
export interface Oas3Components extends Oas3ComponentsBase<Oas3Schema> |
Xml?: VisitFunctionOrObject<Oas3Xml>; | ||
SchemaProperties?: VisitFunctionOrObject<Record<string, Oas3Schema>>; | ||
DiscriminatorMapping?: VisitFunctionOrObject<Record<string, string>>; | ||
Discriminator?: VisitFunctionOrObject<Oas3Discriminator>; | ||
Components?: VisitFunctionOrObject<Oas3Components>; | ||
Components?: VisitFunctionOrObject< | ||
Oas3ComponentsBase<Oas3Schema | Oas3_1Schema> | Oas3_1Components |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Related to https://github.com/Redocly/redocly-cli/pull/1795/files?diff=split&w=1#r1898410733 :
Oas3ComponentsBase<Oas3Schema | Oas3_1Schema> | Oas3_1Components | |
Oas3Components | Oas3_1Components |
@@ -264,15 +262,17 @@ function getFileNamePath(componentDirPath: string, componentName: string, ext: s | |||
} | |||
|
|||
function gatherComponentsFiles( | |||
components: Oas3Components, | |||
components: Oas3ComponentsBase<Oas3Schema | Oas3_1Schema> | Oas3_1Components, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Related to https://github.com/Redocly/redocly-cli/pull/1795/files?diff=split&w=1#r1898410733 :
components: Oas3ComponentsBase<Oas3Schema | Oas3_1Schema> | Oas3_1Components, | |
components: Oas3Components | Oas3_1Components, |
{ usedIn: Location[]; componentType?: keyof Oas3Components; name: string } | ||
{ | ||
usedIn: Location[]; | ||
componentType?: keyof (Oas3ComponentsBase<Oas3Schema | Oas3_1Schema> | Oas3_1Components); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Related to https://github.com/Redocly/redocly-cli/pull/1795/files?diff=split&w=1#r1898410733 :
componentType?: keyof (Oas3ComponentsBase<Oas3Schema | Oas3_1Schema> | Oas3_1Components); | |
componentType?: keyof (Oas3Components | Oas3_1Components); |
>(); | ||
|
||
function registerComponent( | ||
location: Location, | ||
componentType: keyof Oas3Components, | ||
componentType: keyof (Oas3ComponentsBase<Oas3Schema | Oas3_1Schema> | Oas3_1Components), |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
componentType: keyof (Oas3ComponentsBase<Oas3Schema | Oas3_1Schema> | Oas3_1Components), | |
componentType: keyof (Oas3Components | Oas3_1Components), |
paths?: Oas3Paths; | ||
components?: Oas3Components; | ||
paths?: Oas3Paths<T>; | ||
components?: T extends Oas3_1Schema ? Oas3_1Components : Oas3ComponentsBase<T>; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Related to https://github.com/Redocly/redocly-cli/pull/1795/files?diff=split&w=1#r1898410733 :
components?: T extends Oas3_1Schema ? Oas3_1Components : Oas3ComponentsBase<T>; | |
components?: T extends Oas3_1Schema ? Oas3_1Components : Oas3Components; |
fixes #1547
What/Why/How?
The typings for OAS 3 and OAS 3_1 schemas were incorrectly defined per the OpenAPI Specification.
OAS 3.0 has a specific requirement which defines an OpenAPI Schema rather than a JSON Schema schema. There are subtleties to the OpenAPI 3.0 Schema.
OpenAPI 3.1 Schemas are equivalent to a JSON Schema 2020-12 schema.
Reference
Per the OpenAPI 3.0 Specification
4.7.24.1 JSON Schema Keywords
The following keywords are taken directly from the JSON Schema definition and follow the same specifications:
The following keywords are taken from the JSON Schema definition but their definitions were adjusted to the OpenAPI Specification.
Alternatively, any time a Schema Object can be used, a Reference Object can be used in its place. This allows referencing definitions instead of defining them inline.
Additional keywords defined by the JSON Schema specification that are not mentioned here are strictly unsupported.
Other than the JSON Schema subset fields, the following fields MAY be used for further schema documentation:
4.7.24.2 Fixed Fields
Per the OpenAPI 3.1 Specification
4.8.24 Schema Object
The Schema Object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. This object is a superset of the JSON Schema Specification Draft 2020-12. The empty schema (which allows any instance to validate) MAY be represented by the boolean value true and a schema which allows no instance to validate MAY be represented by the boolean value false.
For more information about the keywords, see JSON Schema Core and JSON Schema Validation.
Unless stated otherwise, the keyword definitions follow those of JSON Schema and do not add any additional semantics; this includes keywords such as $schema, $id, $ref, and $dynamicRef being URIs rather than URLs. Where JSON Schema indicates that behavior is defined by the application (e.g. for annotations), OAS also defers the definition of semantics to the application consuming the OpenAPI document.
Testing
Screenshots (optional)
Check yourself
Security