experimental-agent 0.5.0 → 0.6.1

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 (47) hide show
  1. package/dist/{adapter-Cl735Kp4.d.mts → adapter-txsF6hou.d.mts} +2 -0
  2. package/dist/{adapter-Cl735Kp4.d.ts → adapter-txsF6hou.d.ts} +2 -0
  3. package/dist/{chunk-AB2JYY6A.mjs → chunk-CCWLV27N.mjs} +10 -2
  4. package/dist/chunk-CS2SEUAA.mjs +405 -0
  5. package/dist/{chunk-6MS4CGEZ.mjs → chunk-D35AQN7O.mjs} +5 -5
  6. package/dist/chunk-LZOMFHX3.mjs +38 -0
  7. package/dist/chunk-PH2FXKOU.mjs +9 -0
  8. package/dist/client-B2ohNvwc.d.mts +494 -0
  9. package/dist/client-BbQZtxca.d.ts +494 -0
  10. package/dist/client.mjs +1 -1
  11. package/dist/{docker-OBUQX5ZI.mjs → docker-FCSNVBEQ.mjs} +1 -1
  12. package/dist/{entry-Bs17QEiq.d.mts → entry-BUiucCNp.d.mts} +1 -1
  13. package/dist/{entry-QNyd4S1s.d.ts → entry-ok9EBUS3.d.ts} +1 -1
  14. package/dist/index.d.mts +475 -475
  15. package/dist/index.d.ts +475 -475
  16. package/dist/index.js +16595 -245
  17. package/dist/index.mjs +16406 -117
  18. package/dist/lifecycle-workflow-steps.d.mts +2 -2
  19. package/dist/lifecycle-workflow-steps.d.ts +2 -2
  20. package/dist/lifecycle-workflow-steps.mjs +1 -1
  21. package/dist/lifecycle-workflow.d.mts +2 -2
  22. package/dist/lifecycle-workflow.d.ts +2 -2
  23. package/dist/lifecycle-workflow.mjs +1 -1
  24. package/dist/{local-4C3V4EFS.mjs → local-NXHIUJTO.mjs} +1 -1
  25. package/dist/next/loader.js +10 -2
  26. package/dist/next/loader.mjs +2 -2
  27. package/dist/next.js +10 -2
  28. package/dist/next.mjs +2 -2
  29. package/dist/{process-manager-WQHAIVRB.mjs → process-manager-26NELLRU.mjs} +1 -1
  30. package/dist/react.d.mts +56 -0
  31. package/dist/react.d.ts +56 -0
  32. package/dist/react.js +144 -0
  33. package/dist/react.mjs +117 -0
  34. package/dist/sandbox.d.mts +3 -3
  35. package/dist/sandbox.d.ts +3 -3
  36. package/dist/sandbox.js +5 -5
  37. package/dist/sandbox.mjs +2 -2
  38. package/dist/{steps-XA4wG8W3.d.ts → steps-BOKeU8X3.d.ts} +3 -2
  39. package/dist/{steps-eTytqxQb.d.mts → steps-Mi3sjYbD.d.mts} +3 -2
  40. package/dist/storage.d.mts +2 -2
  41. package/dist/storage.d.ts +2 -2
  42. package/dist/storage.js +107 -48
  43. package/dist/storage.mjs +2 -2
  44. package/dist/{vercel-6ORAC625.mjs → vercel-BOGHAFI4.mjs} +2 -2
  45. package/package.json +9 -1
  46. package/dist/chunk-BJTO5JO5.mjs +0 -11
  47. package/dist/chunk-I5DCB7RU.mjs +0 -346
@@ -230,10 +230,10 @@ function vercelSandbox(defaults) {
230
230
  return {
231
231
  type: "vercel",
232
232
  defaults,
233
- async create({ agent, setup, record, signal: _signal, log }) {
233
+ async create({ cwd: createCwd, agent, setup, record, signal: _signal, log }) {
234
234
  const storage = agent.storage;
235
235
  const config = setup.config ?? {};
236
- const cwd = config.cwd;
236
+ const cwd = config.cwd ?? createCwd ?? void 0;
237
237
  const resources = config.resources ?? { vcpus: DEFAULT_VCPUS };
238
238
  const ports = config.ports;
239
239
  const networkPolicy = config.networkPolicy ?? setup.networkPolicy ?? void 0;
@@ -308,13 +308,13 @@ function vercelSandbox(defaults) {
308
308
  metadata: { sandboxId: sdk.sandboxId }
309
309
  };
310
310
  },
311
- async connect({ metadata }) {
311
+ async connect({ metadata, cwd }) {
312
312
  const SandboxSDK = await loadSandboxSDK();
313
313
  const sdk = await SandboxSDK.get({
314
314
  sandboxId: metadata.sandboxId,
315
315
  ...getTestCredentials()
316
316
  });
317
- return new VercelSandboxInstance(sdk);
317
+ return new VercelSandboxInstance(sdk, cwd ?? void 0);
318
318
  }
319
319
  };
320
320
  }
@@ -322,4 +322,4 @@ function vercelSandbox(defaults) {
322
322
  export {
323
323
  vercelSandbox
324
324
  };
325
- //# 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(\n  defaults?: Partial<import(\"../adapter\").SandboxSetupFields> & {\n    run?: (sandbox: SandboxInstance) => Promise<void>;\n    config?: VercelBindingConfig;\n  }\n): SandboxBinding<\"vercel\", VercelBindingConfig, VercelBindingMetadata> {\n  return {\n    type: \"vercel\",\n    defaults,\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"]
}

325
+ //# 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(\n  defaults?: Partial<import(\"../adapter\").SandboxSetupFields> & {\n    run?: (sandbox: SandboxInstance) => Promise<void>;\n    config?: VercelBindingConfig;\n  }\n): SandboxBinding<\"vercel\", VercelBindingConfig, VercelBindingMetadata> {\n  return {\n    type: \"vercel\",\n    defaults,\n    async create({ cwd: createCwd, agent, setup, record, signal: _signal, log }) {\n      const storage = agent.storage;\n      const config = setup.config ?? {};\n      const cwd = config.cwd ?? createCwd ?? undefined;\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, cwd }) {\n      const SandboxSDK = await loadSandboxSDK();\n      const sdk = await SandboxSDK.get({\n        sandboxId: metadata.sandboxId,\n        ...getTestCredentials(),\n      });\n      return new VercelSandboxInstance(sdk, cwd ?? undefined);\n    },\n  };\n}\n"],
  "mappings": "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",
  "names": ["sdk", "instance"]
}

@@ -0,0 +1,38 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
8
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
9
+ }) : x)(function(x) {
10
+ if (typeof require !== "undefined") return require.apply(this, arguments);
11
+ throw Error('Dynamic require of "' + x + '" is not supported');
12
+ });
13
+ var __commonJS = (cb, mod) => function __require2() {
14
+ return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
15
+ };
16
+ var __copyProps = (to, from, except, desc) => {
17
+ if (from && typeof from === "object" || typeof from === "function") {
18
+ for (let key of __getOwnPropNames(from))
19
+ if (!__hasOwnProp.call(to, key) && key !== except)
20
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
21
+ }
22
+ return to;
23
+ };
24
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
25
+ // If the importer is in node compatibility mode or this is not an ESM
26
+ // file that has been converted to a CommonJS file using a Babel-
27
+ // compatible transform (i.e. "__esModule" has not been set), then set
28
+ // "default" to the CommonJS "module.exports" for node compatibility.
29
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
30
+ mod
31
+ ));
32
+
33
+ export {
34
+ __require,
35
+ __commonJS,
36
+ __toESM
37
+ };
38
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFtdLAogICJzb3VyY2VzQ29udGVudCI6IFtdLAogICJtYXBwaW5ncyI6ICIiLAogICJuYW1lcyI6IFtdCn0K
@@ -0,0 +1,9 @@
1
+ // src/rpc/base-path.ts
2
+ function basePathForAgent(agent) {
3
+ return `/api/agents/${agent}`;
4
+ }
5
+
6
+ export {
7
+ basePathForAgent
8
+ };
9
+ //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL3JwYy9iYXNlLXBhdGgudHMiXSwKICAic291cmNlc0NvbnRlbnQiOiBbImV4cG9ydCB0eXBlIEJhc2VQYXRoID0gYC9hcGkvYWdlbnRzL1thZ2VudF1gO1xuZXhwb3J0IHR5cGUgU2Vzc2lvblBhdGggPSBgJHtCYXNlUGF0aCB8IChzdHJpbmcgJiB7fSl9L1tzZXNzaW9uSWRdYDtcbmV4cG9ydCB0eXBlIFJlY29ubmVjdFBhdGggPSBgJHtTZXNzaW9uUGF0aCB8IChzdHJpbmcgJiB7fSl9L3JlY29ubmVjdGA7XG5leHBvcnQgdHlwZSBJbnRlcnJ1cHRQYXRoID0gYCR7U2Vzc2lvblBhdGggfCAoc3RyaW5nICYge30pfS9pbnRlcnJ1cHRgO1xuXG5leHBvcnQgdHlwZSBQYXRoID0gU2Vzc2lvblBhdGggfCBSZWNvbm5lY3RQYXRoIHwgSW50ZXJydXB0UGF0aDtcblxuZXhwb3J0IGZ1bmN0aW9uIGJhc2VQYXRoRm9yQWdlbnQoYWdlbnQ6IHN0cmluZykge1xuICByZXR1cm4gYC9hcGkvYWdlbnRzLyR7YWdlbnR9YCBhcyBjb25zdDtcbn1cbiJdLAogICJtYXBwaW5ncyI6ICI7QUFPTyxTQUFTLGlCQUFpQixPQUFlO0FBQzlDLFNBQU8sZUFBZSxLQUFLO0FBQzdCOyIsCiAgIm5hbWVzIjogW10KfQo=