You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
The schema contains many inline schemas (that should be using re-usable components) and many inline schemas and components that have duplicate title properties
This causes problems when using tools like json-schema-to-typescript where you end up with many TypeScript interfaces named User_3, Repository_1, etc.
Expected
No inline schemas for re-used definitions, or schemas that have the same title
Reproduction Steps
This script logs all duplicate title properties found
@wolfy1339 Thanks for opening this issue. The JSON Schema spec provides this documentation for the title field1:
The title keyword in JSON Schema is used to provide a human-readable label for a schema or its parts. It does not affect data validation but serves as an informative annotation.
Since the title is just meta data for the schema and not intended to be a unique identifier, we don't consider the duplicate titles an issue in our schema. I would work with the maintainer of the json-schema-to-typescript and see if they have a way to work around that. Alternatively, GitHub does provide openapi-types, a library of Typescript definitions generated from our OpenAPI schema.
Yes, I am aware of all those points. I am also very aware of openapi-types, as I help maintain it.
The duplicate titles are pointing to a bigger issue, those items should most likely be using the reusable components or have a different title that explains the difference between the reusable component and that inline definition.
Example, having the title be App Instance on many of them isn't very informative considering there is already a reusable component with the same title. What is different between that one and the reusable component? Maybe it's App Instance With Organization, or App Instance Owned By Organization?
I understand that titles aren't necessarily unique, but I believe that this points to a bigger issue of general duplication within the OpenAPI spec and should be looked at for each occurrence to see if there is a way to reduce the duplication.
The schema is already a mighty 10MB.
I hope you understand the point I'm trying to make with this issue.
Schema Inaccuracy
The schema contains many inline schemas (that should be using re-usable components) and many inline schemas and components that have duplicate
title
propertiesThis causes problems when using tools like
json-schema-to-typescript
where you end up with many TypeScript interfaces namedUser_3
,Repository_1
, etc.Expected
No inline schemas for re-used definitions, or schemas that have the same title
Reproduction Steps
This script logs all duplicate
title
properties foundHere is the list of duplicates I have found, which is too long to post directly into the issue body:
duplicates.txt
The text was updated successfully, but these errors were encountered: