Reusable adapter for VineJS schemas
https://typeschema.com ✨
import {initTRPC} from '@trpc/server';
import vine from '@vinejs/vine';
import {wrap} from '@typeschema/vine';
const schema = vine.object({name: vine.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
@vinejs/vine
: Required for inference and validation (^2.1.0
)
Infer<TSchema>
: Extracts the output type of a schemaInferIn<TSchema>
: Extracts the input type of a schema
wrap(schema)
: Returns the wrapped schema with access to its operationsvalidate(schema, data)
: Returns the validated data or a list of validation issuesassert(schema, data)
: Returns the validated data or throws anAggregateError