experimental-agent 0.2.1 → 0.3.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.
Files changed (71) hide show
  1. package/README.md +55 -254
  2. package/dist/adapter-BigchkkI.d.mts +201 -0
  3. package/dist/adapter-BigchkkI.d.ts +201 -0
  4. package/dist/chunk-BFFNCESS.mjs +302 -0
  5. package/dist/chunk-C4VSUEY2.mjs +72 -0
  6. package/dist/chunk-DOD4MC5D.mjs +196 -0
  7. package/dist/chunk-ELWIUJUK.mjs +96 -0
  8. package/dist/chunk-GKASMIBR.mjs +50 -0
  9. package/dist/chunk-JO3JDCH5.mjs +107 -0
  10. package/dist/chunk-MSWINCCM.mjs +128 -0
  11. package/dist/chunk-RT72C52I.mjs +324 -0
  12. package/dist/chunk-ZUFJJYC4.mjs +150 -0
  13. package/dist/{handler-FRUPZ4LX.mjs → docker-QPCLWLYR.mjs} +3 -4
  14. package/dist/entry-BmQ8FO-5.d.ts +36 -0
  15. package/dist/entry-CZd9aAwn.d.mts +36 -0
  16. package/dist/index.d.mts +415 -18
  17. package/dist/index.d.ts +415 -18
  18. package/dist/index.js +3036 -5494
  19. package/dist/index.mjs +3264 -1142
  20. package/dist/lifecycle-workflow-steps.d.mts +5 -0
  21. package/dist/lifecycle-workflow-steps.d.ts +5 -0
  22. package/dist/lifecycle-workflow-steps.js +263 -0
  23. package/dist/lifecycle-workflow-steps.mjs +9 -0
  24. package/dist/lifecycle-workflow.d.mts +6 -6
  25. package/dist/lifecycle-workflow.d.ts +6 -6
  26. package/dist/lifecycle-workflow.js +192 -905
  27. package/dist/lifecycle-workflow.mjs +3 -1
  28. package/dist/local-KJ3BSIFJ.mjs +8 -0
  29. package/dist/next/loader.d.mts +1 -0
  30. package/dist/next/loader.d.ts +1 -0
  31. package/dist/next/loader.js +44 -18
  32. package/dist/next/loader.mjs +18 -13
  33. package/dist/next.js +32 -9
  34. package/dist/next.mjs +6 -4
  35. package/dist/{process-manager-JDUJDYGU.mjs → process-manager-WQHAIVRB.mjs} +1 -1
  36. package/dist/sandbox.d.mts +6 -0
  37. package/dist/sandbox.d.ts +6 -0
  38. package/dist/sandbox.js +1070 -0
  39. package/dist/sandbox.mjs +19 -0
  40. package/dist/steps-BnkRQKlc.d.ts +173 -0
  41. package/dist/steps-u-mGDbP_.d.mts +173 -0
  42. package/dist/storage.d.mts +11 -0
  43. package/dist/storage.d.ts +11 -0
  44. package/dist/storage.js +234 -0
  45. package/dist/storage.mjs +12 -0
  46. package/dist/vercel-QZ6INPMV.mjs +11 -0
  47. package/package.json +26 -5
  48. package/dist/agent-workflow.d.mts +0 -30
  49. package/dist/agent-workflow.d.ts +0 -30
  50. package/dist/agent-workflow.js +0 -5433
  51. package/dist/agent-workflow.mjs +0 -14
  52. package/dist/chunk-AML2VCQS.mjs +0 -1287
  53. package/dist/chunk-FQ67QZOI.mjs +0 -75
  54. package/dist/chunk-NO7RHGTH.mjs +0 -2367
  55. package/dist/chunk-NXDVNJRS.mjs +0 -106
  56. package/dist/chunk-OZZVS6L5.mjs +0 -139
  57. package/dist/chunk-QRWGDFFY.mjs +0 -75
  58. package/dist/chunk-SJVFFE5D.mjs +0 -402
  59. package/dist/chunk-TAXLUVIC.mjs +0 -1
  60. package/dist/chunk-TGNVXSMX.mjs +0 -399
  61. package/dist/chunk-YRYXN7W4.mjs +0 -48
  62. package/dist/chunk-ZIAHPXOJ.mjs +0 -595
  63. package/dist/client-BKA7XBGW.mjs +0 -15
  64. package/dist/client-CEeSFGva.d.mts +0 -2376
  65. package/dist/client-CEeSFGva.d.ts +0 -2376
  66. package/dist/docker-FB2MJTHJ.mjs +0 -12
  67. package/dist/local-fs-handlers-SYOCKTPN.mjs +0 -447
  68. package/dist/sandbox-UENKQV3T.mjs +0 -21
  69. package/dist/storage-LSDMRW73.mjs +0 -20
  70. package/dist/vercel-SD3JTECG.mjs +0 -20
  71. package/dist/vercel-sdk-I6A4MVAN.mjs +0 -8
@@ -5,9 +5,6 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
5
5
  var __getOwnPropNames = Object.getOwnPropertyNames;
6
6
  var __getProtoOf = Object.getPrototypeOf;
7
7
  var __hasOwnProp = Object.prototype.hasOwnProperty;
8
- var __esm = (fn, res) => function __init() {
9
- return fn && (res = (0, fn[__getOwnPropNames(fn)[0]])(fn = 0)), res;
10
- };
11
8
  var __export = (target, all) => {
12
9
  for (var name in all)
13
10
  __defProp(target, name, { get: all[name], enumerable: true });
@@ -30,887 +27,142 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
30
27
  ));
31
28
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
32
29
 
33
- // src/sandbox/bindings/vercel-sdk.ts
34
- var vercel_sdk_exports = {};
35
- __export(vercel_sdk_exports, {
36
- Sandbox: () => import_sandbox.Sandbox
37
- });
38
- var import_sandbox;
39
- var init_vercel_sdk = __esm({
40
- "src/sandbox/bindings/vercel-sdk.ts"() {
41
- "use strict";
42
- import_sandbox = require("@vercel/sandbox");
43
- }
44
- });
45
-
46
- // src/errors.ts
47
- var errore, SessionNotFoundError, SessionError, SandboxNotFoundError, StorageError, StorageConflictError, SandboxError, MessageNotFoundError;
48
- var init_errors = __esm({
49
- "src/errors.ts"() {
50
- "use strict";
51
- errore = __toESM(require("errore"));
52
- SessionNotFoundError = class extends errore.createTaggedError({
53
- name: "SessionNotFoundError",
54
- message: "Session $id not found"
55
- }) {
56
- };
57
- SessionError = class extends errore.createTaggedError({
58
- name: "SessionError",
59
- message: "Session $id failed: $reason"
60
- }) {
61
- };
62
- SandboxNotFoundError = class extends errore.createTaggedError({
63
- name: "SandboxNotFoundError",
64
- message: "Sandbox $id not found"
65
- }) {
66
- };
67
- StorageError = class extends errore.createTaggedError({
68
- name: "StorageError",
69
- message: "$reason"
70
- }) {
71
- };
72
- StorageConflictError = class extends errore.createTaggedError({
73
- name: "StorageConflictError",
74
- message: "$reason"
75
- }) {
76
- };
77
- SandboxError = class extends errore.createTaggedError({
78
- name: "SandboxError",
79
- message: "$reason"
80
- }) {
81
- };
82
- MessageNotFoundError = class extends errore.createTaggedError({
83
- name: "MessageNotFoundError",
84
- message: "Message $id not found"
85
- }) {
86
- };
87
- }
30
+ // src/sandbox/bindings/vercel-lifecycle/workflow.ts
31
+ var workflow_exports = {};
32
+ __export(workflow_exports, {
33
+ sandboxLifecycleWorkflow: () => sandboxLifecycleWorkflow
88
34
  });
35
+ module.exports = __toCommonJS(workflow_exports);
36
+ var import_workflow = require("workflow");
89
37
 
90
- // src/storage/client.ts
91
- function getStorageClient(rpcFn, name) {
92
- async function rpc(method, params) {
93
- const result = await rpcFn({ name, method, params });
94
- if ("error" in result) {
95
- if (result.error.code === "CONFLICT") {
96
- throw new StorageConflictError({ reason: result.error.message });
97
- }
98
- throw new StorageError({
99
- reason: `[${result.error.code}] ${result.error.message}`
100
- });
101
- }
102
- return result.result;
103
- }
104
- return {
105
- session: {
106
- get: async (id) => {
107
- try {
108
- const result = await rpc("session.get", { id });
109
- if (result === null) {
110
- return new SessionNotFoundError({ id });
111
- }
112
- return result;
113
- } catch (e) {
114
- if (e instanceof StorageError) {
115
- return e;
116
- }
117
- return new StorageError({ reason: String(e), cause: e });
118
- }
119
- },
120
- set: async (session) => {
121
- try {
122
- return await rpc("session.set", session);
123
- } catch (e) {
124
- if (e instanceof StorageError) {
125
- return e;
126
- }
127
- return new StorageError({ reason: String(e), cause: e });
128
- }
129
- },
130
- update: async (opts) => {
131
- try {
132
- return await rpc("session.update", opts);
133
- } catch (e) {
134
- if (e instanceof StorageConflictError) {
135
- return e;
136
- }
137
- if (e instanceof StorageError) {
138
- return e;
139
- }
140
- return new StorageError({ reason: String(e), cause: e });
141
- }
142
- },
143
- delete: async (id) => {
144
- try {
145
- await rpc("session.delete", { id });
146
- } catch (e) {
147
- if (e instanceof StorageError) {
148
- return e;
149
- }
150
- return new StorageError({ reason: String(e), cause: e });
151
- }
152
- },
153
- list: async (opts) => {
154
- try {
155
- return await rpc("session.list", {
156
- tags: opts?.tags,
157
- order: opts?.order,
158
- cursor: opts?.cursor,
159
- limit: opts?.limit
160
- });
161
- } catch (e) {
162
- if (e instanceof StorageError) {
163
- return e;
164
- }
165
- return new StorageError({ reason: String(e), cause: e });
166
- }
167
- },
168
- listBySandbox: async (opts) => {
169
- try {
170
- return await rpc("session.listBySandbox", {
171
- sandboxId: opts.sandboxId,
172
- tags: opts.tags,
173
- order: opts.order,
174
- cursor: opts.cursor,
175
- limit: opts.limit
176
- });
177
- } catch (e) {
178
- if (e instanceof StorageError) {
179
- return e;
180
- }
181
- return new StorageError({ reason: String(e), cause: e });
182
- }
183
- },
184
- tag: {
185
- set: async ({ sessionId, tags }) => {
186
- try {
187
- return await rpc("session.tag.set", { sessionId, tags });
188
- } catch (e) {
189
- if (e instanceof StorageError) {
190
- return e;
191
- }
192
- return new StorageError({ reason: String(e), cause: e });
193
- }
194
- }
195
- }
196
- },
197
- message: {
198
- list: async (sessionId, opts) => {
199
- try {
200
- return await rpc("message.list", {
201
- sessionId,
202
- cursor: opts?.cursor,
203
- limit: opts?.limit
204
- });
205
- } catch (e) {
206
- if (e instanceof StorageError) {
207
- return e;
208
- }
209
- return new StorageError({ reason: String(e), cause: e });
210
- }
211
- },
212
- get: async (id) => {
213
- try {
214
- const result = await rpc("message.get", { id });
215
- if (result === null) {
216
- return new MessageNotFoundError({ id });
217
- }
218
- return result;
219
- } catch (e) {
220
- if (e instanceof StorageError) {
221
- return e;
222
- }
223
- return new StorageError({ reason: String(e), cause: e });
224
- }
225
- },
226
- set: async (message) => {
227
- try {
228
- return await rpc("message.set", message);
229
- } catch (e) {
230
- if (e instanceof StorageError) {
231
- return e;
232
- }
233
- return new StorageError({ reason: String(e), cause: e });
234
- }
235
- }
236
- },
237
- part: {
238
- listByMessage: async (messageId, opts) => {
239
- try {
240
- const result = await rpc("part.listByMessage", {
241
- messageId,
242
- cursor: opts?.cursor,
243
- limit: opts?.limit
244
- });
245
- return result;
246
- } catch (e) {
247
- if (e instanceof StorageError) {
248
- return e;
249
- }
250
- return new StorageError({ reason: String(e), cause: e });
251
- }
252
- },
253
- listBySession: async (sessionId, opts) => {
254
- try {
255
- const result = await rpc("part.listBySession", {
256
- sessionId,
257
- cursor: opts?.cursor,
258
- limit: opts?.limit
259
- });
260
- return result;
261
- } catch (e) {
262
- if (e instanceof StorageError) {
263
- return e;
264
- }
265
- return new StorageError({ reason: String(e), cause: e });
266
- }
267
- },
268
- set: async (part) => {
269
- try {
270
- return await rpc("part.set", part);
271
- } catch (e) {
272
- if (e instanceof StorageError) {
273
- return e;
274
- }
275
- return new StorageError({ reason: String(e), cause: e });
276
- }
277
- },
278
- delete: async (id) => {
279
- try {
280
- await rpc("part.delete", { id });
281
- } catch (e) {
282
- if (e instanceof StorageError) {
283
- return e;
284
- }
285
- return new StorageError({ reason: String(e), cause: e });
286
- }
287
- }
288
- },
289
- sandbox: {
290
- get: async (key) => {
291
- try {
292
- const result = await rpc("sandbox.get", { key });
293
- if (result === null) {
294
- return new SandboxNotFoundError({ id: key });
295
- }
296
- return result;
297
- } catch (e) {
298
- if (e instanceof StorageError) {
299
- return e;
300
- }
301
- return new StorageError({ reason: String(e), cause: e });
302
- }
303
- },
304
- getBySession: async (sessionId) => {
305
- try {
306
- const result = await rpc("sandbox.getBySession", { sessionId });
307
- if (result === null) {
308
- return new SandboxNotFoundError({ id: sessionId });
309
- }
310
- return result;
311
- } catch (e) {
312
- if (e instanceof StorageError) {
313
- return e;
314
- }
315
- return new StorageError({ reason: String(e), cause: e });
316
- }
317
- },
318
- set: async (record) => {
319
- try {
320
- await rpc("sandbox.set", record);
321
- return record;
322
- } catch (e) {
323
- if (e instanceof StorageError) {
324
- return e;
325
- }
326
- return new StorageError({ reason: String(e), cause: e });
327
- }
328
- },
329
- update: async (opts) => {
330
- try {
331
- return await rpc("sandbox.update", opts);
332
- } catch (e) {
333
- if (e instanceof StorageError) {
334
- return e;
335
- }
336
- return new StorageError({ reason: String(e), cause: e });
337
- }
338
- },
339
- list: async (opts) => {
340
- try {
341
- return await rpc("sandbox.list", {
342
- tags: opts?.tags,
343
- order: opts?.order,
344
- cursor: opts?.cursor,
345
- limit: opts?.limit
346
- });
347
- } catch (e) {
348
- if (e instanceof StorageError) {
349
- return e;
350
- }
351
- return new StorageError({ reason: String(e), cause: e });
352
- }
353
- },
354
- tag: {
355
- set: async ({ sandboxId, tags }) => {
356
- try {
357
- return await rpc("sandbox.tag.set", { sandboxId, tags });
358
- } catch (e) {
359
- if (e instanceof StorageError) {
360
- return e;
361
- }
362
- return new StorageError({ reason: String(e), cause: e });
363
- }
364
- }
365
- },
366
- acquireLock: async (record, lockTimeoutMs) => {
367
- try {
368
- return await rpc("sandbox.acquireLock", {
369
- record,
370
- lockTimeoutMs
371
- });
372
- } catch (e) {
373
- if (e instanceof StorageError) {
374
- return e;
375
- }
376
- return new StorageError({ reason: String(e), cause: e });
377
- }
378
- }
379
- },
380
- setup: {
381
- get: async (key) => {
382
- try {
383
- return await rpc("setup.get", { key });
384
- } catch (e) {
385
- if (e instanceof StorageError) {
386
- return e;
387
- }
388
- return new StorageError({ reason: String(e), cause: e });
389
- }
390
- },
391
- set: async (snapshot) => {
392
- try {
393
- await rpc("setup.set", snapshot);
394
- return snapshot;
395
- } catch (e) {
396
- if (e instanceof StorageError) {
397
- return e;
398
- }
399
- return new StorageError({ reason: String(e), cause: e });
400
- }
401
- },
402
- delete: async (key) => {
403
- try {
404
- await rpc("setup.delete", { key });
405
- } catch (e) {
406
- if (e instanceof StorageError) {
407
- return e;
408
- }
409
- return new StorageError({ reason: String(e), cause: e });
410
- }
411
- },
412
- acquireLock: async (key, lockId, lockTimeoutMs) => {
413
- try {
414
- return await rpc("setup.acquireLock", {
415
- key,
416
- lockId,
417
- lockTimeoutMs
418
- });
419
- } catch (e) {
420
- if (e instanceof StorageError) {
421
- return e;
422
- }
423
- return new StorageError({ reason: String(e), cause: e });
424
- }
425
- }
426
- },
427
- command: {
428
- get: async (id) => {
429
- try {
430
- return await rpc("command.get", { id });
431
- } catch (e) {
432
- if (e instanceof StorageError) {
433
- return e;
434
- }
435
- return new StorageError({ reason: String(e), cause: e });
436
- }
437
- },
438
- set: async (command) => {
439
- try {
440
- return await rpc("command.set", command);
441
- } catch (e) {
442
- if (e instanceof StorageError) {
443
- return e;
444
- }
445
- return new StorageError({ reason: String(e), cause: e });
446
- }
447
- },
448
- list: async (sessionId, opts) => {
449
- try {
450
- const result = await rpc("command.list", {
451
- sessionId,
452
- includeFinished: opts?.includeFinished,
453
- cursor: opts?.cursor,
454
- limit: opts?.limit
455
- });
456
- return result;
457
- } catch (e) {
458
- if (e instanceof StorageError) {
459
- return e;
460
- }
461
- return new StorageError({ reason: String(e), cause: e });
462
- }
463
- }
464
- }
465
- };
38
+ // src/utils/logger.ts
39
+ var LOG_LEVEL_PRIORITY = {
40
+ info: 0,
41
+ warn: 1,
42
+ error: 2,
43
+ silent: 3
44
+ };
45
+ function getLevel(config) {
46
+ return config.level ?? "warn";
47
+ }
48
+ function getPrefix(config) {
49
+ return config.prefix ?? "agent";
466
50
  }
467
- function getStorage(opts) {
468
- const name = opts.config.name ?? DEFAULT_NAMESPACE;
469
- return getStorageClient(opts.rpc, name);
51
+ function shouldLog(config, level) {
52
+ return LOG_LEVEL_PRIORITY[level] >= LOG_LEVEL_PRIORITY[getLevel(config)];
470
53
  }
471
- var DEFAULT_NAMESPACE, LOCAL_STORAGE_VERSION;
472
- var init_client = __esm({
473
- "src/storage/client.ts"() {
474
- "use strict";
475
- init_errors();
476
- DEFAULT_NAMESPACE = "default";
477
- LOCAL_STORAGE_VERSION = "v1";
54
+ function formatTag(config, subsystem) {
55
+ return `[${getPrefix(config)}:${config.name}:${subsystem}]`;
56
+ }
57
+ function formatData(context, extra) {
58
+ const merged = { ...context, ...extra };
59
+ const entries = Object.entries(merged).filter(
60
+ ([, v]) => v !== void 0 && v !== null
61
+ );
62
+ if (entries.length === 0) {
63
+ return void 0;
478
64
  }
479
- });
480
-
481
- // src/storage/rpc.ts
482
- function ListResultSchema(itemSchema) {
483
- return import_zod.z.object({
484
- items: import_zod.z.array(itemSchema),
485
- nextCursor: import_zod.z.string().nullable()
486
- });
65
+ return Object.fromEntries(entries);
487
66
  }
488
- var import_zod, VercelLifecycleConfigSchema, NetworkPolicySchema, SandboxConfigBase, SandboxConfigSchema, GenerationSchema, SessionSchema, StepUsageSchema, UsageSummarySchema, MessageUsageSchema, InterruptedLastPartSchema, MessageSchema, PartSchema, CommandResultSchema, SandboxRecordSchema, SessionUpdateSchema, SandboxUpdateSchema, CommandBaseSchema, CommandSchema, SetupSnapshotSchema, methods, STORAGE_RPC_METHODS;
489
- var init_rpc = __esm({
490
- "src/storage/rpc.ts"() {
491
- "use strict";
492
- import_zod = require("zod");
493
- VercelLifecycleConfigSchema = import_zod.z.object({
494
- pollIntervalMs: import_zod.z.number().optional(),
495
- stopAfterInactiveMs: import_zod.z.number().optional(),
496
- snapshotBeforeTimeoutMs: import_zod.z.number().optional(),
497
- snapshotId: import_zod.z.string().optional(),
498
- autoStart: import_zod.z.boolean().optional()
499
- });
500
- NetworkPolicySchema = import_zod.z.custom().optional();
501
- SandboxConfigBase = import_zod.z.object({
502
- cwd: import_zod.z.string().optional()
503
- });
504
- SandboxConfigSchema = import_zod.z.discriminatedUnion("type", [
505
- SandboxConfigBase.extend({
506
- type: import_zod.z.literal("vercel"),
507
- resources: import_zod.z.object({ vcpus: import_zod.z.number() }).optional(),
508
- ports: import_zod.z.array(import_zod.z.number()).optional(),
509
- lifecycle: VercelLifecycleConfigSchema.optional(),
510
- networkPolicy: NetworkPolicySchema
511
- }),
512
- SandboxConfigBase.extend({
513
- type: import_zod.z.literal("local")
514
- }),
515
- SandboxConfigBase.extend({
516
- type: import_zod.z.literal("docker")
517
- }),
518
- SandboxConfigBase.extend({
519
- type: import_zod.z.literal("custom"),
520
- url: import_zod.z.string(),
521
- headers: import_zod.z.record(import_zod.z.string(), import_zod.z.string()).optional()
522
- })
523
- ]);
524
- GenerationSchema = import_zod.z.object({
525
- maxSteps: import_zod.z.number().optional(),
526
- temperature: import_zod.z.number().optional(),
527
- topK: import_zod.z.number().optional(),
528
- topP: import_zod.z.number().optional(),
529
- frequencyPenalty: import_zod.z.number().optional(),
530
- presencePenalty: import_zod.z.number().optional(),
531
- maxOutputTokens: import_zod.z.number().optional(),
532
- headers: import_zod.z.record(import_zod.z.string(), import_zod.z.string()).optional()
533
- });
534
- SessionSchema = import_zod.z.object({
535
- id: import_zod.z.string(),
536
- createdAt: import_zod.z.number(),
537
- updatedAt: import_zod.z.number(),
538
- runId: import_zod.z.string().nullable(),
539
- lastMessageId: import_zod.z.string().nullable(),
540
- tags: import_zod.z.record(import_zod.z.string(), import_zod.z.unknown()).nullable(),
541
- system: import_zod.z.string().nullable(),
542
- model: import_zod.z.string().nullable(),
543
- sandboxId: import_zod.z.string().nullable(),
544
- skillsDir: import_zod.z.array(import_zod.z.string()).nullable(),
545
- hookToken: import_zod.z.string().nullable(),
546
- activeTools: import_zod.z.array(import_zod.z.string()).nullable(),
547
- generation: GenerationSchema.nullable().default(null)
548
- });
549
- StepUsageSchema = import_zod.z.object({
550
- stepIndex: import_zod.z.number(),
551
- model: import_zod.z.string(),
552
- inputTokens: import_zod.z.number(),
553
- outputTokens: import_zod.z.number(),
554
- totalTokens: import_zod.z.number(),
555
- cacheReadTokens: import_zod.z.number(),
556
- cacheWriteTokens: import_zod.z.number(),
557
- reasoningTokens: import_zod.z.number()
558
- });
559
- UsageSummarySchema = import_zod.z.object({
560
- model: import_zod.z.string(),
561
- inputTokens: import_zod.z.number(),
562
- outputTokens: import_zod.z.number(),
563
- totalTokens: import_zod.z.number(),
564
- cacheReadTokens: import_zod.z.number(),
565
- cacheWriteTokens: import_zod.z.number(),
566
- reasoningTokens: import_zod.z.number(),
567
- stepCount: import_zod.z.number()
568
- });
569
- MessageUsageSchema = import_zod.z.object({
570
- steps: import_zod.z.array(StepUsageSchema),
571
- summary: UsageSummarySchema
572
- });
573
- InterruptedLastPartSchema = import_zod.z.object({
574
- index: import_zod.z.number(),
575
- part: import_zod.z.unknown()
576
- });
577
- MessageSchema = import_zod.z.object({
578
- id: import_zod.z.string(),
579
- sessionId: import_zod.z.string(),
580
- role: import_zod.z.enum(["user", "assistant", "system"]),
581
- createdAt: import_zod.z.number(),
582
- startedAt: import_zod.z.number().nullable(),
583
- completedAt: import_zod.z.number().nullable(),
584
- interruptedAt: import_zod.z.number().nullable(),
585
- interruptedLastPart: InterruptedLastPartSchema.nullable().default(null),
586
- usage: MessageUsageSchema.nullable()
587
- });
588
- PartSchema = import_zod.z.object({
589
- id: import_zod.z.string(),
590
- messageId: import_zod.z.string(),
591
- sessionId: import_zod.z.string(),
592
- index: import_zod.z.number(),
593
- part: import_zod.z.unknown()
594
- });
595
- CommandResultSchema = import_zod.z.object({
596
- stdout: import_zod.z.string(),
597
- stderr: import_zod.z.string(),
598
- exitCode: import_zod.z.number(),
599
- completedAt: import_zod.z.number()
600
- });
601
- SandboxRecordSchema = import_zod.z.object({
602
- id: import_zod.z.string(),
603
- config: SandboxConfigSchema,
604
- tags: import_zod.z.record(import_zod.z.string(), import_zod.z.unknown()).nullable(),
605
- createdAt: import_zod.z.number().nullable(),
606
- lastActivityAt: import_zod.z.number().nullable(),
607
- acquiringLockId: import_zod.z.string().nullable(),
608
- acquiringLockAt: import_zod.z.number().nullable(),
609
- setupKey: import_zod.z.string().nullable().optional(),
610
- setupCompletedAt: import_zod.z.number().nullable().optional(),
611
- providerMetadata: import_zod.z.discriminatedUnion("provider", [
612
- import_zod.z.object({
613
- provider: import_zod.z.literal("vercel"),
614
- sandboxId: import_zod.z.string().nullable(),
615
- snapshotId: import_zod.z.string().nullable()
616
- })
617
- ]).optional()
618
- });
619
- SessionUpdateSchema = SessionSchema.omit({
620
- id: true,
621
- generation: true
622
- }).partial().extend({
623
- id: SessionSchema.shape.id,
624
- generation: GenerationSchema.nullable().optional()
625
- }).strict();
626
- SandboxUpdateSchema = SandboxRecordSchema.omit({ id: true }).partial().extend({
627
- id: SandboxRecordSchema.shape.id
628
- }).strict();
629
- CommandBaseSchema = import_zod.z.object({
630
- id: import_zod.z.string(),
631
- sessionId: import_zod.z.string(),
632
- command: import_zod.z.string(),
633
- args: import_zod.z.array(import_zod.z.string()).optional(),
634
- startedAt: import_zod.z.number()
67
+ var Logger = class _Logger {
68
+ subsystem;
69
+ config;
70
+ context;
71
+ constructor({
72
+ subsystem,
73
+ config,
74
+ context
75
+ }) {
76
+ this.subsystem = subsystem;
77
+ this.config = config;
78
+ this.context = context ?? {};
79
+ }
80
+ child({
81
+ subsystem,
82
+ context
83
+ }) {
84
+ return new _Logger({
85
+ config: this.config,
86
+ subsystem: subsystem ? `${this.subsystem}:${subsystem}` : this.subsystem,
87
+ context: { ...this.context, ...context }
635
88
  });
636
- CommandSchema = import_zod.z.discriminatedUnion("status", [
637
- CommandBaseSchema.extend({ status: import_zod.z.literal("running") }),
638
- CommandBaseSchema.extend({
639
- status: import_zod.z.literal("completed"),
640
- result: CommandResultSchema
641
- }),
642
- CommandBaseSchema.extend({
643
- status: import_zod.z.literal("killed"),
644
- result: CommandResultSchema.optional()
645
- }),
646
- CommandBaseSchema.extend({
647
- status: import_zod.z.literal("failed"),
648
- result: CommandResultSchema
649
- })
650
- ]);
651
- SetupSnapshotSchema = import_zod.z.object({
652
- key: import_zod.z.string(),
653
- snapshotId: import_zod.z.string().nullable(),
654
- createdAt: import_zod.z.number(),
655
- lastUsedAt: import_zod.z.number().nullable(),
656
- acquiringLockId: import_zod.z.string().nullable(),
657
- acquiringLockAt: import_zod.z.number().nullable()
89
+ }
90
+ withContext(context) {
91
+ return new _Logger({
92
+ config: this.config,
93
+ subsystem: this.subsystem,
94
+ context: { ...this.context, ...context }
658
95
  });
659
- methods = {
660
- "session.get": {
661
- params: import_zod.z.object({ id: import_zod.z.string() }),
662
- result: SessionSchema.nullable()
663
- },
664
- "session.set": {
665
- params: SessionSchema,
666
- result: SessionSchema
667
- },
668
- "session.update": {
669
- params: SessionUpdateSchema,
670
- result: SessionSchema
671
- },
672
- "session.list": {
673
- params: import_zod.z.object({
674
- tags: import_zod.z.record(import_zod.z.string(), import_zod.z.unknown()).optional(),
675
- order: import_zod.z.enum([
676
- "createdAt_asc",
677
- "createdAt_desc",
678
- "updatedAt_asc",
679
- "updatedAt_desc"
680
- ]).optional(),
681
- cursor: import_zod.z.string().optional(),
682
- limit: import_zod.z.number().optional()
683
- }),
684
- result: ListResultSchema(SessionSchema)
685
- },
686
- "session.listBySandbox": {
687
- params: import_zod.z.object({
688
- sandboxId: import_zod.z.string(),
689
- tags: import_zod.z.record(import_zod.z.string(), import_zod.z.unknown()).optional(),
690
- order: import_zod.z.enum([
691
- "createdAt_asc",
692
- "createdAt_desc",
693
- "updatedAt_asc",
694
- "updatedAt_desc"
695
- ]).optional(),
696
- cursor: import_zod.z.string().optional(),
697
- limit: import_zod.z.number().optional()
698
- }),
699
- result: ListResultSchema(SessionSchema)
700
- },
701
- "session.delete": {
702
- params: import_zod.z.object({ id: import_zod.z.string() }),
703
- result: import_zod.z.void()
704
- },
705
- "session.tag.set": {
706
- params: import_zod.z.object({
707
- sessionId: import_zod.z.string(),
708
- tags: import_zod.z.record(import_zod.z.string(), import_zod.z.unknown())
709
- }),
710
- result: SessionSchema
711
- },
712
- "message.get": {
713
- params: import_zod.z.object({ id: import_zod.z.string() }),
714
- result: MessageSchema.nullable()
715
- },
716
- "message.set": {
717
- params: MessageSchema,
718
- result: MessageSchema
719
- },
720
- "message.list": {
721
- params: import_zod.z.object({
722
- sessionId: import_zod.z.string(),
723
- cursor: import_zod.z.string().optional(),
724
- limit: import_zod.z.number().optional()
725
- }),
726
- result: ListResultSchema(MessageSchema)
727
- },
728
- "part.listByMessage": {
729
- params: import_zod.z.object({
730
- messageId: import_zod.z.string(),
731
- cursor: import_zod.z.string().optional(),
732
- limit: import_zod.z.number().optional()
733
- }),
734
- result: ListResultSchema(PartSchema)
735
- },
736
- "part.listBySession": {
737
- params: import_zod.z.object({
738
- sessionId: import_zod.z.string(),
739
- cursor: import_zod.z.string().optional(),
740
- limit: import_zod.z.number().optional()
741
- }),
742
- result: ListResultSchema(PartSchema)
743
- },
744
- "part.set": {
745
- params: PartSchema,
746
- result: PartSchema
747
- },
748
- "part.delete": {
749
- params: import_zod.z.object({ id: import_zod.z.string() }),
750
- result: import_zod.z.void()
751
- },
752
- "sandbox.get": {
753
- params: import_zod.z.object({ key: import_zod.z.string() }),
754
- result: SandboxRecordSchema.nullable()
755
- },
756
- "sandbox.getBySession": {
757
- params: import_zod.z.object({ sessionId: import_zod.z.string() }),
758
- result: SandboxRecordSchema.nullable()
759
- },
760
- "sandbox.set": {
761
- params: SandboxRecordSchema,
762
- result: import_zod.z.void()
763
- },
764
- "sandbox.update": {
765
- params: SandboxUpdateSchema,
766
- result: SandboxRecordSchema
767
- },
768
- "sandbox.list": {
769
- params: import_zod.z.object({
770
- tags: import_zod.z.record(import_zod.z.string(), import_zod.z.unknown()).optional(),
771
- order: import_zod.z.enum([
772
- "createdAt_asc",
773
- "createdAt_desc",
774
- "lastActivityAt_asc",
775
- "lastActivityAt_desc"
776
- ]).optional(),
777
- cursor: import_zod.z.string().optional(),
778
- limit: import_zod.z.number().optional()
779
- }),
780
- result: ListResultSchema(SandboxRecordSchema)
781
- },
782
- "sandbox.tag.set": {
783
- params: import_zod.z.object({
784
- sandboxId: import_zod.z.string(),
785
- tags: import_zod.z.record(import_zod.z.string(), import_zod.z.unknown())
786
- }),
787
- result: SandboxRecordSchema
788
- },
789
- "command.get": {
790
- params: import_zod.z.object({ id: import_zod.z.string() }),
791
- result: CommandSchema.nullable()
792
- },
793
- "command.set": {
794
- params: CommandSchema,
795
- result: CommandSchema
796
- },
797
- "command.list": {
798
- params: import_zod.z.object({
799
- sessionId: import_zod.z.string(),
800
- includeFinished: import_zod.z.boolean().optional(),
801
- cursor: import_zod.z.string().optional(),
802
- limit: import_zod.z.number().optional()
803
- }),
804
- result: ListResultSchema(CommandSchema)
805
- },
806
- "setup.get": {
807
- params: import_zod.z.object({ key: import_zod.z.string() }),
808
- result: SetupSnapshotSchema.nullable()
809
- },
810
- "setup.set": {
811
- params: SetupSnapshotSchema,
812
- result: import_zod.z.void()
813
- },
814
- "setup.delete": {
815
- params: import_zod.z.object({ key: import_zod.z.string() }),
816
- result: import_zod.z.void()
817
- },
818
- "setup.acquireLock": {
819
- params: import_zod.z.object({
820
- key: import_zod.z.string(),
821
- lockId: import_zod.z.string(),
822
- lockTimeoutMs: import_zod.z.number()
823
- }),
824
- result: SetupSnapshotSchema.nullable()
825
- },
826
- "sandbox.acquireLock": {
827
- params: import_zod.z.object({
828
- record: SandboxRecordSchema,
829
- lockTimeoutMs: import_zod.z.number()
830
- }),
831
- result: SandboxRecordSchema.nullable()
832
- }
833
- };
834
- STORAGE_RPC_METHODS = Object.keys(methods);
835
96
  }
836
- });
837
-
838
- // src/storage/handler.ts
839
- async function handleStorageRpc(body, handlers) {
840
- const { method, params } = body;
841
- if (!(method in methods)) {
842
- return {
843
- error: { code: "METHOD_NOT_FOUND", message: `Unknown method: ${method}` }
844
- };
97
+ info(message, data) {
98
+ if (!shouldLog(this.config, "info")) {
99
+ return;
100
+ }
101
+ const d = formatData(this.context, data);
102
+ if (d) {
103
+ console.info(formatTag(this.config, this.subsystem), message, d);
104
+ } else {
105
+ console.info(formatTag(this.config, this.subsystem), message);
106
+ }
845
107
  }
846
- const methodName = method;
847
- const schema = methods[methodName].params;
848
- const parsed = schema.safeParse(params);
849
- if (!parsed.success) {
850
- return {
851
- error: {
852
- code: "INVALID_PARAMS",
853
- message: parsed.error.issues.map((i) => `${i.path.join(".")}: ${i.message}`).join(", ")
854
- }
855
- };
108
+ warn(message, data) {
109
+ if (!shouldLog(this.config, "warn")) {
110
+ return;
111
+ }
112
+ const d = formatData(this.context, data);
113
+ if (d) {
114
+ console.warn(formatTag(this.config, this.subsystem), message, d);
115
+ } else {
116
+ console.warn(formatTag(this.config, this.subsystem), message);
117
+ }
856
118
  }
857
- try {
858
- const handler = handlers[methodName];
859
- const result = await handler(parsed.data);
860
- return { result };
861
- } catch (e) {
862
- const isConflict = e instanceof StorageConflictError || e instanceof Error && e.name === "StorageConflictError";
863
- if (isConflict) {
864
- return {
865
- error: {
866
- code: "CONFLICT",
867
- message: e instanceof Error ? e.message : String(e)
868
- }
869
- };
119
+ error(message, data) {
120
+ if (!shouldLog(this.config, "error")) {
121
+ return;
870
122
  }
871
- return {
872
- error: {
873
- code: "INTERNAL_ERROR",
874
- message: e instanceof Error ? e.message : String(e)
875
- }
123
+ const d = formatData(this.context, data);
124
+ if (d) {
125
+ console.error(formatTag(this.config, this.subsystem), message, d);
126
+ } else {
127
+ console.error(formatTag(this.config, this.subsystem), message);
128
+ }
129
+ }
130
+ /**
131
+ * Returns a function that, when called, logs the elapsed time at info level.
132
+ * Pass `logOnStart: true` to also log when the timer begins.
133
+ *
134
+ * @example
135
+ * const done = log.time("sandbox setup", { sandboxId }, { logOnStart: true });
136
+ * await setup();
137
+ * done(); // start: [agent:default:sandbox] sandbox setup { sandboxId: '...' }
138
+ * // end: [agent:default:sandbox] sandbox setup { sandboxId: '...', durationMs: 123 }
139
+ */
140
+ time(message, data, opts) {
141
+ if (opts?.logOnStart) {
142
+ this.info(`[start] ${message}`, data);
143
+ }
144
+ const t0 = Date.now();
145
+ return (endData) => {
146
+ this.info(opts?.logOnStart ? `[end] ${message}` : message, {
147
+ ...data,
148
+ ...endData,
149
+ durationMs: Date.now() - t0
150
+ });
876
151
  };
877
152
  }
153
+ };
154
+ function createLogger({
155
+ config,
156
+ subsystem,
157
+ context
158
+ }) {
159
+ return new Logger({ config, subsystem, context });
878
160
  }
879
- var init_handler = __esm({
880
- "src/storage/handler.ts"() {
881
- "use strict";
882
- init_errors();
883
- init_rpc();
884
- }
885
- });
886
-
887
- // src/storage/index.ts
888
- var storage_exports = {};
889
- __export(storage_exports, {
890
- DEFAULT_NAMESPACE: () => DEFAULT_NAMESPACE,
891
- LOCAL_STORAGE_VERSION: () => LOCAL_STORAGE_VERSION,
892
- STORAGE_RPC_METHODS: () => STORAGE_RPC_METHODS,
893
- getStorage: () => getStorage,
894
- handleStorageRpc: () => handleStorageRpc
895
- });
896
- var init_storage = __esm({
897
- "src/storage/index.ts"() {
898
- "use strict";
899
- init_client();
900
- init_handler();
901
- init_rpc();
902
- }
903
- });
904
161
 
905
- // src/sandbox/bindings/lifecycle-workflow.ts
906
- var lifecycle_workflow_exports = {};
907
- __export(lifecycle_workflow_exports, {
908
- sandboxLifecycleWorkflow: () => sandboxLifecycleWorkflow
909
- });
910
- module.exports = __toCommonJS(lifecycle_workflow_exports);
911
- var import_workflow = require("workflow");
912
-
913
- // src/sandbox/bindings/lifecycle-workflow-steps.ts
162
+ // src/sandbox/bindings/vercel-lifecycle/steps.ts
163
+ async function loadSandboxSDK() {
164
+ return (await import("@vercel/sandbox")).Sandbox;
165
+ }
914
166
  var DEFAULT_POLL_INTERVAL_MS = 2 * 60 * 1e3;
915
167
  var DEFAULT_IDLE_TIMEOUT_MS = 5 * 60 * 1e3;
916
168
  var SNAPSHOT_BEFORE_TIMEOUT_MS = 10 * 60 * 1e3;
@@ -921,40 +173,44 @@ var getTestCredentials = () => process.env.NODE_ENV === "test" ? {
921
173
  } : {};
922
174
  async function checkAndSnapshotStep(input) {
923
175
  "use step";
924
- const { Sandbox: VercelSandboxSDK } = await Promise.resolve().then(() => (init_vercel_sdk(), vercel_sdk_exports));
925
- const { getStorage: getStorage2 } = await Promise.resolve().then(() => (init_storage(), storage_exports));
926
- if (!input.rpc) {
927
- throw new Error("RPC not found");
928
- }
929
- const storage = getStorage2({
930
- config: input.storageConfig,
931
- rpc: input.rpc
176
+ const storage = input.agent.storage;
177
+ const log = createLogger({
178
+ config: { ...input.agent.options.logging, name: input.agent.name },
179
+ subsystem: "sandbox:lifecycle",
180
+ context: { sandboxId: input.sandboxId }
181
+ });
182
+ log.info("lifecycle check started", {
183
+ vercelSandboxId: input.vercelSandboxId
932
184
  });
933
- const record = await storage.sandbox.get(input.id);
934
- if (record instanceof Error) {
185
+ const record = await storage.sandbox.get(input.sandboxId);
186
+ if (!record) {
187
+ log.warn("sandbox record not found, exiting lifecycle");
935
188
  return { action: "exit", reason: "not_found" };
936
189
  }
937
- const currentSandboxId = record.providerMetadata?.provider === "vercel" ? record.providerMetadata.sandboxId : null;
190
+ const metadata = record.setup?.metadata;
191
+ const currentSandboxId = metadata?.sandboxId ?? null;
938
192
  if (currentSandboxId !== input.vercelSandboxId) {
193
+ log.info("sandbox ID changed, exiting lifecycle", {
194
+ expected: input.vercelSandboxId,
195
+ actual: currentSandboxId
196
+ });
939
197
  return { action: "exit", reason: "sandboxId_changed" };
940
198
  }
941
199
  if (!currentSandboxId) {
200
+ log.warn("no current sandbox ID in metadata, exiting lifecycle");
942
201
  return { action: "exit", reason: "not_found" };
943
202
  }
944
- const config = record.config;
945
- if (config.type !== "vercel") {
946
- return { action: "exit", reason: "not_found" };
947
- }
948
- const pollIntervalMs = config.lifecycle?.pollIntervalMs ?? DEFAULT_POLL_INTERVAL_MS;
949
- const idleTimeoutMs = config.lifecycle?.stopAfterInactiveMs ?? DEFAULT_IDLE_TIMEOUT_MS;
950
- const snapshotBeforeTimeoutMs = config.lifecycle?.snapshotBeforeTimeoutMs ?? SNAPSHOT_BEFORE_TIMEOUT_MS;
203
+ const pollIntervalMs = input.config?.pollIntervalMs ?? DEFAULT_POLL_INTERVAL_MS;
204
+ const idleTimeoutMs = input.config?.stopAfterInactiveMs ?? DEFAULT_IDLE_TIMEOUT_MS;
205
+ const snapshotBeforeTimeoutMs = input.config?.snapshotBeforeTimeoutMs ?? SNAPSHOT_BEFORE_TIMEOUT_MS;
951
206
  const now = Date.now();
952
- const lastActivity = record.lastActivityAt ?? record.createdAt ?? now;
207
+ const lastActivity = record.lastActiveAt ?? record.createdAt ?? now;
953
208
  const idleDuration = now - lastActivity;
954
209
  const shouldSnapshotDueToIdle = idleDuration > idleTimeoutMs;
955
210
  let shouldSnapshotDueToTimeout = false;
956
211
  try {
957
- const sandbox = await VercelSandboxSDK.get({
212
+ const SandboxSDK = await loadSandboxSDK();
213
+ const sandbox = await SandboxSDK.get({
958
214
  sandboxId: currentSandboxId,
959
215
  ...getTestCredentials()
960
216
  });
@@ -962,47 +218,78 @@ async function checkAndSnapshotStep(input) {
962
218
  shouldSnapshotDueToTimeout = true;
963
219
  }
964
220
  } catch {
221
+ log.warn("failed to get sandbox from SDK, exiting lifecycle", {
222
+ vercelSandboxId: currentSandboxId
223
+ });
965
224
  return { action: "exit", reason: "not_found" };
966
225
  }
967
226
  if (shouldSnapshotDueToIdle || shouldSnapshotDueToTimeout) {
227
+ const reason = shouldSnapshotDueToIdle ? "idle" : "timeout";
228
+ log.info("snapshotting sandbox before exit", {
229
+ reason,
230
+ idleDurationMs: idleDuration,
231
+ vercelSandboxId: currentSandboxId
232
+ });
968
233
  try {
969
- const sandbox = await VercelSandboxSDK.get({
234
+ const SandboxSDK = await loadSandboxSDK();
235
+ const sandbox = await SandboxSDK.get({
970
236
  sandboxId: currentSandboxId,
971
237
  ...getTestCredentials()
972
238
  });
973
239
  const snapshot = await sandbox.snapshot();
974
- await storage.sandbox.update({
975
- id: record.id,
976
- acquiringLockId: null,
977
- acquiringLockAt: null,
978
- providerMetadata: {
979
- provider: "vercel",
980
- sandboxId: null,
981
- snapshotId: snapshot.snapshotId
240
+ log.info("snapshot created", { snapshotId: snapshot.snapshotId });
241
+ await storage.sandbox.update(input.sandboxId, {
242
+ setup: {
243
+ ...record.setup,
244
+ metadata: { sandboxId: null, snapshotId: snapshot.snapshotId }
982
245
  }
983
246
  });
247
+ log.info("sandbox record updated with snapshot");
984
248
  } catch (e) {
249
+ log.error("failed to snapshot sandbox", { cause: e });
985
250
  return e instanceof Error ? e : new Error(String(e));
986
251
  }
987
- return {
988
- action: "exit",
989
- reason: shouldSnapshotDueToIdle ? "idle" : "timeout"
990
- };
252
+ return { action: "exit", reason };
991
253
  }
254
+ log.info("sandbox still active, continuing lifecycle", {
255
+ idleDurationMs: idleDuration,
256
+ nextPollMs: pollIntervalMs
257
+ });
992
258
  return { action: "continue", nextPollMs: pollIntervalMs };
993
259
  }
994
260
 
995
- // src/sandbox/bindings/lifecycle-workflow.ts
261
+ // src/sandbox/bindings/vercel-lifecycle/workflow.ts
996
262
  var DEFAULT_POLL_MS = 2 * 60 * 1e3;
997
263
  async function sandboxLifecycleWorkflow({
998
264
  input
999
265
  }) {
1000
266
  "use workflow";
1001
- let nextPollMs = DEFAULT_POLL_MS;
267
+ let nextPollMs = input.config?.pollIntervalMs ?? DEFAULT_POLL_MS;
268
+ const log = createLogger({
269
+ config: { ...input.agent.options.logging, name: input.agent.name },
270
+ subsystem: "sandbox:lifecycle",
271
+ context: { sandboxId: input.sandboxId }
272
+ });
273
+ log.info("lifecycle workflow started", {
274
+ sandboxId: input.sandboxId,
275
+ vercelSandboxId: input.vercelSandboxId,
276
+ pollMs: nextPollMs
277
+ });
1002
278
  while (true) {
1003
279
  await (0, import_workflow.sleep)(nextPollMs);
1004
280
  const result = await checkAndSnapshotStep(input);
1005
- if (result instanceof Error || result.action === "exit") {
281
+ if (result instanceof Error) {
282
+ log.error("lifecycle step failed", {
283
+ sandboxId: input.sandboxId,
284
+ error: result.message
285
+ });
286
+ break;
287
+ }
288
+ if (result.action === "exit") {
289
+ log.info("lifecycle workflow exiting", {
290
+ sandboxId: input.sandboxId,
291
+ reason: result.reason
292
+ });
1006
293
  break;
1007
294
  }
1008
295
  nextPollMs = result.nextPollMs;
@@ -1012,4 +299,4 @@ async function sandboxLifecycleWorkflow({
1012
299
  0 && (module.exports = {
1013
300
  sandboxLifecycleWorkflow
1014
301
  });
1015
- //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/sandbox/bindings/vercel-sdk.ts", "../src/errors.ts", "../src/storage/client.ts", "../src/storage/rpc.ts", "../src/storage/handler.ts", "../src/storage/index.ts", "../src/sandbox/bindings/lifecycle-workflow.ts", "../src/sandbox/bindings/lifecycle-workflow-steps.ts"],
  "sourcesContent": ["export { Sandbox } from \"@vercel/sandbox\";\n", "import * as errore from \"errore\";\n\nexport class SessionNotFoundError extends errore.createTaggedError({\n  name: \"SessionNotFoundError\",\n  message: \"Session $id not found\",\n}) {}\n\nexport class SessionError extends errore.createTaggedError({\n  name: \"SessionError\",\n  message: \"Session $id failed: $reason\",\n}) {}\n\nexport class SandboxNotFoundError extends errore.createTaggedError({\n  name: \"SandboxNotFoundError\",\n  message: \"Sandbox $id not found\",\n}) {}\n\nexport class StorageError extends errore.createTaggedError({\n  name: \"StorageError\",\n  message: \"$reason\",\n}) {}\n\nexport class StorageConflictError extends errore.createTaggedError({\n  name: \"StorageConflictError\",\n  message: \"$reason\",\n}) {}\n\nexport class SandboxError extends errore.createTaggedError({\n  name: \"SandboxError\",\n  message: \"$reason\",\n}) {}\n\nexport class MessageNotFoundError extends errore.createTaggedError({\n  name: \"MessageNotFoundError\",\n  message: \"Message $id not found\",\n}) {}\n", "import type { z } from \"zod\";\nimport {\n  MessageNotFoundError,\n  SandboxNotFoundError,\n  SessionNotFoundError,\n  StorageConflictError,\n  StorageError,\n} from \"../errors\";\nimport type { StorageMethods } from \"./rpc\";\nimport type {\n  Command,\n  ListResult,\n  Part,\n  SetupSnapshot,\n  Storage,\n  StorageConfig,\n} from \"./types\";\n\ntype RpcResponse<T> =\n  | { result: T }\n  | { error: { code: string; message: string } };\n\nexport type RpcFn = (params: {\n  name?: string;\n  method: string;\n  params: unknown;\n  _quiet?: boolean;\n}) => Promise<RpcResponse<unknown>>;\n\nexport function getStorageClient(rpcFn: RpcFn, name?: string): Storage {\n  async function rpc<M extends keyof StorageMethods>(\n    method: M,\n    params: z.infer<StorageMethods[M][\"params\"]>\n  ): Promise<z.infer<StorageMethods[M][\"result\"]>> {\n    const result = await rpcFn({ name, method, params });\n\n    if (\"error\" in result) {\n      if (result.error.code === \"CONFLICT\") {\n        throw new StorageConflictError({ reason: result.error.message });\n      }\n      throw new StorageError({\n        reason: `[${result.error.code}] ${result.error.message}`,\n      });\n    }\n\n    return result.result as z.infer<StorageMethods[M][\"result\"]>;\n  }\n\n  return {\n    session: {\n      get: async (id) => {\n        try {\n          const result = await rpc(\"session.get\", { id });\n          if (result === null) {\n            return new SessionNotFoundError({ id });\n          }\n          return result;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      set: async (session) => {\n        try {\n          return await rpc(\"session.set\", session);\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      update: async (opts) => {\n        try {\n          return await rpc(\"session.update\", opts);\n        } catch (e) {\n          if (e instanceof StorageConflictError) {\n            return e;\n          }\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      delete: async (id) => {\n        try {\n          await rpc(\"session.delete\", { id });\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      list: async (opts) => {\n        try {\n          return await rpc(\"session.list\", {\n            tags: opts?.tags,\n            order: opts?.order,\n            cursor: opts?.cursor,\n            limit: opts?.limit,\n          });\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      listBySandbox: async (opts) => {\n        try {\n          return await rpc(\"session.listBySandbox\", {\n            sandboxId: opts.sandboxId,\n            tags: opts.tags,\n            order: opts.order,\n            cursor: opts.cursor,\n            limit: opts.limit,\n          });\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      tag: {\n        set: async ({ sessionId, tags }) => {\n          try {\n            return await rpc(\"session.tag.set\", { sessionId, tags });\n          } catch (e) {\n            if (e instanceof StorageError) {\n              return e;\n            }\n            return new StorageError({ reason: String(e), cause: e });\n          }\n        },\n      },\n    },\n    message: {\n      list: async (sessionId, opts) => {\n        try {\n          return await rpc(\"message.list\", {\n            sessionId,\n            cursor: opts?.cursor,\n            limit: opts?.limit,\n          });\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      get: async (id) => {\n        try {\n          const result = await rpc(\"message.get\", { id });\n          if (result === null) {\n            return new MessageNotFoundError({ id });\n          }\n          return result;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      set: async (message) => {\n        try {\n          return await rpc(\"message.set\", message);\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n    },\n    part: {\n      listByMessage: async (messageId, opts) => {\n        try {\n          const result = await rpc(\"part.listByMessage\", {\n            messageId,\n            cursor: opts?.cursor,\n            limit: opts?.limit,\n          });\n          return result as ListResult<Part>;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      listBySession: async (sessionId, opts) => {\n        try {\n          const result = await rpc(\"part.listBySession\", {\n            sessionId,\n            cursor: opts?.cursor,\n            limit: opts?.limit,\n          });\n          return result as ListResult<Part>;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      set: async (part) => {\n        try {\n          return (await rpc(\"part.set\", part)) as Part;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      delete: async (id) => {\n        try {\n          await rpc(\"part.delete\", { id });\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n    },\n    sandbox: {\n      get: async (key) => {\n        try {\n          const result = await rpc(\"sandbox.get\", { key });\n          if (result === null) {\n            return new SandboxNotFoundError({ id: key });\n          }\n          return result;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      getBySession: async (sessionId) => {\n        try {\n          const result = await rpc(\"sandbox.getBySession\", { sessionId });\n          if (result === null) {\n            return new SandboxNotFoundError({ id: sessionId });\n          }\n          return result;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      set: async (record) => {\n        try {\n          await rpc(\"sandbox.set\", record);\n          return record;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      update: async (opts) => {\n        try {\n          return await rpc(\"sandbox.update\", opts);\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      list: async (opts) => {\n        try {\n          return await rpc(\"sandbox.list\", {\n            tags: opts?.tags,\n            order: opts?.order,\n            cursor: opts?.cursor,\n            limit: opts?.limit,\n          });\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      tag: {\n        set: async ({ sandboxId, tags }) => {\n          try {\n            return await rpc(\"sandbox.tag.set\", { sandboxId, tags });\n          } catch (e) {\n            if (e instanceof StorageError) {\n              return e;\n            }\n            return new StorageError({ reason: String(e), cause: e });\n          }\n        },\n      },\n      acquireLock: async (record, lockTimeoutMs) => {\n        try {\n          return (await rpc(\"sandbox.acquireLock\", {\n            record,\n            lockTimeoutMs,\n          })) as import(\"./types\").SandboxRecord | null;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n    },\n    setup: {\n      get: async (key) => {\n        try {\n          return (await rpc(\"setup.get\", { key })) as SetupSnapshot | null;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      set: async (snapshot) => {\n        try {\n          await rpc(\"setup.set\", snapshot);\n          return snapshot;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      delete: async (key) => {\n        try {\n          await rpc(\"setup.delete\", { key });\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      acquireLock: async (key, lockId, lockTimeoutMs) => {\n        try {\n          return (await rpc(\"setup.acquireLock\", {\n            key,\n            lockId,\n            lockTimeoutMs,\n          })) as SetupSnapshot | null;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n    },\n    command: {\n      get: async (id) => {\n        try {\n          return (await rpc(\"command.get\", { id })) as Command | null;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      set: async (command) => {\n        try {\n          return (await rpc(\"command.set\", command)) as Command;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n      list: async (sessionId, opts) => {\n        try {\n          const result = await rpc(\"command.list\", {\n            sessionId,\n            includeFinished: opts?.includeFinished,\n            cursor: opts?.cursor,\n            limit: opts?.limit,\n          });\n          return result as ListResult<Command>;\n        } catch (e) {\n          if (e instanceof StorageError) {\n            return e;\n          }\n          return new StorageError({ reason: String(e), cause: e });\n        }\n      },\n    },\n  };\n}\n\nexport const DEFAULT_NAMESPACE = \"default\";\nexport const LOCAL_STORAGE_VERSION = \"v1\";\n\nexport function getStorage(opts: {\n  config: StorageConfig;\n  rpc: RpcFn;\n}): Storage {\n  const name = opts.config.name ?? DEFAULT_NAMESPACE;\n  return getStorageClient(opts.rpc, name);\n}\n", "import { z } from \"zod\";\n\nconst VercelLifecycleConfigSchema = z.object({\n  pollIntervalMs: z.number().optional(),\n  stopAfterInactiveMs: z.number().optional(),\n  snapshotBeforeTimeoutMs: z.number().optional(),\n  snapshotId: z.string().optional(),\n  autoStart: z.boolean().optional(),\n});\n\nimport type { NetworkPolicy } from \"@vercel/sandbox\";\n\n/**\n * Passthrough schema \u2014 the SDK validates the actual shape.\n * Typed via z.custom so the inferred TS type matches the SDK's NetworkPolicy.\n */\nconst NetworkPolicySchema = z.custom<NetworkPolicy>().optional();\n\nexport type { NetworkPolicy };\n\nconst SandboxConfigBase = z.object({\n  cwd: z.string().optional(),\n});\n\nexport const SandboxConfigSchema = z.discriminatedUnion(\"type\", [\n  SandboxConfigBase.extend({\n    type: z.literal(\"vercel\"),\n    resources: z.object({ vcpus: z.number() }).optional(),\n    ports: z.array(z.number()).optional(),\n    lifecycle: VercelLifecycleConfigSchema.optional(),\n    networkPolicy: NetworkPolicySchema,\n  }),\n  SandboxConfigBase.extend({\n    type: z.literal(\"local\"),\n  }),\n  SandboxConfigBase.extend({\n    type: z.literal(\"docker\"),\n  }),\n  SandboxConfigBase.extend({\n    type: z.literal(\"custom\"),\n    url: z.string(),\n    headers: z.record(z.string(), z.string()).optional(),\n  }),\n]);\n\nexport type SandboxConfig = z.infer<typeof SandboxConfigSchema>;\n\nconst GenerationSchema = z.object({\n  maxSteps: z.number().optional(),\n  temperature: z.number().optional(),\n  topK: z.number().optional(),\n  topP: z.number().optional(),\n  frequencyPenalty: z.number().optional(),\n  presencePenalty: z.number().optional(),\n  maxOutputTokens: z.number().optional(),\n  headers: z.record(z.string(), z.string()).optional(),\n});\n\nexport const SessionSchema = z.object({\n  id: z.string(),\n  createdAt: z.number(),\n  updatedAt: z.number(),\n  runId: z.string().nullable(),\n  lastMessageId: z.string().nullable(),\n  tags: z.record(z.string(), z.unknown()).nullable(),\n  system: z.string().nullable(),\n  model: z.string().nullable(),\n  sandboxId: z.string().nullable(),\n  skillsDir: z.array(z.string()).nullable(),\n  hookToken: z.string().nullable(),\n  activeTools: z.array(z.string()).nullable(),\n  generation: GenerationSchema.nullable().default(null),\n});\n\nexport const StepUsageSchema = z.object({\n  stepIndex: z.number(),\n  model: z.string(),\n  inputTokens: z.number(),\n  outputTokens: z.number(),\n  totalTokens: z.number(),\n  cacheReadTokens: z.number(),\n  cacheWriteTokens: z.number(),\n  reasoningTokens: z.number(),\n});\n\nexport const UsageSummarySchema = z.object({\n  model: z.string(),\n  inputTokens: z.number(),\n  outputTokens: z.number(),\n  totalTokens: z.number(),\n  cacheReadTokens: z.number(),\n  cacheWriteTokens: z.number(),\n  reasoningTokens: z.number(),\n  stepCount: z.number(),\n});\n\nexport const MessageUsageSchema = z.object({\n  steps: z.array(StepUsageSchema),\n  summary: UsageSummarySchema,\n});\n\nexport type MessageUsage = z.infer<typeof MessageUsageSchema>;\nexport type UsageSummary = z.infer<typeof UsageSummarySchema>;\nexport type StepUsage = z.infer<typeof StepUsageSchema>;\n\nexport const InterruptedLastPartSchema = z.object({\n  index: z.number(),\n  part: z.unknown(),\n});\n\nexport const MessageSchema = z.object({\n  id: z.string(),\n  sessionId: z.string(),\n  role: z.enum([\"user\", \"assistant\", \"system\"]),\n  createdAt: z.number(),\n  startedAt: z.number().nullable(),\n  completedAt: z.number().nullable(),\n  interruptedAt: z.number().nullable(),\n  interruptedLastPart: InterruptedLastPartSchema.nullable().default(null),\n  usage: MessageUsageSchema.nullable(),\n});\n\n/**\n * The `part` field corresponds to `UIMessage[\"parts\"][number]` from the `ai` package.\n * We use `z.unknown()` because the exact shape varies by part type (text, tool-call,\n * tool-result, etc.) and may evolve with the AI SDK. The RPC layer just passes it through.\n */\nexport const PartSchema = z.object({\n  id: z.string(),\n  messageId: z.string(),\n  sessionId: z.string(),\n  index: z.number(),\n  part: z.unknown(),\n});\n\nexport const CommandResultSchema = z.object({\n  stdout: z.string(),\n  stderr: z.string(),\n  exitCode: z.number(),\n  completedAt: z.number(),\n});\n\nexport const SandboxRecordSchema = z.object({\n  id: z.string(),\n  config: SandboxConfigSchema,\n  tags: z.record(z.string(), z.unknown()).nullable(),\n  createdAt: z.number().nullable(),\n  lastActivityAt: z.number().nullable(),\n  acquiringLockId: z.string().nullable(),\n  acquiringLockAt: z.number().nullable(),\n  setupKey: z.string().nullable().optional(),\n  setupCompletedAt: z.number().nullable().optional(),\n  providerMetadata: z\n    .discriminatedUnion(\"provider\", [\n      z.object({\n        provider: z.literal(\"vercel\"),\n        sandboxId: z.string().nullable(),\n        snapshotId: z.string().nullable(),\n      }),\n    ])\n    .optional(),\n});\n\nconst SessionUpdateSchema = SessionSchema.omit({\n  id: true,\n  generation: true,\n})\n  .partial()\n  .extend({\n    id: SessionSchema.shape.id,\n    generation: GenerationSchema.nullable().optional(),\n  })\n  .strict();\n\nconst SandboxUpdateSchema = SandboxRecordSchema.omit({ id: true })\n  .partial()\n  .extend({\n    id: SandboxRecordSchema.shape.id,\n  })\n  .strict();\n\nconst CommandBaseSchema = z.object({\n  id: z.string(),\n  sessionId: z.string(),\n  command: z.string(),\n  args: z.array(z.string()).optional(),\n  startedAt: z.number(),\n});\n\nexport const CommandSchema = z.discriminatedUnion(\"status\", [\n  CommandBaseSchema.extend({ status: z.literal(\"running\") }),\n  CommandBaseSchema.extend({\n    status: z.literal(\"completed\"),\n    result: CommandResultSchema,\n  }),\n  CommandBaseSchema.extend({\n    status: z.literal(\"killed\"),\n    result: CommandResultSchema.optional(),\n  }),\n  CommandBaseSchema.extend({\n    status: z.literal(\"failed\"),\n    result: CommandResultSchema,\n  }),\n]);\n\nfunction ListResultSchema<T extends z.ZodTypeAny>(itemSchema: T) {\n  return z.object({\n    items: z.array(itemSchema),\n    nextCursor: z.string().nullable(),\n  });\n}\n\nexport const SetupSnapshotSchema = z.object({\n  key: z.string(),\n  snapshotId: z.string().nullable(),\n  createdAt: z.number(),\n  lastUsedAt: z.number().nullable(),\n  acquiringLockId: z.string().nullable(),\n  acquiringLockAt: z.number().nullable(),\n});\n\nconst methods = {\n  \"session.get\": {\n    params: z.object({ id: z.string() }),\n    result: SessionSchema.nullable(),\n  },\n  \"session.set\": {\n    params: SessionSchema,\n    result: SessionSchema,\n  },\n  \"session.update\": {\n    params: SessionUpdateSchema,\n    result: SessionSchema,\n  },\n  \"session.list\": {\n    params: z.object({\n      tags: z.record(z.string(), z.unknown()).optional(),\n      order: z\n        .enum([\n          \"createdAt_asc\",\n          \"createdAt_desc\",\n          \"updatedAt_asc\",\n          \"updatedAt_desc\",\n        ])\n        .optional(),\n      cursor: z.string().optional(),\n      limit: z.number().optional(),\n    }),\n    result: ListResultSchema(SessionSchema),\n  },\n  \"session.listBySandbox\": {\n    params: z.object({\n      sandboxId: z.string(),\n      tags: z.record(z.string(), z.unknown()).optional(),\n      order: z\n        .enum([\n          \"createdAt_asc\",\n          \"createdAt_desc\",\n          \"updatedAt_asc\",\n          \"updatedAt_desc\",\n        ])\n        .optional(),\n      cursor: z.string().optional(),\n      limit: z.number().optional(),\n    }),\n    result: ListResultSchema(SessionSchema),\n  },\n  \"session.delete\": {\n    params: z.object({ id: z.string() }),\n    result: z.void(),\n  },\n  \"session.tag.set\": {\n    params: z.object({\n      sessionId: z.string(),\n      tags: z.record(z.string(), z.unknown()),\n    }),\n    result: SessionSchema,\n  },\n  \"message.get\": {\n    params: z.object({ id: z.string() }),\n    result: MessageSchema.nullable(),\n  },\n  \"message.set\": {\n    params: MessageSchema,\n    result: MessageSchema,\n  },\n  \"message.list\": {\n    params: z.object({\n      sessionId: z.string(),\n      cursor: z.string().optional(),\n      limit: z.number().optional(),\n    }),\n    result: ListResultSchema(MessageSchema),\n  },\n  \"part.listByMessage\": {\n    params: z.object({\n      messageId: z.string(),\n      cursor: z.string().optional(),\n      limit: z.number().optional(),\n    }),\n    result: ListResultSchema(PartSchema),\n  },\n  \"part.listBySession\": {\n    params: z.object({\n      sessionId: z.string(),\n      cursor: z.string().optional(),\n      limit: z.number().optional(),\n    }),\n    result: ListResultSchema(PartSchema),\n  },\n  \"part.set\": {\n    params: PartSchema,\n    result: PartSchema,\n  },\n  \"part.delete\": {\n    params: z.object({ id: z.string() }),\n    result: z.void(),\n  },\n  \"sandbox.get\": {\n    params: z.object({ key: z.string() }),\n    result: SandboxRecordSchema.nullable(),\n  },\n  \"sandbox.getBySession\": {\n    params: z.object({ sessionId: z.string() }),\n    result: SandboxRecordSchema.nullable(),\n  },\n  \"sandbox.set\": {\n    params: SandboxRecordSchema,\n    result: z.void(),\n  },\n  \"sandbox.update\": {\n    params: SandboxUpdateSchema,\n    result: SandboxRecordSchema,\n  },\n  \"sandbox.list\": {\n    params: z.object({\n      tags: z.record(z.string(), z.unknown()).optional(),\n      order: z\n        .enum([\n          \"createdAt_asc\",\n          \"createdAt_desc\",\n          \"lastActivityAt_asc\",\n          \"lastActivityAt_desc\",\n        ])\n        .optional(),\n      cursor: z.string().optional(),\n      limit: z.number().optional(),\n    }),\n    result: ListResultSchema(SandboxRecordSchema),\n  },\n  \"sandbox.tag.set\": {\n    params: z.object({\n      sandboxId: z.string(),\n      tags: z.record(z.string(), z.unknown()),\n    }),\n    result: SandboxRecordSchema,\n  },\n  \"command.get\": {\n    params: z.object({ id: z.string() }),\n    result: CommandSchema.nullable(),\n  },\n  \"command.set\": {\n    params: CommandSchema,\n    result: CommandSchema,\n  },\n  \"command.list\": {\n    params: z.object({\n      sessionId: z.string(),\n      includeFinished: z.boolean().optional(),\n      cursor: z.string().optional(),\n      limit: z.number().optional(),\n    }),\n    result: ListResultSchema(CommandSchema),\n  },\n  \"setup.get\": {\n    params: z.object({ key: z.string() }),\n    result: SetupSnapshotSchema.nullable(),\n  },\n  \"setup.set\": {\n    params: SetupSnapshotSchema,\n    result: z.void(),\n  },\n  \"setup.delete\": {\n    params: z.object({ key: z.string() }),\n    result: z.void(),\n  },\n  \"setup.acquireLock\": {\n    params: z.object({\n      key: z.string(),\n      lockId: z.string(),\n      lockTimeoutMs: z.number(),\n    }),\n    result: SetupSnapshotSchema.nullable(),\n  },\n  \"sandbox.acquireLock\": {\n    params: z.object({\n      record: SandboxRecordSchema,\n      lockTimeoutMs: z.number(),\n    }),\n    result: SandboxRecordSchema.nullable(),\n  },\n} as const;\n\nexport { methods };\nexport type StorageMethods = typeof methods;\nexport type MethodName = keyof StorageMethods;\nexport const STORAGE_RPC_METHODS = Object.keys(methods) as MethodName[];\n", "import type { z } from \"zod\";\nimport { StorageConflictError } from \"../errors\";\nimport { type MethodName, methods, type StorageMethods } from \"./rpc\";\n\nexport type Handlers = {\n  [K in MethodName]: (\n    params: z.infer<StorageMethods[K][\"params\"]>\n  ) => Promise<z.infer<StorageMethods[K][\"result\"]>>;\n};\n\nexport type RpcRequest = {\n  method: string;\n  params: unknown;\n};\n\nexport type RpcSuccessResponse<T = unknown> = {\n  result: T;\n};\n\nexport type RpcErrorResponse = {\n  error: { code: string; message: string };\n};\n\nexport type RpcResponse<T = unknown> = RpcSuccessResponse<T> | RpcErrorResponse;\n\nexport async function handleStorageRpc(\n  body: RpcRequest,\n  handlers: Handlers\n): Promise<RpcResponse> {\n  const { method, params } = body;\n\n  if (!(method in methods)) {\n    return {\n      error: { code: \"METHOD_NOT_FOUND\", message: `Unknown method: ${method}` },\n    };\n  }\n\n  const methodName = method as MethodName;\n  const schema = methods[methodName].params;\n  const parsed = schema.safeParse(params);\n\n  if (!parsed.success) {\n    return {\n      error: {\n        code: \"INVALID_PARAMS\",\n        message: parsed.error.issues\n          .map((i) => `${i.path.join(\".\")}: ${i.message}`)\n          .join(\", \"),\n      },\n    };\n  }\n\n  try {\n    const handler = handlers[methodName] as (\n      params: unknown\n    ) => Promise<unknown>;\n    const result = await handler(parsed.data);\n    return { result };\n  } catch (e) {\n    const isConflict =\n      e instanceof StorageConflictError ||\n      (e instanceof Error && e.name === \"StorageConflictError\");\n\n    if (isConflict) {\n      return {\n        error: {\n          code: \"CONFLICT\",\n          message: e instanceof Error ? e.message : String(e),\n        },\n      };\n    }\n    return {\n      error: {\n        code: \"INTERNAL_ERROR\",\n        message: e instanceof Error ? e.message : String(e),\n      },\n    };\n  }\n}\n", "export {\n  DEFAULT_NAMESPACE,\n  getStorage,\n  LOCAL_STORAGE_VERSION,\n  type RpcFn,\n} from \"./client\";\nexport {\n  type Handlers,\n  handleStorageRpc,\n  type RpcErrorResponse,\n  type RpcRequest,\n  type RpcResponse,\n  type RpcSuccessResponse,\n} from \"./handler\";\nexport {\n  type MessageUsage,\n  type MethodName,\n  type SandboxConfig,\n  STORAGE_RPC_METHODS,\n  type StepUsage,\n  type StorageMethods,\n  type UsageSummary,\n} from \"./rpc\";\nexport type {\n  Command,\n  ListResult,\n  Message,\n  Part,\n  ResolvedStorage,\n  SandboxRecord,\n  Session,\n  SetupSnapshot,\n  Storage,\n  StorageConfig,\n  TypedSession,\n  TypedStorage,\n} from \"./types\";\n", "import { sleep } from \"workflow\";\nimport type { SandboxLifecycleInput } from \"../types\";\nimport { checkAndSnapshotStep } from \"./lifecycle-workflow-steps\";\n\nexport type { SandboxLifecycleInput };\n\nconst DEFAULT_POLL_MS = 2 * 60 * 1000;\n\nexport async function sandboxLifecycleWorkflow({\n  input,\n}: {\n  input: SandboxLifecycleInput;\n}) {\n  \"use workflow\";\n\n  let nextPollMs = DEFAULT_POLL_MS;\n\n  while (true) {\n    await sleep(nextPollMs);\n\n    const result = await checkAndSnapshotStep(input);\n\n    if (result instanceof Error || result.action === \"exit\") {\n      break;\n    }\n\n    nextPollMs = result.nextPollMs;\n  }\n}\n", "import type { SandboxLifecycleInput } from \"../types\";\n\nconst DEFAULT_POLL_INTERVAL_MS = 2 * 60 * 1000;\nconst DEFAULT_IDLE_TIMEOUT_MS = 5 * 60 * 1000;\nconst SNAPSHOT_BEFORE_TIMEOUT_MS = 10 * 60 * 1000;\n\nconst getTestCredentials = () =>\n  process.env.NODE_ENV === \"test\"\n    ? {\n        token: process.env.TEST_VERCEL_TOKEN,\n        teamId: process.env.TEST_VERCEL_TEAM_ID,\n        projectId: process.env.TEST_VERCEL_PROJECT_ID,\n      }\n    : {};\n\nexport type LifecycleStepResult =\n  | { action: \"continue\"; nextPollMs: number }\n  | {\n      action: \"exit\";\n      reason: \"sandboxId_changed\" | \"idle\" | \"timeout\" | \"not_found\";\n    };\n\nexport async function checkAndSnapshotStep(\n  input: SandboxLifecycleInput\n): Promise<Error | LifecycleStepResult> {\n  \"use step\";\n\n  const { Sandbox: VercelSandboxSDK } = await import(\"./vercel-sdk\");\n  const { getStorage } = await import(\"../../storage\");\n  if (!input.rpc) {\n    throw new Error(\"RPC not found\");\n  }\n  const storage = getStorage({\n    config: input.storageConfig,\n    rpc: input.rpc,\n  });\n  const record = await storage.sandbox.get(input.id);\n  if (record instanceof Error) {\n    return { action: \"exit\", reason: \"not_found\" };\n  }\n\n  const currentSandboxId =\n    record.providerMetadata?.provider === \"vercel\"\n      ? record.providerMetadata.sandboxId\n      : null;\n\n  if (currentSandboxId !== input.vercelSandboxId) {\n    return { action: \"exit\", reason: \"sandboxId_changed\" };\n  }\n\n  if (!currentSandboxId) {\n    return { action: \"exit\", reason: \"not_found\" };\n  }\n\n  const config = record.config;\n  if (config.type !== \"vercel\") {\n    return { action: \"exit\", reason: \"not_found\" };\n  }\n\n  const pollIntervalMs =\n    config.lifecycle?.pollIntervalMs ?? DEFAULT_POLL_INTERVAL_MS;\n  const idleTimeoutMs =\n    config.lifecycle?.stopAfterInactiveMs ?? DEFAULT_IDLE_TIMEOUT_MS;\n  const snapshotBeforeTimeoutMs =\n    config.lifecycle?.snapshotBeforeTimeoutMs ?? SNAPSHOT_BEFORE_TIMEOUT_MS;\n\n  const now = Date.now();\n  const lastActivity = record.lastActivityAt ?? record.createdAt ?? now;\n  const idleDuration = now - lastActivity;\n  const shouldSnapshotDueToIdle = idleDuration > idleTimeoutMs;\n\n  let shouldSnapshotDueToTimeout = false;\n  try {\n    const sandbox = await VercelSandboxSDK.get({\n      sandboxId: currentSandboxId,\n      ...getTestCredentials(),\n    });\n    if (sandbox.timeout < snapshotBeforeTimeoutMs) {\n      shouldSnapshotDueToTimeout = true;\n    }\n  } catch {\n    return { action: \"exit\", reason: \"not_found\" };\n  }\n\n  if (shouldSnapshotDueToIdle || shouldSnapshotDueToTimeout) {\n    try {\n      const sandbox = await VercelSandboxSDK.get({\n        sandboxId: currentSandboxId,\n        ...getTestCredentials(),\n      });\n      const snapshot = await sandbox.snapshot();\n      await storage.sandbox.update({\n        id: record.id,\n        acquiringLockId: null,\n        acquiringLockAt: null,\n        providerMetadata: {\n          provider: \"vercel\",\n          sandboxId: null,\n          snapshotId: snapshot.snapshotId,\n        },\n      });\n    } catch (e) {\n      return e instanceof Error ? e : new Error(String(e));\n    }\n    return {\n      action: \"exit\",\n      reason: shouldSnapshotDueToIdle ? \"idle\" : \"timeout\",\n    };\n  }\n\n  return { action: \"continue\", nextPollMs: pollIntervalMs };\n}\n"],
  "mappings": "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",
  "names": ["getStorage"]
}

302
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/sandbox/bindings/vercel-lifecycle/workflow.ts", "../src/utils/logger.ts", "../src/sandbox/bindings/vercel-lifecycle/steps.ts"],
  "sourcesContent": ["import { sleep } from \"workflow\";\nimport { createLogger } from \"../../../utils/logger\";\nimport { checkAndSnapshotStep, type LifecycleInput } from \"./steps\";\n\nexport type { LifecycleInput };\n\nconst DEFAULT_POLL_MS = 2 * 60 * 1000;\n\nexport async function sandboxLifecycleWorkflow({\n  input,\n}: {\n  input: LifecycleInput;\n}) {\n  \"use workflow\";\n\n  let nextPollMs = input.config?.pollIntervalMs ?? DEFAULT_POLL_MS;\n  const log = createLogger({\n    config: { ...input.agent.options.logging, name: input.agent.name },\n    subsystem: \"sandbox:lifecycle\",\n    context: { sandboxId: input.sandboxId },\n  });\n\n  log.info(\"lifecycle workflow started\", {\n    sandboxId: input.sandboxId,\n    vercelSandboxId: input.vercelSandboxId,\n    pollMs: nextPollMs,\n  });\n\n  while (true) {\n    await sleep(nextPollMs);\n\n    const result = await checkAndSnapshotStep(input);\n\n    if (result instanceof Error) {\n      log.error(\"lifecycle step failed\", {\n        sandboxId: input.sandboxId,\n        error: result.message,\n      });\n      break;\n    }\n\n    if (result.action === \"exit\") {\n      log.info(\"lifecycle workflow exiting\", {\n        sandboxId: input.sandboxId,\n        reason: result.reason,\n      });\n      break;\n    }\n\n    nextPollMs = result.nextPollMs;\n  }\n}\n", "export type LogLevel = \"info\" | \"warn\" | \"error\" | \"silent\";\n\nconst LOG_LEVEL_PRIORITY: Record<LogLevel, number> = {\n  info: 0,\n  warn: 1,\n  error: 2,\n  silent: 3,\n};\n\nexport type LogContext = {\n  sessionId?: string;\n  messageId?: string;\n  sandboxId?: string;\n  [key: string]: unknown;\n};\n\nexport type LoggingConfig = {\n  level?: LogLevel;\n  /**\n   * Top-level label for all log lines.\n   * @default \"agent\"\n   * @example \"my-app\" \u2192 [my-app:default:workflow]\n   */\n  prefix?: string;\n  name?: string;\n};\n\nfunction getLevel(config: LoggingConfig): LogLevel {\n  return config.level ?? \"warn\";\n}\n\nfunction getPrefix(config: LoggingConfig): string {\n  return config.prefix ?? \"agent\";\n}\n\nfunction shouldLog(config: LoggingConfig, level: LogLevel): boolean {\n  return LOG_LEVEL_PRIORITY[level] >= LOG_LEVEL_PRIORITY[getLevel(config)];\n}\n\nfunction formatTag(config: LoggingConfig, subsystem: string): string {\n  return `[${getPrefix(config)}:${config.name}:${subsystem}]`;\n}\n\nfunction formatData(\n  context: LogContext,\n  extra?: Record<string, unknown>\n): Record<string, unknown> | undefined {\n  const merged = { ...context, ...extra };\n  const entries = Object.entries(merged).filter(\n    ([, v]) => v !== undefined && v !== null\n  );\n  if (entries.length === 0) {\n    return undefined;\n  }\n  return Object.fromEntries(entries);\n}\n\nexport class Logger {\n  readonly subsystem: string;\n  private readonly config: LoggingConfig;\n  private readonly context: LogContext;\n\n  constructor({\n    subsystem,\n    config,\n    context,\n  }: {\n    subsystem: string;\n    config: LoggingConfig;\n    context?: LogContext;\n  }) {\n    this.subsystem = subsystem;\n    this.config = config;\n    this.context = context ?? {};\n  }\n\n  child({\n    subsystem,\n    context,\n  }: {\n    subsystem?: string;\n    context?: LogContext;\n  }): Logger {\n    return new Logger({\n      config: this.config,\n      subsystem: subsystem ? `${this.subsystem}:${subsystem}` : this.subsystem,\n      context: { ...this.context, ...context },\n    });\n  }\n\n  withContext(context: LogContext): Logger {\n    return new Logger({\n      config: this.config,\n      subsystem: this.subsystem,\n      context: { ...this.context, ...context },\n    });\n  }\n\n  info(message: string, data?: Record<string, unknown>): void {\n    if (!shouldLog(this.config, \"info\")) {\n      return;\n    }\n    const d = formatData(this.context, data);\n    if (d) {\n      console.info(formatTag(this.config, this.subsystem), message, d);\n    } else {\n      console.info(formatTag(this.config, this.subsystem), message);\n    }\n  }\n\n  warn(message: string, data?: Record<string, unknown>): void {\n    if (!shouldLog(this.config, \"warn\")) {\n      return;\n    }\n    const d = formatData(this.context, data);\n    if (d) {\n      console.warn(formatTag(this.config, this.subsystem), message, d);\n    } else {\n      console.warn(formatTag(this.config, this.subsystem), message);\n    }\n  }\n\n  error(message: string, data?: Record<string, unknown>): void {\n    if (!shouldLog(this.config, \"error\")) {\n      return;\n    }\n    const d = formatData(this.context, data);\n    if (d) {\n      console.error(formatTag(this.config, this.subsystem), message, d);\n    } else {\n      console.error(formatTag(this.config, this.subsystem), message);\n    }\n  }\n\n  /**\n   * Returns a function that, when called, logs the elapsed time at info level.\n   * Pass `logOnStart: true` to also log when the timer begins.\n   *\n   * @example\n   * const done = log.time(\"sandbox setup\", { sandboxId }, { logOnStart: true });\n   * await setup();\n   * done(); // start: [agent:default:sandbox] sandbox setup { sandboxId: '...' }\n   *         // end:   [agent:default:sandbox] sandbox setup { sandboxId: '...', durationMs: 123 }\n   */\n  time(\n    message: string,\n    data?: Record<string, unknown>,\n    opts?: { logOnStart?: boolean }\n  ): (endData?: Record<string, unknown>) => void {\n    if (opts?.logOnStart) {\n      this.info(`[start] ${message}`, data);\n    }\n    const t0 = Date.now();\n    return (endData?: Record<string, unknown>) => {\n      this.info(opts?.logOnStart ? `[end] ${message}` : message, {\n        ...data,\n        ...endData,\n        durationMs: Date.now() - t0,\n      });\n    };\n  }\n}\n\nexport function createLogger({\n  config,\n  subsystem,\n  context,\n}: {\n  config: LoggingConfig;\n  subsystem: string;\n  context?: LogContext;\n}): Logger {\n  return new Logger({ config, subsystem, context });\n}\n", "import type { Sandbox as VercelSandboxSDK } from \"@vercel/sandbox\";\nimport { createLogger } from \"../../../utils/logger\";\nimport type { SandboxAgentRef } from \"../../adapter\";\nimport type { VercelBindingMetadata } from \"../vercel\";\n\nasync function loadSandboxSDK(): Promise<typeof VercelSandboxSDK> {\n  return (await import(\"@vercel/sandbox\")).Sandbox;\n}\n\nconst DEFAULT_POLL_INTERVAL_MS = 2 * 60 * 1000;\nconst DEFAULT_IDLE_TIMEOUT_MS = 5 * 60 * 1000;\nconst SNAPSHOT_BEFORE_TIMEOUT_MS = 10 * 60 * 1000;\n\nconst getTestCredentials = () =>\n  process.env.NODE_ENV === \"test\"\n    ? {\n        token: process.env.TEST_VERCEL_TOKEN,\n        teamId: process.env.TEST_VERCEL_TEAM_ID,\n        projectId: process.env.TEST_VERCEL_PROJECT_ID,\n      }\n    : {};\n\nexport type LifecycleStepResult =\n  | { action: \"continue\"; nextPollMs: number }\n  | {\n      action: \"exit\";\n      reason: \"sandboxId_changed\" | \"idle\" | \"timeout\" | \"not_found\";\n    };\n\nexport type LifecycleConfig = {\n  pollIntervalMs?: number;\n  stopAfterInactiveMs?: number;\n  snapshotBeforeTimeoutMs?: number;\n};\n\nexport type LifecycleInput = {\n  agent: SandboxAgentRef;\n  sandboxId: string;\n  vercelSandboxId: string;\n  config?: LifecycleConfig;\n};\n\nexport async function checkAndSnapshotStep(\n  input: LifecycleInput\n): Promise<Error | LifecycleStepResult> {\n  \"use step\";\n\n  const storage = input.agent.storage;\n  const log = createLogger({\n    config: { ...input.agent.options.logging, name: input.agent.name },\n    subsystem: \"sandbox:lifecycle\",\n    context: { sandboxId: input.sandboxId },\n  });\n\n  log.info(\"lifecycle check started\", {\n    vercelSandboxId: input.vercelSandboxId,\n  });\n\n  const record = await storage.sandbox.get(input.sandboxId);\n  if (!record) {\n    log.warn(\"sandbox record not found, exiting lifecycle\");\n    return { action: \"exit\", reason: \"not_found\" };\n  }\n\n  const metadata = record.setup?.metadata as VercelBindingMetadata | null;\n  const currentSandboxId = metadata?.sandboxId ?? null;\n\n  if (currentSandboxId !== input.vercelSandboxId) {\n    log.info(\"sandbox ID changed, exiting lifecycle\", {\n      expected: input.vercelSandboxId,\n      actual: currentSandboxId,\n    });\n    return { action: \"exit\", reason: \"sandboxId_changed\" };\n  }\n\n  if (!currentSandboxId) {\n    log.warn(\"no current sandbox ID in metadata, exiting lifecycle\");\n    return { action: \"exit\", reason: \"not_found\" };\n  }\n\n  const pollIntervalMs =\n    input.config?.pollIntervalMs ?? DEFAULT_POLL_INTERVAL_MS;\n  const idleTimeoutMs =\n    input.config?.stopAfterInactiveMs ?? DEFAULT_IDLE_TIMEOUT_MS;\n  const snapshotBeforeTimeoutMs =\n    input.config?.snapshotBeforeTimeoutMs ?? SNAPSHOT_BEFORE_TIMEOUT_MS;\n\n  const now = Date.now();\n  const lastActivity = record.lastActiveAt ?? record.createdAt ?? now;\n  const idleDuration = now - lastActivity;\n  const shouldSnapshotDueToIdle = idleDuration > idleTimeoutMs;\n\n  let shouldSnapshotDueToTimeout = false;\n  try {\n    const SandboxSDK = await loadSandboxSDK();\n    const sandbox = await SandboxSDK.get({\n      sandboxId: currentSandboxId,\n      ...getTestCredentials(),\n    });\n    if (sandbox.timeout < snapshotBeforeTimeoutMs) {\n      shouldSnapshotDueToTimeout = true;\n    }\n  } catch {\n    log.warn(\"failed to get sandbox from SDK, exiting lifecycle\", {\n      vercelSandboxId: currentSandboxId,\n    });\n    return { action: \"exit\", reason: \"not_found\" };\n  }\n\n  if (shouldSnapshotDueToIdle || shouldSnapshotDueToTimeout) {\n    const reason = shouldSnapshotDueToIdle ? \"idle\" : \"timeout\";\n    log.info(\"snapshotting sandbox before exit\", {\n      reason,\n      idleDurationMs: idleDuration,\n      vercelSandboxId: currentSandboxId,\n    });\n\n    try {\n      const SandboxSDK = await loadSandboxSDK();\n      const sandbox = await SandboxSDK.get({\n        sandboxId: currentSandboxId,\n        ...getTestCredentials(),\n      });\n      const snapshot = await sandbox.snapshot();\n      log.info(\"snapshot created\", { snapshotId: snapshot.snapshotId });\n\n      await storage.sandbox.update(input.sandboxId, {\n        setup: {\n          ...record.setup,\n          metadata: { sandboxId: null, snapshotId: snapshot.snapshotId },\n        },\n      });\n      log.info(\"sandbox record updated with snapshot\");\n    } catch (e) {\n      log.error(\"failed to snapshot sandbox\", { cause: e });\n      return e instanceof Error ? e : new Error(String(e));\n    }\n    return { action: \"exit\", reason };\n  }\n\n  log.info(\"sandbox still active, continuing lifecycle\", {\n    idleDurationMs: idleDuration,\n    nextPollMs: pollIntervalMs,\n  });\n  return { action: \"continue\", nextPollMs: pollIntervalMs };\n}\n"],
  "mappings": "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",
  "names": []
}
