|
@@ -6,6 +6,7 @@ const PROTOCOL = process.env.PROTOCOL ?? DEFAULT_PROTOCOL;
|
|
const BASE_URL = process.env.BASE_URL ?? OPENAI_URL;
|
|
const BASE_URL = process.env.BASE_URL ?? OPENAI_URL;
|
|
|
|
|
|
export async function requestOpenai(req: NextRequest) {
|
|
export async function requestOpenai(req: NextRequest) {
|
|
|
|
+ const controller = new AbortController();
|
|
const authValue = req.headers.get("Authorization") ?? "";
|
|
const authValue = req.headers.get("Authorization") ?? "";
|
|
const openaiPath = `${req.nextUrl.pathname}${req.nextUrl.search}`.replaceAll(
|
|
const openaiPath = `${req.nextUrl.pathname}${req.nextUrl.search}`.replaceAll(
|
|
"/api/openai/",
|
|
"/api/openai/",
|
|
@@ -25,16 +26,31 @@ export async function requestOpenai(req: NextRequest) {
|
|
console.log("[Org ID]", process.env.OPENAI_ORG_ID);
|
|
console.log("[Org ID]", process.env.OPENAI_ORG_ID);
|
|
}
|
|
}
|
|
|
|
|
|
- return fetch(`${baseUrl}/${openaiPath}`, {
|
|
|
|
- headers: {
|
|
|
|
- "Content-Type": "application/json",
|
|
|
|
- Authorization: authValue,
|
|
|
|
- ...(process.env.OPENAI_ORG_ID && {
|
|
|
|
- "OpenAI-Organization": process.env.OPENAI_ORG_ID,
|
|
|
|
- }),
|
|
|
|
- },
|
|
|
|
- cache: "no-store",
|
|
|
|
- method: req.method,
|
|
|
|
- body: req.body,
|
|
|
|
- });
|
|
|
|
|
|
+ const timeoutId = setTimeout(() => {
|
|
|
|
+ controller.abort();
|
|
|
|
+ }, 10 * 60 * 1000);
|
|
|
|
+
|
|
|
|
+ try {
|
|
|
|
+ return await fetch(`${baseUrl}/${openaiPath}`, {
|
|
|
|
+ headers: {
|
|
|
|
+ "Content-Type": "application/json",
|
|
|
|
+ Authorization: authValue,
|
|
|
|
+ ...(process.env.OPENAI_ORG_ID && {
|
|
|
|
+ "OpenAI-Organization": process.env.OPENAI_ORG_ID,
|
|
|
|
+ }),
|
|
|
|
+ },
|
|
|
|
+ cache: "no-store",
|
|
|
|
+ method: req.method,
|
|
|
|
+ body: req.body,
|
|
|
|
+ signal: controller.signal,
|
|
|
|
+ });
|
|
|
|
+ } catch (err: unknown) {
|
|
|
|
+ if (err instanceof Error && err.name === 'AbortError') {
|
|
|
|
+ console.log('Fetch aborted');
|
|
|
|
+ } else {
|
|
|
|
+ throw err;
|
|
|
|
+ }
|
|
|
|
+ } finally {
|
|
|
|
+ clearTimeout(timeoutId);
|
|
|
|
+ }
|
|
}
|
|
}
|