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 }
);
}
}