Skip to content

Latest commit

 

History

History

effect

Folders and files

NameName
Last commit message
Last commit date

parent directory

..
 
 
 
 
 
 
 
 
 
 

TypeSchema

@typeschema/effect

License Bundle size npm downloads GitHub stars

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

import * as S from '@effect/schema/Schema';
import {initTRPC} from '@trpc/server';

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

const schema = S.struct({name: S.string});

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

Use it directly or through @typeschema/main

Dependencies

  • @effect/schema: Required for inference, validation, and serialization (^0.71.1)
  • effect: Required for inference and validation (^3.6.5)

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