supercompat 2.9.0 → 2.10.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.
@@ -1 +1 @@
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/serializeChunk.ts","../src/adapters/client/mistralClientAdapter/completions/serializeBody.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","serializeDelta","delta","toolCalls","rest","tool_calls","serializeChoice","choice","finishReason","finish_reason","serializeChunk","choices","map","serializeMessage","message","tool_call_id","toolCallId","serializeBody","messages","mistral","serializedBody","serializedChunk","complete","agentSideRoles","alternatingMessages","forEach","index","push","nextMessage","role","content","includes","perplexity","nonEmptyMessages","import_radash2","isEmpty","firstUserMessages","firstMessage","serializeTools","tools","tool","function","description","input_schema","parameters","text","toolCall","id","input","arguments","tool_use_id","serializeMessages","anthropic","systemMessages","otherMessages","system","chatMessages","resultOptions","import_radash3","fork","join","omit","max_tokens","messageDelta","partial_json","uid","object","content_block","import_lodash","import_dayjs","serializeToolCall","output","serializeMessageWithContent","serializeContent","metadata","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","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/serializeChunk.ts\nvar serializeDelta = ({\n delta: {\n toolCalls,\n ...rest\n }\n}) => ({\n ...rest,\n ...toolCalls ? {\n tool_calls: toolCalls\n } : {}\n});\nvar serializeChoice = ({\n choice: {\n finishReason,\n delta,\n ...rest\n }\n}) => ({\n ...rest,\n finish_reason: finishReason ?? null,\n delta: serializeDelta({ delta })\n});\nvar serializeChunk = ({\n chunk\n}) => ({\n ...chunk.data,\n ...chunk.data.choices ? {\n choices: chunk.data.choices.map((choice) => serializeChoice({ choice }))\n } : {}\n});\n\n// src/adapters/client/mistralClientAdapter/completions/serializeBody.ts\nvar serializeMessage = ({\n message: {\n // @ts-ignore-next-line\n tool_calls,\n // @ts-ignore-next-line\n tool_call_id,\n ...rest\n }\n}) => ({\n ...rest,\n ...tool_call_id ? {\n toolCallId: tool_call_id\n } : {},\n ...tool_calls ? {\n toolCalls: tool_calls\n } : {}\n});\nvar serializeBody = ({\n body\n}) => ({\n ...body,\n messages: body.messages.map((message) => serializeMessage({\n message\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 const serializedBody = serializeBody({\n body\n });\n if (body.stream) {\n const response = await mistral.chat.stream(serializedBody);\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n const serializedChunk = serializeChunk({\n chunk\n });\n controller.enqueue(`data: ${JSON.stringify(serializedChunk)}\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(serializedBody);\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 serializeMessage2 = ({\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) => serializeMessage2({\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 serializeMessage3 = ({\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) => serializeMessage3({ 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 choices = chunk.choices ?? [];\n const choice = 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 serializeMessage4 = ({\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 serializeMessage4({ 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) => serializeMessage4({ 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 = serializeMessage4({ 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 ...serializeMessage4({ 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","const serializeDelta = ({\n delta: {\n toolCalls,\n ...rest\n },\n}: {\n delta: any\n}) => ({\n ...rest,\n ...(toolCalls ? {\n tool_calls: toolCalls,\n } : {}),\n})\n\nconst serializeChoice = ({\n choice: {\n finishReason,\n delta,\n ...rest\n },\n}: {\n choice: any\n}) => ({\n ...rest,\n finish_reason: finishReason ?? null,\n delta: serializeDelta({ delta }),\n})\n\nexport const serializeChunk = ({\n chunk,\n}: {\n chunk: any\n}) => ({\n ...chunk.data,\n ...(chunk.data.choices ? {\n choices: chunk.data.choices.map((choice: any) => (\n serializeChoice({ choice })\n )),\n }: {}),\n})\n","import type OpenAI from 'openai'\n\nconst serializeMessage = ({\n message: {\n // @ts-ignore-next-line\n tool_calls,\n // @ts-ignore-next-line\n tool_call_id,\n ...rest\n },\n}: {\n message: OpenAI.ChatCompletionMessageParam\n}) => ({\n ...rest,\n ...(tool_call_id ? {\n toolCallId: tool_call_id,\n } : {}),\n ...(tool_calls ? {\n toolCalls: tool_calls,\n } : {}),\n})\n\nexport const serializeBody = ({\n body,\n}: {\n body: any\n}) => ({\n ...body,\n messages: body.messages.map((message: OpenAI.ChatCompletionMessageParam) => (\n serializeMessage({\n message,\n })\n )),\n})\n","import type { Mistral } from '@mistralai/mistralai'\nimport { serializeChunk } from './serializeChunk'\nimport { serializeBody } from './serializeBody'\n\nexport const post = ({\n mistral,\n}: {\n mistral: Mistral\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n const serializedBody = serializeBody({\n body,\n })\n\n if (body.stream) {\n const response = await mistral.chat.stream(serializedBody)\n\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n const serializedChunk = serializeChunk({\n chunk,\n })\n\n controller.enqueue(`data: ${JSON.stringify(serializedChunk)}\\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(serializedBody)\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 choices = chunk.choices ?? []\n const choice = 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/models/get.ts","../src/adapters/client/groqClientAdapter/models/index.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/serializeChunk.ts","../src/adapters/client/mistralClientAdapter/completions/serializeBody.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","groq","_url","_options","data","error","models","list","Response","JSON","stringify","status","post","body","response","stream","parse","chat","completions","ReadableStream","start","controller","chunk","enqueue","close","openai","console","dir","depth","azureOpenai","serializeDelta","delta","toolCalls","rest","tool_calls","serializeChoice","choice","finishReason","finish_reason","serializeChunk","choices","map","serializeMessage","message","tool_call_id","toolCallId","serializeBody","messages","mistral","serializedBody","serializedChunk","complete","agentSideRoles","alternatingMessages","forEach","index","push","nextMessage","role","content","includes","perplexity","nonEmptyMessages","import_radash2","isEmpty","firstUserMessages","firstMessage","serializeTools","tools","tool","function","description","input_schema","parameters","text","toolCall","id","input","arguments","tool_use_id","serializeMessages","anthropic","systemMessages","otherMessages","system","chatMessages","resultOptions","import_radash3","fork","join","omit","max_tokens","messageDelta","partial_json","uid","object","content_block","import_lodash","import_dayjs","serializeToolCall","output","serializeMessageWithContent","serializeContent","metadata","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","event","model","response_format","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","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/models/get.ts\nvar get = ({\n groq\n}) => async (_url, _options) => {\n try {\n const data = await groq.models.list();\n return new Response(JSON.stringify(data), {\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// src/adapters/client/groqClientAdapter/models/index.ts\nvar models = ({\n groq\n}) => ({\n get: get({ groq })\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/models$\": models({ groq }),\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 console.dir({ response }, { depth: null });\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 console.dir({ data }, { depth: null });\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/serializeChunk.ts\nvar serializeDelta = ({\n delta: {\n toolCalls,\n ...rest\n }\n}) => ({\n ...rest,\n ...toolCalls ? {\n tool_calls: toolCalls\n } : {}\n});\nvar serializeChoice = ({\n choice: {\n finishReason,\n delta,\n ...rest\n }\n}) => ({\n ...rest,\n finish_reason: finishReason ?? null,\n delta: serializeDelta({ delta })\n});\nvar serializeChunk = ({\n chunk\n}) => ({\n ...chunk.data,\n ...chunk.data.choices ? {\n choices: chunk.data.choices.map((choice) => serializeChoice({ choice }))\n } : {}\n});\n\n// src/adapters/client/mistralClientAdapter/completions/serializeBody.ts\nvar serializeMessage = ({\n message: {\n // @ts-ignore-next-line\n tool_calls,\n // @ts-ignore-next-line\n tool_call_id,\n ...rest\n }\n}) => ({\n ...rest,\n ...tool_call_id ? {\n toolCallId: tool_call_id\n } : {},\n ...tool_calls ? {\n toolCalls: tool_calls\n } : {}\n});\nvar serializeBody = ({\n body\n}) => ({\n ...body,\n messages: body.messages.map((message) => serializeMessage({\n message\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 const serializedBody = serializeBody({\n body\n });\n if (body.stream) {\n const response = await mistral.chat.stream(serializedBody);\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n const serializedChunk = serializeChunk({\n chunk\n });\n controller.enqueue(`data: ${JSON.stringify(serializedChunk)}\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(serializedBody);\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 serializeMessage2 = ({\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) => serializeMessage2({\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 serializeMessage3 = ({\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) => serializeMessage3({ 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 choices = chunk.choices ?? [];\n const choice = 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 serializeMessage4 = ({\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 serializeMessage4({ 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 get2 = ({\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) => serializeMessage4({ 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: get2({ 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 get3 = ({\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 = serializeMessage4({ 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 ...serializeMessage4({ 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: get3({ prisma }),\n post: post8({ prisma, runAdapter })\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/run/get.ts\nvar get4 = ({\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: get4({ prisma })\n // post: post({ prisma, runAdapter }),\n});\n\n// src/adapters/storage/prismaStorageAdapter/threads/runs/steps/get.ts\nvar import_radash10 = require(\"radash\");\nvar get5 = ({\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: get5({ 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 get = ({\n groq,\n}: {\n groq: Groq\n}) => async (_url: string, _options: any) => {\n try {\n const data = await groq.models.list()\n\n return new Response(JSON.stringify(data), {\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","import type Groq from 'groq-sdk'\nimport { get } from './get'\n\nexport const models = ({\n groq,\n}: {\n groq: Groq\n}) => ({\n get: get({ groq }),\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 { models } from './models'\nimport { completions } from './completions'\n\nexport const groqClientAdapter = ({\n groq,\n}: {\n // TODO\n groq: any\n}) => ({\n client: groq,\n requestHandlers: {\n '^/v1/models$': models({ groq }),\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 console.dir({ response }, { depth: null })\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 console.dir({ data }, { depth: null })\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","const serializeDelta = ({\n delta: {\n toolCalls,\n ...rest\n },\n}: {\n delta: any\n}) => ({\n ...rest,\n ...(toolCalls ? {\n tool_calls: toolCalls,\n } : {}),\n})\n\nconst serializeChoice = ({\n choice: {\n finishReason,\n delta,\n ...rest\n },\n}: {\n choice: any\n}) => ({\n ...rest,\n finish_reason: finishReason ?? null,\n delta: serializeDelta({ delta }),\n})\n\nexport const serializeChunk = ({\n chunk,\n}: {\n chunk: any\n}) => ({\n ...chunk.data,\n ...(chunk.data.choices ? {\n choices: chunk.data.choices.map((choice: any) => (\n serializeChoice({ choice })\n )),\n }: {}),\n})\n","import type OpenAI from 'openai'\n\nconst serializeMessage = ({\n message: {\n // @ts-ignore-next-line\n tool_calls,\n // @ts-ignore-next-line\n tool_call_id,\n ...rest\n },\n}: {\n message: OpenAI.ChatCompletionMessageParam\n}) => ({\n ...rest,\n ...(tool_call_id ? {\n toolCallId: tool_call_id,\n } : {}),\n ...(tool_calls ? {\n toolCalls: tool_calls,\n } : {}),\n})\n\nexport const serializeBody = ({\n body,\n}: {\n body: any\n}) => ({\n ...body,\n messages: body.messages.map((message: OpenAI.ChatCompletionMessageParam) => (\n serializeMessage({\n message,\n })\n )),\n})\n","import type { Mistral } from '@mistralai/mistralai'\nimport { serializeChunk } from './serializeChunk'\nimport { serializeBody } from './serializeBody'\n\nexport const post = ({\n mistral,\n}: {\n mistral: Mistral\n}) => async (_url: string, options: any) => {\n const body = JSON.parse(options.body)\n const serializedBody = serializeBody({\n body,\n })\n\n if (body.stream) {\n const response = await mistral.chat.stream(serializedBody)\n\n const stream = new ReadableStream({\n async start(controller) {\n for await (const chunk of response) {\n const serializedChunk = serializeChunk({\n chunk,\n })\n\n controller.enqueue(`data: ${JSON.stringify(serializedChunk)}\\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(serializedBody)\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 choices = chunk.choices ?? []\n const choice = 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"]}