experimental-agent 0.5.0 → 0.6.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (47) hide show
  1. package/dist/{adapter-Cl735Kp4.d.mts → adapter-txsF6hou.d.mts} +2 -0
  2. package/dist/{adapter-Cl735Kp4.d.ts → adapter-txsF6hou.d.ts} +2 -0
  3. package/dist/{chunk-AB2JYY6A.mjs → chunk-CCWLV27N.mjs} +10 -2
  4. package/dist/chunk-CS2SEUAA.mjs +405 -0
  5. package/dist/{chunk-6MS4CGEZ.mjs → chunk-D35AQN7O.mjs} +5 -5
  6. package/dist/chunk-LZOMFHX3.mjs +38 -0
  7. package/dist/chunk-PH2FXKOU.mjs +9 -0
  8. package/dist/client-B2ohNvwc.d.mts +494 -0
  9. package/dist/client-BbQZtxca.d.ts +494 -0
  10. package/dist/client.mjs +1 -1
  11. package/dist/{docker-OBUQX5ZI.mjs → docker-FCSNVBEQ.mjs} +1 -1
  12. package/dist/{entry-Bs17QEiq.d.mts → entry-BUiucCNp.d.mts} +1 -1
  13. package/dist/{entry-QNyd4S1s.d.ts → entry-ok9EBUS3.d.ts} +1 -1
  14. package/dist/index.d.mts +475 -475
  15. package/dist/index.d.ts +475 -475
  16. package/dist/index.js +16595 -245
  17. package/dist/index.mjs +16406 -117
  18. package/dist/lifecycle-workflow-steps.d.mts +2 -2
  19. package/dist/lifecycle-workflow-steps.d.ts +2 -2
  20. package/dist/lifecycle-workflow-steps.mjs +1 -1
  21. package/dist/lifecycle-workflow.d.mts +2 -2
  22. package/dist/lifecycle-workflow.d.ts +2 -2
  23. package/dist/lifecycle-workflow.mjs +1 -1
  24. package/dist/{local-4C3V4EFS.mjs → local-NXHIUJTO.mjs} +1 -1
  25. package/dist/next/loader.js +10 -2
  26. package/dist/next/loader.mjs +2 -2
  27. package/dist/next.js +10 -2
  28. package/dist/next.mjs +2 -2
  29. package/dist/{process-manager-WQHAIVRB.mjs → process-manager-26NELLRU.mjs} +1 -1
  30. package/dist/react.d.mts +56 -0
  31. package/dist/react.d.ts +56 -0
  32. package/dist/react.js +144 -0
  33. package/dist/react.mjs +117 -0
  34. package/dist/sandbox.d.mts +3 -3
  35. package/dist/sandbox.d.ts +3 -3
  36. package/dist/sandbox.js +5 -5
  37. package/dist/sandbox.mjs +2 -2
  38. package/dist/{steps-XA4wG8W3.d.ts → steps-BOKeU8X3.d.ts} +3 -2
  39. package/dist/{steps-eTytqxQb.d.mts → steps-Mi3sjYbD.d.mts} +3 -2
  40. package/dist/storage.d.mts +2 -2
  41. package/dist/storage.d.ts +2 -2
  42. package/dist/storage.js +107 -48
  43. package/dist/storage.mjs +2 -2
  44. package/dist/{vercel-6ORAC625.mjs → vercel-BOGHAFI4.mjs} +2 -2
  45. package/package.json +9 -1
  46. package/dist/chunk-BJTO5JO5.mjs +0 -11
  47. package/dist/chunk-I5DCB7RU.mjs +0 -346
package/dist/react.js ADDED
@@ -0,0 +1,144 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+
20
+ // src/react/index.ts
21
+ var react_exports = {};
22
+ __export(react_exports, {
23
+ useAgent: () => useAgent,
24
+ useInterruptSession: () => useInterruptSession,
25
+ useSessionHistory: () => useSessionHistory
26
+ });
27
+ module.exports = __toCommonJS(react_exports);
28
+
29
+ // src/react/use-agent.ts
30
+ var import_react = require("@ai-sdk/react");
31
+ var import_ai = require("ai");
32
+ var import_react2 = require("react");
33
+
34
+ // src/rpc/base-path.ts
35
+ function basePathForAgent(agent) {
36
+ return `/api/agents/${agent}`;
37
+ }
38
+
39
+ // src/react/use-agent.ts
40
+ function useAgent(name, {
41
+ headers,
42
+ id,
43
+ ...options
44
+ } = {}) {
45
+ const basePath = options.basePath ?? basePathForAgent(name);
46
+ const [agentStatus, setAgentStatus] = (0, import_react2.useState)(null);
47
+ const onData = (0, import_react2.useRef)(options.onData);
48
+ (0, import_react2.useEffect)(() => {
49
+ onData.current = options.onData;
50
+ }, [options.onData]);
51
+ const chat = (0, import_react.useChat)({
52
+ chat: (0, import_react2.useMemo)(
53
+ () => new import_react.Chat({
54
+ id,
55
+ transport: new import_ai.DefaultChatTransport({
56
+ api: basePath,
57
+ prepareSendMessagesRequest: async ({ messages }) => {
58
+ const h = await (typeof headers === "function" ? headers() : headers);
59
+ const lastAssistant = messages.findLast(
60
+ (m) => m.role === "assistant"
61
+ );
62
+ const lastPartContent = lastAssistant?.parts.at(-1);
63
+ const lastPart = lastAssistant && lastPartContent != null ? {
64
+ index: lastAssistant.parts.length - 1,
65
+ part: lastPartContent
66
+ } : void 0;
67
+ const body = {
68
+ message: messages.at(-1),
69
+ interruptIfStreaming: lastPart ? { lastPart } : true
70
+ };
71
+ return {
72
+ body,
73
+ headers: new Headers(h),
74
+ api: `${basePath}/${id}`
75
+ };
76
+ },
77
+ prepareReconnectToStreamRequest: async (request) => {
78
+ const h = await (typeof headers === "function" ? headers() : headers);
79
+ return {
80
+ ...request,
81
+ api: `${basePath}/${id}/reconnect`,
82
+ headers: h
83
+ };
84
+ }
85
+ }),
86
+ onData: (_part) => {
87
+ const part = _part;
88
+ if (part.type === "data-status") {
89
+ setAgentStatus(part.data);
90
+ }
91
+ onData.current?.(part);
92
+ }
93
+ }),
94
+ [id, basePath, headers]
95
+ )
96
+ });
97
+ return {
98
+ chat,
99
+ agentStatus
100
+ };
101
+ }
102
+
103
+ // src/react/use-history-query.ts
104
+ var import_react_query2 = require("@tanstack/react-query");
105
+
106
+ // src/react/use-query.ts
107
+ var import_react_query = require("@tanstack/react-query");
108
+ var client = new import_react_query.QueryClient();
109
+ function useQuery(options) {
110
+ return (0, import_react_query.useQuery)(options, client);
111
+ }
112
+
113
+ // src/react/use-history-query.ts
114
+ function useSessionHistory(options) {
115
+ return useQuery({
116
+ ...options.options,
117
+ queryKey: ["history", options.sessionId],
118
+ queryFn: options.sessionId ? async () => {
119
+ const path = `${options.basePath}/${options.sessionId}`;
120
+ return await fetch(path).then((res) => res.json());
121
+ } : import_react_query2.skipToken
122
+ });
123
+ }
124
+
125
+ // src/react/use-interrupt.ts
126
+ var import_react_query3 = require("@tanstack/react-query");
127
+ function useInterruptSession(options) {
128
+ return (0, import_react_query3.useMutation)({
129
+ mutationFn: async (input) => {
130
+ const path = `${options.basePath}/${options.sessionId}/interrupt`;
131
+ return await fetch(path, {
132
+ method: "POST",
133
+ body: JSON.stringify(input)
134
+ }).then((res) => res.json());
135
+ }
136
+ });
137
+ }
138
+ // Annotate the CommonJS export names for ESM import in node:
139
+ 0 && (module.exports = {
140
+ useAgent,
141
+ useInterruptSession,
142
+ useSessionHistory
143
+ });
144
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/react/index.ts", "../src/react/use-agent.ts", "../src/rpc/base-path.ts", "../src/react/use-history-query.ts", "../src/react/use-query.ts", "../src/react/use-interrupt.ts"],
  "sourcesContent": ["export { useAgent } from \"./use-agent\";\nexport { useSessionHistory } from \"./use-history-query\";\nexport { useInterruptSession } from \"./use-interrupt\";\n", "import { Chat, useChat } from \"@ai-sdk/react\";\nimport { DefaultChatTransport } from \"ai\";\nimport { useEffect, useMemo, useRef, useState } from \"react\";\nimport type { AgentStatus, AnyAgent } from \"../agent/client\";\nimport { basePathForAgent } from \"../rpc/base-path\";\n\ntype DataEvent = {\n  type: \"data-status\";\n  data: AgentStatus;\n};\n\nexport function useAgent<Agent extends AnyAgent>(\n  name: Agent[\"name\"],\n  {\n    headers,\n    id,\n    ...options\n  }: {\n    basePath?: string;\n    headers?: HeadersInit | (() => Promise<HeadersInit>);\n    id?: string;\n    onData?: (data: DataEvent) => void;\n  } = {}\n) {\n  const basePath = options.basePath ?? basePathForAgent(name);\n  const [agentStatus, setAgentStatus] = useState<AgentStatus | null>(null);\n  const onData = useRef(options.onData);\n  useEffect(() => {\n    onData.current = options.onData;\n  }, [options.onData]);\n  const chat = useChat<Agent[\"$UIMessage\"]>({\n    chat: useMemo(\n      () =>\n        new Chat({\n          id,\n          transport: new DefaultChatTransport({\n            api: basePath,\n            prepareSendMessagesRequest: async ({ messages }) => {\n              const h = await (typeof headers === \"function\"\n                ? headers()\n                : headers);\n              const lastAssistant = messages.findLast(\n                (m) => m.role === \"assistant\"\n              );\n              const lastPartContent = lastAssistant?.parts.at(-1);\n              const lastPart =\n                lastAssistant && lastPartContent != null\n                  ? {\n                      index: lastAssistant.parts.length - 1,\n                      part: lastPartContent,\n                    }\n                  : undefined;\n              const body: Record<string, unknown> = {\n                message: messages.at(-1),\n                interruptIfStreaming: lastPart ? { lastPart } : true,\n              };\n              return {\n                body,\n                headers: new Headers(h),\n                api: `${basePath}/${id}`,\n              };\n            },\n            prepareReconnectToStreamRequest: async (request) => {\n              const h = await (typeof headers === \"function\"\n                ? headers()\n                : headers);\n              return {\n                ...request,\n                api: `${basePath}/${id}/reconnect`,\n                headers: h,\n              };\n            },\n          }),\n          onData: (_part) => {\n            const part = _part as unknown as DataEvent;\n            if (part.type === \"data-status\") {\n              setAgentStatus(part.data);\n            }\n            onData.current?.(part);\n          },\n        }),\n      [id, basePath, headers]\n    ),\n  });\n\n  return {\n    chat,\n    agentStatus,\n  };\n}\n", "export type BasePath = `/api/agents/[agent]`;\nexport type SessionPath = `${BasePath | (string & {})}/[sessionId]`;\nexport type ReconnectPath = `${SessionPath | (string & {})}/reconnect`;\nexport type InterruptPath = `${SessionPath | (string & {})}/interrupt`;\n\nexport type Path = SessionPath | ReconnectPath | InterruptPath;\n\nexport function basePathForAgent(agent: string) {\n  return `/api/agents/${agent}` as const;\n}\n", "import { type QueryOptions, skipToken } from \"@tanstack/react-query\";\nimport type { AnyAgent } from \"../agent/client\";\nimport { useQuery } from \"./use-query\";\n\ntype Response<Agent extends AnyAgent> = Awaited<\n  ReturnType<ReturnType<Agent[\"session\"]>[\"history\"]>\n>;\n\nexport function useSessionHistory<Agent extends AnyAgent>(options: {\n  basePath?: string;\n  sessionId: string | undefined;\n  options?: Omit<QueryOptions<Response<Agent>>, \"queryKey\" | \"queryFn\">;\n}) {\n  return useQuery<Response<Agent>>({\n    ...options.options,\n    queryKey: [\"history\", options.sessionId],\n    queryFn: options.sessionId\n      ? async () => {\n          const path = `${options.basePath}/${options.sessionId}`;\n          return await fetch(path).then((res) => res.json());\n        }\n      : skipToken,\n  });\n}\n", "import {\n  QueryClient,\n  type UseMutationOptions,\n  type UseQueryOptions,\n  useMutation as useUpstreamMutation,\n  useQuery as useUpstreamQuery,\n} from \"@tanstack/react-query\";\n\nconst client = new QueryClient();\n\nexport function useQuery<T>(options: UseQueryOptions<T>) {\n  return useUpstreamQuery<T>(options, client);\n}\n\nexport function useMutation<T, Variables, Error, Data>(\n  options: UseMutationOptions<T, Variables, Error, Data>\n) {\n  return useUpstreamMutation<T, Variables, Error, Data>(options, client);\n}\n", "import { useMutation } from \"@tanstack/react-query\";\nimport type { AnyAgent } from \"../agent/client\";\n\ntype Fn<Agent extends AnyAgent> = ReturnType<Agent[\"session\"]>[\"interrupt\"];\ntype Response<Agent extends AnyAgent> = Awaited<ReturnType<Fn<Agent>>>;\ntype Variables<Agent extends AnyAgent> = Parameters<Fn<Agent>>[0];\n\nexport function useInterruptSession<Agent extends AnyAgent>(options: {\n  basePath?: string;\n  sessionId: string;\n}) {\n  return useMutation<Response<Agent>, Error, Variables<Agent>, void>({\n    mutationFn: async (input) => {\n      const path = `${options.basePath}/${options.sessionId}/interrupt`;\n      return await fetch(path, {\n        method: \"POST\",\n        body: JSON.stringify(input),\n      }).then((res) => res.json());\n    },\n  });\n}\n"],
  "mappings": "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",
  "names": ["import_react", "import_react_query", "useUpstreamQuery", "import_react_query"]
}

package/dist/react.mjs ADDED
@@ -0,0 +1,117 @@
1
+ import {
2
+ basePathForAgent
3
+ } from "./chunk-PH2FXKOU.mjs";
4
+ import "./chunk-LZOMFHX3.mjs";
5
+
6
+ // src/react/use-agent.ts
7
+ import { Chat, useChat } from "@ai-sdk/react";
8
+ import { DefaultChatTransport } from "ai";
9
+ import { useEffect, useMemo, useRef, useState } from "react";
10
+ function useAgent(name, {
11
+ headers,
12
+ id,
13
+ ...options
14
+ } = {}) {
15
+ const basePath = options.basePath ?? basePathForAgent(name);
16
+ const [agentStatus, setAgentStatus] = useState(null);
17
+ const onData = useRef(options.onData);
18
+ useEffect(() => {
19
+ onData.current = options.onData;
20
+ }, [options.onData]);
21
+ const chat = useChat({
22
+ chat: useMemo(
23
+ () => new Chat({
24
+ id,
25
+ transport: new DefaultChatTransport({
26
+ api: basePath,
27
+ prepareSendMessagesRequest: async ({ messages }) => {
28
+ const h = await (typeof headers === "function" ? headers() : headers);
29
+ const lastAssistant = messages.findLast(
30
+ (m) => m.role === "assistant"
31
+ );
32
+ const lastPartContent = lastAssistant?.parts.at(-1);
33
+ const lastPart = lastAssistant && lastPartContent != null ? {
34
+ index: lastAssistant.parts.length - 1,
35
+ part: lastPartContent
36
+ } : void 0;
37
+ const body = {
38
+ message: messages.at(-1),
39
+ interruptIfStreaming: lastPart ? { lastPart } : true
40
+ };
41
+ return {
42
+ body,
43
+ headers: new Headers(h),
44
+ api: `${basePath}/${id}`
45
+ };
46
+ },
47
+ prepareReconnectToStreamRequest: async (request) => {
48
+ const h = await (typeof headers === "function" ? headers() : headers);
49
+ return {
50
+ ...request,
51
+ api: `${basePath}/${id}/reconnect`,
52
+ headers: h
53
+ };
54
+ }
55
+ }),
56
+ onData: (_part) => {
57
+ const part = _part;
58
+ if (part.type === "data-status") {
59
+ setAgentStatus(part.data);
60
+ }
61
+ onData.current?.(part);
62
+ }
63
+ }),
64
+ [id, basePath, headers]
65
+ )
66
+ });
67
+ return {
68
+ chat,
69
+ agentStatus
70
+ };
71
+ }
72
+
73
+ // src/react/use-history-query.ts
74
+ import { skipToken } from "@tanstack/react-query";
75
+
76
+ // src/react/use-query.ts
77
+ import {
78
+ QueryClient,
79
+ useMutation as useUpstreamMutation,
80
+ useQuery as useUpstreamQuery
81
+ } from "@tanstack/react-query";
82
+ var client = new QueryClient();
83
+ function useQuery(options) {
84
+ return useUpstreamQuery(options, client);
85
+ }
86
+
87
+ // src/react/use-history-query.ts
88
+ function useSessionHistory(options) {
89
+ return useQuery({
90
+ ...options.options,
91
+ queryKey: ["history", options.sessionId],
92
+ queryFn: options.sessionId ? async () => {
93
+ const path = `${options.basePath}/${options.sessionId}`;
94
+ return await fetch(path).then((res) => res.json());
95
+ } : skipToken
96
+ });
97
+ }
98
+
99
+ // src/react/use-interrupt.ts
100
+ import { useMutation } from "@tanstack/react-query";
101
+ function useInterruptSession(options) {
102
+ return useMutation({
103
+ mutationFn: async (input) => {
104
+ const path = `${options.basePath}/${options.sessionId}/interrupt`;
105
+ return await fetch(path, {
106
+ method: "POST",
107
+ body: JSON.stringify(input)
108
+ }).then((res) => res.json());
109
+ }
110
+ });
111
+ }
112
+ export {
113
+ useAgent,
114
+ useInterruptSession,
115
+ useSessionHistory
116
+ };
117
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/react/use-agent.ts", "../src/react/use-history-query.ts", "../src/react/use-query.ts", "../src/react/use-interrupt.ts"],
  "sourcesContent": ["import { Chat, useChat } from \"@ai-sdk/react\";\nimport { DefaultChatTransport } from \"ai\";\nimport { useEffect, useMemo, useRef, useState } from \"react\";\nimport type { AgentStatus, AnyAgent } from \"../agent/client\";\nimport { basePathForAgent } from \"../rpc/base-path\";\n\ntype DataEvent = {\n  type: \"data-status\";\n  data: AgentStatus;\n};\n\nexport function useAgent<Agent extends AnyAgent>(\n  name: Agent[\"name\"],\n  {\n    headers,\n    id,\n    ...options\n  }: {\n    basePath?: string;\n    headers?: HeadersInit | (() => Promise<HeadersInit>);\n    id?: string;\n    onData?: (data: DataEvent) => void;\n  } = {}\n) {\n  const basePath = options.basePath ?? basePathForAgent(name);\n  const [agentStatus, setAgentStatus] = useState<AgentStatus | null>(null);\n  const onData = useRef(options.onData);\n  useEffect(() => {\n    onData.current = options.onData;\n  }, [options.onData]);\n  const chat = useChat<Agent[\"$UIMessage\"]>({\n    chat: useMemo(\n      () =>\n        new Chat({\n          id,\n          transport: new DefaultChatTransport({\n            api: basePath,\n            prepareSendMessagesRequest: async ({ messages }) => {\n              const h = await (typeof headers === \"function\"\n                ? headers()\n                : headers);\n              const lastAssistant = messages.findLast(\n                (m) => m.role === \"assistant\"\n              );\n              const lastPartContent = lastAssistant?.parts.at(-1);\n              const lastPart =\n                lastAssistant && lastPartContent != null\n                  ? {\n                      index: lastAssistant.parts.length - 1,\n                      part: lastPartContent,\n                    }\n                  : undefined;\n              const body: Record<string, unknown> = {\n                message: messages.at(-1),\n                interruptIfStreaming: lastPart ? { lastPart } : true,\n              };\n              return {\n                body,\n                headers: new Headers(h),\n                api: `${basePath}/${id}`,\n              };\n            },\n            prepareReconnectToStreamRequest: async (request) => {\n              const h = await (typeof headers === \"function\"\n                ? headers()\n                : headers);\n              return {\n                ...request,\n                api: `${basePath}/${id}/reconnect`,\n                headers: h,\n              };\n            },\n          }),\n          onData: (_part) => {\n            const part = _part as unknown as DataEvent;\n            if (part.type === \"data-status\") {\n              setAgentStatus(part.data);\n            }\n            onData.current?.(part);\n          },\n        }),\n      [id, basePath, headers]\n    ),\n  });\n\n  return {\n    chat,\n    agentStatus,\n  };\n}\n", "import { type QueryOptions, skipToken } from \"@tanstack/react-query\";\nimport type { AnyAgent } from \"../agent/client\";\nimport { useQuery } from \"./use-query\";\n\ntype Response<Agent extends AnyAgent> = Awaited<\n  ReturnType<ReturnType<Agent[\"session\"]>[\"history\"]>\n>;\n\nexport function useSessionHistory<Agent extends AnyAgent>(options: {\n  basePath?: string;\n  sessionId: string | undefined;\n  options?: Omit<QueryOptions<Response<Agent>>, \"queryKey\" | \"queryFn\">;\n}) {\n  return useQuery<Response<Agent>>({\n    ...options.options,\n    queryKey: [\"history\", options.sessionId],\n    queryFn: options.sessionId\n      ? async () => {\n          const path = `${options.basePath}/${options.sessionId}`;\n          return await fetch(path).then((res) => res.json());\n        }\n      : skipToken,\n  });\n}\n", "import {\n  QueryClient,\n  type UseMutationOptions,\n  type UseQueryOptions,\n  useMutation as useUpstreamMutation,\n  useQuery as useUpstreamQuery,\n} from \"@tanstack/react-query\";\n\nconst client = new QueryClient();\n\nexport function useQuery<T>(options: UseQueryOptions<T>) {\n  return useUpstreamQuery<T>(options, client);\n}\n\nexport function useMutation<T, Variables, Error, Data>(\n  options: UseMutationOptions<T, Variables, Error, Data>\n) {\n  return useUpstreamMutation<T, Variables, Error, Data>(options, client);\n}\n", "import { useMutation } from \"@tanstack/react-query\";\nimport type { AnyAgent } from \"../agent/client\";\n\ntype Fn<Agent extends AnyAgent> = ReturnType<Agent[\"session\"]>[\"interrupt\"];\ntype Response<Agent extends AnyAgent> = Awaited<ReturnType<Fn<Agent>>>;\ntype Variables<Agent extends AnyAgent> = Parameters<Fn<Agent>>[0];\n\nexport function useInterruptSession<Agent extends AnyAgent>(options: {\n  basePath?: string;\n  sessionId: string;\n}) {\n  return useMutation<Response<Agent>, Error, Variables<Agent>, void>({\n    mutationFn: async (input) => {\n      const path = `${options.basePath}/${options.sessionId}/interrupt`;\n      return await fetch(path, {\n        method: \"POST\",\n        body: JSON.stringify(input),\n      }).then((res) => res.json());\n    },\n  });\n}\n"],
  "mappings": "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",
  "names": []
}

@@ -1,6 +1,6 @@
1
- export { E as ExecResult, d as SandboxAgentRef, S as SandboxBinding, b as SandboxInstance, a as SandboxSetupFields, U as UploadableFile } from './steps-eTytqxQb.mjs';
2
- export { d as dockerSandbox, l as localSandbox, v as vercelSandbox } from './entry-Bs17QEiq.mjs';
1
+ export { E as ExecResult, S as SandboxAgentRef, a as SandboxBinding, b as SandboxInstance, c as SandboxSetupFields, U as UploadableFile } from './steps-Mi3sjYbD.mjs';
2
+ export { d as dockerSandbox, l as localSandbox, v as vercelSandbox } from './entry-BUiucCNp.mjs';
3
3
  import '@vercel/sandbox';
4
- import './adapter-Cl735Kp4.mjs';
4
+ import './adapter-txsF6hou.mjs';
5
5
  import '@workflow/serde';
6
6
  import 'ai';
package/dist/sandbox.d.ts CHANGED
@@ -1,6 +1,6 @@
1
- export { E as ExecResult, d as SandboxAgentRef, S as SandboxBinding, b as SandboxInstance, a as SandboxSetupFields, U as UploadableFile } from './steps-XA4wG8W3.js';
2
- export { d as dockerSandbox, l as localSandbox, v as vercelSandbox } from './entry-QNyd4S1s.js';
1
+ export { E as ExecResult, S as SandboxAgentRef, a as SandboxBinding, b as SandboxInstance, c as SandboxSetupFields, U as UploadableFile } from './steps-BOKeU8X3.js';
2
+ export { d as dockerSandbox, l as localSandbox, v as vercelSandbox } from './entry-ok9EBUS3.js';
3
3
  import '@vercel/sandbox';
4
- import './adapter-Cl735Kp4.js';
4
+ import './adapter-txsF6hou.js';
5
5
  import '@workflow/serde';
6
6
  import 'ai';