experimental-agent 0.2.3 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +55 -254
- package/dist/adapter-BigchkkI.d.mts +201 -0
- package/dist/adapter-BigchkkI.d.ts +201 -0
- package/dist/chunk-BFFNCESS.mjs +302 -0
- package/dist/chunk-C4VSUEY2.mjs +72 -0
- package/dist/chunk-DOD4MC5D.mjs +196 -0
- package/dist/chunk-ELWIUJUK.mjs +96 -0
- package/dist/chunk-GKASMIBR.mjs +50 -0
- package/dist/chunk-JO3JDCH5.mjs +107 -0
- package/dist/chunk-MSWINCCM.mjs +128 -0
- package/dist/chunk-RT72C52I.mjs +324 -0
- package/dist/chunk-ZUFJJYC4.mjs +150 -0
- package/dist/{handler-FRUPZ4LX.mjs → docker-QPCLWLYR.mjs} +3 -4
- package/dist/entry-BmQ8FO-5.d.ts +36 -0
- package/dist/entry-CZd9aAwn.d.mts +36 -0
- package/dist/index.d.mts +415 -18
- package/dist/index.d.ts +415 -18
- package/dist/index.js +3036 -5494
- package/dist/index.mjs +3264 -1142
- package/dist/lifecycle-workflow-steps.d.mts +5 -0
- package/dist/lifecycle-workflow-steps.d.ts +5 -0
- package/dist/lifecycle-workflow-steps.js +263 -0
- package/dist/lifecycle-workflow-steps.mjs +9 -0
- package/dist/lifecycle-workflow.d.mts +6 -6
- package/dist/lifecycle-workflow.d.ts +6 -6
- package/dist/lifecycle-workflow.js +192 -905
- package/dist/lifecycle-workflow.mjs +3 -1
- package/dist/local-KJ3BSIFJ.mjs +8 -0
- package/dist/next/loader.js +27 -6
- package/dist/next/loader.mjs +1 -1
- package/dist/next.js +27 -6
- package/dist/next.mjs +1 -1
- package/dist/{process-manager-JDUJDYGU.mjs → process-manager-WQHAIVRB.mjs} +1 -1
- package/dist/sandbox.d.mts +6 -0
- package/dist/sandbox.d.ts +6 -0
- package/dist/sandbox.js +1070 -0
- package/dist/sandbox.mjs +19 -0
- package/dist/steps-BnkRQKlc.d.ts +173 -0
- package/dist/steps-u-mGDbP_.d.mts +173 -0
- package/dist/storage.d.mts +11 -0
- package/dist/storage.d.ts +11 -0
- package/dist/storage.js +234 -0
- package/dist/storage.mjs +12 -0
- package/dist/vercel-QZ6INPMV.mjs +11 -0
- package/package.json +26 -5
- package/dist/agent-workflow.d.mts +0 -30
- package/dist/agent-workflow.d.ts +0 -30
- package/dist/agent-workflow.js +0 -5433
- package/dist/agent-workflow.mjs +0 -14
- package/dist/chunk-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,150 @@
|
|
|
1
|
+
// src/sandbox/bindings/local.ts
|
|
2
|
+
import { ulid } from "ulid";
|
|
3
|
+
var LocalSandboxInstance = class {
|
|
4
|
+
cwd;
|
|
5
|
+
basePath;
|
|
6
|
+
processes = /* @__PURE__ */ new Map();
|
|
7
|
+
constructor(basePath) {
|
|
8
|
+
this.basePath = basePath;
|
|
9
|
+
this.cwd = basePath;
|
|
10
|
+
}
|
|
11
|
+
async exec(opts) {
|
|
12
|
+
const { spawn } = await import("child_process");
|
|
13
|
+
const path = await import("path");
|
|
14
|
+
const commandId = `command_${ulid()}`;
|
|
15
|
+
const finalCmd = opts.sudo ? "sudo" : opts.command;
|
|
16
|
+
const finalArgs = opts.sudo ? [opts.command, ...opts.args ?? []] : opts.args ?? [];
|
|
17
|
+
const child = spawn(finalCmd, finalArgs, {
|
|
18
|
+
cwd: opts.cwd ? path.resolve(this.basePath, opts.cwd) : this.basePath,
|
|
19
|
+
env: opts.env ? { ...process.env, ...opts.env } : void 0,
|
|
20
|
+
signal: opts.signal
|
|
21
|
+
});
|
|
22
|
+
this.processes.set(commandId, child);
|
|
23
|
+
let stdout = "";
|
|
24
|
+
let stderr = "";
|
|
25
|
+
const logQueue = [];
|
|
26
|
+
let logResolve = null;
|
|
27
|
+
let closed = false;
|
|
28
|
+
child.stdout.on("data", (data) => {
|
|
29
|
+
const str = String(data);
|
|
30
|
+
stdout += str;
|
|
31
|
+
logQueue.push({ stream: "stdout", data: str });
|
|
32
|
+
logResolve?.();
|
|
33
|
+
});
|
|
34
|
+
child.stderr.on("data", (data) => {
|
|
35
|
+
const str = String(data);
|
|
36
|
+
stderr += str;
|
|
37
|
+
logQueue.push({ stream: "stderr", data: str });
|
|
38
|
+
logResolve?.();
|
|
39
|
+
});
|
|
40
|
+
const result = new Promise((resolve, reject) => {
|
|
41
|
+
child.on("error", (err) => {
|
|
42
|
+
this.processes.delete(commandId);
|
|
43
|
+
closed = true;
|
|
44
|
+
logResolve?.();
|
|
45
|
+
reject(err);
|
|
46
|
+
});
|
|
47
|
+
child.on("close", (code) => {
|
|
48
|
+
this.processes.delete(commandId);
|
|
49
|
+
closed = true;
|
|
50
|
+
logResolve?.();
|
|
51
|
+
resolve({ stdout, stderr, exitCode: code ?? 0 });
|
|
52
|
+
});
|
|
53
|
+
});
|
|
54
|
+
async function* logs() {
|
|
55
|
+
while (!closed || logQueue.length > 0) {
|
|
56
|
+
const entry = logQueue.shift();
|
|
57
|
+
if (entry) {
|
|
58
|
+
yield entry;
|
|
59
|
+
} else if (!closed) {
|
|
60
|
+
await new Promise((r) => {
|
|
61
|
+
logResolve = r;
|
|
62
|
+
});
|
|
63
|
+
logResolve = null;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
return { commandId, logs, result };
|
|
68
|
+
}
|
|
69
|
+
async readFile(opts) {
|
|
70
|
+
const fs = await import("fs/promises");
|
|
71
|
+
const path = await import("path");
|
|
72
|
+
const fullPath = path.resolve(this.basePath, opts.path);
|
|
73
|
+
try {
|
|
74
|
+
return await fs.readFile(fullPath);
|
|
75
|
+
} catch (e) {
|
|
76
|
+
if (e instanceof Error && "code" in e && e.code === "ENOENT") {
|
|
77
|
+
return null;
|
|
78
|
+
}
|
|
79
|
+
throw e;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
async writeFiles(opts) {
|
|
83
|
+
const fs = await import("fs/promises");
|
|
84
|
+
const pathMod = await import("path");
|
|
85
|
+
for (const file of opts.files) {
|
|
86
|
+
const fullPath = pathMod.resolve(this.basePath, opts.destPath, file.path);
|
|
87
|
+
await fs.mkdir(pathMod.dirname(fullPath), { recursive: true });
|
|
88
|
+
await fs.writeFile(fullPath, file.content);
|
|
89
|
+
if (file.path.endsWith(".sh")) {
|
|
90
|
+
await fs.chmod(fullPath, 493);
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
// biome-ignore lint/suspicious/useAwait: .
|
|
95
|
+
async getDomain(opts) {
|
|
96
|
+
return `http://localhost:${opts.port}`;
|
|
97
|
+
}
|
|
98
|
+
// biome-ignore lint/suspicious/useAwait: .
|
|
99
|
+
async kill(opts) {
|
|
100
|
+
const child = this.processes.get(opts.commandId);
|
|
101
|
+
if (child) {
|
|
102
|
+
child.kill("SIGTERM");
|
|
103
|
+
this.processes.delete(opts.commandId);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
// biome-ignore lint/suspicious/useAwait: .
|
|
107
|
+
async getStatus() {
|
|
108
|
+
return "running";
|
|
109
|
+
}
|
|
110
|
+
async start() {
|
|
111
|
+
}
|
|
112
|
+
// biome-ignore lint/suspicious/useAwait: .
|
|
113
|
+
async stop() {
|
|
114
|
+
throw new Error("stop is not supported for local sandboxes");
|
|
115
|
+
}
|
|
116
|
+
// biome-ignore lint/suspicious/useAwait: .
|
|
117
|
+
async snapshot() {
|
|
118
|
+
throw new Error("snapshot is not supported for local sandboxes");
|
|
119
|
+
}
|
|
120
|
+
// biome-ignore lint/suspicious/useAwait: .
|
|
121
|
+
async updateNetworkPolicy() {
|
|
122
|
+
throw new Error("updateNetworkPolicy is not supported for local sandboxes");
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
function localSandbox() {
|
|
126
|
+
return {
|
|
127
|
+
type: "local",
|
|
128
|
+
async create(opts) {
|
|
129
|
+
const basePath = opts.setup.config?.cwd ?? process.cwd();
|
|
130
|
+
const instance = new LocalSandboxInstance(basePath);
|
|
131
|
+
if (opts.setup?.run) {
|
|
132
|
+
await opts.setup.run(instance);
|
|
133
|
+
}
|
|
134
|
+
return {
|
|
135
|
+
instance,
|
|
136
|
+
metadata: { basePath, pid: process.pid }
|
|
137
|
+
};
|
|
138
|
+
},
|
|
139
|
+
// biome-ignore lint/suspicious/useAwait: .
|
|
140
|
+
async connect(opts) {
|
|
141
|
+
const basePath = opts.metadata.basePath;
|
|
142
|
+
return new LocalSandboxInstance(basePath);
|
|
143
|
+
}
|
|
144
|
+
};
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
export {
|
|
148
|
+
localSandbox
|
|
149
|
+
};
|
|
150
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/sandbox/bindings/local.ts"],
  "sourcesContent": ["import { ulid } from \"ulid\";\nimport type { ExecResult, SandboxBinding, SandboxInstance } from \"../adapter\";\n\nexport type LocalBindingConfig = {\n  cwd?: string;\n};\n\nexport type LocalBindingMetadata = {\n  basePath: string;\n  pid: number;\n};\n\nclass LocalSandboxInstance implements SandboxInstance {\n  readonly cwd: string;\n  private readonly basePath: string;\n  private readonly processes = new Map<\n    string,\n    import(\"node:child_process\").ChildProcess\n  >();\n\n  constructor(basePath: string) {\n    this.basePath = basePath;\n    this.cwd = basePath;\n  }\n\n  async exec(opts: {\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 { spawn } = await import(\"node:child_process\");\n    const path = await import(\"node:path\");\n    const commandId = `command_${ulid()}`;\n\n    const finalCmd = opts.sudo ? \"sudo\" : opts.command;\n    const finalArgs = opts.sudo\n      ? [opts.command, ...(opts.args ?? [])]\n      : (opts.args ?? []);\n\n    const child = spawn(finalCmd, finalArgs, {\n      cwd: opts.cwd ? path.resolve(this.basePath, opts.cwd) : this.basePath,\n      env: opts.env ? { ...process.env, ...opts.env } : undefined,\n      signal: opts.signal,\n    });\n\n    this.processes.set(commandId, child);\n\n    let stdout = \"\";\n    let stderr = \"\";\n    const logQueue: { stream: \"stdout\" | \"stderr\"; data: string }[] = [];\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        this.processes.delete(commandId);\n        closed = true;\n        logResolve?.();\n        reject(err);\n      });\n\n      child.on(\"close\", (code: number | null) => {\n        this.processes.delete(commandId);\n        closed = true;\n        logResolve?.();\n        resolve({ stdout, stderr, exitCode: code ?? 0 });\n      });\n    });\n\n    async function* logs(): AsyncIterable<{\n      stream: \"stdout\" | \"stderr\";\n      data: string;\n    }> {\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>((r) => {\n            logResolve = r;\n          });\n          logResolve = null;\n        }\n      }\n    }\n\n    return { commandId, logs, result };\n  }\n\n  async readFile(opts: {\n    path: string;\n    signal?: AbortSignal;\n  }): Promise<Buffer | null> {\n    const fs = await import(\"node:fs/promises\");\n    const path = await import(\"node:path\");\n    const fullPath = path.resolve(this.basePath, opts.path);\n    try {\n      return await fs.readFile(fullPath);\n    } catch (e: unknown) {\n      if (\n        e instanceof Error &&\n        \"code\" in e &&\n        (e as NodeJS.ErrnoException).code === \"ENOENT\"\n      ) {\n        return null;\n      }\n      throw e;\n    }\n  }\n\n  async writeFiles(opts: {\n    files: { path: string; content: string | Buffer }[];\n    destPath: string;\n    signal?: AbortSignal;\n  }): Promise<void> {\n    const fs = await import(\"node:fs/promises\");\n    const pathMod = await import(\"node:path\");\n    for (const file of opts.files) {\n      const fullPath = pathMod.resolve(this.basePath, opts.destPath, file.path);\n      await fs.mkdir(pathMod.dirname(fullPath), { recursive: true });\n      await fs.writeFile(fullPath, file.content);\n      if (file.path.endsWith(\".sh\")) {\n        await fs.chmod(fullPath, 0o755);\n      }\n    }\n  }\n\n  // biome-ignore lint/suspicious/useAwait: .\n  async getDomain(opts: {\n    port: number;\n    signal?: AbortSignal;\n  }): Promise<string> {\n    return `http://localhost:${opts.port}`;\n  }\n\n  // biome-ignore lint/suspicious/useAwait: .\n  async kill(opts: { commandId: string; signal?: AbortSignal }): Promise<void> {\n    const child = this.processes.get(opts.commandId);\n    if (child) {\n      child.kill(\"SIGTERM\");\n      this.processes.delete(opts.commandId);\n    }\n  }\n\n  // biome-ignore lint/suspicious/useAwait: .\n  async getStatus(): Promise<\"running\"> {\n    return \"running\";\n  }\n\n  async start(): Promise<void> {\n    // no-op: local sandbox is always started\n  }\n\n  // biome-ignore lint/suspicious/useAwait: .\n  async stop(): Promise<void> {\n    throw new Error(\"stop is not supported for local sandboxes\");\n  }\n\n  // biome-ignore lint/suspicious/useAwait: .\n  async snapshot(): Promise<{ snapshotId: string }> {\n    throw new Error(\"snapshot is not supported for local sandboxes\");\n  }\n\n  // biome-ignore lint/suspicious/useAwait: .\n  async updateNetworkPolicy(): Promise<never> {\n    throw new Error(\"updateNetworkPolicy is not supported for local sandboxes\");\n  }\n}\n\nexport function localSandbox(): SandboxBinding<\n  \"local\",\n  LocalBindingConfig,\n  LocalBindingMetadata\n> {\n  return {\n    type: \"local\",\n    async create(opts) {\n      const basePath = opts.setup.config?.cwd ?? process.cwd();\n      const instance = new LocalSandboxInstance(basePath);\n\n      if (opts.setup?.run) {\n        await opts.setup.run(instance);\n      }\n\n      return {\n        instance,\n        metadata: { basePath, pid: process.pid },\n      };\n    },\n\n    // biome-ignore lint/suspicious/useAwait: .\n    async connect(opts) {\n      const basePath = opts.metadata.basePath;\n      return new LocalSandboxInstance(basePath);\n    },\n  };\n}\n"],
  "mappings": "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",
  "names": []
}

|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
import {
|
|
2
|
-
|
|
3
|
-
} from "./chunk-
|
|
4
|
-
import "./chunk-YRYXN7W4.mjs";
|
|
2
|
+
dockerSandbox
|
|
3
|
+
} from "./chunk-BFFNCESS.mjs";
|
|
5
4
|
import "./chunk-BJTO5JO5.mjs";
|
|
6
5
|
export {
|
|
7
|
-
|
|
6
|
+
dockerSandbox
|
|
8
7
|
};
|
|
9
8
|
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { S as SandboxBinding, e as LifecycleConfig } from './steps-BnkRQKlc.js';
|
|
2
|
+
import * as _vercel_sandbox from '@vercel/sandbox';
|
|
3
|
+
|
|
4
|
+
type DockerBindingConfig = {
|
|
5
|
+
cwd?: string;
|
|
6
|
+
};
|
|
7
|
+
type DockerBindingMetadata = {
|
|
8
|
+
sandboxName: string;
|
|
9
|
+
};
|
|
10
|
+
declare function dockerSandbox(): SandboxBinding<"docker", DockerBindingConfig, DockerBindingMetadata>;
|
|
11
|
+
|
|
12
|
+
type LocalBindingConfig = {
|
|
13
|
+
cwd?: string;
|
|
14
|
+
};
|
|
15
|
+
type LocalBindingMetadata = {
|
|
16
|
+
basePath: string;
|
|
17
|
+
pid: number;
|
|
18
|
+
};
|
|
19
|
+
declare function localSandbox(): SandboxBinding<"local", LocalBindingConfig, LocalBindingMetadata>;
|
|
20
|
+
|
|
21
|
+
type VercelBindingConfig = {
|
|
22
|
+
cwd?: string;
|
|
23
|
+
resources?: {
|
|
24
|
+
vcpus: number;
|
|
25
|
+
};
|
|
26
|
+
ports?: number[];
|
|
27
|
+
networkPolicy?: _vercel_sandbox.NetworkPolicy;
|
|
28
|
+
snapshotId?: string;
|
|
29
|
+
lifecycle?: LifecycleConfig;
|
|
30
|
+
};
|
|
31
|
+
type VercelBindingMetadata = {
|
|
32
|
+
sandboxId: string;
|
|
33
|
+
};
|
|
34
|
+
declare function vercelSandbox(): SandboxBinding<"vercel", VercelBindingConfig, VercelBindingMetadata>;
|
|
35
|
+
|
|
36
|
+
export { type DockerBindingConfig as D, type LocalBindingConfig as L, type VercelBindingConfig as V, type LocalBindingMetadata as a, type VercelBindingMetadata as b, type DockerBindingMetadata as c, dockerSandbox as d, localSandbox as l, vercelSandbox as v };
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
import { S as SandboxBinding, e as LifecycleConfig } from './steps-u-mGDbP_.mjs';
|
|
2
|
+
import * as _vercel_sandbox from '@vercel/sandbox';
|
|
3
|
+
|
|
4
|
+
type DockerBindingConfig = {
|
|
5
|
+
cwd?: string;
|
|
6
|
+
};
|
|
7
|
+
type DockerBindingMetadata = {
|
|
8
|
+
sandboxName: string;
|
|
9
|
+
};
|
|
10
|
+
declare function dockerSandbox(): SandboxBinding<"docker", DockerBindingConfig, DockerBindingMetadata>;
|
|
11
|
+
|
|
12
|
+
type LocalBindingConfig = {
|
|
13
|
+
cwd?: string;
|
|
14
|
+
};
|
|
15
|
+
type LocalBindingMetadata = {
|
|
16
|
+
basePath: string;
|
|
17
|
+
pid: number;
|
|
18
|
+
};
|
|
19
|
+
declare function localSandbox(): SandboxBinding<"local", LocalBindingConfig, LocalBindingMetadata>;
|
|
20
|
+
|
|
21
|
+
type VercelBindingConfig = {
|
|
22
|
+
cwd?: string;
|
|
23
|
+
resources?: {
|
|
24
|
+
vcpus: number;
|
|
25
|
+
};
|
|
26
|
+
ports?: number[];
|
|
27
|
+
networkPolicy?: _vercel_sandbox.NetworkPolicy;
|
|
28
|
+
snapshotId?: string;
|
|
29
|
+
lifecycle?: LifecycleConfig;
|
|
30
|
+
};
|
|
31
|
+
type VercelBindingMetadata = {
|
|
32
|
+
sandboxId: string;
|
|
33
|
+
};
|
|
34
|
+
declare function vercelSandbox(): SandboxBinding<"vercel", VercelBindingConfig, VercelBindingMetadata>;
|
|
35
|
+
|
|
36
|
+
export { type DockerBindingConfig as D, type LocalBindingConfig as L, type VercelBindingConfig as V, type LocalBindingMetadata as a, type VercelBindingMetadata as b, type DockerBindingMetadata as c, dockerSandbox as d, localSandbox as l, vercelSandbox as v };
|