- 更新客户端类型引用,将APIClient替换为RouterClient以保持类型一致性。 - 删除旧的 RPC 合约定义文件,移除过时的类型和验证逻辑。 - 添加合约入口文件并导出待办事项合约 - 添加待办事项合约,定义列表、创建、更新和删除操作的输入输出验证规则。 - 更新 todo 处理程序以使用统一的合约导入并简化导入路径。 - 调整导出内容,仅导出客户端的orpc函数和类型模块。 - 使用合约类型替换原有路由客户端类型,并引入合约输入输出的类型推断。
52 lines
1.3 KiB
TypeScript
52 lines
1.3 KiB
TypeScript
import { implement, ORPCError } from '@orpc/server'
|
|
import { eq } from 'drizzle-orm'
|
|
import { todoTable } from '@/db/schema'
|
|
import { dbProvider } from '@/orpc/middlewares'
|
|
import { contract } from '../contracts'
|
|
|
|
export const list = implement(contract.todo.list)
|
|
.use(dbProvider)
|
|
.handler(async ({ context }) => {
|
|
const todos = await context.db.query.todoTable.findMany({
|
|
orderBy: (todos, { desc }) => [desc(todos.createdAt)],
|
|
})
|
|
return todos
|
|
})
|
|
|
|
export const create = implement(contract.todo.create)
|
|
.use(dbProvider)
|
|
.handler(async ({ context, input }) => {
|
|
const [newTodo] = await context.db
|
|
.insert(todoTable)
|
|
.values(input)
|
|
.returning()
|
|
|
|
if (!newTodo) {
|
|
throw new ORPCError('NOT_FOUND')
|
|
}
|
|
|
|
return newTodo
|
|
})
|
|
|
|
export const update = implement(contract.todo.update)
|
|
.use(dbProvider)
|
|
.handler(async ({ context, input }) => {
|
|
const [updatedTodo] = await context.db
|
|
.update(todoTable)
|
|
.set(input.data)
|
|
.where(eq(todoTable.id, input.id))
|
|
.returning()
|
|
|
|
if (!updatedTodo) {
|
|
throw new ORPCError('NOT_FOUND')
|
|
}
|
|
|
|
return updatedTodo
|
|
})
|
|
|
|
export const remove = implement(contract.todo.remove)
|
|
.use(dbProvider)
|
|
.handler(async ({ context, input }) => {
|
|
await context.db.delete(todoTable).where(eq(todoTable.id, input.id))
|
|
})
|