722440b9b5
Ersätter getAuthHeaders() + auth() standalone med withAuth() wrapper i alla route handlers. Auth() standalone fungerar inte korrekt i Next.js 16 + NextAuth beta.28 pga async cookies() kompatibilitet. withAuth() använder auth() i wrapper-form sa att request.auth populeras direkt av NextAuth. Pavaerkade filer: 27 route handlers + ny lib/with-auth.ts
31 lines
1.2 KiB
TypeScript
31 lines
1.2 KiB
TypeScript
import { NextResponse } from 'next/server';
|
|
import { withAuth } from '../../../lib/with-auth';
|
|
|
|
export const POST = withAuth(async (request, session) => {
|
|
try {
|
|
const contentType = request.headers.get('content-type') ?? '';
|
|
const isMultipart = contentType.includes('multipart/form-data');
|
|
const backendUrl = process.env.NEXT_PUBLIC_API_URL_INTERNAL || 'http://recipe-api:8080';
|
|
|
|
const response = await fetch(`${backendUrl}/api/quick-import`, {
|
|
method: 'POST',
|
|
body: isMultipart
|
|
? await request.formData()
|
|
: JSON.stringify(await request.json()),
|
|
headers: isMultipart
|
|
? { Authorization: `Bearer ${session.accessToken}` }
|
|
: { 'Content-Type': 'application/json', Authorization: `Bearer ${session.accessToken}` },
|
|
cache: 'no-store',
|
|
});
|
|
|
|
const text = await response.text();
|
|
return new NextResponse(text, {
|
|
status: response.status,
|
|
headers: { 'Content-Type': response.headers.get('content-type') ?? 'application/json' },
|
|
});
|
|
} catch (error) {
|
|
console.error('[QuickImportProxy] EXCEPTION:', error);
|
|
return NextResponse.json({ message: 'Kunde inte nå importtjänsten.' }, { status: 503 });
|
|
}
|
|
});
|