Security News
Input Validation Vulnerabilities Dominate MITRE's 2024 CWE Top 25 List
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
openapi-ts-json-schema
Advanced tools
Generate TypeScript JSON schema files (.ts
modules with as const
assertions) from OpenAPI definitions.
TypeScript JSON schemas serve various purposes, including:
json-schema-to-ts
)@fastify/type-provider-json-schema-to-ts
)Given an OpenAPI definition file, openapi-ts-json-schema
will:
$ref
s and dereference them with @apidevtools/json-schema-ref-parser
$ref
s@openapi-contrib/openapi-schema-to-json-schema
and openapi-jsonschema-parameters
.ts
files with as const
assertion)TypeScript JSON schemas are 100% valid JSON schemas.
npm i openapi-ts-json-schema -D
Generate your TypeScript JSON schemas:
import { openapiToTsJsonSchema } from 'openapi-ts-json-schema';
const { outputPath } = await openapiToTsJsonSchema({
openApiSchema: 'path/to/open-api-specs.yaml',
definitionPathsToGenerateFrom: ['paths', 'components.schemas'],
});
...and use them in your TS project:
import Ajv from 'ajv';
import type { FromSchema } from 'json-schema-to-ts';
import mySchema from 'path/to/generated/schemas/MyModel.ts';
const ajv = new Ajv();
// Perform data validation and type inference using the same schema
const validate = ajv.compile<FromSchema<typeof mySchema>>(mySchema);
const data: unknown = {};
if (validate(data)) {
// data gets type inference
console.log(data.foo);
} else {
console.log(validate.errors);
}
Property | Type | Description | Default |
---|---|---|---|
openApiSchema (required) | string | Path to the OpenApi file (supports yaml and json). | - |
definitionPathsToGenerateFrom (required) | string[] | OpenApi definition object paths to generate the JSON schemas from. Only matching paths will be generated. Supports dot notation: ["components.schemas"] . | - |
refHandling | "import" | "inline" | "keep" | "import" : generate and import $ref schemas."inline" : inline $ref schemas."keep" : keep $ref values. | "import" |
$idMapper | (params: { id: string }) => string | Customize generated schemas $id s and $ref s | - |
schemaPatcher | (params: { schema: JSONSchema }) => void | Dynamically patch generated JSON schemas. The provided function will be invoked against every single JSON schema node. | - |
outputPath | string | Path where the generated schemas will be saved. Defaults to /schemas-autogenerated in the same directory of openApiSchema . | - |
plugins | ReturnType<Plugin>[] | A set of optional plugins to generate extra custom output. See plugins docs. | - |
silent | boolean | Don't log user messages. | false |
Take a look at the Developer's notes for a few more in-depth explanations.
$ref
s handlingopenapi-ts-json-schema
provides 3 refHandling
strategies for OpenAPI $ref
properties:
refHandling option | |
---|---|
inline | Replaces $ref s with inline copies of the target definition, creating self-contained schemas with potential redundancy |
import | Replaces $ref s with a local variable pointing to the module of the target $ref definition |
keep | Retains $ref s values without modification |
$ref
sCircular $ref
s references are supported, too:
refHandling option | |
---|---|
inline | Nested circular references are replaced with {} |
import | Completely resolves the JSON schema tree. However, the TypeScript engine will halt type recursion and assign the schema type as any , resulting in error ts(7022) |
keep | Does not resolve circular references by definition |
For further details, refer to the relevant tests.
Beside generating the expected schema files under outputPath
, openapiToTsJsonSchema
returns the following meta data:
{
// The path where the schemas are generated
outputPath: string;
metaData: {
// Meta data of the generated schemas
schemas: Map<
// Schema internal id. Eg: "/components/schemas/MySchema"
string,
{
id: string;
// Internal unique schema identifier. Eg `"/components/schemas/MySchema"`
$id: string;
// JSON schema Compound Schema Document `$id`. Eg: `"/components/schemas/MySchema"`
uniqueName: string;
// Unique JavaScript identifier used as import name. Eg: `"componentsSchemasMySchema"`
originalSchema: JSONSchema | string;
// Original dereferenced JSON schema
isRef: boolean;
// True if schemas is used as a `$ref`
absoluteDirName: string;
// Absolute path pointing to schema folder (posix or win32). Eg: `"Users/username/output/path/components/schemas"`
absolutePath: string;
// Absolute path pointing to schema file (posix or win32). Eg: `"Users/username/output/path/components/schemas/MySchema.ts"`
absoluteImportPath: string;
// Absolute import path (posix or win32, without extension). Eg: `"Users/username/output/path/components/schemas/MySchema"`
}
>;
}
}
Plugins are intended as a way to generate extra artifacts based on the same internal metadata created to generate the JSON schema output.
openapi-ts-json-schema
currently ships with one plugin specifically designed to better integrate with Fastify, but you can write your own!
Read plugins documentation 📖.
definitionPathsToGenerateFrom
option in favour of exporting the whole OpenAPI definitions based on the structure defined in specs#ref
s handling (currently being inlined and duplicated)0.10.0
sharedSchemasFilter
option renamed as schemaFilter
onInit
and onBeforeGeneration
methodsmetaData.schemas
entry registered by internal id (components/schemas/Foo
) instead of $ref
$idMapper
optionaddSchema
can resolveFAQs
OpenAPI to JSON schema generator with TypeScript in mind
The npm package openapi-ts-json-schema receives a total of 1,054 weekly downloads. As such, openapi-ts-json-schema popularity was classified as popular.
We found that openapi-ts-json-schema demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
MITRE's 2024 CWE Top 25 highlights critical software vulnerabilities like XSS, SQL Injection, and CSRF, reflecting shifts due to a refined ranking methodology.
Security News
In this segment of the Risky Business podcast, Feross Aboukhadijeh and Patrick Gray discuss the challenges of tracking malware discovered in open source softare.
Research
Security News
A threat actor's playbook for exploiting the npm ecosystem was exposed on the dark web, detailing how to build a blockchain-powered botnet.