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 }); });