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
-
@effect/schema
: Required for inference, validation, and serialization (^0.71.1
) -
effect
: Required for inference and validation (^3.6.5
)
-
Infer<TSchema>
: Extracts the output type of a schema -
InferIn<TSchema>
: Extracts the input type of a schema
-
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 anAggregateError
-
toJSONSchema(schema)
: Converts the schema into the equivalent JSON schema