Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

@typeschema/json

decs177MIT0.14.0TypeScript support: included

Reusable adapter for JSON schemas

typescript, type, schema, adapter, validation, inference, assert

readme

TypeSchema

@typeschema/json

License Bundle size npm downloads GitHub stars

Reusable adapter for JSON schemas
https://typeschema.com

import {initTRPC} from '@trpc/server';

import {wrap} from '@typeschema/json';

const schema = {
  additionalProperties: false,
  properties: {name: {type: 'string'}},
  required: ['name'],
  type: 'object',
} as const;

const t = initTRPC.create();
const appRouter = t.router({
  hello: t.procedure
    .input(wrap(schema))
    .query(({input}) => `Hello, ${(input as any).name}!`),
  //         ^? {name: string}
});

Use it directly or through @typeschema/main

Dependencies

  • ajv: Required for validation and serialization (^8.17.1)
  • json-schema-to-ts: Required for inference (^3.1.0)

API

Inference

  • Infer<TSchema>: Extracts the output type of a schema
  • InferIn<TSchema>: Extracts the input type of a schema

Validation

  • wrap(schema): Returns the wrapped schema with access to its operations
  • validate(schema, data): Returns the validated data or a list of validation issues
  • assert(schema, data): Returns the validated data or throws an AggregateError

Serialization

  • toJSONSchema(schema): Converts the schema into the equivalent JSON schema