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
36 lines
1.4 KiB
TypeScript
36 lines
1.4 KiB
TypeScript
import { NextResponse } from 'next/server';
|
|
import { withAuth } from '../../../../lib/with-auth';
|
|
|
|
const API_BASE = process.env.NEXT_PUBLIC_API_URL_INTERNAL || 'http://recipe-api:8080';
|
|
|
|
export const GET = withAuth(async (request, session, context) => {
|
|
const { id } = await context.params;
|
|
const res = await fetch(`${API_BASE}/api/recipes/${id}`, {
|
|
headers: { Authorization: `Bearer ${session.accessToken}` },
|
|
cache: 'no-store',
|
|
});
|
|
const text = await res.text();
|
|
return new NextResponse(text, { status: res.status, headers: { 'Content-Type': 'application/json' } });
|
|
});
|
|
|
|
export const PATCH = withAuth(async (request, session, context) => {
|
|
const { id } = await context.params;
|
|
const body = await request.json();
|
|
const res = await fetch(`${API_BASE}/api/recipes/${id}`, {
|
|
method: 'PATCH',
|
|
headers: { 'Content-Type': 'application/json', Authorization: `Bearer ${session.accessToken}` },
|
|
body: JSON.stringify(body),
|
|
});
|
|
const text = await res.text();
|
|
return new NextResponse(text, { status: res.status, headers: { 'Content-Type': 'application/json' } });
|
|
});
|
|
|
|
export const DELETE = withAuth(async (_request, session, context) => {
|
|
const { id } = await context.params;
|
|
const res = await fetch(`${API_BASE}/api/recipes/${id}`, {
|
|
method: 'DELETE',
|
|
headers: { Authorization: `Bearer ${session.accessToken}` },
|
|
});
|
|
return new NextResponse(null, { status: res.status });
|
|
});
|