drizzle-valibot

drizzle-valibot 是一个 Drizzle ORM 的插件,它允许您从 Drizzle ORM 模式中生成 valibot 模式。

安装依赖

npm
yarn
pnpm
bun
npm i drizzle-valibot

使用方法

import { pgEnum, pgTable, serial, text, timestamp } from 'drizzle-orm/pg-core';
import { createInsertSchema, createSelectSchema } from 'drizzle-valibot';
import { string, parse, number } from 'valibot';

const users = pgTable('users', {
  id: serial('id').primaryKey(),
  name: text('name').notNull(),
  email: text('email').notNull(),
  role: text('role', { enum: ['admin', 'user'] }).notNull(),
  createdAt: timestamp('created_at').notNull().defaultNow(),
});

// 插入用户的模式 - 可以用来验证 API 请求
const insertUserSchema = createInsertSchema(users);

// 选择用户的模式 - 可以用来验证 API 响应
const selectUserSchema = createSelectSchema(users);

// 覆盖字段
const insertUserSchema = createInsertSchema(users, {
  role: string(),
});

// 精炼字段 - 如果您想在它们在最终模式中变为可选/可为空之前改变字段
const insertUserSchema = createInsertSchema(users, {
  id: (schema) => number([minValue(0)]),
  role: string(),
});

// 使用方法

const isUserValid = parse(insertUserSchema, {
  name: 'John Doe',
  email: 'johndoe@test.com',
  role: 'admin',
});
Become a Gold Sponsor