43 lines
1.3 KiB
TypeScript
43 lines
1.3 KiB
TypeScript
import { NextRequest, NextResponse } from 'next/server';
|
|
|
|
const API_BASE = process.env.API_URL || 'https://ai.aaronnelson.studio';
|
|
|
|
async function handler(request: NextRequest, { params }: { params: Promise<{ slug: string[] }> }) {
|
|
const { slug } = await params;
|
|
const path = '/' + slug.join('/');
|
|
const url = `${API_BASE}${path}${request.nextUrl.search}`;
|
|
|
|
const headers = new Headers();
|
|
const contentType = request.headers.get('content-type');
|
|
if (contentType) headers.set('content-type', contentType);
|
|
const cookie = request.headers.get('cookie');
|
|
if (cookie) headers.set('cookie', cookie);
|
|
|
|
const body = request.method !== 'GET' && request.method !== 'HEAD'
|
|
? await request.blob()
|
|
: undefined;
|
|
|
|
const response = await fetch(url, {
|
|
method: request.method,
|
|
headers,
|
|
body,
|
|
});
|
|
|
|
const responseHeaders = new Headers();
|
|
const setCookie = response.headers.get('set-cookie');
|
|
if (setCookie) responseHeaders.set('set-cookie', setCookie);
|
|
responseHeaders.set('content-type', response.headers.get('content-type') || 'application/json');
|
|
|
|
return new NextResponse(response.body, {
|
|
status: response.status,
|
|
headers: responseHeaders,
|
|
});
|
|
}
|
|
|
|
export const GET = handler;
|
|
export const POST = handler;
|
|
export const PUT = handler;
|
|
export const PATCH = handler;
|
|
export const DELETE = handler;
|
|
export const OPTIONS = handler;
|