computesdk 1.1.1 → 1.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 +3 -3
- package/dist/index.d.mts +68 -258
- package/dist/index.d.ts +68 -258
- package/dist/index.js +327 -708
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +324 -706
- package/dist/index.mjs.map +1 -1
- package/package.json +1 -1
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/sandbox.ts","../src/compute.ts","../src/request-handler.ts","../src/factory.ts"],"sourcesContent":["/**\n * ComputeSDK Core\n * \n * Clean Provider/Sandbox separation architecture with extensible compute.* API\n */\n\n// Export all types\nexport * from './types';\n\n// Export compute singleton - the main API\nexport { compute } from './compute';\n\n// Export request handler for web framework integration\nexport { handleComputeRequest } from './request-handler';\n\n// Export compute request/response types\nexport type { \n ComputeRequest, \n ComputeResponse, \n HandleComputeRequestParams \n} from './request-handler';\n\n// Export managers for advanced usage and testing\nexport { SandboxManager } from './sandbox';\n\n// Export provider factory for creating custom providers\nexport { createProvider } from './factory';\nexport type { ProviderConfig, SandboxMethods } from './factory';\nexport type { SandboxManagerMethods } from './types';\n\n// Test suite is available separately via @computesdk/test-utils package","/**\n * Sandbox Management - Provider-Centric Approach\n * \n * No registry - providers are the single source of truth\n */\n\nimport type { Sandbox, Provider, CreateSandboxOptions } from './types';\n\n/**\n * Sandbox manager - thin wrapper around provider APIs\n */\nexport class SandboxManager {\n /**\n * Create a sandbox from a provider\n */\n async create(provider: Provider, options?: CreateSandboxOptions): Promise<Sandbox> {\n // Provider creates and manages the sandbox - no local tracking\n return await provider.sandbox.create(options);\n }\n\n /**\n * Get an existing sandbox by ID from a provider\n */\n async getById(provider: Provider, sandboxId: string): Promise<Sandbox | null> {\n // Always fetch from provider API - provider is source of truth\n return await provider.sandbox.getById(sandboxId);\n }\n\n /**\n * List all active sandboxes from a provider\n */\n async list(provider: Provider): Promise<Sandbox[]> {\n // Always fetch from provider API - provider is source of truth\n return await provider.sandbox.list();\n }\n\n /**\n * Destroy a sandbox via a provider\n */\n async destroy(provider: Provider, sandboxId: string): Promise<void> {\n // Provider handles destruction - no local cleanup needed\n return await provider.sandbox.destroy(sandboxId);\n }\n}","/**\n * Compute Singleton - Main API Orchestrator\n * \n * Provides the unified compute.* API and delegates to specialized managers\n */\n\nimport type { ComputeAPI, CreateSandboxParams, CreateSandboxParamsWithOptionalProvider, ComputeConfig, Sandbox, Provider } from './types';\nimport { SandboxManager } from './sandbox';\n\n/**\n * Compute singleton implementation - orchestrates all compute operations\n */\nclass ComputeManager implements ComputeAPI {\n private sandboxManager = new SandboxManager();\n private config: ComputeConfig | null = null;\n\n /**\n * Set default configuration\n */\n setConfig(config: ComputeConfig): void {\n this.config = config;\n }\n\n /**\n * Get current configuration\n */\n getConfig(): ComputeConfig | null {\n return this.config;\n }\n\n /**\n * Clear current configuration\n */\n clearConfig(): void {\n this.config = null;\n }\n\n /**\n * Get the default provider, throwing if not configured\n */\n private getDefaultProvider(): Provider {\n if (!this.config?.provider) {\n throw new Error(\n 'No default provider configured. Either call compute.setConfig({ provider }) or pass provider explicitly.'\n );\n }\n return this.config.provider;\n }\n\n sandbox = {\n /**\n * Create a sandbox from a provider (or default provider if configured)\n * \n * @example\n * ```typescript\n * import { e2b } from '@computesdk/e2b'\n * import { compute } from 'computesdk'\n * \n * // With explicit provider\n * const sandbox = await compute.sandbox.create({\n * provider: e2b({ apiKey: 'your-key' })\n * })\n * \n * // With default provider (both forms work)\n * compute.setConfig({ provider: e2b({ apiKey: 'your-key' }) })\n * const sandbox1 = await compute.sandbox.create({})\n * const sandbox2 = await compute.sandbox.create()\n * ```\n */\n create: async (params?: CreateSandboxParams | CreateSandboxParamsWithOptionalProvider): Promise<Sandbox> => {\n const provider = params && 'provider' in params && params.provider ? params.provider : this.getDefaultProvider();\n const options = params?.options;\n return await this.sandboxManager.create(provider, options);\n },\n\n /**\n * Get an existing sandbox by ID from a provider (or default provider if configured)\n */\n getById: async (providerOrSandboxId: Provider | string, sandboxId?: string): Promise<Sandbox | null> => {\n if (typeof providerOrSandboxId === 'string') {\n // Called with just sandboxId, use default provider\n const provider = this.getDefaultProvider();\n return await this.sandboxManager.getById(provider, providerOrSandboxId);\n } else {\n // Called with provider and sandboxId\n if (!sandboxId) {\n throw new Error('sandboxId is required when provider is specified');\n }\n return await this.sandboxManager.getById(providerOrSandboxId, sandboxId);\n }\n },\n\n /**\n * List all active sandboxes from a provider (or default provider if configured)\n */\n list: async (provider?: Provider): Promise<Sandbox[]> => {\n const actualProvider = provider || this.getDefaultProvider();\n return await this.sandboxManager.list(actualProvider);\n },\n\n /**\n * Destroy a sandbox via a provider (or default provider if configured)\n */\n destroy: async (providerOrSandboxId: Provider | string, sandboxId?: string): Promise<void> => {\n if (typeof providerOrSandboxId === 'string') {\n // Called with just sandboxId, use default provider\n const provider = this.getDefaultProvider();\n return await this.sandboxManager.destroy(provider, providerOrSandboxId);\n } else {\n // Called with provider and sandboxId\n if (!sandboxId) {\n throw new Error('sandboxId is required when provider is specified');\n }\n return await this.sandboxManager.destroy(providerOrSandboxId, sandboxId);\n }\n }\n };\n\n // Future: compute.blob.*, compute.database.*, compute.git.* will be added here\n // blob = new BlobManager();\n // database = new DatabaseManager(); \n // git = new GitManager();\n\n /**\n * Get the sandbox manager (useful for testing)\n */\n getSandboxManager(): SandboxManager {\n return this.sandboxManager;\n }\n}\n\n/**\n * Singleton instance - the main API\n */\nexport const compute: ComputeAPI = new ComputeManager();\n\n","/**\n * Request Handler for Web Framework Integration\n * \n * Maps web requests to ComputeSDK operations with comprehensive support for:\n * - Sandbox management (create, destroy, getInfo)\n * - Code execution\n * - Filesystem operations\n * - Terminal operations\n */\n\nimport type { Provider, Runtime, Sandbox } from './types';\nimport { compute } from './compute';\n\n/**\n * Terminal callback manager for handling multiple SSE connections\n */\nclass TerminalCallbackManager {\n private static instance: TerminalCallbackManager;\n private callbacks = new Map<string, Map<string, (data: Uint8Array) => void>>();\n private terminals = new Map<string, any>();\n\n static getInstance(): TerminalCallbackManager {\n if (!TerminalCallbackManager.instance) {\n TerminalCallbackManager.instance = new TerminalCallbackManager();\n }\n return TerminalCallbackManager.instance;\n }\n\n /**\n * Add a callback for a terminal\n */\n addCallback(terminalId: string, connectionId: string, callback: (data: Uint8Array) => void, terminal: any): void {\n // Initialize terminal callbacks if not exists\n if (!this.callbacks.has(terminalId)) {\n this.callbacks.set(terminalId, new Map());\n this.terminals.set(terminalId, terminal);\n \n // Set up the master onData callback that broadcasts to all connections\n terminal.onData = (data: Uint8Array) => {\n const terminalCallbacks = this.callbacks.get(terminalId);\n if (terminalCallbacks) {\n terminalCallbacks.forEach(cb => {\n try {\n cb(data);\n } catch (error) {\n // Ignore errors from individual callbacks\n console.warn('Terminal callback error:', error);\n }\n });\n }\n };\n }\n\n // Add this connection's callback\n this.callbacks.get(terminalId)!.set(connectionId, callback);\n }\n\n /**\n * Remove a callback for a terminal\n */\n removeCallback(terminalId: string, connectionId: string): void {\n const terminalCallbacks = this.callbacks.get(terminalId);\n if (terminalCallbacks) {\n terminalCallbacks.delete(connectionId);\n \n // If no more callbacks, clean up the terminal's onData\n if (terminalCallbacks.size === 0) {\n const terminal = this.terminals.get(terminalId);\n if (terminal) {\n terminal.onData = undefined;\n }\n this.callbacks.delete(terminalId);\n this.terminals.delete(terminalId);\n }\n }\n }\n\n /**\n * Get number of active connections for a terminal\n */\n getConnectionCount(terminalId: string): number {\n return this.callbacks.get(terminalId)?.size || 0;\n }\n}\n\n/**\n * Extended request structure supporting all SDK capabilities\n */\nexport interface ComputeRequest {\n /** Type of operation to perform */\n action: \n // Sandbox operations\n | 'compute.sandbox.create' \n | 'compute.sandbox.destroy' \n | 'compute.sandbox.getInfo'\n | 'compute.sandbox.list'\n // Code execution\n | 'compute.sandbox.runCode'\n | 'compute.sandbox.runCommand'\n // Filesystem operations\n | 'compute.sandbox.filesystem.readFile'\n | 'compute.sandbox.filesystem.writeFile'\n | 'compute.sandbox.filesystem.mkdir'\n | 'compute.sandbox.filesystem.readdir'\n | 'compute.sandbox.filesystem.exists'\n | 'compute.sandbox.filesystem.remove'\n // Terminal operations\n | 'compute.sandbox.terminal.create'\n | 'compute.sandbox.terminal.getById'\n | 'compute.sandbox.terminal.list'\n | 'compute.sandbox.terminal.destroy'\n // Terminal I/O operations\n | 'compute.sandbox.terminal.write'\n | 'compute.sandbox.terminal.resize'\n | 'compute.sandbox.terminal.kill';\n\n /** Sandbox ID (required for operations on existing sandboxes) */\n sandboxId?: string;\n \n /** Code to execute (for runCode action) */\n code?: string;\n \n /** Command to run (for runCommand action) */\n command?: string;\n \n /** Command arguments (for runCommand action) */\n args?: string[];\n \n /** Runtime environment */\n runtime?: Runtime;\n \n /** File path (for filesystem operations) */\n path?: string;\n \n /** File content (for writeFile action) */\n content?: string;\n \n /** Terminal options (for terminal.create) */\n terminalOptions?: {\n command?: string;\n cols?: number;\n rows?: number;\n env?: Record<string, string>;\n };\n\n /** Terminal ID (for terminal operations) */\n terminalId?: string;\n\n /** Terminal input data (for terminal.write) */\n data?: string | Uint8Array;\n\n /** Terminal resize dimensions (for terminal.resize) */\n cols?: number;\n rows?: number;\n \n /** Additional sandbox creation options */\n options?: {\n runtime?: Runtime;\n timeout?: number;\n sandboxId?: string;\n };\n}\n\n/**\n * Response structure for compute operations\n */\nexport interface ComputeResponse {\n /** Whether the operation was successful */\n success: boolean;\n /** Error message if operation failed */\n error?: string;\n /** Sandbox ID involved in the operation */\n sandboxId: string;\n /** Provider that handled the operation */\n provider: string;\n \n /** Execution result (for runCode/runCommand actions) */\n result?: {\n stdout: string;\n stderr: string;\n exitCode: number;\n executionTime: number;\n };\n \n /** Sandbox info (for getInfo action) */\n info?: {\n id: string;\n provider: string;\n runtime: Runtime;\n status: string;\n createdAt: string;\n timeout: number;\n metadata?: Record<string, any>;\n };\n \n /** File content (for readFile action) */\n fileContent?: string;\n \n /** Directory listing (for readdir action) */\n files?: Array<{\n name: string;\n path: string;\n isDirectory: boolean;\n size: number;\n lastModified: string;\n }>;\n \n /** File/directory exists (for exists action) */\n exists?: boolean;\n \n /** Sandbox list (for list action) */\n sandboxes?: Array<{\n sandboxId: string;\n provider: string;\n }>;\n \n /** Terminal session (for terminal.create action) */\n terminal?: {\n pid: number;\n command: string;\n status: string;\n cols: number;\n rows: number;\n };\n \n /** Terminal sessions (for terminal.list action) */\n terminals?: Array<{\n pid: number;\n command: string;\n status: string;\n cols: number;\n rows: number;\n }>;\n\n /** WebSocket connection info (for terminal.connect action) */\n websocket?: {\n url: string;\n headers?: Record<string, string>;\n protocols?: string[];\n };\n}\n\n/**\n * Parameters for handleComputeRequest\n */\nexport interface HandleComputeRequestParams {\n /** The compute request to handle */\n request: ComputeRequest;\n /** Provider to use for the operation */\n provider: Provider;\n}\n\n/**\n * Parameters for handleHttpComputeRequest\n */\nexport interface HandleHttpComputeRequestParams {\n /** The HTTP request to handle */\n request: Request;\n /** Provider to use for the operation */\n provider: Provider;\n}\n\n/**\n * Handle HTTP compute requests with automatic SSE detection\n * \n * This is the main entry point for web frameworks. It automatically detects\n * different request types and routes them appropriately:\n * - GET with action=terminal.stream: Returns SSE stream for terminal output\n * - POST: Regular compute operations (including terminal I/O)\n * \n * @example\n * ```typescript\n * // Framework implementation (works for Next.js, Nuxt, SvelteKit, etc.)\n * export async function GET(request: Request) {\n * return handleHttpComputeRequest({\n * request,\n * provider: e2b({ apiKey: process.env.E2B_API_KEY })\n * });\n * }\n * \n * export async function POST(request: Request) {\n * return handleHttpComputeRequest({\n * request,\n * provider: e2b({ apiKey: process.env.E2B_API_KEY })\n * });\n * }\n * \n * // Client usage\n * // 1. Create terminal (HTTP POST)\n * fetch('/api/compute', {\n * method: 'POST',\n * body: JSON.stringify({ action: 'compute.sandbox.terminal.create', sandboxId: '123' })\n * });\n * \n * // 2. Stream terminal output (EventSource GET)\n * const eventSource = new EventSource('/api/compute?action=terminal.stream&terminalId=456');\n * eventSource.onmessage = (event) => xtermInstance.write(JSON.parse(event.data));\n * \n * // 3. Send terminal input (HTTP POST)\n * fetch('/api/compute', {\n * method: 'POST',\n * body: JSON.stringify({ action: 'compute.sandbox.terminal.write', terminalId: '456', data: 'ls -la\\n' })\n * });\n * ```\n */\nexport async function handleHttpComputeRequest(params: HandleHttpComputeRequestParams): Promise<Response> {\n const { request, provider } = params;\n \n // Handle GET requests (SSE streaming)\n if (request.method === 'GET') {\n const url = new URL(request.url);\n const action = url.searchParams.get('action');\n \n if (action === 'terminal.stream') {\n return handleTerminalStream(request, provider);\n }\n \n // Other GET requests not supported\n return Response.json({\n success: false,\n error: 'GET requests only supported for terminal.stream action',\n sandboxId: '',\n provider: provider.name\n }, { status: 400 });\n }\n \n // Handle POST requests (regular compute operations)\n try {\n const body = await request.json();\n const computeRequest = body as ComputeRequest;\n \n // Use existing handleComputeRequest function\n const response = await handleComputeRequest({\n request: computeRequest,\n provider\n });\n \n return Response.json(response);\n \n } catch (error) {\n return Response.json({\n success: false,\n error: error instanceof Error ? error.message : 'Invalid request format',\n sandboxId: '',\n provider: provider.name\n }, { status: 400 });\n }\n}\n\n/**\n * Handle terminal SSE streaming\n */\nasync function handleTerminalStream(request: Request, provider: Provider): Promise<Response> {\n const url = new URL(request.url);\n const sandboxId = url.searchParams.get('sandboxId');\n const terminalId = url.searchParams.get('terminalId');\n \n if (!sandboxId || !terminalId) {\n return Response.json({\n success: false,\n error: 'sandboxId and terminalId are required for terminal streaming',\n sandboxId: sandboxId || '',\n provider: provider.name\n }, { status: 400 });\n }\n \n try {\n // Get the sandbox and terminal\n const sandbox = await compute.sandbox.getById(provider, sandboxId);\n if (!sandbox) {\n return Response.json({\n success: false,\n error: `Sandbox with ID ${sandboxId} not found`,\n sandboxId,\n provider: provider.name\n }, { status: 404 });\n }\n \n const terminal = await sandbox.terminal.getById(terminalId);\n if (!terminal) {\n return Response.json({\n success: false,\n error: `Terminal with ID ${terminalId} not found`,\n sandboxId,\n provider: provider.name\n }, { status: 404 });\n }\n \n // Generate unique connection ID\n const connectionId = `${Date.now()}-${Math.random().toString(36).substring(2, 11)}`;\n const callbackManager = TerminalCallbackManager.getInstance();\n \n // Create SSE stream\n const stream = new ReadableStream({\n start(controller) {\n // Set up callback for this connection\n const callback = (data: Uint8Array) => {\n const dataArray = Array.from(data);\n const sseData = `data: ${JSON.stringify(dataArray)}\\n\\n`;\n controller.enqueue(new TextEncoder().encode(sseData));\n };\n \n // Register callback with manager\n callbackManager.addCallback(terminalId, connectionId, callback, terminal);\n \n // Send initial connection message\n const connectMsg = `data: ${JSON.stringify({ \n type: 'connected', \n terminalId, \n connectionId,\n activeConnections: callbackManager.getConnectionCount(terminalId)\n })}\\n\\n`;\n controller.enqueue(new TextEncoder().encode(connectMsg));\n },\n \n cancel() {\n // Clean up this connection's callback\n callbackManager.removeCallback(terminalId, connectionId);\n }\n });\n \n return new Response(stream, {\n headers: {\n 'Content-Type': 'text/event-stream',\n 'Cache-Control': 'no-cache',\n 'Connection': 'keep-alive',\n 'Access-Control-Allow-Origin': '*',\n 'Access-Control-Allow-Headers': 'Cache-Control'\n }\n });\n \n } catch (error) {\n return Response.json({\n success: false,\n error: error instanceof Error ? error.message : 'Failed to create terminal stream',\n sandboxId,\n provider: provider.name\n }, { status: 500 });\n }\n}\n\n/**\n * Handle a compute request - unified API for web frameworks\n * \n * Maps web requests to ComputeSDK operations with full support for:\n * - All sandbox operations via compute.sandbox.*\n * - All filesystem operations via sandbox.filesystem.*\n * - All terminal operations via sandbox.terminal.*\n * \n * @example\n * ```typescript\n * // Execute code\n * const response = await handleComputeRequest({\n * request: { \n * action: 'sandbox.runCode', \n * code: 'print(\"hello\")',\n * sandboxId: 'existing-sandbox-id' // optional, creates new if not provided\n * },\n * provider: e2b({ apiKey: process.env.E2B_API_KEY })\n * });\n * \n * // Filesystem operations\n * const response = await handleComputeRequest({\n * request: { \n * action: 'filesystem.writeFile', \n * sandboxId: 'sandbox-id',\n * path: '/tmp/hello.py',\n * content: 'print(\"Hello from file!\")'\n * },\n * provider: e2b({ apiKey: process.env.E2B_API_KEY })\n * });\n * ```\n */\nexport async function handleComputeRequest(params: HandleComputeRequestParams): Promise<ComputeResponse> {\n const { request, provider } = params;\n \n try {\n // Helper function to get or create sandbox\n const getSandbox = async (sandboxId?: string): Promise<Sandbox> => {\n if (sandboxId) {\n const existingSandbox = await compute.sandbox.getById(provider, sandboxId);\n if (!existingSandbox) {\n throw new Error(`Sandbox with ID ${sandboxId} not found`);\n }\n return existingSandbox;\n } else {\n // Create new sandbox\n return await compute.sandbox.create({\n provider,\n options: request.options || { runtime: 'python' }\n });\n }\n };\n\n switch (request.action) {\n // Sandbox operations\n case 'compute.sandbox.create': {\n const sandbox = await compute.sandbox.create({\n provider,\n options: request.options || { runtime: 'python' }\n });\n\n return {\n success: true,\n sandboxId: sandbox.sandboxId,\n provider: provider.name\n };\n }\n\n case 'compute.sandbox.destroy': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for destroy action',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n await compute.sandbox.destroy(provider, request.sandboxId);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n case 'compute.sandbox.getInfo': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for getInfo action',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const info = await sandbox.getInfo();\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name,\n info: {\n id: info.id,\n provider: info.provider,\n runtime: info.runtime,\n status: info.status,\n createdAt: info.createdAt.toISOString(),\n timeout: info.timeout,\n metadata: info.metadata\n }\n };\n }\n\n case 'compute.sandbox.list': {\n const sandboxes = await compute.sandbox.list(provider);\n \n return {\n success: true,\n sandboxId: '',\n provider: provider.name,\n sandboxes: sandboxes.map(sandbox => ({\n sandboxId: sandbox.sandboxId,\n provider: sandbox.provider\n }))\n };\n }\n\n // Code execution\n case 'compute.sandbox.runCode': {\n if (!request.code) {\n return {\n success: false,\n error: 'Code is required for runCode action',\n sandboxId: request.sandboxId || '',\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const result = await sandbox.runCode(request.code, request.runtime);\n \n return {\n success: true,\n sandboxId: sandbox.sandboxId,\n provider: provider.name,\n result: {\n stdout: result.stdout,\n stderr: result.stderr,\n exitCode: result.exitCode,\n executionTime: result.executionTime\n }\n };\n }\n\n case 'compute.sandbox.runCommand': {\n if (!request.command) {\n return {\n success: false,\n error: 'Command is required for runCommand action',\n sandboxId: request.sandboxId || '',\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const result = await sandbox.runCommand(request.command, request.args);\n \n return {\n success: true,\n sandboxId: sandbox.sandboxId,\n provider: provider.name,\n result: {\n stdout: result.stdout,\n stderr: result.stderr,\n exitCode: result.exitCode,\n executionTime: result.executionTime\n }\n };\n }\n\n // Filesystem operations\n case 'compute.sandbox.filesystem.readFile': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for filesystem operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.path) {\n return {\n success: false,\n error: 'File path is required for readFile action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const content = await sandbox.filesystem.readFile(request.path);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name,\n fileContent: content\n };\n }\n\n case 'compute.sandbox.filesystem.writeFile': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for filesystem operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.path) {\n return {\n success: false,\n error: 'File path is required for writeFile action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n if (request.content === undefined) {\n return {\n success: false,\n error: 'File content is required for writeFile action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n await sandbox.filesystem.writeFile(request.path, request.content);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n case 'compute.sandbox.filesystem.mkdir': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for filesystem operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.path) {\n return {\n success: false,\n error: 'Directory path is required for mkdir action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n await sandbox.filesystem.mkdir(request.path);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n case 'compute.sandbox.filesystem.readdir': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for filesystem operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.path) {\n return {\n success: false,\n error: 'Directory path is required for readdir action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const entries = await sandbox.filesystem.readdir(request.path);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name,\n files: entries.map(entry => ({\n name: entry.name,\n path: entry.path,\n isDirectory: entry.isDirectory,\n size: entry.size,\n lastModified: entry.lastModified.toISOString()\n }))\n };\n }\n\n case 'compute.sandbox.filesystem.exists': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for filesystem operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.path) {\n return {\n success: false,\n error: 'Path is required for exists action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const exists = await sandbox.filesystem.exists(request.path);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name,\n exists\n };\n }\n\n case 'compute.sandbox.filesystem.remove': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for filesystem operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.path) {\n return {\n success: false,\n error: 'Path is required for remove action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n await sandbox.filesystem.remove(request.path);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n // Terminal operations\n case 'compute.sandbox.terminal.create': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for terminal operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const terminal = await sandbox.terminal.create(request.terminalOptions);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name,\n terminal: {\n pid: terminal.pid,\n command: terminal.command,\n status: terminal.status,\n cols: terminal.cols,\n rows: terminal.rows\n }\n };\n }\n\n case 'compute.sandbox.terminal.list': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for terminal operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const terminals = await sandbox.terminal.list();\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name,\n terminals: terminals.map(terminal => ({\n pid: terminal.pid,\n command: terminal.command,\n status: terminal.status,\n cols: terminal.cols,\n rows: terminal.rows\n }))\n };\n }\n\n case 'compute.sandbox.terminal.getById': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for terminal operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.terminalId) {\n return {\n success: false,\n error: 'Terminal ID is required for getById action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const terminal = await sandbox.terminal.getById(request.terminalId);\n \n if (!terminal) {\n return {\n success: false,\n error: `Terminal with ID ${request.terminalId} not found`,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name,\n terminal: {\n pid: terminal.pid,\n command: terminal.command,\n status: terminal.status,\n cols: terminal.cols,\n rows: terminal.rows\n }\n };\n }\n\n case 'compute.sandbox.terminal.destroy': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for terminal operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.terminalId) {\n return {\n success: false,\n error: 'Terminal ID is required for destroy action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n await sandbox.terminal.destroy(request.terminalId);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n // Terminal I/O operations\n case 'compute.sandbox.terminal.write': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for terminal operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.terminalId) {\n return {\n success: false,\n error: 'Terminal ID is required for write action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n if (!request.data) {\n return {\n success: false,\n error: 'Data is required for write action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const terminal = await sandbox.terminal.getById(request.terminalId);\n \n if (!terminal) {\n return {\n success: false,\n error: `Terminal with ID ${request.terminalId} not found`,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n await terminal.write(request.data);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n case 'compute.sandbox.terminal.resize': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for terminal operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.terminalId) {\n return {\n success: false,\n error: 'Terminal ID is required for resize action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n if (!request.cols || !request.rows) {\n return {\n success: false,\n error: 'Cols and rows are required for resize action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const terminal = await sandbox.terminal.getById(request.terminalId);\n \n if (!terminal) {\n return {\n success: false,\n error: `Terminal with ID ${request.terminalId} not found`,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n await terminal.resize(request.cols, request.rows);\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n case 'compute.sandbox.terminal.kill': {\n if (!request.sandboxId) {\n return {\n success: false,\n error: 'Sandbox ID is required for terminal operations',\n sandboxId: '',\n provider: provider.name\n };\n }\n\n if (!request.terminalId) {\n return {\n success: false,\n error: 'Terminal ID is required for kill action',\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n const sandbox = await getSandbox(request.sandboxId);\n const terminal = await sandbox.terminal.getById(request.terminalId);\n \n if (!terminal) {\n return {\n success: false,\n error: `Terminal with ID ${request.terminalId} not found`,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n await terminal.kill();\n \n return {\n success: true,\n sandboxId: request.sandboxId,\n provider: provider.name\n };\n }\n\n default:\n return {\n success: false,\n error: `Unknown action: ${(request as any).action}`,\n sandboxId: request.sandboxId || '',\n provider: provider.name\n };\n }\n } catch (error) {\n return {\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n sandboxId: request.sandboxId || '',\n provider: provider.name\n };\n }\n}\n\n/**\n * Handle WebSocket upgrade requests for real-time terminal I/O\n * \n * TODO: Implement WebSocket terminal connections\n * \n * This function should:\n * 1. Parse WebSocket upgrade request (sandboxId, terminalId from URL/headers)\n * 2. Validate the terminal session exists\n * 3. Upgrade HTTP connection to WebSocket\n * 4. Establish bidirectional proxy to provider's WebSocket\n * 5. Handle connection lifecycle (connect, disconnect, error)\n * \n * @example\n * ```typescript\n * // Framework usage (Next.js)\n * export async function GET(request: Request) {\n * if (request.headers.get('upgrade') === 'websocket') {\n * return handleComputeWebSocket(request, { provider })\n * }\n * return handleComputeRequest({ request, provider })\n * }\n * \n * // Frontend usage\n * const ws = new WebSocket('/api/compute?action=terminal.connect&sandboxId=123&terminalId=456')\n * ws.onmessage = (event) => console.log(event.data)\n * ws.send('ls -la\\n')\n * ```\n * \n * @param request - WebSocket upgrade request\n * @param params - Handler parameters (provider, etc.)\n * @returns WebSocket upgrade response\n */\nexport async function handleComputeWebSocket(\n _request: Request,\n _params: HandleComputeRequestParams\n): Promise<Response> {\n // TODO: Implement WebSocket terminal connections\n // This is a placeholder for future implementation\n \n return new Response('WebSocket terminal connections not yet implemented', {\n status: 501,\n statusText: 'Not Implemented'\n });\n}","/**\n * Provider Factory - Creates providers from method definitions\n * \n * Eliminates boilerplate by auto-generating Provider/Sandbox classes\n * from simple method definitions with automatic feature detection.\n */\n\nimport type {\n Provider,\n ProviderSandboxManager,\n Sandbox,\n SandboxFileSystem,\n SandboxTerminal,\n SandboxInfo,\n ExecutionResult,\n Runtime,\n CreateSandboxOptions,\n FileEntry,\n TerminalSession,\n TerminalCreateOptions,\n} from './types/index.js';\n\n/**\n * Flat sandbox method implementations - all operations in one place\n */\nexport interface SandboxMethods<TSandbox = any, TConfig = any> {\n // Collection operations (map to compute.sandbox.*)\n create: (config: TConfig, options?: CreateSandboxOptions) => Promise<{ sandbox: TSandbox; sandboxId: string }>;\n getById: (config: TConfig, sandboxId: string) => Promise<{ sandbox: TSandbox; sandboxId: string } | null>;\n list: (config: TConfig) => Promise<Array<{ sandbox: TSandbox; sandboxId: string }>>;\n destroy: (config: TConfig, sandboxId: string) => Promise<void>;\n \n // Instance operations (map to individual Sandbox methods)\n runCode: (sandbox: TSandbox, code: string, runtime?: Runtime, config?: TConfig) => Promise<ExecutionResult>;\n runCommand: (sandbox: TSandbox, command: string, args?: string[]) => Promise<ExecutionResult>;\n getInfo: (sandbox: TSandbox) => Promise<SandboxInfo>;\n \n // Optional filesystem methods\n filesystem?: {\n readFile: (sandbox: TSandbox, path: string) => Promise<string>;\n writeFile: (sandbox: TSandbox, path: string, content: string) => Promise<void>;\n mkdir: (sandbox: TSandbox, path: string) => Promise<void>;\n readdir: (sandbox: TSandbox, path: string) => Promise<FileEntry[]>;\n exists: (sandbox: TSandbox, path: string) => Promise<boolean>;\n remove: (sandbox: TSandbox, path: string) => Promise<void>;\n };\n \n // Optional terminal methods\n terminal?: {\n create: (sandbox: TSandbox, options?: TerminalCreateOptions) => Promise<{ terminal: any; terminalId: string }>;\n getById: (sandbox: TSandbox, terminalId: string) => Promise<{ terminal: any; terminalId: string } | null>;\n list: (sandbox: TSandbox) => Promise<Array<{ terminal: any; terminalId: string }>>;\n destroy: (sandbox: TSandbox, terminalId: string) => Promise<void>;\n // Terminal instance methods\n write: (sandbox: TSandbox, terminal: any, data: Uint8Array | string) => Promise<void>;\n resize: (sandbox: TSandbox, terminal: any, cols: number, rows: number) => Promise<void>;\n kill: (sandbox: TSandbox, terminal: any) => Promise<void>;\n };\n}\n\n/**\n * Provider configuration for createProvider()\n */\nexport interface ProviderConfig<TSandbox = any, TConfig = any> {\n name: string;\n methods: {\n sandbox: SandboxMethods<TSandbox, TConfig>;\n };\n}\n\n/**\n * Auto-generated filesystem implementation that throws \"not supported\" errors\n */\nclass UnsupportedFileSystem implements SandboxFileSystem {\n private readonly providerName: string;\n\n constructor(providerName: string) {\n this.providerName = providerName;\n }\n\n async readFile(_path: string): Promise<string> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async writeFile(_path: string, _content: string): Promise<void> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async mkdir(_path: string): Promise<void> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async readdir(_path: string): Promise<FileEntry[]> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async exists(_path: string): Promise<boolean> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async remove(_path: string): Promise<void> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n}\n\n/**\n * Auto-generated terminal implementation that throws \"not supported\" errors\n */\nclass UnsupportedTerminal implements SandboxTerminal {\n private readonly providerName: string;\n\n constructor(providerName: string) {\n this.providerName = providerName;\n }\n\n async create(_options?: TerminalCreateOptions): Promise<TerminalSession> {\n throw new Error(`Terminal operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async getById(_terminalId: string): Promise<TerminalSession | null> {\n throw new Error(`Terminal operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async list(): Promise<TerminalSession[]> {\n throw new Error(`Terminal operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async destroy(_terminalId: string): Promise<void> {\n throw new Error(`Terminal operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n}\n\n/**\n * Auto-generated filesystem implementation that wraps provider methods\n */\nclass SupportedFileSystem<TSandbox> implements SandboxFileSystem {\n constructor(\n private sandbox: TSandbox,\n private methods: NonNullable<SandboxMethods<TSandbox>['filesystem']>\n ) {}\n\n async readFile(path: string): Promise<string> {\n return this.methods.readFile(this.sandbox, path);\n }\n\n async writeFile(path: string, content: string): Promise<void> {\n return this.methods.writeFile(this.sandbox, path, content);\n }\n\n async mkdir(path: string): Promise<void> {\n return this.methods.mkdir(this.sandbox, path);\n }\n\n async readdir(path: string): Promise<FileEntry[]> {\n return this.methods.readdir(this.sandbox, path);\n }\n\n async exists(path: string): Promise<boolean> {\n return this.methods.exists(this.sandbox, path);\n }\n\n async remove(path: string): Promise<void> {\n return this.methods.remove(this.sandbox, path);\n }\n}\n\n/**\n * Generated terminal session class - implements the TerminalSession interface\n */\nclass GeneratedTerminalSession<TSandbox = any> implements TerminalSession {\n readonly pid: number;\n readonly command: string;\n readonly status: 'running' | 'exited';\n readonly cols: number;\n readonly rows: number;\n onData?: (data: Uint8Array) => void;\n onExit?: (exitCode: number) => void;\n\n constructor(\n private terminal: any,\n private sandbox: TSandbox,\n private methods: NonNullable<SandboxMethods<TSandbox>['terminal']>,\n terminalId: string,\n command: string,\n cols: number = 80,\n rows: number = 24\n ) {\n this.pid = parseInt(terminalId);\n this.command = command;\n this.status = 'running';\n this.cols = cols;\n this.rows = rows;\n }\n\n async write(data: Uint8Array | string): Promise<void> {\n return this.methods.write(this.sandbox, this.terminal, data);\n }\n\n async resize(cols: number, rows: number): Promise<void> {\n return this.methods.resize(this.sandbox, this.terminal, cols, rows);\n }\n\n async kill(): Promise<void> {\n return this.methods.kill(this.sandbox, this.terminal);\n }\n}\n\n/**\n * Auto-generated terminal implementation that wraps provider methods\n */\nclass SupportedTerminal<TSandbox> implements SandboxTerminal {\n constructor(\n private sandbox: TSandbox,\n private methods: NonNullable<SandboxMethods<TSandbox>['terminal']>\n ) {}\n\n async create(options?: TerminalCreateOptions): Promise<TerminalSession> {\n // Create a GeneratedTerminalSession first so we can set up callback forwarding\n let terminalSession: GeneratedTerminalSession<TSandbox>;\n \n // Create options with callback forwarding to the GeneratedTerminalSession\n const createOptions: TerminalCreateOptions = {\n ...options,\n onData: (data: Uint8Array) => {\n // Forward to the GeneratedTerminalSession's onData if set\n if (terminalSession?.onData) {\n terminalSession.onData(data);\n }\n },\n onExit: (exitCode: number) => {\n // Forward to the GeneratedTerminalSession's onExit if set\n if (terminalSession?.onExit) {\n terminalSession.onExit(exitCode);\n }\n }\n };\n\n const result = await this.methods.create(this.sandbox, createOptions);\n \n // Now create the GeneratedTerminalSession\n terminalSession = new GeneratedTerminalSession(\n result.terminal,\n this.sandbox,\n this.methods,\n result.terminalId,\n options?.command || 'bash',\n options?.cols || 80,\n options?.rows || 24\n );\n\n // Set the original callbacks on the terminal session\n terminalSession.onData = options?.onData;\n terminalSession.onExit = options?.onExit;\n\n return terminalSession;\n }\n\n async getById(terminalId: string): Promise<TerminalSession | null> {\n const result = await this.methods.getById(this.sandbox, terminalId);\n if (!result) return null;\n \n return new GeneratedTerminalSession(\n result.terminal,\n this.sandbox,\n this.methods,\n result.terminalId,\n 'bash', // Default command for existing terminals\n 80, // Default cols\n 24 // Default rows\n );\n }\n\n async list(): Promise<TerminalSession[]> {\n const results = await this.methods.list(this.sandbox);\n return results.map(result => new GeneratedTerminalSession(\n result.terminal,\n this.sandbox,\n this.methods,\n result.terminalId,\n 'bash', // Default command\n 80, // Default cols\n 24 // Default rows\n ));\n }\n\n async destroy(terminalId: string): Promise<void> {\n return this.methods.destroy(this.sandbox, terminalId);\n }\n}\n\n/**\n * Generated sandbox class - implements the Sandbox interface\n */\nclass GeneratedSandbox<TSandbox = any> implements Sandbox {\n readonly sandboxId: string;\n readonly provider: string;\n readonly filesystem: SandboxFileSystem;\n readonly terminal: SandboxTerminal;\n\n constructor(\n private sandbox: TSandbox,\n sandboxId: string,\n providerName: string,\n private methods: SandboxMethods<TSandbox>,\n private config: any,\n private destroyMethod: (config: any, sandboxId: string) => Promise<void>\n ) {\n this.sandboxId = sandboxId;\n this.provider = providerName;\n\n // Auto-detect filesystem support\n if (methods.filesystem) {\n this.filesystem = new SupportedFileSystem(sandbox, methods.filesystem);\n } else {\n this.filesystem = new UnsupportedFileSystem(providerName);\n }\n\n // Auto-detect terminal support\n if (methods.terminal) {\n this.terminal = new SupportedTerminal(sandbox, methods.terminal);\n } else {\n this.terminal = new UnsupportedTerminal(providerName);\n }\n }\n\n async runCode(code: string, runtime?: Runtime): Promise<ExecutionResult> {\n return await this.methods.runCode(this.sandbox, code, runtime, this.config);\n }\n\n async runCommand(command: string, args?: string[]): Promise<ExecutionResult> {\n return await this.methods.runCommand(this.sandbox, command, args);\n }\n\n async getInfo(): Promise<SandboxInfo> {\n return await this.methods.getInfo(this.sandbox);\n }\n\n async kill(): Promise<void> {\n // For backward compatibility, kill() delegates to destroy()\n await this.destroy();\n }\n\n async destroy(): Promise<void> {\n // Destroy via the provider's destroy method using our sandboxId\n await this.destroyMethod(this.config, this.sandboxId);\n }\n}\n\n/**\n * Auto-generated Sandbox Manager implementation\n */\nclass GeneratedSandboxManager<TSandbox, TConfig> implements ProviderSandboxManager {\n private activeSandboxes: Map<string, GeneratedSandbox<TSandbox>> = new Map();\n\n constructor(\n private config: TConfig,\n private providerName: string,\n private methods: SandboxMethods<TSandbox, TConfig>\n ) {}\n\n async create(options?: CreateSandboxOptions): Promise<Sandbox> {\n const result = await this.methods.create(this.config, options);\n const sandbox = new GeneratedSandbox(\n result.sandbox,\n result.sandboxId,\n this.providerName,\n this.methods,\n this.config,\n this.methods.destroy\n );\n \n this.activeSandboxes.set(result.sandboxId, sandbox);\n return sandbox;\n }\n\n async getById(sandboxId: string): Promise<Sandbox | null> {\n // Check active sandboxes first\n const existing = this.activeSandboxes.get(sandboxId);\n if (existing) {\n return existing;\n }\n\n // Try to reconnect\n const result = await this.methods.getById(this.config, sandboxId);\n if (!result) {\n return null;\n }\n\n const sandbox = new GeneratedSandbox(\n result.sandbox,\n result.sandboxId,\n this.providerName,\n this.methods,\n this.config,\n this.methods.destroy\n );\n \n this.activeSandboxes.set(result.sandboxId, sandbox);\n return sandbox;\n }\n\n async list(): Promise<Sandbox[]> {\n const results = await this.methods.list(this.config);\n const sandboxes: Sandbox[] = [];\n\n for (const result of results) {\n let sandbox = this.activeSandboxes.get(result.sandboxId);\n if (!sandbox) {\n sandbox = new GeneratedSandbox(\n result.sandbox,\n result.sandboxId,\n this.providerName,\n this.methods,\n this.config,\n this.methods.destroy\n );\n this.activeSandboxes.set(result.sandboxId, sandbox);\n }\n sandboxes.push(sandbox);\n }\n\n return sandboxes;\n }\n\n async destroy(sandboxId: string): Promise<void> {\n await this.methods.destroy(this.config, sandboxId);\n this.activeSandboxes.delete(sandboxId);\n }\n}\n\n/**\n * Auto-generated Provider implementation\n */\nclass GeneratedProvider<TSandbox, TConfig> implements Provider {\n readonly name: string;\n readonly sandbox: ProviderSandboxManager;\n\n constructor(config: TConfig, providerConfig: ProviderConfig<TSandbox, TConfig>) {\n this.name = providerConfig.name;\n this.sandbox = new GeneratedSandboxManager(\n config,\n providerConfig.name,\n providerConfig.methods.sandbox\n );\n }\n}\n\n/**\n * Create a provider from method definitions\n * \n * Auto-generates all boilerplate classes and provides feature detection\n * based on which methods are implemented.\n */\nexport function createProvider<TSandbox, TConfig>(\n providerConfig: ProviderConfig<TSandbox, TConfig>\n): (config: TConfig) => Provider {\n return (config: TConfig) => {\n return new GeneratedProvider(config, providerConfig);\n };\n}"],"mappings":"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","names":[]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/types/sandbox.ts","../src/compute.ts","../src/request-handler.ts","../src/factory.ts"],"sourcesContent":["/**\n * ComputeSDK Core\n * \n * Clean Provider/Sandbox separation architecture with extensible compute.* API\n */\n\n// Export all types\nexport * from './types';\n\n// Export compute singleton - the main API\nexport { compute } from './compute';\n\n// Export request handler for web framework integration\nexport { handleComputeRequest } from './request-handler';\n\n// Export compute request/response types\nexport type {\n ComputeRequest,\n ComputeResponse,\n HandleComputeRequestParams\n} from './request-handler';\n\n\n\n// Export provider factory for creating custom providers\nexport { createProvider } from './factory';\nexport type { ProviderConfig, SandboxMethods } from './factory';\n\n// Export error handling utilities (explicitly for clarity)\nexport { CommandExitError, isCommandExitError } from './types/sandbox';\n\n// Test suite is available separately via @computesdk/test-utils package\n","/**\n * Sandbox Types\n * \n * Types related to sandbox execution, filesystem, terminal operations\n */\n\n// Forward declaration to avoid circular dependency\ninterface Provider {\n readonly name: string;\n readonly sandbox: any; // Will be properly typed when imported together\n}\n\n/**\n * Supported runtime environments\n */\nexport type Runtime = 'node' | 'python';\n\n/**\n * Sandbox status types\n */\nexport type SandboxStatus = 'running' | 'stopped' | 'error';\n\n/**\n * Result of code execution\n */\nexport interface ExecutionResult {\n /** Standard output from the execution */\n stdout: string;\n /** Standard error from the execution */\n stderr: string;\n /** Exit code from the execution */\n exitCode: number;\n /** Time taken for execution in milliseconds */\n executionTime: number;\n /** ID of the sandbox where the code was executed */\n sandboxId: string;\n /** Provider that executed the code */\n provider: string;\n}\n\n/**\n * Information about a sandbox\n */\nexport interface SandboxInfo {\n /** Unique identifier for the sandbox */\n id: string;\n /** Provider hosting the sandbox */\n provider: string;\n /** Runtime environment in the sandbox */\n runtime: Runtime;\n /** Current status of the sandbox */\n status: SandboxStatus;\n /** When the sandbox was created */\n createdAt: Date;\n /** Execution timeout in milliseconds */\n timeout: number;\n /** Additional provider-specific metadata */\n metadata?: Record<string, any>;\n}\n\n/**\n * Options for creating a sandbox\n */\nexport interface CreateSandboxOptions {\n /** Runtime environment */\n runtime?: Runtime;\n /** Execution timeout in milliseconds */\n timeout?: number;\n /** Custom sandbox ID (if supported by provider) */\n sandboxId?: string;\n /** Template ID for sandbox creation (provider-specific) */\n templateId?: string;\n /** Additional metadata for the sandbox */\n metadata?: Record<string, any>;\n /** Domain for sandbox connection (provider-specific) */\n domain?: string;\n /** Environment variables for the sandbox */\n envs?: Record<string, string>;\n}\n\n/**\n * File system entry information\n */\nexport interface FileEntry {\n /** File/directory name */\n name: string;\n /** Full path to the entry */\n path: string;\n /** Whether this is a directory */\n isDirectory: boolean;\n /** File size in bytes (0 for directories) */\n size: number;\n /** Last modified timestamp */\n lastModified: Date;\n}\n\n/**\n * File system interface for sandbox operations\n */\nexport interface SandboxFileSystem {\n /** Read file contents */\n readFile(path: string): Promise<string>;\n /** Write file contents */\n writeFile(path: string, content: string): Promise<void>;\n /** Create directory */\n mkdir(path: string): Promise<void>;\n /** List directory contents */\n readdir(path: string): Promise<FileEntry[]>;\n /** Check if file/directory exists */\n exists(path: string): Promise<boolean>;\n /** Remove file or directory */\n remove(path: string): Promise<void>;\n}\n\n/**\n * Error thrown when a command exits with a non-zero status\n */\nexport class CommandExitError extends Error {\n name = 'CommandExitError';\n constructor(public result: {\n exitCode: number;\n stdout: string;\n stderr: string;\n error: boolean;\n }) {\n super(`Command exited with code ${result.exitCode}`);\n }\n}\n\n/**\n * Type guard to check if an error is a CommandExitError\n */\nexport function isCommandExitError(error: unknown): error is CommandExitError {\n return (\n typeof error === 'object' &&\n error !== null &&\n 'name' in error &&\n error.name === 'CommandExitError' &&\n 'result' in error\n );\n}\n\n\n\n\n\n/**\n * Base sandbox interface - what developers interact with\n */\nexport interface Sandbox {\n /** Unique identifier for the sandbox */\n readonly sandboxId: string;\n /** Provider that created this sandbox */\n readonly provider: string;\n\n /** Execute code in the sandbox */\n runCode(code: string, runtime?: Runtime): Promise<ExecutionResult>;\n /** Execute shell commands */\n runCommand(command: string, args?: string[]): Promise<ExecutionResult>;\n /** Get information about the sandbox */\n getInfo(): Promise<SandboxInfo>;\n /** Get URL for accessing the sandbox on a specific port */\n getUrl(options: { port: number; protocol?: string }): Promise<string>;\n /** Get the provider instance that created this sandbox */\n getProvider(): Provider;\n /** Get the native provider sandbox instance with proper typing */\n getInstance<T = unknown>(): T;\n /** Kill the sandbox */\n kill(): Promise<void>;\n /** Destroy the sandbox and clean up resources */\n destroy(): Promise<void>;\n\n /** File system operations */\n readonly filesystem: SandboxFileSystem;\n}","/**\n * Compute Singleton - Main API Orchestrator\n * \n * Provides the unified compute.* API and delegates to specialized managers\n */\n\nimport type { ComputeAPI, CreateSandboxParams, CreateSandboxParamsWithOptionalProvider, ComputeConfig, Sandbox, Provider } from './types';\n\n/**\n * Compute singleton implementation - orchestrates all compute operations\n */\nclass ComputeManager implements ComputeAPI {\n private config: ComputeConfig | null = null;\n\n /**\n * Set default configuration\n */\n setConfig(config: ComputeConfig): void {\n // Validate that at least one provider is specified\n if (!config.defaultProvider && !config.provider) {\n throw new Error('Either defaultProvider or provider must be specified in setConfig');\n }\n \n // Handle backwards compatibility: if both are provided, defaultProvider takes precedence\n if (config.defaultProvider && config.provider) {\n console.warn('Both defaultProvider and provider specified in setConfig. Using defaultProvider. The provider key is deprecated, please use defaultProvider instead.');\n }\n \n // Normalize config to always have provider for internal use (for backwards compatibility)\n const actualProvider = config.defaultProvider || config.provider!;\n this.config = {\n provider: actualProvider,\n defaultProvider: actualProvider\n };\n }\n\n /**\n * Get current configuration\n */\n getConfig(): ComputeConfig | null {\n return this.config;\n }\n\n /**\n * Clear current configuration\n */\n clearConfig(): void {\n this.config = null;\n }\n\n /**\n * Get the default provider, throwing if not configured\n */\n private getDefaultProvider(): Provider {\n if (!this.config?.provider) {\n throw new Error(\n 'No default provider configured. Either call compute.setConfig({ defaultProvider }) or pass provider explicitly.'\n );\n }\n return this.config.provider;\n }\n\n sandbox = {\n /**\n * Create a sandbox from a provider (or default provider if configured)\n * \n * @example\n * ```typescript\n * import { e2b } from '@computesdk/e2b'\n * import { compute } from 'computesdk'\n * \n * // With explicit provider\n * const sandbox = await compute.sandbox.create({\n * provider: e2b({ apiKey: 'your-key' })\n * })\n * \n * // With default provider (both forms work)\n * compute.setConfig({ defaultProvider: e2b({ apiKey: 'your-key' }) })\n * const sandbox1 = await compute.sandbox.create({})\n * const sandbox2 = await compute.sandbox.create()\n * ```\n */\n create: async (params?: CreateSandboxParams | CreateSandboxParamsWithOptionalProvider): Promise<Sandbox> => {\n const provider = params && 'provider' in params && params.provider ? params.provider : this.getDefaultProvider();\n const options = params?.options;\n return await provider.sandbox.create(options);\n },\n\n /**\n * Get an existing sandbox by ID from a provider (or default provider if configured)\n */\n getById: async (providerOrSandboxId: Provider | string, sandboxId?: string): Promise<Sandbox | null> => {\n if (typeof providerOrSandboxId === 'string') {\n // Called with just sandboxId, use default provider\n const provider = this.getDefaultProvider();\n return await provider.sandbox.getById(providerOrSandboxId);\n } else {\n // Called with provider and sandboxId\n if (!sandboxId) {\n throw new Error('sandboxId is required when provider is specified');\n }\n return await providerOrSandboxId.sandbox.getById(sandboxId);\n }\n },\n\n /**\n * List all active sandboxes from a provider (or default provider if configured)\n */\n list: async (provider?: Provider): Promise<Sandbox[]> => {\n const actualProvider = provider || this.getDefaultProvider();\n return await actualProvider.sandbox.list();\n },\n\n /**\n * Destroy a sandbox via a provider (or default provider if configured)\n */\n destroy: async (providerOrSandboxId: Provider | string, sandboxId?: string): Promise<void> => {\n if (typeof providerOrSandboxId === 'string') {\n // Called with just sandboxId, use default provider\n const provider = this.getDefaultProvider();\n return await provider.sandbox.destroy(providerOrSandboxId);\n } else {\n // Called with provider and sandboxId\n if (!sandboxId) {\n throw new Error('sandboxId is required when provider is specified');\n }\n return await providerOrSandboxId.sandbox.destroy(sandboxId);\n }\n }\n };\n\n // Future: compute.blob.*, compute.database.*, compute.git.* will be added here\n // blob = new BlobManager();\n // database = new DatabaseManager(); \n // git = new GitManager();\n\n\n}\n\n/**\n * Singleton instance - the main API\n */\nexport const compute: ComputeAPI = new ComputeManager();\n\n","/**\n * Simplified Request Handler for Web Framework Integration\n * \n * Handles JSON requests for sandbox and code execution operations.\n * Terminal support removed - will be re-added with WebSocket VM connections.\n */\n\nimport type { Provider, Runtime } from './types';\nimport { compute } from './compute';\n\n/**\n * Request structure supporting sandbox and code execution capabilities\n */\nexport interface ComputeRequest {\n /** Action in dot notation (e.g., 'compute.sandbox.create') */\n action: string;\n \n /** Parameters for the action */\n sandboxId?: string;\n code?: string;\n command?: string;\n args?: string[];\n runtime?: Runtime;\n path?: string;\n content?: string;\n \n /** Sandbox creation options */\n options?: {\n runtime?: Runtime;\n timeout?: number;\n sandboxId?: string;\n };\n}\n\n/**\n * Response structure for compute operations\n */\nexport interface ComputeResponse {\n success: boolean;\n error?: string;\n sandboxId: string;\n provider: string;\n [key: string]: any; // Allow any additional response data\n}\n\n/**\n * Execute compute action using targeted handling\n */\nasync function executeAction(body: ComputeRequest, provider: Provider): Promise<ComputeResponse> {\n try {\n const { action, sandboxId } = body;\n \n // Sandbox management operations\n if (action === 'compute.sandbox.create') {\n const sandbox = await compute.sandbox.create({\n provider,\n options: body.options || { runtime: 'python' }\n });\n return {\n success: true,\n sandboxId: sandbox.sandboxId,\n provider: provider.name\n };\n }\n \n if (action === 'compute.sandbox.list') {\n const sandboxes = await compute.sandbox.list(provider);\n return {\n success: true,\n sandboxId: '',\n provider: provider.name,\n sandboxes: sandboxes.map(sb => ({\n sandboxId: sb.sandboxId,\n provider: sb.provider\n }))\n };\n }\n \n if (action === 'compute.sandbox.destroy') {\n if (!sandboxId) {\n throw new Error('sandboxId is required for destroy action');\n }\n await compute.sandbox.destroy(provider, sandboxId);\n return {\n success: true,\n sandboxId,\n provider: provider.name\n };\n }\n \n // For sandbox instance methods, get the sandbox first\n if (!sandboxId) {\n throw new Error('sandboxId is required for this action');\n }\n \n const sandbox = await compute.sandbox.getById(provider, sandboxId);\n if (!sandbox) {\n throw new Error(`Sandbox ${sandboxId} not found`);\n }\n \n // Sandbox info\n if (action === 'compute.sandbox.getInfo') {\n const result = await sandbox.getInfo();\n return {\n success: true,\n sandboxId,\n provider: provider.name,\n info: {\n id: result.id,\n provider: result.provider,\n runtime: result.runtime,\n status: result.status,\n createdAt: result.createdAt.toISOString(),\n timeout: result.timeout,\n metadata: result.metadata\n }\n };\n }\n \n // Code execution\n if (action === 'compute.sandbox.runCode') {\n if (!body.code) throw new Error('code is required');\n const result = await sandbox.runCode(body.code, body.runtime);\n return {\n success: true,\n sandboxId,\n provider: provider.name,\n result: {\n stdout: result.stdout,\n stderr: result.stderr,\n exitCode: result.exitCode,\n executionTime: result.executionTime\n }\n };\n }\n \n if (action === 'compute.sandbox.runCommand') {\n if (!body.command) throw new Error('command is required');\n const result = await sandbox.runCommand(body.command, body.args);\n return {\n success: true,\n sandboxId,\n provider: provider.name,\n result: {\n stdout: result.stdout,\n stderr: result.stderr,\n exitCode: result.exitCode,\n executionTime: result.executionTime\n }\n };\n }\n \n // Filesystem operations\n if (action === 'compute.sandbox.filesystem.readFile') {\n if (!body.path) throw new Error('path is required');\n const result = await sandbox.filesystem.readFile(body.path);\n return {\n success: true,\n sandboxId,\n provider: provider.name,\n fileContent: result\n };\n }\n \n if (action === 'compute.sandbox.filesystem.writeFile') {\n if (!body.path) throw new Error('path is required');\n if (body.content === undefined) throw new Error('content is required');\n await sandbox.filesystem.writeFile(body.path, body.content);\n return { success: true, sandboxId, provider: provider.name };\n }\n \n if (action === 'compute.sandbox.filesystem.mkdir') {\n if (!body.path) throw new Error('path is required');\n await sandbox.filesystem.mkdir(body.path);\n return { success: true, sandboxId, provider: provider.name };\n }\n \n if (action === 'compute.sandbox.filesystem.readdir') {\n if (!body.path) throw new Error('path is required');\n const result = await sandbox.filesystem.readdir(body.path);\n return {\n success: true,\n sandboxId,\n provider: provider.name,\n files: result.map((entry: any) => ({\n name: entry.name,\n path: entry.path,\n isDirectory: entry.isDirectory,\n size: entry.size,\n lastModified: entry.lastModified.toISOString()\n }))\n };\n }\n \n if (action === 'compute.sandbox.filesystem.exists') {\n if (!body.path) throw new Error('path is required');\n const result = await sandbox.filesystem.exists(body.path);\n return {\n success: true,\n sandboxId,\n provider: provider.name,\n exists: result\n };\n }\n \n if (action === 'compute.sandbox.filesystem.remove') {\n if (!body.path) throw new Error('path is required');\n await sandbox.filesystem.remove(body.path);\n return { success: true, sandboxId, provider: provider.name };\n }\n \n throw new Error(`Unknown action: ${action}`);\n \n } catch (error) {\n return {\n success: false,\n error: error instanceof Error ? error.message : 'Unknown error occurred',\n sandboxId: body.sandboxId || '',\n provider: provider.name\n };\n }\n}\n\n/**\n * Main request handler - handles HTTP requests and pre-parsed bodies\n */\nexport async function handleComputeRequest(\n params: HandleComputeRequestParams\n): Promise<ComputeResponse>;\nexport async function handleComputeRequest(\n requestOrBody: Request | ComputeRequest,\n provider: Provider\n): Promise<Response>;\nexport async function handleComputeRequest(\n paramsOrRequestOrBody: HandleComputeRequestParams | Request | ComputeRequest,\n provider?: Provider\n): Promise<ComputeResponse | Response> {\n // Handle object-style API\n if (typeof paramsOrRequestOrBody === 'object' && 'request' in paramsOrRequestOrBody && 'provider' in paramsOrRequestOrBody) {\n const params = paramsOrRequestOrBody as HandleComputeRequestParams;\n return await executeAction(params.request, params.provider);\n }\n \n // Handle original API\n if (!provider) {\n throw new Error('Provider is required when not using object-style API');\n }\n \n const requestOrBody = paramsOrRequestOrBody as Request | ComputeRequest;\n try {\n let body: ComputeRequest;\n \n if (requestOrBody instanceof Request) {\n // Handle HTTP method validation\n if (requestOrBody.method !== 'POST') {\n return Response.json({\n success: false,\n error: 'Only POST requests are supported',\n sandboxId: '',\n provider: provider.name\n }, { status: 405 });\n }\n \n // Parse JSON body with better error handling\n try {\n body = await requestOrBody.json();\n } catch (parseError) {\n return Response.json({\n success: false,\n error: 'Invalid JSON in request body',\n sandboxId: '',\n provider: provider.name\n }, { status: 400 });\n }\n } else {\n body = requestOrBody;\n }\n \n // Execute the action\n const result = await executeAction(body, provider);\n \n return Response.json(result, {\n status: result.success ? 200 : 500\n });\n \n } catch (error) {\n return Response.json({\n success: false,\n error: error instanceof Error ? error.message : 'Request handling failed',\n sandboxId: '',\n provider: provider.name\n }, { status: 500 });\n }\n}\n\n/**\n * Legacy export for backward compatibility\n */\nexport interface HandleComputeRequestParams {\n request: ComputeRequest;\n provider: Provider;\n}\n\nexport { handleComputeRequest as handleHttpComputeRequest };","/**\n * Provider Factory - Creates providers from method definitions\n * \n * Eliminates boilerplate by auto-generating Provider/Sandbox classes\n * from simple method definitions with automatic feature detection.\n */\n\nimport type {\n Provider,\n ProviderSandboxManager,\n Sandbox,\n SandboxFileSystem,\n SandboxInfo,\n ExecutionResult,\n Runtime,\n CreateSandboxOptions,\n FileEntry,\n} from './types/index.js';\n\n/**\n * Flat sandbox method implementations - all operations in one place\n */\nexport interface SandboxMethods<TSandbox = any, TConfig = any> {\n // Collection operations (map to compute.sandbox.*)\n create: (config: TConfig, options?: CreateSandboxOptions) => Promise<{ sandbox: TSandbox; sandboxId: string }>;\n getById: (config: TConfig, sandboxId: string) => Promise<{ sandbox: TSandbox; sandboxId: string } | null>;\n list: (config: TConfig) => Promise<Array<{ sandbox: TSandbox; sandboxId: string }>>;\n destroy: (config: TConfig, sandboxId: string) => Promise<void>;\n \n // Instance operations (map to individual Sandbox methods)\n runCode: (sandbox: TSandbox, code: string, runtime?: Runtime, config?: TConfig) => Promise<ExecutionResult>;\n runCommand: (sandbox: TSandbox, command: string, args?: string[]) => Promise<ExecutionResult>;\n getInfo: (sandbox: TSandbox) => Promise<SandboxInfo>;\n getUrl: (sandbox: TSandbox, options: { port: number; protocol?: string }) => Promise<string>;\n \n // Optional provider-specific typed getInstance method\n getInstance?: (sandbox: TSandbox) => TSandbox;\n \n // Optional filesystem methods\n filesystem?: {\n readFile: (sandbox: TSandbox, path: string, runCommand: (sandbox: TSandbox, command: string, args?: string[]) => Promise<ExecutionResult>) => Promise<string>;\n writeFile: (sandbox: TSandbox, path: string, content: string, runCommand: (sandbox: TSandbox, command: string, args?: string[]) => Promise<ExecutionResult>) => Promise<void>;\n mkdir: (sandbox: TSandbox, path: string, runCommand: (sandbox: TSandbox, command: string, args?: string[]) => Promise<ExecutionResult>) => Promise<void>;\n readdir: (sandbox: TSandbox, path: string, runCommand: (sandbox: TSandbox, command: string, args?: string[]) => Promise<ExecutionResult>) => Promise<FileEntry[]>;\n exists: (sandbox: TSandbox, path: string, runCommand: (sandbox: TSandbox, command: string, args?: string[]) => Promise<ExecutionResult>) => Promise<boolean>;\n remove: (sandbox: TSandbox, path: string, runCommand: (sandbox: TSandbox, command: string, args?: string[]) => Promise<ExecutionResult>) => Promise<void>;\n };\n \n\n}\n\n/**\n * Provider configuration for createProvider()\n */\nexport interface ProviderConfig<TSandbox = any, TConfig = any> {\n name: string;\n methods: {\n sandbox: SandboxMethods<TSandbox, TConfig>;\n };\n}\n\n/**\n * Default filesystem implementations based on shell commands\n * These work for any provider that supports shell command execution\n */\nconst defaultFilesystemMethods = {\n readFile: async (sandbox: any, path: string, runCommand: (sandbox: any, command: string, args?: string[]) => Promise<ExecutionResult>): Promise<string> => {\n const result = await runCommand(sandbox, 'cat', [path]);\n if (result.exitCode !== 0) {\n throw new Error(`Failed to read file ${path}: ${result.stderr}`);\n }\n // Trim trailing newline that cat command adds\n return result.stdout.replace(/\\n$/, '');\n },\n\n writeFile: async (sandbox: any, path: string, content: string, runCommand: (sandbox: any, command: string, args?: string[]) => Promise<ExecutionResult>): Promise<void> => {\n const result = await runCommand(sandbox, 'sh', ['-c', `echo ${JSON.stringify(content)} > ${JSON.stringify(path)}`]);\n if (result.exitCode !== 0) {\n throw new Error(`Failed to write file ${path}: ${result.stderr}`);\n }\n },\n\n mkdir: async (sandbox: any, path: string, runCommand: (sandbox: any, command: string, args?: string[]) => Promise<ExecutionResult>): Promise<void> => {\n const result = await runCommand(sandbox, 'mkdir', ['-p', path]);\n if (result.exitCode !== 0) {\n throw new Error(`Failed to create directory ${path}: ${result.stderr}`);\n }\n },\n\n readdir: async (sandbox: any, path: string, runCommand: (sandbox: any, command: string, args?: string[]) => Promise<ExecutionResult>): Promise<FileEntry[]> => {\n // Try different ls variations for maximum compatibility\n let result = await runCommand(sandbox, 'ls', ['-la', path]);\n let hasDetailedOutput = true;\n \n // Fall back to basic ls if detailed flags not supported\n if (result.exitCode !== 0) {\n result = await runCommand(sandbox, 'ls', ['-l', path]);\n }\n if (result.exitCode !== 0) {\n result = await runCommand(sandbox, 'ls', [path]);\n hasDetailedOutput = false;\n }\n \n if (result.exitCode !== 0) {\n throw new Error(`Failed to list directory ${path}: ${result.stderr}`);\n }\n\n const lines = (result.stdout || '').split('\\n').filter((line: string) => line.trim() && !line.startsWith('total'));\n\n return lines.map((line: string) => {\n if (hasDetailedOutput && line.includes(' ')) {\n // Parse detailed ls output (ls -la or ls -l)\n const parts = line.trim().split(/\\s+/);\n const name = parts[parts.length - 1];\n const isDirectory = line.startsWith('d');\n \n return {\n name,\n path: `${path}/${name}`,\n isDirectory,\n size: parseInt(parts[4]) || 0,\n lastModified: new Date()\n };\n } else {\n // Parse simple ls output (just filenames)\n const name = line.trim();\n return {\n name,\n path: `${path}/${name}`,\n isDirectory: false, // Can't determine from simple ls\n size: 0,\n lastModified: new Date()\n };\n }\n });\n },\n\n exists: async (sandbox: any, path: string, runCommand: (sandbox: any, command: string, args?: string[]) => Promise<ExecutionResult>): Promise<boolean> => {\n const result = await runCommand(sandbox, 'test', ['-e', path]);\n return result.exitCode === 0; // Exit code 0 means file exists\n },\n\n remove: async (sandbox: any, path: string, runCommand: (sandbox: any, command: string, args?: string[]) => Promise<ExecutionResult>): Promise<void> => {\n const result = await runCommand(sandbox, 'rm', ['-rf', path]);\n if (result.exitCode !== 0) {\n throw new Error(`Failed to remove ${path}: ${result.stderr}`);\n }\n }\n};\n\n/**\n * Auto-generated filesystem implementation that throws \"not supported\" errors\n */\nclass UnsupportedFileSystem implements SandboxFileSystem {\n private readonly providerName: string;\n\n constructor(providerName: string) {\n this.providerName = providerName;\n }\n\n async readFile(_path: string): Promise<string> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async writeFile(_path: string, _content: string): Promise<void> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async mkdir(_path: string): Promise<void> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async readdir(_path: string): Promise<FileEntry[]> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async exists(_path: string): Promise<boolean> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n\n async remove(_path: string): Promise<void> {\n throw new Error(`Filesystem operations are not supported by ${this.providerName}'s sandbox environment. ${this.providerName} sandboxes are designed for code execution only.`);\n }\n}\n\n\n\n/**\n * Auto-generated filesystem implementation that wraps provider methods\n */\nclass SupportedFileSystem<TSandbox> implements SandboxFileSystem {\n constructor(\n private sandbox: TSandbox,\n private methods: NonNullable<SandboxMethods<TSandbox>['filesystem']>,\n private allMethods: SandboxMethods<TSandbox>\n ) {}\n\n async readFile(path: string): Promise<string> {\n return this.methods.readFile(this.sandbox, path, this.allMethods.runCommand);\n }\n\n async writeFile(path: string, content: string): Promise<void> {\n return this.methods.writeFile(this.sandbox, path, content, this.allMethods.runCommand);\n }\n\n async mkdir(path: string): Promise<void> {\n return this.methods.mkdir(this.sandbox, path, this.allMethods.runCommand);\n }\n\n async readdir(path: string): Promise<FileEntry[]> {\n return this.methods.readdir(this.sandbox, path, this.allMethods.runCommand);\n }\n\n async exists(path: string): Promise<boolean> {\n return this.methods.exists(this.sandbox, path, this.allMethods.runCommand);\n }\n\n async remove(path: string): Promise<void> {\n return this.methods.remove(this.sandbox, path, this.allMethods.runCommand);\n }\n}\n\n\n\n\n\n/**\n * Generated sandbox class - implements the Sandbox interface\n */\nclass GeneratedSandbox<TSandbox = any> implements Sandbox {\n readonly sandboxId: string;\n readonly provider: string;\n readonly filesystem: SandboxFileSystem;\n\n constructor(\n private sandbox: TSandbox,\n sandboxId: string,\n providerName: string,\n private methods: SandboxMethods<TSandbox>,\n private config: any,\n private destroyMethod: (config: any, sandboxId: string) => Promise<void>,\n private providerInstance: Provider\n ) {\n this.sandboxId = sandboxId;\n this.provider = providerName;\n\n // Auto-detect filesystem support\n if (methods.filesystem) {\n this.filesystem = new SupportedFileSystem(sandbox, methods.filesystem, methods);\n } else {\n this.filesystem = new UnsupportedFileSystem(providerName);\n }\n }\n\n getInstance<T = TSandbox>(): T {\n // Use provider-specific typed getInstance if available\n if (this.methods.getInstance) {\n return this.methods.getInstance(this.sandbox) as unknown as T;\n }\n // Fallback to generic casting\n return this.sandbox as unknown as T;\n }\n\n async runCode(code: string, runtime?: Runtime): Promise<ExecutionResult> {\n return await this.methods.runCode(this.sandbox, code, runtime, this.config);\n }\n\n async runCommand(command: string, args?: string[]): Promise<ExecutionResult> {\n return await this.methods.runCommand(this.sandbox, command, args);\n }\n\n async getInfo(): Promise<SandboxInfo> {\n return await this.methods.getInfo(this.sandbox);\n }\n\n async getUrl(options: { port: number; protocol?: string }): Promise<string> {\n return await this.methods.getUrl(this.sandbox, options);\n }\n\n getProvider(): Provider {\n return this.providerInstance;\n }\n\n async kill(): Promise<void> {\n // For backward compatibility, kill() delegates to destroy()\n await this.destroy();\n }\n\n async destroy(): Promise<void> {\n // Destroy via the provider's destroy method using our sandboxId\n await this.destroyMethod(this.config, this.sandboxId);\n }\n}\n\n/**\n * Auto-generated Sandbox Manager implementation\n */\nclass GeneratedSandboxManager<TSandbox, TConfig> implements ProviderSandboxManager {\n private activeSandboxes: Map<string, GeneratedSandbox<TSandbox>> = new Map();\n\n constructor(\n private config: TConfig,\n private providerName: string,\n private methods: SandboxMethods<TSandbox, TConfig>,\n private providerInstance: Provider\n ) {}\n\n async create(options?: CreateSandboxOptions): Promise<Sandbox> {\n const result = await this.methods.create(this.config, options);\n const sandbox = new GeneratedSandbox(\n result.sandbox,\n result.sandboxId,\n this.providerName,\n this.methods,\n this.config,\n this.methods.destroy,\n this.providerInstance\n );\n \n this.activeSandboxes.set(result.sandboxId, sandbox);\n return sandbox;\n }\n\n async getById(sandboxId: string): Promise<Sandbox | null> {\n // Check active sandboxes first\n const existing = this.activeSandboxes.get(sandboxId);\n if (existing) {\n return existing;\n }\n\n // Try to reconnect\n const result = await this.methods.getById(this.config, sandboxId);\n if (!result) {\n return null;\n }\n\n const sandbox = new GeneratedSandbox(\n result.sandbox,\n result.sandboxId,\n this.providerName,\n this.methods,\n this.config,\n this.methods.destroy,\n this.providerInstance\n );\n \n this.activeSandboxes.set(result.sandboxId, sandbox);\n return sandbox;\n }\n\n async list(): Promise<Sandbox[]> {\n const results = await this.methods.list(this.config);\n const sandboxes: Sandbox[] = [];\n\n for (const result of results) {\n let sandbox = this.activeSandboxes.get(result.sandboxId);\n if (!sandbox) {\n sandbox = new GeneratedSandbox(\n result.sandbox,\n result.sandboxId,\n this.providerName,\n this.methods,\n this.config,\n this.methods.destroy,\n this.providerInstance\n );\n this.activeSandboxes.set(result.sandboxId, sandbox);\n }\n sandboxes.push(sandbox);\n }\n\n return sandboxes;\n }\n\n async destroy(sandboxId: string): Promise<void> {\n await this.methods.destroy(this.config, sandboxId);\n this.activeSandboxes.delete(sandboxId);\n }\n}\n\n/**\n * Auto-generated Provider implementation\n */\nclass GeneratedProvider<TSandbox, TConfig> implements Provider {\n readonly name: string;\n readonly sandbox: ProviderSandboxManager;\n\n constructor(config: TConfig, providerConfig: ProviderConfig<TSandbox, TConfig>) {\n this.name = providerConfig.name;\n this.sandbox = new GeneratedSandboxManager(\n config,\n providerConfig.name,\n providerConfig.methods.sandbox,\n this\n );\n }\n}\n\n/**\n * Create a provider from method definitions\n * \n * Auto-generates all boilerplate classes and provides feature detection\n * based on which methods are implemented.\n */\nexport function createProvider<TSandbox, TConfig>(\n providerConfig: ProviderConfig<TSandbox, TConfig>\n): (config: TConfig) => Provider {\n // Auto-inject default filesystem methods if none provided\n if (!providerConfig.methods.sandbox.filesystem) {\n providerConfig.methods.sandbox.filesystem = defaultFilesystemMethods;\n }\n\n return (config: TConfig) => {\n return new GeneratedProvider(config, providerConfig);\n };\n}"],"mappings":"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","names":["sandbox"]}
|