experimental-agent 0.2.3 → 0.4.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (69) hide show
  1. package/README.md +103 -241
  2. package/dist/adapter-zgOel4wW.d.mts +256 -0
  3. package/dist/adapter-zgOel4wW.d.ts +256 -0
  4. package/dist/chunk-BFFNCESS.mjs +302 -0
  5. package/dist/chunk-C4VSUEY2.mjs +72 -0
  6. package/dist/chunk-GKASMIBR.mjs +50 -0
  7. package/dist/chunk-IV75IMEW.mjs +328 -0
  8. package/dist/chunk-JO3JDCH5.mjs +107 -0
  9. package/dist/chunk-MSTM6W3Y.mjs +99 -0
  10. package/dist/chunk-MSWINCCM.mjs +128 -0
  11. package/dist/chunk-RT72C52I.mjs +324 -0
  12. package/dist/chunk-ZUFJJYC4.mjs +150 -0
  13. package/dist/{handler-FRUPZ4LX.mjs → docker-QPCLWLYR.mjs} +3 -4
  14. package/dist/entry-6HYg5qqg.d.mts +36 -0
  15. package/dist/entry-BrWOmEK2.d.ts +36 -0
  16. package/dist/index.d.mts +401 -18
  17. package/dist/index.d.ts +401 -18
  18. package/dist/index.js +3396 -5500
  19. package/dist/index.mjs +3511 -1166
  20. package/dist/lifecycle-workflow-steps.d.mts +5 -0
  21. package/dist/lifecycle-workflow-steps.d.ts +5 -0
  22. package/dist/lifecycle-workflow-steps.js +263 -0
  23. package/dist/lifecycle-workflow-steps.mjs +9 -0
  24. package/dist/lifecycle-workflow.d.mts +6 -6
  25. package/dist/lifecycle-workflow.d.ts +6 -6
  26. package/dist/lifecycle-workflow.js +192 -905
  27. package/dist/lifecycle-workflow.mjs +3 -1
  28. package/dist/local-KJ3BSIFJ.mjs +8 -0
  29. package/dist/next/loader.js +31 -7
  30. package/dist/next/loader.mjs +1 -1
  31. package/dist/next.js +35 -8
  32. package/dist/next.mjs +6 -3
  33. package/dist/{process-manager-JDUJDYGU.mjs → process-manager-WQHAIVRB.mjs} +1 -1
  34. package/dist/sandbox.d.mts +6 -0
  35. package/dist/sandbox.d.ts +6 -0
  36. package/dist/sandbox.js +1070 -0
  37. package/dist/sandbox.mjs +19 -0
  38. package/dist/steps-BIsP57pm.d.mts +173 -0
  39. package/dist/steps-DShnXBLf.d.ts +173 -0
  40. package/dist/storage.d.mts +17 -0
  41. package/dist/storage.d.ts +17 -0
  42. package/dist/storage.js +368 -0
  43. package/dist/storage.mjs +16 -0
  44. package/dist/vercel-QZ6INPMV.mjs +11 -0
  45. package/package.json +29 -5
  46. package/dist/agent-workflow.d.mts +0 -30
  47. package/dist/agent-workflow.d.ts +0 -30
  48. package/dist/agent-workflow.js +0 -5433
  49. package/dist/agent-workflow.mjs +0 -14
  50. package/dist/chunk-7M6UPURS.mjs +0 -75
  51. package/dist/chunk-AML2VCQS.mjs +0 -1287
  52. package/dist/chunk-FQ67QZOI.mjs +0 -75
  53. package/dist/chunk-NO7RHGTH.mjs +0 -2367
  54. package/dist/chunk-NXDVNJRS.mjs +0 -106
  55. package/dist/chunk-OZZVS6L5.mjs +0 -139
  56. package/dist/chunk-SJVFFE5D.mjs +0 -402
  57. package/dist/chunk-TAXLUVIC.mjs +0 -1
  58. package/dist/chunk-TGNVXSMX.mjs +0 -399
  59. package/dist/chunk-YRYXN7W4.mjs +0 -48
  60. package/dist/chunk-ZIAHPXOJ.mjs +0 -595
  61. package/dist/client-BKA7XBGW.mjs +0 -15
  62. package/dist/client-CEeSFGva.d.mts +0 -2376
  63. package/dist/client-CEeSFGva.d.ts +0 -2376
  64. package/dist/docker-FB2MJTHJ.mjs +0 -12
  65. package/dist/local-fs-handlers-SYOCKTPN.mjs +0 -447
  66. package/dist/sandbox-UENKQV3T.mjs +0 -21
  67. package/dist/storage-LSDMRW73.mjs +0 -20
  68. package/dist/vercel-SD3JTECG.mjs +0 -20
  69. package/dist/vercel-sdk-I6A4MVAN.mjs +0 -8
@@ -0,0 +1,99 @@
1
+ // package.json
2
+ var package_default = {
3
+ name: "experimental-agent",
4
+ version: "0.4.0",
5
+ main: "./dist/index.js",
6
+ module: "./dist/index.mjs",
7
+ types: "./dist/index.d.ts",
8
+ sideEffects: true,
9
+ license: "MIT",
10
+ files: [
11
+ "dist/**"
12
+ ],
13
+ exports: {
14
+ ".": {
15
+ types: "./dist/index.d.ts",
16
+ import: "./dist/index.mjs",
17
+ require: "./dist/index.js"
18
+ },
19
+ "./storage": {
20
+ types: "./dist/storage.d.ts",
21
+ import: "./dist/storage.mjs",
22
+ require: "./dist/storage.js"
23
+ },
24
+ "./sandbox": {
25
+ types: "./dist/sandbox.d.ts",
26
+ import: "./dist/sandbox.mjs",
27
+ require: "./dist/sandbox.js"
28
+ },
29
+ "./next": {
30
+ types: "./dist/next.d.ts",
31
+ import: "./dist/next.mjs",
32
+ require: "./dist/next.js"
33
+ },
34
+ "./next/loader": {
35
+ types: "./dist/next/loader.d.ts",
36
+ import: "./dist/next/loader.mjs",
37
+ require: "./dist/next/loader.js"
38
+ },
39
+ "./client": {
40
+ types: "./dist/client.d.ts",
41
+ import: "./dist/client.mjs",
42
+ require: "./dist/client.js"
43
+ },
44
+ "./lifecycle-workflow": {
45
+ types: "./dist/lifecycle-workflow.d.ts",
46
+ import: "./dist/lifecycle-workflow.mjs",
47
+ require: "./dist/lifecycle-workflow.js"
48
+ },
49
+ "./lifecycle-workflow-steps": {
50
+ types: "./dist/lifecycle-workflow-steps.d.ts",
51
+ import: "./dist/lifecycle-workflow-steps.mjs",
52
+ require: "./dist/lifecycle-workflow-steps.js"
53
+ }
54
+ },
55
+ scripts: {
56
+ build: "tsup",
57
+ dev: "tsup --watch",
58
+ clean: "rm -rf .turbo && rm -rf node_modules && rm -rf dist",
59
+ release: "pnpm build && npm publish",
60
+ typecheck: "tsc --noEmit",
61
+ test: "vitest run",
62
+ "test:watch": "vitest"
63
+ },
64
+ dependencies: {
65
+ "@swc/core": "^1.10.0",
66
+ "@vercel/kv2": "^0.0.18",
67
+ "@vercel/oidc": "^3.1.0",
68
+ "@vercel/sandbox": "1.7.1",
69
+ "@workflow/serde": "4.1.0-beta.2",
70
+ "better-all": "^0.0.5",
71
+ errore: "^0.14.0",
72
+ "fast-deep-equal": "^3.1.3",
73
+ ulid: "^3.0.2",
74
+ zod: "^4.3.6"
75
+ },
76
+ devDependencies: {
77
+ "@agent/tsconfig": "workspace:*",
78
+ "@ai-sdk/react": "^3.0.88",
79
+ "@types/node": "^20.11.24",
80
+ dotenv: "^17.2.3",
81
+ next: "^16.0.0",
82
+ react: "^19.2.4",
83
+ tsup: "^8.0.2",
84
+ typescript: "5.5.4",
85
+ vitest: "^3.0.0",
86
+ workflow: "4.1.0-beta.60"
87
+ },
88
+ peerDependencies: {
89
+ ai: "^6.0.0"
90
+ },
91
+ publishConfig: {
92
+ access: "public"
93
+ }
94
+ };
95
+
96
+ export {
97
+ package_default
98
+ };
99
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vcGFja2FnZS5qc29uIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJ7XG4gIFwibmFtZVwiOiBcImV4cGVyaW1lbnRhbC1hZ2VudFwiLFxuICBcInZlcnNpb25cIjogXCIwLjQuMFwiLFxuICBcIm1haW5cIjogXCIuL2Rpc3QvaW5kZXguanNcIixcbiAgXCJtb2R1bGVcIjogXCIuL2Rpc3QvaW5kZXgubWpzXCIsXG4gIFwidHlwZXNcIjogXCIuL2Rpc3QvaW5kZXguZC50c1wiLFxuICBcInNpZGVFZmZlY3RzXCI6IHRydWUsXG4gIFwibGljZW5zZVwiOiBcIk1JVFwiLFxuICBcImZpbGVzXCI6IFtcbiAgICBcImRpc3QvKipcIlxuICBdLFxuICBcImV4cG9ydHNcIjoge1xuICAgIFwiLlwiOiB7XG4gICAgICBcInR5cGVzXCI6IFwiLi9kaXN0L2luZGV4LmQudHNcIixcbiAgICAgIFwiaW1wb3J0XCI6IFwiLi9kaXN0L2luZGV4Lm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L2luZGV4LmpzXCJcbiAgICB9LFxuICAgIFwiLi9zdG9yYWdlXCI6IHtcbiAgICAgIFwidHlwZXNcIjogXCIuL2Rpc3Qvc3RvcmFnZS5kLnRzXCIsXG4gICAgICBcImltcG9ydFwiOiBcIi4vZGlzdC9zdG9yYWdlLm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L3N0b3JhZ2UuanNcIlxuICAgIH0sXG4gICAgXCIuL3NhbmRib3hcIjoge1xuICAgICAgXCJ0eXBlc1wiOiBcIi4vZGlzdC9zYW5kYm94LmQudHNcIixcbiAgICAgIFwiaW1wb3J0XCI6IFwiLi9kaXN0L3NhbmRib3gubWpzXCIsXG4gICAgICBcInJlcXVpcmVcIjogXCIuL2Rpc3Qvc2FuZGJveC5qc1wiXG4gICAgfSxcbiAgICBcIi4vbmV4dFwiOiB7XG4gICAgICBcInR5cGVzXCI6IFwiLi9kaXN0L25leHQuZC50c1wiLFxuICAgICAgXCJpbXBvcnRcIjogXCIuL2Rpc3QvbmV4dC5tanNcIixcbiAgICAgIFwicmVxdWlyZVwiOiBcIi4vZGlzdC9uZXh0LmpzXCJcbiAgICB9LFxuICAgIFwiLi9uZXh0L2xvYWRlclwiOiB7XG4gICAgICBcInR5cGVzXCI6IFwiLi9kaXN0L25leHQvbG9hZGVyLmQudHNcIixcbiAgICAgIFwiaW1wb3J0XCI6IFwiLi9kaXN0L25leHQvbG9hZGVyLm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L25leHQvbG9hZGVyLmpzXCJcbiAgICB9LFxuICAgIFwiLi9jbGllbnRcIjoge1xuICAgICAgXCJ0eXBlc1wiOiBcIi4vZGlzdC9jbGllbnQuZC50c1wiLFxuICAgICAgXCJpbXBvcnRcIjogXCIuL2Rpc3QvY2xpZW50Lm1qc1wiLFxuICAgICAgXCJyZXF1aXJlXCI6IFwiLi9kaXN0L2NsaWVudC5qc1wiXG4gICAgfSxcbiAgICBcIi4vbGlmZWN5Y2xlLXdvcmtmbG93XCI6IHtcbiAgICAgIFwidHlwZXNcIjogXCIuL2Rpc3QvbGlmZWN5Y2xlLXdvcmtmbG93LmQudHNcIixcbiAgICAgIFwiaW1wb3J0XCI6IFwiLi9kaXN0L2xpZmVjeWNsZS13b3JrZmxvdy5tanNcIixcbiAgICAgIFwicmVxdWlyZVwiOiBcIi4vZGlzdC9saWZlY3ljbGUtd29ya2Zsb3cuanNcIlxuICAgIH0sXG4gICAgXCIuL2xpZmVjeWNsZS13b3JrZmxvdy1zdGVwc1wiOiB7XG4gICAgICBcInR5cGVzXCI6IFwiLi9kaXN0L2xpZmVjeWNsZS13b3JrZmxvdy1zdGVwcy5kLnRzXCIsXG4gICAgICBcImltcG9ydFwiOiBcIi4vZGlzdC9saWZlY3ljbGUtd29ya2Zsb3ctc3RlcHMubWpzXCIsXG4gICAgICBcInJlcXVpcmVcIjogXCIuL2Rpc3QvbGlmZWN5Y2xlLXdvcmtmbG93LXN0ZXBzLmpzXCJcbiAgICB9XG4gIH0sXG4gIFwic2NyaXB0c1wiOiB7XG4gICAgXCJidWlsZFwiOiBcInRzdXBcIixcbiAgICBcImRldlwiOiBcInRzdXAgLS13YXRjaFwiLFxuICAgIFwiY2xlYW5cIjogXCJybSAtcmYgLnR1cmJvICYmIHJtIC1yZiBub2RlX21vZHVsZXMgJiYgcm0gLXJmIGRpc3RcIixcbiAgICBcInJlbGVhc2VcIjogXCJwbnBtIGJ1aWxkICYmIG5wbSBwdWJsaXNoXCIsXG4gICAgXCJ0eXBlY2hlY2tcIjogXCJ0c2MgLS1ub0VtaXRcIixcbiAgICBcInRlc3RcIjogXCJ2aXRlc3QgcnVuXCIsXG4gICAgXCJ0ZXN0OndhdGNoXCI6IFwidml0ZXN0XCJcbiAgfSxcbiAgXCJkZXBlbmRlbmNpZXNcIjoge1xuICAgIFwiQHN3Yy9jb3JlXCI6IFwiXjEuMTAuMFwiLFxuICAgIFwiQHZlcmNlbC9rdjJcIjogXCJeMC4wLjE4XCIsXG4gICAgXCJAdmVyY2VsL29pZGNcIjogXCJeMy4xLjBcIixcbiAgICBcIkB2ZXJjZWwvc2FuZGJveFwiOiBcIjEuNy4xXCIsXG4gICAgXCJAd29ya2Zsb3cvc2VyZGVcIjogXCI0LjEuMC1iZXRhLjJcIixcbiAgICBcImJldHRlci1hbGxcIjogXCJeMC4wLjVcIixcbiAgICBcImVycm9yZVwiOiBcIl4wLjE0LjBcIixcbiAgICBcImZhc3QtZGVlcC1lcXVhbFwiOiBcIl4zLjEuM1wiLFxuICAgIFwidWxpZFwiOiBcIl4zLjAuMlwiLFxuICAgIFwiem9kXCI6IFwiXjQuMy42XCJcbiAgfSxcbiAgXCJkZXZEZXBlbmRlbmNpZXNcIjoge1xuICAgIFwiQGFnZW50L3RzY29uZmlnXCI6IFwid29ya3NwYWNlOipcIixcbiAgICBcIkBhaS1zZGsvcmVhY3RcIjogXCJeMy4wLjg4XCIsXG4gICAgXCJAdHlwZXMvbm9kZVwiOiBcIl4yMC4xMS4yNFwiLFxuICAgIFwiZG90ZW52XCI6IFwiXjE3LjIuM1wiLFxuICAgIFwibmV4dFwiOiBcIl4xNi4wLjBcIixcbiAgICBcInJlYWN0XCI6IFwiXjE5LjIuNFwiLFxuICAgIFwidHN1cFwiOiBcIl44LjAuMlwiLFxuICAgIFwidHlwZXNjcmlwdFwiOiBcIjUuNS40XCIsXG4gICAgXCJ2aXRlc3RcIjogXCJeMy4wLjBcIixcbiAgICBcIndvcmtmbG93XCI6IFwiNC4xLjAtYmV0YS42MFwiXG4gIH0sXG4gIFwicGVlckRlcGVuZGVuY2llc1wiOiB7XG4gICAgXCJhaVwiOiBcIl42LjAuMFwiXG4gIH0sXG4gIFwicHVibGlzaENvbmZpZ1wiOiB7XG4gICAgXCJhY2Nlc3NcIjogXCJwdWJsaWNcIlxuICB9XG59XG4iXSwKICAibWFwcGluZ3MiOiAiO0FBQUE7QUFBQSxFQUNFLE1BQVE7QUFBQSxFQUNSLFNBQVc7QUFBQSxFQUNYLE1BQVE7QUFBQSxFQUNSLFFBQVU7QUFBQSxFQUNWLE9BQVM7QUFBQSxFQUNULGFBQWU7QUFBQSxFQUNmLFNBQVc7QUFBQSxFQUNYLE9BQVM7QUFBQSxJQUNQO0FBQUEsRUFDRjtBQUFBLEVBQ0EsU0FBVztBQUFBLElBQ1QsS0FBSztBQUFBLE1BQ0gsT0FBUztBQUFBLE1BQ1QsUUFBVTtBQUFBLE1BQ1YsU0FBVztBQUFBLElBQ2I7QUFBQSxJQUNBLGFBQWE7QUFBQSxNQUNYLE9BQVM7QUFBQSxNQUNULFFBQVU7QUFBQSxNQUNWLFNBQVc7QUFBQSxJQUNiO0FBQUEsSUFDQSxhQUFhO0FBQUEsTUFDWCxPQUFTO0FBQUEsTUFDVCxRQUFVO0FBQUEsTUFDVixTQUFXO0FBQUEsSUFDYjtBQUFBLElBQ0EsVUFBVTtBQUFBLE1BQ1IsT0FBUztBQUFBLE1BQ1QsUUFBVTtBQUFBLE1BQ1YsU0FBVztBQUFBLElBQ2I7QUFBQSxJQUNBLGlCQUFpQjtBQUFBLE1BQ2YsT0FBUztBQUFBLE1BQ1QsUUFBVTtBQUFBLE1BQ1YsU0FBVztBQUFBLElBQ2I7QUFBQSxJQUNBLFlBQVk7QUFBQSxNQUNWLE9BQVM7QUFBQSxNQUNULFFBQVU7QUFBQSxNQUNWLFNBQVc7QUFBQSxJQUNiO0FBQUEsSUFDQSx3QkFBd0I7QUFBQSxNQUN0QixPQUFTO0FBQUEsTUFDVCxRQUFVO0FBQUEsTUFDVixTQUFXO0FBQUEsSUFDYjtBQUFBLElBQ0EsOEJBQThCO0FBQUEsTUFDNUIsT0FBUztBQUFBLE1BQ1QsUUFBVTtBQUFBLE1BQ1YsU0FBVztBQUFBLElBQ2I7QUFBQSxFQUNGO0FBQUEsRUFDQSxTQUFXO0FBQUEsSUFDVCxPQUFTO0FBQUEsSUFDVCxLQUFPO0FBQUEsSUFDUCxPQUFTO0FBQUEsSUFDVCxTQUFXO0FBQUEsSUFDWCxXQUFhO0FBQUEsSUFDYixNQUFRO0FBQUEsSUFDUixjQUFjO0FBQUEsRUFDaEI7QUFBQSxFQUNBLGNBQWdCO0FBQUEsSUFDZCxhQUFhO0FBQUEsSUFDYixlQUFlO0FBQUEsSUFDZixnQkFBZ0I7QUFBQSxJQUNoQixtQkFBbUI7QUFBQSxJQUNuQixtQkFBbUI7QUFBQSxJQUNuQixjQUFjO0FBQUEsSUFDZCxRQUFVO0FBQUEsSUFDVixtQkFBbUI7QUFBQSxJQUNuQixNQUFRO0FBQUEsSUFDUixLQUFPO0FBQUEsRUFDVDtBQUFBLEVBQ0EsaUJBQW1CO0FBQUEsSUFDakIsbUJBQW1CO0FBQUEsSUFDbkIsaUJBQWlCO0FBQUEsSUFDakIsZUFBZTtBQUFBLElBQ2YsUUFBVTtBQUFBLElBQ1YsTUFBUTtBQUFBLElBQ1IsT0FBUztBQUFBLElBQ1QsTUFBUTtBQUFBLElBQ1IsWUFBYztBQUFBLElBQ2QsUUFBVTtBQUFBLElBQ1YsVUFBWTtBQUFBLEVBQ2Q7QUFBQSxFQUNBLGtCQUFvQjtBQUFBLElBQ2xCLElBQU07QUFBQSxFQUNSO0FBQUEsRUFDQSxlQUFpQjtBQUFBLElBQ2YsUUFBVTtBQUFBLEVBQ1o7QUFDRjsiLAogICJuYW1lcyI6IFtdCn0K
@@ -0,0 +1,128 @@
1
+ // src/utils/logger.ts
2
+ var LOG_LEVEL_PRIORITY = {
3
+ info: 0,
4
+ warn: 1,
5
+ error: 2,
6
+ silent: 3
7
+ };
8
+ function getLevel(config) {
9
+ return config.level ?? "warn";
10
+ }
11
+ function getPrefix(config) {
12
+ return config.prefix ?? "agent";
13
+ }
14
+ function shouldLog(config, level) {
15
+ return LOG_LEVEL_PRIORITY[level] >= LOG_LEVEL_PRIORITY[getLevel(config)];
16
+ }
17
+ function formatTag(config, subsystem) {
18
+ return `[${getPrefix(config)}:${config.name}:${subsystem}]`;
19
+ }
20
+ function formatData(context, extra) {
21
+ const merged = { ...context, ...extra };
22
+ const entries = Object.entries(merged).filter(
23
+ ([, v]) => v !== void 0 && v !== null
24
+ );
25
+ if (entries.length === 0) {
26
+ return void 0;
27
+ }
28
+ return Object.fromEntries(entries);
29
+ }
30
+ var Logger = class _Logger {
31
+ subsystem;
32
+ config;
33
+ context;
34
+ constructor({
35
+ subsystem,
36
+ config,
37
+ context
38
+ }) {
39
+ this.subsystem = subsystem;
40
+ this.config = config;
41
+ this.context = context ?? {};
42
+ }
43
+ child({
44
+ subsystem,
45
+ context
46
+ }) {
47
+ return new _Logger({
48
+ config: this.config,
49
+ subsystem: subsystem ? `${this.subsystem}:${subsystem}` : this.subsystem,
50
+ context: { ...this.context, ...context }
51
+ });
52
+ }
53
+ withContext(context) {
54
+ return new _Logger({
55
+ config: this.config,
56
+ subsystem: this.subsystem,
57
+ context: { ...this.context, ...context }
58
+ });
59
+ }
60
+ info(message, data) {
61
+ if (!shouldLog(this.config, "info")) {
62
+ return;
63
+ }
64
+ const d = formatData(this.context, data);
65
+ if (d) {
66
+ console.info(formatTag(this.config, this.subsystem), message, d);
67
+ } else {
68
+ console.info(formatTag(this.config, this.subsystem), message);
69
+ }
70
+ }
71
+ warn(message, data) {
72
+ if (!shouldLog(this.config, "warn")) {
73
+ return;
74
+ }
75
+ const d = formatData(this.context, data);
76
+ if (d) {
77
+ console.warn(formatTag(this.config, this.subsystem), message, d);
78
+ } else {
79
+ console.warn(formatTag(this.config, this.subsystem), message);
80
+ }
81
+ }
82
+ error(message, data) {
83
+ if (!shouldLog(this.config, "error")) {
84
+ return;
85
+ }
86
+ const d = formatData(this.context, data);
87
+ if (d) {
88
+ console.error(formatTag(this.config, this.subsystem), message, d);
89
+ } else {
90
+ console.error(formatTag(this.config, this.subsystem), message);
91
+ }
92
+ }
93
+ /**
94
+ * Returns a function that, when called, logs the elapsed time at info level.
95
+ * Pass `logOnStart: true` to also log when the timer begins.
96
+ *
97
+ * @example
98
+ * const done = log.time("sandbox setup", { sandboxId }, { logOnStart: true });
99
+ * await setup();
100
+ * done(); // start: [agent:default:sandbox] sandbox setup { sandboxId: '...' }
101
+ * // end: [agent:default:sandbox] sandbox setup { sandboxId: '...', durationMs: 123 }
102
+ */
103
+ time(message, data, opts) {
104
+ if (opts?.logOnStart) {
105
+ this.info(`[start] ${message}`, data);
106
+ }
107
+ const t0 = Date.now();
108
+ return (endData) => {
109
+ this.info(opts?.logOnStart ? `[end] ${message}` : message, {
110
+ ...data,
111
+ ...endData,
112
+ durationMs: Date.now() - t0
113
+ });
114
+ };
115
+ }
116
+ };
117
+ function createLogger({
118
+ config,
119
+ subsystem,
120
+ context
121
+ }) {
122
+ return new Logger({ config, subsystem, context });
123
+ }
124
+
125
+ export {
126
+ createLogger
127
+ };
128
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/utils/logger.ts"],
  "sourcesContent": ["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"],
  "mappings": ";AAEA,IAAM,qBAA+C;AAAA,EACnD,MAAM;AAAA,EACN,MAAM;AAAA,EACN,OAAO;AAAA,EACP,QAAQ;AACV;AAoBA,SAAS,SAAS,QAAiC;AACjD,SAAO,OAAO,SAAS;AACzB;AAEA,SAAS,UAAU,QAA+B;AAChD,SAAO,OAAO,UAAU;AAC1B;AAEA,SAAS,UAAU,QAAuB,OAA0B;AAClE,SAAO,mBAAmB,KAAK,KAAK,mBAAmB,SAAS,MAAM,CAAC;AACzE;AAEA,SAAS,UAAU,QAAuB,WAA2B;AACnE,SAAO,IAAI,UAAU,MAAM,CAAC,IAAI,OAAO,IAAI,IAAI,SAAS;AAC1D;AAEA,SAAS,WACP,SACA,OACqC;AACrC,QAAM,SAAS,EAAE,GAAG,SAAS,GAAG,MAAM;AACtC,QAAM,UAAU,OAAO,QAAQ,MAAM,EAAE;AAAA,IACrC,CAAC,CAAC,EAAE,CAAC,MAAM,MAAM,UAAa,MAAM;AAAA,EACtC;AACA,MAAI,QAAQ,WAAW,GAAG;AACxB,WAAO;AAAA,EACT;AACA,SAAO,OAAO,YAAY,OAAO;AACnC;AAEO,IAAM,SAAN,MAAM,QAAO;AAAA,EACT;AAAA,EACQ;AAAA,EACA;AAAA,EAEjB,YAAY;AAAA,IACV;AAAA,IACA;AAAA,IACA;AAAA,EACF,GAIG;AACD,SAAK,YAAY;AACjB,SAAK,SAAS;AACd,SAAK,UAAU,WAAW,CAAC;AAAA,EAC7B;AAAA,EAEA,MAAM;AAAA,IACJ;AAAA,IACA;AAAA,EACF,GAGW;AACT,WAAO,IAAI,QAAO;AAAA,MAChB,QAAQ,KAAK;AAAA,MACb,WAAW,YAAY,GAAG,KAAK,SAAS,IAAI,SAAS,KAAK,KAAK;AAAA,MAC/D,SAAS,EAAE,GAAG,KAAK,SAAS,GAAG,QAAQ;AAAA,IACzC,CAAC;AAAA,EACH;AAAA,EAEA,YAAY,SAA6B;AACvC,WAAO,IAAI,QAAO;AAAA,MAChB,QAAQ,KAAK;AAAA,MACb,WAAW,KAAK;AAAA,MAChB,SAAS,EAAE,GAAG,KAAK,SAAS,GAAG,QAAQ;AAAA,IACzC,CAAC;AAAA,EACH;AAAA,EAEA,KAAK,SAAiB,MAAsC;AAC1D,QAAI,CAAC,UAAU,KAAK,QAAQ,MAAM,GAAG;AACnC;AAAA,IACF;AACA,UAAM,IAAI,WAAW,KAAK,SAAS,IAAI;AACvC,QAAI,GAAG;AACL,cAAQ,KAAK,UAAU,KAAK,QAAQ,KAAK,SAAS,GAAG,SAAS,CAAC;AAAA,IACjE,OAAO;AACL,cAAQ,KAAK,UAAU,KAAK,QAAQ,KAAK,SAAS,GAAG,OAAO;AAAA,IAC9D;AAAA,EACF;AAAA,EAEA,KAAK,SAAiB,MAAsC;AAC1D,QAAI,CAAC,UAAU,KAAK,QAAQ,MAAM,GAAG;AACnC;AAAA,IACF;AACA,UAAM,IAAI,WAAW,KAAK,SAAS,IAAI;AACvC,QAAI,GAAG;AACL,cAAQ,KAAK,UAAU,KAAK,QAAQ,KAAK,SAAS,GAAG,SAAS,CAAC;AAAA,IACjE,OAAO;AACL,cAAQ,KAAK,UAAU,KAAK,QAAQ,KAAK,SAAS,GAAG,OAAO;AAAA,IAC9D;AAAA,EACF;AAAA,EAEA,MAAM,SAAiB,MAAsC;AAC3D,QAAI,CAAC,UAAU,KAAK,QAAQ,OAAO,GAAG;AACpC;AAAA,IACF;AACA,UAAM,IAAI,WAAW,KAAK,SAAS,IAAI;AACvC,QAAI,GAAG;AACL,cAAQ,MAAM,UAAU,KAAK,QAAQ,KAAK,SAAS,GAAG,SAAS,CAAC;AAAA,IAClE,OAAO;AACL,cAAQ,MAAM,UAAU,KAAK,QAAQ,KAAK,SAAS,GAAG,OAAO;AAAA,IAC/D;AAAA,EACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAYA,KACE,SACA,MACA,MAC6C;AAC7C,QAAI,MAAM,YAAY;AACpB,WAAK,KAAK,WAAW,OAAO,IAAI,IAAI;AAAA,IACtC;AACA,UAAM,KAAK,KAAK,IAAI;AACpB,WAAO,CAAC,YAAsC;AAC5C,WAAK,KAAK,MAAM,aAAa,SAAS,OAAO,KAAK,SAAS;AAAA,QACzD,GAAG;AAAA,QACH,GAAG;AAAA,QACH,YAAY,KAAK,IAAI,IAAI;AAAA,MAC3B,CAAC;AAAA,IACH;AAAA,EACF;AACF;AAEO,SAAS,aAAa;AAAA,EAC3B;AAAA,EACA;AAAA,EACA;AACF,GAIW;AACT,SAAO,IAAI,OAAO,EAAE,QAAQ,WAAW,QAAQ,CAAC;AAClD;",
  "names": []
}

@@ -0,0 +1,324 @@
1
+ import {
2
+ sandboxLifecycleWorkflow
3
+ } from "./chunk-GKASMIBR.mjs";
4
+
5
+ // src/sandbox/bindings/vercel.ts
6
+ import { start as startWorkflow } from "workflow/api";
7
+ async function loadSandboxSDK() {
8
+ return (await import("@vercel/sandbox")).Sandbox;
9
+ }
10
+ var MAX_TIMEOUT_MS = 5 * 60 * 60 * 1e3;
11
+ var HOME_DIR = "/home/vercel-sandbox";
12
+ var DEFAULT_VCPUS = 2;
13
+ function isSandboxGoneError(e) {
14
+ if (!(e instanceof Error)) {
15
+ return false;
16
+ }
17
+ const status = e.response?.status ?? e.cause?.response?.status;
18
+ if (status === 410 || status === 422) {
19
+ return true;
20
+ }
21
+ const msg = e.message || String(e);
22
+ return msg.includes("Expected a stream of command data") || msg.includes("Expected a stream of logs");
23
+ }
24
+ var getTestCredentials = () => process.env.NODE_ENV === "test" ? {
25
+ token: process.env.TEST_VERCEL_TOKEN,
26
+ teamId: process.env.TEST_VERCEL_TEAM_ID,
27
+ projectId: process.env.TEST_VERCEL_PROJECT_ID
28
+ } : {};
29
+ async function createSdk({
30
+ resources,
31
+ ports,
32
+ networkPolicy,
33
+ snapshotId
34
+ }) {
35
+ const SandboxSDK = await loadSandboxSDK();
36
+ const base = {
37
+ resources,
38
+ timeout: MAX_TIMEOUT_MS,
39
+ ...ports ? { ports } : {},
40
+ ...networkPolicy ? { networkPolicy } : {},
41
+ ...getTestCredentials()
42
+ };
43
+ if (snapshotId) {
44
+ return SandboxSDK.create({
45
+ ...base,
46
+ source: { type: "snapshot", snapshotId }
47
+ });
48
+ }
49
+ return SandboxSDK.create(base);
50
+ }
51
+ async function createSetupSnapshot({
52
+ sandboxOpts,
53
+ run,
54
+ storage,
55
+ snapshotVersion,
56
+ log
57
+ }) {
58
+ let tempSdk = null;
59
+ try {
60
+ tempSdk = await createSdk(sandboxOpts);
61
+ const tempInstance = new VercelSandboxInstance(tempSdk);
62
+ await run(tempInstance);
63
+ const snapshot = await tempSdk.snapshot();
64
+ await storage.setup.set(snapshotVersion, {
65
+ version: snapshotVersion,
66
+ snapshotId: snapshot.snapshotId,
67
+ createdAt: Date.now(),
68
+ lastUsedAt: null
69
+ });
70
+ await tempSdk.stop().catch(() => void 0);
71
+ } catch (error) {
72
+ log.error("failed to create setup snapshot", {
73
+ snapshotVersion,
74
+ cause: error
75
+ });
76
+ if (tempSdk) {
77
+ await tempSdk.stop().catch(() => void 0);
78
+ }
79
+ }
80
+ }
81
+ var VercelSandboxInstance = class {
82
+ sdk;
83
+ cwd;
84
+ constructor(sdk, cwd) {
85
+ this.sdk = sdk;
86
+ this.cwd = cwd ?? HOME_DIR;
87
+ }
88
+ async exec({
89
+ command,
90
+ args,
91
+ cwd,
92
+ env,
93
+ sudo,
94
+ signal
95
+ }) {
96
+ const output = await this.sdk.runCommand({
97
+ cmd: command,
98
+ args,
99
+ cwd: cwd ?? this.cwd,
100
+ env,
101
+ sudo,
102
+ signal,
103
+ detached: true
104
+ });
105
+ let stdout = "";
106
+ let stderr = "";
107
+ const logBuffer = [];
108
+ const state = {
109
+ resolve: null,
110
+ consumed: false
111
+ };
112
+ const consumeLogs = (async () => {
113
+ try {
114
+ for await (const entry of output.logs()) {
115
+ if (entry.stream === "stdout") {
116
+ stdout += entry.data;
117
+ } else {
118
+ stderr += entry.data;
119
+ }
120
+ logBuffer.push(entry);
121
+ state.resolve?.();
122
+ }
123
+ } catch {
124
+ }
125
+ state.consumed = true;
126
+ state.resolve?.();
127
+ })();
128
+ async function* logs() {
129
+ let index = 0;
130
+ while (!state.consumed || index < logBuffer.length) {
131
+ if (index < logBuffer.length) {
132
+ yield logBuffer[index++];
133
+ } else {
134
+ await new Promise((r) => {
135
+ state.resolve = r;
136
+ });
137
+ state.resolve = null;
138
+ }
139
+ }
140
+ }
141
+ const result = consumeLogs.then(async () => {
142
+ try {
143
+ const finished = await output.wait();
144
+ return { stdout, stderr, exitCode: finished.exitCode };
145
+ } catch (e) {
146
+ if (isSandboxGoneError(e)) {
147
+ return { stdout, stderr, exitCode: 1 };
148
+ }
149
+ throw e;
150
+ }
151
+ });
152
+ return { commandId: output.cmdId, logs, result };
153
+ }
154
+ async readFile({
155
+ path: filePath
156
+ }) {
157
+ try {
158
+ return await this.sdk.readFileToBuffer({ path: filePath, cwd: this.cwd });
159
+ } catch {
160
+ return null;
161
+ }
162
+ }
163
+ async writeFiles({
164
+ files,
165
+ destPath
166
+ }) {
167
+ if (files.length === 0) {
168
+ return;
169
+ }
170
+ const path = await import("path");
171
+ const nativeFiles = files.map((file) => {
172
+ const filePath = path.posix.join(destPath, file.path);
173
+ const absolutePath = path.posix.isAbsolute(filePath) ? filePath : path.posix.join(this.cwd, filePath);
174
+ return {
175
+ path: absolutePath,
176
+ content: typeof file.content === "string" ? Buffer.from(file.content) : file.content
177
+ };
178
+ });
179
+ await this.sdk.writeFiles(nativeFiles);
180
+ const shellScripts = nativeFiles.filter((f) => f.path.endsWith(".sh"));
181
+ if (shellScripts.length > 0) {
182
+ const result = await this.exec({
183
+ command: "chmod",
184
+ args: ["+x", ...shellScripts.map((f) => f.path)]
185
+ });
186
+ await result.result;
187
+ }
188
+ }
189
+ // biome-ignore lint/suspicious/useAwait: synchronous SDK call
190
+ async getDomain({
191
+ port
192
+ }) {
193
+ return this.sdk.domain(port);
194
+ }
195
+ async kill({
196
+ commandId
197
+ }) {
198
+ const cmd = await this.sdk.getCommand(commandId);
199
+ await cmd.kill();
200
+ }
201
+ // biome-ignore lint/suspicious/useAwait: synchronous SDK getter
202
+ async getStatus() {
203
+ const status = this.sdk.status;
204
+ if (status === "snapshotting") {
205
+ return "stopping";
206
+ }
207
+ if (status === "aborted") {
208
+ return "failed";
209
+ }
210
+ return status;
211
+ }
212
+ async start() {
213
+ const result = await this.exec({ command: "true" });
214
+ await result.result;
215
+ }
216
+ async stop() {
217
+ await this.sdk.stop();
218
+ }
219
+ async snapshot() {
220
+ const snap = await this.sdk.snapshot();
221
+ return { snapshotId: snap.snapshotId };
222
+ }
223
+ async updateNetworkPolicy({
224
+ policy
225
+ }) {
226
+ return await this.sdk.updateNetworkPolicy(policy);
227
+ }
228
+ };
229
+ function vercelSandbox() {
230
+ return {
231
+ type: "vercel",
232
+ async create({ agent, setup, record, signal: _signal, log }) {
233
+ const storage = agent.storage;
234
+ const config = setup.config ?? {};
235
+ const cwd = config.cwd;
236
+ const resources = config.resources ?? { vcpus: DEFAULT_VCPUS };
237
+ const ports = config.ports;
238
+ const networkPolicy = config.networkPolicy ?? setup.networkPolicy ?? void 0;
239
+ const sandboxOpts = {
240
+ resources,
241
+ ports,
242
+ networkPolicy,
243
+ snapshotId: config.snapshotId
244
+ };
245
+ const _startLifecycle = (vercelSandboxId) => {
246
+ if (!record) {
247
+ return;
248
+ }
249
+ startWorkflow(sandboxLifecycleWorkflow, [
250
+ {
251
+ input: {
252
+ agent,
253
+ sandboxId: record.id,
254
+ vercelSandboxId,
255
+ config: config.lifecycle
256
+ }
257
+ }
258
+ ]).catch((e) => {
259
+ log.error("failed to start lifecycle workflow", { cause: e });
260
+ });
261
+ };
262
+ if (setup.version) {
263
+ const existing = await storage.setup.get(setup.version);
264
+ if (existing?.snapshotId) {
265
+ const sdk2 = await createSdk({
266
+ ...sandboxOpts,
267
+ snapshotId: existing.snapshotId
268
+ });
269
+ const instance2 = new VercelSandboxInstance(sdk2, cwd);
270
+ storage.setup.set(setup.version, {
271
+ ...existing,
272
+ version: setup.version,
273
+ lastUsedAt: Date.now()
274
+ }).catch(() => void 0);
275
+ return {
276
+ instance: instance2,
277
+ metadata: { sandboxId: sdk2.sandboxId }
278
+ };
279
+ }
280
+ }
281
+ if (setup.run) {
282
+ if (!setup.version) {
283
+ log.error("setup.run provided without setup.version", { setup });
284
+ throw new Error("setup.run provided without setup.version");
285
+ }
286
+ createSetupSnapshot({
287
+ sandboxOpts,
288
+ run: setup.run,
289
+ storage,
290
+ snapshotVersion: setup.version,
291
+ log
292
+ }).catch((error) => {
293
+ log.error("background setup snapshot failed", { cause: error });
294
+ });
295
+ const sdk2 = await createSdk(sandboxOpts);
296
+ const instance2 = new VercelSandboxInstance(sdk2, cwd);
297
+ await setup.run(instance2);
298
+ return {
299
+ instance: instance2,
300
+ metadata: { sandboxId: sdk2.sandboxId }
301
+ };
302
+ }
303
+ const sdk = await createSdk(sandboxOpts);
304
+ const instance = new VercelSandboxInstance(sdk, cwd);
305
+ return {
306
+ instance,
307
+ metadata: { sandboxId: sdk.sandboxId }
308
+ };
309
+ },
310
+ async connect({ metadata }) {
311
+ const SandboxSDK = await loadSandboxSDK();
312
+ const sdk = await SandboxSDK.get({
313
+ sandboxId: metadata.sandboxId,
314
+ ...getTestCredentials()
315
+ });
316
+ return new VercelSandboxInstance(sdk);
317
+ }
318
+ };
319
+ }
320
+
321
+ export {
322
+ vercelSandbox
323
+ };
324
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/sandbox/bindings/vercel.ts"],
  "sourcesContent": ["import { start as startWorkflow } from \"workflow/api\";\nimport type { Storage } from \"../../storage\";\nimport type { Logger } from \"../../utils/logger\";\nimport type { ExecResult, SandboxBinding, SandboxInstance } from \"../adapter\";\nimport type { LifecycleConfig } from \"./vercel-lifecycle/steps\";\nimport { sandboxLifecycleWorkflow } from \"./vercel-lifecycle/workflow\";\n\nasync function loadSandboxSDK() {\n  return (await import(\"@vercel/sandbox\")).Sandbox;\n}\n\nconst MAX_TIMEOUT_MS = 5 * 60 * 60 * 1000; // 5 hours\nconst HOME_DIR = \"/home/vercel-sandbox\";\nconst DEFAULT_VCPUS = 2;\n\nexport type VercelBindingConfig = {\n  cwd?: string;\n  resources?: { vcpus: number };\n  ports?: number[];\n  networkPolicy?: import(\"@vercel/sandbox\").NetworkPolicy;\n  snapshotId?: string;\n  lifecycle?: LifecycleConfig;\n};\n\nexport type VercelBindingMetadata = {\n  sandboxId: string;\n};\n\ntype CreateSandboxOpts = {\n  resources: { vcpus: number };\n  ports?: number[];\n  networkPolicy?: import(\"@vercel/sandbox\").NetworkPolicy;\n  snapshotId?: string;\n};\n\nfunction isSandboxGoneError(e: unknown): boolean {\n  if (!(e instanceof Error)) {\n    return false;\n  }\n\n  const status =\n    (e as { response?: { status?: number } }).response?.status ??\n    (e as { cause?: { response?: { status?: number } } }).cause?.response\n      ?.status;\n\n  if (status === 410 || status === 422) {\n    return true;\n  }\n\n  const msg = e.message || String(e);\n  return (\n    msg.includes(\"Expected a stream of command data\") ||\n    msg.includes(\"Expected a stream of logs\")\n  );\n}\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\nasync function createSdk({\n  resources,\n  ports,\n  networkPolicy,\n  snapshotId,\n}: CreateSandboxOpts) {\n  const SandboxSDK = await loadSandboxSDK();\n  const base = {\n    resources,\n    timeout: MAX_TIMEOUT_MS,\n    ...(ports ? { ports } : {}),\n    ...(networkPolicy ? { networkPolicy } : {}),\n    ...getTestCredentials(),\n  };\n\n  if (snapshotId) {\n    return SandboxSDK.create({\n      ...base,\n      source: { type: \"snapshot\" as const, snapshotId },\n    });\n  }\n\n  return SandboxSDK.create(base);\n}\n\nasync function createSetupSnapshot({\n  sandboxOpts,\n  run,\n  storage,\n  snapshotVersion,\n  log,\n}: {\n  sandboxOpts: CreateSandboxOpts;\n  run: (sandbox: SandboxInstance) => Promise<void>;\n  storage: Storage;\n  snapshotVersion: string;\n  log: Logger;\n}): Promise<void> {\n  let tempSdk: Awaited<ReturnType<typeof createSdk>> | null = null;\n  try {\n    tempSdk = await createSdk(sandboxOpts);\n    const tempInstance = new VercelSandboxInstance(tempSdk);\n    await run(tempInstance);\n    const snapshot = await tempSdk.snapshot();\n    await storage.setup.set(snapshotVersion, {\n      version: snapshotVersion,\n      snapshotId: snapshot.snapshotId,\n      createdAt: Date.now(),\n      lastUsedAt: null,\n    });\n    await tempSdk.stop().catch(() => undefined);\n  } catch (error) {\n    log.error(\"failed to create setup snapshot\", {\n      snapshotVersion,\n      cause: error,\n    });\n    if (tempSdk) {\n      await tempSdk.stop().catch(() => undefined);\n    }\n  }\n}\n\nclass VercelSandboxInstance implements SandboxInstance {\n  private readonly sdk: import(\"@vercel/sandbox\").Sandbox;\n  readonly cwd: string;\n\n  constructor(sdk: import(\"@vercel/sandbox\").Sandbox, cwd?: string) {\n    this.sdk = sdk;\n    this.cwd = cwd ?? HOME_DIR;\n  }\n\n  async exec({\n    command,\n    args,\n    cwd,\n    env,\n    sudo,\n    signal,\n  }: {\n    command: string;\n    args?: string[];\n    cwd?: string;\n    env?: Record<string, string>;\n    sudo?: boolean;\n    signal?: AbortSignal;\n  }): Promise<ExecResult> {\n    const output = await this.sdk.runCommand({\n      cmd: command,\n      args,\n      cwd: cwd ?? this.cwd,\n      env,\n      sudo,\n      signal,\n      detached: true,\n    });\n\n    let stdout = \"\";\n    let stderr = \"\";\n    const logBuffer: { stream: \"stdout\" | \"stderr\"; data: string }[] = [];\n    const state = {\n      resolve: null as (() => void) | null,\n      consumed: false,\n    };\n\n    const consumeLogs = (async () => {\n      try {\n        for await (const entry of output.logs()) {\n          if (entry.stream === \"stdout\") {\n            stdout += entry.data;\n          } else {\n            stderr += entry.data;\n          }\n\n          logBuffer.push(entry);\n          state.resolve?.();\n        }\n      } catch {\n        // Sandbox may have been stopped \u2014 logs endpoint returns 422\n      }\n      state.consumed = true;\n      state.resolve?.();\n    })();\n\n    async function* logs(): AsyncIterable<{\n      stream: \"stdout\" | \"stderr\";\n      data: string;\n    }> {\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>((r) => {\n            state.resolve = r;\n          });\n          state.resolve = null;\n        }\n      }\n    }\n\n    const result = consumeLogs.then(async () => {\n      try {\n        const finished = await output.wait();\n        return { stdout, stderr, exitCode: finished.exitCode };\n      } catch (e) {\n        if (isSandboxGoneError(e)) {\n          return { stdout, stderr, exitCode: 1 };\n        }\n        throw e;\n      }\n    });\n\n    return { commandId: output.cmdId, logs, result };\n  }\n\n  async readFile({\n    path: filePath,\n  }: {\n    path: string;\n    signal?: AbortSignal;\n  }): Promise<Buffer | null> {\n    try {\n      return await this.sdk.readFileToBuffer({ path: filePath, cwd: this.cwd });\n    } catch {\n      return null;\n    }\n  }\n\n  async writeFiles({\n    files,\n    destPath,\n  }: {\n    files: { path: string; content: string | Buffer }[];\n    destPath: string;\n    signal?: AbortSignal;\n  }): Promise<void> {\n    if (files.length === 0) {\n      return;\n    }\n\n    const path = await import(\"node:path\");\n    const nativeFiles = files.map((file) => {\n      const filePath = path.posix.join(destPath, file.path);\n      const absolutePath = path.posix.isAbsolute(filePath)\n        ? filePath\n        : path.posix.join(this.cwd, filePath);\n      return {\n        path: absolutePath,\n        content:\n          typeof file.content === \"string\"\n            ? Buffer.from(file.content)\n            : file.content,\n      };\n    });\n\n    await this.sdk.writeFiles(nativeFiles);\n\n    const shellScripts = nativeFiles.filter((f) => f.path.endsWith(\".sh\"));\n    if (shellScripts.length > 0) {\n      const result = await this.exec({\n        command: \"chmod\",\n        args: [\"+x\", ...shellScripts.map((f) => f.path)],\n      });\n      await result.result;\n    }\n  }\n\n  // biome-ignore lint/suspicious/useAwait: synchronous SDK call\n  async getDomain({\n    port,\n  }: {\n    port: number;\n    signal?: AbortSignal;\n  }): Promise<string> {\n    return this.sdk.domain(port);\n  }\n\n  async kill({\n    commandId,\n  }: {\n    commandId: string;\n    signal?: AbortSignal;\n  }): Promise<void> {\n    const cmd = await this.sdk.getCommand(commandId);\n    await cmd.kill();\n  }\n\n  // biome-ignore lint/suspicious/useAwait: synchronous SDK getter\n  async getStatus(): Promise<\n    \"pending\" | \"running\" | \"stopping\" | \"stopped\" | \"failed\"\n  > {\n    const status = this.sdk.status;\n    // Map SDK-only statuses to our interface's union\n    if (status === \"snapshotting\") {\n      return \"stopping\";\n    }\n    if (status === \"aborted\") {\n      return \"failed\";\n    }\n    return status;\n  }\n\n  async start(): Promise<void> {\n    // The Vercel SDK doesn't have a resume method.\n    // Run a no-op command to verify the sandbox is reachable.\n    const result = await this.exec({ command: \"true\" });\n    await result.result;\n  }\n\n  async stop(): Promise<void> {\n    await this.sdk.stop();\n  }\n\n  async snapshot(): Promise<{ snapshotId: string }> {\n    const snap = await this.sdk.snapshot();\n    return { snapshotId: snap.snapshotId };\n  }\n\n  async updateNetworkPolicy({\n    policy,\n  }: {\n    policy: import(\"@vercel/sandbox\").NetworkPolicy;\n    signal?: AbortSignal;\n  }): Promise<import(\"@vercel/sandbox\").NetworkPolicy> {\n    return await this.sdk.updateNetworkPolicy(policy);\n  }\n}\n\nexport function vercelSandbox(): SandboxBinding<\n  \"vercel\",\n  VercelBindingConfig,\n  VercelBindingMetadata\n> {\n  return {\n    type: \"vercel\",\n    async create({ agent, setup, record, signal: _signal, log }) {\n      const storage = agent.storage;\n      const config = setup.config ?? {};\n      const cwd = config.cwd;\n      const resources = config.resources ?? { vcpus: DEFAULT_VCPUS };\n      const ports = config.ports;\n      const networkPolicy =\n        config.networkPolicy ?? setup.networkPolicy ?? undefined;\n\n      const sandboxOpts: CreateSandboxOpts = {\n        resources,\n        ports,\n        networkPolicy,\n        snapshotId: config.snapshotId,\n      };\n\n      const _startLifecycle = (vercelSandboxId: string) => {\n        if (!record) {\n          return;\n        }\n        startWorkflow(sandboxLifecycleWorkflow, [\n          {\n            input: {\n              agent,\n              sandboxId: record.id,\n              vercelSandboxId,\n              config: config.lifecycle,\n            },\n          },\n        ]).catch((e) => {\n          log.error(\"failed to start lifecycle workflow\", { cause: e });\n        });\n      };\n\n      if (setup.version) {\n        const existing = await storage.setup.get(setup.version);\n        if (existing?.snapshotId) {\n          const sdk = await createSdk({\n            ...sandboxOpts,\n            snapshotId: existing.snapshotId,\n          });\n          const instance = new VercelSandboxInstance(sdk, cwd);\n\n          storage.setup\n            .set(setup.version, {\n              ...existing,\n              version: setup.version,\n              lastUsedAt: Date.now(),\n            })\n            .catch(() => undefined);\n\n          return {\n            instance,\n            metadata: { sandboxId: sdk.sandboxId },\n          };\n        }\n      }\n\n      if (setup.run) {\n        if (!setup.version) {\n          log.error(\"setup.run provided without setup.version\", { setup });\n          throw new Error(\"setup.run provided without setup.version\");\n        }\n        createSetupSnapshot({\n          sandboxOpts,\n          run: setup.run,\n          storage,\n          snapshotVersion: setup.version,\n          log,\n        }).catch((error) => {\n          log.error(\"background setup snapshot failed\", { cause: error });\n        });\n\n        const sdk = await createSdk(sandboxOpts);\n        const instance = new VercelSandboxInstance(sdk, cwd);\n        await setup.run(instance);\n\n        return {\n          instance,\n          metadata: { sandboxId: sdk.sandboxId },\n        };\n      }\n\n      const sdk = await createSdk(sandboxOpts);\n      const instance = new VercelSandboxInstance(sdk, cwd);\n\n      return {\n        instance,\n        metadata: { sandboxId: sdk.sandboxId },\n      };\n    },\n\n    async connect({ metadata }) {\n      const SandboxSDK = await loadSandboxSDK();\n      const sdk = await SandboxSDK.get({\n        sandboxId: metadata.sandboxId,\n        ...getTestCredentials(),\n      });\n      return new VercelSandboxInstance(sdk);\n    },\n  };\n}\n"],
  "mappings": "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",
  "names": ["sdk", "instance"]
}
