feat: enhance API response handling and add new components for module management
This commit is contained in:
@@ -1,13 +1,36 @@
|
||||
import { NextResponse } from 'next/server';
|
||||
import * as z from 'zod';
|
||||
|
||||
import {
|
||||
apiError,
|
||||
apiSuccess,
|
||||
emailSchema,
|
||||
requiredString,
|
||||
} from '@kit/next/route-helpers';
|
||||
import { getLogger } from '@kit/shared/logger';
|
||||
import { getSupabaseServerAdminClient } from '@kit/supabase/server-admin-client';
|
||||
|
||||
const EventRegisterSchema = z.object({
|
||||
eventId: requiredString('Event-ID'),
|
||||
firstName: requiredString('Vorname'),
|
||||
lastName: requiredString('Nachname'),
|
||||
email: emailSchema,
|
||||
phone: z.string().optional(),
|
||||
dateOfBirth: z.string().optional(),
|
||||
parentName: z.string().optional(),
|
||||
parentPhone: z.string().optional(),
|
||||
});
|
||||
|
||||
export async function POST(request: Request) {
|
||||
const logger = await getLogger();
|
||||
|
||||
try {
|
||||
const body = await request.json();
|
||||
const parsed = EventRegisterSchema.safeParse(body);
|
||||
|
||||
if (!parsed.success) {
|
||||
return apiError(parsed.error.issues[0]?.message ?? 'Ungültige Eingabe');
|
||||
}
|
||||
|
||||
const {
|
||||
eventId,
|
||||
firstName,
|
||||
@@ -17,21 +40,7 @@ export async function POST(request: Request) {
|
||||
dateOfBirth,
|
||||
parentName,
|
||||
parentPhone,
|
||||
} = body;
|
||||
|
||||
if (!eventId || !firstName || !lastName || !email) {
|
||||
return NextResponse.json(
|
||||
{ error: 'Event-ID, Vorname, Nachname und E-Mail sind erforderlich' },
|
||||
{ status: 400 },
|
||||
);
|
||||
}
|
||||
|
||||
if (!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email)) {
|
||||
return NextResponse.json(
|
||||
{ error: 'Ungültige E-Mail-Adresse' },
|
||||
{ status: 400 },
|
||||
);
|
||||
}
|
||||
} = parsed.data;
|
||||
|
||||
const supabase = getSupabaseServerAdminClient();
|
||||
|
||||
@@ -53,21 +62,15 @@ export async function POST(request: Request) {
|
||||
{ error, context: 'event-register-insert' },
|
||||
'[event-register] Insert error',
|
||||
);
|
||||
return NextResponse.json(
|
||||
{ error: 'Anmeldung fehlgeschlagen' },
|
||||
{ status: 500 },
|
||||
);
|
||||
return apiError('Anmeldung fehlgeschlagen', 500);
|
||||
}
|
||||
|
||||
return NextResponse.json({
|
||||
success: true,
|
||||
message: 'Anmeldung erfolgreich',
|
||||
});
|
||||
return apiSuccess({ message: 'Anmeldung erfolgreich' });
|
||||
} catch (err) {
|
||||
logger.error(
|
||||
{ error: err, context: 'event-register' },
|
||||
'[event-register] Error',
|
||||
);
|
||||
return NextResponse.json({ error: 'Serverfehler' }, { status: 500 });
|
||||
return apiError('Serverfehler', 500);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user