experimental-agent 0.0.2 → 0.0.4

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 (57) hide show
  1. package/README.md +13 -2
  2. package/dist/agent-workflow.d.mts +11 -3
  3. package/dist/agent-workflow.d.ts +11 -3
  4. package/dist/agent-workflow.js +1921 -1144
  5. package/dist/agent-workflow.mjs +7 -3
  6. package/dist/chunk-3ODWQVIA.mjs +12 -0
  7. package/dist/chunk-64THY7Y7.mjs +155 -0
  8. package/dist/chunk-GSRJYPWF.mjs +284 -0
  9. package/dist/chunk-HJGPUEFC.mjs +42 -0
  10. package/dist/chunk-JCPQQWIK.mjs +2057 -0
  11. package/dist/chunk-JEE2FQ4O.mjs +844 -0
  12. package/dist/chunk-T7PMZLOX.mjs +79 -0
  13. package/dist/chunk-TQRCSTCF.mjs +103 -0
  14. package/dist/chunk-VBLZWXVE.mjs +318 -0
  15. package/dist/{types-DPXFq_r6.d.ts → client-6g79J0s3.d.mts} +866 -31
  16. package/dist/{types-DPXFq_r6.d.mts → client-6g79J0s3.d.ts} +866 -31
  17. package/dist/client-SREKHM6I.mjs +15 -0
  18. package/dist/client.d.mts +37 -0
  19. package/dist/client.d.ts +37 -0
  20. package/dist/client.js +58 -0
  21. package/dist/client.mjs +30 -0
  22. package/dist/{client-HUG4HT5L.mjs → handler-36FM5H35.mjs} +4 -5
  23. package/dist/index.d.mts +3 -4
  24. package/dist/index.d.ts +3 -4
  25. package/dist/index.js +3102 -1438
  26. package/dist/index.mjs +720 -147
  27. package/dist/lifecycle-workflow.d.mts +3 -10
  28. package/dist/lifecycle-workflow.d.ts +3 -10
  29. package/dist/lifecycle-workflow.js +170 -1246
  30. package/dist/lifecycle-workflow.mjs +5 -41
  31. package/dist/local-fs-handlers-P4WGW3QY.mjs +235 -0
  32. package/dist/next/loader.d.mts +14 -0
  33. package/dist/next/loader.d.ts +14 -0
  34. package/dist/next/loader.js +206 -0
  35. package/dist/next/loader.mjs +103 -0
  36. package/dist/next.d.mts +34 -0
  37. package/dist/next.d.ts +34 -0
  38. package/dist/next.js +329 -0
  39. package/dist/next.mjs +224 -0
  40. package/dist/process-manager-JAKAXROL.mjs +10 -0
  41. package/dist/{client-4Y3UPWFR.mjs → sandbox-QAPGBVYM.mjs} +4 -3
  42. package/dist/storage-Q376OZH3.mjs +20 -0
  43. package/dist/{vercel-2CFDMEHB.mjs → vercel-LLXAHKVJ.mjs} +3 -1
  44. package/dist/vercel-sdk-VHKEX2GQ.mjs +8 -0
  45. package/package.json +32 -19
  46. package/dist/chunk-24DJSI7C.mjs +0 -374
  47. package/dist/chunk-4RGMKC2M.mjs +0 -755
  48. package/dist/chunk-6ICYKNCC.mjs +0 -284
  49. package/dist/chunk-PGYYQ3WZ.mjs +0 -1088
  50. package/dist/client-BBpD9kKL.d.ts +0 -193
  51. package/dist/client-BGJViybU.d.mts +0 -193
  52. package/dist/lifecycle-workflow-steps-HHN46ZAD.mjs +0 -20
  53. package/dist/local-BYPFRMLZ.mjs +0 -282
  54. package/dist/process-manager-H2HF6G4G.mjs +0 -153
  55. package/dist/sandbox-BFA4ECEQ.mjs +0 -10
  56. package/dist/storage-2U2QFNWI.mjs +0 -27
  57. /package/dist/{chunk-36X6L7SK.mjs → chunk-TAXLUVIC.mjs} +0 -0
@@ -1,282 +0,0 @@
1
- import {
2
- handleStorageRpc
3
- } from "./chunk-6ICYKNCC.mjs";
4
- import "./chunk-24DJSI7C.mjs";
5
-
6
- // src/storage/bindings/local.ts
7
- import { serve } from "@hono/node-server";
8
- import { Hono } from "hono";
9
-
10
- // src/storage/bindings/local-fs-handlers.ts
11
- import { mkdir, readdir, readFile, writeFile } from "node:fs/promises";
12
- import { dirname, join } from "node:path";
13
-
14
- // src/utils/paginate.ts
15
- function paginate(opts) {
16
- const { items, cursor, limit = 50 } = opts;
17
- const startIndex = cursor ? items.findIndex((m) => m.id === cursor) + 1 : 0;
18
- const sliced = items.slice(startIndex, startIndex + limit);
19
- const nextCursor = startIndex + limit < items.length ? sliced.at(-1)?.id ?? null : null;
20
- return { items: sliced, nextCursor };
21
- }
22
-
23
- // src/storage/bindings/local-fs-handlers.ts
24
- function createFilesystemHandlers(basePath) {
25
- const sessionDir = join(basePath, "session");
26
- const messageDir = join(basePath, "message");
27
- const partDir = join(basePath, "part");
28
- const sandboxDir = join(basePath, "sandbox");
29
- const commandDir = join(basePath, "command");
30
- async function ensureDir(dir) {
31
- await mkdir(dir, { recursive: true });
32
- }
33
- async function readJson(filePath) {
34
- try {
35
- const content = await readFile(filePath, "utf-8");
36
- return JSON.parse(content);
37
- } catch {
38
- return null;
39
- }
40
- }
41
- async function writeJsonFile(filePath, data) {
42
- await ensureDir(dirname(filePath));
43
- await writeFile(filePath, JSON.stringify(data, null, 2));
44
- }
45
- async function readAllFromDir(dir) {
46
- try {
47
- const files = await readdir(dir);
48
- const results = await Promise.all(
49
- files.filter((f) => f.endsWith(".json")).map((f) => readJson(join(dir, f)))
50
- );
51
- return results.filter((r) => r !== null);
52
- } catch {
53
- return [];
54
- }
55
- }
56
- return {
57
- "session.get": async ({ id }) => {
58
- const session = await readJson(join(sessionDir, `${id}.json`));
59
- return session ?? null;
60
- },
61
- "session.set": async (session) => {
62
- const now = Date.now();
63
- const sessionPath = join(sessionDir, `${session.id}.json`);
64
- const existing = await readJson(sessionPath);
65
- const newSession = {
66
- ...session,
67
- tags: session.tags ?? existing?.tags ?? {},
68
- createdAt: existing?.createdAt ?? session.createdAt ?? now,
69
- updatedAt: now
70
- };
71
- await writeJsonFile(sessionPath, newSession);
72
- return newSession;
73
- },
74
- "session.list": async ({ tags, cursor, limit }) => {
75
- const allSessions = await readAllFromDir(sessionDir);
76
- let filtered = allSessions;
77
- if (tags && Object.keys(tags).length > 0) {
78
- filtered = filtered.filter((s) => {
79
- const sessionTags = s.tags ?? {};
80
- return Object.entries(tags).every(
81
- ([key, value]) => sessionTags[key] === value
82
- );
83
- });
84
- }
85
- filtered.sort((a, b) => a.createdAt - b.createdAt);
86
- return paginate({ items: filtered, cursor, limit });
87
- },
88
- "session.listBySandbox": async ({ sandboxId, tags, cursor, limit }) => {
89
- const allSessions = await readAllFromDir(sessionDir);
90
- let filtered = allSessions.filter((s) => s.sandboxId === sandboxId);
91
- if (tags && Object.keys(tags).length > 0) {
92
- filtered = filtered.filter((s) => {
93
- const sessionTags = s.tags ?? {};
94
- return Object.entries(tags).every(
95
- ([key, value]) => sessionTags[key] === value
96
- );
97
- });
98
- }
99
- filtered.sort((a, b) => a.createdAt - b.createdAt);
100
- return paginate({ items: filtered, cursor, limit });
101
- },
102
- "session.tag.set": async ({ sessionId, tags }) => {
103
- const sessionPath = join(sessionDir, `${sessionId}.json`);
104
- const existing = await readJson(sessionPath);
105
- if (!existing) {
106
- throw new Error(`Session ${sessionId} not found`);
107
- }
108
- const mergedTags = { ...existing.tags, ...tags };
109
- const now = Date.now();
110
- const updatedSession = {
111
- ...existing,
112
- tags: mergedTags,
113
- updatedAt: now
114
- };
115
- await writeJsonFile(sessionPath, updatedSession);
116
- return updatedSession;
117
- },
118
- "message.get": async ({ id }) => {
119
- return await readJson(join(messageDir, `${id}.json`));
120
- },
121
- "message.set": async (message) => {
122
- await writeJsonFile(join(messageDir, `${message.id}.json`), message);
123
- return message;
124
- },
125
- "message.list": async ({ sessionId, cursor, limit }) => {
126
- const allMessages = await readAllFromDir(messageDir);
127
- const filtered = allMessages.filter((m) => m.sessionId === sessionId).sort((a, b) => a.createdAt - b.createdAt);
128
- return paginate({ items: filtered, cursor, limit });
129
- },
130
- "part.listByMessage": async ({ messageId, cursor, limit }) => {
131
- const allParts = await readAllFromDir(partDir);
132
- const filtered = allParts.filter((p) => p.messageId === messageId).sort((a, b) => a.index - b.index);
133
- return paginate({ items: filtered, cursor, limit });
134
- },
135
- "part.listBySession": async ({ sessionId, cursor, limit }) => {
136
- const allParts = await readAllFromDir(partDir);
137
- const filtered = allParts.filter((p) => p.sessionId === sessionId).sort((a, b) => {
138
- if (a.messageId !== b.messageId) {
139
- return a.messageId.localeCompare(b.messageId);
140
- }
141
- return a.index - b.index;
142
- });
143
- return paginate({ items: filtered, cursor, limit });
144
- },
145
- "part.set": async (part) => {
146
- await writeJsonFile(join(partDir, `${part.id}.json`), part);
147
- return part;
148
- },
149
- "sandbox.get": async ({ key }) => {
150
- const safeName = Buffer.from(key).toString("base64url");
151
- const sandboxPath = join(sandboxDir, `${safeName}.json`);
152
- const data = await readJson(sandboxPath);
153
- if (!data) {
154
- return null;
155
- }
156
- return data;
157
- },
158
- "sandbox.set": async (record) => {
159
- const safeName = Buffer.from(record.id).toString("base64url");
160
- const sandboxPath = join(sandboxDir, `${safeName}.json`);
161
- const existing = await readJson(sandboxPath);
162
- const newRecord = {
163
- ...record,
164
- tags: record.tags ?? existing?.tags ?? null
165
- };
166
- await writeJsonFile(sandboxPath, newRecord);
167
- },
168
- "sandbox.list": async ({ tags, order, cursor, limit }) => {
169
- const allSandboxes = await readAllFromDir(sandboxDir);
170
- let filtered = allSandboxes;
171
- if (tags && Object.keys(tags).length > 0) {
172
- filtered = filtered.filter((s) => {
173
- const sandboxTags = s.tags ?? {};
174
- return Object.entries(tags).every(
175
- ([key, value]) => sandboxTags[key] === value
176
- );
177
- });
178
- }
179
- const sortField = order?.startsWith("lastActivityAt") ? "lastActivityAt" : "createdAt";
180
- const sortDir = order?.endsWith("_desc") ? -1 : 1;
181
- filtered.sort(
182
- (a, b) => sortDir * ((a[sortField] ?? 0) - (b[sortField] ?? 0))
183
- );
184
- return paginate({ items: filtered, cursor, limit });
185
- },
186
- "sandbox.tag.set": async ({ sandboxId, tags }) => {
187
- const safeName = Buffer.from(sandboxId).toString("base64url");
188
- const sandboxPath = join(sandboxDir, `${safeName}.json`);
189
- const existing = await readJson(sandboxPath);
190
- if (!existing) {
191
- throw new Error(`Sandbox ${sandboxId} not found`);
192
- }
193
- const mergedTags = { ...existing.tags, ...tags };
194
- const updatedSandbox = {
195
- ...existing,
196
- tags: mergedTags
197
- };
198
- await writeJsonFile(sandboxPath, updatedSandbox);
199
- return updatedSandbox;
200
- },
201
- "sandbox.getBySession": async ({ sessionId }) => {
202
- const allSandboxes = await readAllFromDir(sandboxDir);
203
- const matching = allSandboxes.filter(
204
- (s) => s.id.startsWith(`${sessionId}-`)
205
- );
206
- if (matching.length === 0) {
207
- return null;
208
- }
209
- matching.sort(
210
- (a, b) => (b.lastActivityAt ?? 0) - (a.lastActivityAt ?? 0)
211
- );
212
- return matching[0];
213
- },
214
- "command.get": async ({ id }) => {
215
- return await readJson(join(commandDir, `${id}.json`));
216
- },
217
- "command.set": async (command) => {
218
- await writeJsonFile(join(commandDir, `${command.id}.json`), command);
219
- return command;
220
- },
221
- "command.list": async ({ sessionId, includeFinished, cursor, limit }) => {
222
- const allCommands = await readAllFromDir(commandDir);
223
- let filtered = allCommands.filter((c) => c.sessionId === sessionId);
224
- if (!includeFinished) {
225
- filtered = filtered.filter((c) => c.status === "running");
226
- }
227
- filtered.sort((a, b) => a.startedAt - b.startedAt);
228
- return paginate({ items: filtered, cursor, limit });
229
- }
230
- };
231
- }
232
-
233
- // src/storage/bindings/local.ts
234
- var DEFAULT_STORAGE_DIR = ".agent-storage";
235
- var startPromise = null;
236
- var serverInstance = null;
237
- function startLocalStorage(opts) {
238
- if (startPromise) {
239
- return startPromise;
240
- }
241
- startPromise = new Promise((resolve) => {
242
- const handlers = createFilesystemHandlers(
243
- opts?.path ?? DEFAULT_STORAGE_DIR
244
- );
245
- const app = new Hono();
246
- app.post("/", async (c) => {
247
- const body = await c.req.json();
248
- const response = await handleStorageRpc(body, handlers);
249
- return c.json(response);
250
- });
251
- const port = opts?.port ?? 0;
252
- const server = serve({
253
- fetch: app.fetch,
254
- port
255
- });
256
- server.on("listening", () => {
257
- const address = server.address();
258
- const actualPort = typeof address === "object" ? address?.port : port;
259
- const url = `http://localhost:${actualPort}`;
260
- serverInstance = { url, server };
261
- console.log(`[agent] Local storage server started at ${url}`);
262
- resolve(url);
263
- });
264
- });
265
- return startPromise;
266
- }
267
- function stopLocalStorage() {
268
- if (serverInstance) {
269
- serverInstance.server.close();
270
- serverInstance = null;
271
- startPromise = null;
272
- }
273
- }
274
- if (typeof process !== "undefined") {
275
- process.on("SIGTERM", stopLocalStorage);
276
- process.on("SIGINT", stopLocalStorage);
277
- }
278
- export {
279
- startLocalStorage,
280
- stopLocalStorage
281
- };
282
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL3N0b3JhZ2UvYmluZGluZ3MvbG9jYWwudHMiLCAiLi4vc3JjL3N0b3JhZ2UvYmluZGluZ3MvbG9jYWwtZnMtaGFuZGxlcnMudHMiLCAiLi4vc3JjL3V0aWxzL3BhZ2luYXRlLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgeyB0eXBlIFNlcnZlclR5cGUsIHNlcnZlIH0gZnJvbSBcIkBob25vL25vZGUtc2VydmVyXCI7XG5pbXBvcnQgeyBIb25vIH0gZnJvbSBcImhvbm9cIjtcbmltcG9ydCB7IGhhbmRsZVN0b3JhZ2VScGMgfSBmcm9tIFwiLi5cIjtcbmltcG9ydCB7IGNyZWF0ZUZpbGVzeXN0ZW1IYW5kbGVycyB9IGZyb20gXCIuL2xvY2FsLWZzLWhhbmRsZXJzXCI7XG5cbmNvbnN0IERFRkFVTFRfU1RPUkFHRV9ESVIgPSBcIi5hZ2VudC1zdG9yYWdlXCI7XG5cbmxldCBzdGFydFByb21pc2U6IFByb21pc2U8c3RyaW5nPiB8IG51bGwgPSBudWxsO1xubGV0IHNlcnZlckluc3RhbmNlOiB7IHVybDogc3RyaW5nOyBzZXJ2ZXI6IFNlcnZlclR5cGUgfSB8IG51bGwgPSBudWxsO1xuXG5leHBvcnQgZnVuY3Rpb24gc3RhcnRMb2NhbFN0b3JhZ2Uob3B0cz86IHtcbiAgcGF0aD86IHN0cmluZztcbiAgcG9ydD86IG51bWJlcjtcbn0pOiBQcm9taXNlPHN0cmluZz4ge1xuICBpZiAoc3RhcnRQcm9taXNlKSB7XG4gICAgcmV0dXJuIHN0YXJ0UHJvbWlzZTtcbiAgfVxuXG4gIHN0YXJ0UHJvbWlzZSA9IG5ldyBQcm9taXNlKChyZXNvbHZlKSA9PiB7XG4gICAgY29uc3QgaGFuZGxlcnMgPSBjcmVhdGVGaWxlc3lzdGVtSGFuZGxlcnMoXG4gICAgICBvcHRzPy5wYXRoID8/IERFRkFVTFRfU1RPUkFHRV9ESVJcbiAgICApO1xuICAgIGNvbnN0IGFwcCA9IG5ldyBIb25vKCk7XG5cbiAgICBhcHAucG9zdChcIi9cIiwgYXN5bmMgKGMpID0+IHtcbiAgICAgIGNvbnN0IGJvZHkgPSBhd2FpdCBjLnJlcS5qc29uKCk7XG4gICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGhhbmRsZVN0b3JhZ2VScGMoYm9keSwgaGFuZGxlcnMpO1xuICAgICAgcmV0dXJuIGMuanNvbihyZXNwb25zZSk7XG4gICAgfSk7XG5cbiAgICBjb25zdCBwb3J0ID0gb3B0cz8ucG9ydCA/PyAwO1xuICAgIGNvbnN0IHNlcnZlciA9IHNlcnZlKHtcbiAgICAgIGZldGNoOiBhcHAuZmV0Y2gsXG4gICAgICBwb3J0LFxuICAgIH0pO1xuXG4gICAgc2VydmVyLm9uKFwibGlzdGVuaW5nXCIsICgpID0+IHtcbiAgICAgIGNvbnN0IGFkZHJlc3MgPSBzZXJ2ZXIuYWRkcmVzcygpO1xuICAgICAgY29uc3QgYWN0dWFsUG9ydCA9IHR5cGVvZiBhZGRyZXNzID09PSBcIm9iamVjdFwiID8gYWRkcmVzcz8ucG9ydCA6IHBvcnQ7XG4gICAgICBjb25zdCB1cmwgPSBgaHR0cDovL2xvY2FsaG9zdDoke2FjdHVhbFBvcnR9YDtcblxuICAgICAgc2VydmVySW5zdGFuY2UgPSB7IHVybCwgc2VydmVyIH07XG4gICAgICBjb25zb2xlLmxvZyhgW2FnZW50XSBMb2NhbCBzdG9yYWdlIHNlcnZlciBzdGFydGVkIGF0ICR7dXJsfWApO1xuICAgICAgcmVzb2x2ZSh1cmwpO1xuICAgIH0pO1xuICB9KTtcblxuICByZXR1cm4gc3RhcnRQcm9taXNlO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc3RvcExvY2FsU3RvcmFnZSgpOiB2b2lkIHtcbiAgaWYgKHNlcnZlckluc3RhbmNlKSB7XG4gICAgc2VydmVySW5zdGFuY2Uuc2VydmVyLmNsb3NlKCk7XG4gICAgc2VydmVySW5zdGFuY2UgPSBudWxsO1xuICAgIHN0YXJ0UHJvbWlzZSA9IG51bGw7XG4gIH1cbn1cblxuaWYgKHR5cGVvZiBwcm9jZXNzICE9PSBcInVuZGVmaW5lZFwiKSB7XG4gIHByb2Nlc3Mub24oXCJTSUdURVJNXCIsIHN0b3BMb2NhbFN0b3JhZ2UpO1xuICBwcm9jZXNzLm9uKFwiU0lHSU5UXCIsIHN0b3BMb2NhbFN0b3JhZ2UpO1xufVxuIiwgImltcG9ydCB7IG1rZGlyLCByZWFkZGlyLCByZWFkRmlsZSwgd3JpdGVGaWxlIH0gZnJvbSBcIm5vZGU6ZnMvcHJvbWlzZXNcIjtcbmltcG9ydCB7IGRpcm5hbWUsIGpvaW4gfSBmcm9tIFwibm9kZTpwYXRoXCI7XG5pbXBvcnQgeyBwYWdpbmF0ZSB9IGZyb20gXCIuLi8uLi91dGlscy9wYWdpbmF0ZVwiO1xuaW1wb3J0IHR5cGUge1xuICBDb21tYW5kLFxuICBIYW5kbGVycyxcbiAgTWVzc2FnZSxcbiAgUGFydCxcbiAgU2FuZGJveFJlY29yZCxcbiAgU2Vzc2lvbixcbn0gZnJvbSBcIi4uXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVGaWxlc3lzdGVtSGFuZGxlcnMoYmFzZVBhdGg6IHN0cmluZyk6IEhhbmRsZXJzIHtcbiAgY29uc3Qgc2Vzc2lvbkRpciA9IGpvaW4oYmFzZVBhdGgsIFwic2Vzc2lvblwiKTtcbiAgY29uc3QgbWVzc2FnZURpciA9IGpvaW4oYmFzZVBhdGgsIFwibWVzc2FnZVwiKTtcbiAgY29uc3QgcGFydERpciA9IGpvaW4oYmFzZVBhdGgsIFwicGFydFwiKTtcbiAgY29uc3Qgc2FuZGJveERpciA9IGpvaW4oYmFzZVBhdGgsIFwic2FuZGJveFwiKTtcbiAgY29uc3QgY29tbWFuZERpciA9IGpvaW4oYmFzZVBhdGgsIFwiY29tbWFuZFwiKTtcblxuICBhc3luYyBmdW5jdGlvbiBlbnN1cmVEaXIoZGlyOiBzdHJpbmcpIHtcbiAgICBhd2FpdCBta2RpcihkaXIsIHsgcmVjdXJzaXZlOiB0cnVlIH0pO1xuICB9XG5cbiAgYXN5bmMgZnVuY3Rpb24gcmVhZEpzb248VD4oZmlsZVBhdGg6IHN0cmluZyk6IFByb21pc2U8VCB8IG51bGw+IHtcbiAgICB0cnkge1xuICAgICAgY29uc3QgY29udGVudCA9IGF3YWl0IHJlYWRGaWxlKGZpbGVQYXRoLCBcInV0Zi04XCIpO1xuICAgICAgcmV0dXJuIEpTT04ucGFyc2UoY29udGVudCkgYXMgVDtcbiAgICB9IGNhdGNoIHtcbiAgICAgIHJldHVybiBudWxsO1xuICAgIH1cbiAgfVxuXG4gIGFzeW5jIGZ1bmN0aW9uIHdyaXRlSnNvbkZpbGUoZmlsZVBhdGg6IHN0cmluZywgZGF0YTogdW5rbm93bikge1xuICAgIGF3YWl0IGVuc3VyZURpcihkaXJuYW1lKGZpbGVQYXRoKSk7XG4gICAgYXdhaXQgd3JpdGVGaWxlKGZpbGVQYXRoLCBKU09OLnN0cmluZ2lmeShkYXRhLCBudWxsLCAyKSk7XG4gIH1cblxuICBhc3luYyBmdW5jdGlvbiByZWFkQWxsRnJvbURpcjxUPihkaXI6IHN0cmluZyk6IFByb21pc2U8VFtdPiB7XG4gICAgdHJ5IHtcbiAgICAgIGNvbnN0IGZpbGVzID0gYXdhaXQgcmVhZGRpcihkaXIpO1xuICAgICAgY29uc3QgcmVzdWx0cyA9IGF3YWl0IFByb21pc2UuYWxsKFxuICAgICAgICBmaWxlc1xuICAgICAgICAgIC5maWx0ZXIoKGYpID0+IGYuZW5kc1dpdGgoXCIuanNvblwiKSlcbiAgICAgICAgICAubWFwKChmKSA9PiByZWFkSnNvbjxUPihqb2luKGRpciwgZikpKVxuICAgICAgKTtcbiAgICAgIHJldHVybiByZXN1bHRzLmZpbHRlcigocik6IHIgaXMgTm9uTnVsbGFibGU8dHlwZW9mIHI+ID0+IHIgIT09IG51bGwpO1xuICAgIH0gY2F0Y2gge1xuICAgICAgcmV0dXJuIFtdO1xuICAgIH1cbiAgfVxuXG4gIHJldHVybiB7XG4gICAgXCJzZXNzaW9uLmdldFwiOiBhc3luYyAoeyBpZCB9KSA9PiB7XG4gICAgICBjb25zdCBzZXNzaW9uID0gYXdhaXQgcmVhZEpzb248U2Vzc2lvbj4oam9pbihzZXNzaW9uRGlyLCBgJHtpZH0uanNvbmApKTtcbiAgICAgIHJldHVybiBzZXNzaW9uID8/IG51bGw7XG4gICAgfSxcblxuICAgIFwic2Vzc2lvbi5zZXRcIjogYXN5bmMgKHNlc3Npb24pID0+IHtcbiAgICAgIGNvbnN0IG5vdyA9IERhdGUubm93KCk7XG4gICAgICBjb25zdCBzZXNzaW9uUGF0aCA9IGpvaW4oc2Vzc2lvbkRpciwgYCR7c2Vzc2lvbi5pZH0uanNvbmApO1xuICAgICAgY29uc3QgZXhpc3RpbmcgPSBhd2FpdCByZWFkSnNvbjxTZXNzaW9uPihzZXNzaW9uUGF0aCk7XG4gICAgICBjb25zdCBuZXdTZXNzaW9uOiBTZXNzaW9uID0ge1xuICAgICAgICAuLi5zZXNzaW9uLFxuICAgICAgICB0YWdzOiBzZXNzaW9uLnRhZ3MgPz8gZXhpc3Rpbmc/LnRhZ3MgPz8ge30sXG4gICAgICAgIGNyZWF0ZWRBdDogZXhpc3Rpbmc/LmNyZWF0ZWRBdCA/PyBzZXNzaW9uLmNyZWF0ZWRBdCA/PyBub3csXG4gICAgICAgIHVwZGF0ZWRBdDogbm93LFxuICAgICAgfTtcbiAgICAgIGF3YWl0IHdyaXRlSnNvbkZpbGUoc2Vzc2lvblBhdGgsIG5ld1Nlc3Npb24pO1xuICAgICAgcmV0dXJuIG5ld1Nlc3Npb247XG4gICAgfSxcblxuICAgIFwic2Vzc2lvbi5saXN0XCI6IGFzeW5jICh7IHRhZ3MsIGN1cnNvciwgbGltaXQgfSkgPT4ge1xuICAgICAgY29uc3QgYWxsU2Vzc2lvbnMgPSBhd2FpdCByZWFkQWxsRnJvbURpcjxTZXNzaW9uPihzZXNzaW9uRGlyKTtcbiAgICAgIGxldCBmaWx0ZXJlZCA9IGFsbFNlc3Npb25zO1xuICAgICAgaWYgKHRhZ3MgJiYgT2JqZWN0LmtleXModGFncykubGVuZ3RoID4gMCkge1xuICAgICAgICBmaWx0ZXJlZCA9IGZpbHRlcmVkLmZpbHRlcigocykgPT4ge1xuICAgICAgICAgIGNvbnN0IHNlc3Npb25UYWdzID0gcy50YWdzID8/IHt9O1xuICAgICAgICAgIHJldHVybiBPYmplY3QuZW50cmllcyh0YWdzKS5ldmVyeShcbiAgICAgICAgICAgIChba2V5LCB2YWx1ZV0pID0+IHNlc3Npb25UYWdzW2tleV0gPT09IHZhbHVlXG4gICAgICAgICAgKTtcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgICBmaWx0ZXJlZC5zb3J0KChhLCBiKSA9PiBhLmNyZWF0ZWRBdCAtIGIuY3JlYXRlZEF0KTtcbiAgICAgIHJldHVybiBwYWdpbmF0ZSh7IGl0ZW1zOiBmaWx0ZXJlZCwgY3Vyc29yLCBsaW1pdCB9KTtcbiAgICB9LFxuXG4gICAgXCJzZXNzaW9uLmxpc3RCeVNhbmRib3hcIjogYXN5bmMgKHsgc2FuZGJveElkLCB0YWdzLCBjdXJzb3IsIGxpbWl0IH0pID0+IHtcbiAgICAgIGNvbnN0IGFsbFNlc3Npb25zID0gYXdhaXQgcmVhZEFsbEZyb21EaXI8U2Vzc2lvbj4oc2Vzc2lvbkRpcik7XG4gICAgICBsZXQgZmlsdGVyZWQgPSBhbGxTZXNzaW9ucy5maWx0ZXIoKHMpID0+IHMuc2FuZGJveElkID09PSBzYW5kYm94SWQpO1xuICAgICAgaWYgKHRhZ3MgJiYgT2JqZWN0LmtleXModGFncykubGVuZ3RoID4gMCkge1xuICAgICAgICBmaWx0ZXJlZCA9IGZpbHRlcmVkLmZpbHRlcigocykgPT4ge1xuICAgICAgICAgIGNvbnN0IHNlc3Npb25UYWdzID0gcy50YWdzID8/IHt9O1xuICAgICAgICAgIHJldHVybiBPYmplY3QuZW50cmllcyh0YWdzKS5ldmVyeShcbiAgICAgICAgICAgIChba2V5LCB2YWx1ZV0pID0+IHNlc3Npb25UYWdzW2tleV0gPT09IHZhbHVlXG4gICAgICAgICAgKTtcbiAgICAgICAgfSk7XG4gICAgICB9XG4gICAgICBmaWx0ZXJlZC5zb3J0KChhLCBiKSA9PiBhLmNyZWF0ZWRBdCAtIGIuY3JlYXRlZEF0KTtcbiAgICAgIHJldHVybiBwYWdpbmF0ZSh7IGl0ZW1zOiBmaWx0ZXJlZCwgY3Vyc29yLCBsaW1pdCB9KTtcbiAgICB9LFxuXG4gICAgXCJzZXNzaW9uLnRhZy5zZXRcIjogYXN5bmMgKHsgc2Vzc2lvbklkLCB0YWdzIH0pID0+IHtcbiAgICAgIGNvbnN0IHNlc3Npb25QYXRoID0gam9pbihzZXNzaW9uRGlyLCBgJHtzZXNzaW9uSWR9Lmpzb25gKTtcbiAgICAgIGNvbnN0IGV4aXN0aW5nID0gYXdhaXQgcmVhZEpzb248U2Vzc2lvbj4oc2Vzc2lvblBhdGgpO1xuICAgICAgaWYgKCFleGlzdGluZykge1xuICAgICAgICB0aHJvdyBuZXcgRXJyb3IoYFNlc3Npb24gJHtzZXNzaW9uSWR9IG5vdCBmb3VuZGApO1xuICAgICAgfVxuICAgICAgY29uc3QgbWVyZ2VkVGFncyA9IHsgLi4uZXhpc3RpbmcudGFncywgLi4udGFncyB9O1xuICAgICAgY29uc3Qgbm93ID0gRGF0ZS5ub3coKTtcbiAgICAgIGNvbnN0IHVwZGF0ZWRTZXNzaW9uOiBTZXNzaW9uID0ge1xuICAgICAgICAuLi5leGlzdGluZyxcbiAgICAgICAgdGFnczogbWVyZ2VkVGFncyxcbiAgICAgICAgdXBkYXRlZEF0OiBub3csXG4gICAgICB9O1xuICAgICAgYXdhaXQgd3JpdGVKc29uRmlsZShzZXNzaW9uUGF0aCwgdXBkYXRlZFNlc3Npb24pO1xuICAgICAgcmV0dXJuIHVwZGF0ZWRTZXNzaW9uO1xuICAgIH0sXG5cbiAgICBcIm1lc3NhZ2UuZ2V0XCI6IGFzeW5jICh7IGlkIH0pID0+IHtcbiAgICAgIHJldHVybiBhd2FpdCByZWFkSnNvbjxNZXNzYWdlPihqb2luKG1lc3NhZ2VEaXIsIGAke2lkfS5qc29uYCkpO1xuICAgIH0sXG5cbiAgICBcIm1lc3NhZ2Uuc2V0XCI6IGFzeW5jIChtZXNzYWdlKSA9PiB7XG4gICAgICBhd2FpdCB3cml0ZUpzb25GaWxlKGpvaW4obWVzc2FnZURpciwgYCR7bWVzc2FnZS5pZH0uanNvbmApLCBtZXNzYWdlKTtcbiAgICAgIHJldHVybiBtZXNzYWdlO1xuICAgIH0sXG5cbiAgICBcIm1lc3NhZ2UubGlzdFwiOiBhc3luYyAoeyBzZXNzaW9uSWQsIGN1cnNvciwgbGltaXQgfSkgPT4ge1xuICAgICAgY29uc3QgYWxsTWVzc2FnZXMgPSBhd2FpdCByZWFkQWxsRnJvbURpcjxNZXNzYWdlPihtZXNzYWdlRGlyKTtcbiAgICAgIGNvbnN0IGZpbHRlcmVkID0gYWxsTWVzc2FnZXNcbiAgICAgICAgLmZpbHRlcigobSkgPT4gbS5zZXNzaW9uSWQgPT09IHNlc3Npb25JZClcbiAgICAgICAgLnNvcnQoKGEsIGIpID0+IGEuY3JlYXRlZEF0IC0gYi5jcmVhdGVkQXQpO1xuICAgICAgcmV0dXJuIHBhZ2luYXRlKHsgaXRlbXM6IGZpbHRlcmVkLCBjdXJzb3IsIGxpbWl0IH0pO1xuICAgIH0sXG5cbiAgICBcInBhcnQubGlzdEJ5TWVzc2FnZVwiOiBhc3luYyAoeyBtZXNzYWdlSWQsIGN1cnNvciwgbGltaXQgfSkgPT4ge1xuICAgICAgY29uc3QgYWxsUGFydHMgPSBhd2FpdCByZWFkQWxsRnJvbURpcjxQYXJ0PihwYXJ0RGlyKTtcbiAgICAgIGNvbnN0IGZpbHRlcmVkID0gYWxsUGFydHNcbiAgICAgICAgLmZpbHRlcigocCkgPT4gcC5tZXNzYWdlSWQgPT09IG1lc3NhZ2VJZClcbiAgICAgICAgLnNvcnQoKGEsIGIpID0+IGEuaW5kZXggLSBiLmluZGV4KTtcbiAgICAgIHJldHVybiBwYWdpbmF0ZSh7IGl0ZW1zOiBmaWx0ZXJlZCwgY3Vyc29yLCBsaW1pdCB9KTtcbiAgICB9LFxuXG4gICAgXCJwYXJ0Lmxpc3RCeVNlc3Npb25cIjogYXN5bmMgKHsgc2Vzc2lvbklkLCBjdXJzb3IsIGxpbWl0IH0pID0+IHtcbiAgICAgIGNvbnN0IGFsbFBhcnRzID0gYXdhaXQgcmVhZEFsbEZyb21EaXI8UGFydD4ocGFydERpcik7XG4gICAgICBjb25zdCBmaWx0ZXJlZCA9IGFsbFBhcnRzXG4gICAgICAgIC5maWx0ZXIoKHApID0+IHAuc2Vzc2lvbklkID09PSBzZXNzaW9uSWQpXG4gICAgICAgIC5zb3J0KChhLCBiKSA9PiB7XG4gICAgICAgICAgaWYgKGEubWVzc2FnZUlkICE9PSBiLm1lc3NhZ2VJZCkge1xuICAgICAgICAgICAgcmV0dXJuIGEubWVzc2FnZUlkLmxvY2FsZUNvbXBhcmUoYi5tZXNzYWdlSWQpO1xuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4gYS5pbmRleCAtIGIuaW5kZXg7XG4gICAgICAgIH0pO1xuICAgICAgcmV0dXJuIHBhZ2luYXRlKHsgaXRlbXM6IGZpbHRlcmVkLCBjdXJzb3IsIGxpbWl0IH0pO1xuICAgIH0sXG5cbiAgICBcInBhcnQuc2V0XCI6IGFzeW5jIChwYXJ0KSA9PiB7XG4gICAgICBhd2FpdCB3cml0ZUpzb25GaWxlKGpvaW4ocGFydERpciwgYCR7cGFydC5pZH0uanNvbmApLCBwYXJ0KTtcbiAgICAgIHJldHVybiBwYXJ0O1xuICAgIH0sXG5cbiAgICBcInNhbmRib3guZ2V0XCI6IGFzeW5jICh7IGtleSB9KSA9PiB7XG4gICAgICBjb25zdCBzYWZlTmFtZSA9IEJ1ZmZlci5mcm9tKGtleSkudG9TdHJpbmcoXCJiYXNlNjR1cmxcIik7XG4gICAgICBjb25zdCBzYW5kYm94UGF0aCA9IGpvaW4oc2FuZGJveERpciwgYCR7c2FmZU5hbWV9Lmpzb25gKTtcbiAgICAgIGNvbnN0IGRhdGEgPSBhd2FpdCByZWFkSnNvbjxTYW5kYm94UmVjb3JkPihzYW5kYm94UGF0aCk7XG4gICAgICBpZiAoIWRhdGEpIHtcbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICB9XG4gICAgICByZXR1cm4gZGF0YTtcbiAgICB9LFxuXG4gICAgXCJzYW5kYm94LnNldFwiOiBhc3luYyAocmVjb3JkKSA9PiB7XG4gICAgICBjb25zdCBzYWZlTmFtZSA9IEJ1ZmZlci5mcm9tKHJlY29yZC5pZCkudG9TdHJpbmcoXCJiYXNlNjR1cmxcIik7XG4gICAgICBjb25zdCBzYW5kYm94UGF0aCA9IGpvaW4oc2FuZGJveERpciwgYCR7c2FmZU5hbWV9Lmpzb25gKTtcbiAgICAgIGNvbnN0IGV4aXN0aW5nID0gYXdhaXQgcmVhZEpzb248U2FuZGJveFJlY29yZD4oc2FuZGJveFBhdGgpO1xuICAgICAgY29uc3QgbmV3UmVjb3JkOiBTYW5kYm94UmVjb3JkID0ge1xuICAgICAgICAuLi5yZWNvcmQsXG4gICAgICAgIHRhZ3M6IHJlY29yZC50YWdzID8/IGV4aXN0aW5nPy50YWdzID8/IG51bGwsXG4gICAgICB9O1xuICAgICAgYXdhaXQgd3JpdGVKc29uRmlsZShzYW5kYm94UGF0aCwgbmV3UmVjb3JkKTtcbiAgICB9LFxuXG4gICAgXCJzYW5kYm94Lmxpc3RcIjogYXN5bmMgKHsgdGFncywgb3JkZXIsIGN1cnNvciwgbGltaXQgfSkgPT4ge1xuICAgICAgY29uc3QgYWxsU2FuZGJveGVzID0gYXdhaXQgcmVhZEFsbEZyb21EaXI8U2FuZGJveFJlY29yZD4oc2FuZGJveERpcik7XG4gICAgICBsZXQgZmlsdGVyZWQgPSBhbGxTYW5kYm94ZXM7XG4gICAgICBpZiAodGFncyAmJiBPYmplY3Qua2V5cyh0YWdzKS5sZW5ndGggPiAwKSB7XG4gICAgICAgIGZpbHRlcmVkID0gZmlsdGVyZWQuZmlsdGVyKChzKSA9PiB7XG4gICAgICAgICAgY29uc3Qgc2FuZGJveFRhZ3MgPSBzLnRhZ3MgPz8ge307XG4gICAgICAgICAgcmV0dXJuIE9iamVjdC5lbnRyaWVzKHRhZ3MpLmV2ZXJ5KFxuICAgICAgICAgICAgKFtrZXksIHZhbHVlXSkgPT4gc2FuZGJveFRhZ3Nba2V5XSA9PT0gdmFsdWVcbiAgICAgICAgICApO1xuICAgICAgICB9KTtcbiAgICAgIH1cbiAgICAgIGNvbnN0IHNvcnRGaWVsZCA9IG9yZGVyPy5zdGFydHNXaXRoKFwibGFzdEFjdGl2aXR5QXRcIilcbiAgICAgICAgPyBcImxhc3RBY3Rpdml0eUF0XCJcbiAgICAgICAgOiBcImNyZWF0ZWRBdFwiO1xuICAgICAgY29uc3Qgc29ydERpciA9IG9yZGVyPy5lbmRzV2l0aChcIl9kZXNjXCIpID8gLTEgOiAxO1xuICAgICAgZmlsdGVyZWQuc29ydChcbiAgICAgICAgKGEsIGIpID0+IHNvcnREaXIgKiAoKGFbc29ydEZpZWxkXSA/PyAwKSAtIChiW3NvcnRGaWVsZF0gPz8gMCkpXG4gICAgICApO1xuICAgICAgcmV0dXJuIHBhZ2luYXRlKHsgaXRlbXM6IGZpbHRlcmVkLCBjdXJzb3IsIGxpbWl0IH0pO1xuICAgIH0sXG5cbiAgICBcInNhbmRib3gudGFnLnNldFwiOiBhc3luYyAoeyBzYW5kYm94SWQsIHRhZ3MgfSkgPT4ge1xuICAgICAgY29uc3Qgc2FmZU5hbWUgPSBCdWZmZXIuZnJvbShzYW5kYm94SWQpLnRvU3RyaW5nKFwiYmFzZTY0dXJsXCIpO1xuICAgICAgY29uc3Qgc2FuZGJveFBhdGggPSBqb2luKHNhbmRib3hEaXIsIGAke3NhZmVOYW1lfS5qc29uYCk7XG4gICAgICBjb25zdCBleGlzdGluZyA9IGF3YWl0IHJlYWRKc29uPFNhbmRib3hSZWNvcmQ+KHNhbmRib3hQYXRoKTtcbiAgICAgIGlmICghZXhpc3RpbmcpIHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBTYW5kYm94ICR7c2FuZGJveElkfSBub3QgZm91bmRgKTtcbiAgICAgIH1cbiAgICAgIGNvbnN0IG1lcmdlZFRhZ3MgPSB7IC4uLmV4aXN0aW5nLnRhZ3MsIC4uLnRhZ3MgfTtcbiAgICAgIGNvbnN0IHVwZGF0ZWRTYW5kYm94OiBTYW5kYm94UmVjb3JkID0ge1xuICAgICAgICAuLi5leGlzdGluZyxcbiAgICAgICAgdGFnczogbWVyZ2VkVGFncyxcbiAgICAgIH07XG4gICAgICBhd2FpdCB3cml0ZUpzb25GaWxlKHNhbmRib3hQYXRoLCB1cGRhdGVkU2FuZGJveCk7XG4gICAgICByZXR1cm4gdXBkYXRlZFNhbmRib3g7XG4gICAgfSxcblxuICAgIFwic2FuZGJveC5nZXRCeVNlc3Npb25cIjogYXN5bmMgKHsgc2Vzc2lvbklkIH0pID0+IHtcbiAgICAgIGNvbnN0IGFsbFNhbmRib3hlcyA9IGF3YWl0IHJlYWRBbGxGcm9tRGlyPFNhbmRib3hSZWNvcmQ+KHNhbmRib3hEaXIpO1xuICAgICAgY29uc3QgbWF0Y2hpbmcgPSBhbGxTYW5kYm94ZXMuZmlsdGVyKChzKSA9PlxuICAgICAgICBzLmlkLnN0YXJ0c1dpdGgoYCR7c2Vzc2lvbklkfS1gKVxuICAgICAgKTtcbiAgICAgIGlmIChtYXRjaGluZy5sZW5ndGggPT09IDApIHtcbiAgICAgICAgcmV0dXJuIG51bGw7XG4gICAgICB9XG4gICAgICBtYXRjaGluZy5zb3J0KFxuICAgICAgICAoYSwgYikgPT4gKGIubGFzdEFjdGl2aXR5QXQgPz8gMCkgLSAoYS5sYXN0QWN0aXZpdHlBdCA/PyAwKVxuICAgICAgKTtcbiAgICAgIHJldHVybiBtYXRjaGluZ1swXTtcbiAgICB9LFxuXG4gICAgXCJjb21tYW5kLmdldFwiOiBhc3luYyAoeyBpZCB9KSA9PiB7XG4gICAgICByZXR1cm4gYXdhaXQgcmVhZEpzb248Q29tbWFuZD4oam9pbihjb21tYW5kRGlyLCBgJHtpZH0uanNvbmApKTtcbiAgICB9LFxuXG4gICAgXCJjb21tYW5kLnNldFwiOiBhc3luYyAoY29tbWFuZCkgPT4ge1xuICAgICAgYXdhaXQgd3JpdGVKc29uRmlsZShqb2luKGNvbW1hbmREaXIsIGAke2NvbW1hbmQuaWR9Lmpzb25gKSwgY29tbWFuZCk7XG4gICAgICByZXR1cm4gY29tbWFuZDtcbiAgICB9LFxuXG4gICAgXCJjb21tYW5kLmxpc3RcIjogYXN5bmMgKHsgc2Vzc2lvbklkLCBpbmNsdWRlRmluaXNoZWQsIGN1cnNvciwgbGltaXQgfSkgPT4ge1xuICAgICAgY29uc3QgYWxsQ29tbWFuZHMgPSBhd2FpdCByZWFkQWxsRnJvbURpcjxDb21tYW5kPihjb21tYW5kRGlyKTtcbiAgICAgIGxldCBmaWx0ZXJlZCA9IGFsbENvbW1hbmRzLmZpbHRlcigoYykgPT4gYy5zZXNzaW9uSWQgPT09IHNlc3Npb25JZCk7XG4gICAgICBpZiAoIWluY2x1ZGVGaW5pc2hlZCkge1xuICAgICAgICBmaWx0ZXJlZCA9IGZpbHRlcmVkLmZpbHRlcigoYykgPT4gYy5zdGF0dXMgPT09IFwicnVubmluZ1wiKTtcbiAgICAgIH1cbiAgICAgIGZpbHRlcmVkLnNvcnQoKGEsIGIpID0+IGEuc3RhcnRlZEF0IC0gYi5zdGFydGVkQXQpO1xuICAgICAgcmV0dXJuIHBhZ2luYXRlKHsgaXRlbXM6IGZpbHRlcmVkLCBjdXJzb3IsIGxpbWl0IH0pO1xuICAgIH0sXG4gIH07XG59XG4iLCAiaW1wb3J0IHR5cGUgeyBMaXN0UmVzdWx0IH0gZnJvbSBcIi4uL3N0b3JhZ2VcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIHBhZ2luYXRlPFQgZXh0ZW5kcyB7IGlkOiBzdHJpbmcgfT4ob3B0czoge1xuICBpdGVtczogVFtdO1xuICBjdXJzb3I/OiBzdHJpbmc7XG4gIGxpbWl0PzogbnVtYmVyO1xufSk6IExpc3RSZXN1bHQ8VD4ge1xuICBjb25zdCB7IGl0ZW1zLCBjdXJzb3IsIGxpbWl0ID0gNTAgfSA9IG9wdHM7XG4gIGNvbnN0IHN0YXJ0SW5kZXggPSBjdXJzb3IgPyBpdGVtcy5maW5kSW5kZXgoKG0pID0+IG0uaWQgPT09IGN1cnNvcikgKyAxIDogMDtcbiAgY29uc3Qgc2xpY2VkID0gaXRlbXMuc2xpY2Uoc3RhcnRJbmRleCwgc3RhcnRJbmRleCArIGxpbWl0KTtcbiAgY29uc3QgbmV4dEN1cnNvciA9XG4gICAgc3RhcnRJbmRleCArIGxpbWl0IDwgaXRlbXMubGVuZ3RoID8gKHNsaWNlZC5hdCgtMSk/LmlkID8/IG51bGwpIDogbnVsbDtcbiAgcmV0dXJuIHsgaXRlbXM6IHNsaWNlZCwgbmV4dEN1cnNvciB9O1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjs7Ozs7O0FBQUEsU0FBMEIsYUFBYTtBQUN2QyxTQUFTLFlBQVk7OztBQ0RyQixTQUFTLE9BQU8sU0FBUyxVQUFVLGlCQUFpQjtBQUNwRCxTQUFTLFNBQVMsWUFBWTs7O0FDQ3ZCLFNBQVMsU0FBbUMsTUFJakM7QUFDaEIsUUFBTSxFQUFFLE9BQU8sUUFBUSxRQUFRLEdBQUcsSUFBSTtBQUN0QyxRQUFNLGFBQWEsU0FBUyxNQUFNLFVBQVUsQ0FBQyxNQUFNLEVBQUUsT0FBTyxNQUFNLElBQUksSUFBSTtBQUMxRSxRQUFNLFNBQVMsTUFBTSxNQUFNLFlBQVksYUFBYSxLQUFLO0FBQ3pELFFBQU0sYUFDSixhQUFhLFFBQVEsTUFBTSxTQUFVLE9BQU8sR0FBRyxFQUFFLEdBQUcsTUFBTSxPQUFRO0FBQ3BF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
@@ -1,153 +0,0 @@
1
- // src/sandbox/process-manager.ts
2
- var DEFAULT_WAIT_UNTIL = 3e4;
3
- var RUN_SCRIPT = `#!/bin/sh
4
- # Process runner for Agent SDK
5
- # All parameters passed via environment variables to avoid escaping issues
6
- # Output is base64 encoded to avoid JSON escaping issues
7
-
8
- AGENT_DIR="$HOME/.agent"
9
- CWD_FILE="$AGENT_DIR/cwd/$SESSION_ID"
10
-
11
- # Get current working directory (per-session)
12
- if [ -f "$CWD_FILE" ]; then
13
- CWD=$(cat "$CWD_FILE")
14
- else
15
- CWD="$HOME"
16
- fi
17
-
18
- # Decode command
19
- CMD=$(echo "$CMD_BASE64" | base64 -d)
20
-
21
- # Background mode (waitUntil = 0)
22
- if [ "$WAIT_UNTIL" = "0" ]; then
23
- cd "$CWD" || cd "$HOME"
24
-
25
- # Generate a simple numeric ID for output file
26
- OUTPUT_ID="$(date +%s)$$"
27
- OUTPUT_FILE="$AGENT_DIR/outputs/$OUTPUT_ID.log"
28
-
29
- # Double-fork to fully detach the process
30
- (
31
- (
32
- eval "$CMD"
33
- pwd > "$CWD_FILE" 2>/dev/null
34
- ) > "$OUTPUT_FILE" 2>&1 < /dev/null &
35
- echo $! > "$AGENT_DIR/pids/$OUTPUT_ID.pid"
36
- )
37
-
38
- # Small delay to ensure PID file is written
39
- sleep 0.05
40
-
41
- # Read PID
42
- if [ -f "$AGENT_DIR/pids/$OUTPUT_ID.pid" ]; then
43
- PID=$(cat "$AGENT_DIR/pids/$OUTPUT_ID.pid")
44
- else
45
- PID=0
46
- fi
47
-
48
- # Output JSON result (no output for background, so no encoding needed)
49
- printf '{"pid":%d,"outputBase64":"","exitCode":-1,"status":"running","outputFile":"%s","cwd":"%s"}\\n' \\
50
- "$PID" "$OUTPUT_FILE" "$CWD"
51
- exit 0
52
- fi
53
-
54
- # Foreground mode (waitUntil > 0) - run directly and capture output
55
- cd "$CWD" || cd "$HOME"
56
-
57
- # Run command, capture output and exit code
58
- OUTPUT=$(eval "$CMD" 2>&1)
59
- EXIT_CODE=$?
60
-
61
- # Update CWD after command
62
- NEW_CWD=$(pwd)
63
- echo "$NEW_CWD" > "$CWD_FILE"
64
-
65
- # Determine status
66
- if [ $EXIT_CODE -eq 0 ]; then
67
- STATUS="completed"
68
- else
69
- STATUS="failed"
70
- fi
71
-
72
- # Base64 encode output to avoid ALL escaping issues
73
- OUTPUT_BASE64=$(printf '%s' "$OUTPUT" | base64 | tr -d '\\n')
74
-
75
- # Output JSON result with base64-encoded output
76
- printf '{"pid":0,"outputBase64":"%s","exitCode":%d,"status":"%s","outputFile":"","cwd":"%s"}\\n' \\
77
- "$OUTPUT_BASE64" "$EXIT_CODE" "$STATUS" "$NEW_CWD"
78
- `;
79
- var createProcessManager = (opts) => {
80
- const { sandbox, sessionId } = opts;
81
- let initialized = false;
82
- const init = async () => {
83
- if (initialized) {
84
- return;
85
- }
86
- const result = await sandbox.exec({
87
- command: "sh",
88
- args: [
89
- "-c",
90
- `mkdir -p $HOME/.agent/bin $HOME/.agent/pids $HOME/.agent/outputs $HOME/.agent/cwd
91
- cat > $HOME/.agent/bin/run.sh << 'SCRIPT_EOF'
92
- ${RUN_SCRIPT}
93
- SCRIPT_EOF
94
- chmod +x $HOME/.agent/bin/run.sh`
95
- ]
96
- });
97
- if (result instanceof Error) {
98
- throw result;
99
- }
100
- await result.result;
101
- initialized = true;
102
- };
103
- const run = async (opts2) => {
104
- await init();
105
- const { command, waitUntil = DEFAULT_WAIT_UNTIL } = opts2;
106
- const cmdBase64 = Buffer.from(command, "utf-8").toString("base64");
107
- const result = await sandbox.exec({
108
- command: "sh",
109
- args: [
110
- "-c",
111
- `CMD_BASE64="${cmdBase64}" WAIT_UNTIL="${waitUntil}" SESSION_ID="${sessionId}" $HOME/.agent/bin/run.sh`
112
- ]
113
- });
114
- if (result instanceof Error) {
115
- throw result;
116
- }
117
- const { stdout } = await result.result;
118
- const parsed = JSON.parse(stdout.trim());
119
- const output = parsed.outputBase64 ? Buffer.from(parsed.outputBase64, "base64").toString("utf-8") : "";
120
- return {
121
- pid: parsed.pid,
122
- output,
123
- exitCode: parsed.exitCode,
124
- status: parsed.status,
125
- cwd: parsed.cwd,
126
- outputFile: parsed.outputFile
127
- };
128
- };
129
- const getCwd = async () => {
130
- await init();
131
- const result = await sandbox.exec({
132
- command: "sh",
133
- args: [
134
- "-c",
135
- `cat $HOME/.agent/cwd/${sessionId} 2>/dev/null || echo "$HOME"`
136
- ]
137
- });
138
- if (result instanceof Error) {
139
- return process.cwd();
140
- }
141
- const { stdout } = await result.result;
142
- return stdout.trim() || process.cwd();
143
- };
144
- return {
145
- init,
146
- run,
147
- getCwd
148
- };
149
- };
150
- export {
151
- createProcessManager
152
- };
153
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL3NhbmRib3gvcHJvY2Vzcy1tYW5hZ2VyLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgdHlwZSB7IEJhc2hSZXN1bHQsIFNhbmRib3ggfSBmcm9tIFwiLi90eXBlc1wiO1xuXG5jb25zdCBERUZBVUxUX1dBSVRfVU5USUwgPSAzMDAwMDtcblxuLyoqXG4gKiBTaGVsbCBzY3JpcHQgdGhhdCBoYW5kbGVzIGFsbCBwcm9jZXNzIGV4ZWN1dGlvbiBsb2dpYy5cbiAqIEluc3RhbGxlZCB0byB+Ly5hZ2VudC9iaW4vcnVuLnNoIGR1cmluZyBpbml0KCkuXG4gKi9cbmNvbnN0IFJVTl9TQ1JJUFQgPSBgIyEvYmluL3NoXG4jIFByb2Nlc3MgcnVubmVyIGZvciBBZ2VudCBTREtcbiMgQWxsIHBhcmFtZXRlcnMgcGFzc2VkIHZpYSBlbnZpcm9ubWVudCB2YXJpYWJsZXMgdG8gYXZvaWQgZXNjYXBpbmcgaXNzdWVzXG4jIE91dHB1dCBpcyBiYXNlNjQgZW5jb2RlZCB0byBhdm9pZCBKU09OIGVzY2FwaW5nIGlzc3Vlc1xuXG5BR0VOVF9ESVI9XCIkSE9NRS8uYWdlbnRcIlxuQ1dEX0ZJTEU9XCIkQUdFTlRfRElSL2N3ZC8kU0VTU0lPTl9JRFwiXG5cbiMgR2V0IGN1cnJlbnQgd29ya2luZyBkaXJlY3RvcnkgKHBlci1zZXNzaW9uKVxuaWYgWyAtZiBcIiRDV0RfRklMRVwiIF07IHRoZW5cbiAgQ1dEPSQoY2F0IFwiJENXRF9GSUxFXCIpXG5lbHNlXG4gIENXRD1cIiRIT01FXCJcbmZpXG5cbiMgRGVjb2RlIGNvbW1hbmRcbkNNRD0kKGVjaG8gXCIkQ01EX0JBU0U2NFwiIHwgYmFzZTY0IC1kKVxuXG4jIEJhY2tncm91bmQgbW9kZSAod2FpdFVudGlsID0gMClcbmlmIFsgXCIkV0FJVF9VTlRJTFwiID0gXCIwXCIgXTsgdGhlblxuICBjZCBcIiRDV0RcIiB8fCBjZCBcIiRIT01FXCJcblxuICAjIEdlbmVyYXRlIGEgc2ltcGxlIG51bWVyaWMgSUQgZm9yIG91dHB1dCBmaWxlXG4gIE9VVFBVVF9JRD1cIiQoZGF0ZSArJXMpJCRcIlxuICBPVVRQVVRfRklMRT1cIiRBR0VOVF9ESVIvb3V0cHV0cy8kT1VUUFVUX0lELmxvZ1wiXG5cbiAgIyBEb3VibGUtZm9yayB0byBmdWxseSBkZXRhY2ggdGhlIHByb2Nlc3NcbiAgKFxuICAgIChcbiAgICAgIGV2YWwgXCIkQ01EXCJcbiAgICAgIHB3ZCA+IFwiJENXRF9GSUxFXCIgMj4vZGV2L251bGxcbiAgICApID4gXCIkT1VUUFVUX0ZJTEVcIiAyPiYxIDwgL2Rldi9udWxsICZcbiAgICBlY2hvICQhID4gXCIkQUdFTlRfRElSL3BpZHMvJE9VVFBVVF9JRC5waWRcIlxuICApXG5cbiAgIyBTbWFsbCBkZWxheSB0byBlbnN1cmUgUElEIGZpbGUgaXMgd3JpdHRlblxuICBzbGVlcCAwLjA1XG5cbiAgIyBSZWFkIFBJRFxuICBpZiBbIC1mIFwiJEFHRU5UX0RJUi9waWRzLyRPVVRQVVRfSUQucGlkXCIgXTsgdGhlblxuICAgIFBJRD0kKGNhdCBcIiRBR0VOVF9ESVIvcGlkcy8kT1VUUFVUX0lELnBpZFwiKVxuICBlbHNlXG4gICAgUElEPTBcbiAgZmlcblxuICAjIE91dHB1dCBKU09OIHJlc3VsdCAobm8gb3V0cHV0IGZvciBiYWNrZ3JvdW5kLCBzbyBubyBlbmNvZGluZyBuZWVkZWQpXG4gIHByaW50ZiAne1wicGlkXCI6JWQsXCJvdXRwdXRCYXNlNjRcIjpcIlwiLFwiZXhpdENvZGVcIjotMSxcInN0YXR1c1wiOlwicnVubmluZ1wiLFwib3V0cHV0RmlsZVwiOlwiJXNcIixcImN3ZFwiOlwiJXNcIn1cXFxcbicgXFxcXFxuICAgIFwiJFBJRFwiIFwiJE9VVFBVVF9GSUxFXCIgXCIkQ1dEXCJcbiAgZXhpdCAwXG5maVxuXG4jIEZvcmVncm91bmQgbW9kZSAod2FpdFVudGlsID4gMCkgLSBydW4gZGlyZWN0bHkgYW5kIGNhcHR1cmUgb3V0cHV0XG5jZCBcIiRDV0RcIiB8fCBjZCBcIiRIT01FXCJcblxuIyBSdW4gY29tbWFuZCwgY2FwdHVyZSBvdXRwdXQgYW5kIGV4aXQgY29kZVxuT1VUUFVUPSQoZXZhbCBcIiRDTURcIiAyPiYxKVxuRVhJVF9DT0RFPSQ/XG5cbiMgVXBkYXRlIENXRCBhZnRlciBjb21tYW5kXG5ORVdfQ1dEPSQocHdkKVxuZWNobyBcIiRORVdfQ1dEXCIgPiBcIiRDV0RfRklMRVwiXG5cbiMgRGV0ZXJtaW5lIHN0YXR1c1xuaWYgWyAkRVhJVF9DT0RFIC1lcSAwIF07IHRoZW5cbiAgU1RBVFVTPVwiY29tcGxldGVkXCJcbmVsc2VcbiAgU1RBVFVTPVwiZmFpbGVkXCJcbmZpXG5cbiMgQmFzZTY0IGVuY29kZSBvdXRwdXQgdG8gYXZvaWQgQUxMIGVzY2FwaW5nIGlzc3Vlc1xuT1VUUFVUX0JBU0U2ND0kKHByaW50ZiAnJXMnIFwiJE9VVFBVVFwiIHwgYmFzZTY0IHwgdHIgLWQgJ1xcXFxuJylcblxuIyBPdXRwdXQgSlNPTiByZXN1bHQgd2l0aCBiYXNlNjQtZW5jb2RlZCBvdXRwdXRcbnByaW50ZiAne1wicGlkXCI6MCxcIm91dHB1dEJhc2U2NFwiOlwiJXNcIixcImV4aXRDb2RlXCI6JWQsXCJzdGF0dXNcIjpcIiVzXCIsXCJvdXRwdXRGaWxlXCI6XCJcIixcImN3ZFwiOlwiJXNcIn1cXFxcbicgXFxcXFxuICBcIiRPVVRQVVRfQkFTRTY0XCIgXCIkRVhJVF9DT0RFXCIgXCIkU1RBVFVTXCIgXCIkTkVXX0NXRFwiXG5gO1xuXG50eXBlIFJ1bk9wdGlvbnMgPSB7XG4gIGNvbW1hbmQ6IHN0cmluZztcbiAgLyoqXG4gICAqIE1heCBtcyB0byB3YWl0IGZvciBjb21wbGV0aW9uLlxuICAgKiAtIDA6IEJhY2tncm91bmQgbW9kZSAtIHJldHVybiBpbW1lZGlhdGVseSB3aXRoIFBJRFxuICAgKiAtID4wOiBGb3JlZ3JvdW5kIG1vZGUgLSB3YWl0IGZvciBjb21wbGV0aW9uIChkZWZhdWx0OiAzMDAwMClcbiAgICovXG4gIHdhaXRVbnRpbD86IG51bWJlcjtcbn07XG5cbi8qKlxuICogUHJvY2VzcyBtYW5hZ2VyIHRoYXQgdXNlcyBhIHNpbmdsZSBzaGVsbCBzY3JpcHQgdG8gaGFuZGxlIGFsbCBleGVjdXRpb24gbG9naWMuXG4gKiBSZWR1Y2VzIHJvdW5kLXRyaXBzIHRvIHRoZSBzYW5kYm94IGJ5IGRvaW5nIGV2ZXJ5dGhpbmcgaW4gb25lIGV4ZWMgY2FsbC5cbiAqL1xuZXhwb3J0IGNvbnN0IGNyZWF0ZVByb2Nlc3NNYW5hZ2VyID0gKG9wdHM6IHtcbiAgc2FuZGJveDogU2FuZGJveDtcbiAgc2Vzc2lvbklkOiBzdHJpbmc7XG4gIGdlbmVyYXRlSWQ6ICgpID0+IHN0cmluZztcbn0pID0+IHtcbiAgY29uc3QgeyBzYW5kYm94LCBzZXNzaW9uSWQgfSA9IG9wdHM7XG4gIGxldCBpbml0aWFsaXplZCA9IGZhbHNlO1xuXG4gIGNvbnN0IGluaXQgPSBhc3luYyAoKTogUHJvbWlzZTx2b2lkPiA9PiB7XG4gICAgaWYgKGluaXRpYWxpemVkKSB7XG4gICAgICByZXR1cm47XG4gICAgfVxuXG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgc2FuZGJveC5leGVjKHtcbiAgICAgIGNvbW1hbmQ6IFwic2hcIixcbiAgICAgIGFyZ3M6IFtcbiAgICAgICAgXCItY1wiLFxuICAgICAgICBgbWtkaXIgLXAgJEhPTUUvLmFnZW50L2JpbiAkSE9NRS8uYWdlbnQvcGlkcyAkSE9NRS8uYWdlbnQvb3V0cHV0cyAkSE9NRS8uYWdlbnQvY3dkXG5jYXQgPiAkSE9NRS8uYWdlbnQvYmluL3J1bi5zaCA8PCAnU0NSSVBUX0VPRidcbiR7UlVOX1NDUklQVH1cblNDUklQVF9FT0ZcbmNobW9kICt4ICRIT01FLy5hZ2VudC9iaW4vcnVuLnNoYCxcbiAgICAgIF0sXG4gICAgfSk7XG5cbiAgICBpZiAocmVzdWx0IGluc3RhbmNlb2YgRXJyb3IpIHtcbiAgICAgIHRocm93IHJlc3VsdDtcbiAgICB9XG4gICAgYXdhaXQgcmVzdWx0LnJlc3VsdDtcbiAgICBpbml0aWFsaXplZCA9IHRydWU7XG4gIH07XG5cbiAgY29uc3QgcnVuID0gYXN5bmMgKG9wdHM6IFJ1bk9wdGlvbnMpOiBQcm9taXNlPEJhc2hSZXN1bHQ+ID0+IHtcbiAgICBhd2FpdCBpbml0KCk7XG5cbiAgICBjb25zdCB7IGNvbW1hbmQsIHdhaXRVbnRpbCA9IERFRkFVTFRfV0FJVF9VTlRJTCB9ID0gb3B0cztcbiAgICBjb25zdCBjbWRCYXNlNjQgPSBCdWZmZXIuZnJvbShjb21tYW5kLCBcInV0Zi04XCIpLnRvU3RyaW5nKFwiYmFzZTY0XCIpO1xuXG4gICAgY29uc3QgcmVzdWx0ID0gYXdhaXQgc2FuZGJveC5leGVjKHtcbiAgICAgIGNvbW1hbmQ6IFwic2hcIixcbiAgICAgIGFyZ3M6IFtcbiAgICAgICAgXCItY1wiLFxuICAgICAgICBgQ01EX0JBU0U2ND1cIiR7Y21kQmFzZTY0fVwiIFdBSVRfVU5USUw9XCIke3dhaXRVbnRpbH1cIiBTRVNTSU9OX0lEPVwiJHtzZXNzaW9uSWR9XCIgJEhPTUUvLmFnZW50L2Jpbi9ydW4uc2hgLFxuICAgICAgXSxcbiAgICB9KTtcblxuICAgIGlmIChyZXN1bHQgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgICAgdGhyb3cgcmVzdWx0O1xuICAgIH1cblxuICAgIGNvbnN0IHsgc3Rkb3V0IH0gPSBhd2FpdCByZXN1bHQucmVzdWx0O1xuICAgIGNvbnN0IHBhcnNlZCA9IEpTT04ucGFyc2Uoc3Rkb3V0LnRyaW0oKSkgYXMge1xuICAgICAgcGlkOiBudW1iZXI7XG4gICAgICBvdXRwdXRCYXNlNjQ6IHN0cmluZztcbiAgICAgIGV4aXRDb2RlOiBudW1iZXI7XG4gICAgICBzdGF0dXM6IFwicnVubmluZ1wiIHwgXCJjb21wbGV0ZWRcIiB8IFwiZmFpbGVkXCI7XG4gICAgICBvdXRwdXRGaWxlOiBzdHJpbmc7XG4gICAgICBjd2Q6IHN0cmluZztcbiAgICB9O1xuXG4gICAgLy8gRGVjb2RlIGJhc2U2NCBvdXRwdXRcbiAgICBjb25zdCBvdXRwdXQgPSBwYXJzZWQub3V0cHV0QmFzZTY0XG4gICAgICA/IEJ1ZmZlci5mcm9tKHBhcnNlZC5vdXRwdXRCYXNlNjQsIFwiYmFzZTY0XCIpLnRvU3RyaW5nKFwidXRmLThcIilcbiAgICAgIDogXCJcIjtcblxuICAgIHJldHVybiB7XG4gICAgICBwaWQ6IHBhcnNlZC5waWQsXG4gICAgICBvdXRwdXQsXG4gICAgICBleGl0Q29kZTogcGFyc2VkLmV4aXRDb2RlLFxuICAgICAgc3RhdHVzOiBwYXJzZWQuc3RhdHVzLFxuICAgICAgY3dkOiBwYXJzZWQuY3dkLFxuICAgICAgb3V0cHV0RmlsZTogcGFyc2VkLm91dHB1dEZpbGUsXG4gICAgfTtcbiAgfTtcblxuICBjb25zdCBnZXRDd2QgPSBhc3luYyAoKTogUHJvbWlzZTxzdHJpbmc+ID0+IHtcbiAgICBhd2FpdCBpbml0KCk7XG5cbiAgICBjb25zdCByZXN1bHQgPSBhd2FpdCBzYW5kYm94LmV4ZWMoe1xuICAgICAgY29tbWFuZDogXCJzaFwiLFxuICAgICAgYXJnczogW1xuICAgICAgICBcIi1jXCIsXG4gICAgICAgIGBjYXQgJEhPTUUvLmFnZW50L2N3ZC8ke3Nlc3Npb25JZH0gMj4vZGV2L251bGwgfHwgZWNobyBcIiRIT01FXCJgLFxuICAgICAgXSxcbiAgICB9KTtcblxuICAgIGlmIChyZXN1bHQgaW5zdGFuY2VvZiBFcnJvcikge1xuICAgICAgcmV0dXJuIHByb2Nlc3MuY3dkKCk7XG4gICAgfVxuXG4gICAgY29uc3QgeyBzdGRvdXQgfSA9IGF3YWl0IHJlc3VsdC5yZXN1bHQ7XG4gICAgcmV0dXJuIHN0ZG91dC50cmltKCkgfHwgcHJvY2Vzcy5jd2QoKTtcbiAgfTtcblxuICByZXR1cm4ge1xuICAgIGluaXQsXG4gICAgcnVuLFxuICAgIGdldEN3ZCxcbiAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIFByb2Nlc3NNYW5hZ2VyID0gUmV0dXJuVHlwZTx0eXBlb2YgY3JlYXRlUHJvY2Vzc01hbmFnZXI+O1xuIl0sCiAgIm1hcHBpbmdzIjogIjtBQUVBLElBQU0scUJBQXFCO0FBTTNCLElBQU0sYUFBYTtBQUFBO0FBQUE7QUFB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
@@ -1,10 +0,0 @@
1
- import "./chunk-36X6L7SK.mjs";
2
- import {
3
- getSandbox
4
- } from "./chunk-4RGMKC2M.mjs";
5
- import "./chunk-6ICYKNCC.mjs";
6
- import "./chunk-24DJSI7C.mjs";
7
- export {
8
- getSandbox
9
- };
10
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
@@ -1,27 +0,0 @@
1
- import {
2
- CommandResultSchema,
3
- CommandSchema,
4
- MessageSchema,
5
- PartSchema,
6
- SandboxConfigSchema,
7
- SandboxRecordSchema,
8
- SessionSchema,
9
- handleStorageRpc,
10
- methods
11
- } from "./chunk-6ICYKNCC.mjs";
12
- import {
13
- getStorage
14
- } from "./chunk-24DJSI7C.mjs";
15
- export {
16
- CommandResultSchema,
17
- CommandSchema,
18
- MessageSchema,
19
- PartSchema,
20
- SandboxConfigSchema,
21
- SandboxRecordSchema,
22
- SessionSchema,
23
- getStorage,
24
- handleStorageRpc,
25
- methods
26
- };
27
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
File without changes