supercompat 2.7.1 → 2.8.0
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.
- package/dist/index.cjs +31 -28
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +1 -1
- package/dist/index.d.ts +1 -1
- package/dist/index.js +26 -27
- package/dist/index.js.map +1 -1
- package/dist/supercompat.cjs +5 -1
- package/dist/supercompat.cjs.map +1 -1
- package/dist/supercompat.js.map +1 -1
- package/dist/types/index.cjs +5 -1
- package/dist/types/index.cjs.map +1 -1
- package/dist/types/prisma.cjs +5 -1
- package/dist/types/prisma.cjs.map +1 -1
- package/dist/types/prisma.js.map +1 -1
- package/package.json +11 -11
package/dist/index.cjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/supercompat.ts","../src/supercompatFetch/requestHandlers.ts","../src/supercompatFetch/findRequestHandler.ts","../src/supercompatFetch/originalFetch.ts","../src/supercompatFetch/index.ts","../src/lib/azureOpenai/endpointFromBaseUrl.ts","../src/adapters/client/groqClientAdapter/completions/post.ts","../src/adapters/client/groqClientAdapter/completions/index.ts","../src/adapters/client/groqClientAdapter/index.ts","../src/adapters/client/openaiClientAdapter/completions/post.ts","../src/adapters/client/openaiClientAdapter/completions/index.ts","../src/adapters/client/openaiClientAdapter/index.ts","../src/adapters/client/azureOpenaiClientAdapter/index.ts","../src/adapters/client/mistralClientAdapter/completions/post.ts","../src/adapters/client/mistralClientAdapter/completions/index.ts","../src/adapters/client/mistralClientAdapter/index.ts","../src/lib/messages/alternatingMessages.ts","../src/adapters/client/perplexityClientAdapter/completions/post.ts","../src/adapters/client/perplexityClientAdapter/completions/index.ts","../src/adapters/client/perplexityClientAdapter/index.ts","../src/adapters/client/anthropicClientAdapter/completions/post.ts","../src/lib/messages/nonEmptyMessages.ts","../src/lib/messages/firstUserMessages.ts","../src/adapters/client/anthropicClientAdapter/completions/serializeTools.ts","../src/adapters/client/anthropicClientAdapter/completions/serializeMessages/serializeMessage.ts","../src/adapters/client/anthropicClientAdapter/completions/serializeMessages/index.ts","../src/adapters/client/anthropicClientAdapter/completions/index.ts","../src/adapters/client/anthropicClientAdapter/index.ts","../src/adapters/run/completionsRunAdapter/index.ts","../src/adapters/run/completionsRunAdapter/messages/index.ts","../src/adapters/run/completionsRunAdapter/messages/serializeMessage.ts","../src/lib/messages/messagesRegexp.ts","../src/lib/runs/runsRegexp.ts","../src/lib/runs/runRegexp.ts","../src/lib/runs/submitToolOutputsRegexp.ts","../src/lib/steps/stepsRegexp.ts","../src/adapters/storage/prismaStorageAdapter/threads/post.ts","../src/adapters/storage/prismaStorageAdapter/threads/serializeThread.ts","../src/adapters/storage/prismaStorageAdapter/threads/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/messages/serializeMessage.ts","../src/adapters/storage/prismaStorageAdapter/threads/messages/post.ts","../src/adapters/storage/prismaStorageAdapter/threads/messages/get.ts","../src/adapters/storage/prismaStorageAdapter/threads/messages/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/get.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/serializeRun.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/post.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunInProgress.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunFailed.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunCompleted.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunRequiresAction.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/steps/serializeRunStep.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunStepCreated.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunStepDelta.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadMessageCreated.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadMessageDelta.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadMessageCompleted.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/getMessages.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/run/get.ts","../src/adapters/storage/prismaStorageAdapter/threads/run/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/steps/get.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/steps/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/submitToolOutputs/post/updateRun.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/submitToolOutputs/post/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/submitToolOutputs/index.ts","../src/adapters/storage/prismaStorageAdapter/index.ts"],"names":["requestHandlers","OpenAI","post","completions","messages","import_radash","content","serializeMessage","run","getMessages","_","onEvent","dayjs","import_dayjs","get","runs","status","data","prisma"],"mappings":"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","sourcesContent":["export { supercompat } from './supercompat'\nexport { groqClientAdapter } from './adapters/client/groqClientAdapter'\nexport { openaiClientAdapter } from './adapters/client/openaiClientAdapter'\nexport { azureOpenaiClientAdapter } from './adapters/client/azureOpenaiClientAdapter'\nexport { mistralClientAdapter } from './adapters/client/mistralClientAdapter'\nexport { perplexityClientAdapter } from './adapters/client/perplexityClientAdapter'\nexport { anthropicClientAdapter } from './adapters/client/anthropicClientAdapter'\nexport { completionsRunAdapter } from './adapters/run/completionsRunAdapter'\nexport { prismaStorageAdapter } from './adapters/storage/prismaStorageAdapter'\n","import OpenAI, { AzureOpenAI } from 'openai'\nimport { supercompatFetch, type Args } from './supercompatFetch'\nimport { endpointFromBaseUrl } from '@/lib/azureOpenai/endpointFromBaseUrl'\n\nexport const supercompat = ({\n client,\n storage,\n runAdapter,\n}: Args) => {\n if (client.type === 'AZURE_OPENAI') {\n return new AzureOpenAI({\n apiKey: client.client.apiKey,\n apiVersion: client.client.apiVersion,\n endpoint: endpointFromBaseUrl({ baseURL: client.client.baseURL }),\n fetch: supercompatFetch({\n client,\n storage,\n runAdapter,\n }),\n })\n }\n\n return new OpenAI({\n apiKey: 'SUPERCOMPAT_PLACEHOLDER_OPENAI_KEY',\n fetch: supercompatFetch({\n client,\n storage,\n runAdapter,\n }),\n })\n}\n","import { assign, partob } from 'radash'\nimport { RunAdapter, StorageAdapterArgs } from '@/types'\n\nconst storageRequestHandlers = ({\n storage,\n runAdapter,\n client,\n}: {\n storage?: (arg0: StorageAdapterArgs) => any\n runAdapter?: RunAdapter\n client: any\n}) => {\n if (!storage) return {}\n if (!runAdapter) return {}\n\n const result = storage({ runAdapter: partob(runAdapter, { client }) })\n return result.requestHandlers\n}\n\nexport const requestHandlers = ({\n client,\n storage,\n runAdapter,\n}: {\n client: any\n storage?: (arg0: StorageAdapterArgs) => any\n runAdapter?: RunAdapter\n}) => (\n assign(\n client.requestHandlers,\n storageRequestHandlers({\n storage,\n runAdapter,\n client,\n })\n )\n)\n","export const findRequestHandler = ({\n url,\n requestHandlers,\n}: {\n url: string\n requestHandlers: any\n}) => {\n const pathname = new URL(url).pathname\n\n for (const key in requestHandlers) {\n const regex = new RegExp(key)\n\n if (regex.test(pathname)) {\n return requestHandlers[key]\n }\n }\n}\n","export const originalFetch = ({\n args,\n client,\n}: {\n args: any[]\n client: any\n}) => {\n if (client.client?.fetch) {\n const [url, options] = args\n\n const headers = {\n ...options.headers,\n authorization: client.client.defaultHeaders().Authorization,\n }\n\n return client.client.fetch(url, {\n ...options,\n headers,\n })\n } else {\n // @ts-ignore-next-line\n return fetch(...args)\n }\n}\n","import { RunAdapter, StorageAdapterArgs } from '@/types'\nimport { requestHandlers as getRequestHandlers } from './requestHandlers'\nimport { findRequestHandler } from './findRequestHandler'\nimport { originalFetch } from './originalFetch'\n\nexport type Args = {\n client: any\n storage?: (arg0: StorageAdapterArgs) => any\n runAdapter?: RunAdapter\n}\n\nexport const supercompatFetch = ({\n client,\n storage,\n runAdapter,\n}: Args) => {\n const requestHandlers = getRequestHandlers({\n client,\n storage,\n runAdapter,\n })\n\n return async (...args: any[]) => {\n const [url, options] = args\n\n const pathHandler = findRequestHandler({\n url,\n requestHandlers,\n })\n\n if (!pathHandler) {\n return originalFetch({\n client,\n args,\n })\n }\n\n const requestHandler = pathHandler[options?.method]\n\n if (!requestHandler) {\n return originalFetch({\n client,\n args,\n })\n }\n\n return requestHandler(...args)\n }\n}\n","export const endpointFromBaseUrl = ({\n baseURL\n}: {\n baseURL: string\n}) => (\n baseURL.replace(/\\/+openai$/, '')\n)\n","import type Groq from 'groq-sdk'\n\nexport const post = ({\n groq,\n}: {\n groq: Groq\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n if (body.stream) {\n const response = await groq.chat.completions.create(body)\n\n const stream = new ReadableStream({\n async start(controller) {\n // @ts-ignore-next-line\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\\n\\n`)\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n const data = await groq.chat.completions.create(body)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type Groq from 'groq-sdk'\nimport { post } from './post'\n\nexport const completions = ({\n groq,\n}: {\n groq: Groq\n}) => ({\n post: post({ groq }),\n})\n","// import type Groq from 'groq-sdk'\nimport { completions } from './completions'\n\nexport const groqClientAdapter = ({\n groq,\n}: {\n // TODO\n groq: any\n}) => ({\n client: groq,\n requestHandlers: {\n '^/v1/chat/completions$': completions({ groq }),\n },\n})\n","import type OpenAI from 'openai'\n\nexport const post = ({\n openai,\n}: {\n openai: OpenAI\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n if (body.stream) {\n const response = await openai.chat.completions.create(body)\n\n const stream = new ReadableStream({\n async start(controller) {\n // @ts-ignore-next-line\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\\n\\n`)\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n const data = await openai.chat.completions.create(body)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type OpenAI from 'openai'\nimport { post } from './post'\n\nexport const completions = ({\n openai,\n}: {\n openai: OpenAI\n}) => ({\n post: post({ openai }),\n})\n","import type OpenAI from 'openai'\nimport { completions } from './completions'\n\nexport const openaiClientAdapter = ({\n openai,\n}: {\n openai: OpenAI\n}) => ({\n client: openai,\n requestHandlers: {\n '^/(?:v1|/?openai)/chat/completions$': completions({ openai }),\n },\n})\n","import type { AzureOpenAI } from 'openai'\nimport { completions } from '@/adapters/client/openaiClientAdapter/completions'\n\nexport const azureOpenaiClientAdapter = ({\n azureOpenai,\n}: {\n azureOpenai: AzureOpenAI\n}) => ({\n type: 'AZURE_OPENAI',\n client: azureOpenai,\n requestHandlers: {\n '^/(?:v1|/?openai)/chat/completions$': completions({\n openai: azureOpenai,\n }),\n },\n})\n","import type Mistral from '@mistralai/mistralai'\n\nexport const post = ({\n mistral,\n}: {\n mistral: Mistral\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n if (body.stream) {\n const response = await mistral.chatStream(body)\n\n const stream = new ReadableStream({\n async start(controller) {\n // @ts-ignore-next-line\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\\n\\n`)\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n const data = await mistral.chat(body)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type Mistral from '@mistralai/mistralai'\nimport { post } from './post'\n\nexport const completions = ({\n mistral,\n}: {\n mistral: Mistral\n}) => ({\n post: post({ mistral }),\n})\n","import type Mistral from '@mistralai/mistralai'\nimport { completions } from './completions'\n\nexport const mistralClientAdapter = ({\n mistral,\n}: {\n mistral: Mistral\n}) => ({\n client: mistral,\n requestHandlers: {\n '^/v1/chat/completions$': completions({ mistral }),\n },\n})\n","import type OpenAI from 'openai'\n\nconst agentSideRoles = ['assistant', 'system']\n\nexport const alternatingMessages = ({\n messages,\n}: {\n messages: OpenAI.Chat.ChatCompletionMessageParam[]\n}) => {\n const result = [] as OpenAI.Chat.ChatCompletionMessageParam[]\n\n messages.forEach((message: OpenAI.Chat.ChatCompletionMessageParam, index: number) => {\n result.push(message)\n\n const nextMessage = messages[index + 1]\n if (!nextMessage) return\n\n if (message.role === 'user' && nextMessage.role === 'user') {\n result.push({\n role: 'assistant',\n content: '-',\n })\n } else if (agentSideRoles.includes(message.role) && agentSideRoles.includes(nextMessage.role)) {\n result.push({\n role: 'user',\n content: '-',\n })\n }\n })\n\n return result\n}\n","import type OpenAI from 'openai'\nimport { alternatingMessages } from '@/lib/messages/alternatingMessages'\n\nexport const post = ({\n perplexity,\n}: {\n perplexity: OpenAI\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n const messages = alternatingMessages({\n messages: body.messages,\n })\n\n if (body.stream) {\n const response = await perplexity.chat.completions.create({\n ...body,\n messages,\n })\n\n const stream = new ReadableStream({\n async start(controller) {\n // @ts-ignore-next-line\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\\n\\n`)\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n const data = await perplexity.chat.completions.create(body)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type OpenAI from 'openai'\nimport { post } from './post'\n\nexport const completions = ({\n perplexity,\n}: {\n perplexity: OpenAI\n}) => ({\n post: post({ perplexity }),\n})\n","import type OpenAI from 'openai'\nimport { completions } from './completions'\n\nexport const perplexityClientAdapter = ({\n perplexity,\n}: {\n perplexity: OpenAI\n}) => ({\n client: perplexity,\n requestHandlers: {\n '^/v1/chat/completions$': completions({ perplexity }),\n },\n})\n","import type Anthropic from '@anthropic-ai/sdk'\nimport type OpenAI from 'openai'\nimport { uid, fork, omit, isEmpty } from 'radash'\nimport { nonEmptyMessages } from '@/lib/messages/nonEmptyMessages'\nimport { alternatingMessages } from '@/lib/messages/alternatingMessages'\nimport { firstUserMessages } from '@/lib/messages/firstUserMessages'\nimport { serializeTools } from './serializeTools'\nimport { serializeMessages } from './serializeMessages'\n\nexport const post = ({\n anthropic,\n}: {\n anthropic: Anthropic\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n const messages = body.messages as OpenAI.ChatCompletionMessageParam[]\n const [systemMessages, otherMessages] = fork(messages, (message) => message.role === 'system')\n const system = systemMessages.map((message) => message.content).join('\\n')\n\n const chatMessages = nonEmptyMessages({\n messages: firstUserMessages({\n messages: alternatingMessages({\n messages: otherMessages,\n }),\n }),\n })\n\n const resultOptions = {\n ...omit(body, ['response_format']),\n stream: body.stream ? isEmpty(body.tools) : false,\n system,\n messages: serializeMessages({\n messages: chatMessages,\n }),\n max_tokens: 4096,\n tools: serializeTools({\n tools: body.tools,\n }),\n }\n\n if (body.stream) {\n // @ts-ignore-next-line\n const response = await anthropic.messages.stream(resultOptions)\n\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n if (chunk.type === 'content_block_delta') {\n const delta = chunk.delta.type === 'input_json_delta' ? {\n tool_calls: [\n {\n index: 0,\n function: {\n arguments: chunk.delta.partial_json,\n },\n },\n ]\n } : {\n content: chunk.delta.text,\n }\n\n const messageDelta = {\n id: `chatcmpl-${uid(29)}`,\n object: 'chat.completion.chunk',\n choices: [\n {\n index: chunk.index,\n delta,\n },\n ],\n }\n\n controller.enqueue(`data: ${JSON.stringify(messageDelta)}\\n\\n`)\n } else if (chunk.type === 'content_block_start') {\n const delta = chunk.content_block.type === 'tool_use' ? {\n content: null,\n tool_calls: [\n {\n index: 0,\n id: chunk.content_block.id,\n type: 'function',\n function: {\n name: chunk.content_block.name,\n arguments: '',\n }\n }\n ],\n } : {\n content: chunk.content_block.text,\n }\n\n const messageDelta = {\n id: `chatcmpl-${uid(29)}`,\n object: 'chat.completion.chunk',\n choices: [\n {\n index: chunk.index,\n delta,\n },\n ],\n }\n\n controller.enqueue(`data: ${JSON.stringify(messageDelta)}\\n\\n`)\n } else if (chunk.type === 'message_start') {\n const messageDelta = {\n id: `chatcmpl-${uid(29)}`,\n object: 'chat.completion.chunk',\n choices: [\n {\n index: 0,\n delta: {\n content: '',\n },\n },\n ],\n }\n\n controller.enqueue(`data: ${JSON.stringify(messageDelta)}\\n\\n`)\n }\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n // @ts-ignore-next-line\n const data = await anthropic.messages.create(resultOptions)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type OpenAI from 'openai'\nimport { isEmpty } from 'radash'\n\nexport const nonEmptyMessages = ({\n messages,\n}: {\n messages: OpenAI.Chat.ChatCompletionMessageParam[]\n}) => {\n const result = [] as OpenAI.Chat.ChatCompletionMessageParam[]\n\n messages.forEach((message: OpenAI.Chat.ChatCompletionMessageParam) => (\n result.push({\n ...message,\n content: isEmpty(message.content) ? '-' : message.content as string,\n })\n ))\n\n return result\n}\n","import type OpenAI from 'openai'\n\nexport const firstUserMessages = ({\n messages,\n}: {\n messages: OpenAI.Chat.ChatCompletionMessageParam[]\n}): OpenAI.Chat.ChatCompletionMessageParam[] => {\n const firstMessage = messages[0]\n if (!firstMessage) return messages\n\n if (firstMessage.role !== 'user') {\n return [\n {\n role: 'user',\n content: '-',\n },\n ...messages,\n ]\n }\n\n return messages\n}\n","import type OpenAI from 'openai'\n\nexport const serializeTools = ({\n tools,\n}: {\n tools: OpenAI.Beta.AssistantTool[] | undefined\n}) => (\n (tools ?? []).map((tool: OpenAI.Beta.AssistantTool) => {\n if (tool.type === 'function') {\n return {\n name: tool.function.name,\n description: tool.function.description,\n input_schema: tool.function.parameters ?? {\n type: 'object',\n },\n }\n }\n\n return tool\n })\n)\n","import type OpenAI from 'openai'\n\nexport const serializeMessage = ({\n message,\n}: {\n message: OpenAI.ChatCompletionMessageParam\n}) => {\n if (message.role === 'user') {\n return {\n role: 'user',\n content: message.content,\n }\n } else if (message.role === 'assistant') {\n return {\n role: 'assistant',\n content: [\n {\n type: 'text',\n text: message.content,\n },\n ...(message.tool_calls ?? []).map((toolCall) => ({\n type: 'tool_use',\n id: toolCall.id,\n name: toolCall.function.name,\n ...(toolCall.function.arguments ? { input: JSON.parse(toolCall.function.arguments) } : {}),\n })),\n ],\n }\n } else if (message.role === 'tool') {\n return {\n role: 'user',\n content: [\n {\n type: 'tool_result',\n tool_use_id: message.tool_call_id,\n content: message.content,\n },\n ],\n }\n }\n}\n","import type OpenAI from 'openai'\nimport { serializeMessage } from './serializeMessage'\n\nexport const serializeMessages = ({\n messages,\n}: {\n messages: OpenAI.ChatCompletionMessageParam[]\n}) => (\n messages.map(message => (\n serializeMessage({\n message,\n })\n ))\n)\n","import type Anthropic from '@anthropic-ai/sdk'\nimport { post } from './post'\n\nexport const completions = ({\n anthropic,\n}: {\n anthropic: Anthropic\n}) => ({\n post: post({ anthropic }),\n})\n","import type Anthropic from '@anthropic-ai/sdk'\nimport { completions } from './completions'\n\nexport const anthropicClientAdapter = ({\n anthropic,\n}: {\n anthropic: Anthropic\n}) => ({\n client: anthropic,\n requestHandlers: {\n '^/v1/chat/completions$': completions({ anthropic }),\n },\n})\n","import _ from 'lodash'\nimport { uid, omit, isEmpty } from 'radash'\nimport dayjs from 'dayjs'\nimport OpenAI from 'openai'\nimport { MessageWithRun } from '@/types'\nimport { messages } from './messages'\nimport { supercompat } from '@/supercompat'\n\nconst updatedToolCall = ({\n toolCall,\n delta,\n}: {\n toolCall: any\n delta: any\n}) => {\n if (!toolCall) return omit(delta, ['index'])\n\n // if (delta.type !== 'function') return toolCall\n\n const result = _.cloneDeep(toolCall)\n\n for (const [key, value] of Object.entries(delta.function)) {\n result.function[key] = `${result.function[key] ?? ''}${value}`\n }\n\n return result\n}\n\nconst toolCallsData = ({\n prevToolCalls,\n delta,\n}: {\n prevToolCalls: any\n delta: any\n}) => {\n if (!prevToolCalls) {\n return delta.tool_calls.map((tc: any) => ({\n id: uid(24),\n type: 'function',\n ...omit(tc, ['index']),\n }))\n }\n\n const newToolCalls = _.cloneDeep(prevToolCalls)\n\n for (const runStepDelta of delta.tool_calls) {\n newToolCalls[runStepDelta.index] = updatedToolCall({\n toolCall: newToolCalls[runStepDelta.index],\n delta: runStepDelta,\n })\n }\n\n return newToolCalls\n}\n\nexport const completionsRunAdapter = () => async ({\n client: clientAdapter,\n run,\n onEvent,\n getMessages,\n}: {\n client: OpenAI\n run: OpenAI.Beta.Threads.Run\n onEvent: (event: OpenAI.Beta.AssistantStreamEvent) => Promise<any>\n getMessages: () => Promise<MessageWithRun[]>\n}) => {\n if (run.status !== 'queued') return\n\n const client = supercompat({\n client: clientAdapter,\n })\n\n onEvent({\n event: 'thread.run.in_progress',\n data: {\n ...run,\n status: 'in_progress',\n },\n })\n\n const opts = {\n messages: await messages({\n run,\n getMessages,\n }),\n model: run.model,\n stream: true,\n response_format: run.response_format,\n ...(isEmpty(run.tools) ? {} : { tools: run.tools }),\n } as OpenAI.ChatCompletionCreateParamsStreaming\n\n let providerResponse\n\n try {\n providerResponse = await client.chat.completions.create(opts)\n } catch(e: any) {\n console.error(e)\n\n return onEvent({\n event: 'thread.run.failed',\n data: {\n ...run,\n failed_at: dayjs().unix(),\n status: 'in_progress',\n last_error: {\n code: 'server_error',\n message: `${e?.message ?? ''} ${e?.cause?.message ?? ''}`,\n },\n },\n })\n }\n\n let message = await onEvent({\n event: 'thread.message.created',\n data: {\n id: 'THERE_IS_A_BUG_IN_SUPERCOMPAT_IF_YOU_SEE_THIS_ID',\n object: 'thread.message',\n completed_at: null,\n run_id: run.id,\n created_at: dayjs().unix(),\n assistant_id: run.assistant_id,\n incomplete_at: null,\n incomplete_details: null,\n metadata: {},\n attachments: [],\n thread_id: run.thread_id,\n content: [{ text: { value: '', annotations: [] }, type: 'text' }],\n role: 'assistant',\n status: 'in_progress',\n },\n })\n\n onEvent({\n event: 'thread.run.step.created',\n data: {\n id: 'THERE_IS_A_BUG_IN_SUPERCOMPAT_IF_YOU_SEE_THIS_ID',\n object: 'thread.run.step',\n run_id: run.id,\n assistant_id: run.assistant_id,\n thread_id: run.thread_id,\n type: 'message_creation',\n status: 'completed',\n completed_at: dayjs().unix(),\n created_at: dayjs().unix(),\n expired_at: null,\n last_error: null,\n metadata: {},\n failed_at: null,\n cancelled_at: null,\n usage: null,\n step_details: {\n type: 'message_creation',\n message_creation: {\n message_id: message.id,\n },\n },\n },\n })\n\n let toolCallsRunStep\n let currentContent = ''\n let currentToolCalls\n\n for await (const chunk of providerResponse) {\n const choice = chunk.choices[0]\n if (!choice) continue\n\n const delta = choice.delta\n\n if (delta.content) {\n currentContent = `${currentContent}${delta.content ?? ''}`\n }\n\n if (delta.tool_calls) {\n if (!toolCallsRunStep) {\n toolCallsRunStep = await onEvent({\n event: 'thread.run.step.created',\n data: {\n id: 'THERE_IS_A_BUG_IN_SUPERCOMPAT_IF_YOU_SEE_THIS_ID',\n object: 'thread.run.step',\n run_id: run.id,\n assistant_id: run.assistant_id,\n thread_id: run.thread_id,\n type: 'tool_calls',\n status: 'in_progress',\n completed_at: null,\n created_at: dayjs().unix(),\n expired_at: null,\n last_error: null,\n metadata: {},\n failed_at: null,\n cancelled_at: null,\n usage: null,\n step_details: {\n type: 'tool_calls',\n tool_calls: [],\n },\n },\n })\n }\n\n onEvent({\n event: 'thread.run.step.delta',\n data: {\n object: 'thread.run.step.delta',\n run_id: run.id,\n id: toolCallsRunStep.id,\n delta: {\n step_details: {\n type: 'tool_calls',\n tool_calls: delta.tool_calls.map((tc: any) => ({\n id: uid(24),\n type: 'function',\n ...tc,\n })),\n },\n },\n },\n } as OpenAI.Beta.AssistantStreamEvent.ThreadRunStepDelta)\n\n currentToolCalls = toolCallsData({ prevToolCalls: currentToolCalls, delta })\n }\n\n if (delta.content) {\n onEvent({\n event: 'thread.message.delta',\n data: {\n id: message.id,\n delta: {\n content: [\n {\n type: 'text',\n index: 0,\n text: {\n value: delta.content,\n },\n },\n ],\n },\n },\n } as OpenAI.Beta.AssistantStreamEvent.ThreadMessageDelta)\n }\n }\n\n message = await onEvent({\n event: 'thread.message.completed',\n data: {\n ...message,\n status: 'completed',\n content: [{ text: { value: currentContent, annotations: [] }, type: 'text' }],\n tool_calls: currentToolCalls,\n },\n })\n\n if (isEmpty(message.toolCalls)) {\n return onEvent({\n event: 'thread.run.completed',\n data: {\n ...run,\n status: 'completed',\n completed_at: dayjs().unix(),\n },\n })\n }\n\n return onEvent({\n event: 'thread.run.requires_action',\n data: {\n ...run,\n status: 'requires_action',\n required_action: {\n type: 'submit_tool_outputs',\n submit_tool_outputs: {\n tool_calls: message.toolCalls,\n },\n },\n },\n })\n}\n","import type OpenAI from 'openai'\nimport { flat } from 'radash'\nimport { MessageWithRun } from '@/types'\nimport { serializeMessage } from './serializeMessage'\n\nexport const messages = async ({\n run,\n getMessages,\n}: {\n run: OpenAI.Beta.Threads.Run\n getMessages: () => Promise<MessageWithRun[]>\n}) => (\n [\n ...(run.instructions ? [{\n role: 'system',\n content: run.instructions,\n }] : []),\n ...flat((await getMessages()).map((message: MessageWithRun) => serializeMessage({ message }))),\n ]\n)\n","import type OpenAI from 'openai'\nimport { MessageWithRun } from '@/types'\n\nconst serializeToolCall = ({\n toolCall,\n}: {\n toolCall: OpenAI.Beta.Threads.Runs.Steps.FunctionToolCall\n}) => ({\n tool_call_id: toolCall.id,\n role: 'tool' as 'tool',\n name: toolCall.function.name,\n content: toolCall.function.output ?? '',\n})\n\nconst serializeMessageWithContent = ({\n message,\n}: {\n message: MessageWithRun\n}) => ({\n role: message.role,\n content: serializeContent({\n content: message.content as unknown as OpenAI.Beta.Threads.Messages.TextContentBlock[],\n }),\n ...(message?.metadata?.toolCalls ? { tool_calls: message.metadata.toolCalls } : {}),\n})\n\nconst serializeContent = ({\n content,\n}: {\n content: OpenAI.Beta.Threads.Messages.TextContentBlock[]\n}) => content.map((content) => content.text.value).join('\\n')\n\nexport const serializeMessage = ({\n message\n}: {\n message: MessageWithRun\n}) => {\n const result = [serializeMessageWithContent({ message })]\n\n const run = message.run\n\n if (!run) return result\n\n const messageToolCalls = message.metadata?.toolCalls || []\n\n messageToolCalls.forEach((tc: OpenAI.Beta.Threads.Runs.Steps.ToolCall) => {\n const runStep = run.runSteps.find((rs) => {\n if (rs.type !== 'tool_calls') return false\n\n return rs.step_details.tool_calls.some((rsTc: OpenAI.Beta.Threads.Runs.Steps.ToolCall) => {\n if (rsTc.type !== 'function') return false\n\n return rsTc.id === tc.id\n })\n })\n\n if (!runStep) return\n\n const toolCall = runStep.step_details.tool_calls.find((rsTc: OpenAI.Beta.Threads.Runs.Steps.ToolCall) => {\n if (rsTc.type !== 'function') return false\n\n return rsTc.id === tc.id\n })\n\n result.push(serializeToolCall({ toolCall }))\n })\n\n return result\n}\n","export const messagesRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/messages$'\n","export const runsRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/runs$'\n","export const runRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/runs/([^/]+)$'\n","export const submitToolOutputsRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/runs/([^/]+)/submit_tool_outputs$'\n","export const stepsRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/runs/([^/]+)/steps$'\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport dayjs from 'dayjs'\nimport { serializeThread } from './serializeThread'\n\ntype ThreadCreateResponse = Response & {\n json: () => Promise<OpenAI.Beta.Threads['create']>\n}\n\nexport const post = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (...args: Parameters<OpenAI.Beta.Threads['create']>): Promise<ThreadCreateResponse> => {\n // @ts-ignore-next-line\n const body = JSON.parse(args[1].body)\n\n const messages = body.messages || []\n const metadata = body.metadata || {}\n\n const initialCreatedAt = dayjs().subtract(messages.length, 'seconds').format()\n\n const thread = await prisma.thread.create({\n data: {\n metadata,\n ...(metadata.assistantId ? ({\n assistant: {\n connect: {\n id: metadata.assistantId,\n },\n },\n }) : {}),\n messages: {\n create: messages.map((message: OpenAI.Beta.ThreadCreateParams.Message, index: number) => ({\n role: message.role === 'user' ? 'USER' : 'ASSISTANT',\n content: [{\n type: 'text',\n text: {\n annotations: [],\n value: message.content,\n },\n },\n ],\n attachments: message.attachments,\n metadata: message.metadata,\n createdAt: dayjs(initialCreatedAt).add(index, 'seconds').toDate(),\n })),\n },\n },\n })\n\n return new Response(JSON.stringify(\n serializeThread({ thread }),\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","// @ts-ignore-next-line\nimport type { Thread } from '@prisma/client'\nimport dayjs from 'dayjs'\n\nexport const serializeThread = ({\n thread,\n}: {\n thread: Thread\n}) => ({\n id: thread.id,\n object: 'thread' as 'thread',\n created_at: dayjs(thread.createdAt).unix(),\n metadata: thread.metadata,\n // TODO\n tool_resources: null,\n})\n","import type { PrismaClient } from '@prisma/client'\nimport { post } from './post'\n\nexport const threads = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => ({\n post: post({ prisma }),\n})\n","// @ts-ignore-next-line\nimport type { Message } from '@prisma/client'\nimport dayjs from 'dayjs'\nimport type OpenAI from 'openai'\nimport { assign } from 'radash'\n\nexport const serializeMessage = ({\n message,\n}: {\n message: Message\n}) => ({\n id: message.id,\n object: 'thread.message' as 'thread.message',\n created_at: dayjs(message.createdAt).unix(),\n thread_id: message.threadId,\n completed_at: message.completedAt ? dayjs(message.completedAt).unix() : null,\n incomplete_at: message.incompleteAt ? dayjs(message.incompleteAt).unix() : null,\n incomplete_details: message.incompleteDetails as unknown as OpenAI.Beta.Threads.Messages.Message.IncompleteDetails,\n role: message.role.toLowerCase() as 'user' | 'assistant',\n content: message.content as unknown as OpenAI.Beta.Threads.Messages.TextContentBlock[],\n assistant_id: message.assistantId,\n run_id: message.runId,\n attachments: message.attachments,\n status: message.status.toLowerCase() as OpenAI.Beta.Threads.Messages.Message['status'],\n metadata: assign(message.metadata as Record<any, any> ?? {}, message.toolCalls ? { toolCalls: message.toolCalls } : {}),\n})\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport { serializeMessage } from './serializeMessage'\nimport { messagesRegexp } from '@/lib/messages/messagesRegexp'\n\ntype MessageCreateResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Messages['create']>>\n}\n\nconst messageContentBlocks = ({\n content,\n}: {\n content: string\n}) => ([\n {\n type: 'text',\n text: {\n value: content ?? '',\n annotations: [],\n },\n },\n])\n\nexport const post = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string, options: any): Promise<MessageCreateResponse> => {\n const url = new URL(urlString)\n\n const [, threadId] = url.pathname.match(new RegExp(messagesRegexp))!\n\n const body = JSON.parse(options.body)\n const { role, content } = body\n\n const message = await prisma.message.create({\n data: {\n threadId,\n content: messageContentBlocks({ content }),\n role: role === 'user' ? 'USER' : 'ASSISTANT',\n },\n })\n\n return new Response(JSON.stringify(\n serializeMessage({ message }),\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","import type OpenAI from 'openai'\n// @ts-ignore-next-line\nimport type { PrismaClient, Message } from '@prisma/client'\nimport { assign, last } from 'radash'\nimport { messagesRegexp } from '@/lib/messages/messagesRegexp'\nimport { serializeMessage } from './serializeMessage'\n\ntype MessageCreateResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Messages['create']>>\n}\n\nexport const get = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string): Promise<MessageCreateResponse> => {\n const url = new URL(urlString)\n\n const [, threadId] = url.pathname.match(new RegExp(messagesRegexp))!\n\n const {\n limit,\n order,\n after,\n } = assign({\n limit: '20',\n order: 'desc',\n // after: null,\n }, Object.fromEntries(url.searchParams))\n\n const messages = await prisma.message.findMany({\n where: {\n threadId,\n },\n take: parseInt(limit),\n orderBy: {\n createdAt: order,\n },\n ...(after ? {\n skip: 1,\n cursor: {\n id: after,\n },\n }: {}),\n }) as Message[]\n\n return new Response(JSON.stringify({\n data: messages.map((message: Message) => (\n serializeMessage({ message })\n )),\n hasNextPage: () => messages.length === parseInt(limit),\n body: {\n last_id: last(messages)?.id ?? null,\n },\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","import type { PrismaClient } from '@prisma/client'\nimport { post } from './post'\nimport { get } from './get'\n\nexport const messages = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => ({\n post: post({ prisma }),\n get: get({ prisma }),\n})\n","import type OpenAI from 'openai'\n// @ts-ignore-next-line\nimport type { PrismaClient, Run } from '@prisma/client'\nimport { assign, last } from 'radash'\nimport { runsRegexp } from '@/lib/runs/runsRegexp'\nimport { serializeRun } from './serializeRun'\n\ntype MessageCreateResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Messages['create']>>\n}\n\nexport const get = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string): Promise<MessageCreateResponse> => {\n const url = new URL(urlString)\n\n const [, threadId] = url.pathname.match(new RegExp(runsRegexp))!\n\n const {\n limit,\n order,\n after,\n } = assign({\n limit: '20',\n order: 'desc',\n // after: null,\n }, Object.fromEntries(url.searchParams))\n\n const runs = await prisma.run.findMany({\n where: {\n threadId,\n },\n take: parseInt(limit),\n orderBy: {\n createdAt: order,\n },\n ...(after ? {\n skip: 1,\n cursor: {\n id: after,\n },\n }: {}),\n })\n\n return new Response(JSON.stringify({\n data: runs.map((run: Run) => (\n serializeRun({ run })\n )),\n hasNextPage: () => runs.length === parseInt(limit),\n body: {\n // @ts-ignore-next-line\n last_id: last(runs)?.id ?? null,\n },\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","import type OpenAI from 'openai'\n// @ts-ignore-next-line\nimport type { Run } from '@prisma/client'\nimport dayjs from 'dayjs'\n\nexport const serializeRun = ({\n run,\n}: {\n run: Run\n}): OpenAI.Beta.Threads.Run => ({\n id: run.id,\n object: 'thread.run' as 'thread.run',\n created_at: dayjs(run.createdAt).unix(),\n thread_id: run.threadId,\n assistant_id: run.assistantId,\n status: run.status.toLowerCase() as OpenAI.Beta.Threads.Run['status'],\n required_action: run.requiredAction as OpenAI.Beta.Threads.Run['required_action'],\n last_error: run.lastError as OpenAI.Beta.Threads.Run['last_error'],\n expires_at: dayjs(run.expiresAt).unix(),\n started_at: run.startedAt ? dayjs(run.startedAt).unix() : null,\n cancelled_at: run.cancelledAt ? dayjs(run.cancelledAt).unix() : null,\n failed_at: run.failedAt ? dayjs(run.failedAt).unix() : null,\n completed_at: run.completedAt ? dayjs(run.completedAt).unix() : null,\n model: run.model,\n instructions: run.instructions,\n tools: run.tools as OpenAI.Beta.Threads.Run['tools'],\n metadata: run.metadata,\n usage: run.usage as OpenAI.Beta.Threads.Run['usage'],\n truncation_strategy: {\n type: 'auto',\n },\n response_format: {\n type: 'text',\n },\n // TODO\n incomplete_details: null,\n max_completion_tokens: null,\n max_prompt_tokens: null,\n tool_choice: 'auto',\n parallel_tool_calls: true,\n})\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport dayjs from 'dayjs'\nimport { assign } from 'radash'\nimport { runsRegexp } from '@/lib/runs/runsRegexp'\nimport { serializeRun } from './serializeRun'\nimport { RunAdapterPartobClient } from '@/types'\nimport { onEvent } from './onEvent'\nimport { getMessages } from './getMessages'\n\ntype RunCreateResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Runs['create']>>\n}\n\nexport const post = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapterPartobClient\n}) => async (urlString: string, options: any): Promise<RunCreateResponse> => {\n const url = new URL(urlString)\n const [, threadId] = url.pathname.match(new RegExp(runsRegexp))!\n\n const body = JSON.parse(options.body)\n const { assistant_id, stream } = body\n\n const assistant = await prisma.assistant.findUnique({\n where: {\n id: assistant_id,\n },\n })\n\n if (!assistant) {\n throw new Error('Assistant not found')\n }\n\n const {\n model,\n instructions,\n // additional_instructions,\n tools,\n metadata,\n response_format,\n truncation_strategy,\n } = assign({\n model: assistant.modelSlug,\n instructions: '',\n additional_instructions: null,\n truncation_strategy: {\n type: 'auto',\n },\n response_format: {\n type: 'text',\n },\n // tools: [],\n // metadata: {},\n }, body)\n\n const run = await prisma.run.create({\n data: {\n status: 'QUEUED',\n expiresAt: dayjs().add(1, 'hour').unix(),\n model,\n instructions,\n tools,\n metadata,\n thread: {\n connect: {\n id: threadId,\n },\n },\n assistant: {\n connect: {\n id: assistant_id,\n },\n },\n truncationStrategy: truncation_strategy,\n responseFormat: response_format,\n },\n })\n\n const data = serializeRun({ run })\n\n const readableStream = new ReadableStream({\n async start(controller) {\n try {\n await runAdapter({\n run: data,\n onEvent: onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\\n\\n`)\n },\n },\n prisma,\n }),\n getMessages: getMessages({\n prisma,\n run,\n }),\n })\n } catch (error: any) {\n console.error(error)\n\n onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\\n\\n`)\n },\n },\n prisma,\n })({\n event: 'thread.run.failed',\n data: {\n id: run.id,\n failed_at: dayjs().unix(),\n last_error: {\n code: 'server_error',\n message: `${error?.message ?? ''} ${error?.cause?.message ?? ''}`,\n },\n },\n } as OpenAI.Beta.AssistantStreamEvent.ThreadRunFailed)\n }\n\n controller.close()\n },\n })\n\n if (stream) {\n return new Response(readableStream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n return new Response(JSON.stringify(\n data\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n}\n","import type OpenAI from 'openai'\nimport { RunStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\n\nexport const threadRunInProgress = ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunInProgress\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunInProgress>\n}) => {\n controller.enqueue(event)\n\n return prisma.run.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: RunStatus.IN_PROGRESS,\n },\n })\n}\n","import type OpenAI from 'openai'\nimport { RunStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\n\nexport const threadRunFailed = ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunFailed\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunFailed>\n}) => {\n controller.enqueue(event)\n\n return prisma.run.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: RunStatus.FAILED,\n failedAt: event.data.failed_at,\n lastError: event.data.last_error,\n },\n })\n}\n","import type OpenAI from 'openai'\nimport { RunStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\n\nexport const threadRunCompleted = ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunCompleted\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunCompleted>\n}) => {\n controller.enqueue(event)\n\n return prisma.run.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: RunStatus.COMPLETED,\n requiredAction: undefined,\n },\n })\n}\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport { RunStatus } from '@/types/prisma'\n\nexport const threadRunRequiresAction = ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunRequiresAction\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunRequiresAction>\n}) => {\n controller.enqueue(event)\n\n return prisma.run.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: RunStatus.REQUIRES_ACTION,\n requiredAction: event.data.required_action,\n },\n })\n}\n","import dayjs from 'dayjs'\n// @ts-ignore-next-line\nimport type { RunStep } from '@prisma/client'\nimport type OpenAI from 'openai'\n\nexport const serializeRunStep = ({\n runStep,\n}: {\n runStep: RunStep\n}) => ({\n id: runStep.id,\n object: 'thread.run.step' as 'thread.run.step',\n created_at: dayjs(runStep.createdAt).unix(),\n assistant_id: runStep.assistantId,\n thread_id: runStep.threadId,\n run_id: runStep.runId,\n type: runStep.type.toLowerCase() as OpenAI.Beta.Threads.Runs.RunStep['type'],\n status: runStep.status.toLowerCase() as OpenAI.Beta.Threads.Runs.RunStep['status'],\n // @ts-ignore-next-line\n step_details: runStep.stepDetails as OpenAI.Beta.Threads.Runs.RunStep['step_details'],\n last_error: runStep.lastError as OpenAI.Beta.Threads.Runs.RunStep['last_error'],\n expired_at: runStep.expiredAt ? dayjs(runStep.expiredAt).unix() : null,\n cancelled_at: runStep.cancelledAt ? dayjs(runStep.cancelledAt).unix() : null,\n failed_at: runStep.failedAt ? dayjs(runStep.failedAt).unix() : null,\n completed_at: runStep.completedAt ? dayjs(runStep.completedAt).unix() : null,\n metadata: runStep.metadata,\n usage: runStep.usage as OpenAI.Beta.Threads.Runs.RunStep['usage'],\n})\n","import type OpenAI from 'openai'\nimport { RunStepType, RunStepStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\nimport { serializeRunStep } from '../../steps/serializeRunStep'\n\nconst type = (event: OpenAI.Beta.AssistantStreamEvent.ThreadRunStepCreated) => {\n if (event.data.type === 'message_creation') return RunStepType.MESSAGE_CREATION\n if (event.data.type === 'tool_calls') return RunStepType.TOOL_CALLS\n\n throw new Error(`Unknown type: ${event.data.type}`)\n}\n\nconst status = (event: OpenAI.Beta.AssistantStreamEvent.ThreadRunStepCreated) => {\n if (event.data.status === 'in_progress') return RunStepStatus.IN_PROGRESS\n if (event.data.status === 'cancelled') return RunStepStatus.CANCELLED\n if (event.data.status === 'completed') return RunStepStatus.COMPLETED\n if (event.data.status === 'failed') return RunStepStatus.FAILED\n if (event.data.status === 'expired') return RunStepStatus.EXPIRED\n\n throw new Error(`Unknown status: ${event.data.status}`)\n}\n\nexport const threadRunStepCreated = async ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunStepCreated\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunStepCreated>\n}) => {\n const runStep = await prisma.runStep.create({\n data: {\n runId: event.data.run_id,\n assistantId: event.data.assistant_id,\n threadId: event.data.thread_id,\n type: type(event),\n status: status(event),\n stepDetails: event.data.step_details,\n completedAt: event.data.completed_at,\n },\n })\n\n const serializedRunStep = serializeRunStep({ runStep })\n\n controller.enqueue({\n ...event,\n data: serializedRunStep,\n })\n\n return serializedRunStep\n}\n","import type OpenAI from 'openai'\n\nexport const threadRunStepDelta = ({\n event,\n controller,\n}: {\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunStepDelta\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunStepDelta>\n}) => (\n controller.enqueue(event)\n)\n","import type OpenAI from 'openai'\nimport { MessageStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\nimport { serializeMessage } from '../../../messages/serializeMessage'\n\nconst status = (event: OpenAI.Beta.AssistantStreamEvent.ThreadMessageCreated) => {\n if (event.data.status === 'completed') return MessageStatus.COMPLETED\n if (event.data.status === 'in_progress') return MessageStatus.IN_PROGRESS\n if (event.data.status === 'incomplete') return MessageStatus.INCOMPLETE\n\n throw new Error(`Unknown status: ${event.data.status}`)\n}\n\nexport const threadMessageCreated = async ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadMessageCreated\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadMessageCreated>\n}) => {\n const message = await prisma.message.create({\n data: {\n threadId: event.data.thread_id,\n content: event.data.content as unknown as OpenAI.Beta.Threads.Messages.TextContentBlock[],\n role: event.data.role === 'assistant' ? 'ASSISTANT' : 'USER',\n assistantId: event.data.assistant_id,\n runId: event.data.run_id,\n status: status(event),\n },\n })\n\n const serializedMessage = serializeMessage({ message })\n\n controller.enqueue({\n ...event,\n data: serializedMessage,\n })\n\n return serializedMessage\n}\n","import type OpenAI from 'openai'\n\nexport const threadMessageDelta = ({\n event,\n controller,\n}: {\n event: OpenAI.Beta.AssistantStreamEvent.ThreadMessageDelta\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadMessageDelta>\n}) => (\n controller.enqueue(event)\n)\n","import type OpenAI from 'openai'\nimport { MessageStatus, RunStepType } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\n\nexport const threadMessageCompleted = async ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadMessageCompleted\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadMessageCompleted>\n}) => {\n controller.enqueue(event)\n\n if (event.data.tool_calls) {\n const latestRunStep = await prisma.runStep.findFirst({\n where: {\n threadId: event.data.thread_id,\n type: RunStepType.TOOL_CALLS,\n },\n orderBy: {\n createdAt: 'desc',\n },\n })\n\n if (!latestRunStep) {\n throw new Error('No run step found')\n }\n\n await prisma.runStep.update({\n where: {\n id: latestRunStep.id,\n },\n data: {\n stepDetails: {\n type: 'tool_calls',\n tool_calls: event.data.tool_calls,\n },\n },\n })\n }\n\n return prisma.message.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: MessageStatus.COMPLETED,\n ...(event.data.content ? { content: event.data.content } : {}),\n ...(event.data.tool_calls ? { toolCalls: event.data.tool_calls } : {}),\n },\n })\n}\n","import { threadRunInProgress } from './threadRunInProgress'\nimport { threadRunFailed } from './threadRunFailed'\nimport { threadRunCompleted } from './threadRunCompleted'\nimport { threadRunRequiresAction } from './threadRunRequiresAction'\nimport { threadRunStepCreated } from './threadRunStepCreated'\nimport { threadRunStepDelta } from './threadRunStepDelta'\nimport { threadMessageCreated } from './threadMessageCreated'\nimport { threadMessageDelta } from './threadMessageDelta'\nimport { threadMessageCompleted } from './threadMessageCompleted'\n\nexport const handlers = {\n 'thread.run.in_progress': threadRunInProgress,\n 'thread.run.failed': threadRunFailed,\n 'thread.run.completed': threadRunCompleted,\n 'thread.run.requires_action': threadRunRequiresAction,\n 'thread.run.step.created': threadRunStepCreated,\n 'thread.run.step.delta': threadRunStepDelta,\n 'thread.message.created': threadMessageCreated,\n 'thread.message.delta': threadMessageDelta,\n 'thread.message.completed': threadMessageCompleted,\n}\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport { handlers } from './handlers'\n\nexport const onEvent = ({\n prisma,\n controller,\n}: {\n prisma: PrismaClient\n controller: ReadableStreamDefaultController\n}) => (event: OpenAI.Beta.AssistantStreamEvent) => {\n // @ts-ignore-next-line\n const handler = handlers[event.event]\n\n if (!handler) {\n console.log('No handler for event', event)\n return\n }\n\n return handler({ prisma, controller, event })\n}\n","import type { PrismaClient } from '@prisma/client'\nimport { serializeMessage } from '../messages/serializeMessage'\nimport { serializeRunStep } from './steps/serializeRunStep'\nimport { serializeRun } from './serializeRun'\nimport type { Run, MessageWithRun, RunStep } from '@/types/prisma'\n\nconst getTake = ({\n run,\n}: {\n run: Run\n}) => {\n // @ts-ignore-next-line\n if (run.truncationStrategy.type === 'auto') {\n return null\n }\n\n // @ts-ignore-next-line\n if (run.truncationStrategy.type === 'last_messages') {\n // @ts-ignore-next-line\n if (!run.truncationStrategy.last_messages) {\n throw new Error('Truncation strategy last_messages is required')\n }\n\n // @ts-ignore-next-line\n return -run.truncationStrategy.last_messages\n }\n\n // @ts-ignore-next-line\n throw new Error(`Unsupported truncation strategy type: ${run.truncationStrategy.type}`)\n}\n\nexport const getMessages = ({\n prisma,\n run,\n}: {\n prisma: PrismaClient\n run: Run\n}) => async () => {\n const take = getTake({\n run,\n })\n\n const messages = await prisma.message.findMany({\n where: {\n threadId: run.threadId,\n },\n include: {\n run: {\n include: {\n runSteps: true,\n },\n },\n },\n orderBy: {\n createdAt: 'asc',\n },\n ...(take ? { take } : {}),\n })\n\n return messages.map((message: MessageWithRun) => ({\n ...serializeMessage({ message }),\n run: message.run ? ({\n ...serializeRun({ run: message.run }),\n runSteps: message.run.runSteps.map((runStep: RunStep) => (\n serializeRunStep({ runStep })\n )),\n }) : null,\n }))\n}\n","import type { PrismaClient } from '@prisma/client'\nimport type { RunAdapter } from '@/types'\nimport { get } from './get'\nimport { post } from './post'\n\nexport const runs = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapter\n}) => ({\n get: get({ prisma }),\n post: post({ prisma, runAdapter }),\n})\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport { runRegexp } from '@/lib/runs/runRegexp'\nimport { serializeRun } from '../runs/serializeRun'\n\ntype GetResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Runs['retrieve']>>\n}\n\nexport const get = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string): Promise<GetResponse> => {\n const url = new URL(urlString)\n\n const [, threadId, runId] = url.pathname.match(new RegExp(runRegexp))!\n\n const run = await prisma.run.findUnique({\n where: {\n id: runId,\n threadId,\n },\n })\n\n return new Response(JSON.stringify(\n serializeRun({ run })\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n 'openai-poll-after-ms': '5000',\n },\n })\n}\n","import type { PrismaClient } from '@prisma/client'\nimport type { RunAdapter } from '@/types'\nimport { get } from './get'\n// import { post } from './post'\n\nexport const run = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapter\n}) => ({\n get: get({ prisma }),\n // post: post({ prisma, runAdapter }),\n})\n","// @ts-ignore-next-line\nimport type { PrismaClient, RunStep } from '@prisma/client'\nimport { assign, last } from 'radash'\nimport { stepsRegexp } from '@/lib/steps/stepsRegexp'\nimport { serializeRunStep } from './serializeRunStep'\n\nexport const get = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string) => {\n const url = new URL(urlString)\n\n const [, threadId,, runId] = url.pathname.match(new RegExp(stepsRegexp))!\n\n const {\n limit,\n order,\n after,\n } = assign({\n limit: '20',\n order: 'desc',\n // after: null,\n }, Object.fromEntries(url.searchParams))\n\n const runSteps = await prisma.runStep.findMany({\n where: {\n threadId,\n runId,\n },\n take: parseInt(limit),\n orderBy: {\n createdAt: order,\n },\n ...(after ? {\n skip: 1,\n cursor: {\n id: after,\n },\n }: {}),\n })\n\n return new Response(JSON.stringify({\n data: runSteps.map((runStep: RunStep) => (\n serializeRunStep({ runStep })\n )),\n hasNextPage: () => runSteps.length === parseInt(limit),\n body: {\n // @ts-ignore-next-line\n last_id: last(runSteps)?.id ?? null,\n },\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","import type { PrismaClient } from '@prisma/client'\nimport { get } from './get'\n\nexport const steps = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => ({\n get: get({ prisma }),\n})\n","import { PrismaClient } from '@prisma/client'\nimport dayjs from 'dayjs'\n\nexport const updateRun = async ({\n prisma,\n runId,\n threadId,\n onThreadRunStepCompleted = () => {},\n tool_outputs,\n}: {\n prisma: PrismaClient\n runId: string\n threadId: string\n onThreadRunStepCompleted?: ({ runStep }: { runStep: any }) => void\n tool_outputs: any\n}) => (\n prisma.$transaction(async (prisma: PrismaClient) => {\n const runSteps = await prisma.runStep.findMany({\n where: {\n threadId,\n runId,\n type: 'TOOL_CALLS',\n status: 'IN_PROGRESS',\n },\n orderBy: {\n createdAt: 'asc',\n },\n })\n\n for (const runStep of runSteps) {\n const completedRunStep = await prisma.runStep.update({\n where: {\n id: runStep.id,\n },\n data: {\n status: 'COMPLETED',\n completedAt: dayjs().unix(),\n stepDetails: {\n type: 'tool_calls',\n // @ts-ignore-next-line\n tool_calls: runStep.stepDetails!.tool_calls.map((toolCall) => {\n // @ts-ignore-next-line\n const toolOutput = tool_outputs.find((output) => output.tool_call_id === toolCall.id) || tool_outputs[0]\n\n if (!toolOutput) {\n console.dir({ toolOutput, runStep, tool_outputs, runSteps }, { depth: null })\n throw new Error('Tool output not found')\n }\n\n return {\n id: toolCall.id,\n type: toolCall.type,\n function: {\n ...toolCall.function,\n output: toolOutput.output,\n },\n }\n }),\n },\n },\n })\n\n onThreadRunStepCompleted({\n runStep: completedRunStep,\n })\n }\n\n return prisma.run.update({\n where: {\n id: runId,\n },\n data: {\n status: 'QUEUED',\n },\n })\n })\n)\n","import type { PrismaClient } from '@prisma/client'\nimport { submitToolOutputsRegexp } from '@/lib/runs/submitToolOutputsRegexp'\nimport { RunAdapterPartobClient } from '@/types'\nimport { serializeRun } from '../../serializeRun'\nimport { onEvent } from '../../onEvent'\nimport { getMessages } from '../../getMessages'\nimport { serializeRunStep } from '../../steps/serializeRunStep'\nimport { updateRun } from './updateRun'\n\nexport const post = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapterPartobClient\n}) => async (urlString: string, options: any) => {\n const url = new URL(urlString)\n const [, threadId, runId] = url.pathname.match(new RegExp(submitToolOutputsRegexp))!\n\n const body = JSON.parse(options.body)\n\n const {\n tool_outputs,\n stream,\n } = body\n\n if (stream) {\n const readableStream = new ReadableStream({\n async start(controller) {\n const run = await updateRun({\n prisma,\n runId,\n threadId,\n tool_outputs,\n onThreadRunStepCompleted: async ({ runStep }) => {\n controller.enqueue(`data: ${JSON.stringify({\n event: 'thread.run.step.completed',\n data: serializeRunStep({ runStep }),\n })}\\n\\n`)\n }\n })\n\n await runAdapter({\n run: serializeRun({ run }),\n onEvent: onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\\n\\n`)\n },\n },\n prisma,\n }),\n getMessages: getMessages({ prisma, run }),\n })\n\n controller.close()\n },\n })\n\n return new Response(readableStream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n const run = await updateRun({\n prisma,\n runId,\n threadId,\n tool_outputs,\n })\n\n await new Promise((resolve) => (\n new ReadableStream({\n async start(controller) {\n await runAdapter({\n run: serializeRun({ run }),\n onEvent: onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\\n\\n`)\n },\n },\n prisma,\n }),\n getMessages: getMessages({ prisma, run }),\n })\n\n controller.close()\n resolve(void 0)\n },\n })\n ))\n\n return new Response(JSON.stringify(\n run\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n}\n","import type { PrismaClient } from '@prisma/client'\nimport type { RunAdapter } from '@/types'\nimport { post } from './post'\n\nexport const submitToolOutputs = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapter\n}) => ({\n post: post({\n prisma,\n // @ts-ignore-next-line\n runAdapter,\n }),\n})\n","import type { PrismaClient } from '@prisma/client'\nimport { StorageAdapterArgs } from '@/types'\nimport { messagesRegexp } from '@/lib/messages/messagesRegexp'\nimport { runsRegexp } from '@/lib/runs/runsRegexp'\nimport { runRegexp } from '@/lib/runs/runRegexp'\nimport { submitToolOutputsRegexp } from '@/lib/runs/submitToolOutputsRegexp'\nimport { stepsRegexp } from '@/lib/steps/stepsRegexp'\nimport { threads } from './threads'\nimport { messages } from './threads/messages'\nimport { runs } from './threads/runs'\nimport { run } from './threads/run'\nimport { steps } from './threads/runs/steps'\nimport { submitToolOutputs } from './threads/runs/submitToolOutputs'\n\nexport const prismaStorageAdapter = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => ({\n runAdapter,\n}: StorageAdapterArgs) => ({\n requestHandlers: {\n '^/(?:v1|/?openai)/threads$': threads({ prisma }),\n [messagesRegexp]: messages({ prisma }),\n [runsRegexp]: runs({ prisma, runAdapter }),\n [runRegexp]: run({ prisma, runAdapter }),\n [stepsRegexp]: steps({ prisma }),\n [submitToolOutputsRegexp]: submitToolOutputs({ prisma, runAdapter }),\n },\n})\n"]}
|
|
1
|
+
{"version":3,"sources":["/Users/domas/Developer/supercorp/supercompat/packages/supercompat/dist/index.cjs","../src/index.ts","../src/supercompat.ts","../src/supercompatFetch/requestHandlers.ts","../src/supercompatFetch/findRequestHandler.ts","../src/supercompatFetch/originalFetch.ts","../src/supercompatFetch/index.ts","../src/lib/azureOpenai/endpointFromBaseUrl.ts","../src/adapters/client/groqClientAdapter/completions/post.ts","../src/adapters/client/groqClientAdapter/completions/index.ts","../src/adapters/client/groqClientAdapter/index.ts","../src/adapters/client/openaiClientAdapter/completions/post.ts","../src/adapters/client/openaiClientAdapter/completions/index.ts","../src/adapters/client/openaiClientAdapter/index.ts","../src/adapters/client/azureOpenaiClientAdapter/index.ts","../src/adapters/client/mistralClientAdapter/completions/post.ts","../src/adapters/client/mistralClientAdapter/completions/index.ts","../src/adapters/client/mistralClientAdapter/index.ts","../src/lib/messages/alternatingMessages.ts","../src/adapters/client/perplexityClientAdapter/completions/post.ts","../src/adapters/client/perplexityClientAdapter/completions/index.ts","../src/adapters/client/perplexityClientAdapter/index.ts","../src/adapters/client/anthropicClientAdapter/completions/post.ts","../src/lib/messages/nonEmptyMessages.ts","../src/lib/messages/firstUserMessages.ts","../src/adapters/client/anthropicClientAdapter/completions/serializeTools.ts","../src/adapters/client/anthropicClientAdapter/completions/serializeMessages/serializeMessage.ts","../src/adapters/client/anthropicClientAdapter/completions/serializeMessages/index.ts","../src/adapters/client/anthropicClientAdapter/completions/index.ts","../src/adapters/client/anthropicClientAdapter/index.ts","../src/adapters/run/completionsRunAdapter/index.ts","../src/adapters/run/completionsRunAdapter/messages/index.ts","../src/adapters/run/completionsRunAdapter/messages/serializeMessage.ts","../src/lib/messages/messagesRegexp.ts","../src/lib/runs/runsRegexp.ts","../src/lib/runs/runRegexp.ts","../src/lib/runs/submitToolOutputsRegexp.ts","../src/lib/steps/stepsRegexp.ts","../src/adapters/storage/prismaStorageAdapter/threads/post.ts","../src/adapters/storage/prismaStorageAdapter/threads/serializeThread.ts","../src/adapters/storage/prismaStorageAdapter/threads/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/messages/serializeMessage.ts","../src/adapters/storage/prismaStorageAdapter/threads/messages/post.ts","../src/adapters/storage/prismaStorageAdapter/threads/messages/get.ts","../src/adapters/storage/prismaStorageAdapter/threads/messages/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/get.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/serializeRun.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/post.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunInProgress.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunFailed.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunCompleted.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunRequiresAction.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/steps/serializeRunStep.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunStepCreated.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunStepDelta.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadMessageCreated.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadMessageDelta.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadMessageCompleted.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/getMessages.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/run/get.ts","../src/adapters/storage/prismaStorageAdapter/threads/run/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/steps/get.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/steps/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/submitToolOutputs/post/updateRun.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/submitToolOutputs/post/index.ts","../src/adapters/storage/prismaStorageAdapter/threads/runs/submitToolOutputs/index.ts","../src/adapters/storage/prismaStorageAdapter/index.ts"],"names":["__create","Object","create","__defProp","defineProperty","__getOwnPropDesc","getOwnPropertyDescriptor","__getOwnPropNames","getOwnPropertyNames","__getProtoOf","getPrototypeOf","__hasOwnProp","prototype","hasOwnProperty","__export","target","all","name","get","enumerable","__copyProps","to","from","except","desc","key","call","__toESM","mod","isNodeMode","__esModule","value","__toCommonJS","src_exports","anthropicClientAdapter","azureOpenaiClientAdapter","completionsRunAdapter","groqClientAdapter","mistralClientAdapter","openaiClientAdapter","perplexityClientAdapter","prismaStorageAdapter","supercompat","module","exports","import_openai","require","import_radash","storageRequestHandlers","storage","runAdapter","client","result","partob","requestHandlers","assign","findRequestHandler","url","pathname","URL","regex","RegExp","test","originalFetch","args","fetch","options","headers","authorization","defaultHeaders","Authorization","supercompatFetch","pathHandler","requestHandler","method","endpointFromBaseUrl","baseURL","replace","type","AzureOpenAI","apiKey","apiVersion","endpoint","OpenAI","post","groq","_url","body","response","stream","data","error","JSON","parse","chat","completions","ReadableStream","start","controller","chunk","enqueue","stringify","close","Response","status","openai","azureOpenai","mistral","complete","agentSideRoles","alternatingMessages","messages","forEach","message","index","push","nextMessage","role","content","includes","perplexity","nonEmptyMessages","import_radash2","isEmpty","firstUserMessages","firstMessage","serializeTools","tools","map","tool","function","description","input_schema","parameters","serializeMessage","text","tool_calls","toolCall","id","input","arguments","tool_use_id","tool_call_id","serializeMessages","anthropic","systemMessages","otherMessages","system","chatMessages","resultOptions","import_radash3","fork","join","omit","max_tokens","delta","messageDelta","partial_json","uid","object","choices","content_block","import_lodash","import_dayjs","serializeToolCall","output","serializeMessageWithContent","serializeContent","metadata","toolCalls","run","messageToolCalls","tc","runStep","runSteps","find","rs","step_details","some","rsTc","getMessages","instructions","import_radash4","flat","updatedToolCall","import_radash5","_","cloneDeep","entries","toolCallsData","prevToolCalls","newToolCalls","runStepDelta","clientAdapter","onEvent","opts","providerResponse","e","toolCallsRunStep","currentContent","currentToolCalls","choice","event","model","response_format","console","failed_at","dayjs","unix","last_error","code","cause","completed_at","run_id","created_at","assistant_id","incomplete_at","incomplete_details","attachments","thread_id","annotations","expired_at","cancelled_at","usage","message_creation","message_id","required_action","submit_tool_outputs","messagesRegexp","runsRegexp","runRegexp","submitToolOutputsRegexp","stepsRegexp","serializeThread","thread","import_dayjs2","createdAt","tool_resources","prisma","initialCreatedAt","import_dayjs3","subtract","length","format","assistantId","assistant","connect","add","toDate","threads","import_dayjs4","threadId","completedAt","incompleteAt","incompleteDetails","toLowerCase","runId","import_radash6","messageContentBlocks","urlString","match","limit","order","after","import_radash7","fromEntries","searchParams","findMany","where","take","parseInt","orderBy","skip","cursor","hasNextPage","last_id","last","serializeRun","import_dayjs5","requiredAction","lastError","expires_at","expiresAt","started_at","startedAt","cancelledAt","failedAt","truncation_strategy","max_completion_tokens","max_prompt_tokens","tool_choice","parallel_tool_calls","runs","import_radash8","threadRunInProgress","update","threadRunFailed","threadRunCompleted","threadRunRequiresAction","serializeRunStep","import_dayjs6","stepDetails","expiredAt","Error","threadRunStepCreated","serializedRunStep","threadRunStepDelta","threadMessageCreated","serializedMessage","threadMessageDelta","threadMessageCompleted","latestRunStep","findFirst","handlers","handler","log","getTake","truncationStrategy","last_messages","include","readableStream","findUnique","import_radash9","modelSlug","additional_instructions","import_dayjs7","responseFormat","import_radash10","steps","updateRun","onThreadRunStepCompleted","tool_outputs","$transaction","completedRunStep","import_dayjs8","toolOutput","dir","depth","Promise","resolve","submitToolOutputs"],"mappings":"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","sourcesContent":["\"use strict\";\nvar __create = Object.create;\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __getProtoOf = Object.getPrototypeOf;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(\n // If the importer is in node compatibility mode or this is not an ESM\n // file that has been converted to a CommonJS file using a Babel-\n // compatible transform (i.e. \"__esModule\" has not been set), then set\n // \"default\" to the CommonJS \"module.exports\" for node compatibility.\n isNodeMode || !mod || !mod.__esModule ? __defProp(target, \"default\", { value: mod, enumerable: true }) : target,\n mod\n));\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// src/index.ts\nvar src_exports = {};\n__export(src_exports, {\n anthropicClientAdapter: () => anthropicClientAdapter,\n azureOpenaiClientAdapter: () => azureOpenaiClientAdapter,\n completionsRunAdapter: () => completionsRunAdapter,\n groqClientAdapter: () => groqClientAdapter,\n mistralClientAdapter: () => mistralClientAdapter,\n openaiClientAdapter: () => openaiClientAdapter,\n perplexityClientAdapter: () => perplexityClientAdapter,\n prismaStorageAdapter: () => prismaStorageAdapter,\n supercompat: () => supercompat\n});\nmodule.exports = __toCommonJS(src_exports);\n\n// src/supercompat.ts\nvar import_openai = __toESM(require(\"openai\"), 1);\n\n// src/supercompatFetch/requestHandlers.ts\nvar import_radash = require(\"radash\");\nvar storageRequestHandlers = ({\n storage,\n runAdapter,\n client\n}) => {\n if (!storage) return {};\n if (!runAdapter) return {};\n const result = storage({ runAdapter: (0, import_radash.partob)(runAdapter, { client }) });\n return result.requestHandlers;\n};\nvar requestHandlers = ({\n client,\n storage,\n runAdapter\n}) => (0, import_radash.assign)(\n client.requestHandlers,\n storageRequestHandlers({\n storage,\n runAdapter,\n client\n })\n);\n\n// src/supercompatFetch/findRequestHandler.ts\nvar findRequestHandler = ({\n url,\n requestHandlers: requestHandlers2\n}) => {\n const pathname = new URL(url).pathname;\n for (const key in requestHandlers2) {\n const regex = new RegExp(key);\n if (regex.test(pathname)) {\n return requestHandlers2[key];\n }\n }\n};\n\n// src/supercompatFetch/originalFetch.ts\nvar originalFetch = ({\n args,\n client\n}) => {\n if (client.client?.fetch) {\n const [url, options] = args;\n const headers = {\n ...options.headers,\n authorization: client.client.defaultHeaders().Authorization\n };\n return client.client.fetch(url, {\n ...options,\n headers\n });\n } else {\n return fetch(...args);\n }\n};\n\n// src/supercompatFetch/index.ts\nvar supercompatFetch = ({\n client,\n storage,\n runAdapter\n}) => {\n const requestHandlers2 = requestHandlers({\n client,\n storage,\n runAdapter\n });\n return async (...args) => {\n const [url, options] = args;\n const pathHandler = findRequestHandler({\n url,\n requestHandlers: requestHandlers2\n });\n if (!pathHandler) {\n return originalFetch({\n client,\n args\n });\n }\n const requestHandler = pathHandler[options?.method];\n if (!requestHandler) {\n return originalFetch({\n client,\n args\n });\n }\n return requestHandler(...args);\n };\n};\n\n// src/lib/azureOpenai/endpointFromBaseUrl.ts\nvar endpointFromBaseUrl = ({\n baseURL\n}) => baseURL.replace(/\\/+openai$/, \"\");\n\n// src/supercompat.ts\nvar supercompat = ({\n client,\n storage,\n runAdapter\n}) => {\n if (client.type === \"AZURE_OPENAI\") {\n return new import_openai.AzureOpenAI({\n apiKey: client.client.apiKey,\n apiVersion: client.client.apiVersion,\n endpoint: endpointFromBaseUrl({ baseURL: client.client.baseURL }),\n fetch: supercompatFetch({\n client,\n storage,\n runAdapter\n })\n });\n }\n return new import_openai.default({\n apiKey: \"SUPERCOMPAT_PLACEHOLDER_OPENAI_KEY\",\n fetch: supercompatFetch({\n client,\n storage,\n runAdapter\n })\n });\n};\n\n// src/adapters/client/groqClientAdapter/completions/post.ts\nvar post = ({\n groq\n}) => async (_url, options) => {\n const body = JSON.parse(options.body);\n if (body.stream) {\n const response = await groq.chat.completions.create(body);\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\n\n`);\n }\n controller.close();\n }\n });\n return new Response(stream, {\n headers: {\n \"Content-Type\": \"text/event-stream\"\n }\n });\n } else {\n try {\n const data = await groq.chat.completions.create(body);\n return new Response(JSON.stringify({\n data\n }), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n } catch (error) {\n return new Response(JSON.stringify({\n error\n }), {\n status: 500,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n }\n }\n};\n\n// src/adapters/client/groqClientAdapter/completions/index.ts\nvar completions = ({\n groq\n}) => ({\n post: post({ groq })\n});\n\n// src/adapters/client/groqClientAdapter/index.ts\nvar groqClientAdapter = ({\n groq\n}) => ({\n client: groq,\n requestHandlers: {\n \"^/v1/chat/completions$\": completions({ groq })\n }\n});\n\n// src/adapters/client/openaiClientAdapter/completions/post.ts\nvar post2 = ({\n openai\n}) => async (_url, options) => {\n const body = JSON.parse(options.body);\n if (body.stream) {\n const response = await openai.chat.completions.create(body);\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\n\n`);\n }\n controller.close();\n }\n });\n return new Response(stream, {\n headers: {\n \"Content-Type\": \"text/event-stream\"\n }\n });\n } else {\n try {\n const data = await openai.chat.completions.create(body);\n return new Response(JSON.stringify({\n data\n }), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n } catch (error) {\n return new Response(JSON.stringify({\n error\n }), {\n status: 500,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n }\n }\n};\n\n// src/adapters/client/openaiClientAdapter/completions/index.ts\nvar completions2 = ({\n openai\n}) => ({\n post: post2({ openai })\n});\n\n// src/adapters/client/openaiClientAdapter/index.ts\nvar openaiClientAdapter = ({\n openai\n}) => ({\n client: openai,\n requestHandlers: {\n \"^/(?:v1|/?openai)/chat/completions$\": completions2({ openai })\n }\n});\n\n// src/adapters/client/azureOpenaiClientAdapter/index.ts\nvar azureOpenaiClientAdapter = ({\n azureOpenai\n}) => ({\n type: \"AZURE_OPENAI\",\n client: azureOpenai,\n requestHandlers: {\n \"^/(?:v1|/?openai)/chat/completions$\": completions2({\n openai: azureOpenai\n })\n }\n});\n\n// src/adapters/client/mistralClientAdapter/completions/post.ts\nvar post3 = ({\n mistral\n}) => async (_url, options) => {\n const body = JSON.parse(options.body);\n if (body.stream) {\n const response = await mistral.chat.stream(body);\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\n\n`);\n }\n controller.close();\n }\n });\n return new Response(stream, {\n headers: {\n \"Content-Type\": \"text/event-stream\"\n }\n });\n } else {\n try {\n const data = await mistral.chat.complete(body);\n return new Response(JSON.stringify({\n data\n }), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n } catch (error) {\n return new Response(JSON.stringify({\n error\n }), {\n status: 500,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n }\n }\n};\n\n// src/adapters/client/mistralClientAdapter/completions/index.ts\nvar completions3 = ({\n mistral\n}) => ({\n post: post3({ mistral })\n});\n\n// src/adapters/client/mistralClientAdapter/index.ts\nvar mistralClientAdapter = ({\n mistral\n}) => ({\n client: mistral,\n requestHandlers: {\n \"^/v1/chat/completions$\": completions3({ mistral })\n }\n});\n\n// src/lib/messages/alternatingMessages.ts\nvar agentSideRoles = [\"assistant\", \"system\"];\nvar alternatingMessages = ({\n messages: messages3\n}) => {\n const result = [];\n messages3.forEach((message, index) => {\n result.push(message);\n const nextMessage = messages3[index + 1];\n if (!nextMessage) return;\n if (message.role === \"user\" && nextMessage.role === \"user\") {\n result.push({\n role: \"assistant\",\n content: \"-\"\n });\n } else if (agentSideRoles.includes(message.role) && agentSideRoles.includes(nextMessage.role)) {\n result.push({\n role: \"user\",\n content: \"-\"\n });\n }\n });\n return result;\n};\n\n// src/adapters/client/perplexityClientAdapter/completions/post.ts\nvar post4 = ({\n perplexity\n}) => async (_url, options) => {\n const body = JSON.parse(options.body);\n const messages3 = alternatingMessages({\n messages: body.messages\n });\n if (body.stream) {\n const response = await perplexity.chat.completions.create({\n ...body,\n messages: messages3\n });\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\n\n`);\n }\n controller.close();\n }\n });\n return new Response(stream, {\n headers: {\n \"Content-Type\": \"text/event-stream\"\n }\n });\n } else {\n try {\n const data = await perplexity.chat.completions.create(body);\n return new Response(JSON.stringify({\n data\n }), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n } catch (error) {\n return new Response(JSON.stringify({\n error\n }), {\n status: 500,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n }\n }\n};\n\n// src/adapters/client/perplexityClientAdapter/completions/index.ts\nvar completions4 = ({\n perplexity\n}) => ({\n post: post4({ perplexity })\n});\n\n// src/adapters/client/perplexityClientAdapter/index.ts\nvar perplexityClientAdapter = ({\n perplexity\n}) => ({\n client: perplexity,\n requestHandlers: {\n \"^/v1/chat/completions$\": completions4({ perplexity })\n }\n});\n\n// src/adapters/client/anthropicClientAdapter/completions/post.ts\nvar import_radash3 = require(\"radash\");\n\n// src/lib/messages/nonEmptyMessages.ts\nvar import_radash2 = require(\"radash\");\nvar nonEmptyMessages = ({\n messages: messages3\n}) => {\n const result = [];\n messages3.forEach((message) => result.push({\n ...message,\n content: (0, import_radash2.isEmpty)(message.content) ? \"-\" : message.content\n }));\n return result;\n};\n\n// src/lib/messages/firstUserMessages.ts\nvar firstUserMessages = ({\n messages: messages3\n}) => {\n const firstMessage = messages3[0];\n if (!firstMessage) return messages3;\n if (firstMessage.role !== \"user\") {\n return [\n {\n role: \"user\",\n content: \"-\"\n },\n ...messages3\n ];\n }\n return messages3;\n};\n\n// src/adapters/client/anthropicClientAdapter/completions/serializeTools.ts\nvar serializeTools = ({\n tools\n}) => (tools ?? []).map((tool) => {\n if (tool.type === \"function\") {\n return {\n name: tool.function.name,\n description: tool.function.description,\n input_schema: tool.function.parameters ?? {\n type: \"object\"\n }\n };\n }\n return tool;\n});\n\n// src/adapters/client/anthropicClientAdapter/completions/serializeMessages/serializeMessage.ts\nvar serializeMessage = ({\n message\n}) => {\n if (message.role === \"user\") {\n return {\n role: \"user\",\n content: message.content\n };\n } else if (message.role === \"assistant\") {\n return {\n role: \"assistant\",\n content: [\n {\n type: \"text\",\n text: message.content\n },\n ...(message.tool_calls ?? []).map((toolCall) => ({\n type: \"tool_use\",\n id: toolCall.id,\n name: toolCall.function.name,\n input: toolCall.function.arguments ? JSON.parse(toolCall.function.arguments) : {}\n }))\n ]\n };\n } else if (message.role === \"tool\") {\n return {\n role: \"user\",\n content: [\n {\n type: \"tool_result\",\n tool_use_id: message.tool_call_id,\n content: message.content\n }\n ]\n };\n }\n};\n\n// src/adapters/client/anthropicClientAdapter/completions/serializeMessages/index.ts\nvar serializeMessages = ({\n messages: messages3\n}) => messages3.map((message) => serializeMessage({\n message\n}));\n\n// src/adapters/client/anthropicClientAdapter/completions/post.ts\nvar post5 = ({\n anthropic\n}) => async (_url, options) => {\n const body = JSON.parse(options.body);\n const messages3 = body.messages;\n const [systemMessages, otherMessages] = (0, import_radash3.fork)(messages3, (message) => message.role === \"system\");\n const system = systemMessages.map((message) => message.content).join(\"\\n\");\n const chatMessages = nonEmptyMessages({\n messages: firstUserMessages({\n messages: alternatingMessages({\n messages: otherMessages\n })\n })\n });\n const resultOptions = {\n ...(0, import_radash3.omit)(body, [\"response_format\"]),\n stream: body.stream ? (0, import_radash3.isEmpty)(body.tools) : false,\n system,\n messages: serializeMessages({\n messages: chatMessages\n }),\n max_tokens: 4096,\n tools: serializeTools({\n tools: body.tools\n })\n };\n if (body.stream) {\n const response = await anthropic.messages.stream(resultOptions);\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n if (chunk.type === \"content_block_delta\") {\n const delta = chunk.delta.type === \"input_json_delta\" ? {\n tool_calls: [\n {\n index: 0,\n function: {\n arguments: chunk.delta.partial_json\n }\n }\n ]\n } : {\n content: chunk.delta.text\n };\n const messageDelta = {\n id: `chatcmpl-${(0, import_radash3.uid)(29)}`,\n object: \"chat.completion.chunk\",\n choices: [\n {\n index: chunk.index,\n delta\n }\n ]\n };\n controller.enqueue(`data: ${JSON.stringify(messageDelta)}\n\n`);\n } else if (chunk.type === \"content_block_start\") {\n const delta = chunk.content_block.type === \"tool_use\" ? {\n content: null,\n tool_calls: [\n {\n index: 0,\n id: chunk.content_block.id,\n type: \"function\",\n function: {\n name: chunk.content_block.name,\n arguments: \"\"\n }\n }\n ]\n } : {\n content: chunk.content_block.text\n };\n const messageDelta = {\n id: `chatcmpl-${(0, import_radash3.uid)(29)}`,\n object: \"chat.completion.chunk\",\n choices: [\n {\n index: chunk.index,\n delta\n }\n ]\n };\n controller.enqueue(`data: ${JSON.stringify(messageDelta)}\n\n`);\n } else if (chunk.type === \"message_start\") {\n const messageDelta = {\n id: `chatcmpl-${(0, import_radash3.uid)(29)}`,\n object: \"chat.completion.chunk\",\n choices: [\n {\n index: 0,\n delta: {\n content: \"\"\n }\n }\n ]\n };\n controller.enqueue(`data: ${JSON.stringify(messageDelta)}\n\n`);\n }\n }\n controller.close();\n }\n });\n return new Response(stream, {\n headers: {\n \"Content-Type\": \"text/event-stream\"\n }\n });\n } else {\n try {\n const data = await anthropic.messages.create(resultOptions);\n return new Response(JSON.stringify({\n data\n }), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n } catch (error) {\n return new Response(JSON.stringify({\n error\n }), {\n status: 500,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n }\n }\n};\n\n// src/adapters/client/anthropicClientAdapter/completions/index.ts\nvar completions5 = ({\n anthropic\n}) => ({\n post: post5({ anthropic })\n});\n\n// src/adapters/client/anthropicClientAdapter/index.ts\nvar anthropicClientAdapter = ({\n anthropic\n}) => ({\n client: anthropic,\n requestHandlers: {\n \"^/v1/chat/completions$\": completions5({ anthropic })\n }\n});\n\n// src/adapters/run/completionsRunAdapter/index.ts\nvar import_lodash = __toESM(require(\"lodash\"), 1);\nvar import_radash5 = require(\"radash\");\nvar import_dayjs = __toESM(require(\"dayjs\"), 1);\n\n// src/adapters/run/completionsRunAdapter/messages/index.ts\nvar import_radash4 = require(\"radash\");\n\n// src/adapters/run/completionsRunAdapter/messages/serializeMessage.ts\nvar serializeToolCall = ({\n toolCall\n}) => ({\n tool_call_id: toolCall.id,\n role: \"tool\",\n name: toolCall.function.name,\n content: toolCall.function.output ?? \"\"\n});\nvar serializeMessageWithContent = ({\n message\n}) => ({\n role: message.role,\n content: serializeContent({\n content: message.content\n }),\n ...message?.metadata?.toolCalls ? { tool_calls: message.metadata.toolCalls } : {}\n});\nvar serializeContent = ({\n content\n}) => content.map((content2) => content2.text.value).join(\"\\n\");\nvar serializeMessage2 = ({\n message\n}) => {\n const result = [serializeMessageWithContent({ message })];\n const run2 = message.run;\n if (!run2) return result;\n const messageToolCalls = message.metadata?.toolCalls || [];\n messageToolCalls.forEach((tc) => {\n const runStep = run2.runSteps.find((rs) => {\n if (rs.type !== \"tool_calls\") return false;\n return rs.step_details.tool_calls.some((rsTc) => {\n if (rsTc.type !== \"function\") return false;\n return rsTc.id === tc.id;\n });\n });\n if (!runStep) return;\n const toolCall = runStep.step_details.tool_calls.find((rsTc) => {\n if (rsTc.type !== \"function\") return false;\n return rsTc.id === tc.id;\n });\n result.push(serializeToolCall({ toolCall }));\n });\n return result;\n};\n\n// src/adapters/run/completionsRunAdapter/messages/index.ts\nvar messages = async ({\n run: run2,\n getMessages: getMessages2\n}) => [\n ...run2.instructions ? [{\n role: \"system\",\n content: run2.instructions\n }] : [],\n ...(0, import_radash4.flat)((await getMessages2()).map((message) => serializeMessage2({ message })))\n];\n\n// src/adapters/run/completionsRunAdapter/index.ts\nvar updatedToolCall = ({\n toolCall,\n delta\n}) => {\n if (!toolCall) return (0, import_radash5.omit)(delta, [\"index\"]);\n const result = import_lodash.default.cloneDeep(toolCall);\n for (const [key, value] of Object.entries(delta.function)) {\n result.function[key] = `${result.function[key] ?? \"\"}${value}`;\n }\n return result;\n};\nvar toolCallsData = ({\n prevToolCalls,\n delta\n}) => {\n if (!prevToolCalls) {\n return delta.tool_calls.map((tc) => ({\n id: (0, import_radash5.uid)(24),\n type: \"function\",\n ...(0, import_radash5.omit)(tc, [\"index\"])\n }));\n }\n const newToolCalls = import_lodash.default.cloneDeep(prevToolCalls);\n for (const runStepDelta of delta.tool_calls) {\n newToolCalls[runStepDelta.index] = updatedToolCall({\n toolCall: newToolCalls[runStepDelta.index],\n delta: runStepDelta\n });\n }\n return newToolCalls;\n};\nvar completionsRunAdapter = () => async ({\n client: clientAdapter,\n run: run2,\n onEvent: onEvent2,\n getMessages: getMessages2\n}) => {\n if (run2.status !== \"queued\") return;\n const client = supercompat({\n client: clientAdapter\n });\n onEvent2({\n event: \"thread.run.in_progress\",\n data: {\n ...run2,\n status: \"in_progress\"\n }\n });\n const opts = {\n messages: await messages({\n run: run2,\n getMessages: getMessages2\n }),\n model: run2.model,\n stream: true,\n response_format: run2.response_format,\n ...(0, import_radash5.isEmpty)(run2.tools) ? {} : { tools: run2.tools }\n };\n let providerResponse;\n try {\n providerResponse = await client.chat.completions.create(opts);\n } catch (e) {\n console.error(e);\n return onEvent2({\n event: \"thread.run.failed\",\n data: {\n ...run2,\n failed_at: (0, import_dayjs.default)().unix(),\n status: \"in_progress\",\n last_error: {\n code: \"server_error\",\n message: `${e?.message ?? \"\"} ${e?.cause?.message ?? \"\"}`\n }\n }\n });\n }\n let message = await onEvent2({\n event: \"thread.message.created\",\n data: {\n id: \"THERE_IS_A_BUG_IN_SUPERCOMPAT_IF_YOU_SEE_THIS_ID\",\n object: \"thread.message\",\n completed_at: null,\n run_id: run2.id,\n created_at: (0, import_dayjs.default)().unix(),\n assistant_id: run2.assistant_id,\n incomplete_at: null,\n incomplete_details: null,\n metadata: {},\n attachments: [],\n thread_id: run2.thread_id,\n content: [{ text: { value: \"\", annotations: [] }, type: \"text\" }],\n role: \"assistant\",\n status: \"in_progress\"\n }\n });\n onEvent2({\n event: \"thread.run.step.created\",\n data: {\n id: \"THERE_IS_A_BUG_IN_SUPERCOMPAT_IF_YOU_SEE_THIS_ID\",\n object: \"thread.run.step\",\n run_id: run2.id,\n assistant_id: run2.assistant_id,\n thread_id: run2.thread_id,\n type: \"message_creation\",\n status: \"completed\",\n completed_at: (0, import_dayjs.default)().unix(),\n created_at: (0, import_dayjs.default)().unix(),\n expired_at: null,\n last_error: null,\n metadata: {},\n failed_at: null,\n cancelled_at: null,\n usage: null,\n step_details: {\n type: \"message_creation\",\n message_creation: {\n message_id: message.id\n }\n }\n }\n });\n let toolCallsRunStep;\n let currentContent = \"\";\n let currentToolCalls;\n for await (const chunk of providerResponse) {\n const choice = chunk.choices[0];\n if (!choice) continue;\n const delta = choice.delta;\n if (delta.content) {\n currentContent = `${currentContent}${delta.content ?? \"\"}`;\n }\n if (delta.tool_calls) {\n if (!toolCallsRunStep) {\n toolCallsRunStep = await onEvent2({\n event: \"thread.run.step.created\",\n data: {\n id: \"THERE_IS_A_BUG_IN_SUPERCOMPAT_IF_YOU_SEE_THIS_ID\",\n object: \"thread.run.step\",\n run_id: run2.id,\n assistant_id: run2.assistant_id,\n thread_id: run2.thread_id,\n type: \"tool_calls\",\n status: \"in_progress\",\n completed_at: null,\n created_at: (0, import_dayjs.default)().unix(),\n expired_at: null,\n last_error: null,\n metadata: {},\n failed_at: null,\n cancelled_at: null,\n usage: null,\n step_details: {\n type: \"tool_calls\",\n tool_calls: []\n }\n }\n });\n }\n onEvent2({\n event: \"thread.run.step.delta\",\n data: {\n object: \"thread.run.step.delta\",\n run_id: run2.id,\n id: toolCallsRunStep.id,\n delta: {\n step_details: {\n type: \"tool_calls\",\n tool_calls: delta.tool_calls.map((tc) => ({\n id: (0, import_radash5.uid)(24),\n type: \"function\",\n ...tc\n }))\n }\n }\n }\n });\n currentToolCalls = toolCallsData({ prevToolCalls: currentToolCalls, delta });\n }\n if (delta.content) {\n onEvent2({\n event: \"thread.message.delta\",\n data: {\n id: message.id,\n delta: {\n content: [\n {\n type: \"text\",\n index: 0,\n text: {\n value: delta.content\n }\n }\n ]\n }\n }\n });\n }\n }\n message = await onEvent2({\n event: \"thread.message.completed\",\n data: {\n ...message,\n status: \"completed\",\n content: [{ text: { value: currentContent, annotations: [] }, type: \"text\" }],\n tool_calls: currentToolCalls\n }\n });\n if ((0, import_radash5.isEmpty)(message.toolCalls)) {\n return onEvent2({\n event: \"thread.run.completed\",\n data: {\n ...run2,\n status: \"completed\",\n completed_at: (0, import_dayjs.default)().unix()\n }\n });\n }\n return onEvent2({\n event: \"thread.run.requires_action\",\n data: {\n ...run2,\n status: \"requires_action\",\n required_action: {\n type: \"submit_tool_outputs\",\n submit_tool_outputs: {\n tool_calls: message.toolCalls\n }\n }\n }\n });\n};\n\n// src/lib/messages/messagesRegexp.ts\nvar messagesRegexp = \"^/(?:v1|/?openai)/threads/([^/]+)/messages$\";\n\n// src/lib/runs/runsRegexp.ts\nvar runsRegexp = \"^/(?:v1|/?openai)/threads/([^/]+)/runs$\";\n\n// src/lib/runs/runRegexp.ts\nvar runRegexp = \"^/(?:v1|/?openai)/threads/([^/]+)/runs/([^/]+)$\";\n\n// src/lib/runs/submitToolOutputsRegexp.ts\nvar submitToolOutputsRegexp = \"^/(?:v1|/?openai)/threads/([^/]+)/runs/([^/]+)/submit_tool_outputs$\";\n\n// src/lib/steps/stepsRegexp.ts\nvar stepsRegexp = \"^/(?:v1|/?openai)/threads/([^/]+)/runs/([^/]+)/steps$\";\n\n// src/adapters/storage/prismaStorageAdapter/threads/post.ts\nvar import_dayjs3 = __toESM(require(\"dayjs\"), 1);\n\n// src/adapters/storage/prismaStorageAdapter/threads/serializeThread.ts\nvar import_dayjs2 = __toESM(require(\"dayjs\"), 1);\nvar serializeThread = ({\n thread\n}) => ({\n id: thread.id,\n object: \"thread\",\n created_at: (0, import_dayjs2.default)(thread.createdAt).unix(),\n metadata: thread.metadata,\n // TODO\n tool_resources: null\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/post.ts\nvar post6 = ({\n prisma\n}) => async (...args) => {\n const body = JSON.parse(args[1].body);\n const messages3 = body.messages || [];\n const metadata = body.metadata || {};\n const initialCreatedAt = (0, import_dayjs3.default)().subtract(messages3.length, \"seconds\").format();\n const thread = await prisma.thread.create({\n data: {\n metadata,\n ...metadata.assistantId ? {\n assistant: {\n connect: {\n id: metadata.assistantId\n }\n }\n } : {},\n messages: {\n create: messages3.map((message, index) => ({\n role: message.role === \"user\" ? \"USER\" : \"ASSISTANT\",\n content: [\n {\n type: \"text\",\n text: {\n annotations: [],\n value: message.content\n }\n }\n ],\n attachments: message.attachments,\n metadata: message.metadata,\n createdAt: (0, import_dayjs3.default)(initialCreatedAt).add(index, \"seconds\").toDate()\n }))\n }\n }\n });\n return new Response(JSON.stringify(\n serializeThread({ thread })\n ), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/index.ts\nvar threads = ({\n prisma\n}) => ({\n post: post6({ prisma })\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/messages/serializeMessage.ts\nvar import_dayjs4 = __toESM(require(\"dayjs\"), 1);\nvar import_radash6 = require(\"radash\");\nvar serializeMessage3 = ({\n message\n}) => ({\n id: message.id,\n object: \"thread.message\",\n created_at: (0, import_dayjs4.default)(message.createdAt).unix(),\n thread_id: message.threadId,\n completed_at: message.completedAt ? (0, import_dayjs4.default)(message.completedAt).unix() : null,\n incomplete_at: message.incompleteAt ? (0, import_dayjs4.default)(message.incompleteAt).unix() : null,\n incomplete_details: message.incompleteDetails,\n role: message.role.toLowerCase(),\n content: message.content,\n assistant_id: message.assistantId,\n run_id: message.runId,\n attachments: message.attachments,\n status: message.status.toLowerCase(),\n metadata: (0, import_radash6.assign)(message.metadata ?? {}, message.toolCalls ? { toolCalls: message.toolCalls } : {})\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/messages/post.ts\nvar messageContentBlocks = ({\n content\n}) => [\n {\n type: \"text\",\n text: {\n value: content ?? \"\",\n annotations: []\n }\n }\n];\nvar post7 = ({\n prisma\n}) => async (urlString, options) => {\n const url = new URL(urlString);\n const [, threadId] = url.pathname.match(new RegExp(messagesRegexp));\n const body = JSON.parse(options.body);\n const { role, content } = body;\n const message = await prisma.message.create({\n data: {\n threadId,\n content: messageContentBlocks({ content }),\n role: role === \"user\" ? \"USER\" : \"ASSISTANT\"\n }\n });\n return new Response(JSON.stringify(\n serializeMessage3({ message })\n ), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/messages/get.ts\nvar import_radash7 = require(\"radash\");\nvar get = ({\n prisma\n}) => async (urlString) => {\n const url = new URL(urlString);\n const [, threadId] = url.pathname.match(new RegExp(messagesRegexp));\n const {\n limit,\n order,\n after\n } = (0, import_radash7.assign)({\n limit: \"20\",\n order: \"desc\"\n // after: null,\n }, Object.fromEntries(url.searchParams));\n const messages3 = await prisma.message.findMany({\n where: {\n threadId\n },\n take: parseInt(limit),\n orderBy: {\n createdAt: order\n },\n ...after ? {\n skip: 1,\n cursor: {\n id: after\n }\n } : {}\n });\n return new Response(JSON.stringify({\n data: messages3.map((message) => serializeMessage3({ message })),\n hasNextPage: () => messages3.length === parseInt(limit),\n body: {\n last_id: (0, import_radash7.last)(messages3)?.id ?? null\n }\n }), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/messages/index.ts\nvar messages2 = ({\n prisma\n}) => ({\n post: post7({ prisma }),\n get: get({ prisma })\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/get.ts\nvar import_radash8 = require(\"radash\");\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/serializeRun.ts\nvar import_dayjs5 = __toESM(require(\"dayjs\"), 1);\nvar serializeRun = ({\n run: run2\n}) => ({\n id: run2.id,\n object: \"thread.run\",\n created_at: (0, import_dayjs5.default)(run2.createdAt).unix(),\n thread_id: run2.threadId,\n assistant_id: run2.assistantId,\n status: run2.status.toLowerCase(),\n required_action: run2.requiredAction,\n last_error: run2.lastError,\n expires_at: (0, import_dayjs5.default)(run2.expiresAt).unix(),\n started_at: run2.startedAt ? (0, import_dayjs5.default)(run2.startedAt).unix() : null,\n cancelled_at: run2.cancelledAt ? (0, import_dayjs5.default)(run2.cancelledAt).unix() : null,\n failed_at: run2.failedAt ? (0, import_dayjs5.default)(run2.failedAt).unix() : null,\n completed_at: run2.completedAt ? (0, import_dayjs5.default)(run2.completedAt).unix() : null,\n model: run2.model,\n instructions: run2.instructions,\n tools: run2.tools,\n metadata: run2.metadata,\n usage: run2.usage,\n truncation_strategy: {\n type: \"auto\"\n },\n response_format: {\n type: \"text\"\n },\n // TODO\n incomplete_details: null,\n max_completion_tokens: null,\n max_prompt_tokens: null,\n tool_choice: \"auto\",\n parallel_tool_calls: true\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/get.ts\nvar get2 = ({\n prisma\n}) => async (urlString) => {\n const url = new URL(urlString);\n const [, threadId] = url.pathname.match(new RegExp(runsRegexp));\n const {\n limit,\n order,\n after\n } = (0, import_radash8.assign)({\n limit: \"20\",\n order: \"desc\"\n // after: null,\n }, Object.fromEntries(url.searchParams));\n const runs2 = await prisma.run.findMany({\n where: {\n threadId\n },\n take: parseInt(limit),\n orderBy: {\n createdAt: order\n },\n ...after ? {\n skip: 1,\n cursor: {\n id: after\n }\n } : {}\n });\n return new Response(JSON.stringify({\n data: runs2.map((run2) => serializeRun({ run: run2 })),\n hasNextPage: () => runs2.length === parseInt(limit),\n body: {\n // @ts-ignore-next-line\n last_id: (0, import_radash8.last)(runs2)?.id ?? null\n }\n }), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/post.ts\nvar import_dayjs7 = __toESM(require(\"dayjs\"), 1);\nvar import_radash9 = require(\"radash\");\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunInProgress.ts\nvar threadRunInProgress = ({\n prisma,\n event,\n controller\n}) => {\n controller.enqueue(event);\n return prisma.run.update({\n where: {\n id: event.data.id\n },\n data: {\n status: \"IN_PROGRESS\" /* IN_PROGRESS */\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunFailed.ts\nvar threadRunFailed = ({\n prisma,\n event,\n controller\n}) => {\n controller.enqueue(event);\n return prisma.run.update({\n where: {\n id: event.data.id\n },\n data: {\n status: \"FAILED\" /* FAILED */,\n failedAt: event.data.failed_at,\n lastError: event.data.last_error\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunCompleted.ts\nvar threadRunCompleted = ({\n prisma,\n event,\n controller\n}) => {\n controller.enqueue(event);\n return prisma.run.update({\n where: {\n id: event.data.id\n },\n data: {\n status: \"COMPLETED\" /* COMPLETED */,\n requiredAction: void 0\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunRequiresAction.ts\nvar threadRunRequiresAction = ({\n prisma,\n event,\n controller\n}) => {\n controller.enqueue(event);\n return prisma.run.update({\n where: {\n id: event.data.id\n },\n data: {\n status: \"REQUIRES_ACTION\" /* REQUIRES_ACTION */,\n requiredAction: event.data.required_action\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/steps/serializeRunStep.ts\nvar import_dayjs6 = __toESM(require(\"dayjs\"), 1);\nvar serializeRunStep = ({\n runStep\n}) => ({\n id: runStep.id,\n object: \"thread.run.step\",\n created_at: (0, import_dayjs6.default)(runStep.createdAt).unix(),\n assistant_id: runStep.assistantId,\n thread_id: runStep.threadId,\n run_id: runStep.runId,\n type: runStep.type.toLowerCase(),\n status: runStep.status.toLowerCase(),\n // @ts-ignore-next-line\n step_details: runStep.stepDetails,\n last_error: runStep.lastError,\n expired_at: runStep.expiredAt ? (0, import_dayjs6.default)(runStep.expiredAt).unix() : null,\n cancelled_at: runStep.cancelledAt ? (0, import_dayjs6.default)(runStep.cancelledAt).unix() : null,\n failed_at: runStep.failedAt ? (0, import_dayjs6.default)(runStep.failedAt).unix() : null,\n completed_at: runStep.completedAt ? (0, import_dayjs6.default)(runStep.completedAt).unix() : null,\n metadata: runStep.metadata,\n usage: runStep.usage\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunStepCreated.ts\nvar type = (event) => {\n if (event.data.type === \"message_creation\") return \"MESSAGE_CREATION\" /* MESSAGE_CREATION */;\n if (event.data.type === \"tool_calls\") return \"TOOL_CALLS\" /* TOOL_CALLS */;\n throw new Error(`Unknown type: ${event.data.type}`);\n};\nvar status = (event) => {\n if (event.data.status === \"in_progress\") return \"IN_PROGRESS\" /* IN_PROGRESS */;\n if (event.data.status === \"cancelled\") return \"CANCELLED\" /* CANCELLED */;\n if (event.data.status === \"completed\") return \"COMPLETED\" /* COMPLETED */;\n if (event.data.status === \"failed\") return \"FAILED\" /* FAILED */;\n if (event.data.status === \"expired\") return \"EXPIRED\" /* EXPIRED */;\n throw new Error(`Unknown status: ${event.data.status}`);\n};\nvar threadRunStepCreated = async ({\n prisma,\n event,\n controller\n}) => {\n const runStep = await prisma.runStep.create({\n data: {\n runId: event.data.run_id,\n assistantId: event.data.assistant_id,\n threadId: event.data.thread_id,\n type: type(event),\n status: status(event),\n stepDetails: event.data.step_details,\n completedAt: event.data.completed_at\n }\n });\n const serializedRunStep = serializeRunStep({ runStep });\n controller.enqueue({\n ...event,\n data: serializedRunStep\n });\n return serializedRunStep;\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadRunStepDelta.ts\nvar threadRunStepDelta = ({\n event,\n controller\n}) => controller.enqueue(event);\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadMessageCreated.ts\nvar status2 = (event) => {\n if (event.data.status === \"completed\") return \"COMPLETED\" /* COMPLETED */;\n if (event.data.status === \"in_progress\") return \"IN_PROGRESS\" /* IN_PROGRESS */;\n if (event.data.status === \"incomplete\") return \"INCOMPLETE\" /* INCOMPLETE */;\n throw new Error(`Unknown status: ${event.data.status}`);\n};\nvar threadMessageCreated = async ({\n prisma,\n event,\n controller\n}) => {\n const message = await prisma.message.create({\n data: {\n threadId: event.data.thread_id,\n content: event.data.content,\n role: event.data.role === \"assistant\" ? \"ASSISTANT\" : \"USER\",\n assistantId: event.data.assistant_id,\n runId: event.data.run_id,\n status: status2(event)\n }\n });\n const serializedMessage = serializeMessage3({ message });\n controller.enqueue({\n ...event,\n data: serializedMessage\n });\n return serializedMessage;\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadMessageDelta.ts\nvar threadMessageDelta = ({\n event,\n controller\n}) => controller.enqueue(event);\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/threadMessageCompleted.ts\nvar threadMessageCompleted = async ({\n prisma,\n event,\n controller\n}) => {\n controller.enqueue(event);\n if (event.data.tool_calls) {\n const latestRunStep = await prisma.runStep.findFirst({\n where: {\n threadId: event.data.thread_id,\n type: \"TOOL_CALLS\" /* TOOL_CALLS */\n },\n orderBy: {\n createdAt: \"desc\"\n }\n });\n if (!latestRunStep) {\n throw new Error(\"No run step found\");\n }\n await prisma.runStep.update({\n where: {\n id: latestRunStep.id\n },\n data: {\n stepDetails: {\n type: \"tool_calls\",\n tool_calls: event.data.tool_calls\n }\n }\n });\n }\n return prisma.message.update({\n where: {\n id: event.data.id\n },\n data: {\n status: \"COMPLETED\" /* COMPLETED */,\n ...event.data.content ? { content: event.data.content } : {},\n ...event.data.tool_calls ? { toolCalls: event.data.tool_calls } : {}\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/handlers/index.ts\nvar handlers = {\n \"thread.run.in_progress\": threadRunInProgress,\n \"thread.run.failed\": threadRunFailed,\n \"thread.run.completed\": threadRunCompleted,\n \"thread.run.requires_action\": threadRunRequiresAction,\n \"thread.run.step.created\": threadRunStepCreated,\n \"thread.run.step.delta\": threadRunStepDelta,\n \"thread.message.created\": threadMessageCreated,\n \"thread.message.delta\": threadMessageDelta,\n \"thread.message.completed\": threadMessageCompleted\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/onEvent/index.ts\nvar onEvent = ({\n prisma,\n controller\n}) => (event) => {\n const handler = handlers[event.event];\n if (!handler) {\n console.log(\"No handler for event\", event);\n return;\n }\n return handler({ prisma, controller, event });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/getMessages.ts\nvar getTake = ({\n run: run2\n}) => {\n if (run2.truncationStrategy.type === \"auto\") {\n return null;\n }\n if (run2.truncationStrategy.type === \"last_messages\") {\n if (!run2.truncationStrategy.last_messages) {\n throw new Error(\"Truncation strategy last_messages is required\");\n }\n return -run2.truncationStrategy.last_messages;\n }\n throw new Error(`Unsupported truncation strategy type: ${run2.truncationStrategy.type}`);\n};\nvar getMessages = ({\n prisma,\n run: run2\n}) => async () => {\n const take = getTake({\n run: run2\n });\n const messages3 = await prisma.message.findMany({\n where: {\n threadId: run2.threadId\n },\n include: {\n run: {\n include: {\n runSteps: true\n }\n }\n },\n orderBy: {\n createdAt: \"asc\"\n },\n ...take ? { take } : {}\n });\n return messages3.map((message) => ({\n ...serializeMessage3({ message }),\n run: message.run ? {\n ...serializeRun({ run: message.run }),\n runSteps: message.run.runSteps.map((runStep) => serializeRunStep({ runStep }))\n } : null\n }));\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/post.ts\nvar post8 = ({\n prisma,\n runAdapter\n}) => async (urlString, options) => {\n const url = new URL(urlString);\n const [, threadId] = url.pathname.match(new RegExp(runsRegexp));\n const body = JSON.parse(options.body);\n const { assistant_id, stream } = body;\n const assistant = await prisma.assistant.findUnique({\n where: {\n id: assistant_id\n }\n });\n if (!assistant) {\n throw new Error(\"Assistant not found\");\n }\n const {\n model,\n instructions,\n // additional_instructions,\n tools,\n metadata,\n response_format,\n truncation_strategy\n } = (0, import_radash9.assign)({\n model: assistant.modelSlug,\n instructions: \"\",\n additional_instructions: null,\n truncation_strategy: {\n type: \"auto\"\n },\n response_format: {\n type: \"text\"\n }\n // tools: [],\n // metadata: {},\n }, body);\n const run2 = await prisma.run.create({\n data: {\n status: \"QUEUED\",\n expiresAt: (0, import_dayjs7.default)().add(1, \"hour\").unix(),\n model,\n instructions,\n tools,\n metadata,\n thread: {\n connect: {\n id: threadId\n }\n },\n assistant: {\n connect: {\n id: assistant_id\n }\n },\n truncationStrategy: truncation_strategy,\n responseFormat: response_format\n }\n });\n const data = serializeRun({ run: run2 });\n const readableStream = new ReadableStream({\n async start(controller) {\n try {\n await runAdapter({\n run: data,\n onEvent: onEvent({\n controller: {\n ...controller,\n enqueue: (data2) => {\n controller.enqueue(`data: ${JSON.stringify(data2)}\n\n`);\n }\n },\n prisma\n }),\n getMessages: getMessages({\n prisma,\n run: run2\n })\n });\n } catch (error) {\n console.error(error);\n onEvent({\n controller: {\n ...controller,\n enqueue: (data2) => {\n controller.enqueue(`data: ${JSON.stringify(data2)}\n\n`);\n }\n },\n prisma\n })({\n event: \"thread.run.failed\",\n data: {\n id: run2.id,\n failed_at: (0, import_dayjs7.default)().unix(),\n last_error: {\n code: \"server_error\",\n message: `${error?.message ?? \"\"} ${error?.cause?.message ?? \"\"}`\n }\n }\n });\n }\n controller.close();\n }\n });\n if (stream) {\n return new Response(readableStream, {\n headers: {\n \"Content-Type\": \"text/event-stream\"\n }\n });\n } else {\n return new Response(JSON.stringify(\n data\n ), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n }\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/index.ts\nvar runs = ({\n prisma,\n runAdapter\n}) => ({\n get: get2({ prisma }),\n post: post8({ prisma, runAdapter })\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/run/get.ts\nvar get3 = ({\n prisma\n}) => async (urlString) => {\n const url = new URL(urlString);\n const [, threadId, runId] = url.pathname.match(new RegExp(runRegexp));\n const run2 = await prisma.run.findUnique({\n where: {\n id: runId,\n threadId\n }\n });\n return new Response(JSON.stringify(\n serializeRun({ run: run2 })\n ), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\",\n \"openai-poll-after-ms\": \"5000\"\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/run/index.ts\nvar run = ({\n prisma,\n runAdapter\n}) => ({\n get: get3({ prisma })\n // post: post({ prisma, runAdapter }),\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/steps/get.ts\nvar import_radash10 = require(\"radash\");\nvar get4 = ({\n prisma\n}) => async (urlString) => {\n const url = new URL(urlString);\n const [, threadId, , runId] = url.pathname.match(new RegExp(stepsRegexp));\n const {\n limit,\n order,\n after\n } = (0, import_radash10.assign)({\n limit: \"20\",\n order: \"desc\"\n // after: null,\n }, Object.fromEntries(url.searchParams));\n const runSteps = await prisma.runStep.findMany({\n where: {\n threadId,\n runId\n },\n take: parseInt(limit),\n orderBy: {\n createdAt: order\n },\n ...after ? {\n skip: 1,\n cursor: {\n id: after\n }\n } : {}\n });\n return new Response(JSON.stringify({\n data: runSteps.map((runStep) => serializeRunStep({ runStep })),\n hasNextPage: () => runSteps.length === parseInt(limit),\n body: {\n // @ts-ignore-next-line\n last_id: (0, import_radash10.last)(runSteps)?.id ?? null\n }\n }), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/steps/index.ts\nvar steps = ({\n prisma\n}) => ({\n get: get4({ prisma })\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/submitToolOutputs/post/updateRun.ts\nvar import_dayjs8 = __toESM(require(\"dayjs\"), 1);\nvar updateRun = async ({\n prisma,\n runId,\n threadId,\n onThreadRunStepCompleted = () => {\n },\n tool_outputs\n}) => prisma.$transaction(async (prisma2) => {\n const runSteps = await prisma2.runStep.findMany({\n where: {\n threadId,\n runId,\n type: \"TOOL_CALLS\",\n status: \"IN_PROGRESS\"\n },\n orderBy: {\n createdAt: \"asc\"\n }\n });\n for (const runStep of runSteps) {\n const completedRunStep = await prisma2.runStep.update({\n where: {\n id: runStep.id\n },\n data: {\n status: \"COMPLETED\",\n completedAt: (0, import_dayjs8.default)().unix(),\n stepDetails: {\n type: \"tool_calls\",\n // @ts-ignore-next-line\n tool_calls: runStep.stepDetails.tool_calls.map((toolCall) => {\n const toolOutput = tool_outputs.find((output) => output.tool_call_id === toolCall.id) || tool_outputs[0];\n if (!toolOutput) {\n console.dir({ toolOutput, runStep, tool_outputs, runSteps }, { depth: null });\n throw new Error(\"Tool output not found\");\n }\n return {\n id: toolCall.id,\n type: toolCall.type,\n function: {\n ...toolCall.function,\n output: toolOutput.output\n }\n };\n })\n }\n }\n });\n onThreadRunStepCompleted({\n runStep: completedRunStep\n });\n }\n return prisma2.run.update({\n where: {\n id: runId\n },\n data: {\n status: \"QUEUED\"\n }\n });\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/submitToolOutputs/post/index.ts\nvar post9 = ({\n prisma,\n runAdapter\n}) => async (urlString, options) => {\n const url = new URL(urlString);\n const [, threadId, runId] = url.pathname.match(new RegExp(submitToolOutputsRegexp));\n const body = JSON.parse(options.body);\n const {\n tool_outputs,\n stream\n } = body;\n if (stream) {\n const readableStream = new ReadableStream({\n async start(controller) {\n const run2 = await updateRun({\n prisma,\n runId,\n threadId,\n tool_outputs,\n onThreadRunStepCompleted: async ({ runStep }) => {\n controller.enqueue(`data: ${JSON.stringify({\n event: \"thread.run.step.completed\",\n data: serializeRunStep({ runStep })\n })}\n\n`);\n }\n });\n await runAdapter({\n run: serializeRun({ run: run2 }),\n onEvent: onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\n\n`);\n }\n },\n prisma\n }),\n getMessages: getMessages({ prisma, run: run2 })\n });\n controller.close();\n }\n });\n return new Response(readableStream, {\n headers: {\n \"Content-Type\": \"text/event-stream\"\n }\n });\n } else {\n const run2 = await updateRun({\n prisma,\n runId,\n threadId,\n tool_outputs\n });\n await new Promise((resolve) => new ReadableStream({\n async start(controller) {\n await runAdapter({\n run: serializeRun({ run: run2 }),\n onEvent: onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\n\n`);\n }\n },\n prisma\n }),\n getMessages: getMessages({ prisma, run: run2 })\n });\n controller.close();\n resolve(void 0);\n }\n }));\n return new Response(JSON.stringify(\n run2\n ), {\n status: 200,\n headers: {\n \"Content-Type\": \"application/json\"\n }\n });\n }\n};\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/submitToolOutputs/index.ts\nvar submitToolOutputs = ({\n prisma,\n runAdapter\n}) => ({\n post: post9({\n prisma,\n // @ts-ignore-next-line\n runAdapter\n })\n});\n\n// src/adapters/storage/prismaStorageAdapter/index.ts\nvar prismaStorageAdapter = ({\n prisma\n}) => ({\n runAdapter\n}) => ({\n requestHandlers: {\n \"^/(?:v1|/?openai)/threads$\": threads({ prisma }),\n [messagesRegexp]: messages2({ prisma }),\n [runsRegexp]: runs({ prisma, runAdapter }),\n [runRegexp]: run({ prisma, runAdapter }),\n [stepsRegexp]: steps({ prisma }),\n [submitToolOutputsRegexp]: submitToolOutputs({ prisma, runAdapter })\n }\n});\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n anthropicClientAdapter,\n azureOpenaiClientAdapter,\n completionsRunAdapter,\n groqClientAdapter,\n mistralClientAdapter,\n openaiClientAdapter,\n perplexityClientAdapter,\n prismaStorageAdapter,\n supercompat\n});\n","export { supercompat } from './supercompat'\nexport { groqClientAdapter } from './adapters/client/groqClientAdapter'\nexport { openaiClientAdapter } from './adapters/client/openaiClientAdapter'\nexport { azureOpenaiClientAdapter } from './adapters/client/azureOpenaiClientAdapter'\nexport { mistralClientAdapter } from './adapters/client/mistralClientAdapter'\nexport { perplexityClientAdapter } from './adapters/client/perplexityClientAdapter'\nexport { anthropicClientAdapter } from './adapters/client/anthropicClientAdapter'\nexport { completionsRunAdapter } from './adapters/run/completionsRunAdapter'\nexport { prismaStorageAdapter } from './adapters/storage/prismaStorageAdapter'\n","import OpenAI, { AzureOpenAI } from 'openai'\nimport { supercompatFetch, type Args } from './supercompatFetch'\nimport { endpointFromBaseUrl } from '@/lib/azureOpenai/endpointFromBaseUrl'\n\nexport const supercompat = ({\n client,\n storage,\n runAdapter,\n}: Args) => {\n if (client.type === 'AZURE_OPENAI') {\n return new AzureOpenAI({\n apiKey: client.client.apiKey,\n apiVersion: client.client.apiVersion,\n endpoint: endpointFromBaseUrl({ baseURL: client.client.baseURL }),\n fetch: supercompatFetch({\n client,\n storage,\n runAdapter,\n }),\n })\n }\n\n return new OpenAI({\n apiKey: 'SUPERCOMPAT_PLACEHOLDER_OPENAI_KEY',\n fetch: supercompatFetch({\n client,\n storage,\n runAdapter,\n }),\n })\n}\n","import { assign, partob } from 'radash'\nimport { RunAdapter, StorageAdapterArgs } from '@/types'\n\nconst storageRequestHandlers = ({\n storage,\n runAdapter,\n client,\n}: {\n storage?: (arg0: StorageAdapterArgs) => any\n runAdapter?: RunAdapter\n client: any\n}) => {\n if (!storage) return {}\n if (!runAdapter) return {}\n\n const result = storage({ runAdapter: partob(runAdapter, { client }) })\n return result.requestHandlers\n}\n\nexport const requestHandlers = ({\n client,\n storage,\n runAdapter,\n}: {\n client: any\n storage?: (arg0: StorageAdapterArgs) => any\n runAdapter?: RunAdapter\n}) => (\n assign(\n client.requestHandlers,\n storageRequestHandlers({\n storage,\n runAdapter,\n client,\n })\n )\n)\n","export const findRequestHandler = ({\n url,\n requestHandlers,\n}: {\n url: string\n requestHandlers: any\n}) => {\n const pathname = new URL(url).pathname\n\n for (const key in requestHandlers) {\n const regex = new RegExp(key)\n\n if (regex.test(pathname)) {\n return requestHandlers[key]\n }\n }\n}\n","export const originalFetch = ({\n args,\n client,\n}: {\n args: any[]\n client: any\n}) => {\n if (client.client?.fetch) {\n const [url, options] = args\n\n const headers = {\n ...options.headers,\n authorization: client.client.defaultHeaders().Authorization,\n }\n\n return client.client.fetch(url, {\n ...options,\n headers,\n })\n } else {\n // @ts-ignore-next-line\n return fetch(...args)\n }\n}\n","import { RunAdapter, StorageAdapterArgs } from '@/types'\nimport { requestHandlers as getRequestHandlers } from './requestHandlers'\nimport { findRequestHandler } from './findRequestHandler'\nimport { originalFetch } from './originalFetch'\n\nexport type Args = {\n client: any\n storage?: (arg0: StorageAdapterArgs) => any\n runAdapter?: RunAdapter\n}\n\nexport const supercompatFetch = ({\n client,\n storage,\n runAdapter,\n}: Args) => {\n const requestHandlers = getRequestHandlers({\n client,\n storage,\n runAdapter,\n })\n\n return async (...args: any[]) => {\n const [url, options] = args\n\n const pathHandler = findRequestHandler({\n url,\n requestHandlers,\n })\n\n if (!pathHandler) {\n return originalFetch({\n client,\n args,\n })\n }\n\n const requestHandler = pathHandler[options?.method]\n\n if (!requestHandler) {\n return originalFetch({\n client,\n args,\n })\n }\n\n return requestHandler(...args)\n }\n}\n","export const endpointFromBaseUrl = ({\n baseURL\n}: {\n baseURL: string\n}) => (\n baseURL.replace(/\\/+openai$/, '')\n)\n","import type Groq from 'groq-sdk'\n\nexport const post = ({\n groq,\n}: {\n groq: Groq\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n if (body.stream) {\n const response = await groq.chat.completions.create(body)\n\n const stream = new ReadableStream({\n async start(controller) {\n // @ts-ignore-next-line\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\\n\\n`)\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n const data = await groq.chat.completions.create(body)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type Groq from 'groq-sdk'\nimport { post } from './post'\n\nexport const completions = ({\n groq,\n}: {\n groq: Groq\n}) => ({\n post: post({ groq }),\n})\n","// import type Groq from 'groq-sdk'\nimport { completions } from './completions'\n\nexport const groqClientAdapter = ({\n groq,\n}: {\n // TODO\n groq: any\n}) => ({\n client: groq,\n requestHandlers: {\n '^/v1/chat/completions$': completions({ groq }),\n },\n})\n","import type OpenAI from 'openai'\n\nexport const post = ({\n openai,\n}: {\n openai: OpenAI\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n if (body.stream) {\n const response = await openai.chat.completions.create(body)\n\n const stream = new ReadableStream({\n async start(controller) {\n // @ts-ignore-next-line\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\\n\\n`)\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n const data = await openai.chat.completions.create(body)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type OpenAI from 'openai'\nimport { post } from './post'\n\nexport const completions = ({\n openai,\n}: {\n openai: OpenAI\n}) => ({\n post: post({ openai }),\n})\n","import type OpenAI from 'openai'\nimport { completions } from './completions'\n\nexport const openaiClientAdapter = ({\n openai,\n}: {\n openai: OpenAI\n}) => ({\n client: openai,\n requestHandlers: {\n '^/(?:v1|/?openai)/chat/completions$': completions({ openai }),\n },\n})\n","import type { AzureOpenAI } from 'openai'\nimport { completions } from '@/adapters/client/openaiClientAdapter/completions'\n\nexport const azureOpenaiClientAdapter = ({\n azureOpenai,\n}: {\n azureOpenai: AzureOpenAI\n}) => ({\n type: 'AZURE_OPENAI',\n client: azureOpenai,\n requestHandlers: {\n '^/(?:v1|/?openai)/chat/completions$': completions({\n openai: azureOpenai,\n }),\n },\n})\n","import type { Mistral } from '@mistralai/mistralai'\n\nexport const post = ({\n mistral,\n}: {\n mistral: Mistral\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n if (body.stream) {\n const response = await mistral.chat.stream(body)\n\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\\n\\n`)\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n const data = await mistral.chat.complete(body)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type { Mistral } from '@mistralai/mistralai'\nimport { post } from './post'\n\nexport const completions = ({\n mistral,\n}: {\n mistral: Mistral\n}) => ({\n post: post({ mistral }),\n})\n","import type { Mistral } from '@mistralai/mistralai'\nimport { completions } from './completions'\n\nexport const mistralClientAdapter = ({\n mistral,\n}: {\n mistral: Mistral\n}) => ({\n client: mistral,\n requestHandlers: {\n '^/v1/chat/completions$': completions({ mistral }),\n },\n})\n","import type OpenAI from 'openai'\n\nconst agentSideRoles = ['assistant', 'system']\n\nexport const alternatingMessages = ({\n messages,\n}: {\n messages: OpenAI.Chat.ChatCompletionMessageParam[]\n}) => {\n const result = [] as OpenAI.Chat.ChatCompletionMessageParam[]\n\n messages.forEach((message: OpenAI.Chat.ChatCompletionMessageParam, index: number) => {\n result.push(message)\n\n const nextMessage = messages[index + 1]\n if (!nextMessage) return\n\n if (message.role === 'user' && nextMessage.role === 'user') {\n result.push({\n role: 'assistant',\n content: '-',\n })\n } else if (agentSideRoles.includes(message.role) && agentSideRoles.includes(nextMessage.role)) {\n result.push({\n role: 'user',\n content: '-',\n })\n }\n })\n\n return result\n}\n","import type OpenAI from 'openai'\nimport { alternatingMessages } from '@/lib/messages/alternatingMessages'\n\nexport const post = ({\n perplexity,\n}: {\n perplexity: OpenAI\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n const messages = alternatingMessages({\n messages: body.messages,\n })\n\n if (body.stream) {\n const response = await perplexity.chat.completions.create({\n ...body,\n messages,\n })\n\n const stream = new ReadableStream({\n async start(controller) {\n // @ts-ignore-next-line\n for await (const chunk of response) {\n controller.enqueue(`data: ${JSON.stringify(chunk)}\\n\\n`)\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n const data = await perplexity.chat.completions.create(body)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type OpenAI from 'openai'\nimport { post } from './post'\n\nexport const completions = ({\n perplexity,\n}: {\n perplexity: OpenAI\n}) => ({\n post: post({ perplexity }),\n})\n","import type OpenAI from 'openai'\nimport { completions } from './completions'\n\nexport const perplexityClientAdapter = ({\n perplexity,\n}: {\n perplexity: OpenAI\n}) => ({\n client: perplexity,\n requestHandlers: {\n '^/v1/chat/completions$': completions({ perplexity }),\n },\n})\n","import type Anthropic from '@anthropic-ai/sdk'\nimport type OpenAI from 'openai'\nimport { uid, fork, omit, isEmpty } from 'radash'\nimport { nonEmptyMessages } from '@/lib/messages/nonEmptyMessages'\nimport { alternatingMessages } from '@/lib/messages/alternatingMessages'\nimport { firstUserMessages } from '@/lib/messages/firstUserMessages'\nimport { serializeTools } from './serializeTools'\nimport { serializeMessages } from './serializeMessages'\n\nexport const post = ({\n anthropic,\n}: {\n anthropic: Anthropic\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n\n const messages = body.messages as OpenAI.ChatCompletionMessageParam[]\n const [systemMessages, otherMessages] = fork(messages, (message) => message.role === 'system')\n const system = systemMessages.map((message) => message.content).join('\\n')\n\n const chatMessages = nonEmptyMessages({\n messages: firstUserMessages({\n messages: alternatingMessages({\n messages: otherMessages,\n }),\n }),\n })\n\n const resultOptions = {\n ...omit(body, ['response_format']),\n stream: body.stream ? isEmpty(body.tools) : false,\n system,\n messages: serializeMessages({\n messages: chatMessages,\n }),\n max_tokens: 4096,\n tools: serializeTools({\n tools: body.tools,\n }),\n }\n\n if (body.stream) {\n // @ts-ignore-next-line\n const response = await anthropic.messages.stream(resultOptions)\n\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n if (chunk.type === 'content_block_delta') {\n const delta = chunk.delta.type === 'input_json_delta' ? {\n tool_calls: [\n {\n index: 0,\n function: {\n arguments: chunk.delta.partial_json,\n },\n },\n ]\n } : {\n content: chunk.delta.text,\n }\n\n const messageDelta = {\n id: `chatcmpl-${uid(29)}`,\n object: 'chat.completion.chunk',\n choices: [\n {\n index: chunk.index,\n delta,\n },\n ],\n }\n\n controller.enqueue(`data: ${JSON.stringify(messageDelta)}\\n\\n`)\n } else if (chunk.type === 'content_block_start') {\n const delta = chunk.content_block.type === 'tool_use' ? {\n content: null,\n tool_calls: [\n {\n index: 0,\n id: chunk.content_block.id,\n type: 'function',\n function: {\n name: chunk.content_block.name,\n arguments: '',\n }\n }\n ],\n } : {\n content: chunk.content_block.text,\n }\n\n const messageDelta = {\n id: `chatcmpl-${uid(29)}`,\n object: 'chat.completion.chunk',\n choices: [\n {\n index: chunk.index,\n delta,\n },\n ],\n }\n\n controller.enqueue(`data: ${JSON.stringify(messageDelta)}\\n\\n`)\n } else if (chunk.type === 'message_start') {\n const messageDelta = {\n id: `chatcmpl-${uid(29)}`,\n object: 'chat.completion.chunk',\n choices: [\n {\n index: 0,\n delta: {\n content: '',\n },\n },\n ],\n }\n\n controller.enqueue(`data: ${JSON.stringify(messageDelta)}\\n\\n`)\n }\n }\n\n controller.close()\n },\n })\n\n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n try {\n // @ts-ignore-next-line\n const data = await anthropic.messages.create(resultOptions)\n\n return new Response(JSON.stringify({\n data,\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n } catch (error) {\n return new Response(JSON.stringify({\n error,\n }), {\n status: 500,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n }\n}\n","import type OpenAI from 'openai'\nimport { isEmpty } from 'radash'\n\nexport const nonEmptyMessages = ({\n messages,\n}: {\n messages: OpenAI.Chat.ChatCompletionMessageParam[]\n}) => {\n const result = [] as OpenAI.Chat.ChatCompletionMessageParam[]\n\n messages.forEach((message: OpenAI.Chat.ChatCompletionMessageParam) => (\n result.push({\n ...message,\n content: isEmpty(message.content) ? '-' : message.content as string,\n })\n ))\n\n return result\n}\n","import type OpenAI from 'openai'\n\nexport const firstUserMessages = ({\n messages,\n}: {\n messages: OpenAI.Chat.ChatCompletionMessageParam[]\n}): OpenAI.Chat.ChatCompletionMessageParam[] => {\n const firstMessage = messages[0]\n if (!firstMessage) return messages\n\n if (firstMessage.role !== 'user') {\n return [\n {\n role: 'user',\n content: '-',\n },\n ...messages,\n ]\n }\n\n return messages\n}\n","import type OpenAI from 'openai'\n\nexport const serializeTools = ({\n tools,\n}: {\n tools: OpenAI.Beta.AssistantTool[] | undefined\n}) => (\n (tools ?? []).map((tool: OpenAI.Beta.AssistantTool) => {\n if (tool.type === 'function') {\n return {\n name: tool.function.name,\n description: tool.function.description,\n input_schema: tool.function.parameters ?? {\n type: 'object',\n },\n }\n }\n\n return tool\n })\n)\n","import type OpenAI from 'openai'\n\nexport const serializeMessage = ({\n message,\n}: {\n message: OpenAI.ChatCompletionMessageParam\n}) => {\n if (message.role === 'user') {\n return {\n role: 'user',\n content: message.content,\n }\n } else if (message.role === 'assistant') {\n return {\n role: 'assistant',\n content: [\n {\n type: 'text',\n text: message.content,\n },\n ...(message.tool_calls ?? []).map((toolCall) => ({\n type: 'tool_use',\n id: toolCall.id,\n name: toolCall.function.name,\n input: toolCall.function.arguments ? JSON.parse(toolCall.function.arguments) : {},\n })),\n ],\n }\n } else if (message.role === 'tool') {\n return {\n role: 'user',\n content: [\n {\n type: 'tool_result',\n tool_use_id: message.tool_call_id,\n content: message.content,\n },\n ],\n }\n }\n}\n","import type OpenAI from 'openai'\nimport { serializeMessage } from './serializeMessage'\n\nexport const serializeMessages = ({\n messages,\n}: {\n messages: OpenAI.ChatCompletionMessageParam[]\n}) => (\n messages.map(message => (\n serializeMessage({\n message,\n })\n ))\n)\n","import type Anthropic from '@anthropic-ai/sdk'\nimport { post } from './post'\n\nexport const completions = ({\n anthropic,\n}: {\n anthropic: Anthropic\n}) => ({\n post: post({ anthropic }),\n})\n","import type Anthropic from '@anthropic-ai/sdk'\nimport { completions } from './completions'\n\nexport const anthropicClientAdapter = ({\n anthropic,\n}: {\n anthropic: Anthropic\n}) => ({\n client: anthropic,\n requestHandlers: {\n '^/v1/chat/completions$': completions({ anthropic }),\n },\n})\n","import _ from 'lodash'\nimport { uid, omit, isEmpty } from 'radash'\nimport dayjs from 'dayjs'\nimport OpenAI from 'openai'\nimport { MessageWithRun } from '@/types'\nimport { messages } from './messages'\nimport { supercompat } from '@/supercompat'\n\nconst updatedToolCall = ({\n toolCall,\n delta,\n}: {\n toolCall: any\n delta: any\n}) => {\n if (!toolCall) return omit(delta, ['index'])\n\n // if (delta.type !== 'function') return toolCall\n\n const result = _.cloneDeep(toolCall)\n\n for (const [key, value] of Object.entries(delta.function)) {\n result.function[key] = `${result.function[key] ?? ''}${value}`\n }\n\n return result\n}\n\nconst toolCallsData = ({\n prevToolCalls,\n delta,\n}: {\n prevToolCalls: any\n delta: any\n}) => {\n if (!prevToolCalls) {\n return delta.tool_calls.map((tc: any) => ({\n id: uid(24),\n type: 'function',\n ...omit(tc, ['index']),\n }))\n }\n\n const newToolCalls = _.cloneDeep(prevToolCalls)\n\n for (const runStepDelta of delta.tool_calls) {\n newToolCalls[runStepDelta.index] = updatedToolCall({\n toolCall: newToolCalls[runStepDelta.index],\n delta: runStepDelta,\n })\n }\n\n return newToolCalls\n}\n\nexport const completionsRunAdapter = () => async ({\n client: clientAdapter,\n run,\n onEvent,\n getMessages,\n}: {\n client: OpenAI\n run: OpenAI.Beta.Threads.Run\n onEvent: (event: OpenAI.Beta.AssistantStreamEvent) => Promise<any>\n getMessages: () => Promise<MessageWithRun[]>\n}) => {\n if (run.status !== 'queued') return\n\n const client = supercompat({\n client: clientAdapter,\n })\n\n onEvent({\n event: 'thread.run.in_progress',\n data: {\n ...run,\n status: 'in_progress',\n },\n })\n\n const opts = {\n messages: await messages({\n run,\n getMessages,\n }),\n model: run.model,\n stream: true,\n response_format: run.response_format,\n ...(isEmpty(run.tools) ? {} : { tools: run.tools }),\n } as OpenAI.ChatCompletionCreateParamsStreaming\n\n let providerResponse\n\n try {\n providerResponse = await client.chat.completions.create(opts)\n } catch(e: any) {\n console.error(e)\n\n return onEvent({\n event: 'thread.run.failed',\n data: {\n ...run,\n failed_at: dayjs().unix(),\n status: 'in_progress',\n last_error: {\n code: 'server_error',\n message: `${e?.message ?? ''} ${e?.cause?.message ?? ''}`,\n },\n },\n })\n }\n\n let message = await onEvent({\n event: 'thread.message.created',\n data: {\n id: 'THERE_IS_A_BUG_IN_SUPERCOMPAT_IF_YOU_SEE_THIS_ID',\n object: 'thread.message',\n completed_at: null,\n run_id: run.id,\n created_at: dayjs().unix(),\n assistant_id: run.assistant_id,\n incomplete_at: null,\n incomplete_details: null,\n metadata: {},\n attachments: [],\n thread_id: run.thread_id,\n content: [{ text: { value: '', annotations: [] }, type: 'text' }],\n role: 'assistant',\n status: 'in_progress',\n },\n })\n\n onEvent({\n event: 'thread.run.step.created',\n data: {\n id: 'THERE_IS_A_BUG_IN_SUPERCOMPAT_IF_YOU_SEE_THIS_ID',\n object: 'thread.run.step',\n run_id: run.id,\n assistant_id: run.assistant_id,\n thread_id: run.thread_id,\n type: 'message_creation',\n status: 'completed',\n completed_at: dayjs().unix(),\n created_at: dayjs().unix(),\n expired_at: null,\n last_error: null,\n metadata: {},\n failed_at: null,\n cancelled_at: null,\n usage: null,\n step_details: {\n type: 'message_creation',\n message_creation: {\n message_id: message.id,\n },\n },\n },\n })\n\n let toolCallsRunStep\n let currentContent = ''\n let currentToolCalls\n\n for await (const chunk of providerResponse) {\n const choice = chunk.choices[0]\n if (!choice) continue\n\n const delta = choice.delta\n\n if (delta.content) {\n currentContent = `${currentContent}${delta.content ?? ''}`\n }\n\n if (delta.tool_calls) {\n if (!toolCallsRunStep) {\n toolCallsRunStep = await onEvent({\n event: 'thread.run.step.created',\n data: {\n id: 'THERE_IS_A_BUG_IN_SUPERCOMPAT_IF_YOU_SEE_THIS_ID',\n object: 'thread.run.step',\n run_id: run.id,\n assistant_id: run.assistant_id,\n thread_id: run.thread_id,\n type: 'tool_calls',\n status: 'in_progress',\n completed_at: null,\n created_at: dayjs().unix(),\n expired_at: null,\n last_error: null,\n metadata: {},\n failed_at: null,\n cancelled_at: null,\n usage: null,\n step_details: {\n type: 'tool_calls',\n tool_calls: [],\n },\n },\n })\n }\n\n onEvent({\n event: 'thread.run.step.delta',\n data: {\n object: 'thread.run.step.delta',\n run_id: run.id,\n id: toolCallsRunStep.id,\n delta: {\n step_details: {\n type: 'tool_calls',\n tool_calls: delta.tool_calls.map((tc: any) => ({\n id: uid(24),\n type: 'function',\n ...tc,\n })),\n },\n },\n },\n } as OpenAI.Beta.AssistantStreamEvent.ThreadRunStepDelta)\n\n currentToolCalls = toolCallsData({ prevToolCalls: currentToolCalls, delta })\n }\n\n if (delta.content) {\n onEvent({\n event: 'thread.message.delta',\n data: {\n id: message.id,\n delta: {\n content: [\n {\n type: 'text',\n index: 0,\n text: {\n value: delta.content,\n },\n },\n ],\n },\n },\n } as OpenAI.Beta.AssistantStreamEvent.ThreadMessageDelta)\n }\n }\n\n message = await onEvent({\n event: 'thread.message.completed',\n data: {\n ...message,\n status: 'completed',\n content: [{ text: { value: currentContent, annotations: [] }, type: 'text' }],\n tool_calls: currentToolCalls,\n },\n })\n\n if (isEmpty(message.toolCalls)) {\n return onEvent({\n event: 'thread.run.completed',\n data: {\n ...run,\n status: 'completed',\n completed_at: dayjs().unix(),\n },\n })\n }\n\n return onEvent({\n event: 'thread.run.requires_action',\n data: {\n ...run,\n status: 'requires_action',\n required_action: {\n type: 'submit_tool_outputs',\n submit_tool_outputs: {\n tool_calls: message.toolCalls,\n },\n },\n },\n })\n}\n","import type OpenAI from 'openai'\nimport { flat } from 'radash'\nimport { MessageWithRun } from '@/types'\nimport { serializeMessage } from './serializeMessage'\n\nexport const messages = async ({\n run,\n getMessages,\n}: {\n run: OpenAI.Beta.Threads.Run\n getMessages: () => Promise<MessageWithRun[]>\n}) => (\n [\n ...(run.instructions ? [{\n role: 'system',\n content: run.instructions,\n }] : []),\n ...flat((await getMessages()).map((message: MessageWithRun) => serializeMessage({ message }))),\n ]\n)\n","import type OpenAI from 'openai'\nimport { MessageWithRun } from '@/types'\n\nconst serializeToolCall = ({\n toolCall,\n}: {\n toolCall: OpenAI.Beta.Threads.Runs.Steps.FunctionToolCall\n}) => ({\n tool_call_id: toolCall.id,\n role: 'tool' as 'tool',\n name: toolCall.function.name,\n content: toolCall.function.output ?? '',\n})\n\nconst serializeMessageWithContent = ({\n message,\n}: {\n message: MessageWithRun\n}) => ({\n role: message.role,\n content: serializeContent({\n content: message.content as unknown as OpenAI.Beta.Threads.Messages.TextContentBlock[],\n }),\n ...(message?.metadata?.toolCalls ? { tool_calls: message.metadata.toolCalls } : {}),\n})\n\nconst serializeContent = ({\n content,\n}: {\n content: OpenAI.Beta.Threads.Messages.TextContentBlock[]\n}) => content.map((content) => content.text.value).join('\\n')\n\nexport const serializeMessage = ({\n message\n}: {\n message: MessageWithRun\n}) => {\n const result = [serializeMessageWithContent({ message })]\n\n const run = message.run\n\n if (!run) return result\n\n const messageToolCalls = message.metadata?.toolCalls || []\n\n messageToolCalls.forEach((tc: OpenAI.Beta.Threads.Runs.Steps.ToolCall) => {\n const runStep = run.runSteps.find((rs) => {\n if (rs.type !== 'tool_calls') return false\n\n return rs.step_details.tool_calls.some((rsTc: OpenAI.Beta.Threads.Runs.Steps.ToolCall) => {\n if (rsTc.type !== 'function') return false\n\n return rsTc.id === tc.id\n })\n })\n\n if (!runStep) return\n\n const toolCall = runStep.step_details.tool_calls.find((rsTc: OpenAI.Beta.Threads.Runs.Steps.ToolCall) => {\n if (rsTc.type !== 'function') return false\n\n return rsTc.id === tc.id\n })\n\n result.push(serializeToolCall({ toolCall }))\n })\n\n return result\n}\n","export const messagesRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/messages$'\n","export const runsRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/runs$'\n","export const runRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/runs/([^/]+)$'\n","export const submitToolOutputsRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/runs/([^/]+)/submit_tool_outputs$'\n","export const stepsRegexp = '^/(?:v1|/?openai)/threads/([^/]+)/runs/([^/]+)/steps$'\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport dayjs from 'dayjs'\nimport { serializeThread } from './serializeThread'\n\ntype ThreadCreateResponse = Response & {\n json: () => Promise<OpenAI.Beta.Threads['create']>\n}\n\nexport const post = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (...args: Parameters<OpenAI.Beta.Threads['create']>): Promise<ThreadCreateResponse> => {\n // @ts-ignore-next-line\n const body = JSON.parse(args[1].body)\n\n const messages = body.messages || []\n const metadata = body.metadata || {}\n\n const initialCreatedAt = dayjs().subtract(messages.length, 'seconds').format()\n\n const thread = await prisma.thread.create({\n data: {\n metadata,\n ...(metadata.assistantId ? ({\n assistant: {\n connect: {\n id: metadata.assistantId,\n },\n },\n }) : {}),\n messages: {\n create: messages.map((message: OpenAI.Beta.ThreadCreateParams.Message, index: number) => ({\n role: message.role === 'user' ? 'USER' : 'ASSISTANT',\n content: [{\n type: 'text',\n text: {\n annotations: [],\n value: message.content,\n },\n },\n ],\n attachments: message.attachments,\n metadata: message.metadata,\n createdAt: dayjs(initialCreatedAt).add(index, 'seconds').toDate(),\n })),\n },\n },\n })\n\n return new Response(JSON.stringify(\n serializeThread({ thread }),\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","// @ts-ignore-next-line\nimport type { Thread } from '@prisma/client'\nimport dayjs from 'dayjs'\n\nexport const serializeThread = ({\n thread,\n}: {\n thread: Thread\n}) => ({\n id: thread.id,\n object: 'thread' as 'thread',\n created_at: dayjs(thread.createdAt).unix(),\n metadata: thread.metadata,\n // TODO\n tool_resources: null,\n})\n","import type { PrismaClient } from '@prisma/client'\nimport { post } from './post'\n\nexport const threads = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => ({\n post: post({ prisma }),\n})\n","// @ts-ignore-next-line\nimport type { Message } from '@prisma/client'\nimport dayjs from 'dayjs'\nimport type OpenAI from 'openai'\nimport { assign } from 'radash'\n\nexport const serializeMessage = ({\n message,\n}: {\n message: Message\n}) => ({\n id: message.id,\n object: 'thread.message' as 'thread.message',\n created_at: dayjs(message.createdAt).unix(),\n thread_id: message.threadId,\n completed_at: message.completedAt ? dayjs(message.completedAt).unix() : null,\n incomplete_at: message.incompleteAt ? dayjs(message.incompleteAt).unix() : null,\n incomplete_details: message.incompleteDetails as unknown as OpenAI.Beta.Threads.Messages.Message.IncompleteDetails,\n role: message.role.toLowerCase() as 'user' | 'assistant',\n content: message.content as unknown as OpenAI.Beta.Threads.Messages.TextContentBlock[],\n assistant_id: message.assistantId,\n run_id: message.runId,\n attachments: message.attachments,\n status: message.status.toLowerCase() as OpenAI.Beta.Threads.Messages.Message['status'],\n metadata: assign(message.metadata as Record<any, any> ?? {}, message.toolCalls ? { toolCalls: message.toolCalls } : {}),\n})\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport { serializeMessage } from './serializeMessage'\nimport { messagesRegexp } from '@/lib/messages/messagesRegexp'\n\ntype MessageCreateResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Messages['create']>>\n}\n\nconst messageContentBlocks = ({\n content,\n}: {\n content: string\n}) => ([\n {\n type: 'text',\n text: {\n value: content ?? '',\n annotations: [],\n },\n },\n])\n\nexport const post = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string, options: any): Promise<MessageCreateResponse> => {\n const url = new URL(urlString)\n\n const [, threadId] = url.pathname.match(new RegExp(messagesRegexp))!\n\n const body = JSON.parse(options.body)\n const { role, content } = body\n\n const message = await prisma.message.create({\n data: {\n threadId,\n content: messageContentBlocks({ content }),\n role: role === 'user' ? 'USER' : 'ASSISTANT',\n },\n })\n\n return new Response(JSON.stringify(\n serializeMessage({ message }),\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","import type OpenAI from 'openai'\n// @ts-ignore-next-line\nimport type { PrismaClient, Message } from '@prisma/client'\nimport { assign, last } from 'radash'\nimport { messagesRegexp } from '@/lib/messages/messagesRegexp'\nimport { serializeMessage } from './serializeMessage'\n\ntype MessageCreateResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Messages['create']>>\n}\n\nexport const get = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string): Promise<MessageCreateResponse> => {\n const url = new URL(urlString)\n\n const [, threadId] = url.pathname.match(new RegExp(messagesRegexp))!\n\n const {\n limit,\n order,\n after,\n } = assign({\n limit: '20',\n order: 'desc',\n // after: null,\n }, Object.fromEntries(url.searchParams))\n\n const messages = await prisma.message.findMany({\n where: {\n threadId,\n },\n take: parseInt(limit),\n orderBy: {\n createdAt: order,\n },\n ...(after ? {\n skip: 1,\n cursor: {\n id: after,\n },\n }: {}),\n }) as Message[]\n\n return new Response(JSON.stringify({\n data: messages.map((message: Message) => (\n serializeMessage({ message })\n )),\n hasNextPage: () => messages.length === parseInt(limit),\n body: {\n last_id: last(messages)?.id ?? null,\n },\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","import type { PrismaClient } from '@prisma/client'\nimport { post } from './post'\nimport { get } from './get'\n\nexport const messages = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => ({\n post: post({ prisma }),\n get: get({ prisma }),\n})\n","import type OpenAI from 'openai'\n// @ts-ignore-next-line\nimport type { PrismaClient, Run } from '@prisma/client'\nimport { assign, last } from 'radash'\nimport { runsRegexp } from '@/lib/runs/runsRegexp'\nimport { serializeRun } from './serializeRun'\n\ntype MessageCreateResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Messages['create']>>\n}\n\nexport const get = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string): Promise<MessageCreateResponse> => {\n const url = new URL(urlString)\n\n const [, threadId] = url.pathname.match(new RegExp(runsRegexp))!\n\n const {\n limit,\n order,\n after,\n } = assign({\n limit: '20',\n order: 'desc',\n // after: null,\n }, Object.fromEntries(url.searchParams))\n\n const runs = await prisma.run.findMany({\n where: {\n threadId,\n },\n take: parseInt(limit),\n orderBy: {\n createdAt: order,\n },\n ...(after ? {\n skip: 1,\n cursor: {\n id: after,\n },\n }: {}),\n })\n\n return new Response(JSON.stringify({\n data: runs.map((run: Run) => (\n serializeRun({ run })\n )),\n hasNextPage: () => runs.length === parseInt(limit),\n body: {\n // @ts-ignore-next-line\n last_id: last(runs)?.id ?? null,\n },\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","import type OpenAI from 'openai'\n// @ts-ignore-next-line\nimport type { Run } from '@prisma/client'\nimport dayjs from 'dayjs'\n\nexport const serializeRun = ({\n run,\n}: {\n run: Run\n}): OpenAI.Beta.Threads.Run => ({\n id: run.id,\n object: 'thread.run' as 'thread.run',\n created_at: dayjs(run.createdAt).unix(),\n thread_id: run.threadId,\n assistant_id: run.assistantId,\n status: run.status.toLowerCase() as OpenAI.Beta.Threads.Run['status'],\n required_action: run.requiredAction as OpenAI.Beta.Threads.Run['required_action'],\n last_error: run.lastError as OpenAI.Beta.Threads.Run['last_error'],\n expires_at: dayjs(run.expiresAt).unix(),\n started_at: run.startedAt ? dayjs(run.startedAt).unix() : null,\n cancelled_at: run.cancelledAt ? dayjs(run.cancelledAt).unix() : null,\n failed_at: run.failedAt ? dayjs(run.failedAt).unix() : null,\n completed_at: run.completedAt ? dayjs(run.completedAt).unix() : null,\n model: run.model,\n instructions: run.instructions,\n tools: run.tools as OpenAI.Beta.Threads.Run['tools'],\n metadata: run.metadata,\n usage: run.usage as OpenAI.Beta.Threads.Run['usage'],\n truncation_strategy: {\n type: 'auto',\n },\n response_format: {\n type: 'text',\n },\n // TODO\n incomplete_details: null,\n max_completion_tokens: null,\n max_prompt_tokens: null,\n tool_choice: 'auto',\n parallel_tool_calls: true,\n})\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport dayjs from 'dayjs'\nimport { assign } from 'radash'\nimport { runsRegexp } from '@/lib/runs/runsRegexp'\nimport { serializeRun } from './serializeRun'\nimport { RunAdapterPartobClient } from '@/types'\nimport { onEvent } from './onEvent'\nimport { getMessages } from './getMessages'\n\ntype RunCreateResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Runs['create']>>\n}\n\nexport const post = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapterPartobClient\n}) => async (urlString: string, options: any): Promise<RunCreateResponse> => {\n const url = new URL(urlString)\n const [, threadId] = url.pathname.match(new RegExp(runsRegexp))!\n\n const body = JSON.parse(options.body)\n const { assistant_id, stream } = body\n\n const assistant = await prisma.assistant.findUnique({\n where: {\n id: assistant_id,\n },\n })\n\n if (!assistant) {\n throw new Error('Assistant not found')\n }\n\n const {\n model,\n instructions,\n // additional_instructions,\n tools,\n metadata,\n response_format,\n truncation_strategy,\n } = assign({\n model: assistant.modelSlug,\n instructions: '',\n additional_instructions: null,\n truncation_strategy: {\n type: 'auto',\n },\n response_format: {\n type: 'text',\n },\n // tools: [],\n // metadata: {},\n }, body)\n\n const run = await prisma.run.create({\n data: {\n status: 'QUEUED',\n expiresAt: dayjs().add(1, 'hour').unix(),\n model,\n instructions,\n tools,\n metadata,\n thread: {\n connect: {\n id: threadId,\n },\n },\n assistant: {\n connect: {\n id: assistant_id,\n },\n },\n truncationStrategy: truncation_strategy,\n responseFormat: response_format,\n },\n })\n\n const data = serializeRun({ run })\n\n const readableStream = new ReadableStream({\n async start(controller) {\n try {\n await runAdapter({\n run: data,\n onEvent: onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\\n\\n`)\n },\n },\n prisma,\n }),\n getMessages: getMessages({\n prisma,\n run,\n }),\n })\n } catch (error: any) {\n console.error(error)\n\n onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\\n\\n`)\n },\n },\n prisma,\n })({\n event: 'thread.run.failed',\n data: {\n id: run.id,\n failed_at: dayjs().unix(),\n last_error: {\n code: 'server_error',\n message: `${error?.message ?? ''} ${error?.cause?.message ?? ''}`,\n },\n },\n } as OpenAI.Beta.AssistantStreamEvent.ThreadRunFailed)\n }\n\n controller.close()\n },\n })\n\n if (stream) {\n return new Response(readableStream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n return new Response(JSON.stringify(\n data\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n}\n","import type OpenAI from 'openai'\nimport { RunStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\n\nexport const threadRunInProgress = ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunInProgress\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunInProgress>\n}) => {\n controller.enqueue(event)\n\n return prisma.run.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: RunStatus.IN_PROGRESS,\n },\n })\n}\n","import type OpenAI from 'openai'\nimport { RunStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\n\nexport const threadRunFailed = ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunFailed\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunFailed>\n}) => {\n controller.enqueue(event)\n\n return prisma.run.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: RunStatus.FAILED,\n failedAt: event.data.failed_at,\n lastError: event.data.last_error,\n },\n })\n}\n","import type OpenAI from 'openai'\nimport { RunStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\n\nexport const threadRunCompleted = ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunCompleted\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunCompleted>\n}) => {\n controller.enqueue(event)\n\n return prisma.run.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: RunStatus.COMPLETED,\n requiredAction: undefined,\n },\n })\n}\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport { RunStatus } from '@/types/prisma'\n\nexport const threadRunRequiresAction = ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunRequiresAction\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunRequiresAction>\n}) => {\n controller.enqueue(event)\n\n return prisma.run.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: RunStatus.REQUIRES_ACTION,\n requiredAction: event.data.required_action,\n },\n })\n}\n","import dayjs from 'dayjs'\n// @ts-ignore-next-line\nimport type { RunStep } from '@prisma/client'\nimport type OpenAI from 'openai'\n\nexport const serializeRunStep = ({\n runStep,\n}: {\n runStep: RunStep\n}) => ({\n id: runStep.id,\n object: 'thread.run.step' as 'thread.run.step',\n created_at: dayjs(runStep.createdAt).unix(),\n assistant_id: runStep.assistantId,\n thread_id: runStep.threadId,\n run_id: runStep.runId,\n type: runStep.type.toLowerCase() as OpenAI.Beta.Threads.Runs.RunStep['type'],\n status: runStep.status.toLowerCase() as OpenAI.Beta.Threads.Runs.RunStep['status'],\n // @ts-ignore-next-line\n step_details: runStep.stepDetails as OpenAI.Beta.Threads.Runs.RunStep['step_details'],\n last_error: runStep.lastError as OpenAI.Beta.Threads.Runs.RunStep['last_error'],\n expired_at: runStep.expiredAt ? dayjs(runStep.expiredAt).unix() : null,\n cancelled_at: runStep.cancelledAt ? dayjs(runStep.cancelledAt).unix() : null,\n failed_at: runStep.failedAt ? dayjs(runStep.failedAt).unix() : null,\n completed_at: runStep.completedAt ? dayjs(runStep.completedAt).unix() : null,\n metadata: runStep.metadata,\n usage: runStep.usage as OpenAI.Beta.Threads.Runs.RunStep['usage'],\n})\n","import type OpenAI from 'openai'\nimport { RunStepType, RunStepStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\nimport { serializeRunStep } from '../../steps/serializeRunStep'\n\nconst type = (event: OpenAI.Beta.AssistantStreamEvent.ThreadRunStepCreated) => {\n if (event.data.type === 'message_creation') return RunStepType.MESSAGE_CREATION\n if (event.data.type === 'tool_calls') return RunStepType.TOOL_CALLS\n\n throw new Error(`Unknown type: ${event.data.type}`)\n}\n\nconst status = (event: OpenAI.Beta.AssistantStreamEvent.ThreadRunStepCreated) => {\n if (event.data.status === 'in_progress') return RunStepStatus.IN_PROGRESS\n if (event.data.status === 'cancelled') return RunStepStatus.CANCELLED\n if (event.data.status === 'completed') return RunStepStatus.COMPLETED\n if (event.data.status === 'failed') return RunStepStatus.FAILED\n if (event.data.status === 'expired') return RunStepStatus.EXPIRED\n\n throw new Error(`Unknown status: ${event.data.status}`)\n}\n\nexport const threadRunStepCreated = async ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunStepCreated\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunStepCreated>\n}) => {\n const runStep = await prisma.runStep.create({\n data: {\n runId: event.data.run_id,\n assistantId: event.data.assistant_id,\n threadId: event.data.thread_id,\n type: type(event),\n status: status(event),\n stepDetails: event.data.step_details,\n completedAt: event.data.completed_at,\n },\n })\n\n const serializedRunStep = serializeRunStep({ runStep })\n\n controller.enqueue({\n ...event,\n data: serializedRunStep,\n })\n\n return serializedRunStep\n}\n","import type OpenAI from 'openai'\n\nexport const threadRunStepDelta = ({\n event,\n controller,\n}: {\n event: OpenAI.Beta.AssistantStreamEvent.ThreadRunStepDelta\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadRunStepDelta>\n}) => (\n controller.enqueue(event)\n)\n","import type OpenAI from 'openai'\nimport { MessageStatus } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\nimport { serializeMessage } from '../../../messages/serializeMessage'\n\nconst status = (event: OpenAI.Beta.AssistantStreamEvent.ThreadMessageCreated) => {\n if (event.data.status === 'completed') return MessageStatus.COMPLETED\n if (event.data.status === 'in_progress') return MessageStatus.IN_PROGRESS\n if (event.data.status === 'incomplete') return MessageStatus.INCOMPLETE\n\n throw new Error(`Unknown status: ${event.data.status}`)\n}\n\nexport const threadMessageCreated = async ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadMessageCreated\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadMessageCreated>\n}) => {\n const message = await prisma.message.create({\n data: {\n threadId: event.data.thread_id,\n content: event.data.content as unknown as OpenAI.Beta.Threads.Messages.TextContentBlock[],\n role: event.data.role === 'assistant' ? 'ASSISTANT' : 'USER',\n assistantId: event.data.assistant_id,\n runId: event.data.run_id,\n status: status(event),\n },\n })\n\n const serializedMessage = serializeMessage({ message })\n\n controller.enqueue({\n ...event,\n data: serializedMessage,\n })\n\n return serializedMessage\n}\n","import type OpenAI from 'openai'\n\nexport const threadMessageDelta = ({\n event,\n controller,\n}: {\n event: OpenAI.Beta.AssistantStreamEvent.ThreadMessageDelta\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadMessageDelta>\n}) => (\n controller.enqueue(event)\n)\n","import type OpenAI from 'openai'\nimport { MessageStatus, RunStepType } from '@/types/prisma'\nimport type { PrismaClient } from '@prisma/client'\n\nexport const threadMessageCompleted = async ({\n prisma,\n event,\n controller,\n}: {\n prisma: PrismaClient\n event: OpenAI.Beta.AssistantStreamEvent.ThreadMessageCompleted\n controller: ReadableStreamDefaultController<OpenAI.Beta.AssistantStreamEvent.ThreadMessageCompleted>\n}) => {\n controller.enqueue(event)\n\n if (event.data.tool_calls) {\n const latestRunStep = await prisma.runStep.findFirst({\n where: {\n threadId: event.data.thread_id,\n type: RunStepType.TOOL_CALLS,\n },\n orderBy: {\n createdAt: 'desc',\n },\n })\n\n if (!latestRunStep) {\n throw new Error('No run step found')\n }\n\n await prisma.runStep.update({\n where: {\n id: latestRunStep.id,\n },\n data: {\n stepDetails: {\n type: 'tool_calls',\n tool_calls: event.data.tool_calls,\n },\n },\n })\n }\n\n return prisma.message.update({\n where: {\n id: event.data.id,\n },\n data: {\n status: MessageStatus.COMPLETED,\n ...(event.data.content ? { content: event.data.content } : {}),\n ...(event.data.tool_calls ? { toolCalls: event.data.tool_calls } : {}),\n },\n })\n}\n","import { threadRunInProgress } from './threadRunInProgress'\nimport { threadRunFailed } from './threadRunFailed'\nimport { threadRunCompleted } from './threadRunCompleted'\nimport { threadRunRequiresAction } from './threadRunRequiresAction'\nimport { threadRunStepCreated } from './threadRunStepCreated'\nimport { threadRunStepDelta } from './threadRunStepDelta'\nimport { threadMessageCreated } from './threadMessageCreated'\nimport { threadMessageDelta } from './threadMessageDelta'\nimport { threadMessageCompleted } from './threadMessageCompleted'\n\nexport const handlers = {\n 'thread.run.in_progress': threadRunInProgress,\n 'thread.run.failed': threadRunFailed,\n 'thread.run.completed': threadRunCompleted,\n 'thread.run.requires_action': threadRunRequiresAction,\n 'thread.run.step.created': threadRunStepCreated,\n 'thread.run.step.delta': threadRunStepDelta,\n 'thread.message.created': threadMessageCreated,\n 'thread.message.delta': threadMessageDelta,\n 'thread.message.completed': threadMessageCompleted,\n}\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport { handlers } from './handlers'\n\nexport const onEvent = ({\n prisma,\n controller,\n}: {\n prisma: PrismaClient\n controller: ReadableStreamDefaultController\n}) => (event: OpenAI.Beta.AssistantStreamEvent) => {\n // @ts-ignore-next-line\n const handler = handlers[event.event]\n\n if (!handler) {\n console.log('No handler for event', event)\n return\n }\n\n return handler({ prisma, controller, event })\n}\n","import type { PrismaClient } from '@prisma/client'\nimport { serializeMessage } from '../messages/serializeMessage'\nimport { serializeRunStep } from './steps/serializeRunStep'\nimport { serializeRun } from './serializeRun'\nimport type { Run, MessageWithRun, RunStep } from '@/types/prisma'\n\nconst getTake = ({\n run,\n}: {\n run: Run\n}) => {\n // @ts-ignore-next-line\n if (run.truncationStrategy.type === 'auto') {\n return null\n }\n\n // @ts-ignore-next-line\n if (run.truncationStrategy.type === 'last_messages') {\n // @ts-ignore-next-line\n if (!run.truncationStrategy.last_messages) {\n throw new Error('Truncation strategy last_messages is required')\n }\n\n // @ts-ignore-next-line\n return -run.truncationStrategy.last_messages\n }\n\n // @ts-ignore-next-line\n throw new Error(`Unsupported truncation strategy type: ${run.truncationStrategy.type}`)\n}\n\nexport const getMessages = ({\n prisma,\n run,\n}: {\n prisma: PrismaClient\n run: Run\n}) => async () => {\n const take = getTake({\n run,\n })\n\n const messages = await prisma.message.findMany({\n where: {\n threadId: run.threadId,\n },\n include: {\n run: {\n include: {\n runSteps: true,\n },\n },\n },\n orderBy: {\n createdAt: 'asc',\n },\n ...(take ? { take } : {}),\n })\n\n return messages.map((message: MessageWithRun) => ({\n ...serializeMessage({ message }),\n run: message.run ? ({\n ...serializeRun({ run: message.run }),\n runSteps: message.run.runSteps.map((runStep: RunStep) => (\n serializeRunStep({ runStep })\n )),\n }) : null,\n }))\n}\n","import type { PrismaClient } from '@prisma/client'\nimport type { RunAdapter } from '@/types'\nimport { get } from './get'\nimport { post } from './post'\n\nexport const runs = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapter\n}) => ({\n get: get({ prisma }),\n post: post({ prisma, runAdapter }),\n})\n","import type OpenAI from 'openai'\nimport type { PrismaClient } from '@prisma/client'\nimport { runRegexp } from '@/lib/runs/runRegexp'\nimport { serializeRun } from '../runs/serializeRun'\n\ntype GetResponse = Response & {\n json: () => Promise<ReturnType<OpenAI.Beta.Threads.Runs['retrieve']>>\n}\n\nexport const get = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string): Promise<GetResponse> => {\n const url = new URL(urlString)\n\n const [, threadId, runId] = url.pathname.match(new RegExp(runRegexp))!\n\n const run = await prisma.run.findUnique({\n where: {\n id: runId,\n threadId,\n },\n })\n\n return new Response(JSON.stringify(\n serializeRun({ run })\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n 'openai-poll-after-ms': '5000',\n },\n })\n}\n","import type { PrismaClient } from '@prisma/client'\nimport type { RunAdapter } from '@/types'\nimport { get } from './get'\n// import { post } from './post'\n\nexport const run = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapter\n}) => ({\n get: get({ prisma }),\n // post: post({ prisma, runAdapter }),\n})\n","// @ts-ignore-next-line\nimport type { PrismaClient, RunStep } from '@prisma/client'\nimport { assign, last } from 'radash'\nimport { stepsRegexp } from '@/lib/steps/stepsRegexp'\nimport { serializeRunStep } from './serializeRunStep'\n\nexport const get = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => async (urlString: string) => {\n const url = new URL(urlString)\n\n const [, threadId,, runId] = url.pathname.match(new RegExp(stepsRegexp))!\n\n const {\n limit,\n order,\n after,\n } = assign({\n limit: '20',\n order: 'desc',\n // after: null,\n }, Object.fromEntries(url.searchParams))\n\n const runSteps = await prisma.runStep.findMany({\n where: {\n threadId,\n runId,\n },\n take: parseInt(limit),\n orderBy: {\n createdAt: order,\n },\n ...(after ? {\n skip: 1,\n cursor: {\n id: after,\n },\n }: {}),\n })\n\n return new Response(JSON.stringify({\n data: runSteps.map((runStep: RunStep) => (\n serializeRunStep({ runStep })\n )),\n hasNextPage: () => runSteps.length === parseInt(limit),\n body: {\n // @ts-ignore-next-line\n last_id: last(runSteps)?.id ?? null,\n },\n }), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n}\n","import type { PrismaClient } from '@prisma/client'\nimport { get } from './get'\n\nexport const steps = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => ({\n get: get({ prisma }),\n})\n","import { PrismaClient } from '@prisma/client'\nimport dayjs from 'dayjs'\n\nexport const updateRun = async ({\n prisma,\n runId,\n threadId,\n onThreadRunStepCompleted = () => {},\n tool_outputs,\n}: {\n prisma: PrismaClient\n runId: string\n threadId: string\n onThreadRunStepCompleted?: ({ runStep }: { runStep: any }) => void\n tool_outputs: any\n}) => (\n prisma.$transaction(async (prisma: PrismaClient) => {\n const runSteps = await prisma.runStep.findMany({\n where: {\n threadId,\n runId,\n type: 'TOOL_CALLS',\n status: 'IN_PROGRESS',\n },\n orderBy: {\n createdAt: 'asc',\n },\n })\n\n for (const runStep of runSteps) {\n const completedRunStep = await prisma.runStep.update({\n where: {\n id: runStep.id,\n },\n data: {\n status: 'COMPLETED',\n completedAt: dayjs().unix(),\n stepDetails: {\n type: 'tool_calls',\n // @ts-ignore-next-line\n tool_calls: runStep.stepDetails!.tool_calls.map((toolCall) => {\n // @ts-ignore-next-line\n const toolOutput = tool_outputs.find((output) => output.tool_call_id === toolCall.id) || tool_outputs[0]\n\n if (!toolOutput) {\n console.dir({ toolOutput, runStep, tool_outputs, runSteps }, { depth: null })\n throw new Error('Tool output not found')\n }\n\n return {\n id: toolCall.id,\n type: toolCall.type,\n function: {\n ...toolCall.function,\n output: toolOutput.output,\n },\n }\n }),\n },\n },\n })\n\n onThreadRunStepCompleted({\n runStep: completedRunStep,\n })\n }\n\n return prisma.run.update({\n where: {\n id: runId,\n },\n data: {\n status: 'QUEUED',\n },\n })\n })\n)\n","import type { PrismaClient } from '@prisma/client'\nimport { submitToolOutputsRegexp } from '@/lib/runs/submitToolOutputsRegexp'\nimport { RunAdapterPartobClient } from '@/types'\nimport { serializeRun } from '../../serializeRun'\nimport { onEvent } from '../../onEvent'\nimport { getMessages } from '../../getMessages'\nimport { serializeRunStep } from '../../steps/serializeRunStep'\nimport { updateRun } from './updateRun'\n\nexport const post = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapterPartobClient\n}) => async (urlString: string, options: any) => {\n const url = new URL(urlString)\n const [, threadId, runId] = url.pathname.match(new RegExp(submitToolOutputsRegexp))!\n\n const body = JSON.parse(options.body)\n\n const {\n tool_outputs,\n stream,\n } = body\n\n if (stream) {\n const readableStream = new ReadableStream({\n async start(controller) {\n const run = await updateRun({\n prisma,\n runId,\n threadId,\n tool_outputs,\n onThreadRunStepCompleted: async ({ runStep }) => {\n controller.enqueue(`data: ${JSON.stringify({\n event: 'thread.run.step.completed',\n data: serializeRunStep({ runStep }),\n })}\\n\\n`)\n }\n })\n\n await runAdapter({\n run: serializeRun({ run }),\n onEvent: onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\\n\\n`)\n },\n },\n prisma,\n }),\n getMessages: getMessages({ prisma, run }),\n })\n\n controller.close()\n },\n })\n\n return new Response(readableStream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n },\n })\n } else {\n const run = await updateRun({\n prisma,\n runId,\n threadId,\n tool_outputs,\n })\n\n await new Promise((resolve) => (\n new ReadableStream({\n async start(controller) {\n await runAdapter({\n run: serializeRun({ run }),\n onEvent: onEvent({\n controller: {\n ...controller,\n enqueue: (data) => {\n controller.enqueue(`data: ${JSON.stringify(data)}\\n\\n`)\n },\n },\n prisma,\n }),\n getMessages: getMessages({ prisma, run }),\n })\n\n controller.close()\n resolve(void 0)\n },\n })\n ))\n\n return new Response(JSON.stringify(\n run\n ), {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n },\n })\n }\n}\n","import type { PrismaClient } from '@prisma/client'\nimport type { RunAdapter } from '@/types'\nimport { post } from './post'\n\nexport const submitToolOutputs = ({\n prisma,\n runAdapter,\n}: {\n prisma: PrismaClient\n runAdapter: RunAdapter\n}) => ({\n post: post({\n prisma,\n // @ts-ignore-next-line\n runAdapter,\n }),\n})\n","import type { PrismaClient } from '@prisma/client'\nimport { StorageAdapterArgs } from '@/types'\nimport { messagesRegexp } from '@/lib/messages/messagesRegexp'\nimport { runsRegexp } from '@/lib/runs/runsRegexp'\nimport { runRegexp } from '@/lib/runs/runRegexp'\nimport { submitToolOutputsRegexp } from '@/lib/runs/submitToolOutputsRegexp'\nimport { stepsRegexp } from '@/lib/steps/stepsRegexp'\nimport { threads } from './threads'\nimport { messages } from './threads/messages'\nimport { runs } from './threads/runs'\nimport { run } from './threads/run'\nimport { steps } from './threads/runs/steps'\nimport { submitToolOutputs } from './threads/runs/submitToolOutputs'\n\nexport const prismaStorageAdapter = ({\n prisma,\n}: {\n prisma: PrismaClient\n}) => ({\n runAdapter,\n}: StorageAdapterArgs) => ({\n requestHandlers: {\n '^/(?:v1|/?openai)/threads$': threads({ prisma }),\n [messagesRegexp]: messages({ prisma }),\n [runsRegexp]: runs({ prisma, runAdapter }),\n [runRegexp]: run({ prisma, runAdapter }),\n [stepsRegexp]: steps({ prisma }),\n [submitToolOutputsRegexp]: submitToolOutputs({ prisma, runAdapter }),\n },\n})\n"]}
|