@superinterface/server 1.1.5 → 1.1.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/build-manifest.json +2 -2
  3. package/.next/cache/.tsbuildinfo +1 -1
  4. package/.next/cache/eslint/.cache_btwyo7 +1 -1
  5. package/.next/fallback-build-manifest.json +2 -2
  6. package/.next/server/app/_not-found.html +1 -1
  7. package/.next/server/app/_not-found.rsc +1 -1
  8. package/.next/server/app/api/workspaces/[workspaceId]/route.js +1 -1
  9. package/.next/server/app/index.html +1 -1
  10. package/.next/server/app/index.rsc +1 -1
  11. package/.next/server/chunks/[root-of-the-server]__0a426407._.js +1 -1
  12. package/.next/server/chunks/[root-of-the-server]__0a426407._.js.map +1 -1
  13. package/.next/server/chunks/[root-of-the-server]__0c1bc5ed._.js +1 -1
  14. package/.next/server/chunks/[root-of-the-server]__0c1bc5ed._.js.map +1 -1
  15. package/.next/server/chunks/[root-of-the-server]__1a7a04d0._.js +1 -1
  16. package/.next/server/chunks/[root-of-the-server]__1a7a04d0._.js.map +1 -1
  17. package/.next/server/chunks/[root-of-the-server]__2945c9e9._.js +1 -1
  18. package/.next/server/chunks/[root-of-the-server]__2945c9e9._.js.map +1 -1
  19. package/.next/server/chunks/[root-of-the-server]__315f084a._.js +1 -1
  20. package/.next/server/chunks/[root-of-the-server]__315f084a._.js.map +1 -1
  21. package/.next/server/chunks/[root-of-the-server]__42ed6203._.js +1 -1
  22. package/.next/server/chunks/[root-of-the-server]__42ed6203._.js.map +1 -1
  23. package/.next/server/chunks/[root-of-the-server]__4c8c04a2._.js +1 -1
  24. package/.next/server/chunks/[root-of-the-server]__4c8c04a2._.js.map +1 -1
  25. package/.next/server/chunks/[root-of-the-server]__4e536bc0._.js +1 -1
  26. package/.next/server/chunks/[root-of-the-server]__4e536bc0._.js.map +1 -1
  27. package/.next/server/chunks/[root-of-the-server]__583a7f1c._.js +1 -1
  28. package/.next/server/chunks/[root-of-the-server]__583a7f1c._.js.map +1 -1
  29. package/.next/server/chunks/[root-of-the-server]__5abf1160._.js +1 -1
  30. package/.next/server/chunks/[root-of-the-server]__5abf1160._.js.map +1 -1
  31. package/.next/server/chunks/[root-of-the-server]__5aedcd8a._.js +1 -1
  32. package/.next/server/chunks/[root-of-the-server]__5aedcd8a._.js.map +1 -1
  33. package/.next/server/chunks/[root-of-the-server]__62d958e7._.js +1 -1
  34. package/.next/server/chunks/[root-of-the-server]__62d958e7._.js.map +1 -1
  35. package/.next/server/chunks/[root-of-the-server]__630959e5._.js +1 -1
  36. package/.next/server/chunks/[root-of-the-server]__630959e5._.js.map +1 -1
  37. package/.next/server/chunks/[root-of-the-server]__83461316._.js +1 -1
  38. package/.next/server/chunks/[root-of-the-server]__83461316._.js.map +1 -1
  39. package/.next/server/chunks/[root-of-the-server]__9a611d42._.js +1 -1
  40. package/.next/server/chunks/[root-of-the-server]__9a611d42._.js.map +1 -1
  41. package/.next/server/chunks/[root-of-the-server]__a9fab3b2._.js +1 -1
  42. package/.next/server/chunks/[root-of-the-server]__a9fab3b2._.js.map +1 -1
  43. package/.next/server/chunks/[root-of-the-server]__b10ec83e._.js +1 -1
  44. package/.next/server/chunks/[root-of-the-server]__b10ec83e._.js.map +1 -1
  45. package/.next/server/chunks/[root-of-the-server]__c1629392._.js +1 -1
  46. package/.next/server/chunks/[root-of-the-server]__c1629392._.js.map +1 -1
  47. package/.next/server/chunks/[root-of-the-server]__e73543af._.js +1 -1
  48. package/.next/server/chunks/[root-of-the-server]__e73543af._.js.map +1 -1
  49. package/.next/server/chunks/[root-of-the-server]__e8127a36._.js +1 -1
  50. package/.next/server/chunks/[root-of-the-server]__e8127a36._.js.map +1 -1
  51. package/.next/server/chunks/c4f00_next_dist_esm_build_templates_app-route_f952d9ab.js +1 -1
  52. package/.next/server/chunks/c4f00_next_dist_esm_build_templates_app-route_f952d9ab.js.map +1 -1
  53. package/.next/server/pages/404.html +1 -1
  54. package/.next/server/pages/500.html +1 -1
  55. package/.next/trace +1 -1
  56. package/README.md +3 -3
  57. package/dist/app/api/messages/buildRoute.d.ts.map +1 -1
  58. package/dist/app/api/messages/buildRoute.js +1 -3
  59. package/dist/lib/cache/cacheHeaders.d.ts.map +1 -1
  60. package/dist/lib/cache/cacheHeaders.js +1 -1
  61. package/package.json +1 -1
  62. /package/.next/static/{euNx_MoPmZ6Ig22d-7GLW → 25Kcgl6uIxdBmkSgq8yP-}/_buildManifest.js +0 -0
  63. /package/.next/static/{euNx_MoPmZ6Ig22d-7GLW → 25Kcgl6uIxdBmkSgq8yP-}/_clientMiddlewareManifest.json +0 -0
  64. /package/.next/static/{euNx_MoPmZ6Ig22d-7GLW → 25Kcgl6uIxdBmkSgq8yP-}/_ssgManifest.js +0 -0
@@ -1 +1 @@
1
- {"version":3,"sources":["turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/route.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/buildRoute.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/lib/initialMessagesResponse.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/threads/validThreadId.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/errors/serializeError.ts","turbopack:///[project]/supercorp/superinterface/node_modules/next/dist/esm/build/templates/app-route.js","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/messages/content.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/lib/getWorkspaceId.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/lib/serializeThread.ts"],"sourcesContent":["import { prisma } from '@/lib/prisma'\nimport { buildGET, buildOPTIONS, buildPOST, maxDuration } from './buildRoute'\n\nexport { maxDuration }\n\nexport const GET = buildGET({ prisma })\n\nexport const POST = buildPOST({ prisma })\n\nexport const OPTIONS = buildOPTIONS()\n","import { type NextRequest, NextResponse } from 'next/server'\nimport OpenAI from 'openai'\nimport {\n LogRequestMethod,\n LogRequestRoute,\n LogLevel,\n type PrismaClient,\n} from '@prisma/client'\nimport type { Thread } from '@prisma/client'\nimport {\n messagesResponse,\n createMessageResponse,\n} from '@superinterface/react/server'\nimport { enqueueJson } from '@superinterface/react/utils'\nimport { cacheHeaders } from '@/lib/cache/cacheHeaders'\nimport { z } from 'zod'\nimport { storageThreadId as getStorageThreadId } from '@/lib/threads/storageThreadId'\nimport { assistantClientAdapter } from '@/lib/assistants/assistantClientAdapter'\nimport { content as getContent } from '@/lib/messages/content'\nimport { workspaceAccessWhere as getWorkspaceAccessWhere } from '@/lib/apiKeys/workspaceAccessWhere'\nimport { initialMessagesResponse } from './lib/initialMessagesResponse'\nimport { createRunOpts } from '@/lib/runs/createRunOpts'\nimport { handleToolCall } from '@/lib/toolCalls/handleToolCall'\nimport { createThread } from '@/lib/threads/createThread'\nimport { managedOpenaiThreadId } from '@/lib/threads/managedOpenaiThreadId'\nimport { createLog } from '@/lib/logs/createLog'\nimport { serializeThread } from './lib/serializeThread'\nimport { getWorkspaceId } from './lib/getWorkspaceId'\nimport { validThreadId } from '@/lib/threads/validThreadId'\nimport { isOpenaiAssistantsStorageProvider } from '@/lib/storageProviders/isOpenaiAssistantsStorageProvider'\nimport { serializeMetadata } from '@/lib/metadata/serializeMetadata'\nimport { isResponsesStorageProvider } from '@/lib/storageProviders/isResponsesStorageProvider'\nimport { serializeError } from '@/lib/errors/serializeError'\n\nexport const maxDuration = 800\n\nexport const buildGET =\n ({ prisma }: { prisma: PrismaClient }) =>\n async (request: NextRequest) => {\n const paramsResult = z\n .object({\n publicApiKey: z.string().optional(),\n assistantId: z.string().optional(),\n threadId: z.string().optional(),\n pageParam: z.string().optional(),\n })\n .parse(Object.fromEntries(request.nextUrl.searchParams.entries()))\n\n const workspaceAccessWhere = await getWorkspaceAccessWhere({\n publicApiKey: paramsResult.publicApiKey ?? null,\n prisma,\n })\n\n if (!workspaceAccessWhere) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n const assistantId = paramsResult.assistantId\n\n if (!assistantId) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No assistantId found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'No assistant id found' },\n { status: 400 },\n )\n }\n\n const { threadId, pageParam } = paramsResult\n\n const assistant = await prisma.assistant.findFirst({\n where: {\n id: assistantId,\n workspace: workspaceAccessWhere,\n },\n include: {\n threads: {\n where: {\n id: validThreadId({ threadId: threadId ?? null }),\n },\n take: 1,\n include: {\n assistant: {\n select: {\n storageProviderType: true,\n },\n },\n },\n },\n workspace: {\n include: {\n modelProviders: true,\n },\n },\n modelProvider: true,\n initialMessages: {\n orderBy: {\n orderNumber: 'desc',\n },\n },\n mcpServers: {\n include: {\n computerUseTool: true,\n stdioTransport: true,\n sseTransport: true,\n httpTransport: true,\n },\n },\n tools: {\n include: {\n fileSearchTool: true,\n webSearchTool: true,\n imageGenerationTool: true,\n codeInterpreterTool: true,\n computerUseTool: true,\n },\n },\n functions: true,\n },\n })\n\n if (!assistant) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No assistant found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json({ error: 'No assistant found' }, { status: 400 })\n }\n\n if (!threadId) {\n return NextResponse.json(await initialMessagesResponse({ assistant }), {\n headers: cacheHeaders,\n })\n }\n\n const thread = assistant.threads[0]\n\n if (!thread) {\n return NextResponse.json(await initialMessagesResponse({ assistant }), {\n headers: cacheHeaders,\n })\n }\n\n const assistantClient = assistantClientAdapter({\n assistant,\n prisma,\n thread,\n })\n\n const storageThreadId = getStorageThreadId({\n thread,\n })\n\n if (!storageThreadId) {\n return NextResponse.json(await initialMessagesResponse({ assistant }), {\n headers: cacheHeaders,\n })\n }\n\n try {\n return NextResponse.json(\n await messagesResponse({\n threadId: storageThreadId,\n client: assistantClient,\n ...(pageParam ? { pageParam } : {}),\n }),\n {\n headers: cacheHeaders,\n },\n )\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.dir({ error }, { depth: null })\n createLog({\n log: {\n requestMethod: LogRequestMethod.GET,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to load messages: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n return NextResponse.json(\n { error: 'Failed to load messages.' },\n { status: 500 },\n )\n }\n }\n\nexport const buildPOST =\n ({\n prisma,\n onSuccessCreateThread = () => void 0,\n }: {\n prisma: PrismaClient\n onSuccessCreateThread?: ({\n thread,\n }: {\n thread: Thread\n }) => void | Promise<void>\n }) =>\n async (request: NextRequest) => {\n const bodyResult = z\n .object({\n audioContent: z.any().optional(),\n content: z.any().optional(),\n attachments: z.array(z.any()).optional(),\n assistantId: z.string().optional(),\n publicApiKey: z.string().optional(),\n threadId: z.string().optional(),\n })\n .passthrough()\n .parse(await request.json())\n\n const {\n audioContent,\n content: textContent,\n attachments,\n assistantId,\n publicApiKey,\n ...variables\n } = bodyResult\n\n const workspaceAccessWhere = await getWorkspaceAccessWhere({\n publicApiKey: publicApiKey ?? null,\n prisma,\n })\n\n if (!workspaceAccessWhere) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n if (!assistantId) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No assistantId found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'No assistantId found.' },\n { status: 400 },\n )\n }\n\n if (!textContent && !audioContent && !attachments?.length) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No content found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json({ error: 'No content found.' }, { status: 400 })\n }\n\n const assistant = await prisma.assistant.findFirst({\n where: {\n id: assistantId,\n workspace: workspaceAccessWhere,\n },\n include: {\n threads: {\n where: {\n id: validThreadId({ threadId: bodyResult.threadId ?? null }),\n },\n include: {\n assistant: {\n select: {\n storageProviderType: true,\n },\n },\n },\n take: 1,\n },\n workspace: {\n include: {\n modelProviders: true,\n },\n },\n mcpServers: {\n include: {\n computerUseTool: true,\n stdioTransport: true,\n sseTransport: true,\n httpTransport: true,\n },\n },\n tools: {\n include: {\n fileSearchTool: true,\n webSearchTool: true,\n imageGenerationTool: true,\n codeInterpreterTool: true,\n computerUseTool: {\n include: {\n mcpServer: {\n include: {\n stdioTransport: true,\n sseTransport: true,\n httpTransport: true,\n },\n },\n },\n },\n },\n },\n functions: {\n include: {\n handler: {\n include: {\n requestHandler: true,\n firecrawlHandler: true,\n replicateHandler: true,\n clientToolHandler: true,\n assistantHandler: true,\n createTaskHandler: true,\n listTasksHandler: true,\n updateTaskHandler: true,\n deleteTaskHandler: true,\n },\n },\n },\n },\n modelProvider: true,\n initialMessages: {\n orderBy: {\n orderNumber: 'asc',\n },\n },\n },\n })\n\n if (!assistant) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No assistant found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'No assistant found.' },\n { status: 400 },\n )\n }\n\n if (\n isOpenaiAssistantsStorageProvider({\n storageProviderType: assistant.storageProviderType,\n }) &&\n !assistant.openaiAssistantId\n ) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'Assistant setup is not done.',\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Assistant setup is not done.' },\n { status: 400 },\n )\n }\n\n let thread = assistant.threads[0]\n let isThreadCreated = false\n\n if (!thread) {\n const createThreadClient = assistantClientAdapter({ assistant, prisma })\n\n try {\n thread = await createThread({\n client: createThreadClient,\n assistant,\n prisma,\n variables: variables as Record<string, string>,\n })\n\n onSuccessCreateThread({ thread })\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.error(error)\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to create thread: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to create thread.' },\n { status: 500 },\n )\n }\n\n isThreadCreated = true\n }\n\n let storageThreadId\n\n try {\n storageThreadId = getStorageThreadId({\n thread,\n })\n } catch (error) {\n console.error(error)\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: 'Failed to get storage thread id.',\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to get storage thread id.' },\n { status: 500 },\n )\n }\n\n if (\n !storageThreadId &&\n (isOpenaiAssistantsStorageProvider({\n storageProviderType: assistant.storageProviderType,\n }) ||\n isResponsesStorageProvider({\n storageProviderType: assistant.storageProviderType,\n }))\n ) {\n try {\n storageThreadId = await managedOpenaiThreadId({\n assistant,\n threadId: thread.id,\n prisma,\n })\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to get managed openai thread id: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to get managed openai thread id.' },\n { status: 500 },\n )\n }\n }\n\n if (!storageThreadId) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: 'Invalid thread configuration.',\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Invalid thread configuration.' },\n { status: 500 },\n )\n }\n\n let content\n\n try {\n content = await getContent({\n audioContent,\n textContent,\n assistant,\n })\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.error(error)\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to get content: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to get content.' },\n { status: 500 },\n )\n }\n\n const assistantClient = assistantClientAdapter({\n assistant,\n prisma,\n thread,\n })\n\n try {\n await assistantClient.beta.threads.messages.create(storageThreadId, {\n role: 'user',\n content,\n ...(attachments?.length ? { attachments } : {}),\n metadata: serializeMetadata({\n variables,\n workspaceId: assistant.workspaceId,\n prisma,\n }),\n })\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.log({ error })\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to create message: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to create message.' },\n { status: 500 },\n )\n }\n\n let createRunStream\n\n try {\n createRunStream = await assistantClient.beta.threads.runs.create(\n storageThreadId,\n await createRunOpts({ assistant, thread, prisma }),\n )\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.error(error)\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to create run stream: ${serializeError({ error })}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to create run stream.' },\n { status: 500 },\n )\n }\n\n let latestInProgressRunData: OpenAI.Beta.Threads.Runs.Run | null = null\n let latestCompletedRunData: OpenAI.Beta.Threads.Runs.Run | null = null\n\n return new Response(\n createMessageResponse({\n client: assistantClient,\n createRunStream,\n handleToolCall: handleToolCall({ assistant, thread, prisma }),\n onStart: ({\n controller,\n }: {\n controller: ReadableStreamDefaultController\n }) => {\n if (!isThreadCreated) return\n\n return enqueueJson({\n controller,\n value: {\n event: 'thread.created',\n data: serializeThread({\n thread,\n }),\n },\n })\n },\n onError: async ({ error }) => {\n if (request.signal.aborted) return\n console.dir({ error }, { depth: null })\n\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Thread Run failed: ${serializeError({ error })}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n // if (latestInProgressRunData) {\n // await assistantClient.beta.threads.runs.cancel(\n // latestInProgressRunData.thread_id,\n // latestInProgressRunData.id,\n // )\n // }\n },\n onEvent: ({ event, data }) => {\n if (event === 'thread.run.failed') {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Thread Run failed: ${data.last_error?.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n } else if (event === 'thread.run.in_progress') {\n latestInProgressRunData = data\n } else if (event === 'thread.run.completed') {\n latestCompletedRunData = data\n }\n },\n onClose: async () => {\n if (latestCompletedRunData) return\n if (\n !isOpenaiAssistantsStorageProvider({\n storageProviderType: assistant.storageProviderType,\n })\n )\n return\n\n if (latestInProgressRunData) {\n await assistantClient.beta.threads.runs.cancel(\n latestInProgressRunData.id,\n {\n thread_id: latestInProgressRunData.thread_id,\n },\n )\n }\n },\n }),\n {\n status: 200,\n headers: {\n 'Content-Type': 'application/json; charset=utf-8',\n },\n },\n )\n }\n\nexport const buildOPTIONS = () => () =>\n NextResponse.json(\n {},\n {\n headers: cacheHeaders,\n },\n )\n","import dayjs from 'dayjs'\nimport type OpenAI from 'openai'\nimport {\n Prisma,\n Assistant,\n StorageProviderType,\n MessageRole,\n} from '@prisma/client'\nimport { optimisticId, serializeMessage } from '@superinterface/react/utils'\nimport { isOpenaiAssistantsStorageProvider } from '@/lib/storageProviders/isOpenaiAssistantsStorageProvider'\nimport { isResponsesStorageProvider } from '@/lib/storageProviders/isResponsesStorageProvider'\n\nconst assistantId = ({ assistant }: { assistant: Assistant }) => {\n if (\n isOpenaiAssistantsStorageProvider({\n storageProviderType: assistant.storageProviderType,\n })\n ) {\n return assistant.openaiAssistantId\n }\n\n if (\n isResponsesStorageProvider({\n storageProviderType: assistant.storageProviderType,\n })\n ) {\n return assistant.id\n }\n\n if (\n assistant.storageProviderType === StorageProviderType.SUPERINTERFACE_CLOUD\n ) {\n return assistant.id\n }\n\n throw new Error('Invalid storage type')\n}\n\nexport const initialMessagesResponse = async ({\n assistant,\n}: {\n assistant: Prisma.AssistantGetPayload<{\n include: {\n initialMessages: true\n }\n }>\n}) => {\n const threadId = optimisticId()\n const initialCreatedAt = dayjs().unix()\n\n return {\n data: await Promise.all(\n assistant.initialMessages.map(\n async (\n message: (typeof assistant.initialMessages)[number],\n index: number,\n ) =>\n serializeMessage({\n message: {\n id: optimisticId(),\n role: message.role.toLowerCase() as OpenAI.Beta.Threads.Messages.Message['role'],\n created_at: initialCreatedAt - index - 1,\n object:\n 'thread.message' as OpenAI.Beta.Threads.Messages.Message['object'],\n content: [\n {\n type: 'text',\n text: {\n annotations: [],\n value: message.content,\n },\n } as OpenAI.Beta.Threads.Messages.TextContentBlock,\n ],\n run_id: null,\n assistant_id:\n message.role === MessageRole.ASSISTANT\n ? assistantId({ assistant })\n : null,\n thread_id: threadId,\n attachments:\n message.attachments as OpenAI.Beta.Threads.Messages.Message['attachments'],\n metadata: message.metadata,\n completed_at: initialCreatedAt - index - 1,\n incomplete_at: null,\n incomplete_details: null,\n status: 'completed',\n runSteps: [],\n },\n }),\n ),\n ),\n hasNextPage: false,\n lastId: null,\n }\n}\n","import { validate } from 'uuid'\n\nconst fallbackUuid = '00000000-0000-0000-0000-000000000000'\n\nexport const validThreadId = ({ threadId }: { threadId: string | null }) => {\n if (!threadId) return fallbackUuid\n if (!validate(threadId)) return fallbackUuid\n\n return threadId\n}\n","const causeMessage = ({ error }: { error: Error }) => {\n if (error.cause instanceof Error) return ` ${error.cause.message}`\n if (error.cause) return ` ${error.cause}`\n return ''\n}\n\nexport const serializeError = ({ error }: { error: unknown }): string => {\n if (!(error instanceof Error)) return String(error)\n\n return `${error.message}${causeMessage({ error })}`\n}\n","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/messages/route\",\n pathname: \"/api/messages\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/supercorp/superinterface/packages/server/src/app/api/messages/route.ts\",\n nextConfigOutput,\n userland\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n var _nextConfig_experimental;\n let srcPage = \"/api/messages/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isRevalidate = isIsr && !supportsDynamicResponse;\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n cacheComponents: Boolean(nextConfig.experimental.cacheComponents),\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: (_nextConfig_experimental = nextConfig.experimental) == null ? void 0 : _nextConfig_experimental.cacheLife,\n isRevalidate,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext)=>routeModule.onRequestError(req, error, errorContext, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${req.url}`);\n }\n });\n };\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!getRequestMeta(req, 'minimalMode') && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n }, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!getRequestMeta(req, 'minimalMode')) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(getRequestMeta(req, 'minimalMode') && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${req.url}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n });\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n","import { ModelProviderType, Prisma } from '@prisma/client'\nimport { toFile } from 'openai'\nimport { buildOpenaiClient } from '@/lib/modelProviders/buildOpenaiClient'\nimport { isEmpty } from 'radash'\n\ntype Args = {\n textContent?: string\n audioContent?: string\n assistant: Prisma.AssistantGetPayload<{\n include: {\n workspace: {\n include: {\n modelProviders: true\n }\n }\n }\n }>\n}\n\nexport const content = async ({\n textContent,\n audioContent,\n assistant,\n}: Args) => {\n if (textContent) {\n return textContent\n }\n\n if (audioContent) {\n const openaiModelProvider = assistant.workspace.modelProviders.find(\n (mp) => mp.type === ModelProviderType.OPENAI,\n )\n\n if (!openaiModelProvider?.apiKey) {\n throw new Error('No OpenAI API key found')\n }\n\n const client = buildOpenaiClient({\n modelProvider: openaiModelProvider,\n })\n\n const base64Content = audioContent.split(',')[1]\n\n if (isEmpty(base64Content)) {\n return '-'\n }\n\n const audioBuffer = Buffer.from(base64Content, 'base64')\n const file = await toFile(audioBuffer, 'message.mp3')\n\n const transcription = await client.audio.transcriptions.create({\n file,\n model: 'whisper-1',\n })\n\n return transcription.text\n }\n\n throw new Error('No content found')\n}\n","import type { Prisma, PrismaClient } from '@prisma/client'\n\nexport const getWorkspaceId = async ({\n workspaceAccessWhere,\n prisma,\n}: {\n workspaceAccessWhere: Prisma.WorkspaceWhereInput\n prisma: PrismaClient\n}) =>\n (await prisma.workspace.findFirst({\n where: workspaceAccessWhere,\n }))!.id\n","import { Prisma } from '@prisma/client'\nimport dayjs from 'dayjs'\nimport { storageThreadId } from '@/lib/threads/storageThreadId'\n\nexport const serializeThread = ({\n thread,\n}: {\n thread: Prisma.ThreadGetPayload<{\n include: {\n assistant: {\n select: {\n storageProviderType: true\n }\n }\n }\n }>\n}) => ({\n id: storageThreadId({ thread }),\n object: 'thread',\n created_at: dayjs(thread.createdAt).unix(),\n metadata: thread.metadata,\n})\n"],"names":[],"mappings":"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","ignoreList":[5]}
1
+ {"version":3,"sources":["turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/route.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/buildRoute.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/lib/initialMessagesResponse.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/threads/validThreadId.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/errors/serializeError.ts","turbopack:///[project]/supercorp/superinterface/node_modules/next/dist/esm/build/templates/app-route.js","turbopack:///[project]/supercorp/superinterface/packages/server/src/lib/messages/content.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/lib/getWorkspaceId.ts","turbopack:///[project]/supercorp/superinterface/packages/server/src/app/api/messages/lib/serializeThread.ts"],"sourcesContent":["import { prisma } from '@/lib/prisma'\nimport { buildGET, buildOPTIONS, buildPOST, maxDuration } from './buildRoute'\n\nexport { maxDuration }\n\nexport const GET = buildGET({ prisma })\n\nexport const POST = buildPOST({ prisma })\n\nexport const OPTIONS = buildOPTIONS()\n","import { type NextRequest, NextResponse } from 'next/server'\nimport OpenAI from 'openai'\nimport {\n LogRequestMethod,\n LogRequestRoute,\n LogLevel,\n type PrismaClient,\n} from '@prisma/client'\nimport type { Thread } from '@prisma/client'\nimport {\n messagesResponse,\n createMessageResponse,\n} from '@superinterface/react/server'\nimport { enqueueJson } from '@superinterface/react/utils'\nimport { cacheHeaders } from '@/lib/cache/cacheHeaders'\nimport { z } from 'zod'\nimport { storageThreadId as getStorageThreadId } from '@/lib/threads/storageThreadId'\nimport { assistantClientAdapter } from '@/lib/assistants/assistantClientAdapter'\nimport { content as getContent } from '@/lib/messages/content'\nimport { workspaceAccessWhere as getWorkspaceAccessWhere } from '@/lib/apiKeys/workspaceAccessWhere'\nimport { initialMessagesResponse } from './lib/initialMessagesResponse'\nimport { createRunOpts } from '@/lib/runs/createRunOpts'\nimport { handleToolCall } from '@/lib/toolCalls/handleToolCall'\nimport { createThread } from '@/lib/threads/createThread'\nimport { managedOpenaiThreadId } from '@/lib/threads/managedOpenaiThreadId'\nimport { createLog } from '@/lib/logs/createLog'\nimport { serializeThread } from './lib/serializeThread'\nimport { getWorkspaceId } from './lib/getWorkspaceId'\nimport { validThreadId } from '@/lib/threads/validThreadId'\nimport { isOpenaiAssistantsStorageProvider } from '@/lib/storageProviders/isOpenaiAssistantsStorageProvider'\nimport { serializeMetadata } from '@/lib/metadata/serializeMetadata'\nimport { isResponsesStorageProvider } from '@/lib/storageProviders/isResponsesStorageProvider'\nimport { serializeError } from '@/lib/errors/serializeError'\n\nexport const maxDuration = 800\n\nexport const buildGET =\n ({ prisma }: { prisma: PrismaClient }) =>\n async (request: NextRequest) => {\n const paramsResult = z\n .object({\n publicApiKey: z.string().optional(),\n assistantId: z.string().optional(),\n threadId: z.string().optional(),\n pageParam: z.string().optional(),\n })\n .parse(Object.fromEntries(request.nextUrl.searchParams.entries()))\n\n const workspaceAccessWhere = await getWorkspaceAccessWhere({\n publicApiKey: paramsResult.publicApiKey ?? null,\n prisma,\n })\n\n if (!workspaceAccessWhere) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n const assistantId = paramsResult.assistantId\n\n if (!assistantId) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No assistantId found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'No assistant id found' },\n { status: 400 },\n )\n }\n\n const { threadId, pageParam } = paramsResult\n\n const assistant = await prisma.assistant.findFirst({\n where: {\n id: assistantId,\n workspace: workspaceAccessWhere,\n },\n include: {\n threads: {\n where: {\n id: validThreadId({ threadId: threadId ?? null }),\n },\n take: 1,\n include: {\n assistant: {\n select: {\n storageProviderType: true,\n },\n },\n },\n },\n workspace: {\n include: {\n modelProviders: true,\n },\n },\n modelProvider: true,\n initialMessages: {\n orderBy: {\n orderNumber: 'desc',\n },\n },\n mcpServers: {\n include: {\n computerUseTool: true,\n stdioTransport: true,\n sseTransport: true,\n httpTransport: true,\n },\n },\n tools: {\n include: {\n fileSearchTool: true,\n webSearchTool: true,\n imageGenerationTool: true,\n codeInterpreterTool: true,\n computerUseTool: true,\n },\n },\n functions: true,\n },\n })\n\n if (!assistant) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No assistant found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json({ error: 'No assistant found' }, { status: 400 })\n }\n\n if (!threadId) {\n return NextResponse.json(await initialMessagesResponse({ assistant }), {\n headers: cacheHeaders,\n })\n }\n\n const thread = assistant.threads[0]\n\n if (!thread) {\n return NextResponse.json(await initialMessagesResponse({ assistant }), {\n headers: cacheHeaders,\n })\n }\n\n const assistantClient = assistantClientAdapter({\n assistant,\n prisma,\n thread,\n })\n\n const storageThreadId = getStorageThreadId({\n thread,\n })\n\n if (!storageThreadId) {\n return NextResponse.json(await initialMessagesResponse({ assistant }), {\n headers: cacheHeaders,\n })\n }\n\n try {\n return NextResponse.json(\n await messagesResponse({\n threadId: storageThreadId,\n client: assistantClient,\n ...(pageParam ? { pageParam } : {}),\n }),\n {\n headers: cacheHeaders,\n },\n )\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.dir({ error }, { depth: null })\n createLog({\n log: {\n requestMethod: LogRequestMethod.GET,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to load messages: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n return NextResponse.json(\n { error: 'Failed to load messages.' },\n { status: 500 },\n )\n }\n }\n\nexport const buildPOST =\n ({\n prisma,\n onSuccessCreateThread = () => void 0,\n }: {\n prisma: PrismaClient\n onSuccessCreateThread?: ({\n thread,\n }: {\n thread: Thread\n }) => void | Promise<void>\n }) =>\n async (request: NextRequest) => {\n const bodyResult = z\n .object({\n audioContent: z.any().optional(),\n content: z.any().optional(),\n attachments: z.array(z.any()).optional(),\n assistantId: z.string().optional(),\n publicApiKey: z.string().optional(),\n threadId: z.string().optional(),\n })\n .passthrough()\n .parse(await request.json())\n\n const {\n audioContent,\n content: textContent,\n attachments,\n assistantId,\n publicApiKey,\n ...variables\n } = bodyResult\n\n const workspaceAccessWhere = await getWorkspaceAccessWhere({\n publicApiKey: publicApiKey ?? null,\n prisma,\n })\n\n if (!workspaceAccessWhere) {\n return NextResponse.json({ error: 'Invalid api key' }, { status: 400 })\n }\n\n if (!assistantId) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No assistantId found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'No assistantId found.' },\n { status: 400 },\n )\n }\n\n if (!textContent && !audioContent && !attachments?.length) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No content found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json({ error: 'No content found.' }, { status: 400 })\n }\n\n const assistant = await prisma.assistant.findFirst({\n where: {\n id: assistantId,\n workspace: workspaceAccessWhere,\n },\n include: {\n threads: {\n where: {\n id: validThreadId({ threadId: bodyResult.threadId ?? null }),\n },\n include: {\n assistant: {\n select: {\n storageProviderType: true,\n },\n },\n },\n take: 1,\n },\n workspace: {\n include: {\n modelProviders: true,\n },\n },\n mcpServers: {\n include: {\n computerUseTool: true,\n stdioTransport: true,\n sseTransport: true,\n httpTransport: true,\n },\n },\n tools: {\n include: {\n fileSearchTool: true,\n webSearchTool: true,\n imageGenerationTool: true,\n codeInterpreterTool: true,\n computerUseTool: {\n include: {\n mcpServer: {\n include: {\n stdioTransport: true,\n sseTransport: true,\n httpTransport: true,\n },\n },\n },\n },\n },\n },\n functions: {\n include: {\n handler: {\n include: {\n requestHandler: true,\n firecrawlHandler: true,\n replicateHandler: true,\n clientToolHandler: true,\n assistantHandler: true,\n createTaskHandler: true,\n listTasksHandler: true,\n updateTaskHandler: true,\n deleteTaskHandler: true,\n },\n },\n },\n },\n modelProvider: true,\n initialMessages: {\n orderBy: {\n orderNumber: 'asc',\n },\n },\n },\n })\n\n if (!assistant) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'No assistant found.',\n workspaceId: await getWorkspaceId({ workspaceAccessWhere, prisma }),\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'No assistant found.' },\n { status: 400 },\n )\n }\n\n if (\n isOpenaiAssistantsStorageProvider({\n storageProviderType: assistant.storageProviderType,\n }) &&\n !assistant.openaiAssistantId\n ) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 400,\n message: 'Assistant setup is not done.',\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Assistant setup is not done.' },\n { status: 400 },\n )\n }\n\n let thread = assistant.threads[0]\n let isThreadCreated = false\n\n if (!thread) {\n const createThreadClient = assistantClientAdapter({ assistant, prisma })\n\n try {\n thread = await createThread({\n client: createThreadClient,\n assistant,\n prisma,\n variables: variables as Record<string, string>,\n })\n\n onSuccessCreateThread({ thread })\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.error(error)\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to create thread: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to create thread.' },\n { status: 500 },\n )\n }\n\n isThreadCreated = true\n }\n\n let storageThreadId\n\n try {\n storageThreadId = getStorageThreadId({\n thread,\n })\n } catch (error) {\n console.error(error)\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: 'Failed to get storage thread id.',\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to get storage thread id.' },\n { status: 500 },\n )\n }\n\n if (\n !storageThreadId &&\n (isOpenaiAssistantsStorageProvider({\n storageProviderType: assistant.storageProviderType,\n }) ||\n isResponsesStorageProvider({\n storageProviderType: assistant.storageProviderType,\n }))\n ) {\n try {\n storageThreadId = await managedOpenaiThreadId({\n assistant,\n threadId: thread.id,\n prisma,\n })\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to get managed openai thread id: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to get managed openai thread id.' },\n { status: 500 },\n )\n }\n }\n\n if (!storageThreadId) {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: 'Invalid thread configuration.',\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Invalid thread configuration.' },\n { status: 500 },\n )\n }\n\n let content\n\n try {\n content = await getContent({\n audioContent,\n textContent,\n assistant,\n })\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.error(error)\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to get content: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to get content.' },\n { status: 500 },\n )\n }\n\n const assistantClient = assistantClientAdapter({\n assistant,\n prisma,\n thread,\n })\n\n try {\n await assistantClient.beta.threads.messages.create(storageThreadId, {\n role: 'user',\n content,\n ...(attachments?.length ? { attachments } : {}),\n metadata: serializeMetadata({\n variables,\n workspaceId: assistant.workspaceId,\n prisma,\n }),\n })\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.log({ error })\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to create message: ${error.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to create message.' },\n { status: 500 },\n )\n }\n\n let createRunStream\n\n try {\n createRunStream = await assistantClient.beta.threads.runs.create(\n storageThreadId,\n await createRunOpts({ assistant, thread, prisma }),\n )\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n } catch (error: any) {\n console.error(error)\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Failed to create run stream: ${serializeError({ error })}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n return NextResponse.json(\n { error: 'Failed to create run stream.' },\n { status: 500 },\n )\n }\n\n let latestInProgressRunData: OpenAI.Beta.Threads.Runs.Run | null = null\n let latestCompletedRunData: OpenAI.Beta.Threads.Runs.Run | null = null\n\n return new Response(\n createMessageResponse({\n client: assistantClient,\n createRunStream,\n handleToolCall: handleToolCall({ assistant, thread, prisma }),\n onStart: ({\n controller,\n }: {\n controller: ReadableStreamDefaultController\n }) => {\n if (!isThreadCreated) return\n\n return enqueueJson({\n controller,\n value: {\n event: 'thread.created',\n data: serializeThread({\n thread,\n }),\n },\n })\n },\n onError: async ({ error }) => {\n if (request.signal.aborted) return\n console.dir({ error }, { depth: null })\n\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Thread Run failed: ${serializeError({ error })}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n\n // if (latestInProgressRunData) {\n // await assistantClient.beta.threads.runs.cancel(\n // latestInProgressRunData.thread_id,\n // latestInProgressRunData.id,\n // )\n // }\n },\n onEvent: ({ event, data }) => {\n if (event === 'thread.run.failed') {\n createLog({\n log: {\n requestMethod: LogRequestMethod.POST,\n requestRoute: LogRequestRoute.MESSAGES,\n level: LogLevel.ERROR,\n status: 500,\n message: `Thread Run failed: ${data.last_error?.message}`,\n workspaceId: assistant.workspaceId,\n assistantId: assistant.id,\n threadId: thread.id,\n },\n prisma,\n })\n } else if (event === 'thread.run.in_progress') {\n latestInProgressRunData = data\n } else if (event === 'thread.run.completed') {\n latestCompletedRunData = data\n }\n },\n onClose: async () => {\n if (latestCompletedRunData) return\n if (\n !isOpenaiAssistantsStorageProvider({\n storageProviderType: assistant.storageProviderType,\n })\n )\n return\n\n if (latestInProgressRunData) {\n await assistantClient.beta.threads.runs.cancel(\n latestInProgressRunData.id,\n {\n thread_id: latestInProgressRunData.thread_id,\n },\n )\n }\n },\n }),\n {\n status: 200,\n headers: {\n ...cacheHeaders,\n 'Content-Type': 'application/json; charset=utf-8',\n },\n },\n )\n }\n\nexport const buildOPTIONS = () => () =>\n NextResponse.json(\n {},\n {\n headers: cacheHeaders,\n },\n )\n","import dayjs from 'dayjs'\nimport type OpenAI from 'openai'\nimport {\n Prisma,\n Assistant,\n StorageProviderType,\n MessageRole,\n} from '@prisma/client'\nimport { optimisticId, serializeMessage } from '@superinterface/react/utils'\nimport { isOpenaiAssistantsStorageProvider } from '@/lib/storageProviders/isOpenaiAssistantsStorageProvider'\nimport { isResponsesStorageProvider } from '@/lib/storageProviders/isResponsesStorageProvider'\n\nconst assistantId = ({ assistant }: { assistant: Assistant }) => {\n if (\n isOpenaiAssistantsStorageProvider({\n storageProviderType: assistant.storageProviderType,\n })\n ) {\n return assistant.openaiAssistantId\n }\n\n if (\n isResponsesStorageProvider({\n storageProviderType: assistant.storageProviderType,\n })\n ) {\n return assistant.id\n }\n\n if (\n assistant.storageProviderType === StorageProviderType.SUPERINTERFACE_CLOUD\n ) {\n return assistant.id\n }\n\n throw new Error('Invalid storage type')\n}\n\nexport const initialMessagesResponse = async ({\n assistant,\n}: {\n assistant: Prisma.AssistantGetPayload<{\n include: {\n initialMessages: true\n }\n }>\n}) => {\n const threadId = optimisticId()\n const initialCreatedAt = dayjs().unix()\n\n return {\n data: await Promise.all(\n assistant.initialMessages.map(\n async (\n message: (typeof assistant.initialMessages)[number],\n index: number,\n ) =>\n serializeMessage({\n message: {\n id: optimisticId(),\n role: message.role.toLowerCase() as OpenAI.Beta.Threads.Messages.Message['role'],\n created_at: initialCreatedAt - index - 1,\n object:\n 'thread.message' as OpenAI.Beta.Threads.Messages.Message['object'],\n content: [\n {\n type: 'text',\n text: {\n annotations: [],\n value: message.content,\n },\n } as OpenAI.Beta.Threads.Messages.TextContentBlock,\n ],\n run_id: null,\n assistant_id:\n message.role === MessageRole.ASSISTANT\n ? assistantId({ assistant })\n : null,\n thread_id: threadId,\n attachments:\n message.attachments as OpenAI.Beta.Threads.Messages.Message['attachments'],\n metadata: message.metadata,\n completed_at: initialCreatedAt - index - 1,\n incomplete_at: null,\n incomplete_details: null,\n status: 'completed',\n runSteps: [],\n },\n }),\n ),\n ),\n hasNextPage: false,\n lastId: null,\n }\n}\n","import { validate } from 'uuid'\n\nconst fallbackUuid = '00000000-0000-0000-0000-000000000000'\n\nexport const validThreadId = ({ threadId }: { threadId: string | null }) => {\n if (!threadId) return fallbackUuid\n if (!validate(threadId)) return fallbackUuid\n\n return threadId\n}\n","const causeMessage = ({ error }: { error: Error }) => {\n if (error.cause instanceof Error) return ` ${error.cause.message}`\n if (error.cause) return ` ${error.cause}`\n return ''\n}\n\nexport const serializeError = ({ error }: { error: unknown }): string => {\n if (!(error instanceof Error)) return String(error)\n\n return `${error.message}${causeMessage({ error })}`\n}\n","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/messages/route\",\n pathname: \"/api/messages\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/supercorp/superinterface/packages/server/src/app/api/messages/route.ts\",\n nextConfigOutput,\n userland\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n var _nextConfig_experimental;\n let srcPage = \"/api/messages/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isRevalidate = isIsr && !supportsDynamicResponse;\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n cacheComponents: Boolean(nextConfig.experimental.cacheComponents),\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: (_nextConfig_experimental = nextConfig.experimental) == null ? void 0 : _nextConfig_experimental.cacheLife,\n isRevalidate,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext)=>routeModule.onRequestError(req, error, errorContext, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${req.url}`);\n }\n });\n };\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!getRequestMeta(req, 'minimalMode') && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n }, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!getRequestMeta(req, 'minimalMode')) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(getRequestMeta(req, 'minimalMode') && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${req.url}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isRevalidate,\n isOnDemandRevalidate\n })\n });\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n","import { ModelProviderType, Prisma } from '@prisma/client'\nimport { toFile } from 'openai'\nimport { buildOpenaiClient } from '@/lib/modelProviders/buildOpenaiClient'\nimport { isEmpty } from 'radash'\n\ntype Args = {\n textContent?: string\n audioContent?: string\n assistant: Prisma.AssistantGetPayload<{\n include: {\n workspace: {\n include: {\n modelProviders: true\n }\n }\n }\n }>\n}\n\nexport const content = async ({\n textContent,\n audioContent,\n assistant,\n}: Args) => {\n if (textContent) {\n return textContent\n }\n\n if (audioContent) {\n const openaiModelProvider = assistant.workspace.modelProviders.find(\n (mp) => mp.type === ModelProviderType.OPENAI,\n )\n\n if (!openaiModelProvider?.apiKey) {\n throw new Error('No OpenAI API key found')\n }\n\n const client = buildOpenaiClient({\n modelProvider: openaiModelProvider,\n })\n\n const base64Content = audioContent.split(',')[1]\n\n if (isEmpty(base64Content)) {\n return '-'\n }\n\n const audioBuffer = Buffer.from(base64Content, 'base64')\n const file = await toFile(audioBuffer, 'message.mp3')\n\n const transcription = await client.audio.transcriptions.create({\n file,\n model: 'whisper-1',\n })\n\n return transcription.text\n }\n\n throw new Error('No content found')\n}\n","import type { Prisma, PrismaClient } from '@prisma/client'\n\nexport const getWorkspaceId = async ({\n workspaceAccessWhere,\n prisma,\n}: {\n workspaceAccessWhere: Prisma.WorkspaceWhereInput\n prisma: PrismaClient\n}) =>\n (await prisma.workspace.findFirst({\n where: workspaceAccessWhere,\n }))!.id\n","import { Prisma } from '@prisma/client'\nimport dayjs from 'dayjs'\nimport { storageThreadId } from '@/lib/threads/storageThreadId'\n\nexport const serializeThread = ({\n thread,\n}: {\n thread: Prisma.ThreadGetPayload<{\n include: {\n assistant: {\n select: {\n storageProviderType: true\n }\n }\n }\n }>\n}) => ({\n id: storageThreadId({ thread }),\n object: 'thread',\n created_at: dayjs(thread.createdAt).unix(),\n metadata: thread.metadata,\n})\n"],"names":[],"mappings":"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","ignoreList":[5]}
@@ -1 +1 @@
1
- <!DOCTYPE html><!--euNx_MoPmZ6Ig22d_7GLW--><html lang="en"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="preload" as="script" fetchPriority="low" href="/_next/static/chunks/76a8a50dbf44f000.js"/><script src="/_next/static/chunks/079ce3572ffa07f6.js" async=""></script><script src="/_next/static/chunks/4649e58e35bcde4b.js" async=""></script><script src="/_next/static/chunks/turbopack-11882cf18a9eb231.js" async=""></script><script src="/_next/static/chunks/03d938d038bc30e3.js" async=""></script><meta name="robots" content="noindex"/><title>404: This page could not be found.</title><script src="/_next/static/chunks/a6dad97d9634a72d.js" noModule=""></script></head><body><div hidden=""><!--$--><!--/$--></div><div style="font-family:system-ui,&quot;Segoe UI&quot;,Roboto,Helvetica,Arial,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;;height:100vh;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center"><div><style>body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}</style><h1 class="next-error-h1" style="display:inline-block;margin:0 20px 0 0;padding:0 23px 0 0;font-size:24px;font-weight:500;vertical-align:top;line-height:49px">404</h1><div style="display:inline-block"><h2 style="font-size:14px;font-weight:400;line-height:49px;margin:0">This page could not be found.</h2></div></div></div><!--$--><!--/$--><script src="/_next/static/chunks/76a8a50dbf44f000.js" id="_R_" async=""></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,"1:\"$Sreact.fragment\"\n2:I[96352,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"default\"]\n3:I[17753,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"default\"]\n4:I[51035,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"OutletBoundary\"]\n6:I[33159,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"AsyncMetadataOutlet\"]\n8:I[51035,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"ViewportBoundary\"]\na:I[51035,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"MetadataBoundary\"]\nb:\"$Sreact.suspense\"\nd:I[25098,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"default\"]\n"])</script><script>self.__next_f.push([1,"0:{\"P\":null,\"b\":\"euNx_MoPmZ6Ig22d-7GLW\",\"p\":\"\",\"c\":[\"\",\"_not-found\"],\"i\":false,\"f\":[[[\"\",{\"children\":[\"/_not-found\",{\"children\":[\"__PAGE__\",{}]}]},\"$undefined\",\"$undefined\",true],[\"\",[\"$\",\"$1\",\"c\",{\"children\":[[[\"$\",\"script\",\"script-0\",{\"src\":\"/_next/static/chunks/03d938d038bc30e3.js\",\"async\":true,\"nonce\":\"$undefined\"}]],[\"$\",\"html\",null,{\"lang\":\"en\",\"children\":[\"$\",\"body\",null,{\"children\":[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":[[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":{\"fontFamily\":\"system-ui,\\\"Segoe UI\\\",Roboto,Helvetica,Arial,sans-serif,\\\"Apple Color Emoji\\\",\\\"Segoe UI Emoji\\\"\",\"height\":\"100vh\",\"textAlign\":\"center\",\"display\":\"flex\",\"flexDirection\":\"column\",\"alignItems\":\"center\",\"justifyContent\":\"center\"},\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":{\"display\":\"inline-block\",\"margin\":\"0 20px 0 0\",\"padding\":\"0 23px 0 0\",\"fontSize\":24,\"fontWeight\":500,\"verticalAlign\":\"top\",\"lineHeight\":\"49px\"},\"children\":404}],[\"$\",\"div\",null,{\"style\":{\"display\":\"inline-block\"},\"children\":[\"$\",\"h2\",null,{\"style\":{\"fontSize\":14,\"fontWeight\":400,\"lineHeight\":\"49px\",\"margin\":0},\"children\":\"This page could not be found.\"}]}]]}]}]],[]],\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]}]}]]}],{\"children\":[\"/_not-found\",[\"$\",\"$1\",\"c\",{\"children\":[null,[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":\"$undefined\",\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]]}],{\"children\":[\"__PAGE__\",[\"$\",\"$1\",\"c\",{\"children\":[[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":\"$0:f:0:1:1:props:children:1:props:children:props:children:props:notFound:0:1:props:style\",\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":\"$0:f:0:1:1:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:1:props:style\",\"children\":404}],[\"$\",\"div\",null,{\"style\":\"$0:f:0:1:1:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:2:props:style\",\"children\":[\"$\",\"h2\",null,{\"style\":\"$0:f:0:1:1:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:2:props:children:props:style\",\"children\":\"This page could not be found.\"}]}]]}]}]],null,[\"$\",\"$L4\",null,{\"children\":[\"$L5\",[\"$\",\"$L6\",null,{\"promise\":\"$@7\"}]]}]]}],{},null,false]},null,false]},null,false],[\"$\",\"$1\",\"h\",{\"children\":[[\"$\",\"meta\",null,{\"name\":\"robots\",\"content\":\"noindex\"}],[[\"$\",\"$L8\",null,{\"children\":\"$L9\"}],null],[\"$\",\"$La\",null,{\"children\":[\"$\",\"div\",null,{\"hidden\":true,\"children\":[\"$\",\"$b\",null,{\"fallback\":null,\"children\":\"$Lc\"}]}]}]]}],false]],\"m\":\"$undefined\",\"G\":[\"$d\",\"$undefined\"],\"s\":false,\"S\":true}\n"])</script><script>self.__next_f.push([1,"9:[[\"$\",\"meta\",\"0\",{\"charSet\":\"utf-8\"}],[\"$\",\"meta\",\"1\",{\"name\":\"viewport\",\"content\":\"width=device-width, initial-scale=1\"}]]\n5:null\n"])</script><script>self.__next_f.push([1,"7:{\"metadata\":[],\"error\":null,\"digest\":\"$undefined\"}\n"])</script><script>self.__next_f.push([1,"c:\"$7:metadata\"\n"])</script></body></html>
1
+ <!DOCTYPE html><!--25Kcgl6uIxdBmkSgq8yP_--><html lang="en"><head><meta charSet="utf-8"/><meta name="viewport" content="width=device-width, initial-scale=1"/><link rel="preload" as="script" fetchPriority="low" href="/_next/static/chunks/76a8a50dbf44f000.js"/><script src="/_next/static/chunks/079ce3572ffa07f6.js" async=""></script><script src="/_next/static/chunks/4649e58e35bcde4b.js" async=""></script><script src="/_next/static/chunks/turbopack-11882cf18a9eb231.js" async=""></script><script src="/_next/static/chunks/03d938d038bc30e3.js" async=""></script><meta name="robots" content="noindex"/><title>404: This page could not be found.</title><script src="/_next/static/chunks/a6dad97d9634a72d.js" noModule=""></script></head><body><div hidden=""><!--$--><!--/$--></div><div style="font-family:system-ui,&quot;Segoe UI&quot;,Roboto,Helvetica,Arial,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;;height:100vh;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center"><div><style>body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}</style><h1 class="next-error-h1" style="display:inline-block;margin:0 20px 0 0;padding:0 23px 0 0;font-size:24px;font-weight:500;vertical-align:top;line-height:49px">404</h1><div style="display:inline-block"><h2 style="font-size:14px;font-weight:400;line-height:49px;margin:0">This page could not be found.</h2></div></div></div><!--$--><!--/$--><script src="/_next/static/chunks/76a8a50dbf44f000.js" id="_R_" async=""></script><script>(self.__next_f=self.__next_f||[]).push([0])</script><script>self.__next_f.push([1,"1:\"$Sreact.fragment\"\n2:I[96352,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"default\"]\n3:I[17753,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"default\"]\n4:I[51035,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"OutletBoundary\"]\n6:I[33159,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"AsyncMetadataOutlet\"]\n8:I[51035,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"ViewportBoundary\"]\na:I[51035,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"MetadataBoundary\"]\nb:\"$Sreact.suspense\"\nd:I[25098,[\"/_next/static/chunks/03d938d038bc30e3.js\"],\"default\"]\n"])</script><script>self.__next_f.push([1,"0:{\"P\":null,\"b\":\"25Kcgl6uIxdBmkSgq8yP-\",\"p\":\"\",\"c\":[\"\",\"_not-found\"],\"i\":false,\"f\":[[[\"\",{\"children\":[\"/_not-found\",{\"children\":[\"__PAGE__\",{}]}]},\"$undefined\",\"$undefined\",true],[\"\",[\"$\",\"$1\",\"c\",{\"children\":[[[\"$\",\"script\",\"script-0\",{\"src\":\"/_next/static/chunks/03d938d038bc30e3.js\",\"async\":true,\"nonce\":\"$undefined\"}]],[\"$\",\"html\",null,{\"lang\":\"en\",\"children\":[\"$\",\"body\",null,{\"children\":[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":[[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":{\"fontFamily\":\"system-ui,\\\"Segoe UI\\\",Roboto,Helvetica,Arial,sans-serif,\\\"Apple Color Emoji\\\",\\\"Segoe UI Emoji\\\"\",\"height\":\"100vh\",\"textAlign\":\"center\",\"display\":\"flex\",\"flexDirection\":\"column\",\"alignItems\":\"center\",\"justifyContent\":\"center\"},\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":{\"display\":\"inline-block\",\"margin\":\"0 20px 0 0\",\"padding\":\"0 23px 0 0\",\"fontSize\":24,\"fontWeight\":500,\"verticalAlign\":\"top\",\"lineHeight\":\"49px\"},\"children\":404}],[\"$\",\"div\",null,{\"style\":{\"display\":\"inline-block\"},\"children\":[\"$\",\"h2\",null,{\"style\":{\"fontSize\":14,\"fontWeight\":400,\"lineHeight\":\"49px\",\"margin\":0},\"children\":\"This page could not be found.\"}]}]]}]}]],[]],\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]}]}]]}],{\"children\":[\"/_not-found\",[\"$\",\"$1\",\"c\",{\"children\":[null,[\"$\",\"$L2\",null,{\"parallelRouterKey\":\"children\",\"error\":\"$undefined\",\"errorStyles\":\"$undefined\",\"errorScripts\":\"$undefined\",\"template\":[\"$\",\"$L3\",null,{}],\"templateStyles\":\"$undefined\",\"templateScripts\":\"$undefined\",\"notFound\":\"$undefined\",\"forbidden\":\"$undefined\",\"unauthorized\":\"$undefined\"}]]}],{\"children\":[\"__PAGE__\",[\"$\",\"$1\",\"c\",{\"children\":[[[\"$\",\"title\",null,{\"children\":\"404: This page could not be found.\"}],[\"$\",\"div\",null,{\"style\":\"$0:f:0:1:1:props:children:1:props:children:props:children:props:notFound:0:1:props:style\",\"children\":[\"$\",\"div\",null,{\"children\":[[\"$\",\"style\",null,{\"dangerouslySetInnerHTML\":{\"__html\":\"body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}\"}}],[\"$\",\"h1\",null,{\"className\":\"next-error-h1\",\"style\":\"$0:f:0:1:1:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:1:props:style\",\"children\":404}],[\"$\",\"div\",null,{\"style\":\"$0:f:0:1:1:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:2:props:style\",\"children\":[\"$\",\"h2\",null,{\"style\":\"$0:f:0:1:1:props:children:1:props:children:props:children:props:notFound:0:1:props:children:props:children:2:props:children:props:style\",\"children\":\"This page could not be found.\"}]}]]}]}]],null,[\"$\",\"$L4\",null,{\"children\":[\"$L5\",[\"$\",\"$L6\",null,{\"promise\":\"$@7\"}]]}]]}],{},null,false]},null,false]},null,false],[\"$\",\"$1\",\"h\",{\"children\":[[\"$\",\"meta\",null,{\"name\":\"robots\",\"content\":\"noindex\"}],[[\"$\",\"$L8\",null,{\"children\":\"$L9\"}],null],[\"$\",\"$La\",null,{\"children\":[\"$\",\"div\",null,{\"hidden\":true,\"children\":[\"$\",\"$b\",null,{\"fallback\":null,\"children\":\"$Lc\"}]}]}]]}],false]],\"m\":\"$undefined\",\"G\":[\"$d\",\"$undefined\"],\"s\":false,\"S\":true}\n"])</script><script>self.__next_f.push([1,"9:[[\"$\",\"meta\",\"0\",{\"charSet\":\"utf-8\"}],[\"$\",\"meta\",\"1\",{\"name\":\"viewport\",\"content\":\"width=device-width, initial-scale=1\"}]]\n5:null\n"])</script><script>self.__next_f.push([1,"7:{\"metadata\":[],\"error\":null,\"digest\":\"$undefined\"}\n"])</script><script>self.__next_f.push([1,"c:\"$7:metadata\"\n"])</script></body></html>
@@ -1 +1 @@
1
- <!DOCTYPE html><html><head><meta charSet="utf-8" data-next-head=""/><meta name="viewport" content="width=device-width" data-next-head=""/><title data-next-head="">500: Internal Server Error</title><noscript data-n-css=""></noscript><script defer="" noModule="" src="/_next/static/chunks/a6dad97d9634a72d.js"></script><script src="/_next/static/chunks/22bca0be24d1dbb3.js" defer=""></script><script src="/_next/static/chunks/bd1a5816a611d718.js" defer=""></script><script src="/_next/static/chunks/turbopack-3bdbb570d8566903.js" defer=""></script><script src="/_next/static/chunks/e57ec661e9850a31.js" defer=""></script><script src="/_next/static/chunks/turbopack-67ff8c1c5b1ad9a8.js" defer=""></script><script src="/_next/static/euNx_MoPmZ6Ig22d-7GLW/_ssgManifest.js" defer=""></script><script src="/_next/static/euNx_MoPmZ6Ig22d-7GLW/_buildManifest.js" defer=""></script></head><body><div id="__next"><div style="font-family:system-ui,&quot;Segoe UI&quot;,Roboto,Helvetica,Arial,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;;height:100vh;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center"><div style="line-height:48px"><style>body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}</style><h1 class="next-error-h1" style="display:inline-block;margin:0 20px 0 0;padding-right:23px;font-size:24px;font-weight:500;vertical-align:top">500</h1><div style="display:inline-block"><h2 style="font-size:14px;font-weight:400;line-height:28px">Internal Server Error<!-- -->.</h2></div></div></div></div><script id="__NEXT_DATA__" type="application/json">{"props":{"pageProps":{"statusCode":500}},"page":"/_error","query":{},"buildId":"euNx_MoPmZ6Ig22d-7GLW","nextExport":true,"isFallback":false,"gip":true,"scriptLoader":[]}</script></body></html>
1
+ <!DOCTYPE html><html><head><meta charSet="utf-8" data-next-head=""/><meta name="viewport" content="width=device-width" data-next-head=""/><title data-next-head="">500: Internal Server Error</title><noscript data-n-css=""></noscript><script defer="" noModule="" src="/_next/static/chunks/a6dad97d9634a72d.js"></script><script src="/_next/static/chunks/22bca0be24d1dbb3.js" defer=""></script><script src="/_next/static/chunks/bd1a5816a611d718.js" defer=""></script><script src="/_next/static/chunks/turbopack-3bdbb570d8566903.js" defer=""></script><script src="/_next/static/chunks/e57ec661e9850a31.js" defer=""></script><script src="/_next/static/chunks/turbopack-67ff8c1c5b1ad9a8.js" defer=""></script><script src="/_next/static/25Kcgl6uIxdBmkSgq8yP-/_ssgManifest.js" defer=""></script><script src="/_next/static/25Kcgl6uIxdBmkSgq8yP-/_buildManifest.js" defer=""></script></head><body><div id="__next"><div style="font-family:system-ui,&quot;Segoe UI&quot;,Roboto,Helvetica,Arial,sans-serif,&quot;Apple Color Emoji&quot;,&quot;Segoe UI Emoji&quot;;height:100vh;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center"><div style="line-height:48px"><style>body{color:#000;background:#fff;margin:0}.next-error-h1{border-right:1px solid rgba(0,0,0,.3)}@media (prefers-color-scheme:dark){body{color:#fff;background:#000}.next-error-h1{border-right:1px solid rgba(255,255,255,.3)}}</style><h1 class="next-error-h1" style="display:inline-block;margin:0 20px 0 0;padding-right:23px;font-size:24px;font-weight:500;vertical-align:top">500</h1><div style="display:inline-block"><h2 style="font-size:14px;font-weight:400;line-height:28px">Internal Server Error<!-- -->.</h2></div></div></div></div><script id="__NEXT_DATA__" type="application/json">{"props":{"pageProps":{"statusCode":500}},"page":"/_error","query":{},"buildId":"25Kcgl6uIxdBmkSgq8yP-","nextExport":true,"isFallback":false,"gip":true,"scriptLoader":[]}</script></body></html>
package/.next/trace CHANGED
@@ -1 +1 @@
1
- [{"name":"generate-buildid","duration":176,"timestamp":2432971181862,"id":4,"parentId":1,"tags":{},"startTime":1762324492570,"traceId":"edd1b4771e8d549b"},{"name":"load-custom-routes","duration":202,"timestamp":2432971182096,"id":5,"parentId":1,"tags":{},"startTime":1762324492570,"traceId":"edd1b4771e8d549b"},{"name":"create-dist-dir","duration":1791,"timestamp":2432971240651,"id":6,"parentId":1,"tags":{},"startTime":1762324492629,"traceId":"edd1b4771e8d549b"},{"name":"create-pages-mapping","duration":299,"timestamp":2432971441046,"id":7,"parentId":1,"tags":{},"startTime":1762324492829,"traceId":"edd1b4771e8d549b"},{"name":"collect-app-files","duration":6864,"timestamp":2432971441422,"id":8,"parentId":1,"tags":{},"startTime":1762324492830,"traceId":"edd1b4771e8d549b"},{"name":"create-app-mapping","duration":2314,"timestamp":2432971448330,"id":9,"parentId":1,"tags":{},"startTime":1762324492837,"traceId":"edd1b4771e8d549b"},{"name":"create-app-layouts","duration":392,"timestamp":2432971450693,"id":10,"parentId":1,"tags":{},"startTime":1762324492839,"traceId":"edd1b4771e8d549b"},{"name":"collect-default-files","duration":10292,"timestamp":2432971457837,"id":12,"parentId":1,"tags":{},"startTime":1762324492846,"traceId":"edd1b4771e8d549b"},{"name":"generate-route-types","duration":66651,"timestamp":2432971451535,"id":11,"parentId":1,"tags":{},"startTime":1762324492840,"traceId":"edd1b4771e8d549b"},{"name":"public-dir-conflict-check","duration":2059,"timestamp":2432971518322,"id":13,"parentId":1,"tags":{},"startTime":1762324492907,"traceId":"edd1b4771e8d549b"},{"name":"generate-routes-manifest","duration":3173,"timestamp":2432971521121,"id":14,"parentId":1,"tags":{},"startTime":1762324492909,"traceId":"edd1b4771e8d549b"},{"name":"run-turbopack-compiler","duration":9053488,"timestamp":2432971592905,"id":16,"parentId":1,"tags":{},"startTime":1762324492981,"traceId":"edd1b4771e8d549b"},{"name":"verify-and-lint","duration":2066493,"timestamp":2432980661029,"id":19,"parentId":1,"tags":{},"startTime":1762324502049,"traceId":"edd1b4771e8d549b"},{"name":"verify-typescript-setup","duration":6300006,"timestamp":2432980658221,"id":18,"parentId":1,"tags":{},"startTime":1762324502047,"traceId":"edd1b4771e8d549b"},{"name":"check-static-error-page","duration":1871,"timestamp":2432986971216,"id":22,"parentId":21,"tags":{},"startTime":1762324508360,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":3022,"timestamp":2432987027260,"id":23,"parentId":21,"tags":{"page":"/_app"},"startTime":1762324508416,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":2511,"timestamp":2432987027780,"id":25,"parentId":21,"tags":{"page":"/_document"},"startTime":1762324508416,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":2574,"timestamp":2432987027718,"id":24,"parentId":21,"tags":{"page":"/_error"},"startTime":1762324508416,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":295092,"timestamp":2432987035923,"id":55,"parentId":35,"tags":{},"startTime":1762324508424,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":302478,"timestamp":2432987028583,"id":35,"parentId":21,"tags":{"page":"/api/assistants"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":297771,"timestamp":2432987034996,"id":50,"parentId":28,"tags":{},"startTime":1762324508423,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":304873,"timestamp":2432987027913,"id":28,"parentId":21,"tags":{"page":"/api/api-keys"},"startTime":1762324508416,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":326257,"timestamp":2432987035496,"id":51,"parentId":31,"tags":{},"startTime":1762324508424,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":334053,"timestamp":2432987028383,"id":31,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/initial-messages"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":338089,"timestamp":2432987039749,"id":58,"parentId":46,"tags":{},"startTime":1762324508428,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":349039,"timestamp":2432987028829,"id":46,"parentId":21,"tags":{"page":"/api/threads/runs/submit-client-tool-outputs"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":348419,"timestamp":2432987046077,"id":60,"parentId":29,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":366636,"timestamp":2432987027921,"id":29,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/functions/[functionId]"},"startTime":1762324508416,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":354282,"timestamp":2432987046096,"id":61,"parentId":27,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":372507,"timestamp":2432987027897,"id":27,"parentId":21,"tags":{"page":"/api/api-keys/[apiKeyId]"},"startTime":1762324508416,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":358536,"timestamp":2432987046098,"id":62,"parentId":32,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":376194,"timestamp":2432987028494,"id":32,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":365987,"timestamp":2432987046102,"id":63,"parentId":34,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":383581,"timestamp":2432987028562,"id":34,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":371993,"timestamp":2432987046104,"id":64,"parentId":41,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":389427,"timestamp":2432987028697,"id":41,"parentId":21,"tags":{"page":"/api/providers/[modelProviderId]"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":406875,"timestamp":2432987046106,"id":65,"parentId":43,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":424278,"timestamp":2432987028734,"id":43,"parentId":21,"tags":{"page":"/api/tasks/[taskId]"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":414469,"timestamp":2432987046274,"id":66,"parentId":47,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":431950,"timestamp":2432987028848,"id":47,"parentId":21,"tags":{"page":"/api/workspaces/[workspaceId]"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":450685,"timestamp":2432987035715,"id":52,"parentId":36,"tags":{},"startTime":1762324508424,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":457858,"timestamp":2432987028602,"id":36,"parentId":21,"tags":{"page":"/api/files/[fileId]/contents"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":451582,"timestamp":2432987046404,"id":68,"parentId":48,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":469168,"timestamp":2432987028870,"id":48,"parentId":21,"tags":{"page":"/api/workspaces"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":454397,"timestamp":2432987046313,"id":67,"parentId":26,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":472964,"timestamp":2432987027795,"id":26,"parentId":21,"tags":{"page":"/_not-found"},"startTime":1762324508416,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":458143,"timestamp":2432987046503,"id":70,"parentId":42,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":475976,"timestamp":2432987028716,"id":42,"parentId":21,"tags":{"page":"/api/providers"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":458666,"timestamp":2432987046500,"id":69,"parentId":30,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":477256,"timestamp":2432987027935,"id":30,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/functions"},"startTime":1762324508416,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":463185,"timestamp":2432987046505,"id":71,"parentId":45,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":480935,"timestamp":2432987028808,"id":45,"parentId":21,"tags":{"page":"/api/tasks"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":464660,"timestamp":2432987046507,"id":72,"parentId":33,"tags":{},"startTime":1762324508435,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":482654,"timestamp":2432987028535,"id":33,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/mcp-servers"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":465926,"timestamp":2432987047336,"id":73,"parentId":49,"tags":{},"startTime":1762324508436,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":484388,"timestamp":2432987028888,"id":49,"parentId":21,"tags":{"page":"/"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":537908,"timestamp":2432987035794,"id":53,"parentId":39,"tags":{},"startTime":1762324508424,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":545085,"timestamp":2432987028655,"id":39,"parentId":21,"tags":{"page":"/api/providers/[modelProviderId]/assistants"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":538734,"timestamp":2432987045357,"id":59,"parentId":44,"tags":{},"startTime":1762324508434,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":555369,"timestamp":2432987028788,"id":44,"parentId":21,"tags":{"page":"/api/tasks/callback"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":551335,"timestamp":2432987039130,"id":57,"parentId":37,"tags":{},"startTime":1762324508428,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":561869,"timestamp":2432987028620,"id":37,"parentId":21,"tags":{"page":"/api/files"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":580010,"timestamp":2432987038112,"id":56,"parentId":38,"tags":{},"startTime":1762324508427,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":589514,"timestamp":2432987028638,"id":38,"parentId":21,"tags":{"page":"/api/messages"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"is-page-static","duration":588541,"timestamp":2432987035832,"id":54,"parentId":40,"tags":{},"startTime":1762324508424,"traceId":"edd1b4771e8d549b"},{"name":"check-page","duration":595726,"timestamp":2432987028672,"id":40,"parentId":21,"tags":{"page":"/api/providers/[modelProviderId]/models"},"startTime":1762324508417,"traceId":"edd1b4771e8d549b"},{"name":"static-check","duration":653769,"timestamp":2432986970650,"id":21,"parentId":1,"tags":{},"startTime":1762324508359,"traceId":"edd1b4771e8d549b"},{"name":"generate-required-server-files","duration":288,"timestamp":2432987624679,"id":75,"parentId":1,"tags":{},"startTime":1762324509013,"traceId":"edd1b4771e8d549b"},{"name":"write-routes-manifest","duration":662,"timestamp":2432987631695,"id":77,"parentId":1,"tags":{},"startTime":1762324509020,"traceId":"edd1b4771e8d549b"},{"name":"load-dotenv","duration":18,"timestamp":2432987644545,"id":80,"parentId":79,"tags":{},"startTime":1762324509033,"traceId":"edd1b4771e8d549b"},{"name":"run-export-path-map","duration":253,"timestamp":2432987748384,"id":81,"parentId":79,"tags":{},"startTime":1762324509137,"traceId":"edd1b4771e8d549b"},{"name":"next-export","duration":754670,"timestamp":2432987643987,"id":79,"parentId":1,"tags":{},"startTime":1762324509032,"traceId":"edd1b4771e8d549b"},{"name":"move-exported-app-not-found-","duration":173165,"timestamp":2432988399722,"id":82,"parentId":78,"tags":{},"startTime":1762324509788,"traceId":"edd1b4771e8d549b"},{"name":"move-exported-page","duration":162993,"timestamp":2432988573008,"id":83,"parentId":78,"tags":{},"startTime":1762324509961,"traceId":"edd1b4771e8d549b"},{"name":"static-generation","duration":1399614,"timestamp":2432987640694,"id":78,"parentId":1,"tags":{},"startTime":1762324509029,"traceId":"edd1b4771e8d549b"},{"name":"write-routes-manifest","duration":112189,"timestamp":2432989040548,"id":84,"parentId":1,"tags":{},"startTime":1762324510429,"traceId":"edd1b4771e8d549b"},{"name":"node-file-trace-build","duration":3986970,"timestamp":2432987626514,"id":76,"parentId":1,"tags":{"isTurbotrace":"false"},"startTime":1762324509015,"traceId":"edd1b4771e8d549b"},{"name":"apply-include-excludes","duration":468,"timestamp":2432991613520,"id":85,"parentId":1,"tags":{},"startTime":1762324513002,"traceId":"edd1b4771e8d549b"},{"name":"print-tree-view","duration":2126,"timestamp":2432991614440,"id":86,"parentId":1,"tags":{},"startTime":1762324513003,"traceId":"edd1b4771e8d549b"},{"name":"telemetry-flush","duration":45,"timestamp":2432991616576,"id":87,"parentId":1,"tags":{},"startTime":1762324513005,"traceId":"edd1b4771e8d549b"},{"name":"next-build","duration":21035340,"timestamp":2432970581285,"id":1,"tags":{"buildMode":"default","isTurboBuild":"true","version":"15.5.4","has-custom-webpack-config":"false","use-build-worker":"true"},"startTime":1762324491970,"traceId":"edd1b4771e8d549b"}]
1
+ [{"name":"generate-buildid","duration":110,"timestamp":2440090930693,"id":4,"parentId":1,"tags":{},"startTime":1762331612330,"traceId":"167107ea80a40fa9"},{"name":"load-custom-routes","duration":154,"timestamp":2440090930847,"id":5,"parentId":1,"tags":{},"startTime":1762331612331,"traceId":"167107ea80a40fa9"},{"name":"create-dist-dir","duration":527,"timestamp":2440090960111,"id":6,"parentId":1,"tags":{},"startTime":1762331612360,"traceId":"167107ea80a40fa9"},{"name":"create-pages-mapping","duration":97,"timestamp":2440091208425,"id":7,"parentId":1,"tags":{},"startTime":1762331612608,"traceId":"167107ea80a40fa9"},{"name":"collect-app-files","duration":2253,"timestamp":2440091208540,"id":8,"parentId":1,"tags":{},"startTime":1762331612608,"traceId":"167107ea80a40fa9"},{"name":"create-app-mapping","duration":836,"timestamp":2440091210804,"id":9,"parentId":1,"tags":{},"startTime":1762331612610,"traceId":"167107ea80a40fa9"},{"name":"create-app-layouts","duration":238,"timestamp":2440091211654,"id":10,"parentId":1,"tags":{},"startTime":1762331612611,"traceId":"167107ea80a40fa9"},{"name":"collect-default-files","duration":704,"timestamp":2440091212648,"id":12,"parentId":1,"tags":{},"startTime":1762331612612,"traceId":"167107ea80a40fa9"},{"name":"generate-route-types","duration":11731,"timestamp":2440091212217,"id":11,"parentId":1,"tags":{},"startTime":1762331612612,"traceId":"167107ea80a40fa9"},{"name":"public-dir-conflict-check","duration":333,"timestamp":2440091223997,"id":13,"parentId":1,"tags":{},"startTime":1762331612624,"traceId":"167107ea80a40fa9"},{"name":"generate-routes-manifest","duration":1139,"timestamp":2440091224460,"id":14,"parentId":1,"tags":{},"startTime":1762331612624,"traceId":"167107ea80a40fa9"},{"name":"run-turbopack-compiler","duration":3888744,"timestamp":2440091228229,"id":16,"parentId":1,"tags":{},"startTime":1762331612628,"traceId":"167107ea80a40fa9"},{"name":"verify-and-lint","duration":2334424,"timestamp":2440095124324,"id":19,"parentId":1,"tags":{},"startTime":1762331616524,"traceId":"167107ea80a40fa9"},{"name":"verify-typescript-setup","duration":8502446,"timestamp":2440095122695,"id":18,"parentId":1,"tags":{},"startTime":1762331616522,"traceId":"167107ea80a40fa9"},{"name":"check-static-error-page","duration":4712,"timestamp":2440103657231,"id":22,"parentId":21,"tags":{},"startTime":1762331625057,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1912,"timestamp":2440103742652,"id":23,"parentId":21,"tags":{"page":"/_app"},"startTime":1762331625142,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1329,"timestamp":2440103743244,"id":25,"parentId":21,"tags":{"page":"/_document"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1413,"timestamp":2440103743162,"id":24,"parentId":21,"tags":{"page":"/_error"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":892809,"timestamp":2440103753564,"id":50,"parentId":26,"tags":{},"startTime":1762331625153,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":903201,"timestamp":2440103743260,"id":26,"parentId":21,"tags":{"page":"/_not-found"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":952248,"timestamp":2440103766833,"id":53,"parentId":42,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":975635,"timestamp":2440103743503,"id":42,"parentId":21,"tags":{"page":"/api/providers"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1024632,"timestamp":2440103766869,"id":54,"parentId":45,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1048011,"timestamp":2440103743517,"id":45,"parentId":21,"tags":{"page":"/api/tasks"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1175098,"timestamp":2440103766970,"id":55,"parentId":31,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1198734,"timestamp":2440103743363,"id":31,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/initial-messages"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1174786,"timestamp":2440103767366,"id":57,"parentId":29,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1198814,"timestamp":2440103743345,"id":29,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/functions/[functionId]"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1175434,"timestamp":2440103766752,"id":52,"parentId":33,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1198736,"timestamp":2440103743455,"id":33,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/mcp-servers"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1175564,"timestamp":2440103766652,"id":51,"parentId":30,"tags":{},"startTime":1762331625166,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1198867,"timestamp":2440103743352,"id":30,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/functions"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1186301,"timestamp":2440103767354,"id":56,"parentId":27,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1210383,"timestamp":2440103743322,"id":27,"parentId":21,"tags":{"page":"/api/api-keys/[apiKeyId]"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1212863,"timestamp":2440103767375,"id":58,"parentId":32,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1236862,"timestamp":2440103743442,"id":32,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]/mcp-servers/[mcpServerId]"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1226552,"timestamp":2440103767395,"id":60,"parentId":41,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1250606,"timestamp":2440103743498,"id":41,"parentId":21,"tags":{"page":"/api/providers/[modelProviderId]"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1227771,"timestamp":2440103767401,"id":61,"parentId":43,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1251706,"timestamp":2440103743508,"id":43,"parentId":21,"tags":{"page":"/api/tasks/[taskId]"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1227924,"timestamp":2440103767445,"id":62,"parentId":28,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1252048,"timestamp":2440103743337,"id":28,"parentId":21,"tags":{"page":"/api/api-keys"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1228131,"timestamp":2440103767383,"id":59,"parentId":34,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1252073,"timestamp":2440103743462,"id":34,"parentId":21,"tags":{"page":"/api/assistants/[assistantId]"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1248450,"timestamp":2440103767646,"id":66,"parentId":35,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1272697,"timestamp":2440103743468,"id":35,"parentId":21,"tags":{"page":"/api/assistants"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1265091,"timestamp":2440103770292,"id":70,"parentId":47,"tags":{},"startTime":1762331625170,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1291911,"timestamp":2440103743526,"id":47,"parentId":21,"tags":{"page":"/api/workspaces/[workspaceId]"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1288112,"timestamp":2440103770337,"id":71,"parentId":48,"tags":{},"startTime":1762331625170,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1314940,"timestamp":2440103743535,"id":48,"parentId":21,"tags":{"page":"/api/workspaces"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1290826,"timestamp":2440103767679,"id":67,"parentId":46,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1314997,"timestamp":2440103743522,"id":46,"parentId":21,"tags":{"page":"/api/threads/runs/submit-client-tool-outputs"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1352232,"timestamp":2440103770648,"id":73,"parentId":49,"tags":{},"startTime":1762331625170,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1379390,"timestamp":2440103743540,"id":49,"parentId":21,"tags":{"page":"/"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1541815,"timestamp":2440103767516,"id":63,"parentId":36,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1565976,"timestamp":2440103743473,"id":36,"parentId":21,"tags":{"page":"/api/files/[fileId]/contents"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1565020,"timestamp":2440103770370,"id":72,"parentId":37,"tags":{},"startTime":1762331625170,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1591970,"timestamp":2440103743478,"id":37,"parentId":21,"tags":{"page":"/api/files"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1667892,"timestamp":2440103767521,"id":65,"parentId":39,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1691988,"timestamp":2440103743488,"id":39,"parentId":21,"tags":{"page":"/api/providers/[modelProviderId]/assistants"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1680379,"timestamp":2440103767519,"id":64,"parentId":40,"tags":{},"startTime":1762331625167,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1704445,"timestamp":2440103743492,"id":40,"parentId":21,"tags":{"page":"/api/providers/[modelProviderId]/models"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1696331,"timestamp":2440103768627,"id":68,"parentId":44,"tags":{},"startTime":1762331625168,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1721508,"timestamp":2440103743513,"id":44,"parentId":21,"tags":{"page":"/api/tasks/callback"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"is-page-static","duration":1720409,"timestamp":2440103770191,"id":69,"parentId":38,"tags":{},"startTime":1762331625170,"traceId":"167107ea80a40fa9"},{"name":"check-page","duration":1747149,"timestamp":2440103743483,"id":38,"parentId":21,"tags":{"page":"/api/messages"},"startTime":1762331625143,"traceId":"167107ea80a40fa9"},{"name":"static-check","duration":1833983,"timestamp":2440103656704,"id":21,"parentId":1,"tags":{},"startTime":1762331625056,"traceId":"167107ea80a40fa9"},{"name":"generate-required-server-files","duration":313,"timestamp":2440105491173,"id":75,"parentId":1,"tags":{},"startTime":1762331626891,"traceId":"167107ea80a40fa9"},{"name":"write-routes-manifest","duration":1325,"timestamp":2440105501807,"id":77,"parentId":1,"tags":{},"startTime":1762331626902,"traceId":"167107ea80a40fa9"},{"name":"load-dotenv","duration":20,"timestamp":2440105655016,"id":80,"parentId":79,"tags":{},"startTime":1762331627055,"traceId":"167107ea80a40fa9"},{"name":"run-export-path-map","duration":304,"timestamp":2440105717888,"id":81,"parentId":79,"tags":{},"startTime":1762331627118,"traceId":"167107ea80a40fa9"},{"name":"next-export","duration":1077928,"timestamp":2440105654463,"id":79,"parentId":1,"tags":{},"startTime":1762331627054,"traceId":"167107ea80a40fa9"},{"name":"move-exported-app-not-found-","duration":7899,"timestamp":2440106733692,"id":82,"parentId":78,"tags":{},"startTime":1762331628133,"traceId":"167107ea80a40fa9"},{"name":"move-exported-page","duration":17891,"timestamp":2440106741729,"id":83,"parentId":78,"tags":{},"startTime":1762331628142,"traceId":"167107ea80a40fa9"},{"name":"static-generation","duration":1224034,"timestamp":2440105638871,"id":78,"parentId":1,"tags":{},"startTime":1762331627039,"traceId":"167107ea80a40fa9"},{"name":"write-routes-manifest","duration":7294,"timestamp":2440106863152,"id":84,"parentId":1,"tags":{},"startTime":1762331628263,"traceId":"167107ea80a40fa9"},{"name":"node-file-trace-build","duration":5144688,"timestamp":2440105496663,"id":76,"parentId":1,"tags":{"isTurbotrace":"false"},"startTime":1762331626896,"traceId":"167107ea80a40fa9"},{"name":"apply-include-excludes","duration":369,"timestamp":2440110641378,"id":85,"parentId":1,"tags":{},"startTime":1762331632041,"traceId":"167107ea80a40fa9"},{"name":"print-tree-view","duration":2091,"timestamp":2440110642157,"id":86,"parentId":1,"tags":{},"startTime":1762331632042,"traceId":"167107ea80a40fa9"},{"name":"telemetry-flush","duration":29,"timestamp":2440110644260,"id":87,"parentId":1,"tags":{},"startTime":1762331632044,"traceId":"167107ea80a40fa9"},{"name":"next-build","duration":19962001,"timestamp":2440090682292,"id":1,"tags":{"buildMode":"default","isTurboBuild":"true","version":"15.5.4","has-custom-webpack-config":"false","use-build-worker":"true"},"startTime":1762331612082,"traceId":"167107ea80a40fa9"}]
package/README.md CHANGED
@@ -40,9 +40,9 @@ Check out our [Next.js deployment documentation](https://nextjs.org/docs/app/bui
40
40
  ```bash
41
41
  cd /Users/domas/Developer/supercorp/superinterface
42
42
  npm install
43
- docker buildx bake server-release --set TAG=1.1.4
44
- docker push supercorp/superinterface-server:1.1.4
43
+ docker buildx bake server-release --set server-release.tags=supercorp/superinterface-server:<version>,supercorp/superinterface-server:latest
44
+ docker push supercorp/superinterface-server:<version>
45
45
  docker push supercorp/superinterface-server:latest
46
46
  ```
47
47
 
48
- Replace the tag as needed for future releases.
48
+ Replace `<version>` with the published npm version.
@@ -1 +1 @@
1
- {"version":3,"file":"buildRoute.d.ts","sourceRoot":"","sources":["../../../../src/app/api/messages/buildRoute.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAC5D,OAAO,MAAM,MAAM,QAAQ,CAAA;AAC3B,OAAO,EAIL,KAAK,YAAY,EAClB,MAAM,gBAAgB,CAAA;AACvB,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AA0B5C,eAAO,MAAM,WAAW,MAAM,CAAA;AAE9B,eAAO,MAAM,QAAQ,GAClB,YAAY;IAAE,MAAM,EAAE,YAAY,CAAA;CAAE,MAC9B,SAAS,WAAW;;;;;;;;;;;;;;;;;;4EA2K1B,CAAA;AAEH,eAAO,MAAM,SAAS,GACnB,oCAGE;IACD,MAAM,EAAE,YAAY,CAAA;IACpB,qBAAqB,CAAC,EAAE,CAAC,EACvB,MAAM,GACP,EAAE;QACD,MAAM,EAAE,MAAM,CAAA;KACf,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;CAC3B,MACM,SAAS,WAAW,sBAggB1B,CAAA;AAEH,eAAO,MAAM,YAAY,8BAMtB,CAAA"}
1
+ {"version":3,"file":"buildRoute.d.ts","sourceRoot":"","sources":["../../../../src/app/api/messages/buildRoute.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,WAAW,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAC5D,OAAO,MAAM,MAAM,QAAQ,CAAA;AAC3B,OAAO,EAIL,KAAK,YAAY,EAClB,MAAM,gBAAgB,CAAA;AACvB,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAA;AA0B5C,eAAO,MAAM,WAAW,MAAM,CAAA;AAE9B,eAAO,MAAM,QAAQ,GAClB,YAAY;IAAE,MAAM,EAAE,YAAY,CAAA;CAAE,MAC9B,SAAS,WAAW;;;;;;;;;;;;;;;;;;4EA2K1B,CAAA;AAEH,eAAO,MAAM,SAAS,GACnB,oCAGE;IACD,MAAM,EAAE,YAAY,CAAA;IACpB,qBAAqB,CAAC,EAAE,CAAC,EACvB,MAAM,GACP,EAAE;QACD,MAAM,EAAE,MAAM,CAAA;KACf,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;CAC3B,MACM,SAAS,WAAW,sBAigB1B,CAAA;AAEH,eAAO,MAAM,YAAY,8BAMtB,CAAA"}
@@ -598,9 +598,7 @@ export const buildPOST = ({ prisma, onSuccessCreateThread = () => void 0, }) =>
598
598
  },
599
599
  }), {
600
600
  status: 200,
601
- headers: {
602
- 'Content-Type': 'application/json; charset=utf-8',
603
- },
601
+ headers: Object.assign(Object.assign({}, cacheHeaders), { 'Content-Type': 'application/json; charset=utf-8' }),
604
602
  });
605
603
  };
606
604
  export const buildOPTIONS = () => () => NextResponse.json({}, {
@@ -1 +1 @@
1
- {"version":3,"file":"cacheHeaders.d.ts","sourceRoot":"","sources":["../../../src/lib/cache/cacheHeaders.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY;;;;CAIxB,CAAA"}
1
+ {"version":3,"file":"cacheHeaders.d.ts","sourceRoot":"","sources":["../../../src/lib/cache/cacheHeaders.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,YAAY;;;;CAKxB,CAAA"}
@@ -1,5 +1,5 @@
1
1
  export const cacheHeaders = {
2
2
  'Access-Control-Allow-Origin': '*',
3
3
  'Access-Control-Allow-Methods': 'GET, POST, PUT, DELETE, OPTIONS',
4
- 'Access-Control-Allow-Headers': 'Content-Type',
4
+ 'Access-Control-Allow-Headers': 'Content-Type, Authorization, X-Requested-With, Accept',
5
5
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@superinterface/server",
3
- "version": "1.1.5",
3
+ "version": "1.1.7",
4
4
  "type": "module",
5
5
  "bin": {
6
6
  "superinterface-server": "./bin/index.cjs"