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.
- package/README.md +103 -241
- package/dist/adapter-zgOel4wW.d.mts +256 -0
- package/dist/adapter-zgOel4wW.d.ts +256 -0
- package/dist/chunk-BFFNCESS.mjs +302 -0
- package/dist/chunk-C4VSUEY2.mjs +72 -0
- package/dist/chunk-GKASMIBR.mjs +50 -0
- package/dist/chunk-IV75IMEW.mjs +328 -0
- package/dist/chunk-JO3JDCH5.mjs +107 -0
- package/dist/chunk-MSTM6W3Y.mjs +99 -0
- package/dist/chunk-MSWINCCM.mjs +128 -0
- package/dist/chunk-RT72C52I.mjs +324 -0
- package/dist/chunk-ZUFJJYC4.mjs +150 -0
- package/dist/{handler-FRUPZ4LX.mjs → docker-QPCLWLYR.mjs} +3 -4
- package/dist/entry-6HYg5qqg.d.mts +36 -0
- package/dist/entry-BrWOmEK2.d.ts +36 -0
- package/dist/index.d.mts +401 -18
- package/dist/index.d.ts +401 -18
- package/dist/index.js +3396 -5500
- package/dist/index.mjs +3511 -1166
- package/dist/lifecycle-workflow-steps.d.mts +5 -0
- package/dist/lifecycle-workflow-steps.d.ts +5 -0
- package/dist/lifecycle-workflow-steps.js +263 -0
- package/dist/lifecycle-workflow-steps.mjs +9 -0
- package/dist/lifecycle-workflow.d.mts +6 -6
- package/dist/lifecycle-workflow.d.ts +6 -6
- package/dist/lifecycle-workflow.js +192 -905
- package/dist/lifecycle-workflow.mjs +3 -1
- package/dist/local-KJ3BSIFJ.mjs +8 -0
- package/dist/next/loader.js +31 -7
- package/dist/next/loader.mjs +1 -1
- package/dist/next.js +35 -8
- package/dist/next.mjs +6 -3
- package/dist/{process-manager-JDUJDYGU.mjs → process-manager-WQHAIVRB.mjs} +1 -1
- package/dist/sandbox.d.mts +6 -0
- package/dist/sandbox.d.ts +6 -0
- package/dist/sandbox.js +1070 -0
- package/dist/sandbox.mjs +19 -0
- package/dist/steps-BIsP57pm.d.mts +173 -0
- package/dist/steps-DShnXBLf.d.ts +173 -0
- package/dist/storage.d.mts +17 -0
- package/dist/storage.d.ts +17 -0
- package/dist/storage.js +368 -0
- package/dist/storage.mjs +16 -0
- package/dist/vercel-QZ6INPMV.mjs +11 -0
- package/package.json +29 -5
- package/dist/agent-workflow.d.mts +0 -30
- package/dist/agent-workflow.d.ts +0 -30
- package/dist/agent-workflow.js +0 -5433
- package/dist/agent-workflow.mjs +0 -14
- package/dist/chunk-7M6UPURS.mjs +0 -75
- package/dist/chunk-AML2VCQS.mjs +0 -1287
- package/dist/chunk-FQ67QZOI.mjs +0 -75
- package/dist/chunk-NO7RHGTH.mjs +0 -2367
- package/dist/chunk-NXDVNJRS.mjs +0 -106
- package/dist/chunk-OZZVS6L5.mjs +0 -139
- package/dist/chunk-SJVFFE5D.mjs +0 -402
- package/dist/chunk-TAXLUVIC.mjs +0 -1
- package/dist/chunk-TGNVXSMX.mjs +0 -399
- package/dist/chunk-YRYXN7W4.mjs +0 -48
- package/dist/chunk-ZIAHPXOJ.mjs +0 -595
- package/dist/client-BKA7XBGW.mjs +0 -15
- package/dist/client-CEeSFGva.d.mts +0 -2376
- package/dist/client-CEeSFGva.d.ts +0 -2376
- package/dist/docker-FB2MJTHJ.mjs +0 -12
- package/dist/local-fs-handlers-SYOCKTPN.mjs +0 -447
- package/dist/sandbox-UENKQV3T.mjs +0 -21
- package/dist/storage-LSDMRW73.mjs +0 -20
- package/dist/vercel-SD3JTECG.mjs +0 -20
- package/dist/vercel-sdk-I6A4MVAN.mjs +0 -8
|
@@ -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": "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",
  "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"]
}

|