experimental-agent 0.0.0 → 0.0.2
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 +118 -55
- package/dist/agent-workflow.d.mts +1 -1
- package/dist/agent-workflow.d.ts +1 -1
- package/dist/agent-workflow.js +474 -66
- package/dist/agent-workflow.mjs +1 -1
- package/dist/{chunk-DPPQO7DA.mjs → chunk-24DJSI7C.mjs} +34 -3
- package/dist/chunk-4RGMKC2M.mjs +755 -0
- package/dist/{chunk-2YI7MQGZ.mjs → chunk-6ICYKNCC.mjs} +24 -1
- package/dist/chunk-PGYYQ3WZ.mjs +1088 -0
- package/dist/{client-FCFZYOOB.mjs → client-4Y3UPWFR.mjs} +3 -3
- package/dist/client-BBpD9kKL.d.ts +193 -0
- package/dist/client-BGJViybU.d.mts +193 -0
- package/dist/{client-RRX3GDQD.mjs → client-HUG4HT5L.mjs} +1 -1
- package/dist/index.d.mts +5 -106
- package/dist/index.d.ts +5 -106
- package/dist/index.js +526 -77
- package/dist/index.mjs +57 -16
- package/dist/{lifecycle-workflow-steps-6BLGTYVB.mjs → lifecycle-workflow-steps-HHN46ZAD.mjs} +2 -2
- package/dist/lifecycle-workflow.d.mts +2 -2
- package/dist/lifecycle-workflow.d.ts +2 -2
- package/dist/lifecycle-workflow.js +217 -19
- package/dist/lifecycle-workflow.mjs +1 -1
- package/dist/{local-J6QFWSWB.mjs → local-BYPFRMLZ.mjs} +42 -4
- package/dist/{sandbox-Y3ENCNUA.mjs → sandbox-BFA4ECEQ.mjs} +3 -3
- package/dist/{storage-QSTSE2ZB.mjs → storage-2U2QFNWI.mjs} +2 -2
- package/dist/{types-vRxN1Qz1.d.mts → types-DPXFq_r6.d.mts} +110 -1
- package/dist/{types-vRxN1Qz1.d.ts → types-DPXFq_r6.d.ts} +110 -1
- package/package.json +13 -12
- package/dist/chunk-JQPR6M7D.mjs +0 -649
- package/dist/chunk-MR4UWCJT.mjs +0 -878
- package/dist/types-Lwut_0_u.d.mts +0 -80
- package/dist/types-ctZeJ3iQ.d.ts +0 -80
|
@@ -0,0 +1,755 @@
|
|
|
1
|
+
import {
|
|
2
|
+
SandboxError,
|
|
3
|
+
SandboxNotFoundError,
|
|
4
|
+
getStorage
|
|
5
|
+
} from "./chunk-24DJSI7C.mjs";
|
|
6
|
+
|
|
7
|
+
// src/sandbox/bindings/local.ts
|
|
8
|
+
import { spawn } from "node:child_process";
|
|
9
|
+
import * as errore from "errore";
|
|
10
|
+
import { ulid } from "ulid";
|
|
11
|
+
|
|
12
|
+
// src/sandbox/write-files.ts
|
|
13
|
+
import * as path from "node:path";
|
|
14
|
+
async function writeFiles(opts) {
|
|
15
|
+
const { sandbox, files, destPath } = opts;
|
|
16
|
+
if (files.length === 0) {
|
|
17
|
+
return;
|
|
18
|
+
}
|
|
19
|
+
const filePaths = files.map(
|
|
20
|
+
(file) => path.posix.join(destPath, file.path)
|
|
21
|
+
);
|
|
22
|
+
const parentDirs = Array.from(
|
|
23
|
+
new Set(filePaths.map((p) => path.posix.dirname(p)))
|
|
24
|
+
);
|
|
25
|
+
const shellScripts = filePaths.filter((p) => p.endsWith(".sh"));
|
|
26
|
+
const mkdirResult = await sandbox.exec({
|
|
27
|
+
command: "mkdir",
|
|
28
|
+
args: ["-p", ...parentDirs]
|
|
29
|
+
});
|
|
30
|
+
if (mkdirResult instanceof Error) {
|
|
31
|
+
throw mkdirResult;
|
|
32
|
+
}
|
|
33
|
+
await mkdirResult.result;
|
|
34
|
+
const CHUNK_SIZE = 5e4;
|
|
35
|
+
for (let i = 0; i < files.length; i++) {
|
|
36
|
+
const file = files[i];
|
|
37
|
+
const fullPath = filePaths[i];
|
|
38
|
+
const base64Content = toBase64(file.content);
|
|
39
|
+
if (base64Content.length < CHUNK_SIZE) {
|
|
40
|
+
const marker = `EOF_${i}`;
|
|
41
|
+
const execResult = await sandbox.exec({
|
|
42
|
+
command: "bash",
|
|
43
|
+
args: [
|
|
44
|
+
"-c",
|
|
45
|
+
`base64 -d > ${quote(fullPath)} << '${marker}'
|
|
46
|
+
${base64Content}
|
|
47
|
+
${marker}`
|
|
48
|
+
]
|
|
49
|
+
});
|
|
50
|
+
if (execResult instanceof Error) {
|
|
51
|
+
throw execResult;
|
|
52
|
+
}
|
|
53
|
+
const { exitCode, stderr } = await execResult.result;
|
|
54
|
+
if (exitCode !== 0) {
|
|
55
|
+
throw new Error(
|
|
56
|
+
`writeFiles failed with exit code ${exitCode}: ${stderr}`
|
|
57
|
+
);
|
|
58
|
+
}
|
|
59
|
+
} else {
|
|
60
|
+
const tempB64 = `/tmp/chunk-${Date.now()}-${i}.b64`;
|
|
61
|
+
const clearResult = await sandbox.exec({
|
|
62
|
+
command: "bash",
|
|
63
|
+
args: ["-c", `> ${quote(tempB64)}`]
|
|
64
|
+
});
|
|
65
|
+
if (clearResult instanceof Error) {
|
|
66
|
+
throw clearResult;
|
|
67
|
+
}
|
|
68
|
+
await clearResult.result;
|
|
69
|
+
for (let offset = 0; offset < base64Content.length; offset += CHUNK_SIZE) {
|
|
70
|
+
const chunk = base64Content.slice(offset, offset + CHUNK_SIZE);
|
|
71
|
+
const marker = `CHUNK_${offset}`;
|
|
72
|
+
const appendResult = await sandbox.exec({
|
|
73
|
+
command: "bash",
|
|
74
|
+
args: [
|
|
75
|
+
"-c",
|
|
76
|
+
`cat >> ${quote(tempB64)} << '${marker}'
|
|
77
|
+
${chunk}
|
|
78
|
+
${marker}`
|
|
79
|
+
]
|
|
80
|
+
});
|
|
81
|
+
if (appendResult instanceof Error) {
|
|
82
|
+
throw appendResult;
|
|
83
|
+
}
|
|
84
|
+
const { exitCode: exitCode2, stderr: stderr2 } = await appendResult.result;
|
|
85
|
+
if (exitCode2 !== 0) {
|
|
86
|
+
throw new Error(
|
|
87
|
+
`writeFiles chunk failed with exit code ${exitCode2}: ${stderr2}`
|
|
88
|
+
);
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
const decodeResult = await sandbox.exec({
|
|
92
|
+
command: "bash",
|
|
93
|
+
args: [
|
|
94
|
+
"-c",
|
|
95
|
+
`base64 -d < ${quote(tempB64)} > ${quote(fullPath)} && rm -f ${quote(tempB64)}`
|
|
96
|
+
]
|
|
97
|
+
});
|
|
98
|
+
if (decodeResult instanceof Error) {
|
|
99
|
+
throw decodeResult;
|
|
100
|
+
}
|
|
101
|
+
const { exitCode, stderr } = await decodeResult.result;
|
|
102
|
+
if (exitCode !== 0) {
|
|
103
|
+
throw new Error(
|
|
104
|
+
`writeFiles decode failed with exit code ${exitCode}: ${stderr}`
|
|
105
|
+
);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
if (shellScripts.length > 0) {
|
|
110
|
+
const chmodResult = await sandbox.exec({
|
|
111
|
+
command: "chmod",
|
|
112
|
+
args: ["+x", ...shellScripts]
|
|
113
|
+
});
|
|
114
|
+
if (chmodResult instanceof Error) {
|
|
115
|
+
throw chmodResult;
|
|
116
|
+
}
|
|
117
|
+
await chmodResult.result;
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
function toBase64(content) {
|
|
121
|
+
if (typeof content === "string") {
|
|
122
|
+
return Buffer.from(content).toString("base64");
|
|
123
|
+
}
|
|
124
|
+
return content.toString("base64");
|
|
125
|
+
}
|
|
126
|
+
function quote(s) {
|
|
127
|
+
return `'${s.replace(/'/g, "'\\''")}'`;
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
// src/sandbox/bindings/local.ts
|
|
131
|
+
var localSandbox = ({
|
|
132
|
+
sandboxRecord,
|
|
133
|
+
storageConfig
|
|
134
|
+
}) => {
|
|
135
|
+
const config = sandboxRecord.config;
|
|
136
|
+
const basePath = config.path ?? process.cwd();
|
|
137
|
+
const processes = /* @__PURE__ */ new Map();
|
|
138
|
+
const storage = getStorage(storageConfig);
|
|
139
|
+
const sandbox = {
|
|
140
|
+
id: sandboxRecord.id,
|
|
141
|
+
config: sandboxRecord.config,
|
|
142
|
+
exec: ({ command, args, signal }) => {
|
|
143
|
+
return errore.tryAsync({
|
|
144
|
+
try: () => {
|
|
145
|
+
const commandId = `command_${ulid()}`;
|
|
146
|
+
const child = spawn(command, args, {
|
|
147
|
+
cwd: basePath,
|
|
148
|
+
signal
|
|
149
|
+
});
|
|
150
|
+
processes.set(commandId, child);
|
|
151
|
+
let stdout = "";
|
|
152
|
+
let stderr = "";
|
|
153
|
+
const logQueue = [];
|
|
154
|
+
let logResolve = null;
|
|
155
|
+
let closed = false;
|
|
156
|
+
child.stdout.on("data", (data) => {
|
|
157
|
+
const str = String(data);
|
|
158
|
+
stdout += str;
|
|
159
|
+
logQueue.push({ stream: "stdout", data: str });
|
|
160
|
+
logResolve?.();
|
|
161
|
+
});
|
|
162
|
+
child.stderr.on("data", (data) => {
|
|
163
|
+
const str = String(data);
|
|
164
|
+
stderr += str;
|
|
165
|
+
logQueue.push({ stream: "stderr", data: str });
|
|
166
|
+
logResolve?.();
|
|
167
|
+
});
|
|
168
|
+
const result = new Promise((resolve, reject) => {
|
|
169
|
+
child.on("error", (err) => {
|
|
170
|
+
processes.delete(commandId);
|
|
171
|
+
closed = true;
|
|
172
|
+
logResolve?.();
|
|
173
|
+
reject(err);
|
|
174
|
+
});
|
|
175
|
+
child.on("close", (code) => {
|
|
176
|
+
processes.delete(commandId);
|
|
177
|
+
closed = true;
|
|
178
|
+
logResolve?.();
|
|
179
|
+
resolve({ stdout, stderr, exitCode: code ?? 0 });
|
|
180
|
+
});
|
|
181
|
+
});
|
|
182
|
+
async function* logs() {
|
|
183
|
+
while (!closed || logQueue.length > 0) {
|
|
184
|
+
const entry = logQueue.shift();
|
|
185
|
+
if (entry) {
|
|
186
|
+
yield entry;
|
|
187
|
+
} else if (!closed) {
|
|
188
|
+
await new Promise((resolve) => {
|
|
189
|
+
logResolve = resolve;
|
|
190
|
+
});
|
|
191
|
+
logResolve = null;
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
return Promise.resolve({ commandId, logs, result });
|
|
196
|
+
},
|
|
197
|
+
catch: (e) => new SandboxError({ reason: String(e), cause: e })
|
|
198
|
+
});
|
|
199
|
+
},
|
|
200
|
+
getDomain: (port) => {
|
|
201
|
+
return Promise.resolve(`http://localhost:${port}`);
|
|
202
|
+
},
|
|
203
|
+
kill: async ({ commandId, storage: storage2 }) => {
|
|
204
|
+
const child = processes.get(commandId);
|
|
205
|
+
if (!child) {
|
|
206
|
+
return new SandboxError({
|
|
207
|
+
reason: `Command ${commandId} not found or already finished`
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
child.kill("SIGTERM");
|
|
211
|
+
const cmd = await storage2.command.get(commandId);
|
|
212
|
+
if (cmd instanceof Error) {
|
|
213
|
+
return new SandboxError({ reason: cmd.message, cause: cmd });
|
|
214
|
+
}
|
|
215
|
+
if (cmd && cmd.status === "running") {
|
|
216
|
+
const result = await storage2.command.set({
|
|
217
|
+
...cmd,
|
|
218
|
+
status: "killed"
|
|
219
|
+
});
|
|
220
|
+
if (result instanceof Error) {
|
|
221
|
+
return new SandboxError({ reason: result.message, cause: result });
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
},
|
|
225
|
+
writeFiles: (opts) => writeFiles({ sandbox, ...opts }),
|
|
226
|
+
tag: {
|
|
227
|
+
list: async () => {
|
|
228
|
+
const sandboxRecord2 = await storage.sandbox.get(sandbox.id);
|
|
229
|
+
if (sandboxRecord2 instanceof Error) {
|
|
230
|
+
return sandboxRecord2;
|
|
231
|
+
}
|
|
232
|
+
return sandboxRecord2.tags ?? {};
|
|
233
|
+
},
|
|
234
|
+
get: async (key) => {
|
|
235
|
+
const sandboxRecord2 = await storage.sandbox.get(sandbox.id);
|
|
236
|
+
if (sandboxRecord2 instanceof Error) {
|
|
237
|
+
return sandboxRecord2;
|
|
238
|
+
}
|
|
239
|
+
return sandboxRecord2.tags?.[key];
|
|
240
|
+
},
|
|
241
|
+
set: async (key, value) => {
|
|
242
|
+
const result = await storage.sandbox.tag.set({
|
|
243
|
+
sandboxId: sandbox.id,
|
|
244
|
+
tags: { [key]: value }
|
|
245
|
+
});
|
|
246
|
+
if (result instanceof Error) {
|
|
247
|
+
return result;
|
|
248
|
+
}
|
|
249
|
+
return void 0;
|
|
250
|
+
},
|
|
251
|
+
setMany: async (tags) => {
|
|
252
|
+
const result = await storage.sandbox.tag.set({
|
|
253
|
+
sandboxId: sandbox.id,
|
|
254
|
+
tags
|
|
255
|
+
});
|
|
256
|
+
if (result instanceof Error) {
|
|
257
|
+
return result;
|
|
258
|
+
}
|
|
259
|
+
return void 0;
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
};
|
|
263
|
+
return sandbox;
|
|
264
|
+
};
|
|
265
|
+
|
|
266
|
+
// src/sandbox/bindings/vercel.ts
|
|
267
|
+
import * as errore2 from "errore";
|
|
268
|
+
import { Sandbox as VercelSandboxSDK } from "sandbox";
|
|
269
|
+
var VERCEL_MAX_TIMEOUT_MS = 5 * 60 * 60 * 1e3;
|
|
270
|
+
var LOCK_TIMEOUT_MS = 2 * 60 * 1e3;
|
|
271
|
+
var LOCK_POLL_INTERVAL_MS = 200;
|
|
272
|
+
var getTestCredentials = () => process.env.NODE_ENV === "test" ? {
|
|
273
|
+
token: process.env.TEST_VERCEL_TOKEN,
|
|
274
|
+
teamId: process.env.TEST_VERCEL_TEAM_ID,
|
|
275
|
+
projectId: process.env.TEST_VERCEL_PROJECT_ID
|
|
276
|
+
} : {};
|
|
277
|
+
var createPromises = /* @__PURE__ */ new Map();
|
|
278
|
+
var ACTIVITY_THROTTLE_MS = 1e4;
|
|
279
|
+
var lastActivitySent = /* @__PURE__ */ new Map();
|
|
280
|
+
var DEFAULT_VCPUS = 2;
|
|
281
|
+
var vercelSandbox = ({
|
|
282
|
+
sandboxRecord,
|
|
283
|
+
storageConfig,
|
|
284
|
+
enableLifecycleWorkflow = true,
|
|
285
|
+
storage: storageOverride
|
|
286
|
+
}) => {
|
|
287
|
+
const { id, config } = sandboxRecord;
|
|
288
|
+
const vcpus = config.resources?.vcpus ?? DEFAULT_VCPUS;
|
|
289
|
+
const ports = config.ports;
|
|
290
|
+
const storage = storageOverride ?? getStorage(storageConfig);
|
|
291
|
+
const initialVercel = sandboxRecord.providerMetadata?.provider === "vercel" ? sandboxRecord.providerMetadata : null;
|
|
292
|
+
let sandboxPromise = null;
|
|
293
|
+
const HOME_DIR = "/home/vercel-sandbox";
|
|
294
|
+
async function pollForSandboxId() {
|
|
295
|
+
const deadline = Date.now() + LOCK_TIMEOUT_MS;
|
|
296
|
+
while (Date.now() < deadline) {
|
|
297
|
+
await new Promise((r) => setTimeout(r, LOCK_POLL_INTERVAL_MS));
|
|
298
|
+
const record = await storage.sandbox.get(id);
|
|
299
|
+
if (record instanceof Error) {
|
|
300
|
+
return new SandboxError({ reason: record.message, cause: record });
|
|
301
|
+
}
|
|
302
|
+
const vercelSandboxId = record?.providerMetadata?.provider === "vercel" ? record.providerMetadata.sandboxId : null;
|
|
303
|
+
if (vercelSandboxId) {
|
|
304
|
+
return vercelSandboxId;
|
|
305
|
+
}
|
|
306
|
+
if (!record?.acquiringLockAt) {
|
|
307
|
+
const finalCheck = await storage.sandbox.get(id);
|
|
308
|
+
if (finalCheck instanceof Error) {
|
|
309
|
+
return new SandboxError({
|
|
310
|
+
reason: finalCheck.message,
|
|
311
|
+
cause: finalCheck
|
|
312
|
+
});
|
|
313
|
+
}
|
|
314
|
+
const finalVercelSandboxId = finalCheck?.providerMetadata?.provider === "vercel" ? finalCheck.providerMetadata.sandboxId : null;
|
|
315
|
+
if (finalVercelSandboxId) {
|
|
316
|
+
return finalVercelSandboxId;
|
|
317
|
+
}
|
|
318
|
+
return doGetOrCreateSandboxId();
|
|
319
|
+
}
|
|
320
|
+
}
|
|
321
|
+
return new SandboxError({
|
|
322
|
+
reason: "Timed out waiting for sandbox creation by another process"
|
|
323
|
+
});
|
|
324
|
+
}
|
|
325
|
+
async function createSandboxFromSnapshot(snapshotId) {
|
|
326
|
+
return await errore2.tryAsync({
|
|
327
|
+
try: async () => {
|
|
328
|
+
const sandbox2 = await VercelSandboxSDK.create({
|
|
329
|
+
source: { type: "snapshot", snapshotId },
|
|
330
|
+
resources: { vcpus },
|
|
331
|
+
timeout: VERCEL_MAX_TIMEOUT_MS,
|
|
332
|
+
ports,
|
|
333
|
+
...getTestCredentials()
|
|
334
|
+
});
|
|
335
|
+
const now = Date.now();
|
|
336
|
+
await storage.sandbox.set({
|
|
337
|
+
id,
|
|
338
|
+
config,
|
|
339
|
+
tags: sandboxRecord.tags,
|
|
340
|
+
createdAt: now,
|
|
341
|
+
lastActivityAt: now,
|
|
342
|
+
acquiringLockId: null,
|
|
343
|
+
acquiringLockAt: null,
|
|
344
|
+
providerMetadata: {
|
|
345
|
+
provider: "vercel",
|
|
346
|
+
sandboxId: sandbox2.sandboxId,
|
|
347
|
+
snapshotId
|
|
348
|
+
}
|
|
349
|
+
});
|
|
350
|
+
return sandbox2.sandboxId;
|
|
351
|
+
},
|
|
352
|
+
catch: (e) => new SandboxError({ reason: String(e), cause: e })
|
|
353
|
+
});
|
|
354
|
+
}
|
|
355
|
+
async function createFreshSandbox() {
|
|
356
|
+
return await errore2.tryAsync({
|
|
357
|
+
try: async () => {
|
|
358
|
+
const sandbox2 = await VercelSandboxSDK.create({
|
|
359
|
+
resources: { vcpus },
|
|
360
|
+
timeout: VERCEL_MAX_TIMEOUT_MS,
|
|
361
|
+
ports,
|
|
362
|
+
...getTestCredentials()
|
|
363
|
+
});
|
|
364
|
+
const now = Date.now();
|
|
365
|
+
await storage.sandbox.set({
|
|
366
|
+
id,
|
|
367
|
+
config,
|
|
368
|
+
tags: sandboxRecord.tags,
|
|
369
|
+
createdAt: now,
|
|
370
|
+
lastActivityAt: now,
|
|
371
|
+
acquiringLockId: null,
|
|
372
|
+
acquiringLockAt: null,
|
|
373
|
+
providerMetadata: {
|
|
374
|
+
provider: "vercel",
|
|
375
|
+
sandboxId: sandbox2.sandboxId,
|
|
376
|
+
snapshotId: null
|
|
377
|
+
}
|
|
378
|
+
});
|
|
379
|
+
return sandbox2.sandboxId;
|
|
380
|
+
},
|
|
381
|
+
catch: (e) => new SandboxError({ reason: String(e), cause: e })
|
|
382
|
+
});
|
|
383
|
+
}
|
|
384
|
+
async function doGetOrCreateSandboxId() {
|
|
385
|
+
if (initialVercel?.sandboxId) {
|
|
386
|
+
return initialVercel.sandboxId;
|
|
387
|
+
}
|
|
388
|
+
const existing = await storage.sandbox.get(id);
|
|
389
|
+
if (existing instanceof Error) {
|
|
390
|
+
if (existing instanceof SandboxNotFoundError) {
|
|
391
|
+
} else {
|
|
392
|
+
return new SandboxError({ reason: existing.message, cause: existing });
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
const existingRecord = existing instanceof SandboxNotFoundError ? null : existing;
|
|
396
|
+
const existingVercel = existingRecord?.providerMetadata?.provider === "vercel" ? existingRecord.providerMetadata : null;
|
|
397
|
+
if (existingVercel?.sandboxId) {
|
|
398
|
+
return existingVercel.sandboxId;
|
|
399
|
+
}
|
|
400
|
+
const hasActiveLock = existingRecord?.acquiringLockId && existingRecord.acquiringLockAt && Date.now() - existingRecord.acquiringLockAt < LOCK_TIMEOUT_MS;
|
|
401
|
+
if (hasActiveLock) {
|
|
402
|
+
return pollForSandboxId();
|
|
403
|
+
}
|
|
404
|
+
const lockId = crypto.randomUUID();
|
|
405
|
+
const now = Date.now();
|
|
406
|
+
await storage.sandbox.set({
|
|
407
|
+
id,
|
|
408
|
+
config,
|
|
409
|
+
tags: existingRecord?.tags ?? sandboxRecord.tags,
|
|
410
|
+
createdAt: existingRecord?.createdAt ?? sandboxRecord.createdAt,
|
|
411
|
+
lastActivityAt: existingRecord?.lastActivityAt ?? sandboxRecord.lastActivityAt,
|
|
412
|
+
acquiringLockId: lockId,
|
|
413
|
+
acquiringLockAt: now,
|
|
414
|
+
providerMetadata: {
|
|
415
|
+
provider: "vercel",
|
|
416
|
+
sandboxId: null,
|
|
417
|
+
snapshotId: existingVercel?.snapshotId ?? initialVercel?.snapshotId ?? null
|
|
418
|
+
}
|
|
419
|
+
});
|
|
420
|
+
const afterLock = await storage.sandbox.get(id);
|
|
421
|
+
if (afterLock instanceof Error) {
|
|
422
|
+
return new SandboxError({ reason: afterLock.message, cause: afterLock });
|
|
423
|
+
}
|
|
424
|
+
if (afterLock?.acquiringLockId !== lockId) {
|
|
425
|
+
return pollForSandboxId();
|
|
426
|
+
}
|
|
427
|
+
const snapshotId = existingVercel?.snapshotId ?? initialVercel?.snapshotId ?? config.lifecycle?.snapshotId;
|
|
428
|
+
if (snapshotId) {
|
|
429
|
+
const result = await createSandboxFromSnapshot(snapshotId);
|
|
430
|
+
if (!(result instanceof Error)) {
|
|
431
|
+
return result;
|
|
432
|
+
}
|
|
433
|
+
}
|
|
434
|
+
return createFreshSandbox();
|
|
435
|
+
}
|
|
436
|
+
function getOrCreateSandboxId() {
|
|
437
|
+
const cached = createPromises.get(id);
|
|
438
|
+
if (cached) {
|
|
439
|
+
return cached;
|
|
440
|
+
}
|
|
441
|
+
const promise = doGetOrCreateSandboxId().finally(() => {
|
|
442
|
+
createPromises.delete(id);
|
|
443
|
+
});
|
|
444
|
+
createPromises.set(id, promise);
|
|
445
|
+
return promise;
|
|
446
|
+
}
|
|
447
|
+
async function doGetSandbox() {
|
|
448
|
+
const vercelSandboxId = await getOrCreateSandboxId();
|
|
449
|
+
if (vercelSandboxId instanceof Error) {
|
|
450
|
+
return vercelSandboxId;
|
|
451
|
+
}
|
|
452
|
+
return errore2.tryAsync({
|
|
453
|
+
try: () => VercelSandboxSDK.get({
|
|
454
|
+
sandboxId: vercelSandboxId,
|
|
455
|
+
...getTestCredentials()
|
|
456
|
+
}),
|
|
457
|
+
catch: (e) => new SandboxError({ reason: String(e), cause: e })
|
|
458
|
+
});
|
|
459
|
+
}
|
|
460
|
+
function getSandbox2() {
|
|
461
|
+
if (!sandboxPromise) {
|
|
462
|
+
sandboxPromise = doGetSandbox();
|
|
463
|
+
}
|
|
464
|
+
return sandboxPromise;
|
|
465
|
+
}
|
|
466
|
+
async function updateLastActivity() {
|
|
467
|
+
const now = Date.now();
|
|
468
|
+
const lastSent = lastActivitySent.get(id);
|
|
469
|
+
if (lastSent && now - lastSent < ACTIVITY_THROTTLE_MS) {
|
|
470
|
+
return;
|
|
471
|
+
}
|
|
472
|
+
lastActivitySent.set(id, now);
|
|
473
|
+
const existing = await storage.sandbox.get(id);
|
|
474
|
+
if (existing instanceof Error || !existing) {
|
|
475
|
+
return;
|
|
476
|
+
}
|
|
477
|
+
const existingVercel = existing.providerMetadata?.provider === "vercel" ? existing.providerMetadata : null;
|
|
478
|
+
await storage.sandbox.set({
|
|
479
|
+
id: existing.id,
|
|
480
|
+
config: existing.config,
|
|
481
|
+
tags: existing.tags,
|
|
482
|
+
createdAt: existing.createdAt,
|
|
483
|
+
lastActivityAt: now,
|
|
484
|
+
acquiringLockId: null,
|
|
485
|
+
acquiringLockAt: null,
|
|
486
|
+
providerMetadata: existingVercel ?? {
|
|
487
|
+
provider: "vercel",
|
|
488
|
+
sandboxId: null,
|
|
489
|
+
snapshotId: null
|
|
490
|
+
}
|
|
491
|
+
});
|
|
492
|
+
if (enableLifecycleWorkflow) {
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
const lifecycle = {
|
|
496
|
+
start: async () => {
|
|
497
|
+
const sandbox2 = await getSandbox2();
|
|
498
|
+
if (sandbox2 instanceof Error) {
|
|
499
|
+
return sandbox2;
|
|
500
|
+
}
|
|
501
|
+
await updateLastActivity();
|
|
502
|
+
return sandbox2.status;
|
|
503
|
+
},
|
|
504
|
+
snapshot: async () => {
|
|
505
|
+
const sandbox2 = await getSandbox2();
|
|
506
|
+
if (sandbox2 instanceof Error) {
|
|
507
|
+
return sandbox2;
|
|
508
|
+
}
|
|
509
|
+
return errore2.tryAsync({
|
|
510
|
+
try: async () => {
|
|
511
|
+
const existing = await storage.sandbox.get(id);
|
|
512
|
+
const snapshot = await sandbox2.snapshot();
|
|
513
|
+
await storage.sandbox.set({
|
|
514
|
+
id,
|
|
515
|
+
config,
|
|
516
|
+
tags: existing instanceof Error ? null : existing?.tags ?? null,
|
|
517
|
+
createdAt: existing instanceof Error ? null : existing?.createdAt ?? null,
|
|
518
|
+
lastActivityAt: existing instanceof Error ? null : existing?.lastActivityAt ?? null,
|
|
519
|
+
acquiringLockId: null,
|
|
520
|
+
acquiringLockAt: null,
|
|
521
|
+
providerMetadata: {
|
|
522
|
+
provider: "vercel",
|
|
523
|
+
sandboxId: null,
|
|
524
|
+
snapshotId: snapshot.snapshotId
|
|
525
|
+
}
|
|
526
|
+
});
|
|
527
|
+
return { snapshotId: snapshot.snapshotId };
|
|
528
|
+
},
|
|
529
|
+
catch: (e) => new SandboxError({ reason: String(e), cause: e })
|
|
530
|
+
});
|
|
531
|
+
},
|
|
532
|
+
stop: async () => {
|
|
533
|
+
const sandbox2 = await getSandbox2();
|
|
534
|
+
if (sandbox2 instanceof Error) {
|
|
535
|
+
return sandbox2;
|
|
536
|
+
}
|
|
537
|
+
return errore2.tryAsync({
|
|
538
|
+
try: async () => {
|
|
539
|
+
await sandbox2.stop();
|
|
540
|
+
const existing = await storage.sandbox.get(id);
|
|
541
|
+
if (existing instanceof Error || !existing) {
|
|
542
|
+
return void 0;
|
|
543
|
+
}
|
|
544
|
+
await storage.sandbox.set({
|
|
545
|
+
id: existing.id,
|
|
546
|
+
config: existing.config,
|
|
547
|
+
tags: existing.tags,
|
|
548
|
+
createdAt: existing.createdAt,
|
|
549
|
+
lastActivityAt: existing.lastActivityAt,
|
|
550
|
+
acquiringLockId: null,
|
|
551
|
+
acquiringLockAt: null,
|
|
552
|
+
providerMetadata: {
|
|
553
|
+
provider: "vercel",
|
|
554
|
+
sandboxId: null,
|
|
555
|
+
snapshotId: null
|
|
556
|
+
}
|
|
557
|
+
});
|
|
558
|
+
return void 0;
|
|
559
|
+
},
|
|
560
|
+
catch: (e) => new SandboxError({ reason: String(e), cause: e })
|
|
561
|
+
});
|
|
562
|
+
},
|
|
563
|
+
getStatus: async () => {
|
|
564
|
+
const sandbox2 = await getSandbox2();
|
|
565
|
+
if (sandbox2 instanceof Error) {
|
|
566
|
+
return sandbox2;
|
|
567
|
+
}
|
|
568
|
+
return sandbox2.status;
|
|
569
|
+
},
|
|
570
|
+
getCreatedAt: async () => {
|
|
571
|
+
const sandbox2 = await getSandbox2();
|
|
572
|
+
if (sandbox2 instanceof Error) {
|
|
573
|
+
return sandbox2;
|
|
574
|
+
}
|
|
575
|
+
return sandbox2.createdAt;
|
|
576
|
+
},
|
|
577
|
+
getRemainingTimeout: async () => {
|
|
578
|
+
const sandbox2 = await getSandbox2();
|
|
579
|
+
if (sandbox2 instanceof Error) {
|
|
580
|
+
return sandbox2;
|
|
581
|
+
}
|
|
582
|
+
return sandbox2.timeout;
|
|
583
|
+
}
|
|
584
|
+
};
|
|
585
|
+
const sandbox = {
|
|
586
|
+
id,
|
|
587
|
+
config,
|
|
588
|
+
exec: async ({ command, args, signal }) => {
|
|
589
|
+
const instance = await getSandbox2();
|
|
590
|
+
if (instance instanceof Error) {
|
|
591
|
+
return instance;
|
|
592
|
+
}
|
|
593
|
+
const updatePromise = updateLastActivity();
|
|
594
|
+
const execResult = await errore2.tryAsync({
|
|
595
|
+
try: async () => {
|
|
596
|
+
const output = await instance.runCommand({
|
|
597
|
+
cwd: HOME_DIR,
|
|
598
|
+
args,
|
|
599
|
+
cmd: command,
|
|
600
|
+
signal
|
|
601
|
+
});
|
|
602
|
+
let stdout = "";
|
|
603
|
+
let stderr = "";
|
|
604
|
+
const logBuffer = [];
|
|
605
|
+
const state = {
|
|
606
|
+
resolve: null,
|
|
607
|
+
consumed: false
|
|
608
|
+
};
|
|
609
|
+
const consumeLogs = (async () => {
|
|
610
|
+
for await (const log of output.logs()) {
|
|
611
|
+
const entry = log.stream === "stdout" ? { stream: "stdout", data: log.data } : { stream: "stderr", data: log.data };
|
|
612
|
+
if (log.stream === "stdout") {
|
|
613
|
+
stdout += log.data;
|
|
614
|
+
} else {
|
|
615
|
+
stderr += log.data;
|
|
616
|
+
}
|
|
617
|
+
logBuffer.push(entry);
|
|
618
|
+
state.resolve?.();
|
|
619
|
+
}
|
|
620
|
+
state.consumed = true;
|
|
621
|
+
state.resolve?.();
|
|
622
|
+
})();
|
|
623
|
+
async function* logs() {
|
|
624
|
+
let index = 0;
|
|
625
|
+
while (!state.consumed || index < logBuffer.length) {
|
|
626
|
+
if (index < logBuffer.length) {
|
|
627
|
+
yield logBuffer[index++];
|
|
628
|
+
} else {
|
|
629
|
+
await new Promise((resolve) => {
|
|
630
|
+
state.resolve = resolve;
|
|
631
|
+
});
|
|
632
|
+
state.resolve = null;
|
|
633
|
+
}
|
|
634
|
+
}
|
|
635
|
+
}
|
|
636
|
+
const result = consumeLogs.then(() => ({
|
|
637
|
+
stdout,
|
|
638
|
+
stderr,
|
|
639
|
+
exitCode: output.exitCode
|
|
640
|
+
}));
|
|
641
|
+
return { commandId: output.cmdId, logs, result };
|
|
642
|
+
},
|
|
643
|
+
catch: (e) => new SandboxError({ reason: String(e), cause: e })
|
|
644
|
+
});
|
|
645
|
+
await updatePromise;
|
|
646
|
+
return execResult;
|
|
647
|
+
},
|
|
648
|
+
getDomain: async (port) => {
|
|
649
|
+
const sandbox2 = await getSandbox2();
|
|
650
|
+
if (sandbox2 instanceof Error) {
|
|
651
|
+
return sandbox2;
|
|
652
|
+
}
|
|
653
|
+
try {
|
|
654
|
+
return sandbox2.domain(port);
|
|
655
|
+
} catch (e) {
|
|
656
|
+
return new SandboxError({ reason: String(e), cause: e });
|
|
657
|
+
}
|
|
658
|
+
},
|
|
659
|
+
kill: async ({ commandId, storage: cmdStorage }) => {
|
|
660
|
+
const instance = await getSandbox2();
|
|
661
|
+
if (instance instanceof Error) {
|
|
662
|
+
return instance;
|
|
663
|
+
}
|
|
664
|
+
const cmd = await cmdStorage.command.get(commandId);
|
|
665
|
+
if (cmd instanceof Error) {
|
|
666
|
+
return new SandboxError({ reason: cmd.message, cause: cmd });
|
|
667
|
+
}
|
|
668
|
+
if (cmd && cmd.status === "running") {
|
|
669
|
+
const result = await cmdStorage.command.set({
|
|
670
|
+
...cmd,
|
|
671
|
+
status: "killed"
|
|
672
|
+
});
|
|
673
|
+
if (result instanceof Error) {
|
|
674
|
+
return new SandboxError({ reason: result.message, cause: result });
|
|
675
|
+
}
|
|
676
|
+
}
|
|
677
|
+
return void 0;
|
|
678
|
+
},
|
|
679
|
+
writeFiles: (opts) => writeFiles({ sandbox, ...opts }),
|
|
680
|
+
lifecycle,
|
|
681
|
+
tag: {
|
|
682
|
+
list: async () => {
|
|
683
|
+
const sandboxRecord2 = await storage.sandbox.get(id);
|
|
684
|
+
if (sandboxRecord2 instanceof Error) {
|
|
685
|
+
return sandboxRecord2;
|
|
686
|
+
}
|
|
687
|
+
return sandboxRecord2.tags ?? {};
|
|
688
|
+
},
|
|
689
|
+
get: async (key) => {
|
|
690
|
+
const sandboxRecord2 = await storage.sandbox.get(id);
|
|
691
|
+
if (sandboxRecord2 instanceof Error) {
|
|
692
|
+
return sandboxRecord2;
|
|
693
|
+
}
|
|
694
|
+
return sandboxRecord2.tags?.[key];
|
|
695
|
+
},
|
|
696
|
+
set: async (key, value) => {
|
|
697
|
+
const result = await storage.sandbox.tag.set({
|
|
698
|
+
sandboxId: id,
|
|
699
|
+
tags: { [key]: value }
|
|
700
|
+
});
|
|
701
|
+
if (result instanceof Error) {
|
|
702
|
+
return result;
|
|
703
|
+
}
|
|
704
|
+
return void 0;
|
|
705
|
+
},
|
|
706
|
+
setMany: async (tags) => {
|
|
707
|
+
const result = await storage.sandbox.tag.set({
|
|
708
|
+
sandboxId: id,
|
|
709
|
+
tags
|
|
710
|
+
});
|
|
711
|
+
if (result instanceof Error) {
|
|
712
|
+
return result;
|
|
713
|
+
}
|
|
714
|
+
return void 0;
|
|
715
|
+
}
|
|
716
|
+
}
|
|
717
|
+
};
|
|
718
|
+
if (config.lifecycle?.autoStart !== false) {
|
|
719
|
+
sandboxPromise = doGetSandbox();
|
|
720
|
+
}
|
|
721
|
+
return sandbox;
|
|
722
|
+
};
|
|
723
|
+
|
|
724
|
+
// src/sandbox/client.ts
|
|
725
|
+
function getSandbox({
|
|
726
|
+
sandboxRecord,
|
|
727
|
+
storageConfig
|
|
728
|
+
}) {
|
|
729
|
+
const { config } = sandboxRecord;
|
|
730
|
+
switch (config.type) {
|
|
731
|
+
case "local":
|
|
732
|
+
return localSandbox({
|
|
733
|
+
sandboxRecord,
|
|
734
|
+
storageConfig
|
|
735
|
+
});
|
|
736
|
+
case "vercel":
|
|
737
|
+
return vercelSandbox({
|
|
738
|
+
sandboxRecord,
|
|
739
|
+
storageConfig
|
|
740
|
+
});
|
|
741
|
+
case "custom":
|
|
742
|
+
throw new Error("Custom sandboxes are not supported");
|
|
743
|
+
default:
|
|
744
|
+
config;
|
|
745
|
+
throw new Error(
|
|
746
|
+
`Unknown sandbox type: ${// biome-ignore lint/suspicious/noExplicitAny: .
|
|
747
|
+
config.type}`
|
|
748
|
+
);
|
|
749
|
+
}
|
|
750
|
+
}
|
|
751
|
+
|
|
752
|
+
export {
|
|
753
|
+
getSandbox
|
|
754
|
+
};
|
|
755
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/sandbox/bindings/local.ts", "../src/sandbox/write-files.ts", "../src/sandbox/bindings/vercel.ts", "../src/sandbox/client.ts"],
  "sourcesContent": ["import type { ChildProcess } from \"node:child_process\";\nimport { spawn } from \"node:child_process\";\nimport * as errore from \"errore\";\nimport { ulid } from \"ulid\";\nimport { SandboxError } from \"../../errors\";\nimport type { TagsSchema } from \"../../index\";\nimport {\n  getStorage,\n  type SandboxRecord,\n  type StorageConfig,\n} from \"../../storage\";\nimport type { LogEntry, Sandbox } from \"../types\";\nimport { writeFiles } from \"../write-files\";\n\nexport const localSandbox = <TTags extends TagsSchema = TagsSchema>({\n  sandboxRecord,\n  storageConfig,\n}: {\n  sandboxRecord: SandboxRecord & { config: { type: \"local\" } };\n  storageConfig: StorageConfig;\n}): Sandbox<TTags> => {\n  const config = sandboxRecord.config;\n  const basePath = config.path ?? process.cwd();\n  const processes = new Map<string, ChildProcess>();\n  const storage = getStorage(storageConfig);\n\n  const sandbox: Sandbox<TTags> = {\n    id: sandboxRecord.id,\n    config: sandboxRecord.config,\n    exec: ({ command, args, signal }) => {\n      return errore.tryAsync({\n        try: () => {\n          const commandId = `command_${ulid()}`;\n\n          const child = spawn(command, args, {\n            cwd: basePath,\n            signal,\n          });\n\n          processes.set(commandId, child);\n\n          let stdout = \"\";\n          let stderr = \"\";\n          const logQueue: LogEntry[] = [];\n          let logResolve: (() => void) | null = null;\n          let closed = false;\n\n          child.stdout.on(\"data\", (data: string | Buffer) => {\n            const str = String(data);\n            stdout += str;\n            logQueue.push({ stream: \"stdout\", data: str });\n            logResolve?.();\n          });\n\n          child.stderr.on(\"data\", (data: string | Buffer) => {\n            const str = String(data);\n            stderr += str;\n            logQueue.push({ stream: \"stderr\", data: str });\n            logResolve?.();\n          });\n\n          const result = new Promise<{\n            stdout: string;\n            stderr: string;\n            exitCode: number;\n          }>((resolve, reject) => {\n            child.on(\"error\", (err) => {\n              processes.delete(commandId);\n              closed = true;\n              logResolve?.();\n              reject(err);\n            });\n\n            child.on(\"close\", (code: number | null) => {\n              processes.delete(commandId);\n              closed = true;\n              logResolve?.();\n              resolve({ stdout, stderr, exitCode: code ?? 0 });\n            });\n          });\n\n          async function* logs(): AsyncIterable<LogEntry> {\n            while (!closed || logQueue.length > 0) {\n              const entry = logQueue.shift();\n              if (entry) {\n                yield entry;\n              } else if (!closed) {\n                await new Promise<void>((resolve) => {\n                  logResolve = resolve;\n                });\n                logResolve = null;\n              }\n            }\n          }\n\n          return Promise.resolve({ commandId, logs, result });\n        },\n        catch: (e: unknown) =>\n          new SandboxError({ reason: String(e), cause: e }),\n      });\n    },\n\n    getDomain: (port) => {\n      return Promise.resolve(`http://localhost:${port}`);\n    },\n\n    kill: async ({ commandId, storage }) => {\n      const child = processes.get(commandId);\n      if (!child) {\n        return new SandboxError({\n          reason: `Command ${commandId} not found or already finished`,\n        });\n      }\n\n      child.kill(\"SIGTERM\");\n\n      const cmd = await storage.command.get(commandId);\n      if (cmd instanceof Error) {\n        return new SandboxError({ reason: cmd.message, cause: cmd });\n      }\n      if (cmd && cmd.status === \"running\") {\n        const result = await storage.command.set({\n          ...cmd,\n          status: \"killed\",\n        });\n        if (result instanceof Error) {\n          return new SandboxError({ reason: result.message, cause: result });\n        }\n      }\n    },\n\n    writeFiles: (opts) => writeFiles({ sandbox, ...opts }),\n\n    tag: {\n      list: async () => {\n        const sandboxRecord = await storage.sandbox.get(sandbox.id);\n        if (sandboxRecord instanceof Error) {\n          return sandboxRecord;\n        }\n        return (sandboxRecord.tags ?? {}) as TTags;\n      },\n      get: async (key: string) => {\n        const sandboxRecord = await storage.sandbox.get(sandbox.id);\n        if (sandboxRecord instanceof Error) {\n          return sandboxRecord;\n        }\n        return sandboxRecord.tags?.[key as string] as\n          | TTags[typeof key]\n          | undefined;\n      },\n      set: async (key: string, value: unknown) => {\n        const result = await storage.sandbox.tag.set({\n          sandboxId: sandbox.id,\n          tags: { [key]: value } as Record<string, unknown>,\n        });\n        if (result instanceof Error) {\n          return result;\n        }\n        return undefined;\n      },\n      setMany: async (tags: Record<string, unknown>) => {\n        const result = await storage.sandbox.tag.set({\n          sandboxId: sandbox.id,\n          tags: tags as Record<string, unknown>,\n        });\n        if (result instanceof Error) {\n          return result;\n        }\n        return undefined;\n      },\n    },\n  };\n\n  return sandbox;\n};\n", "import * as path from \"node:path\";\nimport type { UploadableFile } from \"../skills/types\";\nimport type { Sandbox } from \"./types\";\n\n/**\n * Writes files to a sandbox at the specified destination path.\n * Shell scripts (.sh files) are automatically made executable.\n *\n * For small files (<100KB total), uses single exec with heredoc.\n * For large files, writes base64 chunks then decodes to avoid ARG_MAX limits.\n */\nexport async function writeFiles(opts: {\n  sandbox: Pick<Sandbox, \"exec\">;\n  files: UploadableFile[];\n  destPath: string;\n}): Promise<void> {\n  const { sandbox, files, destPath } = opts;\n\n  if (files.length === 0) {\n    return;\n  }\n\n  const filePaths = files.map((file) =>\n    path.posix.join(destPath, file.path)\n  );\n  const parentDirs = Array.from(\n    new Set(filePaths.map((p) => path.posix.dirname(p)))\n  );\n  const shellScripts = filePaths.filter((p) => p.endsWith(\".sh\"));\n\n  const mkdirResult = await sandbox.exec({\n    command: \"mkdir\",\n    args: [\"-p\", ...parentDirs],\n  });\n  if (mkdirResult instanceof Error) {\n    throw mkdirResult;\n  }\n  await mkdirResult.result;\n\n  const CHUNK_SIZE = 50_000;\n\n  for (let i = 0; i < files.length; i++) {\n    const file = files[i];\n    const fullPath = filePaths[i];\n    const base64Content = toBase64(file.content);\n\n    if (base64Content.length < CHUNK_SIZE) {\n      const marker = `EOF_${i}`;\n      const execResult = await sandbox.exec({\n        command: \"bash\",\n        args: [\n          \"-c\",\n          `base64 -d > ${quote(fullPath)} << '${marker}'\n${base64Content}\n${marker}`,\n        ],\n      });\n\n      if (execResult instanceof Error) {\n        throw execResult;\n      }\n\n      const { exitCode, stderr } = await execResult.result;\n      if (exitCode !== 0) {\n        throw new Error(\n          `writeFiles failed with exit code ${exitCode}: ${stderr}`\n        );\n      }\n    } else {\n      const tempB64 = `/tmp/chunk-${Date.now()}-${i}.b64`;\n\n      const clearResult = await sandbox.exec({\n        command: \"bash\",\n        args: [\"-c\", `> ${quote(tempB64)}`],\n      });\n      if (clearResult instanceof Error) {\n        throw clearResult;\n      }\n      await clearResult.result;\n\n      for (\n        let offset = 0;\n        offset < base64Content.length;\n        offset += CHUNK_SIZE\n      ) {\n        const chunk = base64Content.slice(offset, offset + CHUNK_SIZE);\n        const marker = `CHUNK_${offset}`;\n        const appendResult = await sandbox.exec({\n          command: \"bash\",\n          args: [\n            \"-c\",\n            `cat >> ${quote(tempB64)} << '${marker}'\n${chunk}\n${marker}`,\n          ],\n        });\n\n        if (appendResult instanceof Error) {\n          throw appendResult;\n        }\n\n        const { exitCode, stderr } = await appendResult.result;\n        if (exitCode !== 0) {\n          throw new Error(\n            `writeFiles chunk failed with exit code ${exitCode}: ${stderr}`\n          );\n        }\n      }\n\n      const decodeResult = await sandbox.exec({\n        command: \"bash\",\n        args: [\n          \"-c\",\n          `base64 -d < ${quote(tempB64)} > ${quote(fullPath)} && rm -f ${quote(tempB64)}`,\n        ],\n      });\n\n      if (decodeResult instanceof Error) {\n        throw decodeResult;\n      }\n\n      const { exitCode, stderr } = await decodeResult.result;\n      if (exitCode !== 0) {\n        throw new Error(\n          `writeFiles decode failed with exit code ${exitCode}: ${stderr}`\n        );\n      }\n    }\n  }\n\n  if (shellScripts.length > 0) {\n    const chmodResult = await sandbox.exec({\n      command: \"chmod\",\n      args: [\"+x\", ...shellScripts],\n    });\n    if (chmodResult instanceof Error) {\n      throw chmodResult;\n    }\n    await chmodResult.result;\n  }\n}\n\nfunction toBase64(content: string | Buffer): string {\n  if (typeof content === \"string\") {\n    return Buffer.from(content).toString(\"base64\");\n  }\n  return content.toString(\"base64\");\n}\n\nfunction quote(s: string): string {\n  return `'${s.replace(/'/g, \"'\\\\''\")}'`;\n}\n", "import * as errore from \"errore\";\nimport { Sandbox as VercelSandboxSDK } from \"sandbox\";\nimport { SandboxError, SandboxNotFoundError } from \"../../errors\";\nimport type { TagsSchema } from \"../../index\";\nimport {\n  getStorage,\n  type SandboxRecord,\n  type Storage,\n  type StorageConfig,\n} from \"../../storage\";\nimport type {\n  LogEntry,\n  Sandbox,\n  SandboxLifecycle,\n  SandboxStatus,\n} from \"../types\";\nimport { writeFiles } from \"../write-files\";\n\nexport type VercelSandboxCreateOptions = Extract<\n  Parameters<typeof VercelSandboxSDK.create>[0],\n  // biome-ignore lint/complexity/noBannedTypes: .\n  {}\n>;\n\nexport const VERCEL_MAX_TIMEOUT_MS = 5 * 60 * 60 * 1000; // 5 hours\nconst LOCK_TIMEOUT_MS = 2 * 60 * 1000; // 2 minutes - if lock older than this, consider it stale\nconst LOCK_POLL_INTERVAL_MS = 200;\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\n/**\n * Module-level cache for in-flight sandbox creation promises.\n * Prevents parallel requests within the same process from creating duplicate sandboxes.\n */\nconst createPromises = new Map<string, Promise<SandboxError | string>>();\n\nconst ACTIVITY_THROTTLE_MS = 10_000;\nconst lastActivitySent = new Map<string, number>();\n\nconst DEFAULT_VCPUS = 2;\n\nexport const vercelSandbox = <TTags extends TagsSchema = TagsSchema>({\n  sandboxRecord,\n  storageConfig,\n  enableLifecycleWorkflow = true,\n  storage: storageOverride,\n}: {\n  sandboxRecord: SandboxRecord & { config: { type: \"vercel\" } };\n  storageConfig: StorageConfig;\n  enableLifecycleWorkflow?: boolean;\n  storage?: Storage;\n}): Sandbox<TTags> => {\n  const { id, config } = sandboxRecord;\n  const vcpus = config.resources?.vcpus ?? DEFAULT_VCPUS;\n  const ports = config.ports;\n  const storage = storageOverride ?? getStorage(storageConfig);\n  const initialVercel =\n    sandboxRecord.providerMetadata?.provider === \"vercel\"\n      ? sandboxRecord.providerMetadata\n      : null;\n\n  type SandboxInstance = Awaited<ReturnType<typeof VercelSandboxSDK.get>>;\n  let sandboxPromise: Promise<SandboxError | SandboxInstance> | null = null;\n  const HOME_DIR = \"/home/vercel-sandbox\";\n\n  async function pollForSandboxId(): Promise<SandboxError | string> {\n    const deadline = Date.now() + LOCK_TIMEOUT_MS;\n    while (Date.now() < deadline) {\n      await new Promise((r) => setTimeout(r, LOCK_POLL_INTERVAL_MS));\n      const record = await storage.sandbox.get(id);\n      if (record instanceof Error) {\n        return new SandboxError({ reason: record.message, cause: record });\n      }\n      const vercelSandboxId =\n        record?.providerMetadata?.provider === \"vercel\"\n          ? record.providerMetadata.sandboxId\n          : null;\n      if (vercelSandboxId) {\n        return vercelSandboxId;\n      }\n      if (!record?.acquiringLockAt) {\n        const finalCheck = await storage.sandbox.get(id);\n        if (finalCheck instanceof Error) {\n          return new SandboxError({\n            reason: finalCheck.message,\n            cause: finalCheck,\n          });\n        }\n        const finalVercelSandboxId =\n          finalCheck?.providerMetadata?.provider === \"vercel\"\n            ? finalCheck.providerMetadata.sandboxId\n            : null;\n        if (finalVercelSandboxId) {\n          return finalVercelSandboxId;\n        }\n        return doGetOrCreateSandboxId();\n      }\n    }\n    return new SandboxError({\n      reason: \"Timed out waiting for sandbox creation by another process\",\n    });\n  }\n\n  async function createSandboxFromSnapshot(\n    snapshotId: string\n  ): Promise<SandboxError | string> {\n    return await errore.tryAsync({\n      try: async () => {\n        const sandbox = await VercelSandboxSDK.create({\n          source: { type: \"snapshot\", snapshotId },\n          resources: { vcpus },\n          timeout: VERCEL_MAX_TIMEOUT_MS,\n          ports,\n          ...getTestCredentials(),\n        });\n        const now = Date.now();\n        await storage.sandbox.set({\n          id,\n          config,\n          tags: sandboxRecord.tags,\n          createdAt: now,\n          lastActivityAt: now,\n          acquiringLockId: null,\n          acquiringLockAt: null,\n          providerMetadata: {\n            provider: \"vercel\",\n            sandboxId: sandbox.sandboxId,\n            snapshotId,\n          },\n        });\n        return sandbox.sandboxId;\n      },\n      catch: (e) => new SandboxError({ reason: String(e), cause: e }),\n    });\n  }\n\n  async function createFreshSandbox(): Promise<SandboxError | string> {\n    return await errore.tryAsync({\n      try: async () => {\n        const sandbox = await VercelSandboxSDK.create({\n          resources: { vcpus },\n          timeout: VERCEL_MAX_TIMEOUT_MS,\n          ports,\n          ...getTestCredentials(),\n        });\n        const now = Date.now();\n        await storage.sandbox.set({\n          id,\n          config,\n          tags: sandboxRecord.tags,\n          createdAt: now,\n          lastActivityAt: now,\n          acquiringLockId: null,\n          acquiringLockAt: null,\n          providerMetadata: {\n            provider: \"vercel\",\n            sandboxId: sandbox.sandboxId,\n            snapshotId: null,\n          },\n        });\n        return sandbox.sandboxId;\n      },\n      catch: (e) => new SandboxError({ reason: String(e), cause: e }),\n    });\n  }\n\n  async function doGetOrCreateSandboxId(): Promise<SandboxError | string> {\n    if (initialVercel?.sandboxId) {\n      return initialVercel.sandboxId;\n    }\n\n    const existing = await storage.sandbox.get(id);\n    if (existing instanceof Error) {\n      if (existing instanceof SandboxNotFoundError) {\n        // Sandbox doesn't exist yet, continue with creation\n      } else {\n        return new SandboxError({ reason: existing.message, cause: existing });\n      }\n    }\n\n    const existingRecord =\n      existing instanceof SandboxNotFoundError ? null : existing;\n    const existingVercel =\n      existingRecord?.providerMetadata?.provider === \"vercel\"\n        ? existingRecord.providerMetadata\n        : null;\n\n    if (existingVercel?.sandboxId) {\n      return existingVercel.sandboxId;\n    }\n\n    const hasActiveLock =\n      existingRecord?.acquiringLockId &&\n      existingRecord.acquiringLockAt &&\n      Date.now() - existingRecord.acquiringLockAt < LOCK_TIMEOUT_MS;\n\n    if (hasActiveLock) {\n      return pollForSandboxId();\n    }\n\n    const lockId = crypto.randomUUID();\n    const now = Date.now();\n    await storage.sandbox.set({\n      id,\n      config,\n      tags: existingRecord?.tags ?? sandboxRecord.tags,\n      createdAt: existingRecord?.createdAt ?? sandboxRecord.createdAt,\n      lastActivityAt:\n        existingRecord?.lastActivityAt ?? sandboxRecord.lastActivityAt,\n      acquiringLockId: lockId,\n      acquiringLockAt: now,\n      providerMetadata: {\n        provider: \"vercel\",\n        sandboxId: null,\n        snapshotId:\n          existingVercel?.snapshotId ?? initialVercel?.snapshotId ?? null,\n      },\n    });\n\n    const afterLock = await storage.sandbox.get(id);\n    if (afterLock instanceof Error) {\n      return new SandboxError({ reason: afterLock.message, cause: afterLock });\n    }\n    if (afterLock?.acquiringLockId !== lockId) {\n      return pollForSandboxId();\n    }\n\n    const snapshotId =\n      existingVercel?.snapshotId ??\n      initialVercel?.snapshotId ??\n      config.lifecycle?.snapshotId;\n    if (snapshotId) {\n      const result = await createSandboxFromSnapshot(snapshotId);\n      if (!(result instanceof Error)) {\n        return result;\n      }\n    }\n\n    return createFreshSandbox();\n  }\n\n  function getOrCreateSandboxId(): Promise<SandboxError | string> {\n    const cached = createPromises.get(id);\n    if (cached) {\n      return cached;\n    }\n\n    const promise = doGetOrCreateSandboxId().finally(() => {\n      createPromises.delete(id);\n    });\n    createPromises.set(id, promise);\n    return promise;\n  }\n\n  async function doGetSandbox(): Promise<SandboxError | SandboxInstance> {\n    const vercelSandboxId = await getOrCreateSandboxId();\n    if (vercelSandboxId instanceof Error) {\n      return vercelSandboxId;\n    }\n\n    return errore.tryAsync({\n      try: () =>\n        VercelSandboxSDK.get({\n          sandboxId: vercelSandboxId,\n          ...getTestCredentials(),\n        }),\n      catch: (e) => new SandboxError({ reason: String(e), cause: e }),\n    });\n  }\n\n  function getSandbox(): Promise<SandboxError | SandboxInstance> {\n    if (!sandboxPromise) {\n      sandboxPromise = doGetSandbox();\n    }\n    return sandboxPromise;\n  }\n\n  async function updateLastActivity(): Promise<void> {\n    const now = Date.now();\n    const lastSent = lastActivitySent.get(id);\n    if (lastSent && now - lastSent < ACTIVITY_THROTTLE_MS) {\n      return;\n    }\n    lastActivitySent.set(id, now);\n\n    const existing = await storage.sandbox.get(id);\n    if (existing instanceof Error || !existing) {\n      return;\n    }\n    const existingVercel =\n      existing.providerMetadata?.provider === \"vercel\"\n        ? existing.providerMetadata\n        : null;\n    await storage.sandbox.set({\n      id: existing.id,\n      config: existing.config,\n      tags: existing.tags,\n      createdAt: existing.createdAt,\n      lastActivityAt: now,\n      acquiringLockId: null,\n      acquiringLockAt: null,\n      providerMetadata: existingVercel ?? {\n        provider: \"vercel\",\n        sandboxId: null,\n        snapshotId: null,\n      },\n    });\n\n    if (enableLifecycleWorkflow) {\n      // todo re-enable once we figure out why workflow throws a bunch of errors in dev\n      // const lifecycleInput: SandboxLifecycleInput = {\n      //   id,\n      //   storageConfig,\n      //   initialConfig: config,\n      // };\n      // try {\n      //   await sandboxActivityHook.resume(id, {\n      //     type: \"activity\",\n      //     newConfig: config,\n      //   });\n      // } catch {\n      //   await start(sandboxLifecycleWorkflow, [{ input: lifecycleInput }]);\n      // }\n    }\n  }\n\n  const lifecycle: SandboxLifecycle = {\n    start: async () => {\n      const sandbox = await getSandbox();\n      if (sandbox instanceof Error) {\n        return sandbox;\n      }\n      await updateLastActivity();\n      return sandbox.status as SandboxStatus;\n    },\n\n    snapshot: async () => {\n      const sandbox = await getSandbox();\n      if (sandbox instanceof Error) {\n        return sandbox;\n      }\n\n      return errore.tryAsync({\n        try: async () => {\n          const existing = await storage.sandbox.get(id);\n          const snapshot = await sandbox.snapshot();\n          await storage.sandbox.set({\n            id,\n            config,\n            tags: existing instanceof Error ? null : (existing?.tags ?? null),\n            createdAt:\n              existing instanceof Error ? null : (existing?.createdAt ?? null),\n            lastActivityAt:\n              existing instanceof Error\n                ? null\n                : (existing?.lastActivityAt ?? null),\n            acquiringLockId: null,\n            acquiringLockAt: null,\n            providerMetadata: {\n              provider: \"vercel\",\n              sandboxId: null,\n              snapshotId: snapshot.snapshotId,\n            },\n          });\n          return { snapshotId: snapshot.snapshotId };\n        },\n        catch: (e) => new SandboxError({ reason: String(e), cause: e }),\n      });\n    },\n\n    stop: async () => {\n      const sandbox = await getSandbox();\n      if (sandbox instanceof Error) {\n        return sandbox;\n      }\n\n      return errore.tryAsync({\n        try: async () => {\n          await sandbox.stop();\n          const existing = await storage.sandbox.get(id);\n          if (existing instanceof Error || !existing) {\n            return undefined;\n          }\n          await storage.sandbox.set({\n            id: existing.id,\n            config: existing.config,\n            tags: existing.tags,\n            createdAt: existing.createdAt,\n            lastActivityAt: existing.lastActivityAt,\n            acquiringLockId: null,\n            acquiringLockAt: null,\n            providerMetadata: {\n              provider: \"vercel\",\n              sandboxId: null,\n              snapshotId: null,\n            },\n          });\n          return undefined;\n        },\n        catch: (e) => new SandboxError({ reason: String(e), cause: e }),\n      });\n    },\n\n    getStatus: async () => {\n      const sandbox = await getSandbox();\n      if (sandbox instanceof Error) {\n        return sandbox;\n      }\n      return sandbox.status as SandboxStatus;\n    },\n\n    getCreatedAt: async () => {\n      const sandbox = await getSandbox();\n      if (sandbox instanceof Error) {\n        return sandbox;\n      }\n      return sandbox.createdAt;\n    },\n\n    getRemainingTimeout: async () => {\n      const sandbox = await getSandbox();\n      if (sandbox instanceof Error) {\n        return sandbox;\n      }\n      return sandbox.timeout;\n    },\n  };\n\n  const sandbox: Sandbox<TTags> = {\n    id,\n    config,\n    exec: async ({ command, args, signal }) => {\n      const instance = await getSandbox();\n      if (instance instanceof Error) {\n        return instance;\n      }\n\n      const updatePromise = updateLastActivity();\n\n      const execResult = await errore.tryAsync({\n        try: async () => {\n          const output = await instance.runCommand({\n            cwd: HOME_DIR,\n            args,\n            cmd: command,\n            signal,\n          });\n\n          let stdout = \"\";\n          let stderr = \"\";\n          const logBuffer: LogEntry[] = [];\n          const state = {\n            resolve: null as (() => void) | null,\n            consumed: false,\n          };\n\n          const consumeLogs = (async () => {\n            for await (const log of output.logs()) {\n              const entry: LogEntry =\n                log.stream === \"stdout\"\n                  ? { stream: \"stdout\", data: log.data }\n                  : { stream: \"stderr\", data: log.data };\n\n              if (log.stream === \"stdout\") {\n                stdout += log.data;\n              } else {\n                stderr += log.data;\n              }\n\n              logBuffer.push(entry);\n              state.resolve?.();\n            }\n            state.consumed = true;\n            state.resolve?.();\n          })();\n\n          async function* logs(): AsyncIterable<LogEntry> {\n            let index = 0;\n            while (!state.consumed || index < logBuffer.length) {\n              if (index < logBuffer.length) {\n                yield logBuffer[index++];\n              } else {\n                await new Promise<void>((resolve) => {\n                  state.resolve = resolve;\n                });\n                state.resolve = null;\n              }\n            }\n          }\n\n          const result = consumeLogs.then(() => ({\n            stdout,\n            stderr,\n            exitCode: output.exitCode,\n          }));\n\n          return { commandId: output.cmdId, logs, result };\n        },\n        catch: (e) => new SandboxError({ reason: String(e), cause: e }),\n      });\n\n      await updatePromise;\n      return execResult;\n    },\n\n    getDomain: async (port) => {\n      const sandbox = await getSandbox();\n      if (sandbox instanceof Error) {\n        return sandbox;\n      }\n\n      try {\n        return sandbox.domain(port);\n      } catch (e) {\n        return new SandboxError({ reason: String(e), cause: e });\n      }\n    },\n\n    kill: async ({ commandId, storage: cmdStorage }) => {\n      const instance = await getSandbox();\n      if (instance instanceof Error) {\n        return instance;\n      }\n\n      const cmd = await cmdStorage.command.get(commandId);\n      if (cmd instanceof Error) {\n        return new SandboxError({ reason: cmd.message, cause: cmd });\n      }\n      if (cmd && cmd.status === \"running\") {\n        const result = await cmdStorage.command.set({\n          ...cmd,\n          status: \"killed\",\n        });\n        if (result instanceof Error) {\n          return new SandboxError({ reason: result.message, cause: result });\n        }\n      }\n      return undefined;\n    },\n\n    writeFiles: (opts) => writeFiles({ sandbox, ...opts }),\n\n    lifecycle,\n\n    tag: {\n      list: async () => {\n        const sandboxRecord = await storage.sandbox.get(id);\n        if (sandboxRecord instanceof Error) {\n          return sandboxRecord;\n        }\n        return (sandboxRecord.tags ?? {}) as TTags;\n      },\n      get: async (key: string) => {\n        const sandboxRecord = await storage.sandbox.get(id);\n        if (sandboxRecord instanceof Error) {\n          return sandboxRecord;\n        }\n        return sandboxRecord.tags?.[key as string] as\n          | TTags[typeof key]\n          | undefined;\n      },\n      set: async (key: string, value: unknown) => {\n        const result = await storage.sandbox.tag.set({\n          sandboxId: id,\n          tags: { [key]: value } as Record<string, unknown>,\n        });\n        if (result instanceof Error) {\n          return result;\n        }\n        return undefined;\n      },\n      setMany: async (tags: Record<string, unknown>) => {\n        const result = await storage.sandbox.tag.set({\n          sandboxId: id,\n          tags: tags as Record<string, unknown>,\n        });\n        if (result instanceof Error) {\n          return result;\n        }\n        return undefined;\n      },\n    },\n  };\n\n  if (config.lifecycle?.autoStart !== false) {\n    sandboxPromise = doGetSandbox();\n  }\n\n  return sandbox;\n};\n", "import type { TagsSchema } from \"../index\";\nimport type { SandboxRecord, StorageConfig } from \"../storage\";\nimport { localSandbox } from \"./bindings/local\";\nimport { vercelSandbox } from \"./bindings/vercel\";\nimport type { Sandbox } from \"./types\";\n\nexport function getSandbox<TTags extends TagsSchema = TagsSchema>({\n  sandboxRecord,\n  storageConfig,\n}: {\n  storageConfig: StorageConfig;\n  sandboxRecord: SandboxRecord;\n}): Sandbox<TTags> {\n  const { config } = sandboxRecord;\n  switch (config.type) {\n    case \"local\":\n      return localSandbox<TTags>({\n        sandboxRecord: sandboxRecord as SandboxRecord & {\n          config: { type: \"local\" };\n        },\n        storageConfig,\n      });\n    case \"vercel\":\n      return vercelSandbox<TTags>({\n        sandboxRecord: sandboxRecord as SandboxRecord & {\n          config: { type: \"vercel\" };\n        },\n        storageConfig,\n      });\n    case \"custom\":\n      throw new Error(\"Custom sandboxes are not supported\");\n    default:\n      config satisfies never;\n      throw new Error(\n        `Unknown sandbox type: ${\n          // biome-ignore lint/suspicious/noExplicitAny: .\n          (config as any).type\n        }`\n      );\n  }\n}\n"],
  "mappings": "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",
  "names": ["exitCode", "stderr", "storage", "sandboxRecord", "errore", "sandbox", "getSandbox", "sandboxRecord"]
}

|