Files
myeasycms-v2/apps/web/app/api/club/newsletter/route.ts

67 lines
1.7 KiB
TypeScript

import { NextResponse } from 'next/server';
import { createClient } from '@supabase/supabase-js';
import { getLogger } from '@kit/shared/logger';
export async function POST(request: Request) {
const logger = await getLogger();
try {
const body = await request.json();
const { accountId, email, name } = body;
if (!accountId || !email) {
return NextResponse.json(
{ error: 'accountId und email sind erforderlich' },
{ status: 400 },
);
}
// Validate email format
if (!/^[^\s@]+@[^\s@]+\.[^\s@]+$/.test(email)) {
return NextResponse.json(
{ error: 'Ungültige E-Mail-Adresse' },
{ status: 400 },
);
}
const supabase = createClient(
process.env.NEXT_PUBLIC_SUPABASE_URL!,
process.env.SUPABASE_SERVICE_ROLE_KEY ||
process.env.NEXT_PUBLIC_SUPABASE_PUBLIC_KEY!,
);
const token = crypto.randomUUID();
const { error } = await supabase.from('newsletter_subscriptions').upsert(
{
account_id: accountId,
email,
name: name || null,
confirmation_token: token,
is_active: true,
},
{ onConflict: 'account_id,email' },
);
if (error) {
logger.error(
{ error, context: 'newsletter-subscription' },
'[newsletter] Subscription error',
);
return NextResponse.json(
{ error: 'Anmeldung fehlgeschlagen' },
{ status: 500 },
);
}
return NextResponse.json({
success: true,
message: 'Erfolgreich angemeldet',
});
} catch (err) {
logger.error({ error: err, context: 'newsletter' }, '[newsletter] Error');
return NextResponse.json({ error: 'Serverfehler' }, { status: 500 });
}
}