experimental-agent 0.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.mjs ADDED
@@ -0,0 +1,421 @@
1
+ import "./chunk-36X6L7SK.mjs";
2
+ import {
3
+ getSandbox
4
+ } from "./chunk-JQPR6M7D.mjs";
5
+ import {
6
+ agentMessageHook,
7
+ agentWorkflow,
8
+ assembleUIMessages,
9
+ normalizeSkillsDirs
10
+ } from "./chunk-MR4UWCJT.mjs";
11
+ import {
12
+ handleStorageRpc
13
+ } from "./chunk-2YI7MQGZ.mjs";
14
+ import {
15
+ MessageNotFoundError,
16
+ SandboxError,
17
+ SandboxNotFoundError,
18
+ SessionError,
19
+ SessionNotFoundError,
20
+ StorageError,
21
+ getStorage
22
+ } from "./chunk-DPPQO7DA.mjs";
23
+
24
+ // src/client.ts
25
+ import { all } from "better-all";
26
+ import * as errore from "errore";
27
+ import equal from "fast-deep-equal";
28
+ import { ulid } from "ulid";
29
+ import { getRun, start } from "workflow/api";
30
+
31
+ // src/mcp/index.ts
32
+ import { z } from "zod";
33
+ function serializeMcpConfig(mcp2) {
34
+ return Object.entries(mcp2).map(([name, server]) => ({
35
+ name,
36
+ url: server.url,
37
+ description: server.description,
38
+ tools: Object.entries(server.tools).map(([toolName, tool]) => ({
39
+ name: toolName,
40
+ description: tool.description,
41
+ inputSchema: z.toJSONSchema(tool.inputSchema),
42
+ outputSchema: tool.outputSchema ? z.toJSONSchema(tool.outputSchema) : void 0
43
+ }))
44
+ }));
45
+ }
46
+ function mcp(opts) {
47
+ return opts;
48
+ }
49
+
50
+ // src/utils/message.ts
51
+ function toMessageAndParts({
52
+ sessionId,
53
+ id,
54
+ input,
55
+ generateId,
56
+ defaultRole
57
+ }) {
58
+ const messageId = id ?? generateId("message");
59
+ if (typeof input === "string") {
60
+ return {
61
+ message: {
62
+ id: messageId,
63
+ sessionId,
64
+ role: defaultRole,
65
+ createdAt: Date.now(),
66
+ completedAt: Date.now(),
67
+ mcpContext: null
68
+ },
69
+ parts: [
70
+ {
71
+ sessionId,
72
+ messageId,
73
+ id: generateId("part"),
74
+ index: 0,
75
+ part: { type: "text", text: input }
76
+ }
77
+ ]
78
+ };
79
+ }
80
+ return {
81
+ message: {
82
+ sessionId,
83
+ id: messageId,
84
+ createdAt: Date.now(),
85
+ completedAt: Date.now(),
86
+ mcpContext: null,
87
+ role: input.role ?? defaultRole
88
+ },
89
+ parts: input.parts.map((part, index) => ({
90
+ sessionId,
91
+ messageId,
92
+ id: generateId("part"),
93
+ index,
94
+ part
95
+ }))
96
+ };
97
+ }
98
+
99
+ // src/client.ts
100
+ var agent = (options) => {
101
+ const storageConfig = options.storage ?? { type: "vercel" };
102
+ const storage = getStorage(storageConfig);
103
+ const generateId = options.generateId ?? ((resource) => `${resource}_${ulid()}`);
104
+ const sandbox = async (sandboxId, config) => {
105
+ const existingRecord = await storage.sandbox.get(sandboxId);
106
+ if (existingRecord instanceof Error) {
107
+ if (!(existingRecord instanceof SandboxNotFoundError)) {
108
+ throw existingRecord;
109
+ }
110
+ const sandboxRecord = await storage.sandbox.set({
111
+ id: sandboxId,
112
+ acquiringLockAt: null,
113
+ acquiringLockId: null,
114
+ createdAt: Date.now(),
115
+ lastActivityAt: Date.now(),
116
+ config: config ?? { type: "vercel" }
117
+ });
118
+ if (sandboxRecord instanceof Error) {
119
+ throw sandboxRecord;
120
+ }
121
+ return getSandbox({ storageConfig, sandboxRecord });
122
+ }
123
+ const newConfig = config ?? existingRecord.config;
124
+ if (!equal(existingRecord.config, newConfig)) {
125
+ throw new SandboxError({
126
+ reason: "sandbox config changes are not supported"
127
+ });
128
+ }
129
+ return getSandbox({ storageConfig, sandboxRecord: existingRecord });
130
+ };
131
+ return {
132
+ session: async (sessionId, sessionOptions) => {
133
+ let session = await storage.session.get(sessionId);
134
+ const sandboxInput = sessionOptions?.sandbox ?? options.sandbox;
135
+ const sandboxId = typeof sandboxInput === "string" ? sandboxInput : (
136
+ // biome-ignore lint/style/noNestedTernary: ok
137
+ session instanceof Error ? generateId("sandbox") : session.sandboxId ?? generateId("sandbox")
138
+ );
139
+ const sandboxPromise = sandbox(
140
+ sandboxId,
141
+ typeof sandboxInput === "string" ? void 0 : sandboxInput
142
+ );
143
+ const mcpConfig = options.mcp || sessionOptions?.mcp ? { ...options.mcp, ...sessionOptions?.mcp } : null;
144
+ const skillsDir = sessionOptions?.skillsDir ?? options.skillsDir ?? null;
145
+ if (session instanceof Error) {
146
+ if (session instanceof SessionNotFoundError) {
147
+ const instructions = sessionOptions?.instructions ?? options.instructions ?? null;
148
+ const model = sessionOptions?.model ?? options.model ?? null;
149
+ if (!model) {
150
+ throw new SessionError({
151
+ id: sessionId,
152
+ reason: "Model is not set"
153
+ });
154
+ }
155
+ session = await storage.session.set({
156
+ id: sessionId,
157
+ createdAt: Date.now(),
158
+ updatedAt: Date.now(),
159
+ lastMessageId: null,
160
+ runId: null,
161
+ tags: sessionOptions?.tags ?? null,
162
+ instructions,
163
+ model,
164
+ mcp: mcpConfig ? serializeMcpConfig(mcpConfig) : null,
165
+ sandboxId,
166
+ skillsDir: skillsDir ? normalizeSkillsDirs(skillsDir) : null,
167
+ hookToken: null
168
+ });
169
+ } else {
170
+ throw session;
171
+ }
172
+ } else {
173
+ const updated = {
174
+ ...session,
175
+ ...sessionOptions,
176
+ mcp: mcpConfig ? serializeMcpConfig(mcpConfig) : session.mcp,
177
+ sandboxId,
178
+ skillsDir: skillsDir ? normalizeSkillsDirs(skillsDir) : null
179
+ };
180
+ if (!equal(updated, session)) {
181
+ session = await storage.session.set(updated);
182
+ if (session instanceof Error) {
183
+ throw session;
184
+ }
185
+ }
186
+ }
187
+ return {
188
+ send: async ({
189
+ input,
190
+ mcpContext
191
+ }) => {
192
+ const newMessages = [];
193
+ const newParts = [];
194
+ if (Array.isArray(input)) {
195
+ for (const i of input) {
196
+ const { message, parts } = toMessageAndParts({
197
+ sessionId,
198
+ input: i,
199
+ defaultRole: "user",
200
+ generateId: () => generateId("message")
201
+ });
202
+ newMessages.push(message);
203
+ newParts.push(...parts);
204
+ }
205
+ } else {
206
+ const { message, parts } = toMessageAndParts({
207
+ sessionId,
208
+ input,
209
+ defaultRole: "user",
210
+ generateId: () => generateId("message")
211
+ });
212
+ newMessages.push(message);
213
+ newParts.push(...parts);
214
+ }
215
+ const assistantMessageId = generateId("message");
216
+ newMessages.push({
217
+ id: assistantMessageId,
218
+ sessionId,
219
+ role: "assistant",
220
+ createdAt: Date.now(),
221
+ completedAt: null,
222
+ mcpContext
223
+ });
224
+ const now = Date.now();
225
+ const session2 = await storage.session.get(sessionId);
226
+ if (session2 instanceof Error) {
227
+ throw session2;
228
+ }
229
+ const agentInput = {
230
+ storageConfig,
231
+ sessionId
232
+ };
233
+ const event = {
234
+ assistantMessageId,
235
+ hookToken: crypto.randomUUID()
236
+ };
237
+ return await errore.tryAsync({
238
+ try: async () => {
239
+ await all({
240
+ async saveMessages() {
241
+ await Promise.all(newMessages.map(storage.message.set));
242
+ },
243
+ async saveParts() {
244
+ await Promise.all(newParts.map(storage.part.set));
245
+ },
246
+ async resumeOrStartAgentWorkflow() {
247
+ if (session2.runId) {
248
+ await agentMessageHook.resume(sessionId, event);
249
+ } else {
250
+ const startResult = await start(agentWorkflow, [
251
+ { input: agentInput, event }
252
+ ]);
253
+ session2.runId = startResult.runId;
254
+ }
255
+ },
256
+ async updateSession() {
257
+ await this.$.resumeOrStartAgentWorkflow;
258
+ const result = await storage.session.set({
259
+ ...session2,
260
+ updatedAt: now,
261
+ lastMessageId: assistantMessageId,
262
+ hookToken: event.hookToken
263
+ });
264
+ if (result instanceof Error) {
265
+ throw result;
266
+ }
267
+ return result;
268
+ }
269
+ });
270
+ },
271
+ catch: (e) => {
272
+ if (e instanceof Error) {
273
+ throw e;
274
+ }
275
+ return new SessionError({
276
+ id: sessionId,
277
+ reason: `failed to send: ${String(e)}`,
278
+ cause: e
279
+ });
280
+ }
281
+ });
282
+ },
283
+ stream: async (opts) => {
284
+ const session2 = await storage.session.get(sessionId);
285
+ if (session2 instanceof Error) {
286
+ return session2;
287
+ }
288
+ const messageId = opts?.messageId ?? session2.lastMessageId;
289
+ if (!messageId) {
290
+ return new SessionError({
291
+ id: sessionId,
292
+ reason: "No message associated with session"
293
+ });
294
+ }
295
+ if (!session2.runId) {
296
+ return new SessionError({
297
+ id: sessionId,
298
+ reason: "No run associated with session"
299
+ });
300
+ }
301
+ const run = getRun(session2.runId);
302
+ return run.getReadable({ namespace: messageId });
303
+ },
304
+ ui: async () => {
305
+ const [messagesResult, partsResult] = await Promise.all([
306
+ storage.message.list(sessionId),
307
+ storage.part.listBySession(sessionId)
308
+ ]);
309
+ if (messagesResult instanceof Error) {
310
+ return messagesResult;
311
+ }
312
+ if (partsResult instanceof Error) {
313
+ return partsResult;
314
+ }
315
+ const messages = assembleUIMessages({
316
+ messages: messagesResult.items,
317
+ parts: partsResult.items
318
+ });
319
+ const lastMessage = messagesResult.items.at(-1);
320
+ const isStreaming = lastMessage?.role === "assistant" && lastMessage.completedAt === null;
321
+ const streamingMessageId = isStreaming ? lastMessage.id : null;
322
+ return { messages, streamingMessageId };
323
+ },
324
+ tag: {
325
+ list: async () => {
326
+ const session2 = await storage.session.get(sessionId);
327
+ if (session2 instanceof Error) {
328
+ return session2;
329
+ }
330
+ return session2.tags ?? {};
331
+ },
332
+ get: async (key) => {
333
+ const session2 = await storage.session.get(sessionId);
334
+ if (session2 instanceof Error) {
335
+ return session2;
336
+ }
337
+ return session2.tags?.[key];
338
+ },
339
+ set: async (key, value) => {
340
+ const result = await storage.session.tag.set({
341
+ sessionId,
342
+ tags: { [key]: value }
343
+ });
344
+ if (result instanceof Error) {
345
+ return result;
346
+ }
347
+ return void 0;
348
+ },
349
+ setMany: async (tags) => {
350
+ const result = await storage.session.tag.set({
351
+ sessionId,
352
+ tags
353
+ });
354
+ if (result instanceof Error) {
355
+ return result;
356
+ }
357
+ return void 0;
358
+ }
359
+ },
360
+ sandbox: await sandboxPromise
361
+ };
362
+ },
363
+ sandbox,
364
+ storage,
365
+ handleMcpToolCall: async (body, handlers) => {
366
+ const { server, tool, input, sessionId, messageId, hookToken } = body;
367
+ const handlerKey = `${server}/${tool}`;
368
+ const handler = handlers[handlerKey];
369
+ if (!handler) {
370
+ return {
371
+ error: {
372
+ code: "HANDLER_NOT_FOUND",
373
+ message: `No handler for ${handlerKey}`
374
+ }
375
+ };
376
+ }
377
+ const session = await storage.session.get(sessionId);
378
+ if (session instanceof Error) {
379
+ return {
380
+ error: { code: "SESSION_NOT_FOUND", message: "Session not found" }
381
+ };
382
+ }
383
+ if (!session.hookToken || session.hookToken !== hookToken) {
384
+ return {
385
+ error: { code: "INVALID_TOKEN", message: "Invalid hook token" }
386
+ };
387
+ }
388
+ const message = await storage.message.get(messageId);
389
+ if (message instanceof Error) {
390
+ return {
391
+ error: { code: "MESSAGE_NOT_FOUND", message: "Message not found" }
392
+ };
393
+ }
394
+ const mcpContext = message.mcpContext;
395
+ const serverContext = mcpContext?.[server];
396
+ const headers = serverContext?.headers ?? {};
397
+ try {
398
+ const result = await handler({ input, headers, body });
399
+ return { result };
400
+ } catch (e) {
401
+ return {
402
+ error: {
403
+ code: "EXECUTION_ERROR",
404
+ message: e instanceof Error ? e.message : String(e)
405
+ }
406
+ };
407
+ }
408
+ }
409
+ };
410
+ };
411
+ export {
412
+ MessageNotFoundError,
413
+ SandboxError,
414
+ SandboxNotFoundError,
415
+ SessionNotFoundError,
416
+ StorageError,
417
+ agent,
418
+ handleStorageRpc,
419
+ mcp
420
+ };
421
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/client.ts", "../src/mcp/index.ts", "../src/utils/message.ts"],
  "sourcesContent": ["import type { GatewayModelId, UIMessage } from \"ai\";\nimport { all } from \"better-all\";\nimport * as errore from \"errore\";\nimport equal from \"fast-deep-equal\";\nimport { ulid } from \"ulid\";\nimport { getRun, start } from \"workflow/api\";\nimport {\n  type AgentInput,\n  type AgentMessageInput,\n  agentMessageHook,\n  agentWorkflow,\n} from \"./agent-workflow\";\nimport {\n  SandboxError,\n  SandboxNotFoundError,\n  SessionError,\n  SessionNotFoundError,\n} from \"./errors\";\nimport { type McpConfig, type McpSendOptions, serializeMcpConfig } from \"./mcp\";\nimport { getSandbox } from \"./sandbox\";\nimport { normalizeSkillsDirs } from \"./skills/parser\";\nimport type { SkillsDir } from \"./skills/types\";\nimport {\n  getStorage,\n  type Message,\n  type Part,\n  type Session,\n  type StorageConfig,\n} from \"./storage\";\nimport type { SandboxConfig } from \"./storage/rpc\";\nimport { toMessageAndParts } from \"./utils/message\";\nimport { assembleUIMessages } from \"./utils/ui\";\n\nexport type SendInput =\n  | string\n  | { role?: UIMessage[\"role\"]; parts: UIMessage[\"parts\"]; id?: string };\n\ntype SessionOptions<\n  // biome-ignore lint/complexity/noBannedTypes: needed for generic default\n  TMcp extends McpConfig = {},\n  TTags extends TagsSchema = TagsSchema\n> = {\n  model?: GatewayModelId;\n  instructions?: string;\n  sandbox?: SandboxConfig | string;\n  tags?: TTags;\n  skillsDir?: SkillsDir;\n  mcp?: TMcp;\n};\n\nexport type McpToolCallBody = {\n  server: string;\n  tool: string;\n  input: unknown;\n  sessionId: string;\n  messageId: string;\n  hookToken: string;\n};\n\n// biome-ignore lint/complexity/noBannedTypes: needed for generic default\nexport type AgentOptions<TMcp extends McpConfig = {}> = {\n  storage?: StorageConfig;\n  generateId?: (\n    resource: \"session\" | \"message\" | \"part\" | \"sandbox\" | \"command\"\n  ) => string;\n} & SessionOptions<TMcp>;\n\nexport type TagsSchema = Record<string, unknown>;\n\n// biome-ignore lint/complexity/noBannedTypes: needed for generic default\nexport const agent = <TMcp extends McpConfig = {}>(\n  options: AgentOptions<TMcp>\n) => {\n  const storageConfig = options.storage ?? { type: \"vercel\" };\n  const storage = getStorage(storageConfig);\n  const generateId =\n    options.generateId ?? ((resource) => `${resource}_${ulid()}`);\n\n  const sandbox = async (sandboxId: string, config?: SandboxConfig) => {\n    const existingRecord = await storage.sandbox.get(sandboxId);\n\n    if (existingRecord instanceof Error) {\n      if (!(existingRecord instanceof SandboxNotFoundError)) {\n        throw existingRecord;\n      }\n      const sandboxRecord = await storage.sandbox.set({\n        id: sandboxId,\n        acquiringLockAt: null,\n        acquiringLockId: null,\n        createdAt: Date.now(),\n        lastActivityAt: Date.now(),\n        config: config ?? { type: \"vercel\" },\n      });\n      if (sandboxRecord instanceof Error) {\n        throw sandboxRecord;\n      }\n      return getSandbox({ storageConfig, sandboxRecord });\n    }\n\n    const newConfig = config ?? existingRecord.config;\n    if (!equal(existingRecord.config, newConfig)) {\n      throw new SandboxError({\n        reason: \"sandbox config changes are not supported\",\n      });\n    }\n\n    return getSandbox({ storageConfig, sandboxRecord: existingRecord });\n  };\n\n  return {\n    session: async <\n      TTags extends TagsSchema = TagsSchema,\n      // biome-ignore lint/complexity/noBannedTypes: needed for generic default\n      TMcpOverride extends McpConfig = {}\n    >(\n      sessionId: string,\n      sessionOptions?: SessionOptions<TMcp & TMcpOverride, TTags>\n    ) => {\n      let session = await storage.session.get(sessionId);\n\n      /**\n       * normalize sandbox input to a sandbox ID and config\n       */\n      const sandboxInput = sessionOptions?.sandbox ?? options.sandbox;\n      const sandboxId =\n        typeof sandboxInput === \"string\"\n          ? sandboxInput\n          : // biome-ignore lint/style/noNestedTernary: ok\n          session instanceof Error\n          ? generateId(\"sandbox\")\n          : session.sandboxId ?? generateId(\"sandbox\");\n      const sandboxPromise = sandbox(\n        sandboxId,\n        typeof sandboxInput === \"string\" ? undefined : sandboxInput\n      );\n\n      const mcpConfig =\n        options.mcp || sessionOptions?.mcp\n          ? { ...options.mcp, ...sessionOptions?.mcp }\n          : null;\n      const skillsDir = sessionOptions?.skillsDir ?? options.skillsDir ?? null;\n\n      if (session instanceof Error) {\n        if (session instanceof SessionNotFoundError) {\n          const instructions =\n            sessionOptions?.instructions ?? options.instructions ?? null;\n          const model = sessionOptions?.model ?? options.model ?? null;\n          if (!model) {\n            throw new SessionError({\n              id: sessionId,\n              reason: \"Model is not set\",\n            });\n          }\n          session = await storage.session.set({\n            id: sessionId,\n            createdAt: Date.now(),\n            updatedAt: Date.now(),\n            lastMessageId: null,\n            runId: null,\n            tags: sessionOptions?.tags ?? null,\n            instructions,\n            model,\n            mcp: mcpConfig ? serializeMcpConfig(mcpConfig) : null,\n            sandboxId,\n            skillsDir: skillsDir ? normalizeSkillsDirs(skillsDir) : null,\n            hookToken: null,\n          });\n        } else {\n          throw session;\n        }\n      } else {\n        /**\n         * this is an existing session. we compare the options and update the session if necessary.\n         */\n        const updated: Session = {\n          ...session,\n          ...sessionOptions,\n          mcp: mcpConfig ? serializeMcpConfig(mcpConfig) : session.mcp,\n          sandboxId,\n          skillsDir: skillsDir ? normalizeSkillsDirs(skillsDir) : null,\n        };\n        if (!equal(updated, session)) {\n          session = await storage.session.set(updated);\n          if (session instanceof Error) {\n            throw session;\n          }\n        }\n      }\n\n      return {\n        send: async ({\n          input,\n          mcpContext,\n        }: {\n          input: SendInput | SendInput[];\n          mcpContext?: McpSendOptions<TMcp & TMcpOverride>;\n        }) => {\n          const newMessages: Message[] = [];\n          const newParts: Part[] = [];\n          if (Array.isArray(input)) {\n            for (const i of input) {\n              const { message, parts } = toMessageAndParts({\n                sessionId,\n                input: i,\n                defaultRole: \"user\",\n                generateId: () => generateId(\"message\"),\n              });\n\n              newMessages.push(message);\n              newParts.push(...parts);\n            }\n          } else {\n            const { message, parts } = toMessageAndParts({\n              sessionId,\n              input,\n              defaultRole: \"user\",\n              generateId: () => generateId(\"message\"),\n            });\n            newMessages.push(message);\n            newParts.push(...parts);\n          }\n          /**\n           * we also pre-create the assistant message\n           */\n          const assistantMessageId = generateId(\"message\");\n          newMessages.push({\n            id: assistantMessageId,\n            sessionId,\n            role: \"assistant\",\n            createdAt: Date.now(),\n            completedAt: null,\n            mcpContext,\n          });\n\n          const now = Date.now();\n          const session2 = await storage.session.get(sessionId);\n          if (session2 instanceof Error) {\n            throw session2;\n          }\n\n          const agentInput: AgentInput = {\n            storageConfig,\n            sessionId,\n          };\n          const event: AgentMessageInput = {\n            assistantMessageId,\n            hookToken: crypto.randomUUID(),\n          };\n\n          return await errore.tryAsync({\n            try: async () => {\n              await all({\n                async saveMessages() {\n                  await Promise.all(newMessages.map(storage.message.set));\n                },\n                async saveParts() {\n                  await Promise.all(newParts.map(storage.part.set));\n                },\n                async resumeOrStartAgentWorkflow() {\n                  if (session2.runId) {\n                    await agentMessageHook.resume(sessionId, event);\n                  } else {\n                    const startResult = await start(agentWorkflow, [\n                      { input: agentInput, event },\n                    ]);\n                    session2.runId = startResult.runId;\n                  }\n                },\n                async updateSession() {\n                  await this.$.resumeOrStartAgentWorkflow;\n                  const result = await storage.session.set({\n                    ...session2,\n                    updatedAt: now,\n                    lastMessageId: assistantMessageId,\n                    hookToken: event.hookToken,\n                  });\n                  if (result instanceof Error) {\n                    throw result;\n                  }\n                  return result;\n                },\n              });\n            },\n            catch: (e) => {\n              if (e instanceof Error) {\n                throw e;\n              }\n              return new SessionError({\n                id: sessionId,\n                reason: `failed to send: ${String(e)}`,\n                cause: e,\n              });\n            },\n          });\n        },\n\n        stream: async (opts?: { messageId?: string }) => {\n          const session = await storage.session.get(sessionId);\n          if (session instanceof Error) {\n            return session;\n          }\n          const messageId = opts?.messageId ?? session.lastMessageId;\n          if (!messageId) {\n            return new SessionError({\n              id: sessionId,\n              reason: \"No message associated with session\",\n            });\n          }\n          if (!session.runId) {\n            return new SessionError({\n              id: sessionId,\n              reason: \"No run associated with session\",\n            });\n          }\n          const run = getRun(session.runId);\n          return run.getReadable({ namespace: messageId });\n        },\n\n        ui: async () => {\n          const [messagesResult, partsResult] = await Promise.all([\n            storage.message.list(sessionId),\n            storage.part.listBySession(sessionId),\n          ]);\n\n          if (messagesResult instanceof Error) {\n            return messagesResult;\n          }\n          if (partsResult instanceof Error) {\n            return partsResult;\n          }\n\n          const messages = assembleUIMessages({\n            messages: messagesResult.items,\n            parts: partsResult.items,\n          });\n\n          const lastMessage = messagesResult.items.at(-1);\n          const isStreaming =\n            lastMessage?.role === \"assistant\" &&\n            lastMessage.completedAt === null;\n          const streamingMessageId = isStreaming ? lastMessage.id : null;\n\n          return { messages, streamingMessageId };\n        },\n        tag: {\n          list: async () => {\n            const session = await storage.session.get(sessionId);\n            if (session instanceof Error) {\n              return session;\n            }\n            return (session.tags ?? {}) as TTags;\n          },\n          get: async (key: string) => {\n            const session = await storage.session.get(sessionId);\n            if (session instanceof Error) {\n              return session;\n            }\n            return session.tags?.[key as string] as\n              | TTags[typeof key]\n              | undefined;\n          },\n          set: async (key: string, value: unknown) => {\n            const result = await storage.session.tag.set({\n              sessionId,\n              tags: { [key]: value } as Record<string, unknown>,\n            });\n            if (result instanceof Error) {\n              return result;\n            }\n            return undefined;\n          },\n          setMany: async (tags: Record<string, unknown>) => {\n            const result = await storage.session.tag.set({\n              sessionId,\n              tags: tags as Record<string, unknown>,\n            });\n            if (result instanceof Error) {\n              return result;\n            }\n            return undefined;\n          },\n        },\n        sandbox: await sandboxPromise,\n      };\n    },\n    sandbox,\n    storage,\n    handleMcpToolCall: async (\n      body: McpToolCallBody,\n      handlers: Record<\n        string,\n        (opts: {\n          input: unknown;\n          headers: Record<string, string>;\n          body: McpToolCallBody;\n        }) => Promise<unknown>\n      >\n    ): Promise<\n      { result: unknown } | { error: { code: string; message: string } }\n    > => {\n      const { server, tool, input, sessionId, messageId, hookToken } = body;\n\n      const handlerKey = `${server}/${tool}`;\n      const handler = handlers[handlerKey];\n      if (!handler) {\n        return {\n          error: {\n            code: \"HANDLER_NOT_FOUND\",\n            message: `No handler for ${handlerKey}`,\n          },\n        };\n      }\n\n      const session = await storage.session.get(sessionId);\n      if (session instanceof Error) {\n        return {\n          error: { code: \"SESSION_NOT_FOUND\", message: \"Session not found\" },\n        };\n      }\n\n      if (!session.hookToken || session.hookToken !== hookToken) {\n        return {\n          error: { code: \"INVALID_TOKEN\", message: \"Invalid hook token\" },\n        };\n      }\n\n      const message = await storage.message.get(messageId);\n      if (message instanceof Error) {\n        return {\n          error: { code: \"MESSAGE_NOT_FOUND\", message: \"Message not found\" },\n        };\n      }\n\n      const mcpContext = message.mcpContext as McpSendOptions<TMcp> | undefined;\n      const serverContext = mcpContext?.[server as keyof typeof mcpContext];\n      const headers = (serverContext?.headers ?? {}) as Record<string, string>;\n\n      try {\n        const result = await handler({ input, headers, body });\n        return { result };\n      } catch (e) {\n        return {\n          error: {\n            code: \"EXECUTION_ERROR\",\n            message: e instanceof Error ? e.message : String(e),\n          },\n        };\n      }\n    },\n  };\n};\n", "import { z } from \"zod\";\n\nexport type McpToolDef = {\n  description: string;\n  inputSchema: z.ZodType;\n  outputSchema?: z.ZodType;\n};\n\nexport type McpServerDef<\n  TTools extends Record<string, McpToolDef> = Record<string, McpToolDef>,\n  THeaders extends z.ZodType = z.ZodType,\n> = {\n  url: string;\n  description?: string;\n  headersSchema?: THeaders;\n  tools: TTools;\n};\n\nexport type McpConfig = Record<string, McpServerDef>;\n\nexport function serializeMcpConfig(mcp: McpConfig): McpServerSchema[] {\n  return Object.entries(mcp).map(([name, server]) => ({\n    name,\n    url: server.url,\n    description: server.description,\n    tools: Object.entries(server.tools).map(([toolName, tool]) => ({\n      name: toolName,\n      description: tool.description,\n      inputSchema: z.toJSONSchema(tool.inputSchema),\n      outputSchema: tool.outputSchema\n        ? z.toJSONSchema(tool.outputSchema)\n        : undefined,\n    })),\n  }));\n}\n\nexport type McpToolSchema = {\n  name: string;\n  description: string;\n  inputSchema: unknown;\n  outputSchema?: unknown;\n};\n\nexport type McpServerSchema = {\n  name: string;\n  url: string;\n  description?: string;\n  tools: McpToolSchema[];\n};\n\ntype ExtractHeaders<T> =\n  T extends McpServerDef<infer _TTools, infer THeaders>\n    ? THeaders extends z.ZodType\n      ? z.infer<THeaders>\n      : Record<string, string>\n    : Record<string, string>;\n\ntype HasRequiredHeaders<T extends McpServerDef> = T extends {\n  headersSchema: z.ZodType;\n}\n  ? true\n  : false;\n\ntype ServerSendOptions<T extends McpServerDef> =\n  HasRequiredHeaders<T> extends true\n    ?\n        | { headers: ExtractHeaders<T>; disabled?: false }\n        | { disabled: true; headers?: ExtractHeaders<T> }\n    : { headers?: ExtractHeaders<T>; disabled?: boolean };\n\nexport type McpSendOptions<TMcp extends McpConfig> = {\n  [K in keyof TMcp]?: ServerSendOptions<TMcp[K]>;\n};\n\nexport type McpToolCallRequest = {\n  server: string;\n  tool: string;\n  input: unknown;\n  messageId: string;\n  mcpToken: string;\n};\n\nexport type McpToolCallSuccessResponse<T = unknown> = {\n  result: T;\n};\n\nexport type McpToolCallErrorResponse = {\n  error: { code: string; message: string };\n};\n\nexport type McpToolCallResponse<T = unknown> =\n  | McpToolCallSuccessResponse<T>\n  | McpToolCallErrorResponse;\n\ntype ExtractInput<T extends McpToolDef> = T extends { inputSchema: infer S }\n  ? S extends z.ZodType\n    ? z.infer<S>\n    : unknown\n  : unknown;\n\ntype HandlerForTool<\n  TServer extends McpServerDef,\n  TTool extends McpToolDef,\n> = (opts: {\n  input: ExtractInput<TTool>;\n  headers: ExtractHeaders<TServer>;\n}) => Promise<unknown>;\n\ntype BuildHandlers<TMcp extends McpConfig> = {\n  [K in keyof TMcp & string]: {\n    [T in keyof TMcp[K][\"tools\"] & string]: {\n      key: `${K}/${T}`;\n      handler: HandlerForTool<TMcp[K], TMcp[K][\"tools\"][T]>;\n    };\n  }[keyof TMcp[K][\"tools\"] & string];\n}[keyof TMcp & string];\n\ntype UnionToIntersection<U> = (\n  U extends unknown\n    ? (k: U) => void\n    : never\n) extends (k: infer I) => void\n  ? I\n  : never;\n\ntype HandlersFromUnion<U> = UnionToIntersection<\n  U extends { key: infer K; handler: infer H }\n    ? K extends string\n      ? { [P in K]: H }\n      : never\n    : never\n>;\n\nexport type McpToolCallHandlers<TMcp extends McpConfig> = HandlersFromUnion<\n  BuildHandlers<TMcp>\n>;\n\nexport function mcp<\n  THeaders extends z.ZodType,\n  TTools extends Record<string, McpToolDef>,\n>(opts: {\n  url: string;\n  description?: string;\n  headersSchema?: THeaders;\n  tools: TTools;\n}): McpServerDef<TTools, THeaders> {\n  return opts;\n}\n", "import type { UIMessage } from \"ai\";\nimport type { AgentOptions, SendInput } from \"../client\";\nimport type { Message, Part } from \"../storage\";\n\nexport function toMessageAndParts({\n  sessionId,\n  id,\n  input,\n  generateId,\n  defaultRole,\n}: {\n  sessionId: string;\n  id?: string;\n  input: SendInput;\n  generateId: NonNullable<AgentOptions[\"generateId\"]>;\n  defaultRole: UIMessage[\"role\"];\n}): { message: Message; parts: Part[] } {\n  const messageId = id ?? generateId(\"message\");\n  if (typeof input === \"string\") {\n    return {\n      message: {\n        id: messageId,\n        sessionId,\n        role: defaultRole,\n        createdAt: Date.now(),\n        completedAt: Date.now(),\n        mcpContext: null,\n      },\n      parts: [\n        {\n          sessionId,\n          messageId,\n          id: generateId(\"part\"),\n          index: 0,\n          part: { type: \"text\", text: input },\n        },\n      ],\n    };\n  }\n  return {\n    message: {\n      sessionId,\n      id: messageId,\n      createdAt: Date.now(),\n      completedAt: Date.now(),\n      mcpContext: null,\n      role: input.role ?? defaultRole,\n    },\n    parts: input.parts.map((part, index) => ({\n      sessionId,\n      messageId,\n      id: generateId(\"part\"),\n      index,\n      part,\n    })),\n  };\n}\n"],
  "mappings": "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",
  "names": ["mcp", "session"]
}

@@ -0,0 +1,20 @@
1
+ // src/sandbox/lifecycle-workflow-steps.ts
2
+ async function snapshotSandboxStep(input) {
3
+ "use step";
4
+ const { getStorage } = await import("./storage-QSTSE2ZB.mjs");
5
+ const { getSandbox } = await import("./client-FCFZYOOB.mjs");
6
+ const storage = getStorage(input.storageConfig);
7
+ const sandboxRecord = await storage.sandbox.get(input.id);
8
+ if (sandboxRecord instanceof Error) {
9
+ return sandboxRecord;
10
+ }
11
+ const sandbox = getSandbox({
12
+ sandboxRecord,
13
+ storageConfig: input.storageConfig
14
+ });
15
+ await sandbox.lifecycle?.snapshot();
16
+ }
17
+ export {
18
+ snapshotSandboxStep
19
+ };
20
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL3NhbmRib3gvbGlmZWN5Y2xlLXdvcmtmbG93LXN0ZXBzLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgdHlwZSB7IFNhbmRib3hMaWZlY3ljbGVJbnB1dCB9IGZyb20gXCIuL3R5cGVzXCI7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzbmFwc2hvdFNhbmRib3hTdGVwKGlucHV0OiBTYW5kYm94TGlmZWN5Y2xlSW5wdXQpIHtcbiAgXCJ1c2Ugc3RlcFwiO1xuXG4gIGNvbnN0IHsgZ2V0U3RvcmFnZSB9ID0gYXdhaXQgaW1wb3J0KFwiLi4vc3RvcmFnZVwiKTtcbiAgY29uc3QgeyBnZXRTYW5kYm94IH0gPSBhd2FpdCBpbXBvcnQoXCIuL2NsaWVudFwiKTtcblxuICBjb25zdCBzdG9yYWdlID0gZ2V0U3RvcmFnZShpbnB1dC5zdG9yYWdlQ29uZmlnKTtcbiAgY29uc3Qgc2FuZGJveFJlY29yZCA9IGF3YWl0IHN0b3JhZ2Uuc2FuZGJveC5nZXQoaW5wdXQuaWQpO1xuICBpZiAoc2FuZGJveFJlY29yZCBpbnN0YW5jZW9mIEVycm9yKSB7XG4gICAgcmV0dXJuIHNhbmRib3hSZWNvcmQ7XG4gIH1cblxuICBjb25zdCBzYW5kYm94ID0gZ2V0U2FuZGJveCh7XG4gICAgc2FuZGJveFJlY29yZCxcbiAgICBzdG9yYWdlQ29uZmlnOiBpbnB1dC5zdG9yYWdlQ29uZmlnLFxuICB9KTtcblxuICBhd2FpdCBzYW5kYm94LmxpZmVjeWNsZT8uc25hcHNob3QoKTtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7QUFFQSxlQUFzQixvQkFBb0IsT0FBOEI7QUFDdEU7QUFFQSxRQUFNLEVBQUUsV0FBVyxJQUFJLE1BQU0sT0FBTyx3QkFBWTtBQUNoRCxRQUFNLEVBQUUsV0FBVyxJQUFJLE1BQU0sT0FBTyx1QkFBVTtBQUU5QyxRQUFNLFVBQVUsV0FBVyxNQUFNLGFBQWE7QUFDOUMsUUFBTSxnQkFBZ0IsTUFBTSxRQUFRLFFBQVEsSUFBSSxNQUFNLEVBQUU7QUFDeEQsTUFBSSx5QkFBeUIsT0FBTztBQUNsQyxXQUFPO0FBQUEsRUFDVDtBQUVBLFFBQU0sVUFBVSxXQUFXO0FBQUEsSUFDekI7QUFBQSxJQUNBLGVBQWUsTUFBTTtBQUFBLEVBQ3ZCLENBQUM7QUFFRCxRQUFNLFFBQVEsV0FBVyxTQUFTO0FBQ3BDOyIsCiAgIm5hbWVzIjogW10KfQo=
@@ -0,0 +1,17 @@
1
+ import * as workflow from 'workflow';
2
+ import { e as SandboxConfig } from './types-vRxN1Qz1.mjs';
3
+ import { c as SandboxLifecycleInput } from './types-Lwut_0_u.mjs';
4
+ import 'ai';
5
+ import 'zod';
6
+ import 'errore';
7
+
8
+ type SandboxActivitySignal = {
9
+ type: "activity";
10
+ newConfig: SandboxConfig;
11
+ };
12
+ declare const sandboxActivityHook: workflow.TypedHook<SandboxActivitySignal, SandboxActivitySignal>;
13
+ declare function sandboxLifecycleWorkflow({ input, }: {
14
+ input: SandboxLifecycleInput;
15
+ }): Promise<void>;
16
+
17
+ export { type SandboxActivitySignal, SandboxLifecycleInput, sandboxActivityHook, sandboxLifecycleWorkflow };
@@ -0,0 +1,17 @@
1
+ import * as workflow from 'workflow';
2
+ import { e as SandboxConfig } from './types-vRxN1Qz1.js';
3
+ import { c as SandboxLifecycleInput } from './types-ctZeJ3iQ.js';
4
+ import 'ai';
5
+ import 'zod';
6
+ import 'errore';
7
+
8
+ type SandboxActivitySignal = {
9
+ type: "activity";
10
+ newConfig: SandboxConfig;
11
+ };
12
+ declare const sandboxActivityHook: workflow.TypedHook<SandboxActivitySignal, SandboxActivitySignal>;
13
+ declare function sandboxLifecycleWorkflow({ input, }: {
14
+ input: SandboxLifecycleInput;
15
+ }): Promise<void>;
16
+
17
+ export { type SandboxActivitySignal, SandboxLifecycleInput, sandboxActivityHook, sandboxLifecycleWorkflow };