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.
- package/README.md +55 -254
- package/dist/adapter-BigchkkI.d.mts +201 -0
- package/dist/adapter-BigchkkI.d.ts +201 -0
- package/dist/chunk-BFFNCESS.mjs +302 -0
- package/dist/chunk-C4VSUEY2.mjs +72 -0
- package/dist/chunk-DOD4MC5D.mjs +196 -0
- package/dist/chunk-ELWIUJUK.mjs +96 -0
- package/dist/chunk-GKASMIBR.mjs +50 -0
- package/dist/chunk-JO3JDCH5.mjs +107 -0
- package/dist/chunk-MSWINCCM.mjs +128 -0
- package/dist/chunk-RT72C52I.mjs +324 -0
- package/dist/chunk-ZUFJJYC4.mjs +150 -0
- package/dist/{handler-FRUPZ4LX.mjs → docker-QPCLWLYR.mjs} +3 -4
- package/dist/entry-BmQ8FO-5.d.ts +36 -0
- package/dist/entry-CZd9aAwn.d.mts +36 -0
- package/dist/index.d.mts +415 -18
- package/dist/index.d.ts +415 -18
- package/dist/index.js +3036 -5494
- package/dist/index.mjs +3264 -1142
- package/dist/lifecycle-workflow-steps.d.mts +5 -0
- package/dist/lifecycle-workflow-steps.d.ts +5 -0
- package/dist/lifecycle-workflow-steps.js +263 -0
- package/dist/lifecycle-workflow-steps.mjs +9 -0
- package/dist/lifecycle-workflow.d.mts +6 -6
- package/dist/lifecycle-workflow.d.ts +6 -6
- package/dist/lifecycle-workflow.js +192 -905
- package/dist/lifecycle-workflow.mjs +3 -1
- package/dist/local-KJ3BSIFJ.mjs +8 -0
- package/dist/next/loader.d.mts +1 -0
- package/dist/next/loader.d.ts +1 -0
- package/dist/next/loader.js +44 -18
- package/dist/next/loader.mjs +18 -13
- package/dist/next.js +32 -9
- package/dist/next.mjs +6 -4
- package/dist/{process-manager-JDUJDYGU.mjs → process-manager-WQHAIVRB.mjs} +1 -1
- package/dist/sandbox.d.mts +6 -0
- package/dist/sandbox.d.ts +6 -0
- package/dist/sandbox.js +1070 -0
- package/dist/sandbox.mjs +19 -0
- package/dist/steps-BnkRQKlc.d.ts +173 -0
- package/dist/steps-u-mGDbP_.d.mts +173 -0
- package/dist/storage.d.mts +11 -0
- package/dist/storage.d.ts +11 -0
- package/dist/storage.js +234 -0
- package/dist/storage.mjs +12 -0
- package/dist/vercel-QZ6INPMV.mjs +11 -0
- package/package.json +26 -5
- package/dist/agent-workflow.d.mts +0 -30
- package/dist/agent-workflow.d.ts +0 -30
- package/dist/agent-workflow.js +0 -5433
- package/dist/agent-workflow.mjs +0 -14
- package/dist/chunk-AML2VCQS.mjs +0 -1287
- package/dist/chunk-FQ67QZOI.mjs +0 -75
- package/dist/chunk-NO7RHGTH.mjs +0 -2367
- package/dist/chunk-NXDVNJRS.mjs +0 -106
- package/dist/chunk-OZZVS6L5.mjs +0 -139
- package/dist/chunk-QRWGDFFY.mjs +0 -75
- package/dist/chunk-SJVFFE5D.mjs +0 -402
- package/dist/chunk-TAXLUVIC.mjs +0 -1
- package/dist/chunk-TGNVXSMX.mjs +0 -399
- package/dist/chunk-YRYXN7W4.mjs +0 -48
- package/dist/chunk-ZIAHPXOJ.mjs +0 -595
- package/dist/client-BKA7XBGW.mjs +0 -15
- package/dist/client-CEeSFGva.d.mts +0 -2376
- package/dist/client-CEeSFGva.d.ts +0 -2376
- package/dist/docker-FB2MJTHJ.mjs +0 -12
- package/dist/local-fs-handlers-SYOCKTPN.mjs +0 -447
- package/dist/sandbox-UENKQV3T.mjs +0 -21
- package/dist/storage-LSDMRW73.mjs +0 -20
- package/dist/vercel-SD3JTECG.mjs +0 -20
- 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-
|
|
34
|
-
var
|
|
35
|
-
__export(
|
|
36
|
-
|
|
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/
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
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
|
|
468
|
-
|
|
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
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
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
|
|
489
|
-
|
|
490
|
-
|
|
491
|
-
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
498
|
-
|
|
499
|
-
}
|
|
500
|
-
|
|
501
|
-
|
|
502
|
-
|
|
503
|
-
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
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
|
-
|
|
637
|
-
|
|
638
|
-
|
|
639
|
-
|
|
640
|
-
|
|
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
|
-
|
|
839
|
-
|
|
840
|
-
|
|
841
|
-
|
|
842
|
-
|
|
843
|
-
|
|
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
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
850
|
-
|
|
851
|
-
|
|
852
|
-
|
|
853
|
-
|
|
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
|
-
|
|
858
|
-
|
|
859
|
-
|
|
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
|
-
|
|
872
|
-
|
|
873
|
-
|
|
874
|
-
|
|
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
|
|
906
|
-
|
|
907
|
-
|
|
908
|
-
|
|
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
|
|
925
|
-
const
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
|
|
929
|
-
|
|
930
|
-
|
|
931
|
-
|
|
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.
|
|
934
|
-
if (record
|
|
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
|
|
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
|
|
945
|
-
|
|
946
|
-
|
|
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.
|
|
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
|
|
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
|
|
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
|
-
|
|
975
|
-
|
|
976
|
-
|
|
977
|
-
|
|
978
|
-
|
|
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
|
|
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
|
|
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": []
}

|