feat: add TypeScript definitions for next-auth session with accessToken and user details
Test Suite / test (24.15.0) (push) Has been cancelled

This commit is contained in:
Nils-Johan Gynther
2026-05-04 20:09:21 +02:00
parent afd2607000
commit ffe50e5151
135 changed files with 5 additions and 38 deletions
@@ -0,0 +1,46 @@
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();
try {
const parsed = JSON.parse(text);
// eslint-disable-next-line no-console
console.log('[QuickImportProxy] backend response', {
status: response.status,
hasMarkdown: Boolean(parsed?.markdown),
imageUrl: parsed?.imageUrl ?? null,
imageWarning: parsed?.imageWarning ?? null,
});
} catch {
// eslint-disable-next-line no-console
console.log('[QuickImportProxy] backend non-json response', {
status: response.status,
contentType: response.headers.get('content-type'),
});
}
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 });
}
});