@vm0/cli 9.90.0 → 9.90.2
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/{chunk-KEYG4DHY.js → chunk-VO3BTEUW.js} +277 -222
- package/chunk-VO3BTEUW.js.map +1 -0
- package/index.js +23 -11
- package/index.js.map +1 -1
- package/package.json +1 -1
- package/zero.js +90 -94
- package/zero.js.map +1 -1
- package/chunk-KEYG4DHY.js.map +0 -1
package/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/commands/auth/index.ts","../src/commands/auth/login.ts","../src/lib/api/auth.ts","../src/commands/auth/logout.ts","../src/commands/auth/status.ts","../src/commands/auth/setup-token.ts","../src/commands/info/index.ts","../src/lib/utils/update-checker.ts","../src/lib/utils/spawn.ts","../src/commands/compose/index.ts","../src/lib/domain/yaml-validator.ts","../src/lib/domain/github-skills.ts","../src/lib/external/git-client.ts","../src/lib/storage/system-storage.ts","../src/lib/storage/direct-upload.ts","../src/lib/utils/file-utils.ts","../src/commands/run/run.ts","../src/commands/run/resume.ts","../src/commands/run/continue.ts","../src/commands/run/list.ts","../src/lib/utils/time-parser.ts","../src/commands/run/kill.ts","../src/commands/run/queue.ts","../src/commands/run/index.ts","../src/commands/volume/index.ts","../src/commands/volume/init.ts","../src/lib/storage/storage-utils.ts","../src/commands/volume/push.ts","../src/commands/volume/pull.ts","../src/lib/storage/pull-utils.ts","../src/commands/volume/status.ts","../src/commands/volume/list.ts","../src/commands/volume/clone.ts","../src/lib/storage/clone-utils.ts","../src/commands/artifact/index.ts","../src/commands/artifact/init.ts","../src/commands/artifact/push.ts","../src/commands/artifact/pull.ts","../src/commands/artifact/status.ts","../src/commands/artifact/list.ts","../src/commands/artifact/clone.ts","../src/commands/memory/index.ts","../src/commands/memory/init.ts","../src/commands/memory/push.ts","../src/commands/memory/pull.ts","../src/commands/memory/status.ts","../src/commands/memory/list.ts","../src/commands/memory/clone.ts","../src/commands/cook/cook.ts","../src/lib/domain/cook-state.ts","../src/commands/cook/utils.ts","../src/commands/cook/logs.ts","../src/commands/cook/continue.ts","../src/commands/cook/resume.ts","../src/commands/cook/index.ts","../src/commands/logs/index.ts","../src/lib/utils/paginate.ts","../src/commands/logs/search.ts","../src/commands/init/index.ts","../src/commands/upgrade/index.ts","../src/commands/whoami.ts"],"sourcesContent":["// VM0 CLI entry point - main module\n// Sentry must be initialized before any other imports\nimport \"./instrument.js\";\nimport { Command } from \"commander\";\nimport { configureGlobalProxyFromEnv } from \"./lib/network/proxy.js\";\nimport { authCommand } from \"./commands/auth\";\nimport { infoCommand } from \"./commands/info\";\nimport { composeCommand } from \"./commands/compose\";\nimport { runCommand } from \"./commands/run\";\nimport { volumeCommand } from \"./commands/volume\";\nimport { artifactCommand } from \"./commands/artifact\";\nimport { memoryCommand } from \"./commands/memory\";\nimport { cookCommand } from \"./commands/cook\";\nimport { logsCommand } from \"./commands/logs\";\n\nimport { initCommand } from \"./commands/init\";\n\nimport { upgradeCommand } from \"./commands/upgrade\";\nimport { whoamiCommand } from \"./commands/whoami\";\n\nconst program = new Command();\n\ndeclare const __CLI_VERSION__: string;\n\nprogram\n .name(\"vm0\")\n .description(\"VM0 CLI - Build and run agents with natural language\")\n .version(__CLI_VERSION__);\n\n// Register all commands\nprogram.addCommand(authCommand);\nprogram.addCommand(infoCommand);\nprogram.addCommand(composeCommand);\nprogram.addCommand(runCommand);\nprogram.addCommand(volumeCommand);\nprogram.addCommand(artifactCommand);\nprogram.addCommand(memoryCommand);\nprogram.addCommand(cookCommand);\nprogram.addCommand(logsCommand);\n\nprogram.addCommand(initCommand);\nprogram.addCommand(upgradeCommand);\nprogram.addCommand(whoamiCommand);\n\nexport { program };\n\nif (\n process.argv[1]?.endsWith(\"index.js\") ||\n process.argv[1]?.endsWith(\"index.ts\") ||\n process.argv[1]?.endsWith(\"vm0\")\n) {\n configureGlobalProxyFromEnv();\n program.parse();\n}\n","import { Command } from \"commander\";\nimport { loginCommand } from \"./login\";\nimport { logoutCommand } from \"./logout\";\nimport { statusCommand } from \"./status\";\nimport { setupTokenCommand } from \"./setup-token\";\n\nexport const authCommand = new Command()\n .name(\"auth\")\n .description(\"Authenticate vm0\")\n .addCommand(loginCommand)\n .addCommand(logoutCommand)\n .addCommand(statusCommand)\n .addCommand(setupTokenCommand);\n","import { Command } from \"commander\";\nimport { authenticate } from \"../../lib/api/auth\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const loginCommand = new Command()\n .name(\"login\")\n .description(\"Log in to VM0 (use VM0_API_URL env var to set API URL)\")\n .action(\n withErrorHandler(async () => {\n await authenticate();\n }),\n );\n","import chalk from \"chalk\";\nimport {\n saveConfig,\n clearConfig,\n loadConfig,\n getApiUrl,\n getToken,\n} from \"./config\";\n\n/**\n * Build headers with optional Vercel bypass secret\n * Used to bypass Vercel deployment protection in CI/preview environments\n */\nfunction buildHeaders(): Record<string, string> {\n const headers: Record<string, string> = {\n \"Content-Type\": \"application/json\",\n };\n\n // Add Vercel bypass secret if available (for CI/preview deployments)\n const bypassSecret = process.env.VERCEL_AUTOMATION_BYPASS_SECRET;\n if (bypassSecret) {\n headers[\"x-vercel-protection-bypass\"] = bypassSecret;\n }\n\n return headers;\n}\n\nasync function requestDeviceCode(apiUrl: string): Promise<{\n device_code: string;\n user_code: string;\n verification_path: string;\n expires_in: number;\n interval: number;\n}> {\n const response = await fetch(`${apiUrl}/api/cli/auth/device`, {\n method: \"POST\",\n headers: buildHeaders(),\n body: JSON.stringify({}),\n });\n\n if (!response.ok) {\n if (response.status === 403) {\n throw new Error(\"An unexpected network issue occurred\");\n }\n throw new Error(`Failed to request device code: ${response.statusText}`);\n }\n\n return response.json() as Promise<{\n device_code: string;\n user_code: string;\n verification_path: string;\n expires_in: number;\n interval: number;\n }>;\n}\n\nasync function exchangeToken(\n apiUrl: string,\n deviceCode: string,\n): Promise<{\n access_token?: string;\n refresh_token?: string;\n token_type?: string;\n expires_in?: number;\n org_slug?: string;\n error?: string;\n error_description?: string;\n}> {\n const response = await fetch(`${apiUrl}/api/cli/auth/token`, {\n method: \"POST\",\n headers: buildHeaders(),\n body: JSON.stringify({ device_code: deviceCode }),\n });\n\n return response.json() as Promise<{\n access_token?: string;\n refresh_token?: string;\n token_type?: string;\n expires_in?: number;\n org_slug?: string;\n error?: string;\n error_description?: string;\n }>;\n}\n\nfunction delay(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\nexport async function authenticate(apiUrl?: string): Promise<void> {\n // Use provided apiUrl or get from config/env (with fallback to production)\n const targetApiUrl = apiUrl ?? (await getApiUrl());\n console.log(\"Initiating authentication...\");\n\n // Request device code\n const deviceAuth = await requestDeviceCode(targetApiUrl);\n\n console.log(chalk.green(\"\\nDevice code generated\"));\n\n // Construct verification URL from API URL and server-provided path\n const verificationUrl = `${targetApiUrl}${deviceAuth.verification_path}`;\n console.log(chalk.cyan(`\\nTo authenticate, visit: ${verificationUrl}`));\n console.log(`And enter this code: ${chalk.bold(deviceAuth.user_code)}`);\n console.log(\n `\\nThe code expires in ${Math.floor(deviceAuth.expires_in / 60)} minutes.`,\n );\n\n console.log(\"\\nWaiting for authentication...\");\n\n // Poll for token\n const startTime = Date.now();\n const maxWaitTime = deviceAuth.expires_in * 1000; // Convert to milliseconds\n const pollInterval = (deviceAuth.interval || 5) * 1000; // Use server-specified interval or default to 5 seconds\n\n let isFirstPoll = true;\n\n while (Date.now() - startTime < maxWaitTime) {\n // Skip delay on first poll for faster response\n if (!isFirstPoll) {\n await delay(pollInterval); // Use dynamic polling interval\n }\n isFirstPoll = false;\n\n const tokenResult = await exchangeToken(\n targetApiUrl,\n deviceAuth.device_code,\n );\n\n if (tokenResult.access_token) {\n // Success! Store the token and org context\n await saveConfig({\n token: tokenResult.access_token,\n apiUrl: targetApiUrl,\n });\n\n console.log(chalk.green(\"\\nAuthentication successful!\"));\n console.log(\"Your credentials have been saved\");\n return;\n }\n\n if (tokenResult.error === \"authorization_pending\") {\n // Still waiting for user to authenticate\n process.stdout.write(chalk.dim(\".\"));\n continue;\n }\n\n // Handle other errors\n if (tokenResult.error === \"expired_token\") {\n throw new Error(\"Device code expired, please try again\");\n }\n\n if (tokenResult.error) {\n throw new Error(\n `Authentication failed: ${tokenResult.error_description ?? tokenResult.error}`,\n );\n }\n }\n\n // Timeout\n throw new Error(\"Authentication timed out, please try again\");\n}\n\nexport async function logout(): Promise<void> {\n await clearConfig();\n console.log(chalk.green(\"✓ Successfully logged out\"));\n console.log(\"Your credentials have been cleared\");\n}\n\nexport async function checkAuthStatus(): Promise<void> {\n const config = await loadConfig();\n\n if (config.token) {\n console.log(chalk.green(\"✓ Authenticated\"));\n console.log(\"You are logged in to VM0.\");\n } else {\n console.error(chalk.red(\"✗ Not authenticated\"));\n console.error(chalk.dim(\" Run: vm0 auth login\"));\n }\n\n // Also check for environment variable\n if (process.env.VM0_TOKEN) {\n console.log(\"Using token from VM0_TOKEN environment variable\");\n }\n}\n\nexport async function setupToken(): Promise<void> {\n const token = await getToken();\n\n if (!token) {\n console.error(chalk.red(\"✗ Not authenticated\"));\n console.error(\"\");\n console.error(\"To get a token for CI/CD:\");\n console.error(\" 1. Run 'vm0 auth login' to authenticate\");\n console.error(\" 2. Run 'vm0 auth setup-token' to get your token\");\n console.error(\n \" 3. Store the token in your CI/CD secrets (e.g., VM0_TOKEN)\",\n );\n process.exit(1);\n }\n\n console.log(chalk.green(\"✓ Authentication token exported successfully!\"));\n console.log(\"\");\n console.log(\"Your token:\");\n console.log(\"\");\n console.log(token);\n console.log(\"\");\n console.log(\n `Use this token by setting: ${chalk.cyan(\"export VM0_TOKEN=<token>\")}`,\n );\n}\n","import { Command } from \"commander\";\nimport { logout } from \"../../lib/api/auth\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const logoutCommand = new Command()\n .name(\"logout\")\n .description(\"Log out of VM0\")\n .action(\n withErrorHandler(async () => {\n await logout();\n }),\n );\n","import { Command } from \"commander\";\nimport { checkAuthStatus } from \"../../lib/api/auth\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const statusCommand = new Command()\n .name(\"status\")\n .description(\"Show current authentication status\")\n .action(\n withErrorHandler(async () => {\n await checkAuthStatus();\n }),\n );\n","import { Command } from \"commander\";\nimport { setupToken } from \"../../lib/api/auth\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const setupTokenCommand = new Command()\n .name(\"setup-token\")\n .description(\"Output auth token for CI/CD environments\")\n .action(\n withErrorHandler(async () => {\n await setupToken();\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { existsSync } from \"fs\";\nimport { homedir, release, type } from \"os\";\nimport { join } from \"path\";\nimport { getApiUrl, loadConfig } from \"../../lib/api/config\";\nimport { detectPackageManager } from \"../../lib/utils/update-checker\";\n\ndeclare const __CLI_VERSION__: string;\n\nfunction getConfigPath() {\n return join(homedir(), \".vm0\", \"config.json\");\n}\n\nexport const infoCommand = new Command()\n .name(\"info\")\n .description(\"Display environment and debug information\")\n .action(async () => {\n // CLI version header\n console.log(chalk.bold(`VM0 CLI v${__CLI_VERSION__}`));\n console.log();\n\n // Authentication section\n const config = await loadConfig();\n const hasEnvToken = !!process.env.VM0_TOKEN;\n const hasConfigToken = !!config.token;\n const isAuthenticated = hasEnvToken || hasConfigToken;\n\n console.log(chalk.bold(\"Authentication:\"));\n if (isAuthenticated) {\n const tokenSource = hasEnvToken ? \"VM0_TOKEN env var\" : \"config file\";\n console.log(` ${chalk.green(\"✓\")} Logged in (via ${tokenSource})`);\n } else {\n console.log(` ${chalk.red(\"✗\")} Not authenticated`);\n }\n\n const configExists = existsSync(getConfigPath());\n const configDisplay = configExists\n ? `~/.vm0/config.json`\n : `~/.vm0/config.json (not found)`;\n console.log(` Config: ${configDisplay}`);\n console.log();\n\n // API section\n const apiUrl = await getApiUrl();\n console.log(chalk.bold(\"API:\"));\n console.log(` Host: ${apiUrl}`);\n console.log();\n\n // System section\n console.log(chalk.bold(\"System:\"));\n console.log(` Node: ${process.version}`);\n console.log(` Platform: ${process.platform} (${process.arch})`);\n console.log(` OS: ${type()} ${release()}`);\n console.log(` Shell: ${process.env.SHELL ?? \"unknown\"}`);\n console.log(` Package Manager: ${detectPackageManager()}`);\n });\n","import type { ChildProcess } from \"child_process\";\nimport chalk from \"chalk\";\nimport { safeSpawn } from \"./spawn\";\n\nconst PACKAGE_NAME = \"@vm0/cli\";\nconst NPM_REGISTRY_URL = `https://registry.npmjs.org/${encodeURIComponent(PACKAGE_NAME)}/latest`;\nconst TIMEOUT_MS = 5000;\n\ntype PackageManager = \"npm\" | \"pnpm\" | \"bun\" | \"yarn\" | \"unknown\";\n\n/**\n * Internal state for pending upgrade process\n */\ninterface UpgradeHandle {\n promise: Promise<boolean>;\n child: ChildProcess;\n packageManager: \"npm\" | \"pnpm\";\n}\n\n// Module-level state for pending upgrade\nlet pendingUpgrade: UpgradeHandle | null = null;\n\n/**\n * Detect which package manager was used to install the CLI\n * by checking the executable path for known package manager patterns.\n * Returns \"unknown\" if no known pattern is matched.\n */\nexport function detectPackageManager(): PackageManager {\n const execPath = process.argv[1] ?? \"\";\n\n // Check for pnpm (supported for auto-upgrade)\n if (execPath.includes(\"pnpm\")) {\n return \"pnpm\";\n }\n\n // Check for bun (unsupported - manual upgrade only)\n if (execPath.includes(\"/.bun/\") || execPath.includes(\"/bun/\")) {\n return \"bun\";\n }\n\n // Check for yarn (unsupported - manual upgrade only)\n if (execPath.includes(\"/.yarn/\") || execPath.includes(\"/yarn/\")) {\n return \"yarn\";\n }\n\n // Check for npm (supported for auto-upgrade)\n // Common npm paths: Homebrew, nvm, fnm, volta, nodenv, n, or node_modules\n if (\n execPath.includes(\"/usr/local/\") || // Homebrew on Intel Mac\n execPath.includes(\"/opt/homebrew/\") || // Homebrew on arm64 Mac\n execPath.includes(\"/.nvm/\") ||\n execPath.includes(\"/.fnm/\") ||\n execPath.includes(\"/.volta/\") ||\n execPath.includes(\"/.nodenv/\") ||\n execPath.includes(\"/.n/\") ||\n execPath.includes(\"/node_modules/\") ||\n execPath.includes(\"\\\\npm\\\\\") || // Windows: AppData\\Roaming\\npm\n execPath.includes(\"\\\\nodejs\\\\\") // Windows: Program Files\\nodejs\n ) {\n return \"npm\";\n }\n\n // Unknown package manager - don't assume npm\n return \"unknown\";\n}\n\n/**\n * Check if the package manager supports auto-upgrade\n */\nexport function isAutoUpgradeSupported(\n pm: PackageManager,\n): pm is \"npm\" | \"pnpm\" {\n return pm === \"npm\" || pm === \"pnpm\";\n}\n\n/**\n * Get the manual upgrade command for a package manager\n */\nexport function getManualUpgradeCommand(pm: PackageManager): string {\n switch (pm) {\n case \"bun\":\n return `bun add -g ${PACKAGE_NAME}@latest`;\n case \"yarn\":\n return `yarn global add ${PACKAGE_NAME}@latest`;\n case \"pnpm\":\n return `pnpm add -g ${PACKAGE_NAME}@latest`;\n case \"npm\":\n return `npm install -g ${PACKAGE_NAME}@latest`;\n case \"unknown\":\n return `npm install -g ${PACKAGE_NAME}@latest`;\n }\n}\n\n/**\n * Escape a string for use in shell command display.\n * Uses single quotes which don't interpret any special characters.\n * Embedded single quotes are handled via the '\\'' idiom\n * (end quote, escaped literal quote, start quote).\n */\nfunction escapeForShell(str: string): string {\n return `'${str.replace(/'/g, \"'\\\\''\")}'`;\n}\n\n/**\n * Build the re-run command string\n */\nfunction buildRerunCommand(prompt: string | undefined): string {\n if (prompt) {\n return `vm0 cook ${escapeForShell(prompt)}`;\n }\n return \"vm0 cook\";\n}\n\n/**\n * Fetch the latest version of the package from npm registry\n * Returns null if the request fails or times out\n */\nexport async function getLatestVersion(): Promise<string | null> {\n try {\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), TIMEOUT_MS);\n\n const response = await fetch(NPM_REGISTRY_URL, {\n signal: controller.signal,\n });\n\n clearTimeout(timeoutId);\n\n if (!response.ok) {\n return null;\n }\n\n const json = (await response.json()) as { version?: string };\n return json.version ?? null;\n } catch {\n return null;\n }\n}\n\n/**\n * Execute package manager upgrade command\n * - npm: npm install -g @vm0/cli@latest\n * - pnpm: pnpm add -g @vm0/cli@latest\n * Returns true on success, false on failure\n */\nexport function performUpgrade(\n packageManager: \"npm\" | \"pnpm\",\n): Promise<boolean> {\n return new Promise((resolve) => {\n const args =\n packageManager === \"pnpm\"\n ? [\"add\", \"-g\", `${PACKAGE_NAME}@latest`]\n : [\"install\", \"-g\", `${PACKAGE_NAME}@latest`];\n\n const child = safeSpawn(packageManager, args, {\n stdio: \"inherit\",\n });\n\n child.on(\"close\", (code) => {\n resolve(code === 0);\n });\n\n child.on(\"error\", () => {\n resolve(false);\n });\n });\n}\n\n/**\n * Check for updates and perform upgrade if needed\n * Returns true if caller should exit (upgrade happened or failed)\n * Returns false if caller should continue (no update needed, check failed, or unsupported PM)\n */\nexport async function checkAndUpgrade(\n currentVersion: string,\n prompt: string | undefined,\n): Promise<boolean> {\n const latestVersion = await getLatestVersion();\n\n // If we couldn't check, warn and continue\n if (latestVersion === null) {\n console.log(chalk.yellow(\"⚠ Could not check for updates\"));\n console.log();\n return false;\n }\n\n // If already on latest, continue\n if (latestVersion === currentVersion) {\n return false;\n }\n\n // New version available - show beta notice\n console.log(chalk.yellow(\"vm0 is currently in beta.\"));\n console.log(\n chalk.yellow(\n `Current version: ${currentVersion} -> Latest version: ${latestVersion}`,\n ),\n );\n console.log(\n chalk.yellow(\n \"Please always use the latest version for best compatibility.\",\n ),\n );\n console.log();\n\n // Check package manager\n const packageManager = detectPackageManager();\n\n // For unsupported package managers, show manual upgrade instructions and continue\n if (!isAutoUpgradeSupported(packageManager)) {\n if (packageManager === \"unknown\") {\n console.log(\n chalk.yellow(\"Could not detect your package manager for auto-upgrade.\"),\n );\n } else {\n console.log(\n chalk.yellow(`Auto-upgrade is not supported for ${packageManager}.`),\n );\n }\n console.log(chalk.yellow(\"Please upgrade manually:\"));\n console.log(chalk.cyan(` ${getManualUpgradeCommand(packageManager)}`));\n console.log();\n return false;\n }\n\n // Perform upgrade for supported package managers (npm, pnpm)\n console.log(`Upgrading via ${packageManager}...`);\n const success = await performUpgrade(packageManager);\n\n if (success) {\n console.log(chalk.green(`Upgraded to ${latestVersion}`));\n console.log();\n console.log(\"To continue, run:\");\n console.log(chalk.cyan(` ${buildRerunCommand(prompt)}`));\n return true;\n }\n\n // Upgrade failed - show manual instructions\n console.error();\n console.error(chalk.red(\"✗ Upgrade failed. Please run manually:\"));\n console.error(chalk.cyan(` ${getManualUpgradeCommand(packageManager)}`));\n console.error();\n console.error(\"Then re-run:\");\n console.error(chalk.cyan(` ${buildRerunCommand(prompt)}`));\n return true;\n}\n\n/**\n * Start silent upgrade in background.\n * Call this at command start. Does NOT block after spawning.\n * The upgrade runs in parallel with command execution.\n *\n * @param currentVersion - Current CLI version\n * @returns Promise that resolves after starting upgrade (or determining no upgrade needed)\n */\nexport async function startSilentUpgrade(\n currentVersion: string,\n): Promise<void> {\n // Reset any previous state\n pendingUpgrade = null;\n\n // Check for new version\n const latestVersion = await getLatestVersion();\n\n // If check failed or already on latest, return silently\n if (latestVersion === null || latestVersion === currentVersion) {\n return;\n }\n\n // Check package manager\n const packageManager = detectPackageManager();\n\n // For unsupported package managers, return silently (no whisper)\n if (!isAutoUpgradeSupported(packageManager)) {\n return;\n }\n\n // Spawn upgrade process (don't wait for completion)\n const isWindows = process.platform === \"win32\";\n const args =\n packageManager === \"pnpm\"\n ? [\"add\", \"-g\", `${PACKAGE_NAME}@latest`]\n : [\"install\", \"-g\", `${PACKAGE_NAME}@latest`];\n\n const child = safeSpawn(packageManager, args, {\n stdio: \"pipe\",\n detached: !isWindows,\n windowsHide: true,\n });\n\n const promise = new Promise<boolean>((resolve) => {\n child.on(\"close\", (code) => resolve(code === 0));\n child.on(\"error\", () => resolve(false));\n });\n\n pendingUpgrade = { promise, child, packageManager };\n}\n\n/**\n * Wait for pending upgrade to complete and show warning if failed.\n * Call this at command end.\n *\n * @param timeout - Max time to wait if upgrade still running (ms)\n * @returns Promise that resolves when upgrade completes or times out\n */\nexport async function waitForSilentUpgrade(\n timeout: number = TIMEOUT_MS,\n): Promise<void> {\n if (!pendingUpgrade) {\n return;\n }\n\n const { promise, child, packageManager } = pendingUpgrade;\n pendingUpgrade = null; // Clear state\n\n // Race between upgrade completion and timeout\n const result = await Promise.race([\n promise,\n new Promise<false>((resolve) => {\n setTimeout(() => {\n child.kill();\n resolve(false);\n }, timeout);\n }),\n ]);\n\n // Show whisper message only on failure\n if (!result) {\n console.log(\n chalk.yellow(\n `\\n⚠ vm0 auto upgrade failed. Please run: ${getManualUpgradeCommand(packageManager)}`,\n ),\n );\n }\n}\n","import { spawn, type SpawnOptions } from \"child_process\";\nimport type { ChildProcess } from \"child_process\";\n\n/**\n * Spawn a child process with safe Windows shell handling.\n *\n * On Windows, `shell: true` is required to resolve `.cmd` extensions for\n * commands like `npm`, `pnpm`, etc. On other platforms, shell is disabled\n * to avoid unnecessary shell interpretation. Commands passed to this\n * function must be hardcoded strings (not user input), and arguments\n * must use array form to prevent shell injection.\n *\n */\nexport function safeSpawn(\n command: string,\n args: string[],\n options?: Omit<SpawnOptions, \"shell\">,\n): ChildProcess {\n const isWindows = process.platform === \"win32\";\n const resolvedCommand = isWindows ? `${command}.cmd` : command;\n\n // nosemgrep: javascript.lang.security.audit.spawn-shell-true.spawn-shell-true, javascript.lang.security.detect-child-process.detect-child-process\n return spawn(resolvedCommand, args, {\n ...options,\n shell: isWindows,\n });\n}\n","import { Command, Option } from \"commander\";\nimport chalk from \"chalk\";\nimport { readFile, rm } from \"fs/promises\";\nimport { existsSync } from \"fs\";\nimport { dirname, join } from \"path\";\nimport { parse as parseYaml } from \"yaml\";\nimport { extractAndGroupVariables, resolveSkillRef } from \"@vm0/core\";\nimport {\n getComposeByName,\n createOrUpdateCompose,\n getZeroOrg,\n listZeroSecrets,\n listZeroVariables,\n listZeroConnectors,\n resolveSkills,\n} from \"../../lib/api\";\nimport { validateAgentCompose } from \"../../lib/domain/yaml-validator\";\nimport {\n downloadGitHubDirectory,\n parseGitHubTreeUrl,\n} from \"../../lib/domain/github-skills\";\nimport {\n uploadInstructions,\n uploadSkill,\n type SkillUploadResult,\n} from \"../../lib/storage/system-storage\";\nimport { isInteractive, promptConfirm } from \"../../lib/utils/prompt-utils\";\nimport {\n startSilentUpgrade,\n waitForSilentUpgrade,\n} from \"../../lib/utils/update-checker\";\nimport { withErrorHandler } from \"../../lib/command\";\n\ndeclare const __CLI_VERSION__: string;\n\nconst DEFAULT_CONFIG_FILE = \"vm0.yaml\";\n\n/**\n * Check if input is a GitHub URL (supports plain repo, root with branch, and subdirectory)\n * Matches: https://github.com/owner/repo[/tree/branch[/path]]\n */\nfunction isGitHubUrl(input: string): boolean {\n return /^https:\\/\\/github\\.com\\/[^/]+\\/[^/]+/.test(input);\n}\n\n/**\n * Extract secret names from compose content using variable references.\n * Looks for ${{ secrets.XXX }} patterns in the compose.\n */\nexport function getSecretsFromComposeContent(content: unknown): Set<string> {\n const grouped = extractAndGroupVariables(content);\n return new Set(grouped.secrets.map((r) => r.name));\n}\n\n/**\n * Extract variable names from compose content using variable references.\n * Looks for ${{ vars.XXX }} patterns in the compose.\n */\nfunction getVarsFromComposeContent(content: unknown): Set<string> {\n const grouped = extractAndGroupVariables(content);\n return new Set(grouped.vars.map((r) => r.name));\n}\n\ninterface AgentConfig {\n instructions?: string;\n framework?: string;\n skills?: string[];\n environment?: Record<string, string>;\n}\n\ninterface LoadedConfig {\n config: unknown;\n agentName: string;\n agent: AgentConfig;\n basePath: string;\n}\n\n/**\n * Load and validate the compose config file.\n * Returns parsed config with agent info or exits on error.\n */\nasync function loadAndValidateConfig(\n configFile: string,\n): Promise<LoadedConfig> {\n if (!existsSync(configFile)) {\n throw new Error(`Config file not found: ${configFile}`);\n }\n\n const content = await readFile(configFile, \"utf8\");\n\n let config: unknown;\n try {\n config = parseYaml(content);\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Unknown error\";\n throw new Error(`Invalid YAML format: ${message}`);\n }\n\n const validation = validateAgentCompose(config);\n if (!validation.valid) {\n throw new Error(validation.error);\n }\n\n const cfg = config as Record<string, unknown>;\n const agentsConfig = cfg.agents as Record<string, Record<string, unknown>>;\n const agentName = Object.keys(agentsConfig)[0]!;\n const agent = agentsConfig[agentName] as AgentConfig;\n const basePath = dirname(configFile);\n\n return { config, agentName, agent, basePath };\n}\n\n/**\n * Type guard to check if config has a non-empty volumes field.\n */\nfunction hasVolumes(config: unknown): boolean {\n if (typeof config !== \"object\" || config === null) {\n return false;\n }\n const cfg = config as Record<string, unknown>;\n const volumes = cfg.volumes;\n return (\n typeof volumes === \"object\" &&\n volumes !== null &&\n Object.keys(volumes).length > 0\n );\n}\n\n/**\n * Upload instructions and skills, returning skill results.\n */\nasync function uploadAssets(\n agentName: string,\n agent: AgentConfig,\n basePath: string,\n jsonMode?: boolean,\n): Promise<SkillUploadResult[]> {\n if (agent.instructions) {\n if (!jsonMode) {\n console.log(`Uploading instructions: ${agent.instructions}`);\n }\n const result = await uploadInstructions(\n agentName,\n agent.instructions,\n basePath,\n agent.framework,\n );\n if (!jsonMode) {\n console.log(\n chalk.green(\n `✓ Instructions ${result.action === \"deduplicated\" ? \"(unchanged)\" : \"uploaded\"}: ${result.versionId.slice(0, 8)}`,\n ),\n );\n }\n }\n\n const skillResults: SkillUploadResult[] = [];\n if (agent.skills && Array.isArray(agent.skills)) {\n // Normalize bare skill names to full GitHub URLs before upload\n agent.skills = agent.skills.map(resolveSkillRef);\n\n if (!jsonMode) {\n console.log(`Uploading ${agent.skills.length} skill(s)...`);\n }\n\n // Batch resolve official skills against server cache\n const { resolved, unresolved } = await resolveSkills(agent.skills);\n\n // Use resolved skills directly (no download, no upload)\n for (const skillUrl of agent.skills) {\n const skill = resolved[skillUrl];\n if (skill) {\n const parsed = parseGitHubTreeUrl(skillUrl);\n skillResults.push({\n name: skill.storageName,\n versionId: skill.versionHash,\n action: \"resolved\",\n skillName: parsed.skillName,\n frontmatter: skill.frontmatter,\n });\n if (!jsonMode) {\n console.log(chalk.green(` ✓ ${parsed.skillName} (cached)`));\n }\n }\n }\n\n // Fall back to old flow for unresolved skills\n for (const skillUrl of unresolved) {\n if (!jsonMode) {\n console.log(chalk.dim(` Downloading: ${skillUrl}`));\n }\n const result = await uploadSkill(skillUrl);\n skillResults.push(result);\n if (!jsonMode) {\n console.log(\n chalk.green(\n ` ✓ Skill ${result.action === \"deduplicated\" ? \"(unchanged)\" : \"uploaded\"}: ${result.skillName} (${result.versionId.slice(0, 8)})`,\n ),\n );\n }\n }\n }\n\n return skillResults;\n}\n\n/**\n * Derive the app URL from the API URL by replacing \"www\" with \"app\" in the hostname.\n */\ninterface MissingItemsResult {\n missingSecrets: string[];\n missingVars: string[];\n}\n\n/**\n * Check for missing secrets/vars and print setup URL if any are missing.\n */\nasync function checkAndPromptMissingItems(\n config: unknown,\n options: { json?: boolean },\n): Promise<MissingItemsResult> {\n const requiredSecrets = getSecretsFromComposeContent(config);\n const requiredVars = getVarsFromComposeContent(config);\n\n if (requiredSecrets.size === 0 && requiredVars.size === 0) {\n return { missingSecrets: [], missingVars: [] };\n }\n\n const [secretsResponse, variablesResponse, connectorsResponse] =\n await Promise.all([\n requiredSecrets.size > 0 ? listZeroSecrets() : { secrets: [] },\n requiredVars.size > 0 ? listZeroVariables() : { variables: [] },\n listZeroConnectors(),\n ]);\n\n const existingSecretNames = new Set(\n secretsResponse.secrets.map((s) => s.name),\n );\n const existingVarNames = new Set(\n variablesResponse.variables.map((v) => v.name),\n );\n\n // Connector-provided secrets (e.g., GH_TOKEN from GitHub connector)\n // Use server-computed list to avoid CLI/server version skew issues\n const connectorProvided = new Set(\n connectorsResponse.connectorProvidedSecretNames,\n );\n\n const missingSecrets = [...requiredSecrets].filter(\n (name) => !existingSecretNames.has(name) && !connectorProvided.has(name),\n );\n const missingVars = [...requiredVars].filter(\n (name) => !existingVarNames.has(name),\n );\n\n if (missingSecrets.length === 0 && missingVars.length === 0) {\n return { missingSecrets: [], missingVars: [] };\n }\n\n if (!options.json) {\n console.log();\n console.log(chalk.yellow(\"⚠ Missing secrets/variables detected:\"));\n if (missingSecrets.length > 0) {\n console.log(chalk.yellow(` Secrets: ${missingSecrets.join(\", \")}`));\n }\n if (missingVars.length > 0) {\n console.log(chalk.yellow(` Variables: ${missingVars.join(\", \")}`));\n }\n console.log();\n }\n\n return { missingSecrets, missingVars };\n}\n\n/**\n * Result from finalizeCompose for JSON output\n */\ninterface ComposeResult {\n composeId: string;\n composeName: string;\n versionId: string;\n action: \"created\" | \"existing\";\n displayName: string;\n missingSecrets?: string[];\n missingVars?: string[];\n}\n\n/**\n * Finalize compose: call API and display result.\n * Shared by both GitHub URL and local file flows.\n * Returns the compose result for JSON output mode.\n */\nasync function finalizeCompose(\n config: unknown,\n agent: AgentConfig,\n options: { yes?: boolean; autoUpdate?: boolean; json?: boolean },\n): Promise<ComposeResult> {\n // Call API\n if (!options.json) {\n console.log(\"Uploading compose...\");\n }\n const response = await createOrUpdateCompose({ content: config });\n\n const shortVersionId = response.versionId.slice(0, 8);\n // In --json mode, skip getOrg() — the org prefix in displayName is for human display only\n const displayName = options.json\n ? response.name\n : `${(await getZeroOrg()).slug}/${response.name}`;\n\n // Build result\n const result: ComposeResult = {\n composeId: response.composeId,\n composeName: response.name,\n versionId: response.versionId,\n action: response.action,\n displayName,\n };\n\n // In --json mode, skip missing items check — E2B doesn't read these fields\n if (!options.json) {\n const missingItems = await checkAndPromptMissingItems(config, options);\n if (\n missingItems.missingSecrets.length > 0 ||\n missingItems.missingVars.length > 0\n ) {\n result.missingSecrets = missingItems.missingSecrets;\n result.missingVars = missingItems.missingVars;\n }\n }\n\n // Display human-readable result (skip in JSON mode)\n if (!options.json) {\n if (response.action === \"created\") {\n console.log(chalk.green(`✓ Compose created: ${displayName}`));\n } else {\n console.log(chalk.green(`✓ Compose version exists: ${displayName}`));\n }\n\n console.log(chalk.dim(` Version: ${shortVersionId}`));\n console.log();\n console.log(\" Run your agent:\");\n console.log(\n chalk.cyan(\n ` vm0 run ${displayName}:${shortVersionId} --artifact-name <artifact> \"your prompt\"`,\n ),\n );\n }\n\n // Wait for upgrade at command end (shows warning if failed)\n if (options.autoUpdate !== false) {\n await waitForSilentUpgrade();\n }\n\n return result;\n}\n\n/**\n * Handle compose from GitHub URL\n */\nasync function handleGitHubCompose(\n url: string,\n options: { yes?: boolean; autoUpdate?: boolean; json?: boolean },\n): Promise<ComposeResult> {\n if (!options.json) {\n console.log(`Downloading from GitHub: ${url}`);\n }\n\n const { dir: downloadedDir, tempRoot } = await downloadGitHubDirectory(url);\n const configFile = join(downloadedDir, \"vm0.yaml\");\n\n try {\n if (!existsSync(configFile)) {\n throw new Error(\"vm0.yaml not found in the GitHub directory\", {\n cause: new Error(`URL: ${url}`),\n });\n }\n\n // Load and validate config\n const { config, agentName, agent, basePath } =\n await loadAndValidateConfig(configFile);\n\n // Check if agent with same name already exists\n const existingCompose = await getComposeByName(agentName);\n if (existingCompose) {\n if (!options.json) {\n console.log();\n console.log(\n chalk.yellow(`⚠ An agent named \"${agentName}\" already exists.`),\n );\n }\n\n if (!isInteractive()) {\n // Non-interactive mode: require --yes flag to overwrite\n if (!options.yes) {\n throw new Error(\n \"Cannot overwrite existing agent in non-interactive mode\",\n {\n cause: new Error(\n \"Use --yes flag to confirm overwriting the existing agent.\",\n ),\n },\n );\n }\n } else {\n // Interactive mode: prompt user (default No)\n const confirmed = await promptConfirm(\n \"Do you want to overwrite it?\",\n false,\n );\n if (!confirmed) {\n if (!options.json) {\n console.log(chalk.yellow(\"Compose cancelled.\"));\n }\n process.exit(0);\n }\n }\n }\n\n // Check for unsupported volumes\n if (hasVolumes(config)) {\n throw new Error(\"Volumes are not supported for GitHub URL compose\", {\n cause: new Error(\n \"Clone the repository locally and run: vm0 compose ./path/to/vm0.yaml\",\n ),\n });\n }\n\n // Upload instructions and skills\n await uploadAssets(agentName, agent, basePath, options.json);\n\n // Finalize compose (upload, display)\n return await finalizeCompose(config, agent, options);\n } finally {\n // Cleanup temp directory\n await rm(tempRoot, { recursive: true, force: true });\n }\n}\n\nexport const composeCommand = new Command()\n .name(\"compose\")\n .description(\"Create or update agent compose (e.g., vm0.yaml)\")\n .argument(\n \"[agent-yaml]\",\n `Path to agent YAML file or GitHub tree URL (default: ${DEFAULT_CONFIG_FILE})`,\n )\n .option(\"-y, --yes\", \"Skip confirmation prompts\")\n .option(\n \"--experimental-shared-compose\",\n \"[deprecated] No longer required, kept for backward compatibility\",\n )\n .option(\"--json\", \"Output JSON for scripts (suppresses interactive output)\")\n .option(\n \"--porcelain\",\n \"[deprecated: use --json] Output JSON for scripts\",\n false,\n )\n .addOption(new Option(\"--no-auto-update\").hideHelp())\n .action(\n withErrorHandler(\n async (\n configFile: string | undefined,\n options: {\n yes?: boolean;\n autoUpdate?: boolean;\n experimentalSharedCompose?: boolean;\n json?: boolean;\n porcelain?: boolean;\n },\n ) => {\n const resolvedConfigFile = configFile ?? DEFAULT_CONFIG_FILE;\n\n // Handle deprecated --porcelain flag\n if (options.porcelain && !options.json) {\n console.error(\n chalk.yellow(\"⚠ --porcelain is deprecated, use --json instead\"),\n );\n options.json = true;\n }\n\n // JSON mode implies --yes and disables auto-update (for CI/CD usage)\n if (options.json) {\n options.yes = true;\n options.autoUpdate = false;\n }\n\n // Start upgrade in background at command start (runs in parallel)\n if (options.autoUpdate !== false) {\n await startSilentUpgrade(__CLI_VERSION__);\n }\n\n try {\n let result: ComposeResult;\n\n // Branch based on input type\n if (isGitHubUrl(resolvedConfigFile)) {\n result = await handleGitHubCompose(resolvedConfigFile, options);\n } else {\n // Existing local file flow\n // 1. Load and validate config\n const { config, agentName, agent, basePath } =\n await loadAndValidateConfig(resolvedConfigFile);\n\n // 3. Upload instructions and skills\n await uploadAssets(agentName, agent, basePath, options.json);\n\n // 4. Finalize compose (upload, display)\n result = await finalizeCompose(config, agent, options);\n }\n\n // Output JSON result if requested\n if (options.json) {\n console.log(JSON.stringify(result));\n }\n } catch (error) {\n if (options.json) {\n const message =\n error instanceof Error\n ? error.message\n : \"An unexpected error occurred\";\n console.log(JSON.stringify({ error: message }));\n process.exit(1);\n }\n\n throw error;\n }\n },\n ),\n );\n","import { z } from \"zod\";\nimport {\n agentDefinitionSchema,\n volumeConfigSchema,\n resolveSkillRef,\n} from \"@vm0/core\";\n\n/**\n * CLI-specific agent name schema that allows 3-character names.\n * Pattern: start/end with alphanumeric, middle can have hyphens\n */\nconst cliAgentNameSchema = z\n .string()\n .min(3, \"Agent name must be at least 3 characters\")\n .max(64, \"Agent name must be 64 characters or less\")\n .regex(\n /^[a-zA-Z0-9]([a-zA-Z0-9-]{0,62}[a-zA-Z0-9])?$/,\n \"Agent name must start and end with letter or number, and contain only letters, numbers, and hyphens\",\n );\n\n/**\n * CLI-extended agent definition schema with skills URL validation\n *\n * Note: Framework validation is handled server-side.\n * The server rejects unsupported frameworks.\n */\nconst cliAgentDefinitionSchema = agentDefinitionSchema.superRefine(\n (agent, ctx) => {\n // Validate skills: bare names or full GitHub URLs\n if (agent.skills) {\n for (let i = 0; i < agent.skills.length; i++) {\n const skillRef = agent.skills[i];\n if (skillRef) {\n try {\n resolveSkillRef(skillRef);\n } catch (error) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message:\n error instanceof Error\n ? error.message\n : `Invalid skill reference: ${skillRef}`,\n path: [\"skills\", i],\n });\n }\n }\n }\n }\n },\n);\n\n/**\n * CLI compose schema with single-agent rule and volume mount validation\n */\nconst cliComposeSchema = z\n .object({\n version: z.string().min(1, \"Missing config.version\"),\n agents: z.record(cliAgentNameSchema, cliAgentDefinitionSchema),\n volumes: z.record(z.string(), volumeConfigSchema).optional(),\n })\n .superRefine((config, ctx) => {\n const agentKeys = Object.keys(config.agents);\n\n // CLI business rule: at least one agent required\n if (agentKeys.length === 0) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: \"agents must have at least one agent defined\",\n path: [\"agents\"],\n });\n return;\n }\n\n // CLI business rule: only one agent allowed\n if (agentKeys.length > 1) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: \"Multiple agents not supported yet. Only one agent allowed.\",\n path: [\"agents\"],\n });\n return;\n }\n\n // Volume mount validation\n const agentName = agentKeys[0]!;\n const agent = config.agents[agentName];\n const agentVolumes = agent?.volumes;\n\n if (agentVolumes && agentVolumes.length > 0) {\n if (!config.volumes) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message:\n \"Agent references volumes but no volumes section defined. Each volume must have explicit name and version.\",\n path: [\"volumes\"],\n });\n return;\n }\n\n for (const volDeclaration of agentVolumes) {\n const parts = volDeclaration.split(\":\");\n if (parts.length !== 2) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Invalid volume declaration: ${volDeclaration}. Expected format: volume-key:/mount/path`,\n path: [\"agents\", agentName, \"volumes\"],\n });\n continue;\n }\n\n const volumeKey = parts[0]!.trim();\n if (!config.volumes[volumeKey]) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Volume \"${volumeKey}\" is not defined in volumes section. Each volume must have explicit name and version.`,\n path: [\"volumes\", volumeKey],\n });\n }\n }\n }\n });\n\n/**\n * Format an invalid_type Zod issue into a user-friendly message.\n * Returns null if no special formatting applies.\n */\nfunction formatInvalidTypeIssue(\n path: string,\n issue: z.ZodIssue & { expected?: string },\n): string | null {\n // Zod 4 uses 'input' instead of 'received' in types, but runtime has 'received'\n const received = (issue as unknown as { received?: string }).received;\n\n // Missing required fields (handles both \"Required\" and \"Invalid input:\" messages)\n const isMissing =\n received === \"undefined\" ||\n issue.message.includes(\"received undefined\") ||\n issue.message === \"Required\";\n\n if (path === \"version\" && isMissing) {\n return \"Missing config.version\";\n }\n if (path === \"agents\" && isMissing) {\n return \"Missing agents object in config\";\n }\n // Volume field errors\n if (path.startsWith(\"volumes.\") && path.endsWith(\".name\")) {\n const volumeKey = path.split(\".\")[1];\n return `Volume \"${volumeKey}\" must have a 'name' field (string)`;\n }\n if (path.startsWith(\"volumes.\") && path.endsWith(\".version\")) {\n const volumeKey = path.split(\".\")[1];\n return `Volume \"${volumeKey}\" must have a 'version' field (string)`;\n }\n // Array type errors\n if (issue.expected === \"array\") {\n const fieldName = path.replace(/^agents\\.[^.]+\\./, \"agent.\");\n return `${fieldName} must be an array`;\n }\n // Array element type errors (number where string expected)\n if (issue.expected === \"string\" && received === \"number\") {\n const fieldName = path.replace(/^agents\\.[^.]+\\./, \"agent.\");\n const match = fieldName.match(/^(agent\\.[^.]+)\\.\\d+$/);\n if (match) {\n return `Each entry in ${match[1]?.replace(\"agent.\", \"\")} must be a string`;\n }\n }\n return null;\n}\n\n/**\n * Formats a Zod error into a user-friendly string\n */\nfunction formatZodError(error: z.ZodError): string {\n const issue = error.issues[0];\n if (!issue) return \"Validation failed\";\n\n const path = issue.path.join(\".\");\n const message = issue.message;\n\n // Root-level errors or custom messages without path context\n if (!path) return message;\n\n // Handle invalid_type errors with user-friendly messages\n if (issue.code === \"invalid_type\") {\n const formatted = formatInvalidTypeIssue(path, issue);\n if (formatted) return formatted;\n }\n\n // Handle invalid_key for agent name key validation (Zod 4 uses invalid_key instead of invalid_string)\n if (issue.code === \"invalid_key\" && path.startsWith(\"agents.\")) {\n return \"Invalid agent name format. Must be 3-64 characters, letters, numbers, and hyphens only. Must start and end with letter or number.\";\n }\n\n // Handle invalid key in record (agent name validation)\n if (message === \"Invalid key in record\" && path.startsWith(\"agents.\")) {\n return \"Invalid agent name format. Must be 3-64 characters, letters, numbers, and hyphens only. Must start and end with letter or number.\";\n }\n\n // Handle custom errors (our superRefine messages) - return without path prefix\n if (issue.code === \"custom\") {\n return message;\n }\n\n // Handle agent-level errors with cleaner paths\n if (path.startsWith(\"agents.\")) {\n const cleanPath = path.replace(/^agents\\.[^.]+\\./, \"agent.\");\n // For \"Invalid input\" messages, provide cleaner error\n if (message.startsWith(\"Invalid input:\")) {\n const match = message.match(/expected (\\w+), received (\\w+)/);\n if (match && match[1] === \"string\" && match[2] === \"number\") {\n const fieldMatch = cleanPath.match(/^(agent\\.[^.]+)\\.\\d+$/);\n if (fieldMatch) {\n return `Each entry in ${fieldMatch[1]?.replace(\"agent.\", \"\")} must be a string`;\n }\n }\n }\n return `${cleanPath}: ${message}`;\n }\n\n return `${path}: ${message}`;\n}\n\n/**\n * Validates agent.name format\n */\nexport function validateAgentName(name: string): boolean {\n return cliAgentNameSchema.safeParse(name).success;\n}\n\n/**\n * Known fields in agent definition schema, derived from the Zod schema shape.\n * Used for typo detection against unknown fields in YAML config.\n */\nconst KNOWN_AGENT_FIELDS = Object.keys(agentDefinitionSchema.shape);\n\n/**\n * Computes Levenshtein edit distance between two strings.\n * Uses single-row DP optimization for O(min(m,n)) space.\n */\nfunction levenshteinDistance(a: string, b: string): number {\n if (a === b) return 0;\n if (a.length === 0) return b.length;\n if (b.length === 0) return a.length;\n\n // Ensure a is the shorter string for space optimization\n if (a.length > b.length) [a, b] = [b, a];\n\n const row = Array.from({ length: a.length + 1 }, (_, i) => i);\n\n for (let j = 1; j <= b.length; j++) {\n let prev = j - 1;\n row[0] = j;\n for (let i = 1; i <= a.length; i++) {\n const cost = a[i - 1] === b[j - 1] ? 0 : 1;\n const current = Math.min(\n row[i]! + 1, // deletion\n row[i - 1]! + 1, // insertion\n prev + cost, // substitution\n );\n prev = row[i]!;\n row[i] = current;\n }\n }\n\n return row[a.length]!;\n}\n\n/**\n * Finds the most similar known field for an unknown field name.\n * Uses two strategies:\n * 1. Levenshtein distance ≤ 2 for close typos (e.g., \"environments\" → \"environment\")\n * 2. Prefix containment for abbreviations (e.g., \"env\" → \"environment\")\n *\n * Returns the best matching field name, or null if no match found.\n */\nfunction findSimilarField(\n unknown: string,\n knownFields: string[],\n): string | null {\n let bestMatch: string | null = null;\n let bestDistance = Infinity;\n\n for (const known of knownFields) {\n if (unknown === known) continue;\n\n // Check 1: Levenshtein distance ≤ 2\n const distance = levenshteinDistance(unknown, known);\n if (distance <= 2 && distance < bestDistance) {\n bestDistance = distance;\n bestMatch = known;\n }\n\n // Check 2: Prefix containment (unknown is a prefix of known, min 3 chars)\n if (unknown.length >= 3 && known.startsWith(unknown) && !bestMatch) {\n bestMatch = known;\n }\n }\n\n return bestMatch;\n}\n\n/**\n * Extracts agent entries from raw config, with type guards.\n * Returns null if config structure is invalid for agent inspection.\n */\nfunction extractAgentEntries(\n config: unknown,\n): Record<string, Record<string, unknown>> | null {\n if (!config || typeof config !== \"object\") return null;\n const cfg = config as Record<string, unknown>;\n const agents = cfg.agents as\n | Record<string, Record<string, unknown>>\n | undefined;\n if (!agents || typeof agents !== \"object\" || Array.isArray(agents))\n return null;\n return agents;\n}\n\n/**\n * Checks for unknown fields in agent definitions that look like typos.\n * Returns an error message listing all detected typos, or null if none found.\n */\nfunction checkForFieldTypos(config: unknown): string | null {\n const agents = extractAgentEntries(config);\n if (!agents) return null;\n\n const errors: string[] = [];\n\n for (const [agentName, agent] of Object.entries(agents)) {\n if (!agent || typeof agent !== \"object\" || Array.isArray(agent)) continue;\n\n for (const field of Object.keys(agent)) {\n if (KNOWN_AGENT_FIELDS.includes(field)) continue;\n\n const suggestion = findSimilarField(field, KNOWN_AGENT_FIELDS);\n if (suggestion) {\n errors.push(\n `Unknown field \"${field}\" in agent \"${agentName}\". Did you mean \"${suggestion}\"?`,\n );\n }\n }\n }\n\n return errors.length > 0 ? errors.join(\"\\n\") : null;\n}\n\n/**\n * Checks for deprecated 'provider' field and returns migration error message\n */\nfunction checkForDeprecatedProvider(config: unknown): string | null {\n const agents = extractAgentEntries(config);\n if (!agents) return null;\n\n for (const agent of Object.values(agents)) {\n if (agent && typeof agent === \"object\" && !Array.isArray(agent)) {\n if (\"provider\" in agent && !(\"framework\" in agent)) {\n const providerValue = agent.provider;\n return `'provider' field is deprecated. Use 'framework' instead.\\n\\nChange in your vm0.yaml:\\n - provider: ${providerValue}\\n + framework: ${providerValue}`;\n }\n }\n }\n return null;\n}\n\n/**\n * Validates agent compose structure using Zod schemas\n */\nexport function validateAgentCompose(config: unknown): {\n valid: boolean;\n error?: string;\n} {\n // Pre-check: Deprecated 'provider' field\n const deprecationError = checkForDeprecatedProvider(config);\n if (deprecationError) {\n return { valid: false, error: deprecationError };\n }\n\n // Pre-check: Detect likely typos in agent definition fields\n const typoError = checkForFieldTypos(config);\n if (typoError) {\n return { valid: false, error: typoError };\n }\n\n // Pre-check: Better error for array agents (common mistake)\n if (\n config &&\n typeof config === \"object\" &&\n Array.isArray((config as Record<string, unknown>).agents)\n ) {\n return {\n valid: false,\n error:\n \"agents must be an object, not an array. Use format: agents: { agent-name: { ... } }\",\n };\n }\n\n // Pre-check: Basic object check\n if (!config || typeof config !== \"object\") {\n return { valid: false, error: \"Config must be an object\" };\n }\n\n // Main validation using CLI compose schema\n const result = cliComposeSchema.safeParse(config);\n if (!result.success) {\n return { valid: false, error: formatZodError(result.error) };\n }\n\n return { valid: true };\n}\n","import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\nimport {\n getInstructionsStorageName,\n getSkillStorageName as getCoreSkillStorageName,\n parseGitHubTreeUrl as parseGitHubTreeUrlCore,\n parseSkillFrontmatter,\n type ParsedGitHubTreeUrl,\n type SkillFrontmatter,\n} from \"@vm0/core\";\n\n// Re-export from @vm0/core for convenience\nexport { getInstructionsStorageName, type SkillFrontmatter };\n\n// Re-export git operations from boundary module for backward compatibility\nexport {\n downloadGitHubSkill,\n downloadGitHubDirectory,\n} from \"../external/git-client\";\n\n// Re-export the type with the local name for backwards compatibility\ntype ParsedGitHubUrl = ParsedGitHubTreeUrl;\n\n/**\n * Parse a GitHub tree URL into its components\n * Expected format: https://github.com/{owner}/{repo}/tree/{branch}/{path}\n *\n * Note: Branch names containing slashes (e.g., feature/foo) may not parse correctly.\n * The fullPath field is always correct and used for unique storage naming.\n *\n * @param url - GitHub tree URL\n * @returns Parsed URL components\n * @throws Error if URL format is invalid\n */\nexport function parseGitHubTreeUrl(url: string): ParsedGitHubUrl {\n const parsed = parseGitHubTreeUrlCore(url);\n if (!parsed) {\n throw new Error(\n `Invalid GitHub tree URL: ${url}. Expected format: https://github.com/{owner}/{repo}/tree/{branch}/{path}`,\n );\n }\n return parsed;\n}\n\n/**\n * Generate the storage name for an agent skill\n * Format: agent-skills@{fullPath}\n *\n * @param parsed - Parsed GitHub URL\n * @returns Storage name for the skill\n */\nexport function getSkillStorageName(parsed: ParsedGitHubUrl): string {\n return getCoreSkillStorageName(parsed.fullPath);\n}\n\n/**\n * Validate that a downloaded skill has the required SKILL.md file\n *\n * @param skillDir - Path to the downloaded skill directory\n * @returns True if valid, throws error otherwise\n */\nexport async function validateSkillDirectory(skillDir: string): Promise<void> {\n const skillMdPath = path.join(skillDir, \"SKILL.md\");\n try {\n await fs.access(skillMdPath);\n } catch {\n throw new Error(\n `Skill directory missing required SKILL.md file: ${skillDir}`,\n );\n }\n}\n\n/**\n * Read and parse SKILL.md frontmatter from a skill directory\n *\n * @param skillDir - Path to the skill directory\n * @returns Parsed frontmatter fields\n */\nexport async function readSkillFrontmatter(\n skillDir: string,\n): Promise<SkillFrontmatter> {\n const skillMdPath = path.join(skillDir, \"SKILL.md\");\n const content = await fs.readFile(skillMdPath, \"utf8\");\n return parseSkillFrontmatter(content);\n}\n","import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\nimport * as os from \"node:os\";\nimport { execFile } from \"node:child_process\";\nimport { promisify } from \"node:util\";\nimport {\n parseGitHubUrl as parseGitHubUrlCore,\n type ParsedGitHubTreeUrl,\n} from \"@vm0/core\";\n\nconst execFileAsync = promisify(execFile);\n\n/**\n * Sanitize a value intended as a git positional argument to prevent\n * second-order command injection via flags like `--upload-pack`.\n * Only allows safe characters (alphanumeric, dash, underscore, dot, slash).\n * Returns the value if safe; throws otherwise.\n */\nfunction sanitizeGitArg(value: string, label: string): string {\n if (!/^[a-zA-Z0-9._/\\-@]+$/.test(value)) {\n throw new Error(\n `Invalid ${label}: contains disallowed characters. Only alphanumeric, dash, underscore, dot, slash, and @ are permitted.`,\n );\n }\n if (value.startsWith(\"-\")) {\n throw new Error(`Invalid ${label}: must not start with a dash`);\n }\n return value;\n}\n\n/**\n * Result of downloading a GitHub directory\n */\ninterface GitHubDownloadResult {\n /** Path to the downloaded directory */\n dir: string;\n /** Path to the temp root directory (for cleanup) */\n tempRoot: string;\n}\n\n/**\n * Download a GitHub directory using git sparse-checkout\n *\n * @param parsed - Parsed GitHub URL\n * @param destDir - Destination directory for the downloaded content\n * @returns Path to the downloaded skill directory\n */\nexport async function downloadGitHubSkill(\n parsed: ParsedGitHubTreeUrl,\n destDir: string,\n): Promise<string> {\n const owner = sanitizeGitArg(parsed.owner, \"repository owner\");\n const repo = sanitizeGitArg(parsed.repo, \"repository name\");\n const branch = sanitizeGitArg(parsed.branch, \"branch name\");\n const repoUrl = `https://github.com/${owner}/${repo}.git`;\n const skillDir = path.join(destDir, parsed.skillName);\n\n // Create a temporary directory for sparse checkout\n const tempDir = await fs.mkdtemp(path.join(os.tmpdir(), \"vm0-skill-\"));\n\n try {\n // Initialize sparse checkout\n await execFileAsync(\"git\", [\"init\"], { cwd: tempDir });\n await execFileAsync(\"git\", [\"remote\", \"add\", \"origin\", repoUrl], {\n cwd: tempDir,\n });\n await execFileAsync(\"git\", [\"config\", \"core.sparseCheckout\", \"true\"], {\n cwd: tempDir,\n });\n\n // Configure sparse checkout to only fetch the skill path\n // For root: use \"/*\" to get all root-level files\n // For path: use the path directly\n const sparsePattern = parsed.path || \"/*\";\n const sparseFile = path.join(tempDir, \".git\", \"info\", \"sparse-checkout\");\n await fs.writeFile(sparseFile, sparsePattern + \"\\n\");\n\n // Fetch only the required branch\n await execFileAsync(\"git\", [\"fetch\", \"--depth\", \"1\", \"origin\", branch], {\n cwd: tempDir,\n });\n await execFileAsync(\"git\", [\"checkout\", branch], { cwd: tempDir });\n\n // Move the skill directory to destination\n await fs.mkdir(path.dirname(skillDir), { recursive: true });\n if (parsed.path) {\n // Subdirectory: move the fetched subdirectory\n const fetchedPath = path.join(tempDir, parsed.path);\n await fs.rename(fetchedPath, skillDir);\n } else {\n // Root: move all entries except .git from tempDir\n await fs.mkdir(skillDir, { recursive: true });\n const entries = await fs.readdir(tempDir);\n for (const entry of entries) {\n if (entry === \".git\") continue;\n await fs.rename(path.join(tempDir, entry), path.join(skillDir, entry));\n }\n }\n\n return skillDir;\n } finally {\n // Clean up temp directory\n await fs.rm(tempDir, { recursive: true, force: true });\n }\n}\n\n/**\n * Get the default branch of a GitHub repository using git ls-remote.\n * This avoids dependency on gh CLI and works with just git installed.\n *\n * @param owner - Repository owner\n * @param repo - Repository name\n * @returns Default branch name\n */\nasync function getDefaultBranch(owner: string, repo: string): Promise<string> {\n const safeOwner = sanitizeGitArg(owner, \"repository owner\");\n const safeRepo = sanitizeGitArg(repo, \"repository name\");\n const repoUrl = `https://github.com/${safeOwner}/${safeRepo}.git`;\n try {\n // git ls-remote --symref outputs:\n // ref: refs/heads/main HEAD\n // a1b2c3d... HEAD\n const { stdout } = await execFileAsync(\"git\", [\n \"ls-remote\",\n \"--symref\",\n repoUrl,\n \"HEAD\",\n ]);\n\n // Extract branch name from \"ref: refs/heads/main\" line\n const match = stdout.match(/ref: refs\\/heads\\/([^\\s]+)/);\n if (!match) {\n throw new Error(\n `Could not determine default branch for ${owner}/${repo}`,\n );\n }\n return match[1]!;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n if (\n message.includes(\"not found\") ||\n message.includes(\"Repository not found\")\n ) {\n throw new Error(`Repository not found: ${owner}/${repo}`);\n }\n if (\n message.includes(\"Authentication failed\") ||\n message.includes(\"could not read Username\")\n ) {\n throw new Error(\n `Cannot access repository ${owner}/${repo}. Is it private?`,\n );\n }\n throw error;\n }\n}\n\n/**\n * Download a GitHub directory using git sparse-checkout.\n * Returns paths to both the downloaded directory and the temp root for cleanup.\n *\n * Supports multiple URL formats:\n * - https://github.com/owner/repo (plain repo, uses default branch, downloads root)\n * - https://github.com/owner/repo/tree/branch (root directory with explicit branch)\n * - https://github.com/owner/repo/tree/branch/path (subdirectory)\n *\n * @param url - GitHub URL\n * @returns Object with dir (downloaded path) and tempRoot (for cleanup)\n */\nexport async function downloadGitHubDirectory(\n url: string,\n): Promise<GitHubDownloadResult> {\n const parsed = parseGitHubUrlCore(url);\n if (!parsed) {\n throw new Error(\n `Invalid GitHub URL: ${url}. Expected format: https://github.com/{owner}/{repo}[/tree/{branch}[/path]]`,\n );\n }\n\n const safeOwner = sanitizeGitArg(parsed.owner, \"repository owner\");\n const safeRepo = sanitizeGitArg(parsed.repo, \"repository name\");\n const repoUrl = `https://github.com/${safeOwner}/${safeRepo}.git`;\n const tempDir = await fs.mkdtemp(path.join(os.tmpdir(), \"vm0-github-\"));\n\n try {\n // Check git is available\n try {\n await execFileAsync(\"git\", [\"--version\"]);\n } catch {\n throw new Error(\n \"git command not found. Please install git to use GitHub URLs.\",\n );\n }\n\n // Resolve branch if not specified\n const branch = sanitizeGitArg(\n parsed.branch ?? (await getDefaultBranch(safeOwner, safeRepo)),\n \"branch name\",\n );\n\n // Initialize sparse checkout\n await execFileAsync(\"git\", [\"init\"], { cwd: tempDir });\n await execFileAsync(\"git\", [\"remote\", \"add\", \"origin\", repoUrl], {\n cwd: tempDir,\n });\n await execFileAsync(\"git\", [\"config\", \"core.sparseCheckout\", \"true\"], {\n cwd: tempDir,\n });\n\n // Configure sparse checkout pattern\n // For root: use \"/*\" to get all root-level files\n // For path: use the path directly\n const sparsePattern = parsed.path ?? \"/*\";\n const sparseFile = path.join(tempDir, \".git\", \"info\", \"sparse-checkout\");\n await fs.writeFile(sparseFile, sparsePattern + \"\\n\");\n\n // Fetch only the required branch with better error handling\n try {\n await execFileAsync(\"git\", [\"fetch\", \"--depth\", \"1\", \"origin\", branch], {\n cwd: tempDir,\n });\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n if (\n message.includes(\"Authentication failed\") ||\n message.includes(\"could not read Username\")\n ) {\n throw new Error(`Cannot access repository. Is it private? URL: ${url}`);\n }\n if (message.includes(\"couldn't find remote ref\")) {\n throw new Error(`Branch \"${branch}\" not found in repository: ${url}`);\n }\n throw error;\n }\n\n await execFileAsync(\"git\", [\"checkout\", branch], { cwd: tempDir });\n\n // Return directory path\n // For root: return tempDir directly\n // For path: return tempDir/path\n const downloadedDir = parsed.path\n ? path.join(tempDir, parsed.path)\n : tempDir;\n\n return {\n dir: downloadedDir,\n tempRoot: tempDir,\n };\n } catch (error) {\n // Clean up on error\n await fs.rm(tempDir, { recursive: true, force: true });\n throw error;\n }\n}\n","import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\nimport * as os from \"node:os\";\nimport {\n parseGitHubTreeUrl,\n downloadGitHubSkill,\n getSkillStorageName,\n getInstructionsStorageName,\n validateSkillDirectory,\n readSkillFrontmatter,\n type SkillFrontmatter,\n} from \"../domain/github-skills\";\nimport { directUpload } from \"./direct-upload\";\nimport { getInstructionsFilename } from \"@vm0/core\";\n\ninterface StorageUploadResult {\n name: string;\n versionId: string;\n action: \"created\" | \"deduplicated\";\n}\n\n/**\n * Result of uploading or resolving a skill, including parsed frontmatter.\n * Action \"resolved\" means the skill was found in server cache (no download/upload needed).\n */\nexport interface SkillUploadResult {\n name: string;\n versionId: string;\n action: \"created\" | \"deduplicated\" | \"resolved\";\n skillName: string;\n frontmatter: SkillFrontmatter;\n}\n\n/**\n * Upload instructions file as a volume\n *\n * @param agentName - Name of the agent (used for storage name)\n * @param instructionsFilePath - Path to the instructions file (e.g., AGENTS.md)\n * @param basePath - Base path for resolving relative paths\n * @param framework - Framework name for determining canonical filename\n * @returns Upload result with storage name and version\n */\nexport async function uploadInstructions(\n agentName: string,\n instructionsFilePath: string,\n basePath: string,\n framework?: string,\n): Promise<StorageUploadResult> {\n // Normalize agent name to lowercase to match server's normalization behavior\n // Server normalizes agent names to lowercase when storing compose configs\n const storageName = getInstructionsStorageName(agentName.toLowerCase());\n\n // Resolve file path relative to base path\n const absolutePath = path.isAbsolute(instructionsFilePath)\n ? instructionsFilePath\n : path.join(basePath, instructionsFilePath);\n\n // Read the instructions file\n const content = await fs.readFile(absolutePath, \"utf8\");\n\n // Create a temporary directory with the file\n const tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), \"vm0-instructions-\"));\n const instructionsDir = path.join(tmpDir, \"instructions\");\n await fs.mkdir(instructionsDir);\n\n // Write file with framework-specific name (e.g., CLAUDE.md for claude-code)\n const filename = getInstructionsFilename(framework);\n await fs.writeFile(path.join(instructionsDir, filename), content);\n\n try {\n // Use direct upload (bypasses Vercel 4.5MB limit)\n const result = await directUpload(storageName, \"volume\", instructionsDir);\n\n return {\n name: storageName,\n versionId: result.versionId,\n action: result.deduplicated ? \"deduplicated\" : \"created\",\n };\n } finally {\n // Clean up temp directory\n await fs.rm(tmpDir, { recursive: true, force: true });\n }\n}\n\n/**\n * Upload a skill from GitHub as a volume\n *\n * @param skillUrl - GitHub tree URL for the skill\n * @returns Upload result with storage name, version, and parsed frontmatter\n */\nexport async function uploadSkill(\n skillUrl: string,\n): Promise<SkillUploadResult> {\n const parsed = parseGitHubTreeUrl(skillUrl);\n const storageName = getSkillStorageName(parsed);\n\n // Create temp directory for download\n const tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), \"vm0-skill-\"));\n\n try {\n // Download skill from GitHub\n const skillDir = await downloadGitHubSkill(parsed, tmpDir);\n\n // Validate the skill has SKILL.md\n await validateSkillDirectory(skillDir);\n\n // Parse frontmatter before upload\n const frontmatter = await readSkillFrontmatter(skillDir);\n\n // Use direct upload (bypasses Vercel 4.5MB limit)\n const result = await directUpload(storageName, \"volume\", skillDir);\n\n return {\n name: storageName,\n versionId: result.versionId,\n action: result.deduplicated ? \"deduplicated\" : \"created\",\n skillName: parsed.skillName,\n frontmatter,\n };\n } finally {\n // Clean up temp directory\n await fs.rm(tmpDir, { recursive: true, force: true });\n }\n}\n","import { createHash } from \"crypto\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport * as os from \"os\";\nimport * as tar from \"tar\";\nimport { prepareStorage, commitStorage } from \"../api\";\nimport { excludeVm0Filter } from \"../utils/file-utils\";\n\n/**\n * File entry with pre-computed hash for direct upload\n */\ninterface FileEntryWithHash {\n path: string;\n hash: string;\n size: number;\n}\n\n/**\n * Result of direct upload operation\n */\ninterface DirectUploadResult {\n versionId: string;\n size: number;\n fileCount: number;\n deduplicated: boolean;\n empty: boolean;\n}\n\n/**\n * Progress callback for upload operations\n */\ntype ProgressCallback = (message: string) => void;\n\n/**\n * Compute SHA-256 hash of a file using streaming to avoid loading large files into memory\n */\nasync function hashFileStream(filePath: string): Promise<string> {\n return new Promise((resolve, reject) => {\n const hash = createHash(\"sha256\");\n const stream = fs.createReadStream(filePath);\n\n stream.on(\"data\", (chunk) => hash.update(chunk));\n stream.on(\"end\", () => resolve(hash.digest(\"hex\")));\n stream.on(\"error\", reject);\n });\n}\n\n/**\n * Get all files in directory recursively, excluding .vm0/\n */\nasync function getAllFiles(\n dirPath: string,\n baseDir: string = dirPath,\n): Promise<string[]> {\n const files: string[] = [];\n const entries = await fs.promises.readdir(dirPath, { withFileTypes: true });\n\n for (const entry of entries) {\n const fullPath = path.join(dirPath, entry.name);\n const relativePath = path.relative(baseDir, fullPath);\n\n // Skip .vm0 directory\n if (relativePath.startsWith(\".vm0\")) {\n continue;\n }\n\n if (entry.isDirectory()) {\n const subFiles = await getAllFiles(fullPath, baseDir);\n files.push(...subFiles);\n } else {\n files.push(fullPath);\n }\n }\n\n return files;\n}\n\n/**\n * Collect file metadata with hashes using streaming to handle large files\n */\nasync function collectFileMetadata(\n cwd: string,\n files: string[],\n onProgress?: ProgressCallback,\n): Promise<FileEntryWithHash[]> {\n const fileEntries: FileEntryWithHash[] = [];\n\n for (let i = 0; i < files.length; i++) {\n const file = files[i]!;\n const relativePath = path.relative(cwd, file);\n\n // Use streaming hash to avoid loading large files into memory\n const [hash, stats] = await Promise.all([\n hashFileStream(file),\n fs.promises.stat(file),\n ]);\n\n fileEntries.push({\n path: relativePath,\n hash,\n size: stats.size,\n });\n\n // Report progress every 100 files\n if (onProgress && (i + 1) % 100 === 0) {\n onProgress(`Hashing files... ${i + 1}/${files.length}`);\n }\n }\n\n return fileEntries;\n}\n\n/**\n * Create tar.gz archive of files\n */\nasync function createArchive(cwd: string, files: string[]): Promise<Buffer> {\n const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), \"vm0-\"));\n const tarPath = path.join(tmpDir, \"archive.tar.gz\");\n\n try {\n const relativePaths = files.map((file) => path.relative(cwd, file));\n\n if (relativePaths.length > 0) {\n await tar.create(\n {\n gzip: true,\n file: tarPath,\n cwd: cwd,\n },\n relativePaths,\n );\n } else {\n // For empty directories, create tar.gz excluding .vm0\n await tar.create(\n {\n gzip: true,\n file: tarPath,\n cwd: cwd,\n filter: excludeVm0Filter,\n },\n [\".\"],\n );\n }\n\n const tarBuffer = await fs.promises.readFile(tarPath);\n return tarBuffer;\n } finally {\n // Clean up temp files\n if (fs.existsSync(tarPath)) {\n await fs.promises.unlink(tarPath);\n }\n await fs.promises.rmdir(tmpDir);\n }\n}\n\n/**\n * Create manifest JSON for the upload\n */\nfunction createManifest(files: FileEntryWithHash[]): Buffer {\n const manifest = {\n version: 1,\n files,\n createdAt: new Date().toISOString(),\n };\n return Buffer.from(JSON.stringify(manifest, null, 2));\n}\n\n/**\n * Sleep for a given number of milliseconds\n */\nfunction sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\n/**\n * Upload buffer to presigned URL with retry logic\n */\nasync function uploadToPresignedUrl(\n presignedUrl: string,\n data: Buffer,\n contentType: string,\n maxRetries: number = 3,\n): Promise<void> {\n let lastError: Error | null = null;\n\n for (let attempt = 1; attempt <= maxRetries; attempt++) {\n try {\n const response = await fetch(presignedUrl, {\n method: \"PUT\",\n body: data,\n headers: {\n \"Content-Type\": contentType,\n },\n });\n\n if (response.ok) {\n return;\n }\n\n // For 4xx errors (client errors), don't retry\n if (response.status >= 400 && response.status < 500) {\n const text = await response.text();\n throw new Error(`S3 upload failed: ${response.status} - ${text}`);\n }\n\n // For 5xx errors, retry with backoff\n const text = await response.text();\n lastError = new Error(`S3 upload failed: ${response.status} - ${text}`);\n } catch (error) {\n lastError =\n error instanceof Error ? error : new Error(\"Unknown upload error\");\n\n // Don't retry on client errors\n if (\n lastError.message.includes(\"400\") ||\n lastError.message.includes(\"403\")\n ) {\n throw lastError;\n }\n }\n\n // Exponential backoff: 1s, 2s, 4s...\n if (attempt < maxRetries) {\n const backoffMs = Math.pow(2, attempt - 1) * 1000;\n await sleep(backoffMs);\n }\n }\n\n throw lastError || new Error(\"S3 upload failed after retries\");\n}\n\n/**\n * Options for direct upload\n */\ninterface DirectUploadOptions {\n onProgress?: ProgressCallback;\n force?: boolean;\n}\n\n/**\n * Perform direct S3 upload for a storage (volume or artifact)\n *\n * This bypasses Vercel's 4.5MB request body limit by:\n * 1. Computing file hashes locally\n * 2. Getting presigned URLs from /api/storages/prepare\n * 3. Uploading directly to S3\n * 4. Committing via /api/storages/commit\n */\nexport async function directUpload(\n storageName: string,\n storageType: \"volume\" | \"artifact\" | \"memory\",\n cwd: string,\n options?: DirectUploadOptions,\n): Promise<DirectUploadResult> {\n const { onProgress, force } = options || {};\n\n // Step 1: Collect all files\n onProgress?.(\"Collecting files...\");\n const files = await getAllFiles(cwd);\n\n // Step 2: Compute hashes for all files\n onProgress?.(\"Computing file hashes...\");\n const fileEntries = await collectFileMetadata(cwd, files, onProgress);\n\n // Step 3: Call prepare endpoint\n onProgress?.(\"Preparing upload...\");\n const prepareResult = await prepareStorage({\n storageName,\n storageType,\n files: fileEntries,\n force,\n });\n\n // Step 4: Check if version already exists (deduplication)\n // Skip upload but still call commit to update HEAD (fixes #626)\n if (prepareResult.existing) {\n onProgress?.(\"Version exists, updating HEAD...\");\n\n const commitResult = await commitStorage({\n storageName,\n storageType,\n versionId: prepareResult.versionId,\n files: fileEntries,\n });\n\n return {\n versionId: commitResult.versionId,\n size: commitResult.size,\n fileCount: commitResult.fileCount,\n deduplicated: true,\n empty: commitResult.fileCount === 0,\n };\n }\n\n // Step 5: Create and upload archive (skip for empty artifacts)\n if (files.length > 0) {\n onProgress?.(\"Compressing files...\");\n const archiveBuffer = await createArchive(cwd, files);\n\n onProgress?.(\"Uploading archive to S3...\");\n if (!prepareResult.uploads) {\n throw new Error(\"No upload URLs received from prepare endpoint\");\n }\n\n await uploadToPresignedUrl(\n prepareResult.uploads.archive.presignedUrl,\n archiveBuffer,\n \"application/gzip\",\n );\n }\n\n // Step 6: Create and upload manifest\n onProgress?.(\"Uploading manifest...\");\n if (!prepareResult.uploads) {\n throw new Error(\"No upload URLs received from prepare endpoint\");\n }\n const manifestBuffer = createManifest(fileEntries);\n await uploadToPresignedUrl(\n prepareResult.uploads.manifest.presignedUrl,\n manifestBuffer,\n \"application/json\",\n );\n\n // Step 7: Commit the upload\n onProgress?.(\"Committing...\");\n const commitResult = await commitStorage({\n storageName,\n storageType,\n versionId: prepareResult.versionId,\n files: fileEntries,\n });\n\n return {\n versionId: commitResult.versionId,\n size: commitResult.size,\n fileCount: commitResult.fileCount,\n deduplicated: commitResult.deduplicated || false,\n empty: commitResult.fileCount === 0,\n };\n}\n","import * as fs from \"fs\";\nimport * as path from \"path\";\nimport * as tar from \"tar\";\n\n/**\n * Check if a directory exists and is empty (contains no files or subdirectories).\n * Returns: { exists: boolean, empty: boolean }\n * - Non-existent path: { exists: false, empty: true }\n * - Existing empty directory: { exists: true, empty: true }\n * - Existing non-empty directory: { exists: true, empty: false }\n * - Existing file (not directory): { exists: true, empty: false }\n */\nexport function checkDirectoryStatus(dirPath: string): {\n exists: boolean;\n empty: boolean;\n} {\n if (!fs.existsSync(dirPath)) {\n return { exists: false, empty: true };\n }\n\n const stat = fs.statSync(dirPath);\n if (!stat.isDirectory()) {\n // Path exists but is a file, not a directory\n return { exists: true, empty: false };\n }\n\n const entries = fs.readdirSync(dirPath);\n return { exists: true, empty: entries.length === 0 };\n}\n\n/**\n * Format bytes to human-readable format\n */\nexport function formatBytes(bytes: number): string {\n if (bytes === 0) return \"0 B\";\n const k = 1024;\n const sizes = [\"B\", \"KB\", \"MB\", \"GB\"];\n const i = Math.floor(Math.log(bytes) / Math.log(k));\n return `${(bytes / Math.pow(k, i)).toFixed(2)} ${sizes[i]}`;\n}\n\n/**\n * Format relative time from ISO date string\n */\nexport function formatRelativeTime(isoDate: string): string {\n const date = new Date(isoDate);\n const now = new Date();\n const diffMs = now.getTime() - date.getTime();\n const diffSec = Math.floor(diffMs / 1000);\n const diffMin = Math.floor(diffSec / 60);\n const diffHour = Math.floor(diffMin / 60);\n const diffDay = Math.floor(diffHour / 24);\n const diffWeek = Math.floor(diffDay / 7);\n\n if (diffSec < 60) return \"just now\";\n if (diffMin < 60) return `${diffMin} minute${diffMin === 1 ? \"\" : \"s\"} ago`;\n if (diffHour < 24) return `${diffHour} hour${diffHour === 1 ? \"\" : \"s\"} ago`;\n if (diffDay < 7) return `${diffDay} day${diffDay === 1 ? \"\" : \"s\"} ago`;\n return `${diffWeek} week${diffWeek === 1 ? \"\" : \"s\"} ago`;\n}\n\n/**\n * Filter function for tar.create to exclude .vm0 directory.\n * Paths come as \"./.vm0\" or \".vm0\" depending on tar version.\n */\nexport function excludeVm0Filter(filePath: string): boolean {\n const shouldExclude =\n filePath === \".vm0\" ||\n filePath.startsWith(\".vm0/\") ||\n filePath.startsWith(\"./.vm0\");\n return !shouldExclude;\n}\n\n/**\n * List files in tar.gz buffer using streaming parser.\n */\nexport function listTarFiles(tarPath: string): Promise<string[]> {\n return new Promise((resolve, reject) => {\n const files: string[] = [];\n\n tar\n .list({\n file: tarPath,\n onReadEntry: (entry) => {\n if (entry.type === \"File\") {\n files.push(entry.path);\n }\n },\n })\n .then(() => resolve(files))\n .catch(reject);\n });\n}\n\n/**\n * Recursively list all files in a directory, excluding specified directories.\n * Returns relative paths from the base directory.\n */\nasync function listLocalFiles(\n dir: string,\n excludeDirs: string[] = [\".vm0\"],\n): Promise<string[]> {\n const files: string[] = [];\n\n async function walkDir(currentDir: string, relativePath: string = \"\") {\n const entries = await fs.promises.readdir(currentDir, {\n withFileTypes: true,\n });\n\n for (const entry of entries) {\n const entryRelativePath = relativePath\n ? path.join(relativePath, entry.name)\n : entry.name;\n\n if (entry.isDirectory()) {\n if (!excludeDirs.includes(entry.name)) {\n await walkDir(path.join(currentDir, entry.name), entryRelativePath);\n }\n } else {\n files.push(entryRelativePath);\n }\n }\n }\n\n await walkDir(dir);\n return files;\n}\n\n/**\n * Remove files that exist locally but not in remote.\n * Returns the number of files removed.\n */\nexport async function removeExtraFiles(\n dir: string,\n remoteFiles: Set<string>,\n excludeDirs: string[] = [\".vm0\"],\n): Promise<number> {\n const localFiles = await listLocalFiles(dir, excludeDirs);\n let removedCount = 0;\n\n for (const localFile of localFiles) {\n // Normalize path separators for comparison\n const normalizedPath = localFile.replace(/\\\\/g, \"/\");\n if (!remoteFiles.has(normalizedPath)) {\n const fullPath = path.join(dir, localFile);\n await fs.promises.unlink(fullPath);\n removedCount++;\n }\n }\n\n // Clean up empty directories\n await removeEmptyDirs(dir, excludeDirs);\n\n return removedCount;\n}\n\n/**\n * Recursively remove empty directories, excluding specified directories.\n */\nasync function removeEmptyDirs(\n dir: string,\n excludeDirs: string[] = [\".vm0\"],\n): Promise<boolean> {\n const entries = await fs.promises.readdir(dir, { withFileTypes: true });\n\n let isEmpty = true;\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n\n if (entry.isDirectory()) {\n if (excludeDirs.includes(entry.name)) {\n isEmpty = false;\n } else {\n const subDirEmpty = await removeEmptyDirs(fullPath, excludeDirs);\n if (subDirEmpty) {\n await fs.promises.rmdir(fullPath);\n } else {\n isEmpty = false;\n }\n }\n } else {\n isEmpty = false;\n }\n }\n\n return isEmpty;\n}\n","import { Command, Option } from \"commander\";\nimport {\n getComposeById,\n getComposeByName,\n getComposeVersion,\n createRun,\n} from \"../../lib/api\";\nimport {\n collectKeyValue,\n collectVolumeVersions,\n isUUID,\n extractVarNames,\n extractSecretNames,\n loadValues,\n parseFirewallPolicies,\n parseIdentifier,\n pollEvents,\n showNextSteps,\n renderRunCreated,\n} from \"./shared\";\nimport {\n startSilentUpgrade,\n waitForSilentUpgrade,\n} from \"../../lib/utils/update-checker\";\nimport { withErrorHandler } from \"../../lib/command\";\n\ndeclare const __CLI_VERSION__: string;\n\nexport const mainRunCommand = new Command()\n .name(\"run\")\n .description(\"Run an agent\")\n .argument(\n \"<agent-name>\",\n \"Agent reference: [org/]name[:version] (e.g., 'my-agent', 'lancy/my-agent:abc123', 'my-agent:latest')\",\n )\n .argument(\"<prompt>\", \"Prompt for the agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\n \"--vars <KEY=value>\",\n \"Variables for ${{ vars.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--secrets <KEY=value>\",\n \"Secrets for ${{ secrets.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\"--artifact-name <name>\", \"Artifact storage name (required for run)\")\n .option(\n \"--artifact-version <hash>\",\n \"Artifact version hash (defaults to latest)\",\n )\n .option(\n \"--volume-version <name=version>\",\n \"Volume version override (repeatable, format: volumeName=version)\",\n collectVolumeVersions,\n {},\n )\n .option(\"--memory <name>\", \"Memory storage name\")\n .option(\n \"--conversation <id>\",\n \"Resume from conversation ID (for fine-grained control)\",\n )\n .option(\n \"--model-provider <type>\",\n \"Override model provider (e.g., anthropic-api-key)\",\n )\n .option(\n \"--append-system-prompt <text>\",\n \"Append text to the agent's system prompt\",\n )\n .option(\n \"--disallowed-tools <tools...>\",\n \"Tools to disable in Claude CLI (e.g., CronCreate WebSearch)\",\n )\n .option(\n \"--tools <tools...>\",\n \"Built-in tools to make available in Claude CLI (e.g., Bash Edit Read)\",\n )\n .option(\n \"--settings <json>\",\n \"Settings JSON to pass to Claude CLI (e.g., hooks, permissions)\",\n )\n .option(\n \"--firewall-policies <json>\",\n 'Firewall policies JSON (e.g., \\'{\"github\": {\"actions:read\": \"allow\"}}\\')',\n )\n .option(\"--verbose\", \"Show full tool inputs and outputs\")\n .option(\"--check-env\", \"Validate secrets and vars before running\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .addOption(new Option(\"--no-auto-update\").hideHelp())\n .action(\n withErrorHandler(\n async (\n identifier: string,\n prompt: string,\n options: {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n artifactName?: string;\n artifactVersion?: string;\n memory?: string;\n volumeVersion: Record<string, string>;\n conversation?: string;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n autoUpdate?: boolean;\n },\n ) => {\n // Start upgrade in background at command start (runs in parallel)\n if (options.autoUpdate !== false) {\n await startSilentUpgrade(__CLI_VERSION__);\n }\n\n // 1. Parse identifier for optional org and version specifier\n const { org, name, version } = parseIdentifier(identifier);\n\n // 2. Resolve name to composeId and get compose content\n let composeId: string;\n let composeContent: unknown;\n\n if (isUUID(name)) {\n // It's a UUID compose ID - fetch compose to get content\n const compose = await getComposeById(name);\n composeId = compose.id;\n composeContent = compose.content;\n } else {\n // It's an agent name - resolve to compose ID\n const compose = await getComposeByName(name, org);\n if (!compose) {\n throw new Error(`Agent not found: ${identifier}`, {\n cause: new Error(\n \"Make sure you've composed the agent with: vm0 compose\",\n ),\n });\n }\n\n composeId = compose.id;\n composeContent = compose.content;\n }\n\n // 3. Resolve version if specified\n let agentComposeVersionId: string | undefined;\n\n if (version && version !== \"latest\") {\n // Resolve version hash to full version ID\n try {\n const versionInfo = await getComposeVersion(composeId, version);\n agentComposeVersionId = versionInfo.versionId;\n } catch (error) {\n throw new Error(`Version not found: ${version}`, {\n cause: error instanceof Error ? error : undefined,\n });\n }\n }\n // Note: \"latest\" version uses agentComposeId which resolves to HEAD\n\n // 4. Load vars and secrets with priority: CLI args > --env-file > env vars\n const varNames = extractVarNames(composeContent);\n const vars = loadValues(options.vars, varNames, options.envFile);\n\n const secretNames = extractSecretNames(composeContent);\n const secrets = loadValues(\n options.secrets,\n secretNames,\n options.envFile,\n );\n\n // 5. Call unified API (server handles all variable expansion)\n const response = await createRun({\n // Use agentComposeVersionId if resolved, otherwise use agentComposeId (resolves to HEAD)\n ...(agentComposeVersionId\n ? { agentComposeVersionId }\n : { agentComposeId: composeId }),\n prompt,\n vars,\n secrets,\n artifactName: options.artifactName,\n artifactVersion: options.artifactVersion,\n memoryName: options.memory,\n volumeVersions:\n Object.keys(options.volumeVersion).length > 0\n ? options.volumeVersion\n : undefined,\n conversationId: options.conversation,\n modelProvider: options.modelProvider,\n appendSystemPrompt: options.appendSystemPrompt,\n disallowedTools: options.disallowedTools,\n tools: options.tools,\n settings: options.settings,\n firewallPolicies: parseFirewallPolicies(options.firewallPolicies),\n checkEnv: options.checkEnv || undefined,\n debugNoMockClaude: options.debugNoMockClaude || undefined,\n });\n\n // 4. Check for immediate failure (e.g., missing secrets)\n if (response.status === \"failed\") {\n throw new Error(\n \"Run preparation failed\",\n response.error ? { cause: new Error(response.error) } : undefined,\n );\n }\n\n // 5. Display run started/queued info\n renderRunCreated(response);\n\n // 6. Poll for events and exit with appropriate code\n const result = await pollEvents(response.runId, {\n verbose: options.verbose,\n });\n if (!result.succeeded) {\n throw new Error(\"Run failed\");\n }\n showNextSteps(result);\n\n // Wait for upgrade at command end (shows warning if failed)\n if (options.autoUpdate !== false) {\n await waitForSilentUpgrade();\n }\n },\n ),\n );\n","import { Command, Option } from \"commander\";\nimport { getCheckpoint, createRun } from \"../../lib/api\";\nimport {\n collectKeyValue,\n collectVolumeVersions,\n isUUID,\n loadValues,\n parseFirewallPolicies,\n pollEvents,\n showNextSteps,\n renderRunCreated,\n} from \"./shared\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const resumeCommand = new Command()\n .name(\"resume\")\n .description(\"Resume an agent run from a checkpoint (uses all snapshot data)\")\n .argument(\"<checkpointId>\", \"Checkpoint ID to resume from\")\n .argument(\"<prompt>\", \"Prompt for the resumed agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\n \"--vars <KEY=value>\",\n \"Variables for ${{ vars.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--secrets <KEY=value>\",\n \"Secrets for ${{ secrets.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--volume-version <name=version>\",\n \"Volume version override (repeatable)\",\n collectVolumeVersions,\n {},\n )\n .option(\n \"--model-provider <type>\",\n \"Override model provider (e.g., anthropic-api-key)\",\n )\n .option(\n \"--append-system-prompt <text>\",\n \"Append text to the agent's system prompt\",\n )\n .option(\n \"--disallowed-tools <tools...>\",\n \"Tools to disable in Claude CLI (e.g., CronCreate WebSearch)\",\n )\n .option(\n \"--tools <tools...>\",\n \"Built-in tools to make available in Claude CLI (e.g., Bash Edit Read)\",\n )\n .option(\n \"--settings <json>\",\n \"Settings JSON to pass to Claude CLI (e.g., hooks, permissions)\",\n )\n .option(\n \"--firewall-policies <json>\",\n 'Firewall policies JSON (e.g., \\'{\"github\": {\"actions:read\": \"allow\"}}\\')',\n )\n .option(\"--verbose\", \"Show full tool inputs and outputs\")\n .option(\"--check-env\", \"Validate secrets and vars before running\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .action(\n withErrorHandler(\n async (\n checkpointId: string,\n prompt: string,\n options: {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n },\n command: { optsWithGlobals: () => Record<string, unknown> },\n ) => {\n // Commander.js quirk: when parent command has same option name,\n // the option value goes to parent. Use optsWithGlobals() to get all options.\n const allOpts = command.optsWithGlobals() as {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n volumeVersion: Record<string, string>;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n };\n\n // Merge vars and secrets from command options\n const vars = { ...allOpts.vars, ...options.vars };\n const secrets = { ...allOpts.secrets, ...options.secrets };\n\n // 1. Validate checkpoint ID format\n if (!isUUID(checkpointId)) {\n throw new Error(`Invalid checkpoint ID format: ${checkpointId}`, {\n cause: new Error(\"Checkpoint ID must be a valid UUID\"),\n });\n }\n\n // 2. Fetch checkpoint info to get required secret names\n // This allows loading secrets from environment variables\n const checkpointInfo = await getCheckpoint(checkpointId);\n const requiredSecretNames =\n checkpointInfo.agentComposeSnapshot.secretNames || [];\n\n // 3. Load secrets from CLI options + --env-file + environment variables\n // Priority: CLI flags > --env-file > env vars\n const envFile = options.envFile || allOpts.envFile;\n const loadedSecrets = loadValues(secrets, requiredSecretNames, envFile);\n\n // 4. Call unified API with checkpointId\n const response = await createRun({\n checkpointId,\n prompt,\n vars: Object.keys(vars).length > 0 ? vars : undefined,\n secrets: loadedSecrets,\n volumeVersions:\n Object.keys(allOpts.volumeVersion).length > 0\n ? allOpts.volumeVersion\n : undefined,\n modelProvider: options.modelProvider || allOpts.modelProvider,\n appendSystemPrompt:\n options.appendSystemPrompt || allOpts.appendSystemPrompt,\n disallowedTools: options.disallowedTools || allOpts.disallowedTools,\n tools: options.tools || allOpts.tools,\n settings: options.settings || allOpts.settings,\n firewallPolicies: parseFirewallPolicies(\n options.firewallPolicies || allOpts.firewallPolicies,\n ),\n checkEnv: options.checkEnv || allOpts.checkEnv || undefined,\n debugNoMockClaude:\n options.debugNoMockClaude || allOpts.debugNoMockClaude || undefined,\n });\n\n // 4. Check for immediate failure (e.g., missing secrets)\n if (response.status === \"failed\") {\n throw new Error(\n \"Run preparation failed\",\n response.error ? { cause: new Error(response.error) } : undefined,\n );\n }\n\n // 5. Display run started/queued info\n renderRunCreated(response);\n\n // 6. Poll for events and exit with appropriate code\n const verbose = options.verbose || allOpts.verbose;\n const result = await pollEvents(response.runId, { verbose });\n if (!result.succeeded) {\n throw new Error(\"Run failed\");\n }\n showNextSteps(result);\n },\n ),\n );\n","import { Command, Option } from \"commander\";\nimport { getSession, createRun } from \"../../lib/api\";\nimport {\n collectKeyValue,\n isUUID,\n loadValues,\n parseFirewallPolicies,\n pollEvents,\n showNextSteps,\n renderRunCreated,\n} from \"./shared\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const continueCommand = new Command()\n .name(\"continue\")\n .description(\n \"Continue an agent run from a session (uses latest artifact version)\",\n )\n .argument(\"<agentSessionId>\", \"Agent session ID to continue from\")\n .argument(\"<prompt>\", \"Prompt for the continued agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\n \"--vars <KEY=value>\",\n \"Variables for ${{ vars.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--secrets <KEY=value>\",\n \"Secrets for ${{ secrets.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--model-provider <type>\",\n \"Override model provider (e.g., anthropic-api-key)\",\n )\n .option(\n \"--append-system-prompt <text>\",\n \"Append text to the agent's system prompt\",\n )\n .option(\n \"--disallowed-tools <tools...>\",\n \"Tools to disable in Claude CLI (e.g., CronCreate WebSearch)\",\n )\n .option(\n \"--tools <tools...>\",\n \"Built-in tools to make available in Claude CLI (e.g., Bash Edit Read)\",\n )\n .option(\n \"--settings <json>\",\n \"Settings JSON to pass to Claude CLI (e.g., hooks, permissions)\",\n )\n .option(\n \"--firewall-policies <json>\",\n 'Firewall policies JSON (e.g., \\'{\"github\": {\"actions:read\": \"allow\"}}\\')',\n )\n .option(\"--verbose\", \"Show full tool inputs and outputs\")\n .option(\"--check-env\", \"Validate secrets and vars before running\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .action(\n withErrorHandler(\n async (\n agentSessionId: string,\n prompt: string,\n options: {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n },\n command: { optsWithGlobals: () => Record<string, unknown> },\n ) => {\n // Commander.js quirk: when parent command has same option name,\n // the option value goes to parent. Use optsWithGlobals() to get all options.\n const allOpts = command.optsWithGlobals() as {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n };\n\n // Merge vars and secrets from command options\n const vars = { ...allOpts.vars, ...options.vars };\n const secrets = { ...allOpts.secrets, ...options.secrets };\n\n // 1. Validate session ID format\n if (!isUUID(agentSessionId)) {\n throw new Error(\n `Invalid agent session ID format: ${agentSessionId}`,\n { cause: new Error(\"Agent session ID must be a valid UUID\") },\n );\n }\n\n // 2. Fetch session info to get required secret names\n // This allows loading secrets from environment variables\n const sessionInfo = await getSession(agentSessionId);\n const requiredSecretNames = sessionInfo.secretNames || [];\n\n // 3. Load secrets from CLI options + --env-file + environment variables\n // Priority: CLI flags > --env-file > env vars\n const envFile = options.envFile || allOpts.envFile;\n const loadedSecrets = loadValues(secrets, requiredSecretNames, envFile);\n\n // 4. Call unified API with sessionId\n const response = await createRun({\n sessionId: agentSessionId,\n prompt,\n vars: Object.keys(vars).length > 0 ? vars : undefined,\n secrets: loadedSecrets,\n modelProvider: options.modelProvider || allOpts.modelProvider,\n appendSystemPrompt:\n options.appendSystemPrompt || allOpts.appendSystemPrompt,\n disallowedTools: options.disallowedTools || allOpts.disallowedTools,\n tools: options.tools || allOpts.tools,\n settings: options.settings || allOpts.settings,\n firewallPolicies: parseFirewallPolicies(\n options.firewallPolicies || allOpts.firewallPolicies,\n ),\n checkEnv: options.checkEnv || allOpts.checkEnv || undefined,\n debugNoMockClaude:\n options.debugNoMockClaude || allOpts.debugNoMockClaude || undefined,\n });\n\n // 4. Check for immediate failure (e.g., missing secrets)\n if (response.status === \"failed\") {\n throw new Error(\n \"Run preparation failed\",\n response.error ? { cause: new Error(response.error) } : undefined,\n );\n }\n\n // 5. Display run started/queued info\n renderRunCreated(response);\n\n // 6. Poll for events and exit with appropriate code\n const verbose = options.verbose || allOpts.verbose;\n const result = await pollEvents(response.runId, { verbose });\n if (!result.succeeded) {\n throw new Error(\"Run failed\");\n }\n showNextSteps(result);\n },\n ),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { listRuns } from \"../../lib/api\";\nimport { formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { parseTime } from \"../../lib/utils/time-parser\";\nimport { ALL_RUN_STATUSES, type RunStatus, type RunListItem } from \"@vm0/core\";\nimport { withErrorHandler } from \"../../lib/command\";\n\n/** Standard UUID string length (with hyphens) */\nconst UUID_LENGTH = 36;\n\n/** All valid status values as a string for help text */\nconst VALID_STATUSES = ALL_RUN_STATUSES.join(\",\");\n\n/**\n * Command options type\n */\ninterface ListOptions {\n status?: string;\n all?: boolean;\n agent?: string;\n since?: string;\n until?: string;\n limit?: string;\n}\n\n/**\n * Format run status with color and optional padding\n */\nfunction formatRunStatus(status: RunStatus, width?: number): string {\n const paddedStatus = width ? status.padEnd(width) : status;\n switch (status) {\n case \"queued\":\n return chalk.blue(paddedStatus);\n case \"running\":\n return chalk.green(paddedStatus);\n case \"pending\":\n return chalk.yellow(paddedStatus);\n case \"completed\":\n return chalk.dim(paddedStatus);\n case \"failed\":\n case \"timeout\":\n return chalk.red(paddedStatus);\n default:\n return paddedStatus;\n }\n}\n\n/**\n * Validate and parse status filter from options\n */\nfunction parseStatusFilter(options: ListOptions): string | undefined {\n if (options.all) {\n return VALID_STATUSES;\n }\n\n if (options.status) {\n const values = options.status.split(\",\").map((s) => s.trim());\n for (const v of values) {\n if (!ALL_RUN_STATUSES.includes(v as RunStatus)) {\n throw new Error(`Invalid status \"${v}\"`, {\n cause: new Error(`Valid values: ${VALID_STATUSES}`),\n });\n }\n }\n return values.join(\",\");\n }\n\n if (options.since) {\n // Implicit all when --since is used\n return VALID_STATUSES;\n }\n\n // undefined = backend default (pending,running)\n return undefined;\n}\n\n/**\n * Parse time option to ISO string\n */\nfunction parseTimeOption(value: string, optionName: string): string {\n try {\n return new Date(parseTime(value)).toISOString();\n } catch {\n throw new Error(\n `Invalid ${optionName} format. Use ISO (2026-01-01) or relative (1h, 7d, 30d)`,\n );\n }\n}\n\n/**\n * Parse and validate limit option\n */\nfunction parseLimit(value: string | undefined): number | undefined {\n if (!value) return undefined;\n\n const limit = parseInt(value, 10);\n if (isNaN(limit) || limit < 1 || limit > 100) {\n throw new Error(\"--limit must be between 1 and 100\");\n }\n return limit;\n}\n\n/**\n * Display runs in table format\n */\nfunction displayRuns(runs: RunListItem[]): void {\n // Calculate column widths\n const agentWidth = Math.max(5, ...runs.map((r) => r.agentName.length));\n const statusWidth = Math.max(6, ...runs.map((r) => r.status.length));\n\n // Print header\n const header = [\n \"ID\".padEnd(UUID_LENGTH),\n \"AGENT\".padEnd(agentWidth),\n \"STATUS\".padEnd(statusWidth),\n \"CREATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Print rows\n for (const run of runs) {\n const row = [\n run.id.padEnd(UUID_LENGTH),\n run.agentName.padEnd(agentWidth),\n formatRunStatus(run.status, statusWidth),\n formatRelativeTime(run.createdAt),\n ].join(\" \");\n console.log(row);\n }\n}\n\n/**\n * Display empty state message\n */\nfunction displayEmptyState(hasFilters: boolean): void {\n if (hasFilters) {\n console.log(chalk.dim(\"No runs found matching filters\"));\n } else {\n console.log(chalk.dim(\"No active runs\"));\n console.log(chalk.dim(' Run: vm0 run <agent> \"<prompt>\"'));\n }\n}\n\nexport const listCommand = new Command()\n .name(\"list\")\n .alias(\"ls\")\n .description(\"List runs\")\n .option(\n \"--status <status,...>\",\n `Filter by status: ${VALID_STATUSES} (default: pending,running)`,\n )\n .option(\"--all\", \"Show all statuses (mutually exclusive with --status)\")\n .option(\"--agent <name>\", \"Filter by agent name\")\n .option(\"--since <date>\", \"Start time (ISO format or relative: 1h, 7d, 30d)\")\n .option(\"--until <date>\", \"End time (defaults to now)\")\n .option(\"--limit <n>\", \"Maximum number of results (default: 50, max: 100)\")\n .action(\n withErrorHandler(async (options: ListOptions) => {\n // Validate mutual exclusion\n if (options.all && options.status) {\n throw new Error(\"--all and --status are mutually exclusive\");\n }\n\n // Parse options\n const statusFilter = parseStatusFilter(options);\n const since = options.since\n ? parseTimeOption(options.since, \"--since\")\n : undefined;\n const until = options.until\n ? parseTimeOption(options.until, \"--until\")\n : undefined;\n const limit = parseLimit(options.limit);\n\n // Validate since < until\n if (since && until && new Date(since) >= new Date(until)) {\n throw new Error(\"--since must be before --until\");\n }\n\n // Fetch runs with filters\n const response = await listRuns({\n status: statusFilter,\n agent: options.agent,\n since,\n until,\n limit,\n });\n\n const runs = response.runs;\n\n if (runs.length === 0) {\n const hasFilters = !!(\n options.status ||\n options.all ||\n options.agent ||\n options.since\n );\n displayEmptyState(hasFilters);\n return;\n }\n\n displayRuns(runs);\n }),\n );\n","/**\n * Time parser utility for --since option\n *\n * Supports:\n * - Relative time: 5s, 10m, 2h, 1d, 1w (seconds, minutes, hours, days, weeks)\n * - Absolute time: ISO 8601 format (2024-01-15T10:30:00Z)\n * - Unix timestamp: 1705312200 or 1705312200000 (seconds or milliseconds)\n */\n\n/**\n * Parse a time string and return a Unix timestamp in milliseconds\n * @param timeStr - Time string to parse\n * @returns Unix timestamp in milliseconds\n * @throws Error if the time string is invalid\n */\nexport function parseTime(timeStr: string): number {\n // Try relative time first (e.g., \"5m\", \"2h\", \"1d\")\n const relativeMatch = timeStr.match(/^(\\d+)([smhdw])$/);\n if (relativeMatch) {\n const value = parseInt(relativeMatch[1]!, 10);\n const unit = relativeMatch[2]!;\n return parseRelativeTime(value, unit);\n }\n\n // Try Unix timestamp (seconds or milliseconds)\n if (/^\\d+$/.test(timeStr)) {\n const timestamp = parseInt(timeStr, 10);\n // If timestamp is less than year 2000 in seconds, assume it's already in ms\n // If it looks like seconds (< 10000000000), convert to ms\n if (timestamp < 10000000000) {\n return timestamp * 1000;\n }\n return timestamp;\n }\n\n // Try ISO 8601 format\n const date = new Date(timeStr);\n if (!isNaN(date.getTime())) {\n return date.getTime();\n }\n\n throw new Error(\n `Invalid time format: \"${timeStr}\". ` +\n `Supported formats: relative (5m, 2h, 1d), ISO 8601 (2024-01-15T10:30:00Z), Unix timestamp`,\n );\n}\n\n/**\n * Parse relative time and return Unix timestamp in milliseconds\n */\nfunction parseRelativeTime(value: number, unit: string): number {\n const now = Date.now();\n const multipliers: Record<string, number> = {\n s: 1000, // seconds\n m: 60 * 1000, // minutes\n h: 60 * 60 * 1000, // hours\n d: 24 * 60 * 60 * 1000, // days\n w: 7 * 24 * 60 * 60 * 1000, // weeks\n };\n\n const multiplier = multipliers[unit];\n if (!multiplier) {\n throw new Error(`Unknown time unit: ${unit}`);\n }\n\n return now - value * multiplier;\n}\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cancelRun } from \"../../lib/api\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const killCommand = new Command()\n .name(\"kill\")\n .description(\"Kill (cancel) a pending or running run\")\n .argument(\"<run-id>\", \"Run ID to kill\")\n .action(\n withErrorHandler(async (runId: string) => {\n await cancelRun(runId);\n console.log(chalk.green(`✓ Run ${runId} cancelled`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { getRunQueue } from \"../../lib/api\";\nimport { formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const queueCommand = new Command()\n .name(\"queue\")\n .description(\"Show org run queue status\")\n .action(\n withErrorHandler(async () => {\n const data = await getRunQueue();\n const { concurrency, queue } = data;\n\n // Concurrency header\n const limitDisplay =\n concurrency.limit === 0\n ? \"unlimited\"\n : `${concurrency.active}/${concurrency.limit} slots used`;\n console.log(`Concurrency: ${limitDisplay} (${concurrency.tier} tier)`);\n\n // Queue status\n if (queue.length === 0) {\n console.log(chalk.dim(\"Queue: empty — all slots available\"));\n return;\n }\n\n console.log(\n `Queue: ${queue.length} run${queue.length > 1 ? \"s\" : \"\"} waiting`,\n );\n console.log();\n\n // Dynamic column widths\n const posWidth = Math.max(1, String(queue.length).length);\n const agentWidth = Math.max(\n 5,\n ...queue.map((e) => (e.agentName ?? \"-\").length),\n );\n const emailWidth = Math.max(\n 4,\n ...queue.map((e) => (e.userEmail ?? \"-\").length),\n );\n\n // Header\n const header = [\n \"#\".padEnd(posWidth),\n \"AGENT\".padEnd(agentWidth),\n \"USER\".padEnd(emailWidth),\n \"CREATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Rows\n for (const entry of queue) {\n const marker = entry.runId !== null ? chalk.cyan(\" ← you\") : \"\";\n const row = [\n String(entry.position).padEnd(posWidth),\n (entry.agentName ?? \"-\").padEnd(agentWidth),\n (entry.userEmail ?? \"-\").padEnd(emailWidth),\n formatRelativeTime(entry.createdAt),\n ].join(\" \");\n console.log(row + marker);\n }\n }),\n );\n","import { mainRunCommand } from \"./run\";\nimport { resumeCommand } from \"./resume\";\nimport { continueCommand } from \"./continue\";\nimport { listCommand } from \"./list\";\nimport { killCommand } from \"./kill\";\nimport { queueCommand } from \"./queue\";\n\n// Add subcommands to the main run command\nmainRunCommand.addCommand(resumeCommand);\nmainRunCommand.addCommand(continueCommand);\nmainRunCommand.addCommand(listCommand);\nmainRunCommand.addCommand(killCommand);\nmainRunCommand.addCommand(queueCommand);\n\nexport const runCommand = mainRunCommand;\n","import { Command } from \"commander\";\nimport { initCommand } from \"./init\";\nimport { pushCommand } from \"./push\";\nimport { pullCommand } from \"./pull\";\nimport { statusCommand } from \"./status\";\nimport { listCommand } from \"./list\";\nimport { cloneCommand } from \"./clone\";\n\nexport const volumeCommand = new Command()\n .name(\"volume\")\n .description(\"Manage volumes (defined in compose, not versioned after run)\")\n .addCommand(initCommand)\n .addCommand(pushCommand)\n .addCommand(pullCommand)\n .addCommand(statusCommand)\n .addCommand(listCommand)\n .addCommand(cloneCommand);\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport {\n isValidStorageName,\n writeStorageConfig,\n readStorageConfig,\n} from \"../../lib/storage/storage-utils\";\nimport { promptText, isInteractive } from \"../../lib/utils/prompt-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const initCommand = new Command()\n .name(\"init\")\n .description(\"Initialize a volume in the current directory\")\n .option(\"-n, --name <name>\", \"Volume name (required in non-interactive mode)\")\n .action(\n withErrorHandler(async (options: { name?: string }) => {\n const cwd = process.cwd();\n const dirName = path.basename(cwd);\n\n // Check if storage config already exists\n const existingConfig = await readStorageConfig(cwd);\n if (existingConfig) {\n console.log(\n chalk.yellow(`Volume already initialized: ${existingConfig.name}`),\n );\n console.log(\n chalk.dim(`Config file: ${path.join(cwd, \".vm0\", \"storage.yaml\")}`),\n );\n return;\n }\n\n // Determine volume name\n let volumeName: string;\n\n if (options.name) {\n // Use provided name (non-interactive mode)\n volumeName = options.name;\n } else if (!isInteractive()) {\n throw new Error(\"--name flag is required in non-interactive mode\", {\n cause: new Error(\"Usage: vm0 volume init --name <volume-name>\"),\n });\n } else {\n // Interactive prompt with directory name as default\n const defaultName = isValidStorageName(dirName) ? dirName : undefined;\n const name = await promptText(\n \"Enter volume name\",\n defaultName,\n (value: string) => {\n if (!isValidStorageName(value)) {\n return \"Must be 3-64 characters, lowercase alphanumeric with hyphens\";\n }\n return true;\n },\n );\n\n if (name === undefined) {\n // User cancelled\n console.log(chalk.dim(\"Cancelled\"));\n return;\n }\n\n volumeName = name;\n }\n\n // Validate volume name\n if (!isValidStorageName(volumeName)) {\n throw new Error(`Invalid volume name: \"${volumeName}\"`, {\n cause: new Error(\n \"Volume names must be 3-64 characters, lowercase alphanumeric with hyphens\",\n ),\n });\n }\n\n // Write config file\n await writeStorageConfig(volumeName, cwd);\n\n console.log(chalk.green(`✓ Initialized volume: ${volumeName}`));\n console.log(\n chalk.dim(\n ` Config saved to ${path.join(cwd, \".vm0\", \"storage.yaml\")}`,\n ),\n );\n }),\n );\n","import { readFile, writeFile, mkdir } from \"fs/promises\";\nimport { existsSync } from \"fs\";\nimport { parse as parseYaml, stringify as stringifyYaml } from \"yaml\";\nimport path from \"path\";\n\n/**\n * Storage type\n * - \"volume\": Static storage that doesn't auto-version after runs\n * - \"artifact\": Work products that auto-version after runs\n */\nexport type StorageType = \"volume\" | \"artifact\" | \"memory\";\n\ninterface StorageConfig {\n name: string;\n type: StorageType;\n}\n\nconst CONFIG_DIR = \".vm0\";\nconst CONFIG_FILE = \"storage.yaml\";\n\n/**\n * Validate storage name format\n * Length: 3-64 characters\n * Characters: lowercase letters, numbers, hyphens\n * Must start and end with alphanumeric\n * No consecutive hyphens\n */\nexport function isValidStorageName(name: string): boolean {\n if (name.length < 3 || name.length > 64) {\n return false;\n }\n const pattern = /^[a-z0-9][a-z0-9-]{1,62}[a-z0-9]$/;\n return pattern.test(name) && !name.includes(\"--\");\n}\n\n/**\n * Read storage config from .vm0/storage.yaml\n * Also supports legacy .vm0/volume.yaml for backward compatibility\n */\nexport async function readStorageConfig(\n basePath: string = process.cwd(),\n): Promise<StorageConfig | null> {\n const configPath = path.join(basePath, CONFIG_DIR, CONFIG_FILE);\n const legacyConfigPath = path.join(basePath, CONFIG_DIR, \"volume.yaml\");\n\n // Check for new config file first, then legacy\n let actualPath: string | null = null;\n if (existsSync(configPath)) {\n actualPath = configPath;\n } else if (existsSync(legacyConfigPath)) {\n actualPath = legacyConfigPath;\n }\n\n if (!actualPath) {\n return null;\n }\n\n const content = await readFile(actualPath, \"utf8\");\n const config = parseYaml(content) as StorageConfig;\n\n // Default to \"volume\" type for backward compatibility\n if (!config.type) {\n config.type = \"volume\";\n }\n\n return config;\n}\n\n/**\n * Write storage config to .vm0/storage.yaml\n */\nexport async function writeStorageConfig(\n storageName: string,\n basePath: string = process.cwd(),\n type: StorageType = \"volume\",\n): Promise<void> {\n const configDir = path.join(basePath, CONFIG_DIR);\n const configPath = path.join(configDir, CONFIG_FILE);\n\n // Create .vm0 directory if it doesn't exist\n if (!existsSync(configDir)) {\n await mkdir(configDir, { recursive: true });\n }\n\n const config: StorageConfig = {\n name: storageName,\n type,\n };\n\n const yamlContent = stringifyYaml(config);\n await writeFile(configPath, yamlContent, \"utf8\");\n}\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { directUpload } from \"../../lib/storage/direct-upload\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pushCommand = new Command()\n .name(\"push\")\n .description(\"Push local files to cloud volume\")\n .option(\n \"-f, --force\",\n \"Force upload even if content unchanged (recreate archive)\",\n )\n .action(\n withErrorHandler(async (options: { force?: boolean }) => {\n const cwd = process.cwd();\n\n // Read storage config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No volume initialized in this directory\", {\n cause: new Error(\"Run: vm0 volume init\"),\n });\n }\n\n console.log(`Pushing volume: ${config.name}`);\n\n // Perform direct S3 upload\n const result = await directUpload(config.name, \"volume\", cwd, {\n onProgress: (message) => {\n console.log(chalk.dim(message));\n },\n force: options.force,\n });\n\n // Display short version (8 characters) by default\n const shortVersion = result.versionId.slice(0, 8);\n\n if (result.empty) {\n console.log(chalk.dim(\"No files found (empty volume)\"));\n } else if (result.deduplicated) {\n console.log(chalk.green(\"✓ Content unchanged (deduplicated)\"));\n } else {\n console.log(chalk.green(\"✓ Upload complete\"));\n }\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${result.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(result.size)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport * as fs from \"fs\";\nimport * as os from \"os\";\nimport * as tar from \"tar\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload } from \"../../lib/api\";\nimport {\n formatBytes,\n listTarFiles,\n removeExtraFiles,\n} from \"../../lib/utils/file-utils\";\nimport { handleEmptyStorageResponse } from \"../../lib/storage/pull-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pullCommand = new Command()\n .name(\"pull\")\n .description(\"Pull cloud files to local directory\")\n .argument(\"[versionId]\", \"Version ID to pull (default: latest)\")\n .action(\n withErrorHandler(async (versionId?: string) => {\n const cwd = process.cwd();\n\n // Read storage config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No volume initialized in this directory\", {\n cause: new Error(\"Run: vm0 volume init\"),\n });\n }\n\n if (versionId) {\n console.log(`Pulling volume: ${config.name} (version: ${versionId})`);\n } else {\n console.log(`Pulling volume: ${config.name}`);\n }\n\n // Get download URL from API\n console.log(chalk.dim(\"Getting download URL...\"));\n\n const downloadInfo = await getStorageDownload({\n name: config.name,\n type: \"volume\",\n version: versionId,\n });\n\n // Handle empty volume\n if (\"empty\" in downloadInfo) {\n await handleEmptyStorageResponse(cwd);\n return;\n }\n\n const downloadUrl = downloadInfo.url;\n if (!downloadUrl) {\n throw new Error(\"No download URL returned\");\n }\n\n // Download directly from S3\n console.log(chalk.dim(\"Downloading from S3...\"));\n const s3Response = await fetch(downloadUrl);\n\n if (!s3Response.ok) {\n throw new Error(`S3 download failed: ${s3Response.status}`);\n }\n\n // Get tar.gz buffer\n const arrayBuffer = await s3Response.arrayBuffer();\n const tarBuffer = Buffer.from(arrayBuffer);\n\n console.log(chalk.green(`✓ Downloaded ${formatBytes(tarBuffer.length)}`));\n\n // Save tar.gz to temp file for processing\n const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), \"vm0-\"));\n const tarPath = path.join(tmpDir, \"volume.tar.gz\");\n await fs.promises.writeFile(tarPath, tarBuffer);\n\n // Get remote files list for sync\n console.log(chalk.dim(\"Syncing local files...\"));\n const remoteFiles = await listTarFiles(tarPath);\n const remoteFilesSet = new Set(\n remoteFiles.map((f) => f.replace(/\\\\/g, \"/\")),\n );\n\n // Remove local files not in remote\n const removedCount = await removeExtraFiles(cwd, remoteFilesSet);\n if (removedCount > 0) {\n console.log(\n chalk.green(`✓ Removed ${removedCount} files not in remote`),\n );\n }\n\n // Extract tar.gz\n console.log(chalk.dim(\"Extracting files...\"));\n await tar.extract({\n file: tarPath,\n cwd: cwd,\n gzip: true,\n });\n\n // Clean up temp files\n await fs.promises.unlink(tarPath);\n await fs.promises.rmdir(tmpDir);\n\n console.log(chalk.green(`✓ Extracted ${remoteFiles.length} files`));\n }),\n );\n","import chalk from \"chalk\";\nimport { removeExtraFiles } from \"../utils/file-utils\";\n\n/**\n * Result of handling an empty storage response (HTTP 204).\n */\ninterface EmptyStorageResult {\n removedCount: number;\n}\n\n/**\n * Handle empty storage response (HTTP 204 No Content).\n * Syncs local directory to empty state by removing all tracked files.\n *\n * @param cwd - Current working directory\n * @returns Result with count of removed files\n */\nexport async function handleEmptyStorageResponse(\n cwd: string,\n): Promise<EmptyStorageResult> {\n console.log(chalk.dim(\"Syncing local files...\"));\n\n // Sync to empty state - remove all local files\n const removedCount = await removeExtraFiles(cwd, new Set());\n\n if (removedCount > 0) {\n console.log(chalk.green(`✓ Removed ${removedCount} files not in remote`));\n }\n\n console.log(chalk.green(\"✓ Synced (0 files)\"));\n\n return { removedCount };\n}\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload, ApiRequestError } from \"../../lib/api\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const statusCommand = new Command()\n .name(\"status\")\n .description(\"Show status of cloud volume\")\n .action(\n withErrorHandler(async () => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No volume initialized in this directory\", {\n cause: new Error(\"Run: vm0 volume init\"),\n });\n }\n\n if (config.type !== \"volume\") {\n throw new Error(\n \"This directory is initialized as an artifact, not a volume\",\n { cause: new Error(\"Use: vm0 artifact status\") },\n );\n }\n\n // Start message\n console.log(`Checking volume: ${config.name}`);\n\n // Call API\n try {\n const info = await getStorageDownload({\n name: config.name,\n type: \"volume\",\n });\n const shortVersion = info.versionId.slice(0, 8);\n\n if (\"empty\" in info) {\n console.log(chalk.green(\"✓ Found (empty)\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n } else {\n console.log(chalk.green(\"✓ Found\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${info.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(info.size)}`));\n }\n } catch (error) {\n if (error instanceof ApiRequestError && error.status === 404) {\n throw new Error(\"Not found on remote\", {\n cause: new Error(\"Run: vm0 volume push\"),\n });\n }\n throw error;\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { listStorages } from \"../../lib/api\";\nimport { formatBytes, formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const listCommand = new Command()\n .name(\"list\")\n .alias(\"ls\")\n .description(\"List all remote volumes\")\n .action(\n withErrorHandler(async () => {\n // Call API\n const items = await listStorages({ type: \"volume\" });\n\n if (items.length === 0) {\n console.log(chalk.dim(\"No volumes found\"));\n console.log(\n chalk.dim(\" Create one with: vm0 volume init && vm0 volume push\"),\n );\n return;\n }\n\n // Calculate column widths\n const nameWidth = Math.max(4, ...items.map((i) => i.name.length));\n const sizeWidth = Math.max(\n 4,\n ...items.map((i) => formatBytes(i.size).length),\n );\n const filesWidth = Math.max(\n 5,\n ...items.map((i) => i.fileCount.toString().length),\n );\n\n // Print header\n const header = [\n \"NAME\".padEnd(nameWidth),\n \"SIZE\".padStart(sizeWidth),\n \"FILES\".padStart(filesWidth),\n \"UPDATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Print rows\n for (const item of items) {\n const row = [\n item.name.padEnd(nameWidth),\n formatBytes(item.size).padStart(sizeWidth),\n item.fileCount.toString().padStart(filesWidth),\n formatRelativeTime(item.updatedAt),\n ].join(\" \");\n console.log(row);\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cloneStorage } from \"../../lib/storage/clone-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const cloneCommand = new Command()\n .name(\"clone\")\n .description(\"Clone a remote volume to local directory (latest version)\")\n .argument(\"<name>\", \"Volume name to clone\")\n .argument(\"[destination]\", \"Destination directory (default: volume name)\")\n .action(\n withErrorHandler(async (name: string, destination: string | undefined) => {\n // Use volume name as destination if not specified\n const targetDir = destination || name;\n\n console.log(`Cloning volume: ${name}`);\n\n const result = await cloneStorage(name, \"volume\", targetDir);\n\n console.log(chalk.green(`\\n✓ Successfully cloned volume: ${name}`));\n console.log(chalk.dim(` Location: ${targetDir}/`));\n console.log(chalk.dim(` Version: ${result.versionId.slice(0, 8)}`));\n }),\n );\n","import chalk from \"chalk\";\nimport path from \"path\";\nimport * as fs from \"fs\";\nimport * as os from \"os\";\nimport * as tar from \"tar\";\nimport { writeStorageConfig, type StorageType } from \"./storage-utils\";\nimport { getStorageDownload } from \"../api\";\nimport {\n listTarFiles,\n formatBytes,\n checkDirectoryStatus,\n} from \"../utils/file-utils\";\n\ninterface CloneOptions {\n version?: string;\n}\n\ninterface CloneResult {\n success: boolean;\n fileCount: number;\n size: number;\n versionId: string;\n}\n\n/**\n * Clone a remote storage to a local directory\n * Creates the directory, downloads contents, and initializes .vm0 config\n */\nexport async function cloneStorage(\n name: string,\n type: StorageType,\n destination: string,\n options: CloneOptions = {},\n): Promise<CloneResult> {\n const typeLabel = type;\n\n // Check if destination already exists and is non-empty\n const dirStatus = checkDirectoryStatus(destination);\n if (dirStatus.exists && !dirStatus.empty) {\n throw new Error(`Directory \"${destination}\" is not empty`);\n }\n\n // Check if storage exists on remote\n console.log(chalk.dim(`Checking remote ${typeLabel}...`));\n\n const downloadInfo = await getStorageDownload({\n name,\n type,\n version: options.version,\n });\n\n // Create destination directory\n console.log(chalk.dim(`Creating directory: ${destination}/`));\n await fs.promises.mkdir(destination, { recursive: true });\n\n // Handle empty storage (type guard)\n if (\"empty\" in downloadInfo) {\n // Create .vm0 directory and config\n await writeStorageConfig(name, destination, type);\n\n console.log(chalk.green(`✓ Cloned empty ${typeLabel}: ${name}`));\n console.log(chalk.dim(`✓ Initialized .vm0/storage.yaml`));\n\n return {\n success: true,\n fileCount: 0,\n size: 0,\n versionId: downloadInfo.versionId,\n };\n }\n\n // TypeScript now knows downloadInfo has url property\n const downloadUrl = downloadInfo.url;\n if (!downloadUrl) {\n throw new Error(\"No download URL returned\");\n }\n\n // Download from S3\n console.log(chalk.dim(\"Downloading from S3...\"));\n const s3Response = await fetch(downloadUrl);\n\n if (!s3Response.ok) {\n // Clean up directory on failure\n await fs.promises.rm(destination, { recursive: true, force: true });\n throw new Error(`S3 download failed: ${s3Response.status}`);\n }\n\n // Get tar.gz buffer\n const arrayBuffer = await s3Response.arrayBuffer();\n const tarBuffer = Buffer.from(arrayBuffer);\n\n console.log(chalk.green(`✓ Downloaded ${formatBytes(tarBuffer.length)}`));\n\n // Save tar.gz to temp file for processing\n const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), \"vm0-clone-\"));\n const tarPath = path.join(tmpDir, \"archive.tar.gz\");\n await fs.promises.writeFile(tarPath, tarBuffer);\n\n // Get file list from tar\n const files = await listTarFiles(tarPath);\n\n // Extract tar.gz to destination\n console.log(chalk.dim(\"Extracting files...\"));\n await tar.extract({\n file: tarPath,\n cwd: destination,\n gzip: true,\n });\n\n // Clean up temp files\n await fs.promises.unlink(tarPath);\n await fs.promises.rmdir(tmpDir);\n\n console.log(chalk.green(`✓ Extracted ${files.length} files`));\n\n // Create .vm0 directory and config\n await writeStorageConfig(name, destination, type);\n console.log(chalk.green(`✓ Initialized .vm0/storage.yaml`));\n\n return {\n success: true,\n fileCount: downloadInfo.fileCount,\n size: downloadInfo.size,\n versionId: downloadInfo.versionId,\n };\n}\n","import { Command } from \"commander\";\nimport { initCommand } from \"./init\";\nimport { pushCommand } from \"./push\";\nimport { pullCommand } from \"./pull\";\nimport { statusCommand } from \"./status\";\nimport { listCommand } from \"./list\";\nimport { cloneCommand } from \"./clone\";\n\nexport const artifactCommand = new Command()\n .name(\"artifact\")\n .description(\"Manage artifacts (specified at run, versioned after run)\")\n .addCommand(initCommand)\n .addCommand(pushCommand)\n .addCommand(pullCommand)\n .addCommand(statusCommand)\n .addCommand(listCommand)\n .addCommand(cloneCommand);\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport {\n isValidStorageName,\n writeStorageConfig,\n readStorageConfig,\n} from \"../../lib/storage/storage-utils\";\nimport { promptText, isInteractive } from \"../../lib/utils/prompt-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const initCommand = new Command()\n .name(\"init\")\n .description(\"Initialize an artifact in the current directory\")\n .option(\n \"-n, --name <name>\",\n \"Artifact name (required in non-interactive mode)\",\n )\n .action(\n withErrorHandler(async (options: { name?: string }) => {\n const cwd = process.cwd();\n const dirName = path.basename(cwd);\n\n // Check if config already exists\n const existingConfig = await readStorageConfig(cwd);\n if (existingConfig) {\n if (existingConfig.type === \"artifact\") {\n console.log(\n chalk.yellow(\n `Artifact already initialized: ${existingConfig.name}`,\n ),\n );\n } else {\n console.log(\n chalk.yellow(\n `Directory already initialized as volume: ${existingConfig.name}`,\n ),\n );\n console.log(\n chalk.dim(\n \" To change type, delete .vm0/storage.yaml and reinitialize\",\n ),\n );\n }\n console.log(\n chalk.dim(`Config file: ${path.join(cwd, \".vm0\", \"storage.yaml\")}`),\n );\n return;\n }\n\n // Determine artifact name\n let artifactName: string;\n\n if (options.name) {\n // Use provided name (non-interactive mode)\n artifactName = options.name;\n } else if (!isInteractive()) {\n throw new Error(\"--name flag is required in non-interactive mode\", {\n cause: new Error(\"Usage: vm0 artifact init --name <artifact-name>\"),\n });\n } else {\n // Interactive prompt with directory name as default\n const defaultName = isValidStorageName(dirName) ? dirName : undefined;\n const name = await promptText(\n \"Enter artifact name\",\n defaultName,\n (value: string) => {\n if (!isValidStorageName(value)) {\n return \"Must be 3-64 characters, lowercase alphanumeric with hyphens\";\n }\n return true;\n },\n );\n\n if (name === undefined) {\n // User cancelled\n console.log(chalk.dim(\"Cancelled\"));\n return;\n }\n\n artifactName = name;\n }\n\n // Validate name\n if (!isValidStorageName(artifactName)) {\n throw new Error(`Invalid artifact name: \"${artifactName}\"`, {\n cause: new Error(\n \"Artifact names must be 3-64 characters, lowercase alphanumeric with hyphens\",\n ),\n });\n }\n\n // Write config file with type: artifact\n await writeStorageConfig(artifactName, cwd, \"artifact\");\n\n console.log(chalk.green(`✓ Initialized artifact: ${artifactName}`));\n console.log(\n chalk.dim(\n ` Config saved to ${path.join(cwd, \".vm0\", \"storage.yaml\")}`,\n ),\n );\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { directUpload } from \"../../lib/storage/direct-upload\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pushCommand = new Command()\n .name(\"push\")\n .description(\"Push local files to cloud artifact\")\n .option(\n \"-f, --force\",\n \"Force upload even if content unchanged (recreate archive)\",\n )\n .action(\n withErrorHandler(async (options: { force?: boolean }) => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No artifact initialized in this directory\", {\n cause: new Error(\"Run: vm0 artifact init\"),\n });\n }\n\n if (config.type !== \"artifact\") {\n throw new Error(\n \"This directory is initialized as a volume, not an artifact\",\n { cause: new Error(\"Use: vm0 volume push\") },\n );\n }\n\n console.log(`Pushing artifact: ${config.name}`);\n\n // Perform direct S3 upload\n const result = await directUpload(config.name, \"artifact\", cwd, {\n onProgress: (message) => {\n console.log(chalk.dim(message));\n },\n force: options.force,\n });\n\n // Display short version (8 characters) by default\n const shortVersion = result.versionId.slice(0, 8);\n\n if (result.empty) {\n console.log(chalk.dim(\"No files found (empty artifact)\"));\n } else if (result.deduplicated) {\n console.log(chalk.green(\"✓ Content unchanged (deduplicated)\"));\n } else {\n console.log(chalk.green(\"✓ Upload complete\"));\n }\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${result.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(result.size)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport * as fs from \"fs\";\nimport * as os from \"os\";\nimport * as tar from \"tar\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload } from \"../../lib/api\";\nimport {\n formatBytes,\n listTarFiles,\n removeExtraFiles,\n} from \"../../lib/utils/file-utils\";\nimport { handleEmptyStorageResponse } from \"../../lib/storage/pull-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pullCommand = new Command()\n .name(\"pull\")\n .description(\"Pull cloud artifact to local directory\")\n .argument(\"[versionId]\", \"Version ID to pull (default: latest)\")\n .action(\n withErrorHandler(async (versionId?: string) => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No artifact initialized in this directory\", {\n cause: new Error(\"Run: vm0 artifact init\"),\n });\n }\n\n if (config.type !== \"artifact\") {\n throw new Error(\n \"This directory is initialized as a volume, not an artifact\",\n { cause: new Error(\"Use: vm0 volume pull\") },\n );\n }\n\n if (versionId) {\n console.log(`Pulling artifact: ${config.name} (version: ${versionId})`);\n } else {\n console.log(`Pulling artifact: ${config.name}`);\n }\n\n // Get download URL from API\n console.log(chalk.dim(\"Getting download URL...\"));\n\n const downloadInfo = await getStorageDownload({\n name: config.name,\n type: \"artifact\",\n version: versionId,\n });\n\n // Handle empty artifact\n if (\"empty\" in downloadInfo) {\n await handleEmptyStorageResponse(cwd);\n return;\n }\n\n const downloadUrl = downloadInfo.url;\n if (!downloadUrl) {\n throw new Error(\"No download URL returned\");\n }\n\n // Download directly from S3\n console.log(chalk.dim(\"Downloading from S3...\"));\n const s3Response = await fetch(downloadUrl);\n\n if (!s3Response.ok) {\n throw new Error(`S3 download failed: ${s3Response.status}`);\n }\n\n // Get tar.gz buffer\n const arrayBuffer = await s3Response.arrayBuffer();\n const tarBuffer = Buffer.from(arrayBuffer);\n\n console.log(chalk.green(`✓ Downloaded ${formatBytes(tarBuffer.length)}`));\n\n // Save tar.gz to temp file for processing\n const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), \"vm0-\"));\n const tarPath = path.join(tmpDir, \"artifact.tar.gz\");\n await fs.promises.writeFile(tarPath, tarBuffer);\n\n // Get remote files list for sync\n console.log(chalk.dim(\"Syncing local files...\"));\n const remoteFiles = await listTarFiles(tarPath);\n const remoteFilesSet = new Set(\n remoteFiles.map((f) => f.replace(/\\\\/g, \"/\")),\n );\n\n // Remove local files not in remote\n const removedCount = await removeExtraFiles(cwd, remoteFilesSet);\n if (removedCount > 0) {\n console.log(\n chalk.green(`✓ Removed ${removedCount} files not in remote`),\n );\n }\n\n // Extract tar.gz\n console.log(chalk.dim(\"Extracting files...\"));\n await tar.extract({\n file: tarPath,\n cwd: cwd,\n gzip: true,\n });\n\n // Clean up temp files\n await fs.promises.unlink(tarPath);\n await fs.promises.rmdir(tmpDir);\n\n console.log(chalk.green(`✓ Extracted ${remoteFiles.length} files`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload, ApiRequestError } from \"../../lib/api\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const statusCommand = new Command()\n .name(\"status\")\n .description(\"Show status of cloud artifact\")\n .action(\n withErrorHandler(async () => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No artifact initialized in this directory\", {\n cause: new Error(\"Run: vm0 artifact init\"),\n });\n }\n\n if (config.type !== \"artifact\") {\n throw new Error(\n \"This directory is initialized as a volume, not an artifact\",\n { cause: new Error(\"Use: vm0 volume status\") },\n );\n }\n\n // Start message\n console.log(`Checking artifact: ${config.name}`);\n\n // Call API\n try {\n const info = await getStorageDownload({\n name: config.name,\n type: \"artifact\",\n });\n const shortVersion = info.versionId.slice(0, 8);\n\n if (\"empty\" in info) {\n console.log(chalk.green(\"✓ Found (empty)\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n } else {\n console.log(chalk.green(\"✓ Found\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${info.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(info.size)}`));\n }\n } catch (error) {\n if (error instanceof ApiRequestError && error.status === 404) {\n throw new Error(\"Not found on remote\", {\n cause: new Error(\"Run: vm0 artifact push\"),\n });\n }\n throw error;\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { listStorages } from \"../../lib/api\";\nimport { formatBytes, formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const listCommand = new Command()\n .name(\"list\")\n .alias(\"ls\")\n .description(\"List all remote artifacts\")\n .action(\n withErrorHandler(async () => {\n // Call API\n const items = await listStorages({ type: \"artifact\" });\n\n if (items.length === 0) {\n console.log(chalk.dim(\"No artifacts found\"));\n console.log(\n chalk.dim(\n \" Create one with: vm0 artifact init && vm0 artifact push\",\n ),\n );\n return;\n }\n\n // Calculate column widths\n const nameWidth = Math.max(4, ...items.map((i) => i.name.length));\n const sizeWidth = Math.max(\n 4,\n ...items.map((i) => formatBytes(i.size).length),\n );\n const filesWidth = Math.max(\n 5,\n ...items.map((i) => i.fileCount.toString().length),\n );\n\n // Print header\n const header = [\n \"NAME\".padEnd(nameWidth),\n \"SIZE\".padStart(sizeWidth),\n \"FILES\".padStart(filesWidth),\n \"UPDATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Print rows\n for (const item of items) {\n const row = [\n item.name.padEnd(nameWidth),\n formatBytes(item.size).padStart(sizeWidth),\n item.fileCount.toString().padStart(filesWidth),\n formatRelativeTime(item.updatedAt),\n ].join(\" \");\n console.log(row);\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cloneStorage } from \"../../lib/storage/clone-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const cloneCommand = new Command()\n .name(\"clone\")\n .description(\"Clone a remote artifact to local directory (latest version)\")\n .argument(\"<name>\", \"Artifact name to clone\")\n .argument(\"[destination]\", \"Destination directory (default: artifact name)\")\n .action(\n withErrorHandler(async (name: string, destination: string | undefined) => {\n // Use artifact name as destination if not specified\n const targetDir = destination || name;\n\n console.log(`Cloning artifact: ${name}`);\n\n const result = await cloneStorage(name, \"artifact\", targetDir);\n\n console.log(chalk.green(`\\n✓ Successfully cloned artifact: ${name}`));\n console.log(chalk.dim(` Location: ${targetDir}/`));\n console.log(chalk.dim(` Version: ${result.versionId.slice(0, 8)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport { initCommand } from \"./init\";\nimport { pushCommand } from \"./push\";\nimport { pullCommand } from \"./pull\";\nimport { statusCommand } from \"./status\";\nimport { listCommand } from \"./list\";\nimport { cloneCommand } from \"./clone\";\n\nexport const memoryCommand = new Command()\n .name(\"memory\")\n .description(\"Manage agent long-term memory\")\n .addCommand(initCommand)\n .addCommand(pushCommand)\n .addCommand(pullCommand)\n .addCommand(statusCommand)\n .addCommand(listCommand)\n .addCommand(cloneCommand);\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport {\n isValidStorageName,\n writeStorageConfig,\n readStorageConfig,\n} from \"../../lib/storage/storage-utils\";\nimport { promptText, isInteractive } from \"../../lib/utils/prompt-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const initCommand = new Command()\n .name(\"init\")\n .description(\"Initialize a memory in the current directory\")\n .option(\"-n, --name <name>\", \"Memory name (required in non-interactive mode)\")\n .action(\n withErrorHandler(async (options: { name?: string }) => {\n const cwd = process.cwd();\n const dirName = path.basename(cwd);\n\n // Check if config already exists\n const existingConfig = await readStorageConfig(cwd);\n if (existingConfig) {\n if (existingConfig.type === \"memory\") {\n console.log(\n chalk.yellow(`Memory already initialized: ${existingConfig.name}`),\n );\n } else {\n console.log(\n chalk.yellow(\n `Directory already initialized as ${existingConfig.type}: ${existingConfig.name}`,\n ),\n );\n console.log(\n chalk.dim(\n \" To change type, delete .vm0/storage.yaml and reinitialize\",\n ),\n );\n }\n console.log(\n chalk.dim(`Config file: ${path.join(cwd, \".vm0\", \"storage.yaml\")}`),\n );\n return;\n }\n\n // Determine memory name\n let memoryName: string;\n\n if (options.name) {\n memoryName = options.name;\n } else if (!isInteractive()) {\n throw new Error(\"--name flag is required in non-interactive mode\", {\n cause: new Error(\"Usage: vm0 memory init --name <memory-name>\"),\n });\n } else {\n // Interactive prompt with directory name as default\n const defaultName = isValidStorageName(dirName) ? dirName : undefined;\n const name = await promptText(\n \"Enter memory name\",\n defaultName,\n (value: string) => {\n if (!isValidStorageName(value)) {\n return \"Must be 3-64 characters, lowercase alphanumeric with hyphens\";\n }\n return true;\n },\n );\n\n if (name === undefined) {\n console.log(chalk.dim(\"Cancelled\"));\n return;\n }\n\n memoryName = name;\n }\n\n // Validate name\n if (!isValidStorageName(memoryName)) {\n throw new Error(`Invalid memory name: \"${memoryName}\"`, {\n cause: new Error(\n \"Memory names must be 3-64 characters, lowercase alphanumeric with hyphens\",\n ),\n });\n }\n\n // Write config file with type: memory\n await writeStorageConfig(memoryName, cwd, \"memory\");\n\n console.log(chalk.green(`✓ Initialized memory: ${memoryName}`));\n console.log(\n chalk.dim(\n ` Config saved to ${path.join(cwd, \".vm0\", \"storage.yaml\")}`,\n ),\n );\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { directUpload } from \"../../lib/storage/direct-upload\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pushCommand = new Command()\n .name(\"push\")\n .description(\"Push local files to cloud memory\")\n .option(\n \"-f, --force\",\n \"Force upload even if content unchanged (recreate archive)\",\n )\n .action(\n withErrorHandler(async (options: { force?: boolean }) => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No memory initialized in this directory\", {\n cause: new Error(\"Run: vm0 memory init\"),\n });\n }\n\n if (config.type !== \"memory\") {\n throw new Error(\n `This directory is initialized as ${config.type === \"artifact\" ? \"an artifact\" : \"a volume\"}, not a memory`,\n { cause: new Error(`Use: vm0 ${config.type} push`) },\n );\n }\n\n console.log(`Pushing memory: ${config.name}`);\n\n // Perform direct S3 upload\n const result = await directUpload(config.name, \"memory\", cwd, {\n onProgress: (message) => {\n console.log(chalk.dim(message));\n },\n force: options.force,\n });\n\n // Display short version (8 characters) by default\n const shortVersion = result.versionId.slice(0, 8);\n\n if (result.empty) {\n console.log(chalk.dim(\"No files found (empty memory)\"));\n } else if (result.deduplicated) {\n console.log(chalk.green(\"✓ Content unchanged (deduplicated)\"));\n } else {\n console.log(chalk.green(\"✓ Upload complete\"));\n }\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${result.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(result.size)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cloneStorage } from \"../../lib/storage/clone-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pullCommand = new Command()\n .name(\"pull\")\n .description(\"Pull remote memory to local directory (latest version)\")\n .argument(\"[name]\", \"Memory name to pull\", \"memory\")\n .argument(\"[destination]\", \"Destination directory (default: memory name)\")\n .action(\n withErrorHandler(async (name: string, destination: string | undefined) => {\n const targetDir = destination || name;\n\n console.log(`Pulling memory: ${name}`);\n\n const result = await cloneStorage(name, \"memory\", targetDir);\n\n console.log(chalk.green(`\\n✓ Successfully pulled memory: ${name}`));\n console.log(chalk.dim(` Location: ${targetDir}/`));\n console.log(chalk.dim(` Version: ${result.versionId.slice(0, 8)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload, ApiRequestError } from \"../../lib/api\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const statusCommand = new Command()\n .name(\"status\")\n .description(\"Show status of cloud memory\")\n .action(\n withErrorHandler(async () => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No memory initialized in this directory\", {\n cause: new Error(\"Run: vm0 memory init\"),\n });\n }\n\n if (config.type !== \"memory\") {\n throw new Error(\n `This directory is initialized as ${config.type === \"artifact\" ? \"an artifact\" : \"a volume\"}, not a memory`,\n { cause: new Error(`Use: vm0 ${config.type} status`) },\n );\n }\n\n // Start message\n console.log(`Checking memory: ${config.name}`);\n\n // Call API\n try {\n const info = await getStorageDownload({\n name: config.name,\n type: \"memory\",\n });\n const shortVersion = info.versionId.slice(0, 8);\n\n if (\"empty\" in info) {\n console.log(chalk.green(\"✓ Found (empty)\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n } else {\n console.log(chalk.green(\"✓ Found\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${info.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(info.size)}`));\n }\n } catch (error) {\n if (error instanceof ApiRequestError && error.status === 404) {\n throw new Error(\"Not found on remote\", {\n cause: new Error(\"Run: vm0 memory push\"),\n });\n }\n throw error;\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { listStorages } from \"../../lib/api\";\nimport { formatBytes, formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const listCommand = new Command()\n .name(\"list\")\n .alias(\"ls\")\n .description(\"List all remote memory storages\")\n .action(\n withErrorHandler(async () => {\n const items = await listStorages({ type: \"memory\" });\n\n if (items.length === 0) {\n console.log(chalk.dim(\"No memory storages found\"));\n console.log(\n chalk.dim(\" Memory is created automatically on first agent run\"),\n );\n return;\n }\n\n // Calculate column widths\n const nameWidth = Math.max(4, ...items.map((i) => i.name.length));\n const sizeWidth = Math.max(\n 4,\n ...items.map((i) => formatBytes(i.size).length),\n );\n const filesWidth = Math.max(\n 5,\n ...items.map((i) => i.fileCount.toString().length),\n );\n\n // Print header\n const header = [\n \"NAME\".padEnd(nameWidth),\n \"SIZE\".padStart(sizeWidth),\n \"FILES\".padStart(filesWidth),\n \"UPDATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Print rows\n for (const item of items) {\n const row = [\n item.name.padEnd(nameWidth),\n formatBytes(item.size).padStart(sizeWidth),\n item.fileCount.toString().padStart(filesWidth),\n formatRelativeTime(item.updatedAt),\n ].join(\" \");\n console.log(row);\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cloneStorage } from \"../../lib/storage/clone-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const cloneCommand = new Command()\n .name(\"clone\")\n .description(\"Clone a remote memory to local directory (latest version)\")\n .argument(\"<name>\", \"Memory name to clone\")\n .argument(\"[destination]\", \"Destination directory (default: memory name)\")\n .action(\n withErrorHandler(async (name: string, destination: string | undefined) => {\n // Use memory name as destination if not specified\n const targetDir = destination || name;\n\n console.log(`Cloning memory: ${name}`);\n\n const result = await cloneStorage(name, \"memory\", targetDir);\n\n console.log(chalk.green(`\\n✓ Successfully cloned memory: ${name}`));\n console.log(chalk.dim(` Location: ${targetDir}/`));\n console.log(chalk.dim(` Version: ${result.versionId.slice(0, 8)}`));\n }),\n );\n","import { Command, Option } from \"commander\";\nimport chalk from \"chalk\";\nimport { readFile, mkdir } from \"fs/promises\";\nimport { existsSync } from \"fs\";\nimport path from \"path\";\nimport { parse as parseYaml } from \"yaml\";\nimport { validateAgentCompose } from \"../../lib/domain/yaml-validator\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { checkAndUpgrade } from \"../../lib/utils/update-checker\";\nimport { saveCookState } from \"../../lib/domain/cook-state\";\nimport { withErrorHandler } from \"../../lib/command\";\nimport {\n CONFIG_FILE,\n ARTIFACT_DIR,\n printCommand,\n execVm0Command,\n execVm0RunWithCapture,\n parseRunIdsFromOutput,\n autoPullArtifact,\n} from \"./utils\";\n\ndeclare const __CLI_VERSION__: string;\n\ninterface VolumeConfig {\n name: string;\n version: string;\n}\n\ninterface AgentConfig {\n description?: string;\n framework: string;\n volumes?: string[];\n environment?: Record<string, string>;\n}\n\ninterface AgentComposeConfig {\n version: string;\n agents: Record<string, AgentConfig>;\n volumes?: Record<string, VolumeConfig>;\n}\n\ninterface LoadedConfig {\n config: AgentComposeConfig;\n agentName: string;\n volumeCount: number;\n}\n\n/**\n * Load and validate the compose config file.\n * Returns parsed config or exits on error.\n */\nasync function loadAndValidateConfig(): Promise<LoadedConfig> {\n console.log(chalk.bold(`Reading config: ${CONFIG_FILE}`));\n\n if (!existsSync(CONFIG_FILE)) {\n throw new Error(`Config file not found: ${CONFIG_FILE}`);\n }\n\n let config: AgentComposeConfig;\n try {\n const content = await readFile(CONFIG_FILE, \"utf8\");\n config = parseYaml(content) as AgentComposeConfig;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\"Invalid YAML format\", { cause: error });\n }\n throw new Error(\"Invalid YAML format\");\n }\n\n const validation = validateAgentCompose(config);\n if (!validation.valid) {\n throw new Error(validation.error);\n }\n\n const agentNames = Object.keys(config.agents);\n const agentName = agentNames[0]!;\n const volumeCount = config.volumes ? Object.keys(config.volumes).length : 0;\n\n console.log(\n chalk.green(`✓ Config validated: 1 agent, ${volumeCount} volume(s)`),\n );\n\n return { config, agentName, volumeCount };\n}\n\n/**\n * Process and push all volumes defined in config.\n */\nasync function processVolumes(\n config: AgentComposeConfig,\n cwd: string,\n): Promise<void> {\n if (!config.volumes || Object.keys(config.volumes).length === 0) {\n return;\n }\n\n console.log();\n console.log(chalk.bold(\"Processing volumes:\"));\n\n for (const volumeConfig of Object.values(config.volumes)) {\n const volumeDir = path.join(cwd, volumeConfig.name);\n\n if (!existsSync(volumeDir)) {\n throw new Error(`Directory not found: ${volumeConfig.name}`, {\n cause: new Error(\"Create the directory and add files first\"),\n });\n }\n\n try {\n printCommand(`cd ${volumeConfig.name}`);\n\n // Check if already initialized\n const existingConfig = await readStorageConfig(volumeDir);\n if (!existingConfig) {\n printCommand(`vm0 volume init --name ${volumeConfig.name}`);\n await execVm0Command([\"volume\", \"init\", \"--name\", volumeConfig.name], {\n cwd: volumeDir,\n silent: true,\n });\n }\n\n // Push volume\n printCommand(\"vm0 volume push\");\n await execVm0Command([\"volume\", \"push\"], {\n cwd: volumeDir,\n silent: true,\n });\n\n printCommand(\"cd ..\");\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\"Volume processing failed\", { cause: error });\n }\n throw error;\n }\n }\n}\n\n/**\n * Initialize and push artifact directory.\n */\nasync function processArtifact(cwd: string): Promise<string> {\n console.log();\n console.log(chalk.bold(\"Processing artifact:\"));\n\n const artifactDir = path.join(cwd, ARTIFACT_DIR);\n\n try {\n // Create directory if not exists\n if (!existsSync(artifactDir)) {\n printCommand(`mkdir ${ARTIFACT_DIR}`);\n await mkdir(artifactDir, { recursive: true });\n }\n\n printCommand(`cd ${ARTIFACT_DIR}`);\n\n // Check if already initialized\n const existingConfig = await readStorageConfig(artifactDir);\n if (!existingConfig) {\n printCommand(`vm0 artifact init --name ${ARTIFACT_DIR}`);\n await execVm0Command([\"artifact\", \"init\", \"--name\", ARTIFACT_DIR], {\n cwd: artifactDir,\n silent: true,\n });\n }\n\n // Push artifact\n printCommand(\"vm0 artifact push\");\n await execVm0Command([\"artifact\", \"push\"], {\n cwd: artifactDir,\n silent: true,\n });\n\n printCommand(\"cd ..\");\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\"Artifact processing failed\", { cause: error });\n }\n throw error;\n }\n\n return artifactDir;\n}\n\n/**\n * Compose the agent using vm0 compose command.\n */\nasync function composeAgent(cwd: string, skipConfirm: boolean): Promise<void> {\n console.log();\n console.log(chalk.bold(\"Composing agent:\"));\n const composeArgs = skipConfirm\n ? [\"compose\", \"--yes\", CONFIG_FILE]\n : [\"compose\", CONFIG_FILE];\n printCommand(`vm0 ${composeArgs.join(\" \")}`);\n\n try {\n await execVm0Command(composeArgs, { cwd });\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\"Compose failed\", { cause: error });\n }\n throw error;\n }\n}\n\n/**\n * Run the agent with the given prompt.\n */\nasync function runAgent(\n agentName: string,\n artifactDir: string,\n prompt: string,\n cwd: string,\n options: {\n envFile?: string;\n verbose?: boolean;\n debugNoMockClaude?: boolean;\n },\n): Promise<void> {\n console.log();\n console.log(chalk.bold(\"Running agent:\"));\n printCommand(\n `vm0 run ${agentName} --artifact-name ${ARTIFACT_DIR} \"${prompt}\"`,\n );\n console.log();\n\n const runArgs = [\n \"run\",\n agentName,\n \"--artifact-name\",\n ARTIFACT_DIR,\n ...(options.envFile ? [\"--env-file\", options.envFile] : []),\n ...(options.verbose ? [\"--verbose\"] : []),\n ...(options.debugNoMockClaude ? [\"--debug-no-mock-claude\"] : []),\n prompt,\n ];\n const runOutput = await execVm0RunWithCapture(runArgs, { cwd });\n\n // Save session state for continue/resume commands\n const runIds = parseRunIdsFromOutput(runOutput);\n if (runIds.runId || runIds.sessionId || runIds.checkpointId) {\n await saveCookState({\n lastRunId: runIds.runId,\n lastSessionId: runIds.sessionId,\n lastCheckpointId: runIds.checkpointId,\n });\n }\n\n // Auto-pull artifact if run completed with artifact changes\n await autoPullArtifact(runOutput, artifactDir);\n}\n\nexport const cookAction = new Command()\n .name(\"cook\")\n .description(\"Quick start: prepare, compose and run agent from vm0.yaml\")\n .argument(\"[prompt]\", \"Prompt for the agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\"-y, --yes\", \"Skip confirmation prompts\")\n .option(\"-v, --verbose\", \"Show full tool inputs and outputs\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .addOption(new Option(\"--no-auto-update\").hideHelp())\n .action(\n withErrorHandler(\n async (\n prompt: string | undefined,\n options: {\n envFile?: string;\n yes?: boolean;\n verbose?: boolean;\n debugNoMockClaude?: boolean;\n autoUpdate?: boolean;\n },\n ) => {\n // Step 0: Check for updates and auto-upgrade if needed\n // Note: --no-auto-update sets autoUpdate to false\n if (options.autoUpdate !== false) {\n const shouldExit = await checkAndUpgrade(__CLI_VERSION__, prompt);\n if (shouldExit) {\n process.exit(0);\n }\n }\n\n const cwd = process.cwd();\n\n // Step 1: Load and validate config\n const { config, agentName } = await loadAndValidateConfig();\n\n // Step 2: Process volumes\n await processVolumes(config, cwd);\n\n // Step 3: Process artifact\n const artifactDir = await processArtifact(cwd);\n\n // Step 4: Compose agent\n await composeAgent(cwd, options.yes ?? false);\n\n // Step 5: Run agent (if prompt provided)\n if (prompt) {\n await runAgent(agentName, artifactDir, prompt, cwd, {\n envFile: options.envFile,\n verbose: options.verbose,\n debugNoMockClaude: options.debugNoMockClaude,\n });\n } else {\n console.log();\n console.log(\"To run your agent:\");\n printCommand(\n `vm0 run ${agentName} --artifact-name ${ARTIFACT_DIR} \"your prompt\"`,\n );\n }\n },\n ),\n );\n","import { homedir } from \"os\";\nimport { join } from \"path\";\nimport { readFile, writeFile, mkdir } from \"fs/promises\";\nimport { existsSync } from \"fs\";\n\nconst CONFIG_DIR = join(homedir(), \".vm0\");\nconst COOK_STATE_FILE = join(CONFIG_DIR, \"cook.json\");\nconst STALE_THRESHOLD_MS = 48 * 60 * 60 * 1000; // 48 hours\n\n// Public API interface (unchanged for backward compatibility)\ninterface CookState {\n lastRunId?: string;\n lastSessionId?: string;\n lastCheckpointId?: string;\n}\n\n// Internal storage structure\ninterface CookStateEntry {\n lastRunId?: string;\n lastSessionId?: string;\n lastCheckpointId?: string;\n lastActiveAt: number;\n}\n\ninterface CookStateFile {\n ppid: Record<string, CookStateEntry>;\n}\n\n/**\n * Load cook state file with automatic migration from old format\n */\nasync function loadCookStateFile(): Promise<CookStateFile> {\n if (!existsSync(COOK_STATE_FILE)) {\n return { ppid: {} };\n }\n\n try {\n const content = await readFile(COOK_STATE_FILE, \"utf8\");\n const data = JSON.parse(content) as Record<string, unknown>;\n\n // Detect old format (no ppid field)\n if (!data.ppid) {\n // Migrate old data to current PPID\n const oldState = data as CookState;\n return {\n ppid: {\n [String(process.ppid)]: {\n lastRunId: oldState.lastRunId,\n lastSessionId: oldState.lastSessionId,\n lastCheckpointId: oldState.lastCheckpointId,\n lastActiveAt: Date.now(),\n },\n },\n };\n }\n\n return data as unknown as CookStateFile;\n } catch {\n // If file is corrupted, return empty state\n return { ppid: {} };\n }\n}\n\nexport async function loadCookState(): Promise<CookState> {\n const file = await loadCookStateFile();\n const ppid = String(process.ppid);\n const entry = file.ppid[ppid];\n\n if (!entry) return {};\n\n return {\n lastRunId: entry.lastRunId,\n lastSessionId: entry.lastSessionId,\n lastCheckpointId: entry.lastCheckpointId,\n };\n}\n\nexport async function saveCookState(state: CookState): Promise<void> {\n // Ensure config directory exists\n await mkdir(CONFIG_DIR, { recursive: true });\n\n const file = await loadCookStateFile();\n const ppid = String(process.ppid);\n const now = Date.now();\n\n // Clean up stale entries (older than 48 hours)\n for (const key of Object.keys(file.ppid)) {\n const entry = file.ppid[key];\n if (entry && now - entry.lastActiveAt > STALE_THRESHOLD_MS) {\n delete file.ppid[key];\n }\n }\n\n // Merge with existing entry for this PPID\n const existing = file.ppid[ppid];\n file.ppid[ppid] = {\n lastRunId: state.lastRunId ?? existing?.lastRunId,\n lastSessionId: state.lastSessionId ?? existing?.lastSessionId,\n lastCheckpointId: state.lastCheckpointId ?? existing?.lastCheckpointId,\n lastActiveAt: now,\n };\n\n // Write state file\n await writeFile(COOK_STATE_FILE, JSON.stringify(file, null, 2), \"utf8\");\n}\n","import chalk from \"chalk\";\nimport { existsSync } from \"fs\";\nimport { safeSpawn } from \"../../lib/utils/spawn\";\n\nexport const CONFIG_FILE = \"vm0.yaml\";\nexport const ARTIFACT_DIR = \"artifact\";\n\n/**\n * Print a command hint for tutorial output\n */\nexport function printCommand(cmd: string): void {\n console.log(chalk.dim(`> ${cmd}`));\n}\n\n/**\n * Execute a vm0 command in a subprocess\n * Returns stdout on success, throws on failure with stderr\n *\n * @param options.silent - If true, capture stdout/stderr (no output to terminal)\n */\nexport function execVm0Command(\n args: string[],\n options: { cwd?: string; silent?: boolean } = {},\n): Promise<string> {\n return new Promise((resolve, reject) => {\n // Determine stdio configuration:\n // - silent: pipe all (capture output, no terminal interaction)\n // - default: inherit all (full terminal passthrough, allows prompts)\n const stdio: \"pipe\" | \"inherit\" = options.silent ? \"pipe\" : \"inherit\";\n\n const proc = safeSpawn(\"vm0\", args, {\n cwd: options.cwd,\n stdio,\n });\n\n let stdout = \"\";\n let stderr = \"\";\n\n if (options.silent) {\n proc.stdout?.on(\"data\", (data: Buffer) => {\n stdout += data.toString();\n });\n proc.stderr?.on(\"data\", (data: Buffer) => {\n stderr += data.toString();\n });\n }\n\n proc.on(\"close\", (code) => {\n if (code === 0) {\n resolve(stdout);\n } else {\n reject(new Error(stderr || `Command failed with exit code ${code}`));\n }\n });\n\n proc.on(\"error\", (err) => {\n reject(err);\n });\n });\n}\n\n/**\n * Execute vm0 run command while capturing output for artifact version parsing\n * Streams output to console while also capturing it\n * Returns the captured stdout\n */\nexport function execVm0RunWithCapture(\n args: string[],\n options: { cwd?: string } = {},\n): Promise<string> {\n return new Promise((resolve, reject) => {\n // Force color output when parent is a TTY, since piped stdio disables TTY detection\n const env = process.stdout.isTTY\n ? { ...process.env, FORCE_COLOR: \"1\" }\n : process.env;\n\n const proc = safeSpawn(\"vm0\", args, {\n cwd: options.cwd,\n env,\n stdio: [\"inherit\", \"pipe\", \"pipe\"],\n });\n\n let stdout = \"\";\n let stderr = \"\";\n\n proc.stdout?.on(\"data\", (data: Buffer) => {\n const chunk = data.toString();\n stdout += chunk;\n process.stdout.write(chunk);\n });\n\n proc.stderr?.on(\"data\", (data: Buffer) => {\n const chunk = data.toString();\n stderr += chunk;\n process.stderr.write(chunk);\n });\n\n proc.on(\"close\", (code) => {\n if (code === 0) {\n resolve(stdout);\n } else {\n reject(new Error(stderr || `Command failed with exit code ${code}`));\n }\n });\n\n proc.on(\"error\", (err) => {\n reject(err);\n });\n });\n}\n\n/**\n * Parse artifact version from vm0 run completion output\n * Looks for pattern like:\n * ✓ Run completed successfully\n * ...\n * Artifact:\n * artifactName: abc12345\n * Returns the version string (8 char truncated hash)\n */\nfunction parseArtifactVersionFromCompletion(\n output: string,\n artifactName: string,\n): string | null {\n // Find the completion section marker\n const completionMarker = \"Run completed successfully\";\n const completionIndex = output.indexOf(completionMarker);\n if (completionIndex === -1) return null;\n\n // Get the completion section\n const section = output.slice(completionIndex);\n\n // Look for Artifact section and extract version\n // Pattern: \" artifactName: version\" (with ANSI codes possibly)\n const artifactPattern = new RegExp(\n `^\\\\s*${escapeRegExp(artifactName)}:\\\\s*(?:\\\\x1b\\\\[[0-9;]*m)?([a-f0-9]+)`,\n \"m\",\n );\n const match = section.match(artifactPattern);\n return match ? match[1]! : null;\n}\n\n/**\n * Escape special regex characters in a string\n */\nfunction escapeRegExp(str: string): string {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n\n/**\n * Parse run IDs from vm0 run completion output\n * Extracts runId, sessionId, and checkpointId from the \"Next steps\" section\n */\ninterface ParsedRunIds {\n runId?: string;\n sessionId?: string;\n checkpointId?: string;\n}\n\nexport function parseRunIdsFromOutput(output: string): ParsedRunIds {\n const completionMarker = \"Run completed successfully\";\n const completionIndex = output.indexOf(completionMarker);\n if (completionIndex === -1) return {};\n\n const section = output.slice(completionIndex);\n\n // Strip ANSI codes for reliable matching\n // ESC character (0x1B) followed by [ and ANSI sequence\n const ESC = String.fromCharCode(0x1b);\n const ansiPattern = new RegExp(`${ESC}\\\\[[0-9;]*m`, \"g\");\n const stripped = section.replace(ansiPattern, \"\");\n\n return {\n runId: stripped.match(/vm0 logs ([0-9a-f-]{36})/)?.[1],\n sessionId: stripped.match(/vm0 run continue ([0-9a-f-]{36})/)?.[1],\n checkpointId: stripped.match(/vm0 run resume ([0-9a-f-]{36})/)?.[1],\n };\n}\n\n/**\n * Auto-pull artifact after a successful run\n */\nexport async function autoPullArtifact(\n runOutput: string,\n artifactDir: string,\n): Promise<void> {\n const serverVersion = parseArtifactVersionFromCompletion(\n runOutput,\n ARTIFACT_DIR,\n );\n\n if (serverVersion && existsSync(artifactDir)) {\n console.log();\n console.log(chalk.bold(\"Pulling updated artifact:\"));\n printCommand(`cd ${ARTIFACT_DIR}`);\n printCommand(`vm0 artifact pull ${serverVersion}`);\n\n try {\n await execVm0Command([\"artifact\", \"pull\", serverVersion], {\n cwd: artifactDir,\n silent: true,\n });\n printCommand(\"cd ..\");\n } catch (error) {\n console.error(chalk.red(`✗ Artifact pull failed`));\n if (error instanceof Error) {\n console.error(chalk.dim(` ${error.message}`));\n }\n // Don't exit - the run succeeded, pull is optional\n }\n }\n}\n","import { Command } from \"commander\";\nimport { loadCookState } from \"../../lib/domain/cook-state\";\nimport { withErrorHandler } from \"../../lib/command\";\nimport { printCommand, execVm0Command } from \"./utils\";\n\nexport const logsCommand = new Command()\n .name(\"logs\")\n .description(\"View logs from the last cook run\")\n .option(\"-a, --agent\", \"Show agent events (default)\")\n .option(\"-s, --system\", \"Show system log\")\n .option(\"-m, --metrics\", \"Show metrics\")\n .option(\"-n, --network\", \"Show network logs (proxy traffic)\")\n .option(\n \"--since <time>\",\n \"Show logs since timestamp (e.g., 5m, 2h, 1d, 2024-01-15T10:30:00Z)\",\n )\n .option(\"--tail <n>\", \"Show last N entries (default: 5, max: 100)\")\n .option(\"--head <n>\", \"Show first N entries (max: 100)\")\n .action(\n withErrorHandler(\n async (options: {\n agent?: boolean;\n system?: boolean;\n metrics?: boolean;\n network?: boolean;\n since?: string;\n tail?: string;\n head?: string;\n }) => {\n const state = await loadCookState();\n if (!state.lastRunId) {\n throw new Error(\"No previous run found\", {\n cause: new Error(\"Run 'vm0 cook <prompt>' first\"),\n });\n }\n\n // Build command args\n const args = [\"logs\", state.lastRunId];\n const displayArgs = [`vm0 logs ${state.lastRunId}`];\n\n if (options.agent) {\n args.push(\"--agent\");\n displayArgs.push(\"--agent\");\n }\n if (options.system) {\n args.push(\"--system\");\n displayArgs.push(\"--system\");\n }\n if (options.metrics) {\n args.push(\"--metrics\");\n displayArgs.push(\"--metrics\");\n }\n if (options.network) {\n args.push(\"--network\");\n displayArgs.push(\"--network\");\n }\n if (options.since) {\n args.push(\"--since\", options.since);\n displayArgs.push(`--since ${options.since}`);\n }\n if (options.tail) {\n args.push(\"--tail\", options.tail);\n displayArgs.push(`--tail ${options.tail}`);\n }\n if (options.head) {\n args.push(\"--head\", options.head);\n displayArgs.push(`--head ${options.head}`);\n }\n\n printCommand(displayArgs.join(\" \"));\n await execVm0Command(args);\n },\n ),\n );\n","import { Command, Option } from \"commander\";\nimport path from \"path\";\nimport { loadCookState, saveCookState } from \"../../lib/domain/cook-state\";\nimport { withErrorHandler } from \"../../lib/command\";\nimport {\n ARTIFACT_DIR,\n printCommand,\n execVm0RunWithCapture,\n parseRunIdsFromOutput,\n autoPullArtifact,\n} from \"./utils\";\n\nexport const continueCommand = new Command()\n .name(\"continue\")\n .description(\n \"Continue from the last session (latest conversation and artifact)\",\n )\n .argument(\"<prompt>\", \"Prompt for the continued agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\"-v, --verbose\", \"Show full tool inputs and outputs\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .action(\n withErrorHandler(\n async (\n prompt: string,\n options: {\n envFile?: string;\n verbose?: boolean;\n debugNoMockClaude?: boolean;\n },\n ) => {\n const state = await loadCookState();\n if (!state.lastSessionId) {\n throw new Error(\"No previous session found\", {\n cause: new Error(\"Run 'vm0 cook <prompt>' first\"),\n });\n }\n\n const cwd = process.cwd();\n const artifactDir = path.join(cwd, ARTIFACT_DIR);\n\n const envFileArg = options.envFile\n ? ` --env-file ${options.envFile}`\n : \"\";\n printCommand(\n `vm0 run continue${envFileArg} ${state.lastSessionId} \"${prompt}\"`,\n );\n console.log();\n\n const runOutput = await execVm0RunWithCapture(\n [\n \"run\",\n \"continue\",\n ...(options.envFile ? [\"--env-file\", options.envFile] : []),\n ...(options.verbose ? [\"--verbose\"] : []),\n state.lastSessionId,\n ...(options.debugNoMockClaude ? [\"--debug-no-mock-claude\"] : []),\n prompt,\n ],\n { cwd },\n );\n\n // Update state with new IDs\n const newIds = parseRunIdsFromOutput(runOutput);\n if (newIds.runId || newIds.sessionId || newIds.checkpointId) {\n await saveCookState({\n lastRunId: newIds.runId,\n lastSessionId: newIds.sessionId,\n lastCheckpointId: newIds.checkpointId,\n });\n }\n\n // Auto-pull artifact\n await autoPullArtifact(runOutput, artifactDir);\n },\n ),\n );\n","import { Command, Option } from \"commander\";\nimport path from \"path\";\nimport { loadCookState, saveCookState } from \"../../lib/domain/cook-state\";\nimport { withErrorHandler } from \"../../lib/command\";\nimport {\n ARTIFACT_DIR,\n printCommand,\n execVm0RunWithCapture,\n parseRunIdsFromOutput,\n autoPullArtifact,\n} from \"./utils\";\n\nexport const resumeCommand = new Command()\n .name(\"resume\")\n .description(\n \"Resume from the last checkpoint (snapshotted conversation and artifact)\",\n )\n .argument(\"<prompt>\", \"Prompt for the resumed agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\"-v, --verbose\", \"Show full tool inputs and outputs\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .action(\n withErrorHandler(\n async (\n prompt: string,\n options: {\n envFile?: string;\n verbose?: boolean;\n debugNoMockClaude?: boolean;\n },\n ) => {\n const state = await loadCookState();\n if (!state.lastCheckpointId) {\n throw new Error(\"No previous checkpoint found\", {\n cause: new Error(\"Run 'vm0 cook <prompt>' first\"),\n });\n }\n\n const cwd = process.cwd();\n const artifactDir = path.join(cwd, ARTIFACT_DIR);\n\n const envFileArg = options.envFile\n ? ` --env-file ${options.envFile}`\n : \"\";\n printCommand(\n `vm0 run resume${envFileArg} ${state.lastCheckpointId} \"${prompt}\"`,\n );\n console.log();\n\n const runOutput = await execVm0RunWithCapture(\n [\n \"run\",\n \"resume\",\n ...(options.envFile ? [\"--env-file\", options.envFile] : []),\n ...(options.verbose ? [\"--verbose\"] : []),\n state.lastCheckpointId,\n ...(options.debugNoMockClaude ? [\"--debug-no-mock-claude\"] : []),\n prompt,\n ],\n { cwd },\n );\n\n // Update state with new IDs\n const newIds = parseRunIdsFromOutput(runOutput);\n if (newIds.runId || newIds.sessionId || newIds.checkpointId) {\n await saveCookState({\n lastRunId: newIds.runId,\n lastSessionId: newIds.sessionId,\n lastCheckpointId: newIds.checkpointId,\n });\n }\n\n // Auto-pull artifact\n await autoPullArtifact(runOutput, artifactDir);\n },\n ),\n );\n","import { cookAction } from \"./cook\";\nimport { logsCommand } from \"./logs\";\nimport { continueCommand } from \"./continue\";\nimport { resumeCommand } from \"./resume\";\n\n// Add subcommands to the cook command\ncookAction.addCommand(logsCommand);\ncookAction.addCommand(continueCommand);\ncookAction.addCommand(resumeCommand);\n\nexport const cookCommand = cookAction;\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport {\n getAgentEvents,\n getSystemLog,\n getMetrics,\n getNetworkLogs,\n type TelemetryMetric,\n type RunEvent,\n type NetworkLogEntry,\n} from \"../../lib/api\";\nimport { getApiUrl } from \"../../lib/api/config\";\nimport { parseTime } from \"../../lib/utils/time-parser\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { ClaudeEventParser } from \"../../lib/events/claude-event-parser\";\nimport { EventRenderer } from \"../../lib/events/event-renderer\";\nimport { paginate } from \"../../lib/utils/paginate\";\nimport { searchCommand } from \"./search\";\nimport { withErrorHandler } from \"../../lib/command\";\n\n/**\n * Maximum entries per API request\n */\nconst PAGE_LIMIT = 100;\n\n/**\n * Build platform URL for logs viewer\n * Transforms API URL to platform URL and appends logs path\n */\nfunction buildPlatformLogsUrl(apiUrl: string, runId: string): string {\n const url = new URL(apiUrl);\n const hostname = url.hostname;\n\n // Handle localhost\n if (hostname === \"localhost\" || hostname === \"127.0.0.1\") {\n return `http://${hostname}:3001/logs/${runId}`;\n }\n\n // Transform: www.vm0.ai → app.vm0.ai\n // vm0.ai → app.vm0.ai\n const parts = hostname.split(\".\");\n if (parts[0] === \"www\" || parts[0] === \"app\" || parts[0] === \"platform\") {\n parts[0] = \"app\";\n } else {\n parts.unshift(\"app\");\n }\n\n const platformHost = parts.join(\".\");\n const port = url.port ? `:${url.port}` : \"\";\n return `https://${platformHost}${port}/logs/${runId}`;\n}\n\n/**\n * Log type for mutually exclusive options\n */\ntype LogType = \"agent\" | \"system\" | \"metrics\" | \"network\";\n\n/**\n * Format a single metric line\n */\nfunction formatMetric(metric: TelemetryMetric): string {\n const memPercent = ((metric.mem_used / metric.mem_total) * 100).toFixed(1);\n const diskPercent = ((metric.disk_used / metric.disk_total) * 100).toFixed(1);\n\n return `[${metric.ts}] CPU: ${metric.cpu.toFixed(1)}% | Mem: ${formatBytes(metric.mem_used)}/${formatBytes(metric.mem_total)} (${memPercent}%) | Disk: ${formatBytes(metric.disk_used)}/${formatBytes(metric.disk_total)} (${diskPercent}%)`;\n}\n\n/**\n * Format a denied network request (blocked by firewall permission)\n */\nfunction formatNetworkDeny(entry: NetworkLogEntry): string {\n const method = entry.method || \"???\";\n const url = entry.url || entry.host || \"unknown\";\n const firewall = entry.firewall_name\n ? ` ${chalk.cyan(`[${entry.firewall_name}]`)}`\n : \"\";\n return `[${entry.timestamp}] ${method.padEnd(6)} ${chalk.red.bold(\"DENY\")} ${chalk.dim(url)}${firewall}`;\n}\n\n/**\n * Format an ALLOW or ERROR network request with full HTTP details\n */\nfunction formatNetworkRequest(entry: NetworkLogEntry): string {\n let statusColor: typeof chalk.green;\n const status = entry.status || 0;\n if (status >= 200 && status < 300) {\n statusColor = chalk.green;\n } else if (status >= 300 && status < 400) {\n statusColor = chalk.yellow;\n } else if (status >= 400) {\n statusColor = chalk.red;\n } else {\n statusColor = chalk.gray;\n }\n\n let latencyColor: typeof chalk.green;\n const latencyMs = entry.latency_ms || 0;\n if (latencyMs < 500) {\n latencyColor = chalk.green;\n } else if (latencyMs < 2000) {\n latencyColor = chalk.yellow;\n } else {\n latencyColor = chalk.red;\n }\n\n const method = entry.method || \"???\";\n const requestSize = entry.request_size || 0;\n const responseSize = entry.response_size || 0;\n const url = entry.url || entry.host || \"unknown\";\n const firewall = entry.firewall_name\n ? ` ${chalk.cyan(`[${entry.firewall_name}]`)}`\n : \"\";\n const error = entry.firewall_error\n ? ` ${chalk.red(entry.firewall_error)}`\n : \"\";\n\n return `[${entry.timestamp}] ${method.padEnd(6)} ${statusColor(status)} ${latencyColor(latencyMs + \"ms\")} ${formatBytes(requestSize)}/${formatBytes(responseSize)} ${chalk.dim(url)}${firewall}${error}`;\n}\n\n/**\n * Format a TCP connection log entry\n */\nfunction formatNetworkTcp(entry: NetworkLogEntry): string {\n const host = entry.host || \"unknown\";\n const port = entry.port || 0;\n const requestSize = entry.request_size || 0;\n const responseSize = entry.response_size || 0;\n const latencyMs = entry.latency_ms || 0;\n const error = entry.error ? ` ${chalk.red(entry.error)}` : \"\";\n\n return `[${entry.timestamp}] ${chalk.blue(\"TCP\")} ${latencyMs}ms ${formatBytes(requestSize)}/${formatBytes(responseSize)} ${chalk.dim(`${host}:${port}`)}${error}`;\n}\n\n/**\n * Format a non-TCP/non-HTTP log entry (UDP, ICMP, etc).\n * These come from iptables LOG via /dev/kmsg, not mitmproxy.\n */\nfunction formatNetworkOther(entry: NetworkLogEntry): string {\n const proto = (entry.type || \"???\").toUpperCase();\n const host = entry.host || \"unknown\";\n const port = entry.port || 0;\n const size = entry.request_size || 0;\n\n return `[${entry.timestamp}] ${chalk.magenta(proto.padEnd(5))} ${formatBytes(size)} ${chalk.dim(`${host}:${port}`)}`;\n}\n\n/**\n * Format a network log entry\n */\nfunction formatNetworkLog(entry: NetworkLogEntry): string {\n if (entry.type === \"tcp\") return formatNetworkTcp(entry);\n if (entry.type && entry.type !== \"http\") return formatNetworkOther(entry);\n if (entry.action === \"DENY\") return formatNetworkDeny(entry);\n return formatNetworkRequest(entry);\n}\n\n/**\n * Create an EventRenderer for log viewing (with timestamps)\n * Uses buffered mode to group tool_use/tool_result together for consistent\n * rendering with vm0 run output\n */\nfunction createLogRenderer(verbose: boolean): EventRenderer {\n return new EventRenderer({\n showTimestamp: true,\n verbose,\n });\n}\n\n/**\n * Render an agent event with timestamp for historical log viewing\n */\nfunction renderAgentEvent(event: RunEvent, renderer: EventRenderer): void {\n const eventData = event.eventData as Record<string, unknown>;\n const parsed = ClaudeEventParser.parse(eventData);\n if (parsed) {\n parsed.timestamp = new Date(event.createdAt);\n renderer.render(parsed);\n }\n}\n\n/**\n * Validate mutually exclusive options and return the log type\n */\nfunction getLogType(options: {\n agent?: boolean;\n system?: boolean;\n metrics?: boolean;\n network?: boolean;\n}): LogType {\n const selected = [\n options.agent,\n options.system,\n options.metrics,\n options.network,\n ].filter(Boolean).length;\n\n if (selected > 1) {\n throw new Error(\n \"Options --agent, --system, --metrics, and --network are mutually exclusive\",\n );\n }\n\n if (options.system) return \"system\";\n if (options.metrics) return \"metrics\";\n if (options.network) return \"network\";\n return \"agent\"; // Default\n}\n\nexport const logsCommand = new Command()\n .name(\"logs\")\n .description(\"View and search agent run logs\")\n .argument(\"[runId]\", \"Run ID to fetch logs for\")\n .addCommand(searchCommand)\n .option(\"-a, --agent\", \"Show agent events (default)\")\n .option(\"-s, --system\", \"Show system log\")\n .option(\"-m, --metrics\", \"Show metrics\")\n .option(\"-n, --network\", \"Show network logs (proxy traffic)\")\n .option(\n \"--since <time>\",\n \"Show logs since timestamp (e.g., 5m, 2h, 1d, 2024-01-15T10:30:00Z, 1705312200)\",\n )\n .option(\"--tail <n>\", \"Show last N entries (default: 5)\")\n .option(\"--head <n>\", \"Show first N entries\")\n .option(\"--all\", \"Fetch all log entries\")\n .action(\n withErrorHandler(\n async (\n runId: string | undefined,\n options: {\n agent?: boolean;\n system?: boolean;\n metrics?: boolean;\n network?: boolean;\n since?: string;\n tail?: string;\n head?: string;\n all?: boolean;\n },\n ) => {\n if (!runId) {\n logsCommand.help();\n return;\n }\n\n const logType = getLogType(options);\n\n // Validate --tail, --head, and --all are mutually exclusive\n const countModes = [\n options.tail !== undefined,\n options.head !== undefined,\n options.all === true,\n ].filter(Boolean).length;\n if (countModes > 1) {\n throw new Error(\n \"Options --tail, --head, and --all are mutually exclusive\",\n );\n }\n\n // Parse since option\n let since: number | undefined;\n if (options.since) {\n since = parseTime(options.since);\n }\n\n // Determine pagination mode and order based on flags\n const isAll = options.all === true;\n const isHead = options.head !== undefined;\n const isTail = options.tail !== undefined;\n\n // targetCount: number for --head/--tail, \"all\" for --all, default 5 for no flag\n let targetCount: number | \"all\";\n if (isAll) {\n targetCount = \"all\";\n } else if (isHead) {\n targetCount = Math.max(1, parseInt(options.head!, 10));\n } else if (isTail) {\n targetCount = Math.max(1, parseInt(options.tail!, 10));\n } else {\n // Default: show last 5 entries\n targetCount = 5;\n }\n\n // Order: asc for --head, desc for --tail/--all/default\n const order: \"asc\" | \"desc\" = isHead ? \"asc\" : \"desc\";\n\n // Build platform URL for agent logs\n const apiUrl = await getApiUrl();\n const platformUrl = buildPlatformLogsUrl(apiUrl, runId);\n\n switch (logType) {\n case \"agent\":\n await showAgentEvents(\n runId,\n { since, targetCount, order },\n platformUrl,\n );\n break;\n case \"system\":\n await showSystemLog(runId, { since, targetCount, order });\n break;\n case \"metrics\":\n await showMetrics(runId, { since, targetCount, order });\n break;\n case \"network\":\n await showNetworkLogs(runId, { since, targetCount, order });\n break;\n }\n },\n ),\n );\n\n/**\n * Show agent events with pagination support\n */\nasync function showAgentEvents(\n runId: string,\n options: {\n since?: number;\n targetCount: number | \"all\";\n order: \"asc\" | \"desc\";\n },\n platformUrl: string,\n): Promise<void> {\n // Fetch first page to get framework info\n const firstResponse = await getAgentEvents(runId, {\n since: options.since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n\n if (firstResponse.events.length === 0) {\n console.log(chalk.yellow(\"No agent events found for this run\"));\n return;\n }\n\n // Use pagination to collect all needed events\n let allEvents: RunEvent[];\n\n if (\n !firstResponse.hasMore ||\n (options.targetCount !== \"all\" &&\n firstResponse.events.length >= options.targetCount)\n ) {\n // Single page is enough\n allEvents =\n options.targetCount === \"all\"\n ? firstResponse.events\n : firstResponse.events.slice(0, options.targetCount);\n } else {\n // Need to paginate\n const lastEvent = firstResponse.events[firstResponse.events.length - 1];\n const firstPageTimestamp = lastEvent\n ? new Date(lastEvent.createdAt).getTime()\n : undefined;\n\n const remainingEvents = await paginate<RunEvent>({\n fetchPage: async (since) => {\n const response = await getAgentEvents(runId, {\n since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n return { items: response.events, hasMore: response.hasMore };\n },\n getTimestamp: (event) => new Date(event.createdAt).getTime(),\n targetCount:\n options.targetCount === \"all\"\n ? \"all\"\n : options.targetCount - firstResponse.events.length,\n initialSince: firstPageTimestamp,\n });\n\n allEvents = [...firstResponse.events, ...remainingEvents];\n\n // Trim to target count if needed\n if (\n options.targetCount !== \"all\" &&\n allEvents.length > options.targetCount\n ) {\n allEvents = allEvents.slice(0, options.targetCount);\n }\n }\n\n // Reverse for chronological display when using desc order (--tail)\n const events =\n options.order === \"desc\" ? [...allEvents].reverse() : allEvents;\n\n // Create renderer for log viewing (with timestamps, always verbose)\n const renderer = createLogRenderer(true);\n\n for (const event of events) {\n renderAgentEvent(event, renderer);\n }\n\n console.log(chalk.dim(`View on platform: ${platformUrl}`));\n}\n\n/**\n * Show system log with pagination support\n * Note: System log pagination is limited because the API returns aggregated strings\n * without individual timestamps. The --tail/--head/--all options work on batch count,\n * not line count.\n */\nasync function showSystemLog(\n runId: string,\n options: {\n since?: number;\n targetCount: number | \"all\";\n order: \"asc\" | \"desc\";\n },\n): Promise<void> {\n // For system log, we fetch with a high limit to get more batches\n // The API aggregates batches into a single string\n const limit =\n options.targetCount === \"all\"\n ? PAGE_LIMIT\n : Math.min(options.targetCount, PAGE_LIMIT);\n\n const response = await getSystemLog(runId, {\n since: options.since,\n limit,\n order: options.order,\n });\n\n if (!response.systemLog) {\n console.log(chalk.yellow(\"No system log found for this run\"));\n return;\n }\n\n console.log(response.systemLog);\n}\n\n/**\n * Show metrics with pagination support\n */\nasync function showMetrics(\n runId: string,\n options: {\n since?: number;\n targetCount: number | \"all\";\n order: \"asc\" | \"desc\";\n },\n): Promise<void> {\n // Fetch first page\n const firstResponse = await getMetrics(runId, {\n since: options.since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n\n if (firstResponse.metrics.length === 0) {\n console.log(chalk.yellow(\"No metrics found for this run\"));\n return;\n }\n\n // Use pagination to collect all needed metrics\n let allMetrics: TelemetryMetric[];\n\n if (\n !firstResponse.hasMore ||\n (options.targetCount !== \"all\" &&\n firstResponse.metrics.length >= options.targetCount)\n ) {\n // Single page is enough\n allMetrics =\n options.targetCount === \"all\"\n ? firstResponse.metrics\n : firstResponse.metrics.slice(0, options.targetCount);\n } else {\n // Need to paginate\n const lastMetric = firstResponse.metrics[firstResponse.metrics.length - 1];\n const firstPageTimestamp = lastMetric\n ? new Date(lastMetric.ts).getTime()\n : undefined;\n\n const remainingMetrics = await paginate<TelemetryMetric>({\n fetchPage: async (since) => {\n const response = await getMetrics(runId, {\n since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n return { items: response.metrics, hasMore: response.hasMore };\n },\n getTimestamp: (metric) => new Date(metric.ts).getTime(),\n targetCount:\n options.targetCount === \"all\"\n ? \"all\"\n : options.targetCount - firstResponse.metrics.length,\n initialSince: firstPageTimestamp,\n });\n\n allMetrics = [...firstResponse.metrics, ...remainingMetrics];\n\n // Trim to target count if needed\n if (\n options.targetCount !== \"all\" &&\n allMetrics.length > options.targetCount\n ) {\n allMetrics = allMetrics.slice(0, options.targetCount);\n }\n }\n\n // Reverse for chronological display when using desc order (--tail)\n const metrics =\n options.order === \"desc\" ? [...allMetrics].reverse() : allMetrics;\n\n for (const metric of metrics) {\n console.log(formatMetric(metric));\n }\n}\n\n/**\n * Show network logs with pagination support\n */\nasync function showNetworkLogs(\n runId: string,\n options: {\n since?: number;\n targetCount: number | \"all\";\n order: \"asc\" | \"desc\";\n },\n): Promise<void> {\n // Fetch first page\n const firstResponse = await getNetworkLogs(runId, {\n since: options.since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n\n if (firstResponse.networkLogs.length === 0) {\n console.log(\n chalk.yellow(\n \"No network logs found for this run. Network logs are only captured when using a runner with proxy enabled\",\n ),\n );\n return;\n }\n\n // Use pagination to collect all needed network logs\n let allNetworkLogs: NetworkLogEntry[];\n\n if (\n !firstResponse.hasMore ||\n (options.targetCount !== \"all\" &&\n firstResponse.networkLogs.length >= options.targetCount)\n ) {\n // Single page is enough\n allNetworkLogs =\n options.targetCount === \"all\"\n ? firstResponse.networkLogs\n : firstResponse.networkLogs.slice(0, options.targetCount);\n } else {\n // Need to paginate\n const lastLog =\n firstResponse.networkLogs[firstResponse.networkLogs.length - 1];\n const firstPageTimestamp = lastLog\n ? new Date(lastLog.timestamp).getTime()\n : undefined;\n\n const remainingLogs = await paginate<NetworkLogEntry>({\n fetchPage: async (since) => {\n const response = await getNetworkLogs(runId, {\n since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n return { items: response.networkLogs, hasMore: response.hasMore };\n },\n getTimestamp: (entry) => new Date(entry.timestamp).getTime(),\n targetCount:\n options.targetCount === \"all\"\n ? \"all\"\n : options.targetCount - firstResponse.networkLogs.length,\n initialSince: firstPageTimestamp,\n });\n\n allNetworkLogs = [...firstResponse.networkLogs, ...remainingLogs];\n\n // Trim to target count if needed\n if (\n options.targetCount !== \"all\" &&\n allNetworkLogs.length > options.targetCount\n ) {\n allNetworkLogs = allNetworkLogs.slice(0, options.targetCount);\n }\n }\n\n // Reverse for chronological display when using desc order (--tail)\n const networkLogs =\n options.order === \"desc\" ? [...allNetworkLogs].reverse() : allNetworkLogs;\n\n for (const entry of networkLogs) {\n console.log(formatNetworkLog(entry));\n }\n}\n","/**\n * Generic pagination utility for fetching items across multiple API pages.\n * Supports both limited pagination (fetch up to N items) and unlimited pagination (fetch all items).\n */\n\ninterface PaginateOptions<T> {\n /**\n * Function to fetch a single page of items.\n * @param since - Timestamp cursor for pagination (undefined for first page)\n * @returns Promise with items array and hasMore flag\n */\n fetchPage: (since?: number) => Promise<{ items: T[]; hasMore: boolean }>;\n\n /**\n * Function to extract timestamp from an item for cursor-based pagination.\n * @param item - The item to extract timestamp from\n * @returns Timestamp in milliseconds\n */\n getTimestamp: (item: T) => number;\n\n /**\n * Target number of items to collect, or \"all\" for unlimited.\n */\n targetCount: number | \"all\";\n\n /**\n * Initial since timestamp (optional, used when --since flag is provided).\n */\n initialSince?: number;\n}\n\n/**\n * Paginate through API responses, collecting items until target count is reached\n * or no more items are available.\n *\n * @param options - Pagination configuration\n * @returns Promise resolving to array of collected items\n * @throws Error if any page fetch fails (no partial results)\n */\nexport async function paginate<T>(options: PaginateOptions<T>): Promise<T[]> {\n const { fetchPage, getTimestamp, targetCount, initialSince } = options;\n\n const collected: T[] = [];\n let since = initialSince;\n let hasMore = true;\n\n while (hasMore) {\n const response = await fetchPage(since);\n\n // Append items to collection\n collected.push(...response.items);\n hasMore = response.hasMore;\n\n // Check if we've reached target count\n if (targetCount !== \"all\" && collected.length >= targetCount) {\n // Trim to exact target count and stop\n return collected.slice(0, targetCount);\n }\n\n // Update cursor for next page\n if (response.items.length > 0) {\n const lastItem = response.items[response.items.length - 1]!;\n since = getTimestamp(lastItem);\n } else {\n // No items returned, stop pagination\n hasMore = false;\n }\n }\n\n return collected;\n}\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport {\n searchLogs,\n type RunEvent,\n type LogsSearchResponse,\n} from \"../../lib/api\";\nimport { parseTime } from \"../../lib/utils/time-parser\";\nimport { ClaudeEventParser } from \"../../lib/events/claude-event-parser\";\nimport { EventRenderer } from \"../../lib/events/event-renderer\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nconst SEVEN_DAYS_MS = 7 * 24 * 60 * 60 * 1000;\n\ninterface SearchOptions {\n afterContext?: string;\n beforeContext?: string;\n context?: string;\n agent?: string;\n run?: string;\n since?: string;\n limit?: string;\n}\n\n/**\n * Render a single agent event using EventRenderer\n */\nfunction renderEvent(event: RunEvent, renderer: EventRenderer): void {\n const eventData = event.eventData as Record<string, unknown>;\n const parsed = ClaudeEventParser.parse(eventData);\n if (parsed) {\n parsed.timestamp = new Date(event.createdAt);\n renderer.render(parsed);\n }\n}\n\n/**\n * Format a run header line\n */\nfunction formatRunHeader(\n runId: string,\n agentName: string,\n timestamp: string,\n): string {\n const shortId = runId.slice(0, 8);\n const time = new Date(timestamp).toISOString().replace(/\\.\\d{3}Z$/, \"Z\");\n return `── Run ${shortId} (${agentName}, ${time}) ──────────`;\n}\n\n/**\n * Parse and validate context options (-A, -B, -C)\n */\nfunction parseContextOptions(options: SearchOptions): {\n before: number;\n after: number;\n} {\n const contextN = options.context ? parseInt(options.context, 10) : 0;\n const before = options.beforeContext\n ? parseInt(options.beforeContext, 10)\n : contextN;\n const after = options.afterContext\n ? parseInt(options.afterContext, 10)\n : contextN;\n\n if (isNaN(before) || before < 0 || before > 10) {\n throw new Error(\"--before-context must be between 0 and 10\");\n }\n if (isNaN(after) || after < 0 || after > 10) {\n throw new Error(\"--after-context must be between 0 and 10\");\n }\n\n return { before, after };\n}\n\n/**\n * Parse --limit option with validation\n */\nfunction parseLimit(value: string | undefined): number | undefined {\n if (!value) return undefined;\n const limit = parseInt(value, 10);\n if (isNaN(limit) || limit < 1 || limit > 50) {\n throw new Error(\"--limit must be between 1 and 50\");\n }\n return limit;\n}\n\n/**\n * Render search results grouped by run\n */\nfunction renderResults(response: LogsSearchResponse): void {\n // Group results by run\n const grouped = new Map<\n string,\n { agentName: string; results: LogsSearchResponse[\"results\"] }\n >();\n for (const result of response.results) {\n const existing = grouped.get(result.runId);\n if (existing) {\n existing.results.push(result);\n } else {\n grouped.set(result.runId, {\n agentName: result.agentName,\n results: [result],\n });\n }\n }\n\n // Render each group\n let isFirstGroup = true;\n for (const [runId, group] of grouped) {\n if (!isFirstGroup) {\n console.log(); // Separator between runs\n }\n isFirstGroup = false;\n\n const firstTimestamp = group.results[0]!.matchedEvent.createdAt;\n console.log(\n chalk.bold(formatRunHeader(runId, group.agentName, firstTimestamp)),\n );\n\n for (const result of group.results) {\n const renderer = new EventRenderer({\n showTimestamp: true,\n verbose: false,\n buffered: false,\n });\n\n for (const event of result.contextBefore) {\n renderEvent(event, renderer);\n }\n renderEvent(result.matchedEvent, renderer);\n for (const event of result.contextAfter) {\n renderEvent(event, renderer);\n }\n }\n }\n\n if (response.hasMore) {\n console.log();\n console.log(\n chalk.dim(\n ` Showing first ${response.results.length} matches. Use --limit to see more.`,\n ),\n );\n }\n}\n\nexport const searchCommand = new Command()\n .name(\"search\")\n .description(\"Search agent events across runs\")\n .argument(\"<keyword>\", \"Search keyword\")\n .option(\"-A, --after-context <n>\", \"Show n events after each match\")\n .option(\"-B, --before-context <n>\", \"Show n events before each match\")\n .option(\"-C, --context <n>\", \"Show n events before and after each match\")\n .option(\"--agent <name>\", \"Filter by agent name\")\n .option(\"--run <id>\", \"Filter by specific run ID\")\n .option(\"--since <time>\", \"Search logs since (default: 7d)\")\n .option(\"--limit <n>\", \"Maximum number of matches (default: 20)\")\n .action(\n withErrorHandler(async (keyword: string, options: SearchOptions) => {\n const { before, after } = parseContextOptions(options);\n const since = options.since\n ? parseTime(options.since)\n : Date.now() - SEVEN_DAYS_MS;\n const limit = parseLimit(options.limit);\n\n const response = await searchLogs({\n keyword,\n agent: options.agent,\n runId: options.run,\n since,\n limit,\n before,\n after,\n });\n\n if (response.results.length === 0) {\n console.log(chalk.dim(\"No matches found\"));\n console.log(\n chalk.dim(\n \" Try a broader search with --since 30d or a different keyword\",\n ),\n );\n return;\n }\n\n renderResults(response);\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport { existsSync } from \"fs\";\nimport { writeFile } from \"fs/promises\";\nimport { validateAgentName } from \"../../lib/domain/yaml-validator\";\nimport { promptText, isInteractive } from \"../../lib/utils/prompt-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nconst VM0_YAML_FILE = \"vm0.yaml\";\nconst AGENTS_MD_FILE = \"AGENTS.md\";\n\nfunction generateVm0Yaml(agentName: string): string {\n return `version: \"1.0\"\n\nagents:\n ${agentName}:\n framework: claude-code\n # Build agentic workflow using natural language\n instructions: AGENTS.md\n # Agent skills - see https://github.com/vm0-ai/vm0-skills for available skills\n # skills:\n # - https://github.com/vm0-ai/vm0-skills/tree/main/github\n`;\n}\n\nfunction generateAgentsMd(): string {\n return `# Agent Instructions\n\nYou are a HackerNews AI content curator.\n\n## Workflow\n\n1. Go to HackerNews and read the top 10 articles\n2. Find and extract AI-related content from these articles\n3. Summarize the findings into a X (Twitter) post format\n4. Write the summary to content.md\n`;\n}\n\nfunction checkExistingFiles(): string[] {\n const existingFiles: string[] = [];\n if (existsSync(VM0_YAML_FILE)) existingFiles.push(VM0_YAML_FILE);\n if (existsSync(AGENTS_MD_FILE)) existingFiles.push(AGENTS_MD_FILE);\n return existingFiles;\n}\n\nexport const initCommand = new Command()\n .name(\"init\")\n .description(\"Initialize a new VM0 project in the current directory\")\n .option(\"-f, --force\", \"Overwrite existing files\")\n .option(\"-n, --name <name>\", \"Agent name (required in non-interactive mode)\")\n .action(\n withErrorHandler(async (options: { force?: boolean; name?: string }) => {\n // Check existing files\n const existingFiles = checkExistingFiles();\n if (existingFiles.length > 0 && !options.force) {\n throw new Error(`${existingFiles.join(\", \")} already exists`, {\n cause: new Error(\"To overwrite: vm0 init --force\"),\n });\n }\n\n // Get agent name from option or prompt\n let agentName: string;\n if (options.name) {\n agentName = options.name.trim();\n } else if (!isInteractive()) {\n throw new Error(\"--name flag is required in non-interactive mode\", {\n cause: new Error(\"Usage: vm0 init --name <agent-name>\"),\n });\n } else {\n // Use directory name as default suggestion\n const dirName = path.basename(process.cwd());\n const defaultName = validateAgentName(dirName) ? dirName : undefined;\n\n const name = await promptText(\n \"Enter agent name\",\n defaultName,\n (value: string) => {\n if (!validateAgentName(value)) {\n return \"Must be 3-64 characters, alphanumeric and hyphens, start/end with letter or number\";\n }\n return true;\n },\n );\n\n if (name === undefined) {\n // User cancelled\n console.log(chalk.dim(\"Cancelled\"));\n return;\n }\n\n agentName = name;\n }\n\n // Validate agent name\n if (!agentName || !validateAgentName(agentName)) {\n throw new Error(\"Invalid agent name\", {\n cause: new Error(\n \"Must be 3-64 characters, alphanumeric and hyphens only, start and end with letter or number\",\n ),\n });\n }\n\n // Write vm0.yaml\n await writeFile(VM0_YAML_FILE, generateVm0Yaml(agentName));\n const vm0Status = existingFiles.includes(VM0_YAML_FILE)\n ? \" (overwritten)\"\n : \"\";\n console.log(chalk.green(`✓ Created ${VM0_YAML_FILE}${vm0Status}`));\n\n // Write AGENTS.md\n await writeFile(AGENTS_MD_FILE, generateAgentsMd());\n const agentsStatus = existingFiles.includes(AGENTS_MD_FILE)\n ? \" (overwritten)\"\n : \"\";\n console.log(chalk.green(`✓ Created ${AGENTS_MD_FILE}${agentsStatus}`));\n\n // Print next steps\n console.log();\n console.log(\"Next steps:\");\n console.log(\n ` 1. Set up model provider (one-time): ${chalk.cyan(\"zero org model-provider setup\")}`,\n );\n console.log(\n ` 2. Edit ${chalk.cyan(\"AGENTS.md\")} to customize your agent's workflow`,\n );\n console.log(\n ` 3. Run your agent: ${chalk.cyan('vm0 cook \"let\\'s start working\"')}`,\n );\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport {\n detectPackageManager,\n getLatestVersion,\n getManualUpgradeCommand,\n isAutoUpgradeSupported,\n performUpgrade,\n} from \"../../lib/utils/update-checker\";\nimport { withErrorHandler } from \"../../lib/command\";\n\ndeclare const __CLI_VERSION__: string;\n\nexport const upgradeCommand = new Command()\n .name(\"upgrade\")\n .description(\"Upgrade vm0 CLI to the latest version\")\n .action(\n withErrorHandler(async () => {\n console.log(\"Checking for updates...\");\n\n const latestVersion = await getLatestVersion();\n\n if (latestVersion === null) {\n throw new Error(\"Could not check for updates. Please try again later.\");\n }\n\n if (latestVersion === __CLI_VERSION__) {\n console.log(chalk.green(`✓ Already up to date (${__CLI_VERSION__})`));\n return;\n }\n\n console.log(\n chalk.yellow(\n `Current version: ${__CLI_VERSION__} -> Latest version: ${latestVersion}`,\n ),\n );\n console.log();\n\n const packageManager = detectPackageManager();\n\n if (!isAutoUpgradeSupported(packageManager)) {\n if (packageManager === \"unknown\") {\n console.log(\n chalk.yellow(\n \"Could not detect your package manager for auto-upgrade.\",\n ),\n );\n } else {\n console.log(\n chalk.yellow(\n `Auto-upgrade is not supported for ${packageManager}.`,\n ),\n );\n }\n console.log(chalk.yellow(\"Please upgrade manually:\"));\n console.log(chalk.cyan(` ${getManualUpgradeCommand(packageManager)}`));\n return;\n }\n\n console.log(`Upgrading via ${packageManager}...`);\n const success = await performUpgrade(packageManager);\n\n if (success) {\n console.log(\n chalk.green(`✓ Upgraded from ${__CLI_VERSION__} to ${latestVersion}`),\n );\n return;\n }\n\n throw new Error(\"Upgrade failed\", {\n cause: new Error(\n `Please run manually: ${getManualUpgradeCommand(packageManager)}`,\n ),\n });\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { getApiUrl, getActiveOrg, getToken } from \"../lib/api/config\";\nimport { withErrorHandler } from \"../lib/command\";\n\n/**\n * Detect if running inside a VM0 sandbox (agent runtime).\n * Presence of VM0_RUN_ID indicates sandbox execution.\n */\nfunction isInsideSandbox(): boolean {\n return !!process.env.VM0_RUN_ID;\n}\n\n/**\n * Display agent identity and run information when inside a sandbox.\n */\nasync function showSandboxInfo(): Promise<void> {\n const agentId = process.env.ZERO_AGENT_ID;\n const cliAgentType = process.env.CLI_AGENT_TYPE;\n\n const runId = process.env.VM0_RUN_ID;\n const activeOrg = await getActiveOrg();\n const apiUrl = process.env.VM0_API_URL;\n\n // Agent section\n const hasAgentInfo = agentId || cliAgentType;\n if (hasAgentInfo) {\n console.log(chalk.bold(\"Agent:\"));\n if (agentId) console.log(` ID: ${agentId}`);\n if (cliAgentType) console.log(` Framework: ${cliAgentType}`);\n console.log();\n }\n\n // Run section\n console.log(chalk.bold(\"Run:\"));\n if (runId) console.log(` ID: ${runId}`);\n if (activeOrg) console.log(` Org: ${activeOrg}`);\n if (apiUrl) console.log(` API: ${apiUrl}`);\n}\n\n/**\n * Display authentication and org information when running outside a sandbox.\n */\nasync function showLocalInfo(): Promise<void> {\n const token = await getToken();\n const apiUrl = await getApiUrl();\n const activeOrg = await getActiveOrg();\n\n // Auth section\n console.log(chalk.bold(\"Auth:\"));\n if (token) {\n const tokenSource = process.env.VM0_TOKEN\n ? \"VM0_TOKEN env var\"\n : \"config file\";\n console.log(\n ` Status: ${chalk.green(\"Authenticated\")} (via ${tokenSource})`,\n );\n } else {\n console.log(` Status: ${chalk.dim(\"Not authenticated\")}`);\n }\n console.log(` API: ${apiUrl}`);\n console.log();\n\n // Org section\n if (activeOrg) {\n console.log(chalk.bold(\"Org:\"));\n console.log(` Active: ${activeOrg}`);\n }\n}\n\nexport const whoamiCommand = new Command()\n .name(\"whoami\")\n .description(\"Show current identity and environment information\")\n .action(\n withErrorHandler(async () => {\n if (isInsideSandbox()) {\n await showSandboxInfo();\n } else {\n await showLocalInfo();\n }\n }),\n );\n"],"mappings":"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","names":["Command","Command","Command","Command","Command","Command","Command","Command","Command","Command","chalk","chalk","chalk","Command","chalk","Command","chalk","readFile","rm","existsSync","dirname","join","path","fs","path","parseGitHubTreeUrl","getSkillStorageName","fs","path","os","fs","path","os","tar","fs","path","text","commitResult","parseGitHubTreeUrl","getSkillStorageName","existsSync","readFile","dirname","chalk","parseGitHubTreeUrl","join","rm","Command","Command","Option","Command","Option","Command","Option","Command","Option","Command","Option","Command","Option","Command","chalk","chalk","Command","Command","chalk","Command","chalk","Command","chalk","Command","chalk","Command","Command","chalk","path","readFile","writeFile","mkdir","existsSync","parseYaml","path","type","Command","path","chalk","Command","chalk","Command","chalk","Command","chalk","path","fs","os","tar","chalk","chalk","Command","chalk","path","Command","chalk","statusCommand","Command","chalk","Command","chalk","listCommand","Command","chalk","Command","chalk","chalk","path","fs","os","tar","type","chalk","path","Command","chalk","Command","statusCommand","listCommand","Command","Command","chalk","path","initCommand","Command","path","chalk","Command","chalk","pushCommand","Command","chalk","Command","chalk","path","fs","os","tar","pullCommand","Command","chalk","path","Command","chalk","statusCommand","Command","chalk","Command","chalk","listCommand","Command","chalk","Command","chalk","cloneCommand","Command","chalk","Command","initCommand","pushCommand","pullCommand","statusCommand","listCommand","cloneCommand","Command","Command","chalk","path","initCommand","Command","path","chalk","Command","chalk","pushCommand","Command","chalk","Command","chalk","pullCommand","Command","chalk","Command","chalk","statusCommand","Command","chalk","Command","chalk","listCommand","Command","chalk","Command","chalk","cloneCommand","Command","chalk","Command","initCommand","pushCommand","pullCommand","statusCommand","listCommand","cloneCommand","Command","Option","chalk","readFile","mkdir","existsSync","path","parseYaml","homedir","join","readFile","writeFile","mkdir","existsSync","CONFIG_DIR","chalk","existsSync","CONFIG_FILE","chalk","existsSync","loadAndValidateConfig","chalk","CONFIG_FILE","existsSync","readFile","parseYaml","path","mkdir","Command","Option","Command","Command","Command","Option","path","continueCommand","Command","Option","path","Command","Option","path","resumeCommand","Command","Option","path","continueCommand","resumeCommand","Command","chalk","Command","chalk","parseLimit","chalk","Command","chalk","logsCommand","Command","Command","chalk","path","existsSync","writeFile","existsSync","initCommand","Command","path","chalk","writeFile","Command","chalk","Command","chalk","Command","chalk","chalk","Command","Command","logsCommand","initCommand"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/commands/auth/index.ts","../src/commands/auth/login.ts","../src/lib/api/auth.ts","../src/commands/auth/logout.ts","../src/commands/auth/status.ts","../src/commands/auth/setup-token.ts","../src/commands/info/index.ts","../src/lib/utils/update-checker.ts","../src/lib/utils/spawn.ts","../src/commands/compose/index.ts","../src/lib/domain/yaml-validator.ts","../src/lib/domain/github-skills.ts","../src/lib/external/git-client.ts","../src/lib/storage/system-storage.ts","../src/lib/storage/direct-upload.ts","../src/lib/utils/file-utils.ts","../src/commands/run/run.ts","../src/commands/run/resume.ts","../src/commands/run/continue.ts","../src/commands/run/list.ts","../src/lib/utils/time-parser.ts","../src/commands/run/kill.ts","../src/commands/run/queue.ts","../src/commands/run/index.ts","../src/commands/volume/index.ts","../src/commands/volume/init.ts","../src/lib/storage/storage-utils.ts","../src/commands/volume/push.ts","../src/commands/volume/pull.ts","../src/lib/storage/pull-utils.ts","../src/commands/volume/status.ts","../src/commands/volume/list.ts","../src/commands/volume/clone.ts","../src/lib/storage/clone-utils.ts","../src/commands/artifact/index.ts","../src/commands/artifact/init.ts","../src/commands/artifact/push.ts","../src/commands/artifact/pull.ts","../src/commands/artifact/status.ts","../src/commands/artifact/list.ts","../src/commands/artifact/clone.ts","../src/commands/memory/index.ts","../src/commands/memory/init.ts","../src/commands/memory/push.ts","../src/commands/memory/pull.ts","../src/commands/memory/status.ts","../src/commands/memory/list.ts","../src/commands/memory/clone.ts","../src/commands/cook/cook.ts","../src/lib/domain/cook-state.ts","../src/commands/cook/utils.ts","../src/commands/cook/logs.ts","../src/commands/cook/continue.ts","../src/commands/cook/resume.ts","../src/commands/cook/index.ts","../src/commands/logs/index.ts","../src/lib/utils/paginate.ts","../src/commands/logs/search.ts","../src/commands/init/index.ts","../src/commands/upgrade/index.ts","../src/commands/whoami.ts"],"sourcesContent":["// VM0 CLI entry point - main module\n// Sentry must be initialized before any other imports\nimport \"./instrument.js\";\nimport { Command } from \"commander\";\nimport { configureGlobalProxyFromEnv } from \"./lib/network/proxy.js\";\nimport { authCommand } from \"./commands/auth\";\nimport { infoCommand } from \"./commands/info\";\nimport { composeCommand } from \"./commands/compose\";\nimport { runCommand } from \"./commands/run\";\nimport { volumeCommand } from \"./commands/volume\";\nimport { artifactCommand } from \"./commands/artifact\";\nimport { memoryCommand } from \"./commands/memory\";\nimport { cookCommand } from \"./commands/cook\";\nimport { logsCommand } from \"./commands/logs\";\n\nimport { initCommand } from \"./commands/init\";\n\nimport { upgradeCommand } from \"./commands/upgrade\";\nimport { whoamiCommand } from \"./commands/whoami\";\n\nconst program = new Command();\n\ndeclare const __CLI_VERSION__: string;\n\nprogram\n .name(\"vm0\")\n .description(\"VM0 CLI - Build and run agents with natural language\")\n .version(__CLI_VERSION__);\n\n// Register all commands\nprogram.addCommand(authCommand);\nprogram.addCommand(infoCommand);\nprogram.addCommand(composeCommand);\nprogram.addCommand(runCommand);\nprogram.addCommand(volumeCommand);\nprogram.addCommand(artifactCommand);\nprogram.addCommand(memoryCommand);\nprogram.addCommand(cookCommand);\nprogram.addCommand(logsCommand);\n\nprogram.addCommand(initCommand);\nprogram.addCommand(upgradeCommand);\nprogram.addCommand(whoamiCommand);\n\nexport { program };\n\nif (\n process.argv[1]?.endsWith(\"index.js\") ||\n process.argv[1]?.endsWith(\"index.ts\") ||\n process.argv[1]?.endsWith(\"vm0\")\n) {\n configureGlobalProxyFromEnv();\n program.parse();\n}\n","import { Command } from \"commander\";\nimport { loginCommand } from \"./login\";\nimport { logoutCommand } from \"./logout\";\nimport { statusCommand } from \"./status\";\nimport { setupTokenCommand } from \"./setup-token\";\n\nexport const authCommand = new Command()\n .name(\"auth\")\n .description(\"Authenticate vm0\")\n .addCommand(loginCommand)\n .addCommand(logoutCommand)\n .addCommand(statusCommand)\n .addCommand(setupTokenCommand);\n","import { Command } from \"commander\";\nimport { authenticate } from \"../../lib/api/auth\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const loginCommand = new Command()\n .name(\"login\")\n .description(\"Log in to VM0 (use VM0_API_URL env var to set API URL)\")\n .action(\n withErrorHandler(async () => {\n await authenticate();\n }),\n );\n","import chalk from \"chalk\";\nimport {\n saveConfig,\n clearConfig,\n loadConfig,\n getApiUrl,\n getToken,\n} from \"./config\";\n\n/**\n * Build headers with optional Vercel bypass secret\n * Used to bypass Vercel deployment protection in CI/preview environments\n */\nfunction buildHeaders(): Record<string, string> {\n const headers: Record<string, string> = {\n \"Content-Type\": \"application/json\",\n };\n\n // Add Vercel bypass secret if available (for CI/preview deployments)\n const bypassSecret = process.env.VERCEL_AUTOMATION_BYPASS_SECRET;\n if (bypassSecret) {\n headers[\"x-vercel-protection-bypass\"] = bypassSecret;\n }\n\n return headers;\n}\n\nasync function requestDeviceCode(apiUrl: string): Promise<{\n device_code: string;\n user_code: string;\n verification_path: string;\n expires_in: number;\n interval: number;\n}> {\n const response = await fetch(`${apiUrl}/api/cli/auth/device`, {\n method: \"POST\",\n headers: buildHeaders(),\n body: JSON.stringify({}),\n });\n\n if (!response.ok) {\n if (response.status === 403) {\n throw new Error(\"An unexpected network issue occurred\");\n }\n throw new Error(`Failed to request device code: ${response.statusText}`);\n }\n\n return response.json() as Promise<{\n device_code: string;\n user_code: string;\n verification_path: string;\n expires_in: number;\n interval: number;\n }>;\n}\n\nasync function exchangeToken(\n apiUrl: string,\n deviceCode: string,\n): Promise<{\n access_token?: string;\n refresh_token?: string;\n token_type?: string;\n expires_in?: number;\n org_slug?: string;\n error?: string;\n error_description?: string;\n}> {\n const response = await fetch(`${apiUrl}/api/cli/auth/token`, {\n method: \"POST\",\n headers: buildHeaders(),\n body: JSON.stringify({ device_code: deviceCode }),\n });\n\n return response.json() as Promise<{\n access_token?: string;\n refresh_token?: string;\n token_type?: string;\n expires_in?: number;\n org_slug?: string;\n error?: string;\n error_description?: string;\n }>;\n}\n\nfunction delay(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\nexport async function authenticate(apiUrl?: string): Promise<void> {\n // Use provided apiUrl or get from config/env (with fallback to production)\n const targetApiUrl = apiUrl ?? (await getApiUrl());\n console.log(\"Initiating authentication...\");\n\n // Request device code\n const deviceAuth = await requestDeviceCode(targetApiUrl);\n\n console.log(chalk.green(\"\\nDevice code generated\"));\n\n // Construct verification URL from API URL and server-provided path\n const verificationUrl = `${targetApiUrl}${deviceAuth.verification_path}`;\n console.log(chalk.cyan(`\\nTo authenticate, visit: ${verificationUrl}`));\n console.log(`And enter this code: ${chalk.bold(deviceAuth.user_code)}`);\n console.log(\n `\\nThe code expires in ${Math.floor(deviceAuth.expires_in / 60)} minutes.`,\n );\n\n console.log(\"\\nWaiting for authentication...\");\n\n // Poll for token\n const startTime = Date.now();\n const maxWaitTime = deviceAuth.expires_in * 1000; // Convert to milliseconds\n const pollInterval = (deviceAuth.interval || 5) * 1000; // Use server-specified interval or default to 5 seconds\n\n let isFirstPoll = true;\n\n while (Date.now() - startTime < maxWaitTime) {\n // Skip delay on first poll for faster response\n if (!isFirstPoll) {\n await delay(pollInterval); // Use dynamic polling interval\n }\n isFirstPoll = false;\n\n const tokenResult = await exchangeToken(\n targetApiUrl,\n deviceAuth.device_code,\n );\n\n if (tokenResult.access_token) {\n // Success! Store the token and org context\n await saveConfig({\n token: tokenResult.access_token,\n apiUrl: targetApiUrl,\n });\n\n console.log(chalk.green(\"\\nAuthentication successful!\"));\n console.log(\"Your credentials have been saved\");\n return;\n }\n\n if (tokenResult.error === \"authorization_pending\") {\n // Still waiting for user to authenticate\n process.stdout.write(chalk.dim(\".\"));\n continue;\n }\n\n // Handle other errors\n if (tokenResult.error === \"expired_token\") {\n throw new Error(\"Device code expired, please try again\");\n }\n\n if (tokenResult.error) {\n throw new Error(\n `Authentication failed: ${tokenResult.error_description ?? tokenResult.error}`,\n );\n }\n }\n\n // Timeout\n throw new Error(\"Authentication timed out, please try again\");\n}\n\nexport async function logout(): Promise<void> {\n await clearConfig();\n console.log(chalk.green(\"✓ Successfully logged out\"));\n console.log(\"Your credentials have been cleared\");\n}\n\nexport async function checkAuthStatus(): Promise<void> {\n const config = await loadConfig();\n\n if (config.token) {\n console.log(chalk.green(\"✓ Authenticated\"));\n console.log(\"You are logged in to VM0.\");\n } else {\n console.error(chalk.red(\"✗ Not authenticated\"));\n console.error(chalk.dim(\" Run: vm0 auth login\"));\n }\n\n // Also check for environment variable\n if (process.env.VM0_TOKEN) {\n console.log(\"Using token from VM0_TOKEN environment variable\");\n }\n}\n\nexport async function setupToken(): Promise<void> {\n const token = await getToken();\n\n if (!token) {\n console.error(chalk.red(\"✗ Not authenticated\"));\n console.error(\"\");\n console.error(\"To get a token for CI/CD:\");\n console.error(\" 1. Run 'vm0 auth login' to authenticate\");\n console.error(\" 2. Run 'vm0 auth setup-token' to get your token\");\n console.error(\n \" 3. Store the token in your CI/CD secrets (e.g., VM0_TOKEN)\",\n );\n process.exit(1);\n }\n\n console.log(chalk.green(\"✓ Authentication token exported successfully!\"));\n console.log(\"\");\n console.log(\"Your token:\");\n console.log(\"\");\n console.log(token);\n console.log(\"\");\n console.log(\n `Use this token by setting: ${chalk.cyan(\"export VM0_TOKEN=<token>\")}`,\n );\n}\n","import { Command } from \"commander\";\nimport { logout } from \"../../lib/api/auth\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const logoutCommand = new Command()\n .name(\"logout\")\n .description(\"Log out of VM0\")\n .action(\n withErrorHandler(async () => {\n await logout();\n }),\n );\n","import { Command } from \"commander\";\nimport { checkAuthStatus } from \"../../lib/api/auth\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const statusCommand = new Command()\n .name(\"status\")\n .description(\"Show current authentication status\")\n .action(\n withErrorHandler(async () => {\n await checkAuthStatus();\n }),\n );\n","import { Command } from \"commander\";\nimport { setupToken } from \"../../lib/api/auth\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const setupTokenCommand = new Command()\n .name(\"setup-token\")\n .description(\"Output auth token for CI/CD environments\")\n .action(\n withErrorHandler(async () => {\n await setupToken();\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { existsSync } from \"fs\";\nimport { homedir, release, type } from \"os\";\nimport { join } from \"path\";\nimport { getApiUrl, loadConfig } from \"../../lib/api/config\";\nimport { detectPackageManager } from \"../../lib/utils/update-checker\";\n\ndeclare const __CLI_VERSION__: string;\n\nfunction getConfigPath() {\n return join(homedir(), \".vm0\", \"config.json\");\n}\n\nexport const infoCommand = new Command()\n .name(\"info\")\n .description(\"Display environment and debug information\")\n .action(async () => {\n // CLI version header\n console.log(chalk.bold(`VM0 CLI v${__CLI_VERSION__}`));\n console.log();\n\n // Authentication section\n const config = await loadConfig();\n const hasEnvToken = !!process.env.VM0_TOKEN;\n const hasConfigToken = !!config.token;\n const isAuthenticated = hasEnvToken || hasConfigToken;\n\n console.log(chalk.bold(\"Authentication:\"));\n if (isAuthenticated) {\n const tokenSource = hasEnvToken ? \"VM0_TOKEN env var\" : \"config file\";\n console.log(` ${chalk.green(\"✓\")} Logged in (via ${tokenSource})`);\n } else {\n console.log(` ${chalk.red(\"✗\")} Not authenticated`);\n }\n\n const configExists = existsSync(getConfigPath());\n const configDisplay = configExists\n ? `~/.vm0/config.json`\n : `~/.vm0/config.json (not found)`;\n console.log(` Config: ${configDisplay}`);\n console.log();\n\n // API section\n const apiUrl = await getApiUrl();\n console.log(chalk.bold(\"API:\"));\n console.log(` Host: ${apiUrl}`);\n console.log();\n\n // System section\n console.log(chalk.bold(\"System:\"));\n console.log(` Node: ${process.version}`);\n console.log(` Platform: ${process.platform} (${process.arch})`);\n console.log(` OS: ${type()} ${release()}`);\n console.log(` Shell: ${process.env.SHELL ?? \"unknown\"}`);\n console.log(` Package Manager: ${detectPackageManager()}`);\n });\n","import type { ChildProcess } from \"child_process\";\nimport chalk from \"chalk\";\nimport { safeSpawn } from \"./spawn\";\n\nconst PACKAGE_NAME = \"@vm0/cli\";\nconst NPM_REGISTRY_URL = `https://registry.npmjs.org/${encodeURIComponent(PACKAGE_NAME)}/latest`;\nconst TIMEOUT_MS = 5000;\n\ntype PackageManager = \"npm\" | \"pnpm\" | \"bun\" | \"yarn\" | \"unknown\";\n\n/**\n * Internal state for pending upgrade process\n */\ninterface UpgradeHandle {\n promise: Promise<boolean>;\n child: ChildProcess;\n packageManager: \"npm\" | \"pnpm\";\n}\n\n// Module-level state for pending upgrade\nlet pendingUpgrade: UpgradeHandle | null = null;\n\n/**\n * Detect which package manager was used to install the CLI\n * by checking the executable path for known package manager patterns.\n * Returns \"unknown\" if no known pattern is matched.\n */\nexport function detectPackageManager(): PackageManager {\n const execPath = process.argv[1] ?? \"\";\n\n // Check for pnpm (supported for auto-upgrade)\n if (execPath.includes(\"pnpm\")) {\n return \"pnpm\";\n }\n\n // Check for bun (unsupported - manual upgrade only)\n if (execPath.includes(\"/.bun/\") || execPath.includes(\"/bun/\")) {\n return \"bun\";\n }\n\n // Check for yarn (unsupported - manual upgrade only)\n if (execPath.includes(\"/.yarn/\") || execPath.includes(\"/yarn/\")) {\n return \"yarn\";\n }\n\n // Check for npm (supported for auto-upgrade)\n // Common npm paths: Homebrew, nvm, fnm, volta, nodenv, n, or node_modules\n if (\n execPath.includes(\"/usr/local/\") || // Homebrew on Intel Mac\n execPath.includes(\"/opt/homebrew/\") || // Homebrew on arm64 Mac\n execPath.includes(\"/.nvm/\") ||\n execPath.includes(\"/.fnm/\") ||\n execPath.includes(\"/.volta/\") ||\n execPath.includes(\"/.nodenv/\") ||\n execPath.includes(\"/.n/\") ||\n execPath.includes(\"/node_modules/\") ||\n execPath.includes(\"\\\\npm\\\\\") || // Windows: AppData\\Roaming\\npm\n execPath.includes(\"\\\\nodejs\\\\\") // Windows: Program Files\\nodejs\n ) {\n return \"npm\";\n }\n\n // Unknown package manager - don't assume npm\n return \"unknown\";\n}\n\n/**\n * Check if the package manager supports auto-upgrade\n */\nexport function isAutoUpgradeSupported(\n pm: PackageManager,\n): pm is \"npm\" | \"pnpm\" {\n return pm === \"npm\" || pm === \"pnpm\";\n}\n\n/**\n * Get the manual upgrade command for a package manager\n */\nexport function getManualUpgradeCommand(pm: PackageManager): string {\n switch (pm) {\n case \"bun\":\n return `bun add -g ${PACKAGE_NAME}@latest`;\n case \"yarn\":\n return `yarn global add ${PACKAGE_NAME}@latest`;\n case \"pnpm\":\n return `pnpm add -g ${PACKAGE_NAME}@latest`;\n case \"npm\":\n return `npm install -g ${PACKAGE_NAME}@latest`;\n case \"unknown\":\n return `npm install -g ${PACKAGE_NAME}@latest`;\n }\n}\n\n/**\n * Escape a string for use in shell command display.\n * Uses single quotes which don't interpret any special characters.\n * Embedded single quotes are handled via the '\\'' idiom\n * (end quote, escaped literal quote, start quote).\n */\nfunction escapeForShell(str: string): string {\n return `'${str.replace(/'/g, \"'\\\\''\")}'`;\n}\n\n/**\n * Build the re-run command string\n */\nfunction buildRerunCommand(prompt: string | undefined): string {\n if (prompt) {\n return `vm0 cook ${escapeForShell(prompt)}`;\n }\n return \"vm0 cook\";\n}\n\n/**\n * Fetch the latest version of the package from npm registry\n * Returns null if the request fails or times out\n */\nexport async function getLatestVersion(): Promise<string | null> {\n try {\n const controller = new AbortController();\n const timeoutId = setTimeout(() => controller.abort(), TIMEOUT_MS);\n\n const response = await fetch(NPM_REGISTRY_URL, {\n signal: controller.signal,\n });\n\n clearTimeout(timeoutId);\n\n if (!response.ok) {\n return null;\n }\n\n const json = (await response.json()) as { version?: string };\n return json.version ?? null;\n } catch {\n return null;\n }\n}\n\n/**\n * Execute package manager upgrade command\n * - npm: npm install -g @vm0/cli@latest\n * - pnpm: pnpm add -g @vm0/cli@latest\n * Returns true on success, false on failure\n */\nexport function performUpgrade(\n packageManager: \"npm\" | \"pnpm\",\n): Promise<boolean> {\n return new Promise((resolve) => {\n const args =\n packageManager === \"pnpm\"\n ? [\"add\", \"-g\", `${PACKAGE_NAME}@latest`]\n : [\"install\", \"-g\", `${PACKAGE_NAME}@latest`];\n\n const child = safeSpawn(packageManager, args, {\n stdio: \"inherit\",\n });\n\n child.on(\"close\", (code) => {\n resolve(code === 0);\n });\n\n child.on(\"error\", () => {\n resolve(false);\n });\n });\n}\n\n/**\n * Check for updates and perform upgrade if needed\n * Returns true if caller should exit (upgrade happened or failed)\n * Returns false if caller should continue (no update needed, check failed, or unsupported PM)\n */\nexport async function checkAndUpgrade(\n currentVersion: string,\n prompt: string | undefined,\n): Promise<boolean> {\n const latestVersion = await getLatestVersion();\n\n // If we couldn't check, warn and continue\n if (latestVersion === null) {\n console.log(chalk.yellow(\"⚠ Could not check for updates\"));\n console.log();\n return false;\n }\n\n // If already on latest, continue\n if (latestVersion === currentVersion) {\n return false;\n }\n\n // New version available - show beta notice\n console.log(chalk.yellow(\"vm0 is currently in beta.\"));\n console.log(\n chalk.yellow(\n `Current version: ${currentVersion} -> Latest version: ${latestVersion}`,\n ),\n );\n console.log(\n chalk.yellow(\n \"Please always use the latest version for best compatibility.\",\n ),\n );\n console.log();\n\n // Check package manager\n const packageManager = detectPackageManager();\n\n // For unsupported package managers, show manual upgrade instructions and continue\n if (!isAutoUpgradeSupported(packageManager)) {\n if (packageManager === \"unknown\") {\n console.log(\n chalk.yellow(\"Could not detect your package manager for auto-upgrade.\"),\n );\n } else {\n console.log(\n chalk.yellow(`Auto-upgrade is not supported for ${packageManager}.`),\n );\n }\n console.log(chalk.yellow(\"Please upgrade manually:\"));\n console.log(chalk.cyan(` ${getManualUpgradeCommand(packageManager)}`));\n console.log();\n return false;\n }\n\n // Perform upgrade for supported package managers (npm, pnpm)\n console.log(`Upgrading via ${packageManager}...`);\n const success = await performUpgrade(packageManager);\n\n if (success) {\n console.log(chalk.green(`Upgraded to ${latestVersion}`));\n console.log();\n console.log(\"To continue, run:\");\n console.log(chalk.cyan(` ${buildRerunCommand(prompt)}`));\n return true;\n }\n\n // Upgrade failed - show manual instructions\n console.error();\n console.error(chalk.red(\"✗ Upgrade failed. Please run manually:\"));\n console.error(chalk.cyan(` ${getManualUpgradeCommand(packageManager)}`));\n console.error();\n console.error(\"Then re-run:\");\n console.error(chalk.cyan(` ${buildRerunCommand(prompt)}`));\n return true;\n}\n\n/**\n * Start silent upgrade in background.\n * Call this at command start. Does NOT block after spawning.\n * The upgrade runs in parallel with command execution.\n *\n * @param currentVersion - Current CLI version\n * @returns Promise that resolves after starting upgrade (or determining no upgrade needed)\n */\nexport async function startSilentUpgrade(\n currentVersion: string,\n): Promise<void> {\n // Reset any previous state\n pendingUpgrade = null;\n\n // Check for new version\n const latestVersion = await getLatestVersion();\n\n // If check failed or already on latest, return silently\n if (latestVersion === null || latestVersion === currentVersion) {\n return;\n }\n\n // Check package manager\n const packageManager = detectPackageManager();\n\n // For unsupported package managers, return silently (no whisper)\n if (!isAutoUpgradeSupported(packageManager)) {\n return;\n }\n\n // Spawn upgrade process (don't wait for completion)\n const isWindows = process.platform === \"win32\";\n const args =\n packageManager === \"pnpm\"\n ? [\"add\", \"-g\", `${PACKAGE_NAME}@latest`]\n : [\"install\", \"-g\", `${PACKAGE_NAME}@latest`];\n\n const child = safeSpawn(packageManager, args, {\n stdio: \"pipe\",\n detached: !isWindows,\n windowsHide: true,\n });\n\n const promise = new Promise<boolean>((resolve) => {\n child.on(\"close\", (code) => resolve(code === 0));\n child.on(\"error\", () => resolve(false));\n });\n\n pendingUpgrade = { promise, child, packageManager };\n}\n\n/**\n * Wait for pending upgrade to complete and show warning if failed.\n * Call this at command end.\n *\n * @param timeout - Max time to wait if upgrade still running (ms)\n * @returns Promise that resolves when upgrade completes or times out\n */\nexport async function waitForSilentUpgrade(\n timeout: number = TIMEOUT_MS,\n): Promise<void> {\n if (!pendingUpgrade) {\n return;\n }\n\n const { promise, child, packageManager } = pendingUpgrade;\n pendingUpgrade = null; // Clear state\n\n // Race between upgrade completion and timeout\n const result = await Promise.race([\n promise,\n new Promise<false>((resolve) => {\n setTimeout(() => {\n child.kill();\n resolve(false);\n }, timeout);\n }),\n ]);\n\n // Show whisper message only on failure\n if (!result) {\n console.log(\n chalk.yellow(\n `\\n⚠ vm0 auto upgrade failed. Please run: ${getManualUpgradeCommand(packageManager)}`,\n ),\n );\n }\n}\n","import { spawn, type SpawnOptions } from \"child_process\";\nimport type { ChildProcess } from \"child_process\";\n\n/**\n * Spawn a child process with safe Windows shell handling.\n *\n * On Windows, `shell: true` is required to resolve `.cmd` extensions for\n * commands like `npm`, `pnpm`, etc. On other platforms, shell is disabled\n * to avoid unnecessary shell interpretation. Commands passed to this\n * function must be hardcoded strings (not user input), and arguments\n * must use array form to prevent shell injection.\n *\n */\nexport function safeSpawn(\n command: string,\n args: string[],\n options?: Omit<SpawnOptions, \"shell\">,\n): ChildProcess {\n const isWindows = process.platform === \"win32\";\n const resolvedCommand = isWindows ? `${command}.cmd` : command;\n\n // nosemgrep: javascript.lang.security.audit.spawn-shell-true.spawn-shell-true, javascript.lang.security.detect-child-process.detect-child-process\n return spawn(resolvedCommand, args, {\n ...options,\n shell: isWindows,\n });\n}\n","import { Command, Option } from \"commander\";\nimport chalk from \"chalk\";\nimport { readFile, rm } from \"fs/promises\";\nimport { existsSync } from \"fs\";\nimport { dirname, join } from \"path\";\nimport { parse as parseYaml } from \"yaml\";\nimport { extractAndGroupVariables, resolveSkillRef } from \"@vm0/core\";\nimport {\n getComposeByName,\n createOrUpdateCompose,\n getZeroOrg,\n listZeroSecrets,\n listZeroVariables,\n listZeroConnectors,\n resolveSkills,\n} from \"../../lib/api\";\nimport { validateAgentCompose } from \"../../lib/domain/yaml-validator\";\nimport {\n downloadGitHubDirectory,\n parseGitHubTreeUrl,\n} from \"../../lib/domain/github-skills\";\nimport {\n uploadInstructions,\n uploadSkill,\n type SkillUploadResult,\n} from \"../../lib/storage/system-storage\";\nimport { isInteractive, promptConfirm } from \"../../lib/utils/prompt-utils\";\nimport {\n startSilentUpgrade,\n waitForSilentUpgrade,\n} from \"../../lib/utils/update-checker\";\nimport { withErrorHandler } from \"../../lib/command\";\n\ndeclare const __CLI_VERSION__: string;\n\nconst DEFAULT_CONFIG_FILE = \"vm0.yaml\";\n\n/**\n * Check if input is a GitHub URL (supports plain repo, root with branch, and subdirectory)\n * Matches: https://github.com/owner/repo[/tree/branch[/path]]\n */\nfunction isGitHubUrl(input: string): boolean {\n return /^https:\\/\\/github\\.com\\/[^/]+\\/[^/]+/.test(input);\n}\n\n/**\n * Extract secret names from compose content using variable references.\n * Looks for ${{ secrets.XXX }} patterns in the compose.\n */\nexport function getSecretsFromComposeContent(content: unknown): Set<string> {\n const grouped = extractAndGroupVariables(content);\n return new Set(grouped.secrets.map((r) => r.name));\n}\n\n/**\n * Extract variable names from compose content using variable references.\n * Looks for ${{ vars.XXX }} patterns in the compose.\n */\nfunction getVarsFromComposeContent(content: unknown): Set<string> {\n const grouped = extractAndGroupVariables(content);\n return new Set(grouped.vars.map((r) => r.name));\n}\n\ninterface AgentConfig {\n instructions?: string;\n framework?: string;\n skills?: string[];\n environment?: Record<string, string>;\n}\n\ninterface LoadedConfig {\n config: unknown;\n agentName: string;\n agent: AgentConfig;\n basePath: string;\n}\n\n/**\n * Load and validate the compose config file.\n * Returns parsed config with agent info or exits on error.\n */\nasync function loadAndValidateConfig(\n configFile: string,\n): Promise<LoadedConfig> {\n if (!existsSync(configFile)) {\n throw new Error(`Config file not found: ${configFile}`);\n }\n\n const content = await readFile(configFile, \"utf8\");\n\n let config: unknown;\n try {\n config = parseYaml(content);\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Unknown error\";\n throw new Error(`Invalid YAML format: ${message}`);\n }\n\n const validation = validateAgentCompose(config);\n if (!validation.valid) {\n throw new Error(validation.error);\n }\n\n const cfg = config as Record<string, unknown>;\n const agentsConfig = cfg.agents as Record<string, Record<string, unknown>>;\n const agentName = Object.keys(agentsConfig)[0]!;\n const agent = agentsConfig[agentName] as AgentConfig;\n const basePath = dirname(configFile);\n\n return { config, agentName, agent, basePath };\n}\n\n/**\n * Type guard to check if config has a non-empty volumes field.\n */\nfunction hasVolumes(config: unknown): boolean {\n if (typeof config !== \"object\" || config === null) {\n return false;\n }\n const cfg = config as Record<string, unknown>;\n const volumes = cfg.volumes;\n return (\n typeof volumes === \"object\" &&\n volumes !== null &&\n Object.keys(volumes).length > 0\n );\n}\n\n/**\n * Upload instructions and skills, returning skill results.\n */\nasync function uploadAssets(\n agentName: string,\n agent: AgentConfig,\n basePath: string,\n jsonMode?: boolean,\n): Promise<SkillUploadResult[]> {\n if (agent.instructions) {\n if (!jsonMode) {\n console.log(`Uploading instructions: ${agent.instructions}`);\n }\n const result = await uploadInstructions(\n agentName,\n agent.instructions,\n basePath,\n agent.framework,\n );\n if (!jsonMode) {\n console.log(\n chalk.green(\n `✓ Instructions ${result.action === \"deduplicated\" ? \"(unchanged)\" : \"uploaded\"}: ${result.versionId.slice(0, 8)}`,\n ),\n );\n }\n }\n\n const skillResults: SkillUploadResult[] = [];\n if (agent.skills && Array.isArray(agent.skills)) {\n // Normalize bare skill names to full GitHub URLs before upload\n agent.skills = agent.skills.map(resolveSkillRef);\n\n if (!jsonMode) {\n console.log(`Uploading ${agent.skills.length} skill(s)...`);\n }\n\n // Batch resolve official skills against server cache\n const { resolved, unresolved } = await resolveSkills(agent.skills);\n\n // Use resolved skills directly (no download, no upload)\n for (const skillUrl of agent.skills) {\n const skill = resolved[skillUrl];\n if (skill) {\n const parsed = parseGitHubTreeUrl(skillUrl);\n skillResults.push({\n name: skill.storageName,\n versionId: skill.versionHash,\n action: \"resolved\",\n skillName: parsed.skillName,\n frontmatter: skill.frontmatter,\n });\n if (!jsonMode) {\n console.log(chalk.green(` ✓ ${parsed.skillName} (cached)`));\n }\n }\n }\n\n // Fall back to old flow for unresolved skills\n for (const skillUrl of unresolved) {\n if (!jsonMode) {\n console.log(chalk.dim(` Downloading: ${skillUrl}`));\n }\n const result = await uploadSkill(skillUrl);\n skillResults.push(result);\n if (!jsonMode) {\n console.log(\n chalk.green(\n ` ✓ Skill ${result.action === \"deduplicated\" ? \"(unchanged)\" : \"uploaded\"}: ${result.skillName} (${result.versionId.slice(0, 8)})`,\n ),\n );\n }\n }\n }\n\n return skillResults;\n}\n\n/**\n * Derive the app URL from the API URL by replacing \"www\" with \"app\" in the hostname.\n */\ninterface MissingItemsResult {\n missingSecrets: string[];\n missingVars: string[];\n}\n\n/**\n * Check for missing secrets/vars and print setup URL if any are missing.\n */\nasync function checkAndPromptMissingItems(\n config: unknown,\n options: { json?: boolean },\n): Promise<MissingItemsResult> {\n const requiredSecrets = getSecretsFromComposeContent(config);\n const requiredVars = getVarsFromComposeContent(config);\n\n if (requiredSecrets.size === 0 && requiredVars.size === 0) {\n return { missingSecrets: [], missingVars: [] };\n }\n\n const [secretsResponse, variablesResponse, connectorsResponse] =\n await Promise.all([\n requiredSecrets.size > 0 ? listZeroSecrets() : { secrets: [] },\n requiredVars.size > 0 ? listZeroVariables() : { variables: [] },\n listZeroConnectors(),\n ]);\n\n const existingSecretNames = new Set(\n secretsResponse.secrets.map((s) => s.name),\n );\n const existingVarNames = new Set(\n variablesResponse.variables.map((v) => v.name),\n );\n\n // Connector-provided secrets (e.g., GH_TOKEN from GitHub connector)\n // Use server-computed list to avoid CLI/server version skew issues\n const connectorProvided = new Set(\n connectorsResponse.connectorProvidedSecretNames,\n );\n\n const missingSecrets = [...requiredSecrets].filter(\n (name) => !existingSecretNames.has(name) && !connectorProvided.has(name),\n );\n const missingVars = [...requiredVars].filter(\n (name) => !existingVarNames.has(name),\n );\n\n if (missingSecrets.length === 0 && missingVars.length === 0) {\n return { missingSecrets: [], missingVars: [] };\n }\n\n if (!options.json) {\n console.log();\n console.log(chalk.yellow(\"⚠ Missing secrets/variables detected:\"));\n if (missingSecrets.length > 0) {\n console.log(chalk.yellow(` Secrets: ${missingSecrets.join(\", \")}`));\n }\n if (missingVars.length > 0) {\n console.log(chalk.yellow(` Variables: ${missingVars.join(\", \")}`));\n }\n console.log();\n }\n\n return { missingSecrets, missingVars };\n}\n\n/**\n * Result from finalizeCompose for JSON output\n */\ninterface ComposeResult {\n composeId: string;\n composeName: string;\n versionId: string;\n action: \"created\" | \"existing\";\n displayName: string;\n missingSecrets?: string[];\n missingVars?: string[];\n}\n\n/**\n * Finalize compose: call API and display result.\n * Shared by both GitHub URL and local file flows.\n * Returns the compose result for JSON output mode.\n */\nasync function finalizeCompose(\n config: unknown,\n agent: AgentConfig,\n options: { yes?: boolean; autoUpdate?: boolean; json?: boolean },\n): Promise<ComposeResult> {\n // Call API\n if (!options.json) {\n console.log(\"Uploading compose...\");\n }\n const response = await createOrUpdateCompose({ content: config });\n\n const shortVersionId = response.versionId.slice(0, 8);\n // In --json mode, skip getOrg() — the org prefix in displayName is for human display only\n const displayName = options.json\n ? response.name\n : `${(await getZeroOrg()).slug}/${response.name}`;\n\n // Build result\n const result: ComposeResult = {\n composeId: response.composeId,\n composeName: response.name,\n versionId: response.versionId,\n action: response.action,\n displayName,\n };\n\n // In --json mode, skip missing items check — E2B doesn't read these fields\n if (!options.json) {\n const missingItems = await checkAndPromptMissingItems(config, options);\n if (\n missingItems.missingSecrets.length > 0 ||\n missingItems.missingVars.length > 0\n ) {\n result.missingSecrets = missingItems.missingSecrets;\n result.missingVars = missingItems.missingVars;\n }\n }\n\n // Display human-readable result (skip in JSON mode)\n if (!options.json) {\n if (response.action === \"created\") {\n console.log(chalk.green(`✓ Compose created: ${displayName}`));\n } else {\n console.log(chalk.green(`✓ Compose version exists: ${displayName}`));\n }\n\n console.log(chalk.dim(` Version: ${shortVersionId}`));\n console.log();\n console.log(\" Run your agent:\");\n console.log(\n chalk.cyan(\n ` vm0 run ${displayName}:${shortVersionId} --artifact-name <artifact> \"your prompt\"`,\n ),\n );\n }\n\n // Wait for upgrade at command end (shows warning if failed)\n if (options.autoUpdate !== false) {\n await waitForSilentUpgrade();\n }\n\n return result;\n}\n\n/**\n * Handle compose from GitHub URL\n */\nasync function handleGitHubCompose(\n url: string,\n options: { yes?: boolean; autoUpdate?: boolean; json?: boolean },\n): Promise<ComposeResult> {\n if (!options.json) {\n console.log(`Downloading from GitHub: ${url}`);\n }\n\n const { dir: downloadedDir, tempRoot } = await downloadGitHubDirectory(url);\n const configFile = join(downloadedDir, \"vm0.yaml\");\n\n try {\n if (!existsSync(configFile)) {\n throw new Error(\"vm0.yaml not found in the GitHub directory\", {\n cause: new Error(`URL: ${url}`),\n });\n }\n\n // Load and validate config\n const { config, agentName, agent, basePath } =\n await loadAndValidateConfig(configFile);\n\n // Check if agent with same name already exists\n const existingCompose = await getComposeByName(agentName);\n if (existingCompose) {\n if (!options.json) {\n console.log();\n console.log(\n chalk.yellow(`⚠ An agent named \"${agentName}\" already exists.`),\n );\n }\n\n if (!isInteractive()) {\n // Non-interactive mode: require --yes flag to overwrite\n if (!options.yes) {\n throw new Error(\n \"Cannot overwrite existing agent in non-interactive mode\",\n {\n cause: new Error(\n \"Use --yes flag to confirm overwriting the existing agent.\",\n ),\n },\n );\n }\n } else {\n // Interactive mode: prompt user (default No)\n const confirmed = await promptConfirm(\n \"Do you want to overwrite it?\",\n false,\n );\n if (!confirmed) {\n if (!options.json) {\n console.log(chalk.yellow(\"Compose cancelled.\"));\n }\n process.exit(0);\n }\n }\n }\n\n // Check for unsupported volumes\n if (hasVolumes(config)) {\n throw new Error(\"Volumes are not supported for GitHub URL compose\", {\n cause: new Error(\n \"Clone the repository locally and run: vm0 compose ./path/to/vm0.yaml\",\n ),\n });\n }\n\n // Upload instructions and skills\n await uploadAssets(agentName, agent, basePath, options.json);\n\n // Finalize compose (upload, display)\n return await finalizeCompose(config, agent, options);\n } finally {\n // Cleanup temp directory\n await rm(tempRoot, { recursive: true, force: true });\n }\n}\n\nexport const composeCommand = new Command()\n .name(\"compose\")\n .description(\"Create or update agent compose (e.g., vm0.yaml)\")\n .argument(\n \"[agent-yaml]\",\n `Path to agent YAML file or GitHub tree URL (default: ${DEFAULT_CONFIG_FILE})`,\n )\n .option(\"-y, --yes\", \"Skip confirmation prompts\")\n .option(\n \"--experimental-shared-compose\",\n \"[deprecated] No longer required, kept for backward compatibility\",\n )\n .option(\"--json\", \"Output JSON for scripts (suppresses interactive output)\")\n .option(\n \"--porcelain\",\n \"[deprecated: use --json] Output JSON for scripts\",\n false,\n )\n .addOption(new Option(\"--no-auto-update\").hideHelp())\n .action(\n withErrorHandler(\n async (\n configFile: string | undefined,\n options: {\n yes?: boolean;\n autoUpdate?: boolean;\n experimentalSharedCompose?: boolean;\n json?: boolean;\n porcelain?: boolean;\n },\n ) => {\n const resolvedConfigFile = configFile ?? DEFAULT_CONFIG_FILE;\n\n // Handle deprecated --porcelain flag\n if (options.porcelain && !options.json) {\n console.error(\n chalk.yellow(\"⚠ --porcelain is deprecated, use --json instead\"),\n );\n options.json = true;\n }\n\n // JSON mode implies --yes and disables auto-update (for CI/CD usage)\n if (options.json) {\n options.yes = true;\n options.autoUpdate = false;\n }\n\n // Start upgrade in background at command start (runs in parallel)\n if (options.autoUpdate !== false) {\n await startSilentUpgrade(__CLI_VERSION__);\n }\n\n try {\n let result: ComposeResult;\n\n // Branch based on input type\n if (isGitHubUrl(resolvedConfigFile)) {\n result = await handleGitHubCompose(resolvedConfigFile, options);\n } else {\n // Existing local file flow\n // 1. Load and validate config\n const { config, agentName, agent, basePath } =\n await loadAndValidateConfig(resolvedConfigFile);\n\n // 3. Upload instructions and skills\n await uploadAssets(agentName, agent, basePath, options.json);\n\n // 4. Finalize compose (upload, display)\n result = await finalizeCompose(config, agent, options);\n }\n\n // Output JSON result if requested\n if (options.json) {\n console.log(JSON.stringify(result));\n }\n } catch (error) {\n if (options.json) {\n const message =\n error instanceof Error\n ? error.message\n : \"An unexpected error occurred\";\n console.log(JSON.stringify({ error: message }));\n process.exit(1);\n }\n\n throw error;\n }\n },\n ),\n );\n","import { z } from \"zod\";\nimport {\n agentDefinitionSchema,\n volumeConfigSchema,\n resolveSkillRef,\n} from \"@vm0/core\";\n\n/**\n * CLI-specific agent name schema that allows 3-character names.\n * Pattern: start/end with alphanumeric, middle can have hyphens\n */\nconst cliAgentNameSchema = z\n .string()\n .min(3, \"Agent name must be at least 3 characters\")\n .max(64, \"Agent name must be 64 characters or less\")\n .regex(\n /^[a-zA-Z0-9]([a-zA-Z0-9-]{0,62}[a-zA-Z0-9])?$/,\n \"Agent name must start and end with letter or number, and contain only letters, numbers, and hyphens\",\n );\n\n/**\n * CLI-extended agent definition schema with skills URL validation\n *\n * Note: Framework validation is handled server-side.\n * The server rejects unsupported frameworks.\n */\nconst cliAgentDefinitionSchema = agentDefinitionSchema.superRefine(\n (agent, ctx) => {\n // Validate skills: bare names or full GitHub URLs\n if (agent.skills) {\n for (let i = 0; i < agent.skills.length; i++) {\n const skillRef = agent.skills[i];\n if (skillRef) {\n try {\n resolveSkillRef(skillRef);\n } catch (error) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message:\n error instanceof Error\n ? error.message\n : `Invalid skill reference: ${skillRef}`,\n path: [\"skills\", i],\n });\n }\n }\n }\n }\n },\n);\n\n/**\n * CLI compose schema with single-agent rule and volume mount validation\n */\nconst cliComposeSchema = z\n .object({\n version: z.string().min(1, \"Missing config.version\"),\n agents: z.record(cliAgentNameSchema, cliAgentDefinitionSchema),\n volumes: z.record(z.string(), volumeConfigSchema).optional(),\n })\n .superRefine((config, ctx) => {\n const agentKeys = Object.keys(config.agents);\n\n // CLI business rule: at least one agent required\n if (agentKeys.length === 0) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: \"agents must have at least one agent defined\",\n path: [\"agents\"],\n });\n return;\n }\n\n // CLI business rule: only one agent allowed\n if (agentKeys.length > 1) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: \"Multiple agents not supported yet. Only one agent allowed.\",\n path: [\"agents\"],\n });\n return;\n }\n\n // Volume mount validation\n const agentName = agentKeys[0]!;\n const agent = config.agents[agentName];\n const agentVolumes = agent?.volumes;\n\n if (agentVolumes && agentVolumes.length > 0) {\n if (!config.volumes) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message:\n \"Agent references volumes but no volumes section defined. Each volume must have explicit name and version.\",\n path: [\"volumes\"],\n });\n return;\n }\n\n for (const volDeclaration of agentVolumes) {\n const parts = volDeclaration.split(\":\");\n if (parts.length !== 2) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Invalid volume declaration: ${volDeclaration}. Expected format: volume-key:/mount/path`,\n path: [\"agents\", agentName, \"volumes\"],\n });\n continue;\n }\n\n const volumeKey = parts[0]!.trim();\n if (!config.volumes[volumeKey]) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Volume \"${volumeKey}\" is not defined in volumes section. Each volume must have explicit name and version.`,\n path: [\"volumes\", volumeKey],\n });\n }\n }\n }\n });\n\n/**\n * Format an invalid_type Zod issue into a user-friendly message.\n * Returns null if no special formatting applies.\n */\nfunction formatInvalidTypeIssue(\n path: string,\n issue: z.ZodIssue & { expected?: string },\n): string | null {\n // Zod 4 uses 'input' instead of 'received' in types, but runtime has 'received'\n const received = (issue as unknown as { received?: string }).received;\n\n // Missing required fields (handles both \"Required\" and \"Invalid input:\" messages)\n const isMissing =\n received === \"undefined\" ||\n issue.message.includes(\"received undefined\") ||\n issue.message === \"Required\";\n\n if (path === \"version\" && isMissing) {\n return \"Missing config.version\";\n }\n if (path === \"agents\" && isMissing) {\n return \"Missing agents object in config\";\n }\n // Volume field errors\n if (path.startsWith(\"volumes.\") && path.endsWith(\".name\")) {\n const volumeKey = path.split(\".\")[1];\n return `Volume \"${volumeKey}\" must have a 'name' field (string)`;\n }\n if (path.startsWith(\"volumes.\") && path.endsWith(\".version\")) {\n const volumeKey = path.split(\".\")[1];\n return `Volume \"${volumeKey}\" must have a 'version' field (string)`;\n }\n // Array type errors\n if (issue.expected === \"array\") {\n const fieldName = path.replace(/^agents\\.[^.]+\\./, \"agent.\");\n return `${fieldName} must be an array`;\n }\n // Array element type errors (number where string expected)\n if (issue.expected === \"string\" && received === \"number\") {\n const fieldName = path.replace(/^agents\\.[^.]+\\./, \"agent.\");\n const match = fieldName.match(/^(agent\\.[^.]+)\\.\\d+$/);\n if (match) {\n return `Each entry in ${match[1]?.replace(\"agent.\", \"\")} must be a string`;\n }\n }\n return null;\n}\n\n/**\n * Formats a Zod error into a user-friendly string\n */\nfunction formatZodError(error: z.ZodError): string {\n const issue = error.issues[0];\n if (!issue) return \"Validation failed\";\n\n const path = issue.path.join(\".\");\n const message = issue.message;\n\n // Root-level errors or custom messages without path context\n if (!path) return message;\n\n // Handle invalid_type errors with user-friendly messages\n if (issue.code === \"invalid_type\") {\n const formatted = formatInvalidTypeIssue(path, issue);\n if (formatted) return formatted;\n }\n\n // Handle invalid_key for agent name key validation (Zod 4 uses invalid_key instead of invalid_string)\n if (issue.code === \"invalid_key\" && path.startsWith(\"agents.\")) {\n return \"Invalid agent name format. Must be 3-64 characters, letters, numbers, and hyphens only. Must start and end with letter or number.\";\n }\n\n // Handle invalid key in record (agent name validation)\n if (message === \"Invalid key in record\" && path.startsWith(\"agents.\")) {\n return \"Invalid agent name format. Must be 3-64 characters, letters, numbers, and hyphens only. Must start and end with letter or number.\";\n }\n\n // Handle custom errors (our superRefine messages) - return without path prefix\n if (issue.code === \"custom\") {\n return message;\n }\n\n // Handle agent-level errors with cleaner paths\n if (path.startsWith(\"agents.\")) {\n const cleanPath = path.replace(/^agents\\.[^.]+\\./, \"agent.\");\n // For \"Invalid input\" messages, provide cleaner error\n if (message.startsWith(\"Invalid input:\")) {\n const match = message.match(/expected (\\w+), received (\\w+)/);\n if (match && match[1] === \"string\" && match[2] === \"number\") {\n const fieldMatch = cleanPath.match(/^(agent\\.[^.]+)\\.\\d+$/);\n if (fieldMatch) {\n return `Each entry in ${fieldMatch[1]?.replace(\"agent.\", \"\")} must be a string`;\n }\n }\n }\n return `${cleanPath}: ${message}`;\n }\n\n return `${path}: ${message}`;\n}\n\n/**\n * Validates agent.name format\n */\nexport function validateAgentName(name: string): boolean {\n return cliAgentNameSchema.safeParse(name).success;\n}\n\n/**\n * Known fields in agent definition schema, derived from the Zod schema shape.\n * Used for typo detection against unknown fields in YAML config.\n */\nconst KNOWN_AGENT_FIELDS = Object.keys(agentDefinitionSchema.shape);\n\n/**\n * Computes Levenshtein edit distance between two strings.\n * Uses single-row DP optimization for O(min(m,n)) space.\n */\nfunction levenshteinDistance(a: string, b: string): number {\n if (a === b) return 0;\n if (a.length === 0) return b.length;\n if (b.length === 0) return a.length;\n\n // Ensure a is the shorter string for space optimization\n if (a.length > b.length) [a, b] = [b, a];\n\n const row = Array.from({ length: a.length + 1 }, (_, i) => i);\n\n for (let j = 1; j <= b.length; j++) {\n let prev = j - 1;\n row[0] = j;\n for (let i = 1; i <= a.length; i++) {\n const cost = a[i - 1] === b[j - 1] ? 0 : 1;\n const current = Math.min(\n row[i]! + 1, // deletion\n row[i - 1]! + 1, // insertion\n prev + cost, // substitution\n );\n prev = row[i]!;\n row[i] = current;\n }\n }\n\n return row[a.length]!;\n}\n\n/**\n * Finds the most similar known field for an unknown field name.\n * Uses two strategies:\n * 1. Levenshtein distance ≤ 2 for close typos (e.g., \"environments\" → \"environment\")\n * 2. Prefix containment for abbreviations (e.g., \"env\" → \"environment\")\n *\n * Returns the best matching field name, or null if no match found.\n */\nfunction findSimilarField(\n unknown: string,\n knownFields: string[],\n): string | null {\n let bestMatch: string | null = null;\n let bestDistance = Infinity;\n\n for (const known of knownFields) {\n if (unknown === known) continue;\n\n // Check 1: Levenshtein distance ≤ 2\n const distance = levenshteinDistance(unknown, known);\n if (distance <= 2 && distance < bestDistance) {\n bestDistance = distance;\n bestMatch = known;\n }\n\n // Check 2: Prefix containment (unknown is a prefix of known, min 3 chars)\n if (unknown.length >= 3 && known.startsWith(unknown) && !bestMatch) {\n bestMatch = known;\n }\n }\n\n return bestMatch;\n}\n\n/**\n * Extracts agent entries from raw config, with type guards.\n * Returns null if config structure is invalid for agent inspection.\n */\nfunction extractAgentEntries(\n config: unknown,\n): Record<string, Record<string, unknown>> | null {\n if (!config || typeof config !== \"object\") return null;\n const cfg = config as Record<string, unknown>;\n const agents = cfg.agents as\n | Record<string, Record<string, unknown>>\n | undefined;\n if (!agents || typeof agents !== \"object\" || Array.isArray(agents))\n return null;\n return agents;\n}\n\n/**\n * Checks for unknown fields in agent definitions that look like typos.\n * Returns an error message listing all detected typos, or null if none found.\n */\nfunction checkForFieldTypos(config: unknown): string | null {\n const agents = extractAgentEntries(config);\n if (!agents) return null;\n\n const errors: string[] = [];\n\n for (const [agentName, agent] of Object.entries(agents)) {\n if (!agent || typeof agent !== \"object\" || Array.isArray(agent)) continue;\n\n for (const field of Object.keys(agent)) {\n if (KNOWN_AGENT_FIELDS.includes(field)) continue;\n\n const suggestion = findSimilarField(field, KNOWN_AGENT_FIELDS);\n if (suggestion) {\n errors.push(\n `Unknown field \"${field}\" in agent \"${agentName}\". Did you mean \"${suggestion}\"?`,\n );\n }\n }\n }\n\n return errors.length > 0 ? errors.join(\"\\n\") : null;\n}\n\n/**\n * Checks for deprecated 'provider' field and returns migration error message\n */\nfunction checkForDeprecatedProvider(config: unknown): string | null {\n const agents = extractAgentEntries(config);\n if (!agents) return null;\n\n for (const agent of Object.values(agents)) {\n if (agent && typeof agent === \"object\" && !Array.isArray(agent)) {\n if (\"provider\" in agent && !(\"framework\" in agent)) {\n const providerValue = agent.provider;\n return `'provider' field is deprecated. Use 'framework' instead.\\n\\nChange in your vm0.yaml:\\n - provider: ${providerValue}\\n + framework: ${providerValue}`;\n }\n }\n }\n return null;\n}\n\n/**\n * Validates agent compose structure using Zod schemas\n */\nexport function validateAgentCompose(config: unknown): {\n valid: boolean;\n error?: string;\n} {\n // Pre-check: Deprecated 'provider' field\n const deprecationError = checkForDeprecatedProvider(config);\n if (deprecationError) {\n return { valid: false, error: deprecationError };\n }\n\n // Pre-check: Detect likely typos in agent definition fields\n const typoError = checkForFieldTypos(config);\n if (typoError) {\n return { valid: false, error: typoError };\n }\n\n // Pre-check: Better error for array agents (common mistake)\n if (\n config &&\n typeof config === \"object\" &&\n Array.isArray((config as Record<string, unknown>).agents)\n ) {\n return {\n valid: false,\n error:\n \"agents must be an object, not an array. Use format: agents: { agent-name: { ... } }\",\n };\n }\n\n // Pre-check: Basic object check\n if (!config || typeof config !== \"object\") {\n return { valid: false, error: \"Config must be an object\" };\n }\n\n // Main validation using CLI compose schema\n const result = cliComposeSchema.safeParse(config);\n if (!result.success) {\n return { valid: false, error: formatZodError(result.error) };\n }\n\n return { valid: true };\n}\n","import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\nimport {\n getInstructionsStorageName,\n getSkillStorageName as getCoreSkillStorageName,\n parseGitHubTreeUrl as parseGitHubTreeUrlCore,\n parseSkillFrontmatter,\n type ParsedGitHubTreeUrl,\n type SkillFrontmatter,\n} from \"@vm0/core\";\n\n// Re-export from @vm0/core for convenience\nexport { getInstructionsStorageName, type SkillFrontmatter };\n\n// Re-export git operations from boundary module for backward compatibility\nexport {\n downloadGitHubSkill,\n downloadGitHubDirectory,\n} from \"../external/git-client\";\n\n// Re-export the type with the local name for backwards compatibility\ntype ParsedGitHubUrl = ParsedGitHubTreeUrl;\n\n/**\n * Parse a GitHub tree URL into its components\n * Expected format: https://github.com/{owner}/{repo}/tree/{branch}/{path}\n *\n * Note: Branch names containing slashes (e.g., feature/foo) may not parse correctly.\n * The fullPath field is always correct and used for unique storage naming.\n *\n * @param url - GitHub tree URL\n * @returns Parsed URL components\n * @throws Error if URL format is invalid\n */\nexport function parseGitHubTreeUrl(url: string): ParsedGitHubUrl {\n const parsed = parseGitHubTreeUrlCore(url);\n if (!parsed) {\n throw new Error(\n `Invalid GitHub tree URL: ${url}. Expected format: https://github.com/{owner}/{repo}/tree/{branch}/{path}`,\n );\n }\n return parsed;\n}\n\n/**\n * Generate the storage name for an agent skill\n * Format: agent-skills@{fullPath}\n *\n * @param parsed - Parsed GitHub URL\n * @returns Storage name for the skill\n */\nexport function getSkillStorageName(parsed: ParsedGitHubUrl): string {\n return getCoreSkillStorageName(parsed.fullPath);\n}\n\n/**\n * Validate that a downloaded skill has the required SKILL.md file\n *\n * @param skillDir - Path to the downloaded skill directory\n * @returns True if valid, throws error otherwise\n */\nexport async function validateSkillDirectory(skillDir: string): Promise<void> {\n const skillMdPath = path.join(skillDir, \"SKILL.md\");\n try {\n await fs.access(skillMdPath);\n } catch {\n throw new Error(\n `Skill directory missing required SKILL.md file: ${skillDir}`,\n );\n }\n}\n\n/**\n * Read and parse SKILL.md frontmatter from a skill directory\n *\n * @param skillDir - Path to the skill directory\n * @returns Parsed frontmatter fields\n */\nexport async function readSkillFrontmatter(\n skillDir: string,\n): Promise<SkillFrontmatter> {\n const skillMdPath = path.join(skillDir, \"SKILL.md\");\n const content = await fs.readFile(skillMdPath, \"utf8\");\n return parseSkillFrontmatter(content);\n}\n","import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\nimport * as os from \"node:os\";\nimport { execFile } from \"node:child_process\";\nimport { promisify } from \"node:util\";\nimport {\n parseGitHubUrl as parseGitHubUrlCore,\n type ParsedGitHubTreeUrl,\n} from \"@vm0/core\";\n\nconst execFileAsync = promisify(execFile);\n\n/**\n * Sanitize a value intended as a git positional argument to prevent\n * second-order command injection via flags like `--upload-pack`.\n * Only allows safe characters (alphanumeric, dash, underscore, dot, slash).\n * Returns the value if safe; throws otherwise.\n */\nfunction sanitizeGitArg(value: string, label: string): string {\n if (!/^[a-zA-Z0-9._/\\-@]+$/.test(value)) {\n throw new Error(\n `Invalid ${label}: contains disallowed characters. Only alphanumeric, dash, underscore, dot, slash, and @ are permitted.`,\n );\n }\n if (value.startsWith(\"-\")) {\n throw new Error(`Invalid ${label}: must not start with a dash`);\n }\n return value;\n}\n\n/**\n * Result of downloading a GitHub directory\n */\ninterface GitHubDownloadResult {\n /** Path to the downloaded directory */\n dir: string;\n /** Path to the temp root directory (for cleanup) */\n tempRoot: string;\n}\n\n/**\n * Download a GitHub directory using git sparse-checkout\n *\n * @param parsed - Parsed GitHub URL\n * @param destDir - Destination directory for the downloaded content\n * @returns Path to the downloaded skill directory\n */\nexport async function downloadGitHubSkill(\n parsed: ParsedGitHubTreeUrl,\n destDir: string,\n): Promise<string> {\n const owner = sanitizeGitArg(parsed.owner, \"repository owner\");\n const repo = sanitizeGitArg(parsed.repo, \"repository name\");\n const branch = sanitizeGitArg(parsed.branch, \"branch name\");\n const repoUrl = `https://github.com/${owner}/${repo}.git`;\n const skillDir = path.join(destDir, parsed.skillName);\n\n // Create a temporary directory for sparse checkout\n const tempDir = await fs.mkdtemp(path.join(os.tmpdir(), \"vm0-skill-\"));\n\n try {\n // Initialize sparse checkout\n await execFileAsync(\"git\", [\"init\"], { cwd: tempDir });\n await execFileAsync(\"git\", [\"remote\", \"add\", \"origin\", repoUrl], {\n cwd: tempDir,\n });\n await execFileAsync(\"git\", [\"config\", \"core.sparseCheckout\", \"true\"], {\n cwd: tempDir,\n });\n\n // Configure sparse checkout to only fetch the skill path\n // For root: use \"/*\" to get all root-level files\n // For path: use the path directly\n const sparsePattern = parsed.path || \"/*\";\n const sparseFile = path.join(tempDir, \".git\", \"info\", \"sparse-checkout\");\n await fs.writeFile(sparseFile, sparsePattern + \"\\n\");\n\n // Fetch only the required branch\n await execFileAsync(\"git\", [\"fetch\", \"--depth\", \"1\", \"origin\", branch], {\n cwd: tempDir,\n });\n await execFileAsync(\"git\", [\"checkout\", branch], { cwd: tempDir });\n\n // Move the skill directory to destination\n await fs.mkdir(path.dirname(skillDir), { recursive: true });\n if (parsed.path) {\n // Subdirectory: move the fetched subdirectory\n const fetchedPath = path.join(tempDir, parsed.path);\n await fs.rename(fetchedPath, skillDir);\n } else {\n // Root: move all entries except .git from tempDir\n await fs.mkdir(skillDir, { recursive: true });\n const entries = await fs.readdir(tempDir);\n for (const entry of entries) {\n if (entry === \".git\") continue;\n await fs.rename(path.join(tempDir, entry), path.join(skillDir, entry));\n }\n }\n\n return skillDir;\n } finally {\n // Clean up temp directory\n await fs.rm(tempDir, { recursive: true, force: true });\n }\n}\n\n/**\n * Get the default branch of a GitHub repository using git ls-remote.\n * This avoids dependency on gh CLI and works with just git installed.\n *\n * @param owner - Repository owner\n * @param repo - Repository name\n * @returns Default branch name\n */\nasync function getDefaultBranch(owner: string, repo: string): Promise<string> {\n const safeOwner = sanitizeGitArg(owner, \"repository owner\");\n const safeRepo = sanitizeGitArg(repo, \"repository name\");\n const repoUrl = `https://github.com/${safeOwner}/${safeRepo}.git`;\n try {\n // git ls-remote --symref outputs:\n // ref: refs/heads/main HEAD\n // a1b2c3d... HEAD\n const { stdout } = await execFileAsync(\"git\", [\n \"ls-remote\",\n \"--symref\",\n repoUrl,\n \"HEAD\",\n ]);\n\n // Extract branch name from \"ref: refs/heads/main\" line\n const match = stdout.match(/ref: refs\\/heads\\/([^\\s]+)/);\n if (!match) {\n throw new Error(\n `Could not determine default branch for ${owner}/${repo}`,\n );\n }\n return match[1]!;\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n if (\n message.includes(\"not found\") ||\n message.includes(\"Repository not found\")\n ) {\n throw new Error(`Repository not found: ${owner}/${repo}`);\n }\n if (\n message.includes(\"Authentication failed\") ||\n message.includes(\"could not read Username\")\n ) {\n throw new Error(\n `Cannot access repository ${owner}/${repo}. Is it private?`,\n );\n }\n throw error;\n }\n}\n\n/**\n * Download a GitHub directory using git sparse-checkout.\n * Returns paths to both the downloaded directory and the temp root for cleanup.\n *\n * Supports multiple URL formats:\n * - https://github.com/owner/repo (plain repo, uses default branch, downloads root)\n * - https://github.com/owner/repo/tree/branch (root directory with explicit branch)\n * - https://github.com/owner/repo/tree/branch/path (subdirectory)\n *\n * @param url - GitHub URL\n * @returns Object with dir (downloaded path) and tempRoot (for cleanup)\n */\nexport async function downloadGitHubDirectory(\n url: string,\n): Promise<GitHubDownloadResult> {\n const parsed = parseGitHubUrlCore(url);\n if (!parsed) {\n throw new Error(\n `Invalid GitHub URL: ${url}. Expected format: https://github.com/{owner}/{repo}[/tree/{branch}[/path]]`,\n );\n }\n\n const safeOwner = sanitizeGitArg(parsed.owner, \"repository owner\");\n const safeRepo = sanitizeGitArg(parsed.repo, \"repository name\");\n const repoUrl = `https://github.com/${safeOwner}/${safeRepo}.git`;\n const tempDir = await fs.mkdtemp(path.join(os.tmpdir(), \"vm0-github-\"));\n\n try {\n // Check git is available\n try {\n await execFileAsync(\"git\", [\"--version\"]);\n } catch {\n throw new Error(\n \"git command not found. Please install git to use GitHub URLs.\",\n );\n }\n\n // Resolve branch if not specified\n const branch = sanitizeGitArg(\n parsed.branch ?? (await getDefaultBranch(safeOwner, safeRepo)),\n \"branch name\",\n );\n\n // Initialize sparse checkout\n await execFileAsync(\"git\", [\"init\"], { cwd: tempDir });\n await execFileAsync(\"git\", [\"remote\", \"add\", \"origin\", repoUrl], {\n cwd: tempDir,\n });\n await execFileAsync(\"git\", [\"config\", \"core.sparseCheckout\", \"true\"], {\n cwd: tempDir,\n });\n\n // Configure sparse checkout pattern\n // For root: use \"/*\" to get all root-level files\n // For path: use the path directly\n const sparsePattern = parsed.path ?? \"/*\";\n const sparseFile = path.join(tempDir, \".git\", \"info\", \"sparse-checkout\");\n await fs.writeFile(sparseFile, sparsePattern + \"\\n\");\n\n // Fetch only the required branch with better error handling\n try {\n await execFileAsync(\"git\", [\"fetch\", \"--depth\", \"1\", \"origin\", branch], {\n cwd: tempDir,\n });\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n if (\n message.includes(\"Authentication failed\") ||\n message.includes(\"could not read Username\")\n ) {\n throw new Error(`Cannot access repository. Is it private? URL: ${url}`);\n }\n if (message.includes(\"couldn't find remote ref\")) {\n throw new Error(`Branch \"${branch}\" not found in repository: ${url}`);\n }\n throw error;\n }\n\n await execFileAsync(\"git\", [\"checkout\", branch], { cwd: tempDir });\n\n // Return directory path\n // For root: return tempDir directly\n // For path: return tempDir/path\n const downloadedDir = parsed.path\n ? path.join(tempDir, parsed.path)\n : tempDir;\n\n return {\n dir: downloadedDir,\n tempRoot: tempDir,\n };\n } catch (error) {\n // Clean up on error\n await fs.rm(tempDir, { recursive: true, force: true });\n throw error;\n }\n}\n","import * as fs from \"node:fs/promises\";\nimport * as path from \"node:path\";\nimport * as os from \"node:os\";\nimport {\n parseGitHubTreeUrl,\n downloadGitHubSkill,\n getSkillStorageName,\n getInstructionsStorageName,\n validateSkillDirectory,\n readSkillFrontmatter,\n type SkillFrontmatter,\n} from \"../domain/github-skills\";\nimport { directUpload } from \"./direct-upload\";\nimport { getInstructionsFilename } from \"@vm0/core\";\n\ninterface StorageUploadResult {\n name: string;\n versionId: string;\n action: \"created\" | \"deduplicated\";\n}\n\n/**\n * Result of uploading or resolving a skill, including parsed frontmatter.\n * Action \"resolved\" means the skill was found in server cache (no download/upload needed).\n */\nexport interface SkillUploadResult {\n name: string;\n versionId: string;\n action: \"created\" | \"deduplicated\" | \"resolved\";\n skillName: string;\n frontmatter: SkillFrontmatter;\n}\n\n/**\n * Upload instructions file as a volume\n *\n * @param agentName - Name of the agent (used for storage name)\n * @param instructionsFilePath - Path to the instructions file (e.g., AGENTS.md)\n * @param basePath - Base path for resolving relative paths\n * @param framework - Framework name for determining canonical filename\n * @returns Upload result with storage name and version\n */\nexport async function uploadInstructions(\n agentName: string,\n instructionsFilePath: string,\n basePath: string,\n framework?: string,\n): Promise<StorageUploadResult> {\n // Normalize agent name to lowercase to match server's normalization behavior\n // Server normalizes agent names to lowercase when storing compose configs\n const storageName = getInstructionsStorageName(agentName.toLowerCase());\n\n // Resolve file path relative to base path\n const absolutePath = path.isAbsolute(instructionsFilePath)\n ? instructionsFilePath\n : path.join(basePath, instructionsFilePath);\n\n // Read the instructions file\n const content = await fs.readFile(absolutePath, \"utf8\");\n\n // Create a temporary directory with the file\n const tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), \"vm0-instructions-\"));\n const instructionsDir = path.join(tmpDir, \"instructions\");\n await fs.mkdir(instructionsDir);\n\n // Write file with framework-specific name (e.g., CLAUDE.md for claude-code)\n const filename = getInstructionsFilename(framework);\n await fs.writeFile(path.join(instructionsDir, filename), content);\n\n try {\n // Use direct upload (bypasses Vercel 4.5MB limit)\n const result = await directUpload(storageName, \"volume\", instructionsDir);\n\n return {\n name: storageName,\n versionId: result.versionId,\n action: result.deduplicated ? \"deduplicated\" : \"created\",\n };\n } finally {\n // Clean up temp directory\n await fs.rm(tmpDir, { recursive: true, force: true });\n }\n}\n\n/**\n * Upload a skill from GitHub as a volume\n *\n * @param skillUrl - GitHub tree URL for the skill\n * @returns Upload result with storage name, version, and parsed frontmatter\n */\nexport async function uploadSkill(\n skillUrl: string,\n): Promise<SkillUploadResult> {\n const parsed = parseGitHubTreeUrl(skillUrl);\n const storageName = getSkillStorageName(parsed);\n\n // Create temp directory for download\n const tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), \"vm0-skill-\"));\n\n try {\n // Download skill from GitHub\n const skillDir = await downloadGitHubSkill(parsed, tmpDir);\n\n // Validate the skill has SKILL.md\n await validateSkillDirectory(skillDir);\n\n // Parse frontmatter before upload\n const frontmatter = await readSkillFrontmatter(skillDir);\n\n // Use direct upload (bypasses Vercel 4.5MB limit)\n const result = await directUpload(storageName, \"volume\", skillDir);\n\n return {\n name: storageName,\n versionId: result.versionId,\n action: result.deduplicated ? \"deduplicated\" : \"created\",\n skillName: parsed.skillName,\n frontmatter,\n };\n } finally {\n // Clean up temp directory\n await fs.rm(tmpDir, { recursive: true, force: true });\n }\n}\n","import { createHash } from \"crypto\";\nimport * as fs from \"fs\";\nimport * as path from \"path\";\nimport * as os from \"os\";\nimport * as tar from \"tar\";\nimport { prepareStorage, commitStorage } from \"../api\";\nimport { excludeVm0Filter } from \"../utils/file-utils\";\n\n/**\n * File entry with pre-computed hash for direct upload\n */\ninterface FileEntryWithHash {\n path: string;\n hash: string;\n size: number;\n}\n\n/**\n * Result of direct upload operation\n */\ninterface DirectUploadResult {\n versionId: string;\n size: number;\n fileCount: number;\n deduplicated: boolean;\n empty: boolean;\n}\n\n/**\n * Progress callback for upload operations\n */\ntype ProgressCallback = (message: string) => void;\n\n/**\n * Compute SHA-256 hash of a file using streaming to avoid loading large files into memory\n */\nasync function hashFileStream(filePath: string): Promise<string> {\n return new Promise((resolve, reject) => {\n const hash = createHash(\"sha256\");\n const stream = fs.createReadStream(filePath);\n\n stream.on(\"data\", (chunk) => hash.update(chunk));\n stream.on(\"end\", () => resolve(hash.digest(\"hex\")));\n stream.on(\"error\", reject);\n });\n}\n\n/**\n * Get all files in directory recursively, excluding .vm0/\n */\nasync function getAllFiles(\n dirPath: string,\n baseDir: string = dirPath,\n): Promise<string[]> {\n const files: string[] = [];\n const entries = await fs.promises.readdir(dirPath, { withFileTypes: true });\n\n for (const entry of entries) {\n const fullPath = path.join(dirPath, entry.name);\n const relativePath = path.relative(baseDir, fullPath);\n\n // Skip .vm0 directory\n if (relativePath.startsWith(\".vm0\")) {\n continue;\n }\n\n if (entry.isDirectory()) {\n const subFiles = await getAllFiles(fullPath, baseDir);\n files.push(...subFiles);\n } else {\n files.push(fullPath);\n }\n }\n\n return files;\n}\n\n/**\n * Collect file metadata with hashes using streaming to handle large files\n */\nasync function collectFileMetadata(\n cwd: string,\n files: string[],\n onProgress?: ProgressCallback,\n): Promise<FileEntryWithHash[]> {\n const fileEntries: FileEntryWithHash[] = [];\n\n for (let i = 0; i < files.length; i++) {\n const file = files[i]!;\n const relativePath = path.relative(cwd, file);\n\n // Use streaming hash to avoid loading large files into memory\n const [hash, stats] = await Promise.all([\n hashFileStream(file),\n fs.promises.stat(file),\n ]);\n\n fileEntries.push({\n path: relativePath,\n hash,\n size: stats.size,\n });\n\n // Report progress every 100 files\n if (onProgress && (i + 1) % 100 === 0) {\n onProgress(`Hashing files... ${i + 1}/${files.length}`);\n }\n }\n\n return fileEntries;\n}\n\n/**\n * Create tar.gz archive of files\n */\nasync function createArchive(cwd: string, files: string[]): Promise<Buffer> {\n const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), \"vm0-\"));\n const tarPath = path.join(tmpDir, \"archive.tar.gz\");\n\n try {\n const relativePaths = files.map((file) => path.relative(cwd, file));\n\n if (relativePaths.length > 0) {\n await tar.create(\n {\n gzip: true,\n file: tarPath,\n cwd: cwd,\n },\n relativePaths,\n );\n } else {\n // For empty directories, create tar.gz excluding .vm0\n await tar.create(\n {\n gzip: true,\n file: tarPath,\n cwd: cwd,\n filter: excludeVm0Filter,\n },\n [\".\"],\n );\n }\n\n const tarBuffer = await fs.promises.readFile(tarPath);\n return tarBuffer;\n } finally {\n // Clean up temp files\n if (fs.existsSync(tarPath)) {\n await fs.promises.unlink(tarPath);\n }\n await fs.promises.rmdir(tmpDir);\n }\n}\n\n/**\n * Create manifest JSON for the upload\n */\nfunction createManifest(files: FileEntryWithHash[]): Buffer {\n const manifest = {\n version: 1,\n files,\n createdAt: new Date().toISOString(),\n };\n return Buffer.from(JSON.stringify(manifest, null, 2));\n}\n\n/**\n * Sleep for a given number of milliseconds\n */\nfunction sleep(ms: number): Promise<void> {\n return new Promise((resolve) => setTimeout(resolve, ms));\n}\n\n/**\n * Upload buffer to presigned URL with retry logic\n */\nasync function uploadToPresignedUrl(\n presignedUrl: string,\n data: Buffer,\n contentType: string,\n maxRetries: number = 3,\n): Promise<void> {\n let lastError: Error | null = null;\n\n for (let attempt = 1; attempt <= maxRetries; attempt++) {\n try {\n const response = await fetch(presignedUrl, {\n method: \"PUT\",\n body: data,\n headers: {\n \"Content-Type\": contentType,\n },\n });\n\n if (response.ok) {\n return;\n }\n\n // For 4xx errors (client errors), don't retry\n if (response.status >= 400 && response.status < 500) {\n const text = await response.text();\n throw new Error(`S3 upload failed: ${response.status} - ${text}`);\n }\n\n // For 5xx errors, retry with backoff\n const text = await response.text();\n lastError = new Error(`S3 upload failed: ${response.status} - ${text}`);\n } catch (error) {\n lastError =\n error instanceof Error ? error : new Error(\"Unknown upload error\");\n\n // Don't retry on client errors\n if (\n lastError.message.includes(\"400\") ||\n lastError.message.includes(\"403\")\n ) {\n throw lastError;\n }\n }\n\n // Exponential backoff: 1s, 2s, 4s...\n if (attempt < maxRetries) {\n const backoffMs = Math.pow(2, attempt - 1) * 1000;\n await sleep(backoffMs);\n }\n }\n\n throw lastError || new Error(\"S3 upload failed after retries\");\n}\n\n/**\n * Options for direct upload\n */\ninterface DirectUploadOptions {\n onProgress?: ProgressCallback;\n force?: boolean;\n}\n\n/**\n * Perform direct S3 upload for a storage (volume or artifact)\n *\n * This bypasses Vercel's 4.5MB request body limit by:\n * 1. Computing file hashes locally\n * 2. Getting presigned URLs from /api/storages/prepare\n * 3. Uploading directly to S3\n * 4. Committing via /api/storages/commit\n */\nexport async function directUpload(\n storageName: string,\n storageType: \"volume\" | \"artifact\" | \"memory\",\n cwd: string,\n options?: DirectUploadOptions,\n): Promise<DirectUploadResult> {\n const { onProgress, force } = options || {};\n\n // Step 1: Collect all files\n onProgress?.(\"Collecting files...\");\n const files = await getAllFiles(cwd);\n\n // Step 2: Compute hashes for all files\n onProgress?.(\"Computing file hashes...\");\n const fileEntries = await collectFileMetadata(cwd, files, onProgress);\n\n // Step 3: Call prepare endpoint\n onProgress?.(\"Preparing upload...\");\n const prepareResult = await prepareStorage({\n storageName,\n storageType,\n files: fileEntries,\n force,\n });\n\n // Step 4: Check if version already exists (deduplication)\n // Skip upload but still call commit to update HEAD (fixes #626)\n if (prepareResult.existing) {\n onProgress?.(\"Version exists, updating HEAD...\");\n\n const commitResult = await commitStorage({\n storageName,\n storageType,\n versionId: prepareResult.versionId,\n files: fileEntries,\n });\n\n return {\n versionId: commitResult.versionId,\n size: commitResult.size,\n fileCount: commitResult.fileCount,\n deduplicated: true,\n empty: commitResult.fileCount === 0,\n };\n }\n\n // Step 5: Create and upload archive (skip for empty artifacts)\n if (files.length > 0) {\n onProgress?.(\"Compressing files...\");\n const archiveBuffer = await createArchive(cwd, files);\n\n onProgress?.(\"Uploading archive to S3...\");\n if (!prepareResult.uploads) {\n throw new Error(\"No upload URLs received from prepare endpoint\");\n }\n\n await uploadToPresignedUrl(\n prepareResult.uploads.archive.presignedUrl,\n archiveBuffer,\n \"application/gzip\",\n );\n }\n\n // Step 6: Create and upload manifest\n onProgress?.(\"Uploading manifest...\");\n if (!prepareResult.uploads) {\n throw new Error(\"No upload URLs received from prepare endpoint\");\n }\n const manifestBuffer = createManifest(fileEntries);\n await uploadToPresignedUrl(\n prepareResult.uploads.manifest.presignedUrl,\n manifestBuffer,\n \"application/json\",\n );\n\n // Step 7: Commit the upload\n onProgress?.(\"Committing...\");\n const commitResult = await commitStorage({\n storageName,\n storageType,\n versionId: prepareResult.versionId,\n files: fileEntries,\n });\n\n return {\n versionId: commitResult.versionId,\n size: commitResult.size,\n fileCount: commitResult.fileCount,\n deduplicated: commitResult.deduplicated || false,\n empty: commitResult.fileCount === 0,\n };\n}\n","import * as fs from \"fs\";\nimport * as path from \"path\";\nimport * as tar from \"tar\";\n\n/**\n * Check if a directory exists and is empty (contains no files or subdirectories).\n * Returns: { exists: boolean, empty: boolean }\n * - Non-existent path: { exists: false, empty: true }\n * - Existing empty directory: { exists: true, empty: true }\n * - Existing non-empty directory: { exists: true, empty: false }\n * - Existing file (not directory): { exists: true, empty: false }\n */\nexport function checkDirectoryStatus(dirPath: string): {\n exists: boolean;\n empty: boolean;\n} {\n if (!fs.existsSync(dirPath)) {\n return { exists: false, empty: true };\n }\n\n const stat = fs.statSync(dirPath);\n if (!stat.isDirectory()) {\n // Path exists but is a file, not a directory\n return { exists: true, empty: false };\n }\n\n const entries = fs.readdirSync(dirPath);\n return { exists: true, empty: entries.length === 0 };\n}\n\n/**\n * Format bytes to human-readable format\n */\nexport function formatBytes(bytes: number): string {\n if (bytes === 0) return \"0 B\";\n const k = 1024;\n const sizes = [\"B\", \"KB\", \"MB\", \"GB\"];\n const i = Math.floor(Math.log(bytes) / Math.log(k));\n return `${(bytes / Math.pow(k, i)).toFixed(2)} ${sizes[i]}`;\n}\n\n/**\n * Format relative time from ISO date string\n */\nexport function formatRelativeTime(isoDate: string): string {\n const date = new Date(isoDate);\n const now = new Date();\n const diffMs = now.getTime() - date.getTime();\n const diffSec = Math.floor(diffMs / 1000);\n const diffMin = Math.floor(diffSec / 60);\n const diffHour = Math.floor(diffMin / 60);\n const diffDay = Math.floor(diffHour / 24);\n const diffWeek = Math.floor(diffDay / 7);\n\n if (diffSec < 60) return \"just now\";\n if (diffMin < 60) return `${diffMin} minute${diffMin === 1 ? \"\" : \"s\"} ago`;\n if (diffHour < 24) return `${diffHour} hour${diffHour === 1 ? \"\" : \"s\"} ago`;\n if (diffDay < 7) return `${diffDay} day${diffDay === 1 ? \"\" : \"s\"} ago`;\n return `${diffWeek} week${diffWeek === 1 ? \"\" : \"s\"} ago`;\n}\n\n/**\n * Filter function for tar.create to exclude .vm0 directory.\n * Paths come as \"./.vm0\" or \".vm0\" depending on tar version.\n */\nexport function excludeVm0Filter(filePath: string): boolean {\n const shouldExclude =\n filePath === \".vm0\" ||\n filePath.startsWith(\".vm0/\") ||\n filePath.startsWith(\"./.vm0\");\n return !shouldExclude;\n}\n\n/**\n * List files in tar.gz buffer using streaming parser.\n */\nexport function listTarFiles(tarPath: string): Promise<string[]> {\n return new Promise((resolve, reject) => {\n const files: string[] = [];\n\n tar\n .list({\n file: tarPath,\n onReadEntry: (entry) => {\n if (entry.type === \"File\") {\n files.push(entry.path);\n }\n },\n })\n .then(() => resolve(files))\n .catch(reject);\n });\n}\n\n/**\n * Recursively list all files in a directory, excluding specified directories.\n * Returns relative paths from the base directory.\n */\nasync function listLocalFiles(\n dir: string,\n excludeDirs: string[] = [\".vm0\"],\n): Promise<string[]> {\n const files: string[] = [];\n\n async function walkDir(currentDir: string, relativePath: string = \"\") {\n const entries = await fs.promises.readdir(currentDir, {\n withFileTypes: true,\n });\n\n for (const entry of entries) {\n const entryRelativePath = relativePath\n ? path.join(relativePath, entry.name)\n : entry.name;\n\n if (entry.isDirectory()) {\n if (!excludeDirs.includes(entry.name)) {\n await walkDir(path.join(currentDir, entry.name), entryRelativePath);\n }\n } else {\n files.push(entryRelativePath);\n }\n }\n }\n\n await walkDir(dir);\n return files;\n}\n\n/**\n * Remove files that exist locally but not in remote.\n * Returns the number of files removed.\n */\nexport async function removeExtraFiles(\n dir: string,\n remoteFiles: Set<string>,\n excludeDirs: string[] = [\".vm0\"],\n): Promise<number> {\n const localFiles = await listLocalFiles(dir, excludeDirs);\n let removedCount = 0;\n\n for (const localFile of localFiles) {\n // Normalize path separators for comparison\n const normalizedPath = localFile.replace(/\\\\/g, \"/\");\n if (!remoteFiles.has(normalizedPath)) {\n const fullPath = path.join(dir, localFile);\n await fs.promises.unlink(fullPath);\n removedCount++;\n }\n }\n\n // Clean up empty directories\n await removeEmptyDirs(dir, excludeDirs);\n\n return removedCount;\n}\n\n/**\n * Recursively remove empty directories, excluding specified directories.\n */\nasync function removeEmptyDirs(\n dir: string,\n excludeDirs: string[] = [\".vm0\"],\n): Promise<boolean> {\n const entries = await fs.promises.readdir(dir, { withFileTypes: true });\n\n let isEmpty = true;\n\n for (const entry of entries) {\n const fullPath = path.join(dir, entry.name);\n\n if (entry.isDirectory()) {\n if (excludeDirs.includes(entry.name)) {\n isEmpty = false;\n } else {\n const subDirEmpty = await removeEmptyDirs(fullPath, excludeDirs);\n if (subDirEmpty) {\n await fs.promises.rmdir(fullPath);\n } else {\n isEmpty = false;\n }\n }\n } else {\n isEmpty = false;\n }\n }\n\n return isEmpty;\n}\n","import { Command, Option } from \"commander\";\nimport {\n getComposeById,\n getComposeByName,\n getComposeVersion,\n createRun,\n} from \"../../lib/api\";\nimport {\n collectKeyValue,\n collectVolumeVersions,\n isUUID,\n extractVarNames,\n extractSecretNames,\n loadValues,\n parseFirewallPolicies,\n parseIdentifier,\n pollEvents,\n showNextSteps,\n renderRunCreated,\n} from \"./shared\";\nimport {\n startSilentUpgrade,\n waitForSilentUpgrade,\n} from \"../../lib/utils/update-checker\";\nimport { withErrorHandler } from \"../../lib/command\";\n\ndeclare const __CLI_VERSION__: string;\n\nexport const mainRunCommand = new Command()\n .name(\"run\")\n .description(\"Run an agent\")\n .argument(\n \"<agent-name>\",\n \"Agent reference: [org/]name[:version] (e.g., 'my-agent', 'lancy/my-agent:abc123', 'my-agent:latest')\",\n )\n .argument(\"<prompt>\", \"Prompt for the agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\n \"--vars <KEY=value>\",\n \"Variables for ${{ vars.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--secrets <KEY=value>\",\n \"Secrets for ${{ secrets.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\"--artifact-name <name>\", \"Artifact storage name (required for run)\")\n .option(\n \"--artifact-version <hash>\",\n \"Artifact version hash (defaults to latest)\",\n )\n .option(\n \"--volume-version <name=version>\",\n \"Volume version override (repeatable, format: volumeName=version)\",\n collectVolumeVersions,\n {},\n )\n .option(\"--memory <name>\", \"Memory storage name\")\n .option(\n \"--conversation <id>\",\n \"Resume from conversation ID (for fine-grained control)\",\n )\n .option(\n \"--model-provider <type>\",\n \"Override model provider (e.g., anthropic-api-key)\",\n )\n .option(\n \"--append-system-prompt <text>\",\n \"Append text to the agent's system prompt\",\n )\n .option(\n \"--disallowed-tools <tools...>\",\n \"Tools to disable in Claude CLI (e.g., CronCreate WebSearch)\",\n )\n .option(\n \"--tools <tools...>\",\n \"Built-in tools to make available in Claude CLI (e.g., Bash Edit Read)\",\n )\n .option(\n \"--settings <json>\",\n \"Settings JSON to pass to Claude CLI (e.g., hooks, permissions)\",\n )\n .option(\n \"--firewall-policies <json>\",\n 'Firewall policies JSON (e.g., \\'{\"github\": {\"actions:read\": \"allow\"}}\\')',\n )\n .option(\"--verbose\", \"Show full tool inputs and outputs\")\n .option(\"--check-env\", \"Validate secrets and vars before running\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .addOption(new Option(\"--no-auto-update\").hideHelp())\n .action(\n withErrorHandler(\n async (\n identifier: string,\n prompt: string,\n options: {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n artifactName?: string;\n artifactVersion?: string;\n memory?: string;\n volumeVersion: Record<string, string>;\n conversation?: string;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n autoUpdate?: boolean;\n },\n ) => {\n // Start upgrade in background at command start (runs in parallel)\n if (options.autoUpdate !== false) {\n await startSilentUpgrade(__CLI_VERSION__);\n }\n\n // 1. Parse identifier for optional org and version specifier\n const { org, name, version } = parseIdentifier(identifier);\n\n // 2. Resolve name to composeId and get compose content\n let composeId: string;\n let composeContent: unknown;\n\n if (isUUID(name)) {\n // It's a UUID compose ID - fetch compose to get content\n const compose = await getComposeById(name);\n composeId = compose.id;\n composeContent = compose.content;\n } else {\n // It's an agent name - resolve to compose ID\n const compose = await getComposeByName(name, org);\n if (!compose) {\n throw new Error(`Agent not found: ${identifier}`, {\n cause: new Error(\n \"Make sure you've composed the agent with: vm0 compose\",\n ),\n });\n }\n\n composeId = compose.id;\n composeContent = compose.content;\n }\n\n // 3. Resolve version if specified\n let agentComposeVersionId: string | undefined;\n\n if (version && version !== \"latest\") {\n // Resolve version hash to full version ID\n try {\n const versionInfo = await getComposeVersion(composeId, version);\n agentComposeVersionId = versionInfo.versionId;\n } catch (error) {\n throw new Error(`Version not found: ${version}`, {\n cause: error instanceof Error ? error : undefined,\n });\n }\n }\n // Note: \"latest\" version uses agentComposeId which resolves to HEAD\n\n // 4. Load vars and secrets with priority: CLI args > --env-file > env vars\n const varNames = extractVarNames(composeContent);\n const vars = loadValues(options.vars, varNames, options.envFile);\n\n const secretNames = extractSecretNames(composeContent);\n const secrets = loadValues(\n options.secrets,\n secretNames,\n options.envFile,\n );\n\n // 5. Call unified API (server handles all variable expansion)\n const response = await createRun({\n // Use agentComposeVersionId if resolved, otherwise use agentComposeId (resolves to HEAD)\n ...(agentComposeVersionId\n ? { agentComposeVersionId }\n : { agentComposeId: composeId }),\n prompt,\n vars,\n secrets,\n artifactName: options.artifactName,\n artifactVersion: options.artifactVersion,\n memoryName: options.memory,\n volumeVersions:\n Object.keys(options.volumeVersion).length > 0\n ? options.volumeVersion\n : undefined,\n conversationId: options.conversation,\n modelProvider: options.modelProvider,\n appendSystemPrompt: options.appendSystemPrompt,\n disallowedTools: options.disallowedTools,\n tools: options.tools,\n settings: options.settings,\n firewallPolicies: parseFirewallPolicies(options.firewallPolicies),\n checkEnv: options.checkEnv || undefined,\n debugNoMockClaude: options.debugNoMockClaude || undefined,\n });\n\n // 4. Check for immediate failure (e.g., missing secrets)\n if (response.status === \"failed\") {\n throw new Error(\n \"Run preparation failed\",\n response.error ? { cause: new Error(response.error) } : undefined,\n );\n }\n\n // 5. Display run started/queued info\n renderRunCreated(response);\n\n // 6. Poll for events and exit with appropriate code\n const result = await pollEvents(response.runId, {\n verbose: options.verbose,\n });\n if (!result.succeeded) {\n throw new Error(\"Run failed\");\n }\n showNextSteps(result);\n\n // Wait for upgrade at command end (shows warning if failed)\n if (options.autoUpdate !== false) {\n await waitForSilentUpgrade();\n }\n },\n ),\n );\n","import { Command, Option } from \"commander\";\nimport { getCheckpoint, createRun } from \"../../lib/api\";\nimport {\n collectKeyValue,\n collectVolumeVersions,\n isUUID,\n loadValues,\n parseFirewallPolicies,\n pollEvents,\n showNextSteps,\n renderRunCreated,\n} from \"./shared\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const resumeCommand = new Command()\n .name(\"resume\")\n .description(\"Resume an agent run from a checkpoint (uses all snapshot data)\")\n .argument(\"<checkpointId>\", \"Checkpoint ID to resume from\")\n .argument(\"<prompt>\", \"Prompt for the resumed agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\n \"--vars <KEY=value>\",\n \"Variables for ${{ vars.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--secrets <KEY=value>\",\n \"Secrets for ${{ secrets.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--volume-version <name=version>\",\n \"Volume version override (repeatable)\",\n collectVolumeVersions,\n {},\n )\n .option(\n \"--model-provider <type>\",\n \"Override model provider (e.g., anthropic-api-key)\",\n )\n .option(\n \"--append-system-prompt <text>\",\n \"Append text to the agent's system prompt\",\n )\n .option(\n \"--disallowed-tools <tools...>\",\n \"Tools to disable in Claude CLI (e.g., CronCreate WebSearch)\",\n )\n .option(\n \"--tools <tools...>\",\n \"Built-in tools to make available in Claude CLI (e.g., Bash Edit Read)\",\n )\n .option(\n \"--settings <json>\",\n \"Settings JSON to pass to Claude CLI (e.g., hooks, permissions)\",\n )\n .option(\n \"--firewall-policies <json>\",\n 'Firewall policies JSON (e.g., \\'{\"github\": {\"actions:read\": \"allow\"}}\\')',\n )\n .option(\"--verbose\", \"Show full tool inputs and outputs\")\n .option(\"--check-env\", \"Validate secrets and vars before running\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .action(\n withErrorHandler(\n async (\n checkpointId: string,\n prompt: string,\n options: {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n },\n command: { optsWithGlobals: () => Record<string, unknown> },\n ) => {\n // Commander.js quirk: when parent command has same option name,\n // the option value goes to parent. Use optsWithGlobals() to get all options.\n const allOpts = command.optsWithGlobals() as {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n volumeVersion: Record<string, string>;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n };\n\n // Merge vars and secrets from command options\n const vars = { ...allOpts.vars, ...options.vars };\n const secrets = { ...allOpts.secrets, ...options.secrets };\n\n // 1. Validate checkpoint ID format\n if (!isUUID(checkpointId)) {\n throw new Error(`Invalid checkpoint ID format: ${checkpointId}`, {\n cause: new Error(\"Checkpoint ID must be a valid UUID\"),\n });\n }\n\n // 2. Fetch checkpoint info to get required secret names\n // This allows loading secrets from environment variables\n const checkpointInfo = await getCheckpoint(checkpointId);\n const requiredSecretNames =\n checkpointInfo.agentComposeSnapshot.secretNames || [];\n\n // 3. Load secrets from CLI options + --env-file + environment variables\n // Priority: CLI flags > --env-file > env vars\n const envFile = options.envFile || allOpts.envFile;\n const loadedSecrets = loadValues(secrets, requiredSecretNames, envFile);\n\n // 4. Call unified API with checkpointId\n const response = await createRun({\n checkpointId,\n prompt,\n vars: Object.keys(vars).length > 0 ? vars : undefined,\n secrets: loadedSecrets,\n volumeVersions:\n Object.keys(allOpts.volumeVersion).length > 0\n ? allOpts.volumeVersion\n : undefined,\n modelProvider: options.modelProvider || allOpts.modelProvider,\n appendSystemPrompt:\n options.appendSystemPrompt || allOpts.appendSystemPrompt,\n disallowedTools: options.disallowedTools || allOpts.disallowedTools,\n tools: options.tools || allOpts.tools,\n settings: options.settings || allOpts.settings,\n firewallPolicies: parseFirewallPolicies(\n options.firewallPolicies || allOpts.firewallPolicies,\n ),\n checkEnv: options.checkEnv || allOpts.checkEnv || undefined,\n debugNoMockClaude:\n options.debugNoMockClaude || allOpts.debugNoMockClaude || undefined,\n });\n\n // 4. Check for immediate failure (e.g., missing secrets)\n if (response.status === \"failed\") {\n throw new Error(\n \"Run preparation failed\",\n response.error ? { cause: new Error(response.error) } : undefined,\n );\n }\n\n // 5. Display run started/queued info\n renderRunCreated(response);\n\n // 6. Poll for events and exit with appropriate code\n const verbose = options.verbose || allOpts.verbose;\n const result = await pollEvents(response.runId, { verbose });\n if (!result.succeeded) {\n throw new Error(\"Run failed\");\n }\n showNextSteps(result);\n },\n ),\n );\n","import { Command, Option } from \"commander\";\nimport { getSession, createRun } from \"../../lib/api\";\nimport {\n collectKeyValue,\n isUUID,\n loadValues,\n parseFirewallPolicies,\n pollEvents,\n showNextSteps,\n renderRunCreated,\n} from \"./shared\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const continueCommand = new Command()\n .name(\"continue\")\n .description(\n \"Continue an agent run from a session (uses latest artifact version)\",\n )\n .argument(\"<agentSessionId>\", \"Agent session ID to continue from\")\n .argument(\"<prompt>\", \"Prompt for the continued agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\n \"--vars <KEY=value>\",\n \"Variables for ${{ vars.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--secrets <KEY=value>\",\n \"Secrets for ${{ secrets.xxx }} (repeatable, falls back to --env-file or env vars)\",\n collectKeyValue,\n {},\n )\n .option(\n \"--model-provider <type>\",\n \"Override model provider (e.g., anthropic-api-key)\",\n )\n .option(\n \"--append-system-prompt <text>\",\n \"Append text to the agent's system prompt\",\n )\n .option(\n \"--disallowed-tools <tools...>\",\n \"Tools to disable in Claude CLI (e.g., CronCreate WebSearch)\",\n )\n .option(\n \"--tools <tools...>\",\n \"Built-in tools to make available in Claude CLI (e.g., Bash Edit Read)\",\n )\n .option(\n \"--settings <json>\",\n \"Settings JSON to pass to Claude CLI (e.g., hooks, permissions)\",\n )\n .option(\n \"--firewall-policies <json>\",\n 'Firewall policies JSON (e.g., \\'{\"github\": {\"actions:read\": \"allow\"}}\\')',\n )\n .option(\"--verbose\", \"Show full tool inputs and outputs\")\n .option(\"--check-env\", \"Validate secrets and vars before running\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .action(\n withErrorHandler(\n async (\n agentSessionId: string,\n prompt: string,\n options: {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n },\n command: { optsWithGlobals: () => Record<string, unknown> },\n ) => {\n // Commander.js quirk: when parent command has same option name,\n // the option value goes to parent. Use optsWithGlobals() to get all options.\n const allOpts = command.optsWithGlobals() as {\n envFile?: string;\n vars: Record<string, string>;\n secrets: Record<string, string>;\n modelProvider?: string;\n appendSystemPrompt?: string;\n disallowedTools?: string[];\n tools?: string[];\n settings?: string;\n firewallPolicies?: string;\n verbose?: boolean;\n checkEnv?: boolean;\n debugNoMockClaude?: boolean;\n };\n\n // Merge vars and secrets from command options\n const vars = { ...allOpts.vars, ...options.vars };\n const secrets = { ...allOpts.secrets, ...options.secrets };\n\n // 1. Validate session ID format\n if (!isUUID(agentSessionId)) {\n throw new Error(\n `Invalid agent session ID format: ${agentSessionId}`,\n { cause: new Error(\"Agent session ID must be a valid UUID\") },\n );\n }\n\n // 2. Fetch session info to get required secret names\n // This allows loading secrets from environment variables\n const sessionInfo = await getSession(agentSessionId);\n const requiredSecretNames = sessionInfo.secretNames || [];\n\n // 3. Load secrets from CLI options + --env-file + environment variables\n // Priority: CLI flags > --env-file > env vars\n const envFile = options.envFile || allOpts.envFile;\n const loadedSecrets = loadValues(secrets, requiredSecretNames, envFile);\n\n // 4. Call unified API with sessionId\n const response = await createRun({\n sessionId: agentSessionId,\n prompt,\n vars: Object.keys(vars).length > 0 ? vars : undefined,\n secrets: loadedSecrets,\n modelProvider: options.modelProvider || allOpts.modelProvider,\n appendSystemPrompt:\n options.appendSystemPrompt || allOpts.appendSystemPrompt,\n disallowedTools: options.disallowedTools || allOpts.disallowedTools,\n tools: options.tools || allOpts.tools,\n settings: options.settings || allOpts.settings,\n firewallPolicies: parseFirewallPolicies(\n options.firewallPolicies || allOpts.firewallPolicies,\n ),\n checkEnv: options.checkEnv || allOpts.checkEnv || undefined,\n debugNoMockClaude:\n options.debugNoMockClaude || allOpts.debugNoMockClaude || undefined,\n });\n\n // 4. Check for immediate failure (e.g., missing secrets)\n if (response.status === \"failed\") {\n throw new Error(\n \"Run preparation failed\",\n response.error ? { cause: new Error(response.error) } : undefined,\n );\n }\n\n // 5. Display run started/queued info\n renderRunCreated(response);\n\n // 6. Poll for events and exit with appropriate code\n const verbose = options.verbose || allOpts.verbose;\n const result = await pollEvents(response.runId, { verbose });\n if (!result.succeeded) {\n throw new Error(\"Run failed\");\n }\n showNextSteps(result);\n },\n ),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { listRuns } from \"../../lib/api\";\nimport { formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { parseTime } from \"../../lib/utils/time-parser\";\nimport { ALL_RUN_STATUSES, type RunStatus, type RunListItem } from \"@vm0/core\";\nimport { withErrorHandler } from \"../../lib/command\";\n\n/** Standard UUID string length (with hyphens) */\nconst UUID_LENGTH = 36;\n\n/** All valid status values as a string for help text */\nconst VALID_STATUSES = ALL_RUN_STATUSES.join(\",\");\n\n/**\n * Command options type\n */\ninterface ListOptions {\n status?: string;\n all?: boolean;\n agent?: string;\n since?: string;\n until?: string;\n limit?: string;\n}\n\n/**\n * Format run status with color and optional padding\n */\nfunction formatRunStatus(status: RunStatus, width?: number): string {\n const paddedStatus = width ? status.padEnd(width) : status;\n switch (status) {\n case \"queued\":\n return chalk.blue(paddedStatus);\n case \"running\":\n return chalk.green(paddedStatus);\n case \"pending\":\n return chalk.yellow(paddedStatus);\n case \"completed\":\n return chalk.dim(paddedStatus);\n case \"failed\":\n case \"timeout\":\n return chalk.red(paddedStatus);\n default:\n return paddedStatus;\n }\n}\n\n/**\n * Validate and parse status filter from options\n */\nfunction parseStatusFilter(options: ListOptions): string | undefined {\n if (options.all) {\n return VALID_STATUSES;\n }\n\n if (options.status) {\n const values = options.status.split(\",\").map((s) => s.trim());\n for (const v of values) {\n if (!ALL_RUN_STATUSES.includes(v as RunStatus)) {\n throw new Error(`Invalid status \"${v}\"`, {\n cause: new Error(`Valid values: ${VALID_STATUSES}`),\n });\n }\n }\n return values.join(\",\");\n }\n\n if (options.since) {\n // Implicit all when --since is used\n return VALID_STATUSES;\n }\n\n // undefined = backend default (pending,running)\n return undefined;\n}\n\n/**\n * Parse time option to ISO string\n */\nfunction parseTimeOption(value: string, optionName: string): string {\n try {\n return new Date(parseTime(value)).toISOString();\n } catch {\n throw new Error(\n `Invalid ${optionName} format. Use ISO (2026-01-01) or relative (1h, 7d, 30d)`,\n );\n }\n}\n\n/**\n * Parse and validate limit option\n */\nfunction parseLimit(value: string | undefined): number | undefined {\n if (!value) return undefined;\n\n const limit = parseInt(value, 10);\n if (isNaN(limit) || limit < 1 || limit > 100) {\n throw new Error(\"--limit must be between 1 and 100\");\n }\n return limit;\n}\n\n/**\n * Display runs in table format\n */\nfunction displayRuns(runs: RunListItem[]): void {\n // Calculate column widths\n const agentWidth = Math.max(5, ...runs.map((r) => r.agentName.length));\n const statusWidth = Math.max(6, ...runs.map((r) => r.status.length));\n\n // Print header\n const header = [\n \"ID\".padEnd(UUID_LENGTH),\n \"AGENT\".padEnd(agentWidth),\n \"STATUS\".padEnd(statusWidth),\n \"CREATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Print rows\n for (const run of runs) {\n const row = [\n run.id.padEnd(UUID_LENGTH),\n run.agentName.padEnd(agentWidth),\n formatRunStatus(run.status, statusWidth),\n formatRelativeTime(run.createdAt),\n ].join(\" \");\n console.log(row);\n }\n}\n\n/**\n * Display empty state message\n */\nfunction displayEmptyState(hasFilters: boolean): void {\n if (hasFilters) {\n console.log(chalk.dim(\"No runs found matching filters\"));\n } else {\n console.log(chalk.dim(\"No active runs\"));\n console.log(chalk.dim(' Run: vm0 run <agent> \"<prompt>\"'));\n }\n}\n\nexport const listCommand = new Command()\n .name(\"list\")\n .alias(\"ls\")\n .description(\"List runs\")\n .option(\n \"--status <status,...>\",\n `Filter by status: ${VALID_STATUSES} (default: pending,running)`,\n )\n .option(\"--all\", \"Show all statuses (mutually exclusive with --status)\")\n .option(\"--agent <name>\", \"Filter by agent name\")\n .option(\"--since <date>\", \"Start time (ISO format or relative: 1h, 7d, 30d)\")\n .option(\"--until <date>\", \"End time (defaults to now)\")\n .option(\"--limit <n>\", \"Maximum number of results (default: 50, max: 100)\")\n .action(\n withErrorHandler(async (options: ListOptions) => {\n // Validate mutual exclusion\n if (options.all && options.status) {\n throw new Error(\"--all and --status are mutually exclusive\");\n }\n\n // Parse options\n const statusFilter = parseStatusFilter(options);\n const since = options.since\n ? parseTimeOption(options.since, \"--since\")\n : undefined;\n const until = options.until\n ? parseTimeOption(options.until, \"--until\")\n : undefined;\n const limit = parseLimit(options.limit);\n\n // Validate since < until\n if (since && until && new Date(since) >= new Date(until)) {\n throw new Error(\"--since must be before --until\");\n }\n\n // Fetch runs with filters\n const response = await listRuns({\n status: statusFilter,\n agent: options.agent,\n since,\n until,\n limit,\n });\n\n const runs = response.runs;\n\n if (runs.length === 0) {\n const hasFilters = !!(\n options.status ||\n options.all ||\n options.agent ||\n options.since\n );\n displayEmptyState(hasFilters);\n return;\n }\n\n displayRuns(runs);\n }),\n );\n","/**\n * Time parser utility for --since option\n *\n * Supports:\n * - Relative time: 5s, 10m, 2h, 1d, 1w (seconds, minutes, hours, days, weeks)\n * - Absolute time: ISO 8601 format (2024-01-15T10:30:00Z)\n * - Unix timestamp: 1705312200 or 1705312200000 (seconds or milliseconds)\n */\n\n/**\n * Parse a time string and return a Unix timestamp in milliseconds\n * @param timeStr - Time string to parse\n * @returns Unix timestamp in milliseconds\n * @throws Error if the time string is invalid\n */\nexport function parseTime(timeStr: string): number {\n // Try relative time first (e.g., \"5m\", \"2h\", \"1d\")\n const relativeMatch = timeStr.match(/^(\\d+)([smhdw])$/);\n if (relativeMatch) {\n const value = parseInt(relativeMatch[1]!, 10);\n const unit = relativeMatch[2]!;\n return parseRelativeTime(value, unit);\n }\n\n // Try Unix timestamp (seconds or milliseconds)\n if (/^\\d+$/.test(timeStr)) {\n const timestamp = parseInt(timeStr, 10);\n // If timestamp is less than year 2000 in seconds, assume it's already in ms\n // If it looks like seconds (< 10000000000), convert to ms\n if (timestamp < 10000000000) {\n return timestamp * 1000;\n }\n return timestamp;\n }\n\n // Try ISO 8601 format\n const date = new Date(timeStr);\n if (!isNaN(date.getTime())) {\n return date.getTime();\n }\n\n throw new Error(\n `Invalid time format: \"${timeStr}\". ` +\n `Supported formats: relative (5m, 2h, 1d), ISO 8601 (2024-01-15T10:30:00Z), Unix timestamp`,\n );\n}\n\n/**\n * Parse relative time and return Unix timestamp in milliseconds\n */\nfunction parseRelativeTime(value: number, unit: string): number {\n const now = Date.now();\n const multipliers: Record<string, number> = {\n s: 1000, // seconds\n m: 60 * 1000, // minutes\n h: 60 * 60 * 1000, // hours\n d: 24 * 60 * 60 * 1000, // days\n w: 7 * 24 * 60 * 60 * 1000, // weeks\n };\n\n const multiplier = multipliers[unit];\n if (!multiplier) {\n throw new Error(`Unknown time unit: ${unit}`);\n }\n\n return now - value * multiplier;\n}\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cancelRun } from \"../../lib/api\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const killCommand = new Command()\n .name(\"kill\")\n .description(\"Kill (cancel) a pending or running run\")\n .argument(\"<run-id>\", \"Run ID to kill\")\n .action(\n withErrorHandler(async (runId: string) => {\n await cancelRun(runId);\n console.log(chalk.green(`✓ Run ${runId} cancelled`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { getRunQueue } from \"../../lib/api\";\nimport { formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const queueCommand = new Command()\n .name(\"queue\")\n .description(\"Show org run queue status\")\n .action(\n withErrorHandler(async () => {\n const data = await getRunQueue();\n const { concurrency, queue } = data;\n\n // Concurrency header\n const limitDisplay =\n concurrency.limit === 0\n ? \"unlimited\"\n : `${concurrency.active}/${concurrency.limit} slots used`;\n console.log(`Concurrency: ${limitDisplay} (${concurrency.tier} tier)`);\n\n // Queue status\n if (queue.length === 0) {\n console.log(chalk.dim(\"Queue: empty — all slots available\"));\n return;\n }\n\n console.log(\n `Queue: ${queue.length} run${queue.length > 1 ? \"s\" : \"\"} waiting`,\n );\n console.log();\n\n // Dynamic column widths\n const posWidth = Math.max(1, String(queue.length).length);\n const agentWidth = Math.max(\n 5,\n ...queue.map((e) => (e.agentName ?? \"-\").length),\n );\n const emailWidth = Math.max(\n 4,\n ...queue.map((e) => (e.userEmail ?? \"-\").length),\n );\n\n // Header\n const header = [\n \"#\".padEnd(posWidth),\n \"AGENT\".padEnd(agentWidth),\n \"USER\".padEnd(emailWidth),\n \"CREATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Rows\n for (const entry of queue) {\n const marker = entry.runId !== null ? chalk.cyan(\" ← you\") : \"\";\n const row = [\n String(entry.position).padEnd(posWidth),\n (entry.agentName ?? \"-\").padEnd(agentWidth),\n (entry.userEmail ?? \"-\").padEnd(emailWidth),\n formatRelativeTime(entry.createdAt),\n ].join(\" \");\n console.log(row + marker);\n }\n }),\n );\n","import { mainRunCommand } from \"./run\";\nimport { resumeCommand } from \"./resume\";\nimport { continueCommand } from \"./continue\";\nimport { listCommand } from \"./list\";\nimport { killCommand } from \"./kill\";\nimport { queueCommand } from \"./queue\";\n\n// Add subcommands to the main run command\nmainRunCommand.addCommand(resumeCommand);\nmainRunCommand.addCommand(continueCommand);\nmainRunCommand.addCommand(listCommand);\nmainRunCommand.addCommand(killCommand);\nmainRunCommand.addCommand(queueCommand);\n\nexport const runCommand = mainRunCommand;\n","import { Command } from \"commander\";\nimport { initCommand } from \"./init\";\nimport { pushCommand } from \"./push\";\nimport { pullCommand } from \"./pull\";\nimport { statusCommand } from \"./status\";\nimport { listCommand } from \"./list\";\nimport { cloneCommand } from \"./clone\";\n\nexport const volumeCommand = new Command()\n .name(\"volume\")\n .description(\"Manage volumes (defined in compose, not versioned after run)\")\n .addCommand(initCommand)\n .addCommand(pushCommand)\n .addCommand(pullCommand)\n .addCommand(statusCommand)\n .addCommand(listCommand)\n .addCommand(cloneCommand);\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport {\n isValidStorageName,\n writeStorageConfig,\n readStorageConfig,\n} from \"../../lib/storage/storage-utils\";\nimport { promptText, isInteractive } from \"../../lib/utils/prompt-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const initCommand = new Command()\n .name(\"init\")\n .description(\"Initialize a volume in the current directory\")\n .option(\"-n, --name <name>\", \"Volume name (required in non-interactive mode)\")\n .action(\n withErrorHandler(async (options: { name?: string }) => {\n const cwd = process.cwd();\n const dirName = path.basename(cwd);\n\n // Check if storage config already exists\n const existingConfig = await readStorageConfig(cwd);\n if (existingConfig) {\n console.log(\n chalk.yellow(`Volume already initialized: ${existingConfig.name}`),\n );\n console.log(\n chalk.dim(`Config file: ${path.join(cwd, \".vm0\", \"storage.yaml\")}`),\n );\n return;\n }\n\n // Determine volume name\n let volumeName: string;\n\n if (options.name) {\n // Use provided name (non-interactive mode)\n volumeName = options.name;\n } else if (!isInteractive()) {\n throw new Error(\"--name flag is required in non-interactive mode\", {\n cause: new Error(\"Usage: vm0 volume init --name <volume-name>\"),\n });\n } else {\n // Interactive prompt with directory name as default\n const defaultName = isValidStorageName(dirName) ? dirName : undefined;\n const name = await promptText(\n \"Enter volume name\",\n defaultName,\n (value: string) => {\n if (!isValidStorageName(value)) {\n return \"Must be 3-64 characters, lowercase alphanumeric with hyphens\";\n }\n return true;\n },\n );\n\n if (name === undefined) {\n // User cancelled\n console.log(chalk.dim(\"Cancelled\"));\n return;\n }\n\n volumeName = name;\n }\n\n // Validate volume name\n if (!isValidStorageName(volumeName)) {\n throw new Error(`Invalid volume name: \"${volumeName}\"`, {\n cause: new Error(\n \"Volume names must be 3-64 characters, lowercase alphanumeric with hyphens\",\n ),\n });\n }\n\n // Write config file\n await writeStorageConfig(volumeName, cwd);\n\n console.log(chalk.green(`✓ Initialized volume: ${volumeName}`));\n console.log(\n chalk.dim(\n ` Config saved to ${path.join(cwd, \".vm0\", \"storage.yaml\")}`,\n ),\n );\n }),\n );\n","import { readFile, writeFile, mkdir } from \"fs/promises\";\nimport { existsSync } from \"fs\";\nimport { parse as parseYaml, stringify as stringifyYaml } from \"yaml\";\nimport path from \"path\";\n\n/**\n * Storage type\n * - \"volume\": Static storage that doesn't auto-version after runs\n * - \"artifact\": Work products that auto-version after runs\n */\nexport type StorageType = \"volume\" | \"artifact\" | \"memory\";\n\ninterface StorageConfig {\n name: string;\n type: StorageType;\n}\n\nconst CONFIG_DIR = \".vm0\";\nconst CONFIG_FILE = \"storage.yaml\";\n\n/**\n * Validate storage name format\n * Length: 3-64 characters\n * Characters: lowercase letters, numbers, hyphens\n * Must start and end with alphanumeric\n * No consecutive hyphens\n */\nexport function isValidStorageName(name: string): boolean {\n if (name.length < 3 || name.length > 64) {\n return false;\n }\n const pattern = /^[a-z0-9][a-z0-9-]{1,62}[a-z0-9]$/;\n return pattern.test(name) && !name.includes(\"--\");\n}\n\n/**\n * Read storage config from .vm0/storage.yaml\n * Also supports legacy .vm0/volume.yaml for backward compatibility\n */\nexport async function readStorageConfig(\n basePath: string = process.cwd(),\n): Promise<StorageConfig | null> {\n const configPath = path.join(basePath, CONFIG_DIR, CONFIG_FILE);\n const legacyConfigPath = path.join(basePath, CONFIG_DIR, \"volume.yaml\");\n\n // Check for new config file first, then legacy\n let actualPath: string | null = null;\n if (existsSync(configPath)) {\n actualPath = configPath;\n } else if (existsSync(legacyConfigPath)) {\n actualPath = legacyConfigPath;\n }\n\n if (!actualPath) {\n return null;\n }\n\n const content = await readFile(actualPath, \"utf8\");\n const config = parseYaml(content) as StorageConfig;\n\n // Default to \"volume\" type for backward compatibility\n if (!config.type) {\n config.type = \"volume\";\n }\n\n return config;\n}\n\n/**\n * Write storage config to .vm0/storage.yaml\n */\nexport async function writeStorageConfig(\n storageName: string,\n basePath: string = process.cwd(),\n type: StorageType = \"volume\",\n): Promise<void> {\n const configDir = path.join(basePath, CONFIG_DIR);\n const configPath = path.join(configDir, CONFIG_FILE);\n\n // Create .vm0 directory if it doesn't exist\n if (!existsSync(configDir)) {\n await mkdir(configDir, { recursive: true });\n }\n\n const config: StorageConfig = {\n name: storageName,\n type,\n };\n\n const yamlContent = stringifyYaml(config);\n await writeFile(configPath, yamlContent, \"utf8\");\n}\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { directUpload } from \"../../lib/storage/direct-upload\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pushCommand = new Command()\n .name(\"push\")\n .description(\"Push local files to cloud volume\")\n .option(\n \"-f, --force\",\n \"Force upload even if content unchanged (recreate archive)\",\n )\n .action(\n withErrorHandler(async (options: { force?: boolean }) => {\n const cwd = process.cwd();\n\n // Read storage config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No volume initialized in this directory\", {\n cause: new Error(\"Run: vm0 volume init\"),\n });\n }\n\n console.log(`Pushing volume: ${config.name}`);\n\n // Perform direct S3 upload\n const result = await directUpload(config.name, \"volume\", cwd, {\n onProgress: (message) => {\n console.log(chalk.dim(message));\n },\n force: options.force,\n });\n\n // Display short version (8 characters) by default\n const shortVersion = result.versionId.slice(0, 8);\n\n if (result.empty) {\n console.log(chalk.dim(\"No files found (empty volume)\"));\n } else if (result.deduplicated) {\n console.log(chalk.green(\"✓ Content unchanged (deduplicated)\"));\n } else {\n console.log(chalk.green(\"✓ Upload complete\"));\n }\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${result.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(result.size)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport * as fs from \"fs\";\nimport * as os from \"os\";\nimport * as tar from \"tar\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload } from \"../../lib/api\";\nimport {\n formatBytes,\n listTarFiles,\n removeExtraFiles,\n} from \"../../lib/utils/file-utils\";\nimport { handleEmptyStorageResponse } from \"../../lib/storage/pull-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pullCommand = new Command()\n .name(\"pull\")\n .description(\"Pull cloud files to local directory\")\n .argument(\"[versionId]\", \"Version ID to pull (default: latest)\")\n .action(\n withErrorHandler(async (versionId?: string) => {\n const cwd = process.cwd();\n\n // Read storage config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No volume initialized in this directory\", {\n cause: new Error(\"Run: vm0 volume init\"),\n });\n }\n\n if (versionId) {\n console.log(`Pulling volume: ${config.name} (version: ${versionId})`);\n } else {\n console.log(`Pulling volume: ${config.name}`);\n }\n\n // Get download URL from API\n console.log(chalk.dim(\"Getting download URL...\"));\n\n const downloadInfo = await getStorageDownload({\n name: config.name,\n type: \"volume\",\n version: versionId,\n });\n\n // Handle empty volume\n if (\"empty\" in downloadInfo) {\n await handleEmptyStorageResponse(cwd);\n return;\n }\n\n const downloadUrl = downloadInfo.url;\n if (!downloadUrl) {\n throw new Error(\"No download URL returned\");\n }\n\n // Download directly from S3\n console.log(chalk.dim(\"Downloading from S3...\"));\n const s3Response = await fetch(downloadUrl);\n\n if (!s3Response.ok) {\n throw new Error(`S3 download failed: ${s3Response.status}`);\n }\n\n // Get tar.gz buffer\n const arrayBuffer = await s3Response.arrayBuffer();\n const tarBuffer = Buffer.from(arrayBuffer);\n\n console.log(chalk.green(`✓ Downloaded ${formatBytes(tarBuffer.length)}`));\n\n // Save tar.gz to temp file for processing\n const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), \"vm0-\"));\n const tarPath = path.join(tmpDir, \"volume.tar.gz\");\n await fs.promises.writeFile(tarPath, tarBuffer);\n\n // Get remote files list for sync\n console.log(chalk.dim(\"Syncing local files...\"));\n const remoteFiles = await listTarFiles(tarPath);\n const remoteFilesSet = new Set(\n remoteFiles.map((f) => f.replace(/\\\\/g, \"/\")),\n );\n\n // Remove local files not in remote\n const removedCount = await removeExtraFiles(cwd, remoteFilesSet);\n if (removedCount > 0) {\n console.log(\n chalk.green(`✓ Removed ${removedCount} files not in remote`),\n );\n }\n\n // Extract tar.gz\n console.log(chalk.dim(\"Extracting files...\"));\n await tar.extract({\n file: tarPath,\n cwd: cwd,\n gzip: true,\n });\n\n // Clean up temp files\n await fs.promises.unlink(tarPath);\n await fs.promises.rmdir(tmpDir);\n\n console.log(chalk.green(`✓ Extracted ${remoteFiles.length} files`));\n }),\n );\n","import chalk from \"chalk\";\nimport { removeExtraFiles } from \"../utils/file-utils\";\n\n/**\n * Result of handling an empty storage response (HTTP 204).\n */\ninterface EmptyStorageResult {\n removedCount: number;\n}\n\n/**\n * Handle empty storage response (HTTP 204 No Content).\n * Syncs local directory to empty state by removing all tracked files.\n *\n * @param cwd - Current working directory\n * @returns Result with count of removed files\n */\nexport async function handleEmptyStorageResponse(\n cwd: string,\n): Promise<EmptyStorageResult> {\n console.log(chalk.dim(\"Syncing local files...\"));\n\n // Sync to empty state - remove all local files\n const removedCount = await removeExtraFiles(cwd, new Set());\n\n if (removedCount > 0) {\n console.log(chalk.green(`✓ Removed ${removedCount} files not in remote`));\n }\n\n console.log(chalk.green(\"✓ Synced (0 files)\"));\n\n return { removedCount };\n}\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload, ApiRequestError } from \"../../lib/api\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const statusCommand = new Command()\n .name(\"status\")\n .description(\"Show status of cloud volume\")\n .action(\n withErrorHandler(async () => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No volume initialized in this directory\", {\n cause: new Error(\"Run: vm0 volume init\"),\n });\n }\n\n if (config.type !== \"volume\") {\n throw new Error(\n \"This directory is initialized as an artifact, not a volume\",\n { cause: new Error(\"Use: vm0 artifact status\") },\n );\n }\n\n // Start message\n console.log(`Checking volume: ${config.name}`);\n\n // Call API\n try {\n const info = await getStorageDownload({\n name: config.name,\n type: \"volume\",\n });\n const shortVersion = info.versionId.slice(0, 8);\n\n if (\"empty\" in info) {\n console.log(chalk.green(\"✓ Found (empty)\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n } else {\n console.log(chalk.green(\"✓ Found\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${info.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(info.size)}`));\n }\n } catch (error) {\n if (error instanceof ApiRequestError && error.status === 404) {\n throw new Error(\"Not found on remote\", {\n cause: new Error(\"Run: vm0 volume push\"),\n });\n }\n throw error;\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { listStorages } from \"../../lib/api\";\nimport { formatBytes, formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const listCommand = new Command()\n .name(\"list\")\n .alias(\"ls\")\n .description(\"List all remote volumes\")\n .action(\n withErrorHandler(async () => {\n // Call API\n const items = await listStorages({ type: \"volume\" });\n\n if (items.length === 0) {\n console.log(chalk.dim(\"No volumes found\"));\n console.log(\n chalk.dim(\" Create one with: vm0 volume init && vm0 volume push\"),\n );\n return;\n }\n\n // Calculate column widths\n const nameWidth = Math.max(4, ...items.map((i) => i.name.length));\n const sizeWidth = Math.max(\n 4,\n ...items.map((i) => formatBytes(i.size).length),\n );\n const filesWidth = Math.max(\n 5,\n ...items.map((i) => i.fileCount.toString().length),\n );\n\n // Print header\n const header = [\n \"NAME\".padEnd(nameWidth),\n \"SIZE\".padStart(sizeWidth),\n \"FILES\".padStart(filesWidth),\n \"UPDATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Print rows\n for (const item of items) {\n const row = [\n item.name.padEnd(nameWidth),\n formatBytes(item.size).padStart(sizeWidth),\n item.fileCount.toString().padStart(filesWidth),\n formatRelativeTime(item.updatedAt),\n ].join(\" \");\n console.log(row);\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cloneStorage } from \"../../lib/storage/clone-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const cloneCommand = new Command()\n .name(\"clone\")\n .description(\"Clone a remote volume to local directory (latest version)\")\n .argument(\"<name>\", \"Volume name to clone\")\n .argument(\"[destination]\", \"Destination directory (default: volume name)\")\n .action(\n withErrorHandler(async (name: string, destination: string | undefined) => {\n // Use volume name as destination if not specified\n const targetDir = destination || name;\n\n console.log(`Cloning volume: ${name}`);\n\n const result = await cloneStorage(name, \"volume\", targetDir);\n\n console.log(chalk.green(`\\n✓ Successfully cloned volume: ${name}`));\n console.log(chalk.dim(` Location: ${targetDir}/`));\n console.log(chalk.dim(` Version: ${result.versionId.slice(0, 8)}`));\n }),\n );\n","import chalk from \"chalk\";\nimport path from \"path\";\nimport * as fs from \"fs\";\nimport * as os from \"os\";\nimport * as tar from \"tar\";\nimport { writeStorageConfig, type StorageType } from \"./storage-utils\";\nimport { getStorageDownload } from \"../api\";\nimport {\n listTarFiles,\n formatBytes,\n checkDirectoryStatus,\n} from \"../utils/file-utils\";\n\ninterface CloneOptions {\n version?: string;\n}\n\ninterface CloneResult {\n success: boolean;\n fileCount: number;\n size: number;\n versionId: string;\n}\n\n/**\n * Clone a remote storage to a local directory\n * Creates the directory, downloads contents, and initializes .vm0 config\n */\nexport async function cloneStorage(\n name: string,\n type: StorageType,\n destination: string,\n options: CloneOptions = {},\n): Promise<CloneResult> {\n const typeLabel = type;\n\n // Check if destination already exists and is non-empty\n const dirStatus = checkDirectoryStatus(destination);\n if (dirStatus.exists && !dirStatus.empty) {\n throw new Error(`Directory \"${destination}\" is not empty`);\n }\n\n // Check if storage exists on remote\n console.log(chalk.dim(`Checking remote ${typeLabel}...`));\n\n const downloadInfo = await getStorageDownload({\n name,\n type,\n version: options.version,\n });\n\n // Create destination directory\n console.log(chalk.dim(`Creating directory: ${destination}/`));\n await fs.promises.mkdir(destination, { recursive: true });\n\n // Handle empty storage (type guard)\n if (\"empty\" in downloadInfo) {\n // Create .vm0 directory and config\n await writeStorageConfig(name, destination, type);\n\n console.log(chalk.green(`✓ Cloned empty ${typeLabel}: ${name}`));\n console.log(chalk.dim(`✓ Initialized .vm0/storage.yaml`));\n\n return {\n success: true,\n fileCount: 0,\n size: 0,\n versionId: downloadInfo.versionId,\n };\n }\n\n // TypeScript now knows downloadInfo has url property\n const downloadUrl = downloadInfo.url;\n if (!downloadUrl) {\n throw new Error(\"No download URL returned\");\n }\n\n // Download from S3\n console.log(chalk.dim(\"Downloading from S3...\"));\n const s3Response = await fetch(downloadUrl);\n\n if (!s3Response.ok) {\n // Clean up directory on failure\n await fs.promises.rm(destination, { recursive: true, force: true });\n throw new Error(`S3 download failed: ${s3Response.status}`);\n }\n\n // Get tar.gz buffer\n const arrayBuffer = await s3Response.arrayBuffer();\n const tarBuffer = Buffer.from(arrayBuffer);\n\n console.log(chalk.green(`✓ Downloaded ${formatBytes(tarBuffer.length)}`));\n\n // Save tar.gz to temp file for processing\n const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), \"vm0-clone-\"));\n const tarPath = path.join(tmpDir, \"archive.tar.gz\");\n await fs.promises.writeFile(tarPath, tarBuffer);\n\n // Get file list from tar\n const files = await listTarFiles(tarPath);\n\n // Extract tar.gz to destination\n console.log(chalk.dim(\"Extracting files...\"));\n await tar.extract({\n file: tarPath,\n cwd: destination,\n gzip: true,\n });\n\n // Clean up temp files\n await fs.promises.unlink(tarPath);\n await fs.promises.rmdir(tmpDir);\n\n console.log(chalk.green(`✓ Extracted ${files.length} files`));\n\n // Create .vm0 directory and config\n await writeStorageConfig(name, destination, type);\n console.log(chalk.green(`✓ Initialized .vm0/storage.yaml`));\n\n return {\n success: true,\n fileCount: downloadInfo.fileCount,\n size: downloadInfo.size,\n versionId: downloadInfo.versionId,\n };\n}\n","import { Command } from \"commander\";\nimport { initCommand } from \"./init\";\nimport { pushCommand } from \"./push\";\nimport { pullCommand } from \"./pull\";\nimport { statusCommand } from \"./status\";\nimport { listCommand } from \"./list\";\nimport { cloneCommand } from \"./clone\";\n\nexport const artifactCommand = new Command()\n .name(\"artifact\")\n .description(\"Manage artifacts (specified at run, versioned after run)\")\n .addCommand(initCommand)\n .addCommand(pushCommand)\n .addCommand(pullCommand)\n .addCommand(statusCommand)\n .addCommand(listCommand)\n .addCommand(cloneCommand);\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport {\n isValidStorageName,\n writeStorageConfig,\n readStorageConfig,\n} from \"../../lib/storage/storage-utils\";\nimport { promptText, isInteractive } from \"../../lib/utils/prompt-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const initCommand = new Command()\n .name(\"init\")\n .description(\"Initialize an artifact in the current directory\")\n .option(\n \"-n, --name <name>\",\n \"Artifact name (required in non-interactive mode)\",\n )\n .action(\n withErrorHandler(async (options: { name?: string }) => {\n const cwd = process.cwd();\n const dirName = path.basename(cwd);\n\n // Check if config already exists\n const existingConfig = await readStorageConfig(cwd);\n if (existingConfig) {\n if (existingConfig.type === \"artifact\") {\n console.log(\n chalk.yellow(\n `Artifact already initialized: ${existingConfig.name}`,\n ),\n );\n } else {\n console.log(\n chalk.yellow(\n `Directory already initialized as volume: ${existingConfig.name}`,\n ),\n );\n console.log(\n chalk.dim(\n \" To change type, delete .vm0/storage.yaml and reinitialize\",\n ),\n );\n }\n console.log(\n chalk.dim(`Config file: ${path.join(cwd, \".vm0\", \"storage.yaml\")}`),\n );\n return;\n }\n\n // Determine artifact name\n let artifactName: string;\n\n if (options.name) {\n // Use provided name (non-interactive mode)\n artifactName = options.name;\n } else if (!isInteractive()) {\n throw new Error(\"--name flag is required in non-interactive mode\", {\n cause: new Error(\"Usage: vm0 artifact init --name <artifact-name>\"),\n });\n } else {\n // Interactive prompt with directory name as default\n const defaultName = isValidStorageName(dirName) ? dirName : undefined;\n const name = await promptText(\n \"Enter artifact name\",\n defaultName,\n (value: string) => {\n if (!isValidStorageName(value)) {\n return \"Must be 3-64 characters, lowercase alphanumeric with hyphens\";\n }\n return true;\n },\n );\n\n if (name === undefined) {\n // User cancelled\n console.log(chalk.dim(\"Cancelled\"));\n return;\n }\n\n artifactName = name;\n }\n\n // Validate name\n if (!isValidStorageName(artifactName)) {\n throw new Error(`Invalid artifact name: \"${artifactName}\"`, {\n cause: new Error(\n \"Artifact names must be 3-64 characters, lowercase alphanumeric with hyphens\",\n ),\n });\n }\n\n // Write config file with type: artifact\n await writeStorageConfig(artifactName, cwd, \"artifact\");\n\n console.log(chalk.green(`✓ Initialized artifact: ${artifactName}`));\n console.log(\n chalk.dim(\n ` Config saved to ${path.join(cwd, \".vm0\", \"storage.yaml\")}`,\n ),\n );\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { directUpload } from \"../../lib/storage/direct-upload\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pushCommand = new Command()\n .name(\"push\")\n .description(\"Push local files to cloud artifact\")\n .option(\n \"-f, --force\",\n \"Force upload even if content unchanged (recreate archive)\",\n )\n .action(\n withErrorHandler(async (options: { force?: boolean }) => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No artifact initialized in this directory\", {\n cause: new Error(\"Run: vm0 artifact init\"),\n });\n }\n\n if (config.type !== \"artifact\") {\n throw new Error(\n \"This directory is initialized as a volume, not an artifact\",\n { cause: new Error(\"Use: vm0 volume push\") },\n );\n }\n\n console.log(`Pushing artifact: ${config.name}`);\n\n // Perform direct S3 upload\n const result = await directUpload(config.name, \"artifact\", cwd, {\n onProgress: (message) => {\n console.log(chalk.dim(message));\n },\n force: options.force,\n });\n\n // Display short version (8 characters) by default\n const shortVersion = result.versionId.slice(0, 8);\n\n if (result.empty) {\n console.log(chalk.dim(\"No files found (empty artifact)\"));\n } else if (result.deduplicated) {\n console.log(chalk.green(\"✓ Content unchanged (deduplicated)\"));\n } else {\n console.log(chalk.green(\"✓ Upload complete\"));\n }\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${result.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(result.size)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport * as fs from \"fs\";\nimport * as os from \"os\";\nimport * as tar from \"tar\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload } from \"../../lib/api\";\nimport {\n formatBytes,\n listTarFiles,\n removeExtraFiles,\n} from \"../../lib/utils/file-utils\";\nimport { handleEmptyStorageResponse } from \"../../lib/storage/pull-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pullCommand = new Command()\n .name(\"pull\")\n .description(\"Pull cloud artifact to local directory\")\n .argument(\"[versionId]\", \"Version ID to pull (default: latest)\")\n .action(\n withErrorHandler(async (versionId?: string) => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No artifact initialized in this directory\", {\n cause: new Error(\"Run: vm0 artifact init\"),\n });\n }\n\n if (config.type !== \"artifact\") {\n throw new Error(\n \"This directory is initialized as a volume, not an artifact\",\n { cause: new Error(\"Use: vm0 volume pull\") },\n );\n }\n\n if (versionId) {\n console.log(`Pulling artifact: ${config.name} (version: ${versionId})`);\n } else {\n console.log(`Pulling artifact: ${config.name}`);\n }\n\n // Get download URL from API\n console.log(chalk.dim(\"Getting download URL...\"));\n\n const downloadInfo = await getStorageDownload({\n name: config.name,\n type: \"artifact\",\n version: versionId,\n });\n\n // Handle empty artifact\n if (\"empty\" in downloadInfo) {\n await handleEmptyStorageResponse(cwd);\n return;\n }\n\n const downloadUrl = downloadInfo.url;\n if (!downloadUrl) {\n throw new Error(\"No download URL returned\");\n }\n\n // Download directly from S3\n console.log(chalk.dim(\"Downloading from S3...\"));\n const s3Response = await fetch(downloadUrl);\n\n if (!s3Response.ok) {\n throw new Error(`S3 download failed: ${s3Response.status}`);\n }\n\n // Get tar.gz buffer\n const arrayBuffer = await s3Response.arrayBuffer();\n const tarBuffer = Buffer.from(arrayBuffer);\n\n console.log(chalk.green(`✓ Downloaded ${formatBytes(tarBuffer.length)}`));\n\n // Save tar.gz to temp file for processing\n const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), \"vm0-\"));\n const tarPath = path.join(tmpDir, \"artifact.tar.gz\");\n await fs.promises.writeFile(tarPath, tarBuffer);\n\n // Get remote files list for sync\n console.log(chalk.dim(\"Syncing local files...\"));\n const remoteFiles = await listTarFiles(tarPath);\n const remoteFilesSet = new Set(\n remoteFiles.map((f) => f.replace(/\\\\/g, \"/\")),\n );\n\n // Remove local files not in remote\n const removedCount = await removeExtraFiles(cwd, remoteFilesSet);\n if (removedCount > 0) {\n console.log(\n chalk.green(`✓ Removed ${removedCount} files not in remote`),\n );\n }\n\n // Extract tar.gz\n console.log(chalk.dim(\"Extracting files...\"));\n await tar.extract({\n file: tarPath,\n cwd: cwd,\n gzip: true,\n });\n\n // Clean up temp files\n await fs.promises.unlink(tarPath);\n await fs.promises.rmdir(tmpDir);\n\n console.log(chalk.green(`✓ Extracted ${remoteFiles.length} files`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload, ApiRequestError } from \"../../lib/api\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const statusCommand = new Command()\n .name(\"status\")\n .description(\"Show status of cloud artifact\")\n .action(\n withErrorHandler(async () => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No artifact initialized in this directory\", {\n cause: new Error(\"Run: vm0 artifact init\"),\n });\n }\n\n if (config.type !== \"artifact\") {\n throw new Error(\n \"This directory is initialized as a volume, not an artifact\",\n { cause: new Error(\"Use: vm0 volume status\") },\n );\n }\n\n // Start message\n console.log(`Checking artifact: ${config.name}`);\n\n // Call API\n try {\n const info = await getStorageDownload({\n name: config.name,\n type: \"artifact\",\n });\n const shortVersion = info.versionId.slice(0, 8);\n\n if (\"empty\" in info) {\n console.log(chalk.green(\"✓ Found (empty)\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n } else {\n console.log(chalk.green(\"✓ Found\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${info.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(info.size)}`));\n }\n } catch (error) {\n if (error instanceof ApiRequestError && error.status === 404) {\n throw new Error(\"Not found on remote\", {\n cause: new Error(\"Run: vm0 artifact push\"),\n });\n }\n throw error;\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { listStorages } from \"../../lib/api\";\nimport { formatBytes, formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const listCommand = new Command()\n .name(\"list\")\n .alias(\"ls\")\n .description(\"List all remote artifacts\")\n .action(\n withErrorHandler(async () => {\n // Call API\n const items = await listStorages({ type: \"artifact\" });\n\n if (items.length === 0) {\n console.log(chalk.dim(\"No artifacts found\"));\n console.log(\n chalk.dim(\n \" Create one with: vm0 artifact init && vm0 artifact push\",\n ),\n );\n return;\n }\n\n // Calculate column widths\n const nameWidth = Math.max(4, ...items.map((i) => i.name.length));\n const sizeWidth = Math.max(\n 4,\n ...items.map((i) => formatBytes(i.size).length),\n );\n const filesWidth = Math.max(\n 5,\n ...items.map((i) => i.fileCount.toString().length),\n );\n\n // Print header\n const header = [\n \"NAME\".padEnd(nameWidth),\n \"SIZE\".padStart(sizeWidth),\n \"FILES\".padStart(filesWidth),\n \"UPDATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Print rows\n for (const item of items) {\n const row = [\n item.name.padEnd(nameWidth),\n formatBytes(item.size).padStart(sizeWidth),\n item.fileCount.toString().padStart(filesWidth),\n formatRelativeTime(item.updatedAt),\n ].join(\" \");\n console.log(row);\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cloneStorage } from \"../../lib/storage/clone-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const cloneCommand = new Command()\n .name(\"clone\")\n .description(\"Clone a remote artifact to local directory (latest version)\")\n .argument(\"<name>\", \"Artifact name to clone\")\n .argument(\"[destination]\", \"Destination directory (default: artifact name)\")\n .action(\n withErrorHandler(async (name: string, destination: string | undefined) => {\n // Use artifact name as destination if not specified\n const targetDir = destination || name;\n\n console.log(`Cloning artifact: ${name}`);\n\n const result = await cloneStorage(name, \"artifact\", targetDir);\n\n console.log(chalk.green(`\\n✓ Successfully cloned artifact: ${name}`));\n console.log(chalk.dim(` Location: ${targetDir}/`));\n console.log(chalk.dim(` Version: ${result.versionId.slice(0, 8)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport { initCommand } from \"./init\";\nimport { pushCommand } from \"./push\";\nimport { pullCommand } from \"./pull\";\nimport { statusCommand } from \"./status\";\nimport { listCommand } from \"./list\";\nimport { cloneCommand } from \"./clone\";\n\nexport const memoryCommand = new Command()\n .name(\"memory\")\n .description(\"Manage agent long-term memory\")\n .addCommand(initCommand)\n .addCommand(pushCommand)\n .addCommand(pullCommand)\n .addCommand(statusCommand)\n .addCommand(listCommand)\n .addCommand(cloneCommand);\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport {\n isValidStorageName,\n writeStorageConfig,\n readStorageConfig,\n} from \"../../lib/storage/storage-utils\";\nimport { promptText, isInteractive } from \"../../lib/utils/prompt-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const initCommand = new Command()\n .name(\"init\")\n .description(\"Initialize a memory in the current directory\")\n .option(\"-n, --name <name>\", \"Memory name (required in non-interactive mode)\")\n .action(\n withErrorHandler(async (options: { name?: string }) => {\n const cwd = process.cwd();\n const dirName = path.basename(cwd);\n\n // Check if config already exists\n const existingConfig = await readStorageConfig(cwd);\n if (existingConfig) {\n if (existingConfig.type === \"memory\") {\n console.log(\n chalk.yellow(`Memory already initialized: ${existingConfig.name}`),\n );\n } else {\n console.log(\n chalk.yellow(\n `Directory already initialized as ${existingConfig.type}: ${existingConfig.name}`,\n ),\n );\n console.log(\n chalk.dim(\n \" To change type, delete .vm0/storage.yaml and reinitialize\",\n ),\n );\n }\n console.log(\n chalk.dim(`Config file: ${path.join(cwd, \".vm0\", \"storage.yaml\")}`),\n );\n return;\n }\n\n // Determine memory name\n let memoryName: string;\n\n if (options.name) {\n memoryName = options.name;\n } else if (!isInteractive()) {\n throw new Error(\"--name flag is required in non-interactive mode\", {\n cause: new Error(\"Usage: vm0 memory init --name <memory-name>\"),\n });\n } else {\n // Interactive prompt with directory name as default\n const defaultName = isValidStorageName(dirName) ? dirName : undefined;\n const name = await promptText(\n \"Enter memory name\",\n defaultName,\n (value: string) => {\n if (!isValidStorageName(value)) {\n return \"Must be 3-64 characters, lowercase alphanumeric with hyphens\";\n }\n return true;\n },\n );\n\n if (name === undefined) {\n console.log(chalk.dim(\"Cancelled\"));\n return;\n }\n\n memoryName = name;\n }\n\n // Validate name\n if (!isValidStorageName(memoryName)) {\n throw new Error(`Invalid memory name: \"${memoryName}\"`, {\n cause: new Error(\n \"Memory names must be 3-64 characters, lowercase alphanumeric with hyphens\",\n ),\n });\n }\n\n // Write config file with type: memory\n await writeStorageConfig(memoryName, cwd, \"memory\");\n\n console.log(chalk.green(`✓ Initialized memory: ${memoryName}`));\n console.log(\n chalk.dim(\n ` Config saved to ${path.join(cwd, \".vm0\", \"storage.yaml\")}`,\n ),\n );\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { directUpload } from \"../../lib/storage/direct-upload\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pushCommand = new Command()\n .name(\"push\")\n .description(\"Push local files to cloud memory\")\n .option(\n \"-f, --force\",\n \"Force upload even if content unchanged (recreate archive)\",\n )\n .action(\n withErrorHandler(async (options: { force?: boolean }) => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No memory initialized in this directory\", {\n cause: new Error(\"Run: vm0 memory init\"),\n });\n }\n\n if (config.type !== \"memory\") {\n throw new Error(\n `This directory is initialized as ${config.type === \"artifact\" ? \"an artifact\" : \"a volume\"}, not a memory`,\n { cause: new Error(`Use: vm0 ${config.type} push`) },\n );\n }\n\n console.log(`Pushing memory: ${config.name}`);\n\n // Perform direct S3 upload\n const result = await directUpload(config.name, \"memory\", cwd, {\n onProgress: (message) => {\n console.log(chalk.dim(message));\n },\n force: options.force,\n });\n\n // Display short version (8 characters) by default\n const shortVersion = result.versionId.slice(0, 8);\n\n if (result.empty) {\n console.log(chalk.dim(\"No files found (empty memory)\"));\n } else if (result.deduplicated) {\n console.log(chalk.green(\"✓ Content unchanged (deduplicated)\"));\n } else {\n console.log(chalk.green(\"✓ Upload complete\"));\n }\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${result.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(result.size)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cloneStorage } from \"../../lib/storage/clone-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const pullCommand = new Command()\n .name(\"pull\")\n .description(\"Pull remote memory to local directory (latest version)\")\n .argument(\"[name]\", \"Memory name to pull\", \"memory\")\n .argument(\"[destination]\", \"Destination directory (default: memory name)\")\n .action(\n withErrorHandler(async (name: string, destination: string | undefined) => {\n const targetDir = destination || name;\n\n console.log(`Pulling memory: ${name}`);\n\n const result = await cloneStorage(name, \"memory\", targetDir);\n\n console.log(chalk.green(`\\n✓ Successfully pulled memory: ${name}`));\n console.log(chalk.dim(` Location: ${targetDir}/`));\n console.log(chalk.dim(` Version: ${result.versionId.slice(0, 8)}`));\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { getStorageDownload, ApiRequestError } from \"../../lib/api\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const statusCommand = new Command()\n .name(\"status\")\n .description(\"Show status of cloud memory\")\n .action(\n withErrorHandler(async () => {\n const cwd = process.cwd();\n\n // Read config\n const config = await readStorageConfig(cwd);\n if (!config) {\n throw new Error(\"No memory initialized in this directory\", {\n cause: new Error(\"Run: vm0 memory init\"),\n });\n }\n\n if (config.type !== \"memory\") {\n throw new Error(\n `This directory is initialized as ${config.type === \"artifact\" ? \"an artifact\" : \"a volume\"}, not a memory`,\n { cause: new Error(`Use: vm0 ${config.type} status`) },\n );\n }\n\n // Start message\n console.log(`Checking memory: ${config.name}`);\n\n // Call API\n try {\n const info = await getStorageDownload({\n name: config.name,\n type: \"memory\",\n });\n const shortVersion = info.versionId.slice(0, 8);\n\n if (\"empty\" in info) {\n console.log(chalk.green(\"✓ Found (empty)\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n } else {\n console.log(chalk.green(\"✓ Found\"));\n console.log(chalk.dim(` Version: ${shortVersion}`));\n console.log(chalk.dim(` Files: ${info.fileCount.toLocaleString()}`));\n console.log(chalk.dim(` Size: ${formatBytes(info.size)}`));\n }\n } catch (error) {\n if (error instanceof ApiRequestError && error.status === 404) {\n throw new Error(\"Not found on remote\", {\n cause: new Error(\"Run: vm0 memory push\"),\n });\n }\n throw error;\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { listStorages } from \"../../lib/api\";\nimport { formatBytes, formatRelativeTime } from \"../../lib/utils/file-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const listCommand = new Command()\n .name(\"list\")\n .alias(\"ls\")\n .description(\"List all remote memory storages\")\n .action(\n withErrorHandler(async () => {\n const items = await listStorages({ type: \"memory\" });\n\n if (items.length === 0) {\n console.log(chalk.dim(\"No memory storages found\"));\n console.log(\n chalk.dim(\" Memory is created automatically on first agent run\"),\n );\n return;\n }\n\n // Calculate column widths\n const nameWidth = Math.max(4, ...items.map((i) => i.name.length));\n const sizeWidth = Math.max(\n 4,\n ...items.map((i) => formatBytes(i.size).length),\n );\n const filesWidth = Math.max(\n 5,\n ...items.map((i) => i.fileCount.toString().length),\n );\n\n // Print header\n const header = [\n \"NAME\".padEnd(nameWidth),\n \"SIZE\".padStart(sizeWidth),\n \"FILES\".padStart(filesWidth),\n \"UPDATED\",\n ].join(\" \");\n console.log(chalk.dim(header));\n\n // Print rows\n for (const item of items) {\n const row = [\n item.name.padEnd(nameWidth),\n formatBytes(item.size).padStart(sizeWidth),\n item.fileCount.toString().padStart(filesWidth),\n formatRelativeTime(item.updatedAt),\n ].join(\" \");\n console.log(row);\n }\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { cloneStorage } from \"../../lib/storage/clone-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nexport const cloneCommand = new Command()\n .name(\"clone\")\n .description(\"Clone a remote memory to local directory (latest version)\")\n .argument(\"<name>\", \"Memory name to clone\")\n .argument(\"[destination]\", \"Destination directory (default: memory name)\")\n .action(\n withErrorHandler(async (name: string, destination: string | undefined) => {\n // Use memory name as destination if not specified\n const targetDir = destination || name;\n\n console.log(`Cloning memory: ${name}`);\n\n const result = await cloneStorage(name, \"memory\", targetDir);\n\n console.log(chalk.green(`\\n✓ Successfully cloned memory: ${name}`));\n console.log(chalk.dim(` Location: ${targetDir}/`));\n console.log(chalk.dim(` Version: ${result.versionId.slice(0, 8)}`));\n }),\n );\n","import { Command, Option } from \"commander\";\nimport chalk from \"chalk\";\nimport { readFile, mkdir } from \"fs/promises\";\nimport { existsSync } from \"fs\";\nimport path from \"path\";\nimport { parse as parseYaml } from \"yaml\";\nimport { validateAgentCompose } from \"../../lib/domain/yaml-validator\";\nimport { readStorageConfig } from \"../../lib/storage/storage-utils\";\nimport { checkAndUpgrade } from \"../../lib/utils/update-checker\";\nimport { saveCookState } from \"../../lib/domain/cook-state\";\nimport { withErrorHandler } from \"../../lib/command\";\nimport {\n CONFIG_FILE,\n ARTIFACT_DIR,\n printCommand,\n execVm0Command,\n execVm0RunWithCapture,\n parseRunIdsFromOutput,\n autoPullArtifact,\n} from \"./utils\";\n\ndeclare const __CLI_VERSION__: string;\n\ninterface VolumeConfig {\n name: string;\n version: string;\n}\n\ninterface AgentConfig {\n description?: string;\n framework: string;\n volumes?: string[];\n environment?: Record<string, string>;\n}\n\ninterface AgentComposeConfig {\n version: string;\n agents: Record<string, AgentConfig>;\n volumes?: Record<string, VolumeConfig>;\n}\n\ninterface LoadedConfig {\n config: AgentComposeConfig;\n agentName: string;\n volumeCount: number;\n}\n\n/**\n * Load and validate the compose config file.\n * Returns parsed config or exits on error.\n */\nasync function loadAndValidateConfig(): Promise<LoadedConfig> {\n console.log(chalk.bold(`Reading config: ${CONFIG_FILE}`));\n\n if (!existsSync(CONFIG_FILE)) {\n throw new Error(`Config file not found: ${CONFIG_FILE}`);\n }\n\n let config: AgentComposeConfig;\n try {\n const content = await readFile(CONFIG_FILE, \"utf8\");\n config = parseYaml(content) as AgentComposeConfig;\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\"Invalid YAML format\", { cause: error });\n }\n throw new Error(\"Invalid YAML format\");\n }\n\n const validation = validateAgentCompose(config);\n if (!validation.valid) {\n throw new Error(validation.error);\n }\n\n const agentNames = Object.keys(config.agents);\n const agentName = agentNames[0]!;\n const volumeCount = config.volumes ? Object.keys(config.volumes).length : 0;\n\n console.log(\n chalk.green(`✓ Config validated: 1 agent, ${volumeCount} volume(s)`),\n );\n\n return { config, agentName, volumeCount };\n}\n\n/**\n * Process and push all volumes defined in config.\n */\nasync function processVolumes(\n config: AgentComposeConfig,\n cwd: string,\n): Promise<void> {\n if (!config.volumes || Object.keys(config.volumes).length === 0) {\n return;\n }\n\n console.log();\n console.log(chalk.bold(\"Processing volumes:\"));\n\n for (const volumeConfig of Object.values(config.volumes)) {\n const volumeDir = path.join(cwd, volumeConfig.name);\n\n if (!existsSync(volumeDir)) {\n throw new Error(`Directory not found: ${volumeConfig.name}`, {\n cause: new Error(\"Create the directory and add files first\"),\n });\n }\n\n try {\n printCommand(`cd ${volumeConfig.name}`);\n\n // Check if already initialized\n const existingConfig = await readStorageConfig(volumeDir);\n if (!existingConfig) {\n printCommand(`vm0 volume init --name ${volumeConfig.name}`);\n await execVm0Command([\"volume\", \"init\", \"--name\", volumeConfig.name], {\n cwd: volumeDir,\n silent: true,\n });\n }\n\n // Push volume\n printCommand(\"vm0 volume push\");\n await execVm0Command([\"volume\", \"push\"], {\n cwd: volumeDir,\n silent: true,\n });\n\n printCommand(\"cd ..\");\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\"Volume processing failed\", { cause: error });\n }\n throw error;\n }\n }\n}\n\n/**\n * Initialize and push artifact directory.\n */\nasync function processArtifact(cwd: string): Promise<string> {\n console.log();\n console.log(chalk.bold(\"Processing artifact:\"));\n\n const artifactDir = path.join(cwd, ARTIFACT_DIR);\n\n try {\n // Create directory if not exists\n if (!existsSync(artifactDir)) {\n printCommand(`mkdir ${ARTIFACT_DIR}`);\n await mkdir(artifactDir, { recursive: true });\n }\n\n printCommand(`cd ${ARTIFACT_DIR}`);\n\n // Check if already initialized\n const existingConfig = await readStorageConfig(artifactDir);\n if (!existingConfig) {\n printCommand(`vm0 artifact init --name ${ARTIFACT_DIR}`);\n await execVm0Command([\"artifact\", \"init\", \"--name\", ARTIFACT_DIR], {\n cwd: artifactDir,\n silent: true,\n });\n }\n\n // Push artifact\n printCommand(\"vm0 artifact push\");\n await execVm0Command([\"artifact\", \"push\"], {\n cwd: artifactDir,\n silent: true,\n });\n\n printCommand(\"cd ..\");\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\"Artifact processing failed\", { cause: error });\n }\n throw error;\n }\n\n return artifactDir;\n}\n\n/**\n * Compose the agent using vm0 compose command.\n */\nasync function composeAgent(cwd: string, skipConfirm: boolean): Promise<void> {\n console.log();\n console.log(chalk.bold(\"Composing agent:\"));\n const composeArgs = skipConfirm\n ? [\"compose\", \"--yes\", CONFIG_FILE]\n : [\"compose\", CONFIG_FILE];\n printCommand(`vm0 ${composeArgs.join(\" \")}`);\n\n try {\n await execVm0Command(composeArgs, { cwd });\n } catch (error) {\n if (error instanceof Error) {\n throw new Error(\"Compose failed\", { cause: error });\n }\n throw error;\n }\n}\n\n/**\n * Run the agent with the given prompt.\n */\nasync function runAgent(\n agentName: string,\n artifactDir: string,\n prompt: string,\n cwd: string,\n options: {\n envFile?: string;\n verbose?: boolean;\n debugNoMockClaude?: boolean;\n },\n): Promise<void> {\n console.log();\n console.log(chalk.bold(\"Running agent:\"));\n printCommand(\n `vm0 run ${agentName} --artifact-name ${ARTIFACT_DIR} \"${prompt}\"`,\n );\n console.log();\n\n const runArgs = [\n \"run\",\n agentName,\n \"--artifact-name\",\n ARTIFACT_DIR,\n ...(options.envFile ? [\"--env-file\", options.envFile] : []),\n ...(options.verbose ? [\"--verbose\"] : []),\n ...(options.debugNoMockClaude ? [\"--debug-no-mock-claude\"] : []),\n prompt,\n ];\n const runOutput = await execVm0RunWithCapture(runArgs, { cwd });\n\n // Save session state for continue/resume commands\n const runIds = parseRunIdsFromOutput(runOutput);\n if (runIds.runId || runIds.sessionId || runIds.checkpointId) {\n await saveCookState({\n lastRunId: runIds.runId,\n lastSessionId: runIds.sessionId,\n lastCheckpointId: runIds.checkpointId,\n });\n }\n\n // Auto-pull artifact if run completed with artifact changes\n await autoPullArtifact(runOutput, artifactDir);\n}\n\nexport const cookAction = new Command()\n .name(\"cook\")\n .description(\"Quick start: prepare, compose and run agent from vm0.yaml\")\n .argument(\"[prompt]\", \"Prompt for the agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\"-y, --yes\", \"Skip confirmation prompts\")\n .option(\"-v, --verbose\", \"Show full tool inputs and outputs\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .addOption(new Option(\"--no-auto-update\").hideHelp())\n .action(\n withErrorHandler(\n async (\n prompt: string | undefined,\n options: {\n envFile?: string;\n yes?: boolean;\n verbose?: boolean;\n debugNoMockClaude?: boolean;\n autoUpdate?: boolean;\n },\n ) => {\n // Step 0: Check for updates and auto-upgrade if needed\n // Note: --no-auto-update sets autoUpdate to false\n if (options.autoUpdate !== false) {\n const shouldExit = await checkAndUpgrade(__CLI_VERSION__, prompt);\n if (shouldExit) {\n process.exit(0);\n }\n }\n\n const cwd = process.cwd();\n\n // Step 1: Load and validate config\n const { config, agentName } = await loadAndValidateConfig();\n\n // Step 2: Process volumes\n await processVolumes(config, cwd);\n\n // Step 3: Process artifact\n const artifactDir = await processArtifact(cwd);\n\n // Step 4: Compose agent\n await composeAgent(cwd, options.yes ?? false);\n\n // Step 5: Run agent (if prompt provided)\n if (prompt) {\n await runAgent(agentName, artifactDir, prompt, cwd, {\n envFile: options.envFile,\n verbose: options.verbose,\n debugNoMockClaude: options.debugNoMockClaude,\n });\n } else {\n console.log();\n console.log(\"To run your agent:\");\n printCommand(\n `vm0 run ${agentName} --artifact-name ${ARTIFACT_DIR} \"your prompt\"`,\n );\n }\n },\n ),\n );\n","import { homedir } from \"os\";\nimport { join } from \"path\";\nimport { readFile, writeFile, mkdir } from \"fs/promises\";\nimport { existsSync } from \"fs\";\n\nconst CONFIG_DIR = join(homedir(), \".vm0\");\nconst COOK_STATE_FILE = join(CONFIG_DIR, \"cook.json\");\nconst STALE_THRESHOLD_MS = 48 * 60 * 60 * 1000; // 48 hours\n\n// Public API interface (unchanged for backward compatibility)\ninterface CookState {\n lastRunId?: string;\n lastSessionId?: string;\n lastCheckpointId?: string;\n}\n\n// Internal storage structure\ninterface CookStateEntry {\n lastRunId?: string;\n lastSessionId?: string;\n lastCheckpointId?: string;\n lastActiveAt: number;\n}\n\ninterface CookStateFile {\n ppid: Record<string, CookStateEntry>;\n}\n\n/**\n * Load cook state file with automatic migration from old format\n */\nasync function loadCookStateFile(): Promise<CookStateFile> {\n if (!existsSync(COOK_STATE_FILE)) {\n return { ppid: {} };\n }\n\n try {\n const content = await readFile(COOK_STATE_FILE, \"utf8\");\n const data = JSON.parse(content) as Record<string, unknown>;\n\n // Detect old format (no ppid field)\n if (!data.ppid) {\n // Migrate old data to current PPID\n const oldState = data as CookState;\n return {\n ppid: {\n [String(process.ppid)]: {\n lastRunId: oldState.lastRunId,\n lastSessionId: oldState.lastSessionId,\n lastCheckpointId: oldState.lastCheckpointId,\n lastActiveAt: Date.now(),\n },\n },\n };\n }\n\n return data as unknown as CookStateFile;\n } catch {\n // If file is corrupted, return empty state\n return { ppid: {} };\n }\n}\n\nexport async function loadCookState(): Promise<CookState> {\n const file = await loadCookStateFile();\n const ppid = String(process.ppid);\n const entry = file.ppid[ppid];\n\n if (!entry) return {};\n\n return {\n lastRunId: entry.lastRunId,\n lastSessionId: entry.lastSessionId,\n lastCheckpointId: entry.lastCheckpointId,\n };\n}\n\nexport async function saveCookState(state: CookState): Promise<void> {\n // Ensure config directory exists\n await mkdir(CONFIG_DIR, { recursive: true });\n\n const file = await loadCookStateFile();\n const ppid = String(process.ppid);\n const now = Date.now();\n\n // Clean up stale entries (older than 48 hours)\n for (const key of Object.keys(file.ppid)) {\n const entry = file.ppid[key];\n if (entry && now - entry.lastActiveAt > STALE_THRESHOLD_MS) {\n delete file.ppid[key];\n }\n }\n\n // Merge with existing entry for this PPID\n const existing = file.ppid[ppid];\n file.ppid[ppid] = {\n lastRunId: state.lastRunId ?? existing?.lastRunId,\n lastSessionId: state.lastSessionId ?? existing?.lastSessionId,\n lastCheckpointId: state.lastCheckpointId ?? existing?.lastCheckpointId,\n lastActiveAt: now,\n };\n\n // Write state file\n await writeFile(COOK_STATE_FILE, JSON.stringify(file, null, 2), \"utf8\");\n}\n","import chalk from \"chalk\";\nimport { existsSync } from \"fs\";\nimport { safeSpawn } from \"../../lib/utils/spawn\";\n\nexport const CONFIG_FILE = \"vm0.yaml\";\nexport const ARTIFACT_DIR = \"artifact\";\n\n/**\n * Print a command hint for tutorial output\n */\nexport function printCommand(cmd: string): void {\n console.log(chalk.dim(`> ${cmd}`));\n}\n\n/**\n * Execute a vm0 command in a subprocess\n * Returns stdout on success, throws on failure with stderr\n *\n * @param options.silent - If true, capture stdout/stderr (no output to terminal)\n */\nexport function execVm0Command(\n args: string[],\n options: { cwd?: string; silent?: boolean } = {},\n): Promise<string> {\n return new Promise((resolve, reject) => {\n // Determine stdio configuration:\n // - silent: pipe all (capture output, no terminal interaction)\n // - default: inherit all (full terminal passthrough, allows prompts)\n const stdio: \"pipe\" | \"inherit\" = options.silent ? \"pipe\" : \"inherit\";\n\n const proc = safeSpawn(\"vm0\", args, {\n cwd: options.cwd,\n stdio,\n });\n\n let stdout = \"\";\n let stderr = \"\";\n\n if (options.silent) {\n proc.stdout?.on(\"data\", (data: Buffer) => {\n stdout += data.toString();\n });\n proc.stderr?.on(\"data\", (data: Buffer) => {\n stderr += data.toString();\n });\n }\n\n proc.on(\"close\", (code) => {\n if (code === 0) {\n resolve(stdout);\n } else {\n reject(new Error(stderr || `Command failed with exit code ${code}`));\n }\n });\n\n proc.on(\"error\", (err) => {\n reject(err);\n });\n });\n}\n\n/**\n * Execute vm0 run command while capturing output for artifact version parsing\n * Streams output to console while also capturing it\n * Returns the captured stdout\n */\nexport function execVm0RunWithCapture(\n args: string[],\n options: { cwd?: string } = {},\n): Promise<string> {\n return new Promise((resolve, reject) => {\n // Force color output when parent is a TTY, since piped stdio disables TTY detection\n const env = process.stdout.isTTY\n ? { ...process.env, FORCE_COLOR: \"1\" }\n : process.env;\n\n const proc = safeSpawn(\"vm0\", args, {\n cwd: options.cwd,\n env,\n stdio: [\"inherit\", \"pipe\", \"pipe\"],\n });\n\n let stdout = \"\";\n let stderr = \"\";\n\n proc.stdout?.on(\"data\", (data: Buffer) => {\n const chunk = data.toString();\n stdout += chunk;\n process.stdout.write(chunk);\n });\n\n proc.stderr?.on(\"data\", (data: Buffer) => {\n const chunk = data.toString();\n stderr += chunk;\n process.stderr.write(chunk);\n });\n\n proc.on(\"close\", (code) => {\n if (code === 0) {\n resolve(stdout);\n } else {\n reject(new Error(stderr || `Command failed with exit code ${code}`));\n }\n });\n\n proc.on(\"error\", (err) => {\n reject(err);\n });\n });\n}\n\n/**\n * Parse artifact version from vm0 run completion output\n * Looks for pattern like:\n * ✓ Run completed successfully\n * ...\n * Artifact:\n * artifactName: abc12345\n * Returns the version string (8 char truncated hash)\n */\nfunction parseArtifactVersionFromCompletion(\n output: string,\n artifactName: string,\n): string | null {\n // Find the completion section marker\n const completionMarker = \"Run completed successfully\";\n const completionIndex = output.indexOf(completionMarker);\n if (completionIndex === -1) return null;\n\n // Get the completion section\n const section = output.slice(completionIndex);\n\n // Look for Artifact section and extract version\n // Pattern: \" artifactName: version\" (with ANSI codes possibly)\n const artifactPattern = new RegExp(\n `^\\\\s*${escapeRegExp(artifactName)}:\\\\s*(?:\\\\x1b\\\\[[0-9;]*m)?([a-f0-9]+)`,\n \"m\",\n );\n const match = section.match(artifactPattern);\n return match ? match[1]! : null;\n}\n\n/**\n * Escape special regex characters in a string\n */\nfunction escapeRegExp(str: string): string {\n return str.replace(/[.*+?^${}()|[\\]\\\\]/g, \"\\\\$&\");\n}\n\n/**\n * Parse run IDs from vm0 run completion output\n * Extracts runId, sessionId, and checkpointId from the \"Next steps\" section\n */\ninterface ParsedRunIds {\n runId?: string;\n sessionId?: string;\n checkpointId?: string;\n}\n\nexport function parseRunIdsFromOutput(output: string): ParsedRunIds {\n const completionMarker = \"Run completed successfully\";\n const completionIndex = output.indexOf(completionMarker);\n if (completionIndex === -1) return {};\n\n const section = output.slice(completionIndex);\n\n // Strip ANSI codes for reliable matching\n // ESC character (0x1B) followed by [ and ANSI sequence\n const ESC = String.fromCharCode(0x1b);\n const ansiPattern = new RegExp(`${ESC}\\\\[[0-9;]*m`, \"g\");\n const stripped = section.replace(ansiPattern, \"\");\n\n return {\n runId: stripped.match(/vm0 logs ([0-9a-f-]{36})/)?.[1],\n sessionId: stripped.match(/vm0 run continue ([0-9a-f-]{36})/)?.[1],\n checkpointId: stripped.match(/vm0 run resume ([0-9a-f-]{36})/)?.[1],\n };\n}\n\n/**\n * Auto-pull artifact after a successful run\n */\nexport async function autoPullArtifact(\n runOutput: string,\n artifactDir: string,\n): Promise<void> {\n const serverVersion = parseArtifactVersionFromCompletion(\n runOutput,\n ARTIFACT_DIR,\n );\n\n if (serverVersion && existsSync(artifactDir)) {\n console.log();\n console.log(chalk.bold(\"Pulling updated artifact:\"));\n printCommand(`cd ${ARTIFACT_DIR}`);\n printCommand(`vm0 artifact pull ${serverVersion}`);\n\n try {\n await execVm0Command([\"artifact\", \"pull\", serverVersion], {\n cwd: artifactDir,\n silent: true,\n });\n printCommand(\"cd ..\");\n } catch (error) {\n console.error(chalk.red(`✗ Artifact pull failed`));\n if (error instanceof Error) {\n console.error(chalk.dim(` ${error.message}`));\n }\n // Don't exit - the run succeeded, pull is optional\n }\n }\n}\n","import { Command } from \"commander\";\nimport { loadCookState } from \"../../lib/domain/cook-state\";\nimport { withErrorHandler } from \"../../lib/command\";\nimport { printCommand, execVm0Command } from \"./utils\";\n\nexport const logsCommand = new Command()\n .name(\"logs\")\n .description(\"View logs from the last cook run\")\n .option(\"-a, --agent\", \"Show agent events (default)\")\n .option(\"-s, --system\", \"Show system log\")\n .option(\"-m, --metrics\", \"Show metrics\")\n .option(\"-n, --network\", \"Show network logs (proxy traffic)\")\n .option(\n \"--since <time>\",\n \"Show logs since timestamp (e.g., 5m, 2h, 1d, 2024-01-15T10:30:00Z)\",\n )\n .option(\"--tail <n>\", \"Show last N entries (default: 5, max: 100)\")\n .option(\"--head <n>\", \"Show first N entries (max: 100)\")\n .action(\n withErrorHandler(\n async (options: {\n agent?: boolean;\n system?: boolean;\n metrics?: boolean;\n network?: boolean;\n since?: string;\n tail?: string;\n head?: string;\n }) => {\n const state = await loadCookState();\n if (!state.lastRunId) {\n throw new Error(\"No previous run found\", {\n cause: new Error(\"Run 'vm0 cook <prompt>' first\"),\n });\n }\n\n // Build command args\n const args = [\"logs\", state.lastRunId];\n const displayArgs = [`vm0 logs ${state.lastRunId}`];\n\n if (options.agent) {\n args.push(\"--agent\");\n displayArgs.push(\"--agent\");\n }\n if (options.system) {\n args.push(\"--system\");\n displayArgs.push(\"--system\");\n }\n if (options.metrics) {\n args.push(\"--metrics\");\n displayArgs.push(\"--metrics\");\n }\n if (options.network) {\n args.push(\"--network\");\n displayArgs.push(\"--network\");\n }\n if (options.since) {\n args.push(\"--since\", options.since);\n displayArgs.push(`--since ${options.since}`);\n }\n if (options.tail) {\n args.push(\"--tail\", options.tail);\n displayArgs.push(`--tail ${options.tail}`);\n }\n if (options.head) {\n args.push(\"--head\", options.head);\n displayArgs.push(`--head ${options.head}`);\n }\n\n printCommand(displayArgs.join(\" \"));\n await execVm0Command(args);\n },\n ),\n );\n","import { Command, Option } from \"commander\";\nimport path from \"path\";\nimport { loadCookState, saveCookState } from \"../../lib/domain/cook-state\";\nimport { withErrorHandler } from \"../../lib/command\";\nimport {\n ARTIFACT_DIR,\n printCommand,\n execVm0RunWithCapture,\n parseRunIdsFromOutput,\n autoPullArtifact,\n} from \"./utils\";\n\nexport const continueCommand = new Command()\n .name(\"continue\")\n .description(\n \"Continue from the last session (latest conversation and artifact)\",\n )\n .argument(\"<prompt>\", \"Prompt for the continued agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\"-v, --verbose\", \"Show full tool inputs and outputs\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .action(\n withErrorHandler(\n async (\n prompt: string,\n options: {\n envFile?: string;\n verbose?: boolean;\n debugNoMockClaude?: boolean;\n },\n ) => {\n const state = await loadCookState();\n if (!state.lastSessionId) {\n throw new Error(\"No previous session found\", {\n cause: new Error(\"Run 'vm0 cook <prompt>' first\"),\n });\n }\n\n const cwd = process.cwd();\n const artifactDir = path.join(cwd, ARTIFACT_DIR);\n\n const envFileArg = options.envFile\n ? ` --env-file ${options.envFile}`\n : \"\";\n printCommand(\n `vm0 run continue${envFileArg} ${state.lastSessionId} \"${prompt}\"`,\n );\n console.log();\n\n const runOutput = await execVm0RunWithCapture(\n [\n \"run\",\n \"continue\",\n ...(options.envFile ? [\"--env-file\", options.envFile] : []),\n ...(options.verbose ? [\"--verbose\"] : []),\n state.lastSessionId,\n ...(options.debugNoMockClaude ? [\"--debug-no-mock-claude\"] : []),\n prompt,\n ],\n { cwd },\n );\n\n // Update state with new IDs\n const newIds = parseRunIdsFromOutput(runOutput);\n if (newIds.runId || newIds.sessionId || newIds.checkpointId) {\n await saveCookState({\n lastRunId: newIds.runId,\n lastSessionId: newIds.sessionId,\n lastCheckpointId: newIds.checkpointId,\n });\n }\n\n // Auto-pull artifact\n await autoPullArtifact(runOutput, artifactDir);\n },\n ),\n );\n","import { Command, Option } from \"commander\";\nimport path from \"path\";\nimport { loadCookState, saveCookState } from \"../../lib/domain/cook-state\";\nimport { withErrorHandler } from \"../../lib/command\";\nimport {\n ARTIFACT_DIR,\n printCommand,\n execVm0RunWithCapture,\n parseRunIdsFromOutput,\n autoPullArtifact,\n} from \"./utils\";\n\nexport const resumeCommand = new Command()\n .name(\"resume\")\n .description(\n \"Resume from the last checkpoint (snapshotted conversation and artifact)\",\n )\n .argument(\"<prompt>\", \"Prompt for the resumed agent\")\n .option(\n \"--env-file <path>\",\n \"Load environment variables from file (priority: CLI flags > file > env vars)\",\n )\n .option(\"-v, --verbose\", \"Show full tool inputs and outputs\")\n .addOption(new Option(\"--debug-no-mock-claude\").hideHelp())\n .action(\n withErrorHandler(\n async (\n prompt: string,\n options: {\n envFile?: string;\n verbose?: boolean;\n debugNoMockClaude?: boolean;\n },\n ) => {\n const state = await loadCookState();\n if (!state.lastCheckpointId) {\n throw new Error(\"No previous checkpoint found\", {\n cause: new Error(\"Run 'vm0 cook <prompt>' first\"),\n });\n }\n\n const cwd = process.cwd();\n const artifactDir = path.join(cwd, ARTIFACT_DIR);\n\n const envFileArg = options.envFile\n ? ` --env-file ${options.envFile}`\n : \"\";\n printCommand(\n `vm0 run resume${envFileArg} ${state.lastCheckpointId} \"${prompt}\"`,\n );\n console.log();\n\n const runOutput = await execVm0RunWithCapture(\n [\n \"run\",\n \"resume\",\n ...(options.envFile ? [\"--env-file\", options.envFile] : []),\n ...(options.verbose ? [\"--verbose\"] : []),\n state.lastCheckpointId,\n ...(options.debugNoMockClaude ? [\"--debug-no-mock-claude\"] : []),\n prompt,\n ],\n { cwd },\n );\n\n // Update state with new IDs\n const newIds = parseRunIdsFromOutput(runOutput);\n if (newIds.runId || newIds.sessionId || newIds.checkpointId) {\n await saveCookState({\n lastRunId: newIds.runId,\n lastSessionId: newIds.sessionId,\n lastCheckpointId: newIds.checkpointId,\n });\n }\n\n // Auto-pull artifact\n await autoPullArtifact(runOutput, artifactDir);\n },\n ),\n );\n","import { cookAction } from \"./cook\";\nimport { logsCommand } from \"./logs\";\nimport { continueCommand } from \"./continue\";\nimport { resumeCommand } from \"./resume\";\n\n// Add subcommands to the cook command\ncookAction.addCommand(logsCommand);\ncookAction.addCommand(continueCommand);\ncookAction.addCommand(resumeCommand);\n\nexport const cookCommand = cookAction;\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport {\n getAgentEvents,\n getSystemLog,\n getMetrics,\n getNetworkLogs,\n type TelemetryMetric,\n type RunEvent,\n type NetworkLogEntry,\n} from \"../../lib/api\";\nimport { getApiUrl } from \"../../lib/api/config\";\nimport { parseTime } from \"../../lib/utils/time-parser\";\nimport { formatBytes } from \"../../lib/utils/file-utils\";\nimport { ClaudeEventParser } from \"../../lib/events/claude-event-parser\";\nimport { EventRenderer } from \"../../lib/events/event-renderer\";\nimport { paginate } from \"../../lib/utils/paginate\";\nimport { searchCommand } from \"./search\";\nimport { withErrorHandler } from \"../../lib/command\";\n\n/**\n * Maximum entries per API request\n */\nconst PAGE_LIMIT = 100;\n\n/**\n * Build platform URL for logs viewer\n * Transforms API URL to platform URL and appends logs path\n */\nfunction buildPlatformLogsUrl(apiUrl: string, runId: string): string {\n const url = new URL(apiUrl);\n const hostname = url.hostname;\n\n // Handle localhost\n if (hostname === \"localhost\" || hostname === \"127.0.0.1\") {\n return `http://${hostname}:3001/logs/${runId}`;\n }\n\n // Transform: www.vm0.ai → app.vm0.ai\n // vm0.ai → app.vm0.ai\n const parts = hostname.split(\".\");\n if (parts[0] === \"www\" || parts[0] === \"app\" || parts[0] === \"platform\") {\n parts[0] = \"app\";\n } else {\n parts.unshift(\"app\");\n }\n\n const platformHost = parts.join(\".\");\n const port = url.port ? `:${url.port}` : \"\";\n return `https://${platformHost}${port}/logs/${runId}`;\n}\n\n/**\n * Log type for mutually exclusive options\n */\ntype LogType = \"agent\" | \"system\" | \"metrics\" | \"network\";\n\n/**\n * Format a single metric line\n */\nfunction formatMetric(metric: TelemetryMetric): string {\n const memPercent = ((metric.mem_used / metric.mem_total) * 100).toFixed(1);\n const diskPercent = ((metric.disk_used / metric.disk_total) * 100).toFixed(1);\n\n return `[${metric.ts}] CPU: ${metric.cpu.toFixed(1)}% | Mem: ${formatBytes(metric.mem_used)}/${formatBytes(metric.mem_total)} (${memPercent}%) | Disk: ${formatBytes(metric.disk_used)}/${formatBytes(metric.disk_total)} (${diskPercent}%)`;\n}\n\n/**\n * Format a denied network request (blocked by firewall permission)\n */\nfunction formatNetworkDeny(entry: NetworkLogEntry): string {\n const method = entry.method || \"???\";\n const url = entry.url || entry.host || \"unknown\";\n const firewall = entry.firewall_name\n ? ` ${chalk.cyan(`[${entry.firewall_name}]`)}`\n : \"\";\n return `[${entry.timestamp}] ${method.padEnd(6)} ${chalk.red.bold(\"DENY\")} ${chalk.dim(url)}${firewall}`;\n}\n\n/**\n * Format token replacement info (resolved secrets, refresh/cache status)\n */\nfunction formatTokenInfo(entry: NetworkLogEntry): string {\n if (\n !entry.token_resolved_secrets ||\n entry.token_resolved_secrets.length === 0\n ) {\n return \"\";\n }\n const refreshedSet = new Set(entry.token_refreshed_secrets ?? []);\n const parts = entry.token_resolved_secrets.map((name) => {\n if (refreshedSet.has(name)) return `${name} (refreshed)`;\n if (entry.token_cache_hit) return `${name} (cached)`;\n return name;\n });\n return ` ${chalk.yellow(`\\u2194 ${parts.join(\", \")}`)}`;\n}\n\n/**\n * Format an ALLOW or ERROR network request with full HTTP details\n */\nfunction formatNetworkRequest(entry: NetworkLogEntry): string {\n let statusColor: typeof chalk.green;\n const status = entry.status || 0;\n if (status >= 200 && status < 300) {\n statusColor = chalk.green;\n } else if (status >= 300 && status < 400) {\n statusColor = chalk.yellow;\n } else if (status >= 400) {\n statusColor = chalk.red;\n } else {\n statusColor = chalk.gray;\n }\n\n let latencyColor: typeof chalk.green;\n const latencyMs = entry.latency_ms || 0;\n if (latencyMs < 500) {\n latencyColor = chalk.green;\n } else if (latencyMs < 2000) {\n latencyColor = chalk.yellow;\n } else {\n latencyColor = chalk.red;\n }\n\n const method = entry.method || \"???\";\n const requestSize = entry.request_size || 0;\n const responseSize = entry.response_size || 0;\n const url = entry.url || entry.host || \"unknown\";\n const firewall = entry.firewall_name\n ? ` ${chalk.cyan(`[${entry.firewall_name}]`)}`\n : \"\";\n const error = entry.firewall_error\n ? ` ${chalk.red(entry.firewall_error)}`\n : \"\";\n\n return `[${entry.timestamp}] ${method.padEnd(6)} ${statusColor(status)} ${latencyColor(latencyMs + \"ms\")} ${formatBytes(requestSize)}/${formatBytes(responseSize)} ${chalk.dim(url)}${firewall}${error}${formatTokenInfo(entry)}`;\n}\n\n/**\n * Format a TCP connection log entry\n */\nfunction formatNetworkTcp(entry: NetworkLogEntry): string {\n const host = entry.host || \"unknown\";\n const port = entry.port || 0;\n const requestSize = entry.request_size || 0;\n const responseSize = entry.response_size || 0;\n const latencyMs = entry.latency_ms || 0;\n const error = entry.error ? ` ${chalk.red(entry.error)}` : \"\";\n\n return `[${entry.timestamp}] ${chalk.blue(\"TCP\")} ${latencyMs}ms ${formatBytes(requestSize)}/${formatBytes(responseSize)} ${chalk.dim(`${host}:${port}`)}${error}`;\n}\n\n/**\n * Format a non-TCP/non-HTTP log entry (UDP, ICMP, etc).\n * These come from iptables LOG via /dev/kmsg, not mitmproxy.\n */\nfunction formatNetworkOther(entry: NetworkLogEntry): string {\n const proto = (entry.type || \"???\").toUpperCase();\n const host = entry.host || \"unknown\";\n const port = entry.port || 0;\n const size = entry.request_size || 0;\n\n return `[${entry.timestamp}] ${chalk.magenta(proto.padEnd(5))} ${formatBytes(size)} ${chalk.dim(`${host}:${port}`)}`;\n}\n\n/**\n * Format a network log entry\n */\nfunction formatNetworkLog(entry: NetworkLogEntry): string {\n if (entry.type === \"tcp\") return formatNetworkTcp(entry);\n if (entry.type && entry.type !== \"http\") return formatNetworkOther(entry);\n if (entry.action === \"DENY\") return formatNetworkDeny(entry);\n return formatNetworkRequest(entry);\n}\n\n/**\n * Create an EventRenderer for log viewing (with timestamps)\n * Uses buffered mode to group tool_use/tool_result together for consistent\n * rendering with vm0 run output\n */\nfunction createLogRenderer(verbose: boolean): EventRenderer {\n return new EventRenderer({\n showTimestamp: true,\n verbose,\n });\n}\n\n/**\n * Render an agent event with timestamp for historical log viewing\n */\nfunction renderAgentEvent(event: RunEvent, renderer: EventRenderer): void {\n const eventData = event.eventData as Record<string, unknown>;\n const parsed = ClaudeEventParser.parse(eventData);\n if (parsed) {\n parsed.timestamp = new Date(event.createdAt);\n renderer.render(parsed);\n }\n}\n\n/**\n * Validate mutually exclusive options and return the log type\n */\nfunction getLogType(options: {\n agent?: boolean;\n system?: boolean;\n metrics?: boolean;\n network?: boolean;\n}): LogType {\n const selected = [\n options.agent,\n options.system,\n options.metrics,\n options.network,\n ].filter(Boolean).length;\n\n if (selected > 1) {\n throw new Error(\n \"Options --agent, --system, --metrics, and --network are mutually exclusive\",\n );\n }\n\n if (options.system) return \"system\";\n if (options.metrics) return \"metrics\";\n if (options.network) return \"network\";\n return \"agent\"; // Default\n}\n\nexport const logsCommand = new Command()\n .name(\"logs\")\n .description(\"View and search agent run logs\")\n .argument(\"[runId]\", \"Run ID to fetch logs for\")\n .addCommand(searchCommand)\n .option(\"-a, --agent\", \"Show agent events (default)\")\n .option(\"-s, --system\", \"Show system log\")\n .option(\"-m, --metrics\", \"Show metrics\")\n .option(\"-n, --network\", \"Show network logs (proxy traffic)\")\n .option(\n \"--since <time>\",\n \"Show logs since timestamp (e.g., 5m, 2h, 1d, 2024-01-15T10:30:00Z, 1705312200)\",\n )\n .option(\"--tail <n>\", \"Show last N entries (default: 5)\")\n .option(\"--head <n>\", \"Show first N entries\")\n .option(\"--all\", \"Fetch all log entries\")\n .action(\n withErrorHandler(\n async (\n runId: string | undefined,\n options: {\n agent?: boolean;\n system?: boolean;\n metrics?: boolean;\n network?: boolean;\n since?: string;\n tail?: string;\n head?: string;\n all?: boolean;\n },\n ) => {\n if (!runId) {\n logsCommand.help();\n return;\n }\n\n const logType = getLogType(options);\n\n // Validate --tail, --head, and --all are mutually exclusive\n const countModes = [\n options.tail !== undefined,\n options.head !== undefined,\n options.all === true,\n ].filter(Boolean).length;\n if (countModes > 1) {\n throw new Error(\n \"Options --tail, --head, and --all are mutually exclusive\",\n );\n }\n\n // Parse since option\n let since: number | undefined;\n if (options.since) {\n since = parseTime(options.since);\n }\n\n // Determine pagination mode and order based on flags\n const isAll = options.all === true;\n const isHead = options.head !== undefined;\n const isTail = options.tail !== undefined;\n\n // targetCount: number for --head/--tail, \"all\" for --all, default 5 for no flag\n let targetCount: number | \"all\";\n if (isAll) {\n targetCount = \"all\";\n } else if (isHead) {\n targetCount = Math.max(1, parseInt(options.head!, 10));\n } else if (isTail) {\n targetCount = Math.max(1, parseInt(options.tail!, 10));\n } else {\n // Default: show last 5 entries\n targetCount = 5;\n }\n\n // Order: asc for --head, desc for --tail/--all/default\n const order: \"asc\" | \"desc\" = isHead ? \"asc\" : \"desc\";\n\n // Build platform URL for agent logs\n const apiUrl = await getApiUrl();\n const platformUrl = buildPlatformLogsUrl(apiUrl, runId);\n\n switch (logType) {\n case \"agent\":\n await showAgentEvents(\n runId,\n { since, targetCount, order },\n platformUrl,\n );\n break;\n case \"system\":\n await showSystemLog(runId, { since, targetCount, order });\n break;\n case \"metrics\":\n await showMetrics(runId, { since, targetCount, order });\n break;\n case \"network\":\n await showNetworkLogs(runId, { since, targetCount, order });\n break;\n }\n },\n ),\n );\n\n/**\n * Show agent events with pagination support\n */\nasync function showAgentEvents(\n runId: string,\n options: {\n since?: number;\n targetCount: number | \"all\";\n order: \"asc\" | \"desc\";\n },\n platformUrl: string,\n): Promise<void> {\n // Fetch first page to get framework info\n const firstResponse = await getAgentEvents(runId, {\n since: options.since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n\n if (firstResponse.events.length === 0) {\n console.log(chalk.yellow(\"No agent events found for this run\"));\n return;\n }\n\n // Use pagination to collect all needed events\n let allEvents: RunEvent[];\n\n if (\n !firstResponse.hasMore ||\n (options.targetCount !== \"all\" &&\n firstResponse.events.length >= options.targetCount)\n ) {\n // Single page is enough\n allEvents =\n options.targetCount === \"all\"\n ? firstResponse.events\n : firstResponse.events.slice(0, options.targetCount);\n } else {\n // Need to paginate\n const lastEvent = firstResponse.events[firstResponse.events.length - 1];\n const firstPageTimestamp = lastEvent\n ? new Date(lastEvent.createdAt).getTime()\n : undefined;\n\n const remainingEvents = await paginate<RunEvent>({\n fetchPage: async (since) => {\n const response = await getAgentEvents(runId, {\n since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n return { items: response.events, hasMore: response.hasMore };\n },\n getTimestamp: (event) => new Date(event.createdAt).getTime(),\n targetCount:\n options.targetCount === \"all\"\n ? \"all\"\n : options.targetCount - firstResponse.events.length,\n initialSince: firstPageTimestamp,\n });\n\n allEvents = [...firstResponse.events, ...remainingEvents];\n\n // Trim to target count if needed\n if (\n options.targetCount !== \"all\" &&\n allEvents.length > options.targetCount\n ) {\n allEvents = allEvents.slice(0, options.targetCount);\n }\n }\n\n // Reverse for chronological display when using desc order (--tail)\n const events =\n options.order === \"desc\" ? [...allEvents].reverse() : allEvents;\n\n // Create renderer for log viewing (with timestamps, always verbose)\n const renderer = createLogRenderer(true);\n\n for (const event of events) {\n renderAgentEvent(event, renderer);\n }\n\n console.log(chalk.dim(`View on platform: ${platformUrl}`));\n}\n\n/**\n * Show system log with pagination support\n * Note: System log pagination is limited because the API returns aggregated strings\n * without individual timestamps. The --tail/--head/--all options work on batch count,\n * not line count.\n */\nasync function showSystemLog(\n runId: string,\n options: {\n since?: number;\n targetCount: number | \"all\";\n order: \"asc\" | \"desc\";\n },\n): Promise<void> {\n // For system log, we fetch with a high limit to get more batches\n // The API aggregates batches into a single string\n const limit =\n options.targetCount === \"all\"\n ? PAGE_LIMIT\n : Math.min(options.targetCount, PAGE_LIMIT);\n\n const response = await getSystemLog(runId, {\n since: options.since,\n limit,\n order: options.order,\n });\n\n if (!response.systemLog) {\n console.log(chalk.yellow(\"No system log found for this run\"));\n return;\n }\n\n console.log(response.systemLog);\n}\n\n/**\n * Show metrics with pagination support\n */\nasync function showMetrics(\n runId: string,\n options: {\n since?: number;\n targetCount: number | \"all\";\n order: \"asc\" | \"desc\";\n },\n): Promise<void> {\n // Fetch first page\n const firstResponse = await getMetrics(runId, {\n since: options.since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n\n if (firstResponse.metrics.length === 0) {\n console.log(chalk.yellow(\"No metrics found for this run\"));\n return;\n }\n\n // Use pagination to collect all needed metrics\n let allMetrics: TelemetryMetric[];\n\n if (\n !firstResponse.hasMore ||\n (options.targetCount !== \"all\" &&\n firstResponse.metrics.length >= options.targetCount)\n ) {\n // Single page is enough\n allMetrics =\n options.targetCount === \"all\"\n ? firstResponse.metrics\n : firstResponse.metrics.slice(0, options.targetCount);\n } else {\n // Need to paginate\n const lastMetric = firstResponse.metrics[firstResponse.metrics.length - 1];\n const firstPageTimestamp = lastMetric\n ? new Date(lastMetric.ts).getTime()\n : undefined;\n\n const remainingMetrics = await paginate<TelemetryMetric>({\n fetchPage: async (since) => {\n const response = await getMetrics(runId, {\n since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n return { items: response.metrics, hasMore: response.hasMore };\n },\n getTimestamp: (metric) => new Date(metric.ts).getTime(),\n targetCount:\n options.targetCount === \"all\"\n ? \"all\"\n : options.targetCount - firstResponse.metrics.length,\n initialSince: firstPageTimestamp,\n });\n\n allMetrics = [...firstResponse.metrics, ...remainingMetrics];\n\n // Trim to target count if needed\n if (\n options.targetCount !== \"all\" &&\n allMetrics.length > options.targetCount\n ) {\n allMetrics = allMetrics.slice(0, options.targetCount);\n }\n }\n\n // Reverse for chronological display when using desc order (--tail)\n const metrics =\n options.order === \"desc\" ? [...allMetrics].reverse() : allMetrics;\n\n for (const metric of metrics) {\n console.log(formatMetric(metric));\n }\n}\n\n/**\n * Show network logs with pagination support\n */\nasync function showNetworkLogs(\n runId: string,\n options: {\n since?: number;\n targetCount: number | \"all\";\n order: \"asc\" | \"desc\";\n },\n): Promise<void> {\n // Fetch first page\n const firstResponse = await getNetworkLogs(runId, {\n since: options.since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n\n if (firstResponse.networkLogs.length === 0) {\n console.log(\n chalk.yellow(\n \"No network logs found for this run. Network logs are only captured when using a runner with proxy enabled\",\n ),\n );\n return;\n }\n\n // Use pagination to collect all needed network logs\n let allNetworkLogs: NetworkLogEntry[];\n\n if (\n !firstResponse.hasMore ||\n (options.targetCount !== \"all\" &&\n firstResponse.networkLogs.length >= options.targetCount)\n ) {\n // Single page is enough\n allNetworkLogs =\n options.targetCount === \"all\"\n ? firstResponse.networkLogs\n : firstResponse.networkLogs.slice(0, options.targetCount);\n } else {\n // Need to paginate\n const lastLog =\n firstResponse.networkLogs[firstResponse.networkLogs.length - 1];\n const firstPageTimestamp = lastLog\n ? new Date(lastLog.timestamp).getTime()\n : undefined;\n\n const remainingLogs = await paginate<NetworkLogEntry>({\n fetchPage: async (since) => {\n const response = await getNetworkLogs(runId, {\n since,\n limit: PAGE_LIMIT,\n order: options.order,\n });\n return { items: response.networkLogs, hasMore: response.hasMore };\n },\n getTimestamp: (entry) => new Date(entry.timestamp).getTime(),\n targetCount:\n options.targetCount === \"all\"\n ? \"all\"\n : options.targetCount - firstResponse.networkLogs.length,\n initialSince: firstPageTimestamp,\n });\n\n allNetworkLogs = [...firstResponse.networkLogs, ...remainingLogs];\n\n // Trim to target count if needed\n if (\n options.targetCount !== \"all\" &&\n allNetworkLogs.length > options.targetCount\n ) {\n allNetworkLogs = allNetworkLogs.slice(0, options.targetCount);\n }\n }\n\n // Reverse for chronological display when using desc order (--tail)\n const networkLogs =\n options.order === \"desc\" ? [...allNetworkLogs].reverse() : allNetworkLogs;\n\n for (const entry of networkLogs) {\n console.log(formatNetworkLog(entry));\n }\n}\n","/**\n * Generic pagination utility for fetching items across multiple API pages.\n * Supports both limited pagination (fetch up to N items) and unlimited pagination (fetch all items).\n */\n\ninterface PaginateOptions<T> {\n /**\n * Function to fetch a single page of items.\n * @param since - Timestamp cursor for pagination (undefined for first page)\n * @returns Promise with items array and hasMore flag\n */\n fetchPage: (since?: number) => Promise<{ items: T[]; hasMore: boolean }>;\n\n /**\n * Function to extract timestamp from an item for cursor-based pagination.\n * @param item - The item to extract timestamp from\n * @returns Timestamp in milliseconds\n */\n getTimestamp: (item: T) => number;\n\n /**\n * Target number of items to collect, or \"all\" for unlimited.\n */\n targetCount: number | \"all\";\n\n /**\n * Initial since timestamp (optional, used when --since flag is provided).\n */\n initialSince?: number;\n}\n\n/**\n * Paginate through API responses, collecting items until target count is reached\n * or no more items are available.\n *\n * @param options - Pagination configuration\n * @returns Promise resolving to array of collected items\n * @throws Error if any page fetch fails (no partial results)\n */\nexport async function paginate<T>(options: PaginateOptions<T>): Promise<T[]> {\n const { fetchPage, getTimestamp, targetCount, initialSince } = options;\n\n const collected: T[] = [];\n let since = initialSince;\n let hasMore = true;\n\n while (hasMore) {\n const response = await fetchPage(since);\n\n // Append items to collection\n collected.push(...response.items);\n hasMore = response.hasMore;\n\n // Check if we've reached target count\n if (targetCount !== \"all\" && collected.length >= targetCount) {\n // Trim to exact target count and stop\n return collected.slice(0, targetCount);\n }\n\n // Update cursor for next page\n if (response.items.length > 0) {\n const lastItem = response.items[response.items.length - 1]!;\n since = getTimestamp(lastItem);\n } else {\n // No items returned, stop pagination\n hasMore = false;\n }\n }\n\n return collected;\n}\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport {\n searchLogs,\n type RunEvent,\n type LogsSearchResponse,\n} from \"../../lib/api\";\nimport { parseTime } from \"../../lib/utils/time-parser\";\nimport { ClaudeEventParser } from \"../../lib/events/claude-event-parser\";\nimport { EventRenderer } from \"../../lib/events/event-renderer\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nconst SEVEN_DAYS_MS = 7 * 24 * 60 * 60 * 1000;\n\ninterface SearchOptions {\n afterContext?: string;\n beforeContext?: string;\n context?: string;\n agent?: string;\n run?: string;\n since?: string;\n limit?: string;\n}\n\n/**\n * Render a single agent event using EventRenderer\n */\nfunction renderEvent(event: RunEvent, renderer: EventRenderer): void {\n const eventData = event.eventData as Record<string, unknown>;\n const parsed = ClaudeEventParser.parse(eventData);\n if (parsed) {\n parsed.timestamp = new Date(event.createdAt);\n renderer.render(parsed);\n }\n}\n\n/**\n * Format a run header line\n */\nfunction formatRunHeader(\n runId: string,\n agentName: string,\n timestamp: string,\n): string {\n const shortId = runId.slice(0, 8);\n const time = new Date(timestamp).toISOString().replace(/\\.\\d{3}Z$/, \"Z\");\n return `── Run ${shortId} (${agentName}, ${time}) ──────────`;\n}\n\n/**\n * Parse and validate context options (-A, -B, -C)\n */\nfunction parseContextOptions(options: SearchOptions): {\n before: number;\n after: number;\n} {\n const contextN = options.context ? parseInt(options.context, 10) : 0;\n const before = options.beforeContext\n ? parseInt(options.beforeContext, 10)\n : contextN;\n const after = options.afterContext\n ? parseInt(options.afterContext, 10)\n : contextN;\n\n if (isNaN(before) || before < 0 || before > 10) {\n throw new Error(\"--before-context must be between 0 and 10\");\n }\n if (isNaN(after) || after < 0 || after > 10) {\n throw new Error(\"--after-context must be between 0 and 10\");\n }\n\n return { before, after };\n}\n\n/**\n * Parse --limit option with validation\n */\nfunction parseLimit(value: string | undefined): number | undefined {\n if (!value) return undefined;\n const limit = parseInt(value, 10);\n if (isNaN(limit) || limit < 1 || limit > 50) {\n throw new Error(\"--limit must be between 1 and 50\");\n }\n return limit;\n}\n\n/**\n * Render search results grouped by run\n */\nfunction renderResults(response: LogsSearchResponse): void {\n // Group results by run\n const grouped = new Map<\n string,\n { agentName: string; results: LogsSearchResponse[\"results\"] }\n >();\n for (const result of response.results) {\n const existing = grouped.get(result.runId);\n if (existing) {\n existing.results.push(result);\n } else {\n grouped.set(result.runId, {\n agentName: result.agentName,\n results: [result],\n });\n }\n }\n\n // Render each group\n let isFirstGroup = true;\n for (const [runId, group] of grouped) {\n if (!isFirstGroup) {\n console.log(); // Separator between runs\n }\n isFirstGroup = false;\n\n const firstTimestamp = group.results[0]!.matchedEvent.createdAt;\n console.log(\n chalk.bold(formatRunHeader(runId, group.agentName, firstTimestamp)),\n );\n\n for (const result of group.results) {\n const renderer = new EventRenderer({\n showTimestamp: true,\n verbose: false,\n buffered: false,\n });\n\n for (const event of result.contextBefore) {\n renderEvent(event, renderer);\n }\n renderEvent(result.matchedEvent, renderer);\n for (const event of result.contextAfter) {\n renderEvent(event, renderer);\n }\n }\n }\n\n if (response.hasMore) {\n console.log();\n console.log(\n chalk.dim(\n ` Showing first ${response.results.length} matches. Use --limit to see more.`,\n ),\n );\n }\n}\n\nexport const searchCommand = new Command()\n .name(\"search\")\n .description(\"Search agent events across runs\")\n .argument(\"<keyword>\", \"Search keyword\")\n .option(\"-A, --after-context <n>\", \"Show n events after each match\")\n .option(\"-B, --before-context <n>\", \"Show n events before each match\")\n .option(\"-C, --context <n>\", \"Show n events before and after each match\")\n .option(\"--agent <name>\", \"Filter by agent name\")\n .option(\"--run <id>\", \"Filter by specific run ID\")\n .option(\"--since <time>\", \"Search logs since (default: 7d)\")\n .option(\"--limit <n>\", \"Maximum number of matches (default: 20)\")\n .action(\n withErrorHandler(async (keyword: string, options: SearchOptions) => {\n const { before, after } = parseContextOptions(options);\n const since = options.since\n ? parseTime(options.since)\n : Date.now() - SEVEN_DAYS_MS;\n const limit = parseLimit(options.limit);\n\n const response = await searchLogs({\n keyword,\n agent: options.agent,\n runId: options.run,\n since,\n limit,\n before,\n after,\n });\n\n if (response.results.length === 0) {\n console.log(chalk.dim(\"No matches found\"));\n console.log(\n chalk.dim(\n \" Try a broader search with --since 30d or a different keyword\",\n ),\n );\n return;\n }\n\n renderResults(response);\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport path from \"path\";\nimport { existsSync } from \"fs\";\nimport { writeFile } from \"fs/promises\";\nimport { validateAgentName } from \"../../lib/domain/yaml-validator\";\nimport { promptText, isInteractive } from \"../../lib/utils/prompt-utils\";\nimport { withErrorHandler } from \"../../lib/command\";\n\nconst VM0_YAML_FILE = \"vm0.yaml\";\nconst AGENTS_MD_FILE = \"AGENTS.md\";\n\nfunction generateVm0Yaml(agentName: string): string {\n return `version: \"1.0\"\n\nagents:\n ${agentName}:\n framework: claude-code\n # Build agentic workflow using natural language\n instructions: AGENTS.md\n # Agent skills - see https://github.com/vm0-ai/vm0-skills for available skills\n # skills:\n # - https://github.com/vm0-ai/vm0-skills/tree/main/github\n`;\n}\n\nfunction generateAgentsMd(): string {\n return `# Agent Instructions\n\nYou are a HackerNews AI content curator.\n\n## Workflow\n\n1. Go to HackerNews and read the top 10 articles\n2. Find and extract AI-related content from these articles\n3. Summarize the findings into a X (Twitter) post format\n4. Write the summary to content.md\n`;\n}\n\nfunction checkExistingFiles(): string[] {\n const existingFiles: string[] = [];\n if (existsSync(VM0_YAML_FILE)) existingFiles.push(VM0_YAML_FILE);\n if (existsSync(AGENTS_MD_FILE)) existingFiles.push(AGENTS_MD_FILE);\n return existingFiles;\n}\n\nexport const initCommand = new Command()\n .name(\"init\")\n .description(\"Initialize a new VM0 project in the current directory\")\n .option(\"-f, --force\", \"Overwrite existing files\")\n .option(\"-n, --name <name>\", \"Agent name (required in non-interactive mode)\")\n .action(\n withErrorHandler(async (options: { force?: boolean; name?: string }) => {\n // Check existing files\n const existingFiles = checkExistingFiles();\n if (existingFiles.length > 0 && !options.force) {\n throw new Error(`${existingFiles.join(\", \")} already exists`, {\n cause: new Error(\"To overwrite: vm0 init --force\"),\n });\n }\n\n // Get agent name from option or prompt\n let agentName: string;\n if (options.name) {\n agentName = options.name.trim();\n } else if (!isInteractive()) {\n throw new Error(\"--name flag is required in non-interactive mode\", {\n cause: new Error(\"Usage: vm0 init --name <agent-name>\"),\n });\n } else {\n // Use directory name as default suggestion\n const dirName = path.basename(process.cwd());\n const defaultName = validateAgentName(dirName) ? dirName : undefined;\n\n const name = await promptText(\n \"Enter agent name\",\n defaultName,\n (value: string) => {\n if (!validateAgentName(value)) {\n return \"Must be 3-64 characters, alphanumeric and hyphens, start/end with letter or number\";\n }\n return true;\n },\n );\n\n if (name === undefined) {\n // User cancelled\n console.log(chalk.dim(\"Cancelled\"));\n return;\n }\n\n agentName = name;\n }\n\n // Validate agent name\n if (!agentName || !validateAgentName(agentName)) {\n throw new Error(\"Invalid agent name\", {\n cause: new Error(\n \"Must be 3-64 characters, alphanumeric and hyphens only, start and end with letter or number\",\n ),\n });\n }\n\n // Write vm0.yaml\n await writeFile(VM0_YAML_FILE, generateVm0Yaml(agentName));\n const vm0Status = existingFiles.includes(VM0_YAML_FILE)\n ? \" (overwritten)\"\n : \"\";\n console.log(chalk.green(`✓ Created ${VM0_YAML_FILE}${vm0Status}`));\n\n // Write AGENTS.md\n await writeFile(AGENTS_MD_FILE, generateAgentsMd());\n const agentsStatus = existingFiles.includes(AGENTS_MD_FILE)\n ? \" (overwritten)\"\n : \"\";\n console.log(chalk.green(`✓ Created ${AGENTS_MD_FILE}${agentsStatus}`));\n\n // Print next steps\n console.log();\n console.log(\"Next steps:\");\n console.log(\n ` 1. Set up model provider (one-time): ${chalk.cyan(\"zero org model-provider setup\")}`,\n );\n console.log(\n ` 2. Edit ${chalk.cyan(\"AGENTS.md\")} to customize your agent's workflow`,\n );\n console.log(\n ` 3. Run your agent: ${chalk.cyan('vm0 cook \"let\\'s start working\"')}`,\n );\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport {\n detectPackageManager,\n getLatestVersion,\n getManualUpgradeCommand,\n isAutoUpgradeSupported,\n performUpgrade,\n} from \"../../lib/utils/update-checker\";\nimport { withErrorHandler } from \"../../lib/command\";\n\ndeclare const __CLI_VERSION__: string;\n\nexport const upgradeCommand = new Command()\n .name(\"upgrade\")\n .description(\"Upgrade vm0 CLI to the latest version\")\n .action(\n withErrorHandler(async () => {\n console.log(\"Checking for updates...\");\n\n const latestVersion = await getLatestVersion();\n\n if (latestVersion === null) {\n throw new Error(\"Could not check for updates. Please try again later.\");\n }\n\n if (latestVersion === __CLI_VERSION__) {\n console.log(chalk.green(`✓ Already up to date (${__CLI_VERSION__})`));\n return;\n }\n\n console.log(\n chalk.yellow(\n `Current version: ${__CLI_VERSION__} -> Latest version: ${latestVersion}`,\n ),\n );\n console.log();\n\n const packageManager = detectPackageManager();\n\n if (!isAutoUpgradeSupported(packageManager)) {\n if (packageManager === \"unknown\") {\n console.log(\n chalk.yellow(\n \"Could not detect your package manager for auto-upgrade.\",\n ),\n );\n } else {\n console.log(\n chalk.yellow(\n `Auto-upgrade is not supported for ${packageManager}.`,\n ),\n );\n }\n console.log(chalk.yellow(\"Please upgrade manually:\"));\n console.log(chalk.cyan(` ${getManualUpgradeCommand(packageManager)}`));\n return;\n }\n\n console.log(`Upgrading via ${packageManager}...`);\n const success = await performUpgrade(packageManager);\n\n if (success) {\n console.log(\n chalk.green(`✓ Upgraded from ${__CLI_VERSION__} to ${latestVersion}`),\n );\n return;\n }\n\n throw new Error(\"Upgrade failed\", {\n cause: new Error(\n `Please run manually: ${getManualUpgradeCommand(packageManager)}`,\n ),\n });\n }),\n );\n","import { Command } from \"commander\";\nimport chalk from \"chalk\";\nimport { getApiUrl, getActiveOrg, getToken } from \"../lib/api/config\";\nimport { withErrorHandler } from \"../lib/command\";\n\n/**\n * Detect if running inside a VM0 sandbox (agent runtime).\n * Presence of VM0_RUN_ID indicates sandbox execution.\n */\nfunction isInsideSandbox(): boolean {\n return !!process.env.VM0_RUN_ID;\n}\n\n/**\n * Display agent identity and run information when inside a sandbox.\n */\nasync function showSandboxInfo(): Promise<void> {\n const agentId = process.env.ZERO_AGENT_ID;\n const cliAgentType = process.env.CLI_AGENT_TYPE;\n\n const runId = process.env.VM0_RUN_ID;\n const activeOrg = await getActiveOrg();\n const apiUrl = process.env.VM0_API_URL;\n\n // Agent section\n const hasAgentInfo = agentId || cliAgentType;\n if (hasAgentInfo) {\n console.log(chalk.bold(\"Agent:\"));\n if (agentId) console.log(` ID: ${agentId}`);\n if (cliAgentType) console.log(` Framework: ${cliAgentType}`);\n console.log();\n }\n\n // Run section\n console.log(chalk.bold(\"Run:\"));\n if (runId) console.log(` ID: ${runId}`);\n if (activeOrg) console.log(` Org: ${activeOrg}`);\n if (apiUrl) console.log(` API: ${apiUrl}`);\n}\n\n/**\n * Display authentication and org information when running outside a sandbox.\n */\nasync function showLocalInfo(): Promise<void> {\n const token = await getToken();\n const apiUrl = await getApiUrl();\n const activeOrg = await getActiveOrg();\n\n // Auth section\n console.log(chalk.bold(\"Auth:\"));\n if (token) {\n const tokenSource = process.env.VM0_TOKEN\n ? \"VM0_TOKEN env var\"\n : \"config file\";\n console.log(\n ` Status: ${chalk.green(\"Authenticated\")} (via ${tokenSource})`,\n );\n } else {\n console.log(` Status: ${chalk.dim(\"Not authenticated\")}`);\n }\n console.log(` API: ${apiUrl}`);\n console.log();\n\n // Org section\n if (activeOrg) {\n console.log(chalk.bold(\"Org:\"));\n console.log(` Active: ${activeOrg}`);\n }\n}\n\nexport const whoamiCommand = new Command()\n .name(\"whoami\")\n .description(\"Show current identity and environment information\")\n .action(\n withErrorHandler(async () => {\n if (isInsideSandbox()) {\n await showSandboxInfo();\n } else {\n await showLocalInfo();\n }\n }),\n );\n"],"mappings":"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","names":["Command","Command","Command","Command","Command","Command","Command","Command","Command","Command","chalk","chalk","chalk","Command","chalk","Command","chalk","readFile","rm","existsSync","dirname","join","path","fs","path","parseGitHubTreeUrl","getSkillStorageName","fs","path","os","fs","path","os","tar","fs","path","text","commitResult","parseGitHubTreeUrl","getSkillStorageName","existsSync","readFile","dirname","chalk","parseGitHubTreeUrl","join","rm","Command","Command","Option","Command","Option","Command","Option","Command","Option","Command","Option","Command","Option","Command","chalk","chalk","Command","Command","chalk","Command","chalk","Command","chalk","Command","chalk","Command","Command","chalk","path","readFile","writeFile","mkdir","existsSync","parseYaml","path","type","Command","path","chalk","Command","chalk","Command","chalk","Command","chalk","path","fs","os","tar","chalk","chalk","Command","chalk","path","Command","chalk","statusCommand","Command","chalk","Command","chalk","listCommand","Command","chalk","Command","chalk","chalk","path","fs","os","tar","type","chalk","path","Command","chalk","Command","statusCommand","listCommand","Command","Command","chalk","path","initCommand","Command","path","chalk","Command","chalk","pushCommand","Command","chalk","Command","chalk","path","fs","os","tar","pullCommand","Command","chalk","path","Command","chalk","statusCommand","Command","chalk","Command","chalk","listCommand","Command","chalk","Command","chalk","cloneCommand","Command","chalk","Command","initCommand","pushCommand","pullCommand","statusCommand","listCommand","cloneCommand","Command","Command","chalk","path","initCommand","Command","path","chalk","Command","chalk","pushCommand","Command","chalk","Command","chalk","pullCommand","Command","chalk","Command","chalk","statusCommand","Command","chalk","Command","chalk","listCommand","Command","chalk","Command","chalk","cloneCommand","Command","chalk","Command","initCommand","pushCommand","pullCommand","statusCommand","listCommand","cloneCommand","Command","Option","chalk","readFile","mkdir","existsSync","path","parseYaml","homedir","join","readFile","writeFile","mkdir","existsSync","CONFIG_DIR","chalk","existsSync","CONFIG_FILE","chalk","existsSync","loadAndValidateConfig","chalk","CONFIG_FILE","existsSync","readFile","parseYaml","path","mkdir","Command","Option","Command","Command","Command","Option","path","continueCommand","Command","Option","path","Command","Option","path","resumeCommand","Command","Option","path","continueCommand","resumeCommand","Command","chalk","Command","chalk","parseLimit","chalk","Command","chalk","logsCommand","Command","Command","chalk","path","existsSync","writeFile","existsSync","initCommand","Command","path","chalk","writeFile","Command","chalk","Command","chalk","Command","chalk","chalk","Command","Command","logsCommand","initCommand"]}
|