79 lines
1.9 KiB
TypeScript
79 lines
1.9 KiB
TypeScript
import { NextResponse } from 'next/server';
|
|
|
|
import { getLogger } from '@kit/shared/logger';
|
|
import { getSupabaseServerAdminClient } from '@kit/supabase/server-admin-client';
|
|
|
|
export async function POST(request: Request) {
|
|
const logger = await getLogger();
|
|
|
|
try {
|
|
const body = await request.json();
|
|
const {
|
|
accountId,
|
|
firstName,
|
|
lastName,
|
|
email,
|
|
phone,
|
|
street,
|
|
postalCode,
|
|
city,
|
|
dateOfBirth,
|
|
message,
|
|
} = body;
|
|
|
|
if (!accountId || !firstName || !lastName || !email) {
|
|
return NextResponse.json(
|
|
{
|
|
error: 'Konto-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 },
|
|
);
|
|
}
|
|
|
|
const supabase = getSupabaseServerAdminClient();
|
|
|
|
const { error } = await supabase.from('membership_applications').insert({
|
|
account_id: accountId,
|
|
first_name: firstName,
|
|
last_name: lastName,
|
|
email,
|
|
phone: phone || null,
|
|
street: street || null,
|
|
postal_code: postalCode || null,
|
|
city: city || null,
|
|
date_of_birth: dateOfBirth || null,
|
|
message: message || null,
|
|
status: 'submitted',
|
|
});
|
|
|
|
if (error) {
|
|
logger.error(
|
|
{ error, context: 'membership-apply-insert' },
|
|
'[membership-apply] Insert error',
|
|
);
|
|
return NextResponse.json(
|
|
{ error: 'Bewerbung fehlgeschlagen' },
|
|
{ status: 500 },
|
|
);
|
|
}
|
|
|
|
return NextResponse.json({
|
|
success: true,
|
|
message: 'Bewerbung erfolgreich eingereicht',
|
|
});
|
|
} catch (err) {
|
|
logger.error(
|
|
{ error: err, context: 'membership-apply' },
|
|
'[membership-apply] Error',
|
|
);
|
|
return NextResponse.json({ error: 'Serverfehler' }, { status: 500 });
|
|
}
|
|
}
|