🚀 Big News: Socket Acquires Coana to Bring Reachability Analysis to Every Appsec Team.Learn more
Socket
Book a DemoInstallSign in
Socket

openapi-ts-json-schema

Package Overview
Dependencies
Maintainers
1
Versions
17
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

openapi-ts-json-schema

OpenAPI to JSON schema generator with TypeScript in mind

0.2.0
Source
npm
Version published
Weekly downloads
1.3K
-5.55%
Maintainers
1
Weekly downloads
 
Created
Source

openapi-ts-json-schema

Build Status Npm version Coveralls

Generate JSON schema TypeScript files (.ts) from OpenAPI definitions which can be natively used to infer types from (with json-schema-to-ts or fastify-type-provider-json-schema-to-ts).

Given an OpenAPI definition file, openapi-ts-json-schema will:

Installation

npm i openapi-ts-json-schema -D

Usage

import { openapiToTsJsonSchema } from 'openapi-ts-json-schema';

const { outputPath } = await openapiToTsJsonSchema({
  openApiSchema: 'path/to/open-api-specs.yaml',
  definitionPathsToGenerateFrom: ['paths', 'components.schemas'],
});

...then in your code:

import Ajv from 'ajv';
import { FromSchema } from 'json-schema-to-ts';
import myModelSchema from 'path/to/schemas-autogenerated/MyModel.ts';

// Use generated JSON schemas as usual
const ajv = new Ajv();
const valid = ajv.validate(myModelSchema, { hello: 'World' });

// Use generated JSON schemas to infer model types from
type MyModel = FromSchema<typeof myModelSchema>;

Notes

Generated JSON schema path names get escaped in order to be valid file system names.

Options

PropertyTypeDescriptionDefault
openApiSchema (required)stringPath 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"]).-
schemaPatcher(params: { schema: JSONSchema }) => voidDynamically patch generated JSON schemas. The provided function will be invoked against every single JSON schema node.-
outputPathstringPath where the generated schemas will be saved. Defaults to /schemas-autogenerated in same directory as provided openApiSchema.-
silentbooleanDon't console.log user messages.false

Todo

  • Explore ability to import dereferenced schemas instead of inlining
  • Consider merging "operation" and "path" parameters definition
  • Consider removing required definitionPathsToGenerateFrom option in favour of exporting the whole OpenAPI definitions based on the structure defined in specs

Keywords

openapi

FAQs

Package last updated on 13 Aug 2023

Did you know?

Socket

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.

Install

Related posts