json-schema-typed
v8.0.1
Published
JSON Schema TypeScript definitions with complete inline documentation.
Downloads
3,545,096
Maintainers
Readme
JSON Schema Typed
JSON Schema TypeScript definitions with complete inline documentation.
NOTE: This library only supports defining schemas. You will need a separate library for data validation.
There are 3 JSON Schema drafts included in this package:
draft-07
draft-2019-09
draft-2020-12
Install
npm install json-schema-typed
Usage
- Chose which draft you'd like to import.
The main package export points to the latest supported stable draft, currently
draft-2020-12
. Future releases that point the main package export to a new draft will always incur a bump to the major semantic version.import { type JSONSchema } from "json-schema-typed";
Or you can specify the exact draft you need.
import { type JSONSchema } from "json-schema-typed/draft-2020-12";
Define a schema
import { Format, type JSONSchema } from "json-schema-typed"; const schema: JSONSchema = { properties: { email: { format: Format.Email, type: "string", }, }, type: "object", }; // The JSONSchema namespace also provides type-specific narrowed interfaces const stringSchema: JSONSchema.String = { // Only { type: "string" } and common keywords are allowed maxLength: 100, type: "string", };
Upgrading
Version 8.0.0
has breaking changes from the previous release.
- Now a pure ESM package.
- Many exports were renamed. The table below reflects the new export names. These are considered final and unlikely to change in future releases.
- The
JSONSchema
type was changed from aninterface
to atype
which is a mixed union that allowsboolean
values in order to properly align with the JSON Schema spec. If you were previously extending theJSONSchema
interface, you can access theinterface
directly withJSONSchema.Interface
. - The previous main package export pointed to Draft 7. Import it directly if you
need to continue using it:
import { type JSONSchema } from "json-schema-typed/draft-07";
Exports supported in each draft module
| Name | Type | Purpose |
| ----------------- | --------------- | ------------------------------------------------------------------ |
| $schema
| string
| Draft meta schema URL that can be used with the $schema
keyword. |
| ContentEncoding
| Enum object | String content encoding strategies. |
| draft
| string
| Draft version. |
| Format
| Enum object | String formats. |
| JSONSchema
| TypeScript Type | Used to define a JSON Schema. |
| keywords
| string[]
| All the keywords for the imported draft. |
| TypeName
| Enum object | Simple type names for the type
keyword. |
Versioning
This library follows semantic versioning.