feat: added drizzle for contact management

This commit is contained in:
DESKTOP-RTLN3BA\$punk 2025-09-30 21:36:07 -07:00
parent 1a3faf03d5
commit ba62489715
8 changed files with 762 additions and 18 deletions

View file

@ -0,0 +1,59 @@
import { NextRequest, NextResponse } from 'next/server';
import { db } from '@/app/db';
import { usersTable } from '@/app/db/schema';
import { z } from 'zod';
// Define validation schema matching the database schema
const contactSchema = z.object({
name: z.string().min(1, 'Name is required').max(255, 'Name is too long'),
email: z.string().email('Invalid email address').max(255, 'Email is too long'),
company: z.string().min(1, 'Company is required').max(255, 'Company name is too long'),
message: z.string().optional().default(''),
});
export async function POST(request: NextRequest) {
try {
const body = await request.json();
// Validate the request body
const validatedData = contactSchema.parse(body);
// Insert into database
const result = await db.insert(usersTable).values({
name: validatedData.name,
email: validatedData.email,
company: validatedData.company,
message: validatedData.message,
}).returning();
return NextResponse.json(
{
success: true,
message: 'Contact form submitted successfully',
data: result[0]
},
{ status: 201 }
);
} catch (error) {
if (error instanceof z.ZodError) {
return NextResponse.json(
{
success: false,
message: 'Validation error',
errors: error.errors
},
{ status: 400 }
);
}
console.error('Error submitting contact form:', error);
return NextResponse.json(
{
success: false,
message: 'Failed to submit contact form'
},
{ status: 500 }
);
}
}

View file

@ -0,0 +1,6 @@
import { drizzle } from 'drizzle-orm/postgres-js'
import postgres from 'postgres'
import * as schema from './schema'
const client = postgres(process.env.DATABASE_URL!)
export const db = drizzle({ client, schema });

View file

@ -0,0 +1,9 @@
import { integer, pgTable, text, varchar } from "drizzle-orm/pg-core";
export const usersTable = pgTable("users", {
id: integer().primaryKey().generatedAlwaysAsIdentity(),
name: varchar({ length: 255 }).notNull(),
email: varchar({ length: 255 }).notNull().unique(),
company: varchar({ length: 255 }).notNull(),
message: text().default(''),
});