import { resolver, SecurePassword } from "blitz" import db, { Role } from "../../../db" import { Signup } from "../validations" import { computeEncryptionKey } from "../../../db/_encryption" export default resolver.pipe(resolver.zod(Signup), async ({ email, password }, ctx) => { const hashedPassword = await SecurePassword.hash(password.trim()) const user = await db.user.create({ data: { email: email.toLowerCase().trim(), hashedPassword, role: Role.USER }, select: { id: true, name: true, email: true, role: true }, }) const encryptionKey = computeEncryptionKey(user.id).toString("hex") await db.customer.create({ data: { id: user.id, encryptionKey } }) await ctx.session.$create({ userId: user.id, role: user.role }) return user })