adhdev 0.1.53 → 0.2.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli-entrypoint.js +12020 -0
- package/dist/cli-entrypoint.js.map +1 -0
- package/dist/index.js +9789 -9864
- package/dist/index.js.map +1 -0
- package/package.json +19 -16
- package/providers/_builtin/CONTRIBUTING.md +141 -0
- package/providers/_builtin/README.md +51 -0
- package/providers/_builtin/acp/agentpool/provider.json +47 -0
- package/providers/_builtin/acp/amp/provider.json +45 -0
- package/providers/_builtin/acp/auggie/provider.json +50 -0
- package/providers/_builtin/acp/autodev/provider.json +47 -0
- package/providers/_builtin/acp/autohand/provider.json +45 -0
- package/providers/_builtin/acp/blackbox-ai/provider.json +47 -0
- package/providers/_builtin/acp/claude-agent/provider.json +50 -0
- package/providers/_builtin/acp/cline-acp/provider.json +47 -0
- package/providers/_builtin/acp/code-assistant/provider.json +47 -0
- package/providers/_builtin/acp/codebuddy/provider.json +47 -0
- package/providers/_builtin/acp/codex-cli/provider.json +50 -0
- package/providers/_builtin/acp/corust-agent/provider.json +45 -0
- package/providers/_builtin/acp/crow-cli/provider.json +47 -0
- package/providers/_builtin/acp/cursor-acp/provider.json +47 -0
- package/providers/_builtin/acp/deepagents/provider.json +45 -0
- package/providers/_builtin/acp/dimcode/provider.json +47 -0
- package/providers/_builtin/acp/docker-cagent/provider.json +50 -0
- package/providers/_builtin/acp/factory-droid/provider.json +53 -0
- package/providers/_builtin/acp/fast-agent/provider.json +45 -0
- package/providers/_builtin/acp/fount/provider.json +47 -0
- package/providers/_builtin/acp/gemini-cli/provider.json +107 -0
- package/providers/_builtin/acp/github-copilot/provider.json +47 -0
- package/providers/_builtin/acp/goose/provider.json +50 -0
- package/providers/_builtin/acp/junie/provider.json +45 -0
- package/providers/_builtin/acp/kilo/provider.json +45 -0
- package/providers/_builtin/acp/kimi-cli/provider.json +50 -0
- package/providers/_builtin/acp/kiro-cli/provider.json +47 -0
- package/providers/_builtin/acp/minion-code/provider.json +45 -0
- package/providers/_builtin/acp/mistral-vibe/provider.json +50 -0
- package/providers/_builtin/acp/nova/provider.json +47 -0
- package/providers/_builtin/acp/openclaw/provider.json +47 -0
- package/providers/_builtin/acp/opencode/provider.json +45 -0
- package/providers/_builtin/acp/openhands/provider.json +47 -0
- package/providers/_builtin/acp/pi-acp/provider.json +45 -0
- package/providers/_builtin/acp/qoder/provider.json +47 -0
- package/providers/_builtin/acp/qwen-code/provider.json +53 -0
- package/providers/_builtin/acp/stakpak/provider.json +47 -0
- package/providers/_builtin/acp/vtcode/provider.json +47 -0
- package/providers/_builtin/cli/claude-cli/provider.json +78 -0
- package/providers/_builtin/cli/codex-cli/provider.json +60 -0
- package/providers/_builtin/cli/gemini-cli/provider.json +64 -0
- package/providers/_builtin/extension/cline/provider.json +11 -0
- package/providers/_builtin/extension/cline/scripts/open_panel.js +1 -1
- package/providers/_builtin/extension/cline/{provider.js → scripts.js} +29 -55
- package/providers/_builtin/extension/roo-code/provider.json +11 -0
- package/providers/_builtin/extension/roo-code/{provider.js → scripts.js} +27 -97
- package/providers/_builtin/ide/antigravity/provider.json +32 -0
- package/providers/_builtin/ide/antigravity/scripts.js +73 -0
- package/providers/_builtin/ide/cursor/provider.json +35 -0
- package/providers/_builtin/ide/cursor/{provider.js → scripts.js} +31 -69
- package/providers/_builtin/ide/kiro/provider.json +36 -0
- package/providers/_builtin/ide/kiro/scripts/webview_send_message.js +72 -0
- package/providers/_builtin/ide/kiro/scripts.js +62 -0
- package/providers/_builtin/ide/pearai/provider.json +36 -0
- package/providers/_builtin/ide/pearai/scripts/list_sessions.js +38 -0
- package/providers/_builtin/ide/pearai/scripts/new_session.js +55 -0
- package/providers/_builtin/ide/pearai/scripts/webview_list_sessions.js +62 -0
- package/providers/_builtin/ide/pearai/scripts/webview_new_session.js +32 -4
- package/providers/_builtin/ide/pearai/scripts/webview_send_message.js +72 -0
- package/providers/_builtin/ide/pearai/scripts/webview_switch_session.js +34 -0
- package/providers/_builtin/ide/pearai/scripts.js +74 -0
- package/providers/_builtin/ide/trae/provider.json +35 -0
- package/providers/_builtin/ide/trae/scripts/send_message.js +53 -3
- package/providers/_builtin/ide/trae/scripts.js +57 -0
- package/providers/_builtin/ide/vscode/provider.json +33 -0
- package/providers/_builtin/ide/vscode-insiders/provider.json +31 -0
- package/providers/_builtin/ide/vscodium/provider.json +32 -0
- package/providers/_builtin/ide/windsurf/provider.json +22 -0
- package/providers/_builtin/ide/windsurf/scripts.js +57 -0
- package/providers/_builtin/validate.js +156 -0
- package/README.md +0 -43
- package/dist/dev-console-monaco.js +0 -176
- package/dist/dev-console.css +0 -326
- package/dist/dev-console.html +0 -148
- package/dist/dev-console.js +0 -1165
- package/dist/index.d.ts +0 -2
- package/dist/node_datachannel-LPY6EJH5.node +0 -0
- package/providers/_builtin/acp/codex-cli/provider.js +0 -54
- package/providers/_builtin/acp/goose/provider.js +0 -32
- package/providers/_builtin/acp/opencode/provider.js +0 -32
- package/providers/_builtin/cli/claude-cli/provider.js +0 -125
- package/providers/_builtin/cli/codex-cli/provider.js +0 -77
- package/providers/_builtin/cli/gemini-cli/provider.js +0 -121
- package/providers/_builtin/ide/antigravity/provider.js +0 -114
- package/providers/_builtin/ide/cursor/provider.js.backup +0 -116
- package/providers/_builtin/ide/cursor/provider.js.bak +0 -127
- package/providers/_builtin/ide/cursor/scripts_backup/focus_editor.js +0 -20
- package/providers/_builtin/ide/cursor/scripts_backup/list_chats.js +0 -111
- package/providers/_builtin/ide/cursor/scripts_backup/new_session.js +0 -62
- package/providers/_builtin/ide/cursor/scripts_backup/open_panel.js +0 -31
- package/providers/_builtin/ide/cursor/scripts_backup/read_chat.js +0 -433
- package/providers/_builtin/ide/cursor/scripts_backup/resolve_action.js +0 -90
- package/providers/_builtin/ide/cursor/scripts_backup/send_message.js +0 -86
- package/providers/_builtin/ide/cursor/scripts_backup/switch_session.js +0 -63
- package/providers/_builtin/ide/kiro/provider.js +0 -86
- package/providers/_builtin/ide/pearai/provider.js +0 -88
- package/providers/_builtin/ide/trae/provider.js +0 -83
- package/providers/_builtin/ide/vscode/provider.js +0 -36
- package/providers/_builtin/ide/vscode-insiders/provider.js +0 -27
- package/providers/_builtin/ide/vscodium/provider.js +0 -27
- package/providers/_builtin/ide/windsurf/provider.js +0 -76
- /package/providers/{_helpers → _builtin/_helpers}/index.js +0 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../daemon-core/src/config.ts","../../daemon-core/src/index.ts","../../daemon-core/src/detector.ts","../../daemon-core/src/cli-detector.ts","../../daemon-core/src/daemon-cdp.ts","../../daemon-core/src/daemon-cdp-devtools.ts","../../daemon-core/src/daemon-commands.ts","../../daemon-core/src/chat-history.ts","../../daemon-core/src/daemon-status.ts","../../daemon-core/src/daemon-logger.ts","../../daemon-core/src/daemon-command-log.ts","../../daemon-core/src/daemon-cli.ts","../../daemon-core/src/cli-adapters/provider-cli-adapter.ts","../../daemon-core/src/providers/cli-provider-instance.ts","../../daemon-core/src/providers/status-monitor.ts","../../daemon-core/src/providers/acp-provider-instance.ts","../../daemon-core/src/launch.ts","../../daemon-core/src/providers/provider-loader.ts","../../daemon-core/src/ipc-protocol.ts","../../daemon-core/src/agent-stream/provider-adapter.ts","../../daemon-core/src/agent-stream/manager.ts","../../daemon-core/src/providers/provider-instance-manager.ts","../../daemon-core/src/providers/ide-provider-instance.ts","../../daemon-core/src/providers/extension-provider-instance.ts","../../daemon-core/src/daemon/dev-server.ts","../../daemon-core/src/daemon/scaffold-template.ts","../../daemon-core/src/installer.ts","../src/server-connection.ts","../src/daemon-p2p.ts","../src/adhdev-daemon.ts","../src/cli-entrypoint.ts","../src/wizard.ts"],"sourcesContent":["/**\n * ADHDev Launcher — Configuration\n * \n * Manages launcher config, server connection tokens, and user preferences.\n */\n\nimport { homedir } from 'os';\nimport { join } from 'path';\nimport { existsSync, mkdirSync, readFileSync, writeFileSync, chmodSync } from 'fs';\n\nexport interface ADHDevConfig {\n // Server connection\n serverUrl: string;\n apiToken: string | null;\n connectionToken: string | null;\n\n // Selected IDE (primary)\n selectedIde: string | null;\n\n // All configured IDEs (multiple)\n configuredIdes: string[];\n\n // Installed extensions\n installedExtensions: string[];\n\n // User preferences\n autoConnect: boolean;\n notifications: boolean;\n\n // Auth\n userEmail: string | null;\n userName: string | null;\n\n // Setup state\n setupCompleted: boolean;\n setupDate: string | null;\n\n // Configured CLI agents\n configuredCLIs: string[];\n\n // Daemon: which IDEs to connect (empty = all)\n enabledIdes: string[];\n recentCliWorkspaces: string[];\n\n // Machine nickname (user-customizable label for this machine)\n machineNickname: string | null;\n\n // CLI launch history\n cliHistory: CliHistoryEntry[];\n\n // Per-provider user config (public setting values)\n providerSettings: Record<string, Record<string, any>>;\n\n // Per-IDE extension config (per-IDE on/off control)\n ideSettings: Record<string, {\n extensions?: Record<string, { enabled: boolean }>;\n }>;\n}\n\nexport interface CliHistoryEntry {\n cliType: string;\n dir: string;\n cliArgs?: string[];\n timestamp: number;\n label?: string;\n}\n\nconst DEFAULT_CONFIG: ADHDevConfig = {\n serverUrl: 'https://api.adhf.dev',\n apiToken: null,\n connectionToken: null,\n selectedIde: null,\n configuredIdes: [],\n installedExtensions: [],\n autoConnect: true,\n notifications: true,\n userEmail: null,\n userName: null,\n setupCompleted: false,\n setupDate: null,\n configuredCLIs: [],\n enabledIdes: [],\n recentCliWorkspaces: [],\n machineNickname: null,\n cliHistory: [],\n providerSettings: {},\n ideSettings: {},\n};\n\n/**\n * Get the config directory path\n */\nexport function getConfigDir(): string {\n const dir = join(homedir(), '.adhdev');\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true });\n }\n return dir;\n}\n\n/**\n * Get the config file path\n */\nfunction getConfigPath(): string {\n return join(getConfigDir(), 'config.json');\n}\n\n/**\n * Load configuration from disk\n */\nexport function loadConfig(): ADHDevConfig {\n const configPath = getConfigPath();\n\n if (!existsSync(configPath)) {\n return { ...DEFAULT_CONFIG };\n }\n\n try {\n const raw = readFileSync(configPath, 'utf-8');\n const parsed = JSON.parse(raw);\n return { ...DEFAULT_CONFIG, ...parsed };\n } catch {\n return { ...DEFAULT_CONFIG };\n }\n}\n\n/**\n * Save configuration to disk\n */\nexport function saveConfig(config: ADHDevConfig): void {\n const configPath = getConfigPath();\n const dir = getConfigDir();\n\n if (!existsSync(dir)) {\n mkdirSync(dir, { recursive: true, mode: 0o700 });\n }\n\n writeFileSync(configPath, JSON.stringify(config, null, 2), { encoding: 'utf-8', mode: 0o600 });\n try { chmodSync(configPath, 0o600); } catch { /* Windows etc. not supported */ }\n}\n\n/**\n * Update specific config fields\n */\nexport function updateConfig(updates: Partial<ADHDevConfig>): ADHDevConfig {\n const config = loadConfig();\n const updated = { ...config, ...updates };\n saveConfig(updated);\n return updated;\n}\n\n/**\n * Mark setup as completed\n */\nexport function markSetupComplete(\n ideId: string | string[],\n extensions: string[]\n): ADHDevConfig {\n const ideIds = Array.isArray(ideId) ? ideId : [ideId];\n return updateConfig({\n selectedIde: ideIds[0],\n configuredIdes: ideIds,\n installedExtensions: extensions,\n setupCompleted: true,\n setupDate: new Date().toISOString(),\n });\n}\n\n/**\n * Check if setup has been completed before\n */\nexport function isSetupComplete(): boolean {\n const config = loadConfig();\n return config.setupCompleted;\n}\n\n/**\n * Reset configuration\n */\nexport function resetConfig(): void {\n saveConfig({ ...DEFAULT_CONFIG });\n}\n\n/**\n * Generate a connection token for server authentication\n */\nexport function generateConnectionToken(): string {\n const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';\n let token = 'db_';\n for (let i = 0; i < 32; i++) {\n token += chars.charAt(Math.floor(Math.random() * chars.length));\n }\n return token;\n}\n/**\n * Add CLI launch to history (max 20, dedup by cliType+dir+args)\n */\nexport function addCliHistory(entry: Omit<CliHistoryEntry, 'timestamp'>): void {\n const config = loadConfig();\n const history = config.cliHistory || [];\n const argsKey = (entry.cliArgs || []).join(' ');\n \n // Remove duplicate (same cliType + dir + args)\n const filtered = history.filter(h => {\n const hArgsKey = (h.cliArgs || []).join(' ');\n return !(h.cliType === entry.cliType && h.dir === entry.dir && hArgsKey === argsKey);\n });\n \n // Add to front\n filtered.unshift({\n ...entry,\n timestamp: Date.now(),\n label: entry.label || `${entry.cliType} · ${entry.dir.split('/').filter(Boolean).pop() || 'root'}${argsKey ? ` (${argsKey})` : ''}`,\n });\n \n // Keep max 20\n config.cliHistory = filtered.slice(0, 20);\n saveConfig(config);\n}\n","/**\n * @adhdev/daemon-core — Public API\n *\n * Core logic for daemon: CDP, Provider, IDE detection, CLI/ACP adapters and more.\n * Used by both daemon-standalone and daemon-cloud.\n */\n\n// ── Types ──\nexport type {\n DaemonStatus,\n IdeEntry,\n CliEntry,\n AcpEntry,\n ChatMessage,\n ExtensionInfo,\n CommandResult as CoreCommandResult,\n ProviderConfig,\n DaemonEvent,\n StatusResponse,\n SystemInfo,\n DetectedIde,\n ProviderInfo,\n AgentStreamEntry,\n AgentEntry,\n} from './types.js';\n\n// ── Core Interface ──\nexport type { IDaemonCore, DaemonCoreOptions } from './daemon-core.js';\n\n// ── Config ──\nexport { loadConfig, saveConfig, resetConfig, isSetupComplete, addCliHistory, markSetupComplete, updateConfig } from './config.js';\n\n// ── Detection ──\nexport { detectIDEs } from './detector.js';\nexport type { IDEInfo } from './detector.js';\nexport { detectCLIs } from './cli-detector.js';\n\n// ── CDP ──\nexport { DaemonCdpManager } from './daemon-cdp.js';\nexport { CdpDomHandlers } from './daemon-cdp-devtools.js';\n\n// ── Commands ──\nexport { DaemonCommandHandler } from './daemon-commands.js';\nexport type { CommandResult, CommandContext } from './daemon-commands.js';\n\n// ── Status ──\nexport { DaemonStatusReporter } from './daemon-status.js';\n\n// ── Logger ──\nexport { LOG, installGlobalInterceptor } from './daemon-logger.js';\nexport { logCommand, getRecentCommands } from './daemon-command-log.js';\n\n// ── CLI Management ──\nexport { DaemonCliManager } from './daemon-cli.js';\n\n// ── Launch ──\nexport { launchWithCdp, getAvailableIdeIds } from './launch.js';\n\n// ── IPC ──\nexport { DEFAULT_DAEMON_PORT, DAEMON_WS_PATH } from './ipc-protocol.js';\n\n// ── Chat History ──\nexport { readChatHistory } from './chat-history.js';\n\n// ── Agent Stream ──\nexport { DaemonAgentStreamManager } from './agent-stream/index.js';\n\n// ── Providers ──\nexport { ProviderLoader } from './providers/provider-loader.js';\nexport { ProviderInstanceManager } from './providers/provider-instance-manager.js';\nexport { IdeProviderInstance } from './providers/ide-provider-instance.js';\nexport { CliProviderInstance } from './providers/cli-provider-instance.js';\nexport { AcpProviderInstance } from './providers/acp-provider-instance.js';\nexport type { ProviderModule } from './providers/contracts.js';\n\n// ── Dev Server ──\nexport { DevServer } from './daemon/dev-server.js';\n\n// ── CLI Adapters ──\nexport { ProviderCliAdapter } from './cli-adapters/provider-cli-adapter.js';\nexport type { CliAdapter } from './cli-adapter-types.js';\n\n// ── Installer ──\nexport { getAIExtensions, installExtensions, launchIDE, isExtensionInstalled } from './installer.js';\nexport type { ExtensionInfo as InstallerExtensionInfo } from './installer.js';\n\n","/**\n * ADHDev — IDE Detector (canonical implementation)\n * \n * Detects installed IDEs on the user's local machine.\n * Supports macOS, Windows, and Linux.\n * \n * Migrated from @adhdev/core — this is now the single source of truth.\n */\n\nimport { execSync } from 'child_process';\nimport { existsSync } from 'fs';\nimport { platform, homedir } from 'os';\n\n// ─── Types ──────────────────────────────────────\n\nexport interface IDEInfo {\n id: string;\n name: string;\n displayName: string;\n installed: boolean;\n path: string | null;\n cliCommand: string | null;\n version: string | null;\n icon: string;\n extensionSupport: 'full' | 'partial' | 'none';\n notes?: string;\n}\n\nexport interface IDEDefinition {\n id: string;\n name: string;\n displayName: string;\n icon: string;\n extensionSupport: 'full' | 'partial' | 'none';\n cli: string;\n paths: {\n darwin?: string[];\n win32?: string[];\n linux?: string[];\n [key: string]: string[] | undefined;\n };\n}\n\n// No builtin IDE definitions — provider.js registered via registerToDetector() is the single source of truth\n// To add new IDE: create providers/_builtin/ide/{name}/provider.js then define paths/cli\nconst BUILTIN_IDE_DEFINITIONS: IDEDefinition[] = [];\n\n// ─── Runtime Registry ───────────────────────────\nconst registeredIDEs = new Map<string, IDEDefinition>();\n\nexport function registerIDEDefinition(def: IDEDefinition): void {\n registeredIDEs.set(def.id, def);\n}\n\nfunction getMergedDefinitions(): IDEDefinition[] {\n const merged = new Map<string, IDEDefinition>();\n for (const def of BUILTIN_IDE_DEFINITIONS) {\n merged.set(def.id, def);\n }\n for (const [id, def] of registeredIDEs) {\n merged.set(id, def);\n }\n return [...merged.values()];\n}\n\nfunction findCliCommand(command: string): string | null {\n try {\n const result = execSync(\n platform() === 'win32' ? `where ${command}` : `which ${command}`,\n { encoding: 'utf-8', timeout: 5000, stdio: ['pipe', 'pipe', 'pipe'] }\n ).trim();\n return result.split('\\n')[0] || null;\n } catch {\n return null;\n }\n}\n\nfunction getIdeVersion(cliCommand: string): string | null {\n try {\n const result = execSync(`\"${cliCommand}\" --version`, {\n encoding: 'utf-8',\n timeout: 10000,\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n return result.split('\\n')[0] || null;\n } catch {\n return null;\n }\n}\n\nfunction checkPathExists(paths: string[]): string | null {\n for (const p of paths) {\n if (p.includes('*')) {\n const home = homedir();\n const starIdx = p.indexOf('*');\n const suffix = p.substring(starIdx + 1);\n const homeNormalized = home.replace(/\\//g, '\\\\\\\\');\n const resolved = homeNormalized + suffix;\n if (existsSync(resolved)) return resolved;\n } else {\n if (existsSync(p)) return p;\n }\n }\n return null;\n}\n\nexport async function detectIDEs(): Promise<IDEInfo[]> {\n const os = platform() as 'darwin' | 'win32' | 'linux';\n const results: IDEInfo[] = [];\n\n for (const def of getMergedDefinitions()) {\n const cliPath = findCliCommand(def.cli);\n const appPath = checkPathExists(def.paths[os] || []);\n const installed = !!(cliPath || appPath);\n\n let resolvedCli = cliPath;\n\n if (!resolvedCli && appPath && os === 'darwin') {\n const bundledCli = `${appPath}/Contents/Resources/app/bin/${def.cli}`;\n if (existsSync(bundledCli)) resolvedCli = bundledCli;\n }\n\n if (!resolvedCli && appPath && os === 'win32') {\n const { dirname } = await import('path');\n const appDir = dirname(appPath);\n const candidates = [\n `${appDir}\\\\\\\\bin\\\\\\\\${def.cli}.cmd`,\n `${appDir}\\\\\\\\bin\\\\\\\\${def.cli}`,\n `${appDir}\\\\\\\\${def.cli}.cmd`,\n `${appDir}\\\\\\\\${def.cli}.exe`,\n `${appDir}\\\\\\\\resources\\\\\\\\app\\\\\\\\bin\\\\\\\\${def.cli}.cmd`,\n ];\n for (const c of candidates) {\n if (existsSync(c)) {\n resolvedCli = c;\n break;\n }\n }\n }\n\n const version = resolvedCli ? getIdeVersion(resolvedCli) : null;\n\n results.push({\n id: def.id,\n name: def.name,\n displayName: def.displayName,\n installed,\n path: appPath || cliPath,\n cliCommand: resolvedCli || null,\n version,\n icon: def.icon,\n extensionSupport: def.extensionSupport,\n });\n }\n\n return results;\n}\n","/**\n * CLI AI Agent Detector\n * \n * Dynamic CLI detection based on Provider.\n * Reads spawn.command from cli/acp categories via ProviderLoader to check installation.\n * \n * Fallback: works with default CLI list without ProviderLoader (backward compatible).\n */\n\nimport { execSync } from 'child_process';\nimport * as os from 'os';\nimport type { ProviderLoader } from './providers/provider-loader.js';\n\nexport interface CLIInfo {\n id: string;\n displayName: string;\n icon: string;\n command: string;\n installed: boolean;\n version?: string;\n path?: string;\n}\n\n/**\n * all CLI/ACP agent detect\n * @param providerLoader ProviderLoader instance (dynamic list creation)\n */\nexport async function detectCLIs(providerLoader?: ProviderLoader): Promise<CLIInfo[]> {\n const platform = os.platform();\n const whichCmd = platform === 'win32' ? 'where' : 'which';\n\n // Provider-based dynamic list creation, fallback is empty array\n const cliList = providerLoader\n ? providerLoader.getCliDetectionList()\n : [];\n\n const results: CLIInfo[] = [];\n\n for (const cli of cliList) {\n try {\n const pathResult = execSync(`${whichCmd} ${cli.command} 2>/dev/null`, {\n encoding: 'utf-8',\n timeout: 5000,\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim().split('\\n')[0];\n\n if (!pathResult) throw new Error('Not found');\n\n let version: string | undefined;\n try {\n const versionResult = execSync(`${cli.command} --version 2>/dev/null`, {\n encoding: 'utf-8',\n timeout: 5000,\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n // Extract version number from first line (e.g. \"gemini v1.2.3\" → \"1.2.3\")\n const match = versionResult.match(/(\\d+\\.\\d+[\\.\\d]*)/);\n version = match ? match[1] : versionResult.split('\\n')[0].slice(0, 30);\n } catch { }\n\n results.push({ ...cli, installed: true, version, path: pathResult });\n } catch {\n results.push({ ...cli, installed: false });\n }\n }\n\n return results;\n}\n\n/** Detect specific CLI */\nexport async function detectCLI(cliId: string, providerLoader?: ProviderLoader): Promise<CLIInfo | null> {\n // Resolve alias\n const resolvedId = providerLoader ? providerLoader.resolveAlias(cliId) : cliId;\n const all = await detectCLIs(providerLoader);\n return all.find((c) => c.id === resolvedId && c.installed) || null;\n}\n","/**\n * CDP Manager for ADHDev Daemon\n * \n * Ported cdp.ts from Extension for Daemon use.\n * vscode dependencies removed — works in pure Node.js environment.\n * \n * Connects to IDE CDP port (9222, 9333 etc) to:\n * - Execute JS via Runtime.evaluate\n * - Agent webview iframe search & session connection\n * - DOM query\n */\n\nimport WebSocket from 'ws';\nimport * as http from 'http';\nimport * as fs from 'fs';\n\ninterface CdpTarget {\n id: string;\n type: string;\n title: string;\n url: string;\n webSocketDebuggerUrl: string;\n}\n\nexport interface AgentWebviewTarget {\n targetId: string;\n extensionId: string;\n agentType: string;\n url: string;\n}\n\n\nexport class DaemonCdpManager {\n private ws: WebSocket | null = null;\n private browserWs: WebSocket | null = null; // browser-level WS for Target discovery\n private browserMsgId = 10000;\n private browserPending = new Map<number, {\n resolve: (v: any) => void;\n reject: (e: Error) => void;\n }>();\n private msgId = 1;\n private pending = new Map<number, {\n resolve: (v: any) => void;\n reject: (e: Error) => void;\n }>();\n private port: number;\n private _connected = false;\n private _browserConnected = false;\n private targetUrl = '';\n private reconnectTimer: ReturnType<typeof setTimeout> | null = null;\n private contexts = new Set<number>();\n private connectPromise: Promise<boolean> | null = null;\n private failureCount = 0;\n private readonly MAX_FAILURES = 5;\n private agentSessions = new Map<string, AgentWebviewTarget>();\n private logFn: (msg: string) => void;\n private extensionProviders: { agentType: string; extensionId: string; extensionIdPattern: RegExp }[] = [];\n private _lastDiscoverSig = '';\n private _targetId: string | null = null; // Connect to specific targetId (multi-window support)\n private _pageTitle: string = ''; // Connected page title\n\n constructor(port = 9333, logFn?: (msg: string) => void, targetId?: string) {\n this.port = port;\n this._targetId = targetId || null;\n this.logFn = logFn || ((msg) => {\n console.log(msg);\n });\n }\n\n /** Connected page title (includes workspace name) */\n get pageTitle(): string { return this._pageTitle; }\n\n /**\n * Query all workbench pages on port (static)\n * Returns multiple entries if multiple IDE windows are open on same port\n */\n static listAllTargets(port: number): Promise<CdpTarget[]> {\n return new Promise((resolve) => {\n const req = http.get(`http://127.0.0.1:${port}/json`, (res) => {\n let data = '';\n res.on('data', (chunk: Buffer) => data += chunk.toString());\n res.on('end', () => {\n try {\n const targets: CdpTarget[] = JSON.parse(data);\n const pages = targets.filter(\n t => t.type === 'page' && t.webSocketDebuggerUrl\n );\n const isNonMain = (title: string) =>\n !title || /extension-output|ADHDev CDP|Debug Console|Output\\s*$|Launchpad/i.test(title);\n // Main pages only, not agent subpages within workbench\n const mainPages = pages.filter(t =>\n !isNonMain(t.title || '') &&\n t.url?.includes('workbench.html') &&\n !t.url?.includes('agent')\n );\n resolve(mainPages.length > 0 ? mainPages : pages.filter(t => !isNonMain(t.title || '')));\n } catch { resolve([]); }\n });\n });\n req.on('error', () => resolve([]));\n req.setTimeout(2000, () => { req.destroy(); resolve([]); });\n });\n }\n\n setPort(port: number): void {\n this.port = port;\n this.log(`[CDP] Port changed to ${port}`);\n }\n\n getPort(): number { return this.port; }\n\n private log(msg: string): void {\n this.logFn(msg);\n }\n\n // ─── Connection Management ───────────────────────────────\n\n async connect(): Promise<boolean> {\n if (this._connected && this.ws?.readyState === WebSocket.OPEN) return true;\n if (this.connectPromise) return this.connectPromise;\n this.connectPromise = this.doConnect();\n try {\n return await this.connectPromise;\n } finally {\n this.connectPromise = null;\n }\n }\n\n private async doConnect(): Promise<boolean> {\n try {\n const target = await this.findTarget();\n if (!target) return false;\n\n this.log(`[CDP] Connecting to: ${target.title} (${target.id}) on port ${this.port}`);\n this.targetUrl = target.webSocketDebuggerUrl;\n const ok = await this.connectToTarget(this.targetUrl);\n if (ok) this.log('[CDP] ✅ Connected');\n return ok;\n } catch (err) {\n this.log(`[CDP] Connection error: ${(err as Error).message}`);\n return false;\n }\n }\n\n private findTargetOnPort(port: number): Promise<CdpTarget | null> {\n return new Promise((resolve) => {\n const req = http.get(`http://127.0.0.1:${port}/json`, (res) => {\n let data = '';\n res.on('data', (chunk: Buffer) => data += chunk.toString());\n res.on('end', () => {\n try {\n const targets: CdpTarget[] = JSON.parse(data);\n const pages = targets.filter(\n t => (t.type === 'page' || t.type === 'browser' || t.type === 'Page') && t.webSocketDebuggerUrl\n );\n if (pages.length === 0) {\n resolve(targets.find(t => t.webSocketDebuggerUrl) || null);\n return;\n }\n\n // Exclude non-main tabs\n const isNonMain = (title: string) =>\n !title || /extension-output|ADHDev CDP|Debug Console|Output\\s*$|Launchpad/i.test(title);\n const mainPages = pages.filter(t => !isNonMain(t.title || ''));\n const list = mainPages.length > 0 ? mainPages : pages;\n\n this.log(`[CDP] pages(${list.length}): ${list.map(t => `\"${t.title}\"`).join(', ')}`);\n\n // If targetId is specified, select only matching page\n if (this._targetId) {\n const specific = list.find(t => t.id === this._targetId);\n if (specific) {\n this._pageTitle = specific.title || '';\n resolve(specific);\n } else {\n this.log(`[CDP] Target ${this._targetId} not found in page list`);\n resolve(null);\n }\n return;\n }\n\n this._pageTitle = list[0]?.title || '';\n resolve(list[0]);\n } catch { resolve(null); }\n });\n });\n req.on('error', () => resolve(null));\n req.setTimeout(2000, () => { req.destroy(); resolve(null); });\n });\n }\n\n private async findTarget(): Promise<CdpTarget | null> {\n return this.findTargetOnPort(this.port);\n }\n\n setExtensionProviders(providers: { agentType: string; extensionId: string; extensionIdPattern: RegExp }[]): void {\n this.extensionProviders = providers;\n }\n\n private connectToTarget(wsUrl: string): Promise<boolean> {\n return new Promise((resolve) => {\n this.ws = new WebSocket(wsUrl);\n\n this.ws.on('open', async () => {\n this._connected = true;\n try { await this.sendInternal('Runtime.enable'); } catch { }\n // Also connect Browser-level WS (for discovering agent iframes)\n this.connectBrowserWs().catch(() => { });\n resolve(true);\n });\n\n this.ws.on('message', (data) => {\n try {\n const msg = JSON.parse(data.toString());\n if (msg.id && this.pending.has(msg.id)) {\n const { resolve, reject } = this.pending.get(msg.id)!;\n this.pending.delete(msg.id);\n this.failureCount = 0;\n if (msg.error) reject(new Error(msg.error.message));\n else resolve(msg.result);\n } else if (msg.method === 'Runtime.executionContextCreated') {\n this.contexts.add(msg.params.context.id);\n } else if (msg.method === 'Runtime.executionContextDestroyed') {\n this.contexts.delete(msg.params.executionContextId);\n } else if (msg.method === 'Runtime.executionContextsCleared') {\n this.contexts.clear();\n }\n } catch { }\n });\n\n this.ws.on('close', () => {\n this.log('[CDP] WebSocket closed — scheduling reconnect');\n this._connected = false;\n this._browserConnected = false;\n this.browserWs?.close();\n this.browserWs = null;\n this.connectPromise = null;\n this.scheduleReconnect();\n });\n\n this.ws.on('error', (err) => {\n this.log(`[CDP] WebSocket error: ${err.message}`);\n this._connected = false;\n resolve(false);\n });\n });\n }\n\n /** Browser-level CDP connection — needed for Target discovery */\n private async connectBrowserWs(): Promise<void> {\n if (this._browserConnected && this.browserWs?.readyState === WebSocket.OPEN) return;\n try {\n const browserWsUrl = await this.getBrowserWsUrl();\n if (!browserWsUrl) {\n this.log('[CDP] No browser WS URL found');\n return;\n }\n this.log(`[CDP] Connecting browser WS for target discovery...`);\n await new Promise<void>((resolve, reject) => {\n this.browserWs = new WebSocket(browserWsUrl);\n this.browserWs.on('open', async () => {\n this._browserConnected = true;\n this.log('[CDP] ✅ Browser WS connected — enabling target discovery');\n try {\n await this.sendBrowser('Target.setDiscoverTargets', { discover: true });\n } catch (e) {\n this.log(`[CDP] setDiscoverTargets failed: ${(e as Error).message}`);\n }\n resolve();\n });\n this.browserWs.on('message', (data) => {\n try {\n const msg = JSON.parse(data.toString());\n if (msg.id && this.browserPending.has(msg.id)) {\n const { resolve, reject } = this.browserPending.get(msg.id)!;\n this.browserPending.delete(msg.id);\n if (msg.error) reject(new Error(msg.error.message));\n else resolve(msg.result);\n }\n } catch { }\n });\n this.browserWs.on('close', () => {\n this._browserConnected = false;\n this.browserWs = null;\n });\n this.browserWs.on('error', (err) => {\n this.log(`[CDP] Browser WS error: ${err.message}`);\n this._browserConnected = false;\n reject(err);\n });\n });\n } catch (e) {\n this.log(`[CDP] Browser WS connect failed: ${(e as Error).message}`);\n }\n }\n\n private getBrowserWsUrl(): Promise<string | null> {\n return new Promise((resolve) => {\n const req = http.get(`http://127.0.0.1:${this.port}/json/version`, (res) => {\n let data = '';\n res.on('data', (chunk: Buffer) => data += chunk.toString());\n res.on('end', () => {\n try {\n const info = JSON.parse(data);\n resolve(info.webSocketDebuggerUrl || null);\n } catch { resolve(null); }\n });\n });\n req.on('error', () => resolve(null));\n req.setTimeout(3000, () => { req.destroy(); resolve(null); });\n });\n }\n\n private sendBrowser(method: string, params: Record<string, unknown> = {}, timeoutMs = 15000): Promise<any> {\n return new Promise((resolve, reject) => {\n if (!this.browserWs || !this._browserConnected) return reject(new Error('Browser WS not connected'));\n const id = this.browserMsgId++;\n this.browserPending.set(id, { resolve, reject });\n this.browserWs.send(JSON.stringify({ id, method, params }));\n setTimeout(() => {\n if (this.browserPending.has(id)) {\n this.browserPending.delete(id);\n reject(new Error(`Browser CDP timeout: ${method}`));\n }\n }, timeoutMs);\n });\n }\n\n private scheduleReconnect(): void {\n if (this.reconnectTimer) return;\n this.reconnectTimer = setTimeout(async () => {\n this.reconnectTimer = null;\n if (!this._connected) {\n const ok = await this.connect();\n // Schedule reconnect on connection failure (prevent infinite loop: only when port is alive)\n if (!ok && !this._connected) {\n this.scheduleReconnect();\n }\n }\n }, 5000);\n }\n\n disconnect(): void {\n if (this.reconnectTimer) {\n clearTimeout(this.reconnectTimer);\n this.reconnectTimer = null;\n }\n this.ws?.close();\n this.ws = null;\n this._connected = false;\n this.browserWs?.close();\n this.browserWs = null;\n this._browserConnected = false;\n this.failureCount = 0;\n }\n\n get isConnected(): boolean {\n return this._connected || this.ws?.readyState === WebSocket.OPEN;\n }\n\n // ─── CDP Protocol ────────────────────────────────────────\n\n private sendInternal(method: string, params: Record<string, unknown> = {}, timeoutMs = 15000): Promise<any> {\n return new Promise((resolve, reject) => {\n if (!this.ws || !this._connected) return reject(new Error('CDP not connected'));\n if (this.ws.readyState !== WebSocket.OPEN) return reject(new Error('WebSocket not open'));\n\n const id = this.msgId++;\n this.pending.set(id, { resolve, reject });\n this.ws.send(JSON.stringify({ id, method, params }));\n\n setTimeout(() => {\n if (this.pending.has(id)) {\n this.pending.delete(id);\n this.failureCount++;\n if (this.failureCount >= this.MAX_FAILURES) {\n this.log(`[CDP] Force-disconnecting: ${this.failureCount} timeouts (last: ${method})`);\n this.disconnect();\n }\n reject(new Error(`CDP timeout: ${method}`));\n }\n }, timeoutMs);\n });\n }\n\n send(method: string, params: Record<string, unknown> = {}, timeoutMs = 15000): Promise<any> {\n return this.sendInternal(method, params, timeoutMs);\n }\n\n async sendCdpCommand(method: string, params: Record<string, unknown> = {}): Promise<any> {\n return this.sendInternal(method, params);\n }\n\n async evaluate(expression: string, timeoutMs = 30000): Promise<unknown> {\n try {\n const { result } = await this.sendInternal('Runtime.evaluate', {\n expression,\n returnByValue: true,\n awaitPromise: true,\n }, timeoutMs);\n if (result.subtype === 'error') throw new Error(result.description);\n this.failureCount = 0;\n return result.value;\n } catch (e) {\n const isTimeout = (e as Error).message?.includes('timeout');\n if (isTimeout) throw e;\n\n for (const ctxId of this.contexts) {\n try {\n const { result } = await this.sendInternal('Runtime.evaluate', {\n expression,\n returnByValue: true,\n awaitPromise: true,\n contextId: ctxId,\n });\n if (result.subtype === 'error') continue;\n return result.value;\n } catch { continue; }\n }\n throw e;\n }\n }\n\n async querySelector(selector: string): Promise<string | null> {\n return await this.evaluate(`\n (() => {\n const el = document.querySelector(${JSON.stringify(selector)});\n return el ? el.outerHTML.substring(0, 2000) : null;\n })()\n `) as string | null;\n }\n\n /**\n * Input text via CDP protocol then send Enter\n * Used for editors where execCommand does not work (e.g. Lexical).\n * \n * 1. Find editor by selector, focus + click\n * 2. Insert text via Input.insertText\n * 3. Send Enter via Input.dispatchKeyEvent\n */\n async typeAndSend(selector: string, text: string): Promise<boolean> {\n if (!this.isConnected) return false;\n\n // Step 1: Focus + get position\n const focusResult = await this.evaluate(`(() => {\n const e = document.querySelector(${JSON.stringify(selector)});\n if (!e) return null;\n e.focus();\n const r = e.getBoundingClientRect();\n return JSON.stringify({ x: r.x + r.width / 2, y: r.y + r.height / 2 });\n })()`) as string | null;\n\n if (!focusResult) {\n this.log('[CDP] typeAndSend: selector not found');\n return false;\n }\n\n const pos = JSON.parse(focusResult);\n\n // Step 2: Click to ensure focus\n await this.sendInternal('Input.dispatchMouseEvent', {\n type: 'mousePressed', x: Math.round(pos.x), y: Math.round(pos.y),\n button: 'left', clickCount: 1\n });\n await this.sendInternal('Input.dispatchMouseEvent', {\n type: 'mouseReleased', x: Math.round(pos.x), y: Math.round(pos.y),\n button: 'left', clickCount: 1\n });\n await new Promise(r => setTimeout(r, 150));\n\n // Step 3: Insert text\n await this.sendInternal('Input.insertText', { text });\n await new Promise(r => setTimeout(r, 200));\n\n // Step 4: Press Enter\n await this.sendInternal('Input.dispatchKeyEvent', {\n type: 'rawKeyDown', key: 'Enter', code: 'Enter',\n windowsVirtualKeyCode: 13, nativeVirtualKeyCode: 13,\n });\n await this.sendInternal('Input.dispatchKeyEvent', {\n type: 'keyUp', key: 'Enter', code: 'Enter',\n windowsVirtualKeyCode: 13, nativeVirtualKeyCode: 13,\n });\n\n this.log(`[CDP] typeAndSend: sent \"${text.substring(0, 50)}...\"`);\n return true;\n }\n\n /**\n * Coordinate-based typeAndSend — for input fields inside webview iframe\n * Receives coordinates directly instead of selector for click+input+Enter\n */\n async typeAndSendAt(x: number, y: number, text: string): Promise<boolean> {\n if (!this.isConnected) return false;\n\n // Step 1: Click to focus\n await this.sendInternal('Input.dispatchMouseEvent', {\n type: 'mousePressed', x: Math.round(x), y: Math.round(y),\n button: 'left', clickCount: 1\n });\n await this.sendInternal('Input.dispatchMouseEvent', {\n type: 'mouseReleased', x: Math.round(x), y: Math.round(y),\n button: 'left', clickCount: 1\n });\n await new Promise(r => setTimeout(r, 300));\n\n // Step 2: Select all + delete (remove existing content)\n await this.sendInternal('Input.dispatchKeyEvent', {\n type: 'rawKeyDown', key: 'a', code: 'KeyA',\n windowsVirtualKeyCode: 65, modifiers: 8, // Meta\n });\n await this.sendInternal('Input.dispatchKeyEvent', {\n type: 'keyUp', key: 'a', code: 'KeyA',\n windowsVirtualKeyCode: 65, modifiers: 8,\n });\n await this.sendInternal('Input.dispatchKeyEvent', {\n type: 'rawKeyDown', key: 'Backspace', code: 'Backspace',\n windowsVirtualKeyCode: 8,\n });\n await this.sendInternal('Input.dispatchKeyEvent', {\n type: 'keyUp', key: 'Backspace', code: 'Backspace',\n windowsVirtualKeyCode: 8,\n });\n await new Promise(r => setTimeout(r, 150));\n\n // Step 3: Insert text\n await this.sendInternal('Input.insertText', { text });\n await new Promise(r => setTimeout(r, 200));\n\n // Step 4: Press Enter\n await this.sendInternal('Input.dispatchKeyEvent', {\n type: 'rawKeyDown', key: 'Enter', code: 'Enter',\n windowsVirtualKeyCode: 13, nativeVirtualKeyCode: 13,\n });\n await this.sendInternal('Input.dispatchKeyEvent', {\n type: 'keyUp', key: 'Enter', code: 'Enter',\n windowsVirtualKeyCode: 13, nativeVirtualKeyCode: 13,\n });\n\n this.log(`[CDP] typeAndSendAt(${Math.round(x)},${Math.round(y)}): sent \"${text.substring(0, 50)}...\"`);\n return true;\n }\n\n /**\n * Evaluate JS from inside Webview iframe\n * Kiro, PearAI etc Used for IDEs where chat UI is inside webview iframe.\n * \n * 1. Query Target.getTargets via browser WS → find vscode-webview iframes\n * 2. Target.attachToTarget → session acquire\n * 3. Page.getFrameTree → nested iframe find\n * 4. Page.createIsolatedWorld → contextId acquire\n * 5. Runtime.evaluate → result return\n * \n * @param expression JS expression to execute\n * @param matchFn webview iframe URL match function (optional, all webview attempt)\n * @returns evaluate result or null\n */\n async evaluateInWebviewFrame(expression: string, matchFn?: (bodyPreview: string) => boolean): Promise<string | null> {\n if (!this._browserConnected) {\n await this.connectBrowserWs().catch(() => { });\n }\n if (!this.browserWs || !this._browserConnected) {\n this.log('[CDP] evaluateInWebviewFrame: no browser WS');\n return null;\n }\n\n const browserWs = this.browserWs;\n let msgId = this.browserMsgId;\n\n const sendWs = (method: string, params: Record<string, unknown> = {}, sessionId?: string): Promise<any> => {\n return new Promise((resolve, reject) => {\n const mid = msgId++;\n this.browserMsgId = msgId;\n const handler = (raw: WebSocket.Data) => {\n try {\n const msg = JSON.parse(raw.toString());\n if (msg.id === mid) {\n browserWs.removeListener('message', handler);\n if (msg.error) reject(new Error(msg.error.message || JSON.stringify(msg.error)));\n else resolve(msg.result);\n }\n } catch { /* skip non-JSON */ }\n };\n browserWs.on('message', handler);\n const payload: any = { id: mid, method, params };\n if (sessionId) payload.sessionId = sessionId;\n browserWs.send(JSON.stringify(payload));\n setTimeout(() => {\n browserWs.removeListener('message', handler);\n reject(new Error(`timeout: ${method}`));\n }, 10000);\n });\n };\n\n try {\n // 1. Find webview iframe targets\n const { targetInfos } = await sendWs('Target.getTargets');\n const webviewIframes = (targetInfos || []).filter(\n (t: any) => t.type === 'iframe' && (t.url || '').includes('vscode-webview')\n );\n\n if (webviewIframes.length === 0) {\n this.log('[CDP] evaluateInWebviewFrame: no webview iframes found');\n return null;\n }\n\n // 2. Try each webview iframe\n for (const iframe of webviewIframes) {\n let sessionId: string | undefined;\n try {\n const attached = await sendWs('Target.attachToTarget', {\n targetId: iframe.targetId, flatten: true,\n });\n sessionId = attached.sessionId;\n\n // 3. Get frame tree (nested iframe)\n const { frameTree } = await sendWs('Page.getFrameTree', {}, sessionId);\n const childFrame = frameTree?.childFrames?.[0]?.frame;\n if (!childFrame) {\n await sendWs('Target.detachFromTarget', { sessionId }).catch(() => { });\n continue;\n }\n\n // 4. Create isolated world in child frame\n const { executionContextId } = await sendWs('Page.createIsolatedWorld', {\n frameId: childFrame.id,\n worldName: 'adhdev-eval',\n grantUniveralAccess: true,\n }, sessionId);\n\n // 5. If matchFn provided, check body content first\n if (matchFn) {\n const checkResult = await sendWs('Runtime.evaluate', {\n expression: `document.documentElement?.outerHTML?.substring(0, 500000) || ''`,\n returnByValue: true,\n contextId: executionContextId,\n }, sessionId);\n const bodyText = checkResult?.result?.value || '';\n if (!matchFn(bodyText)) {\n await sendWs('Target.detachFromTarget', { sessionId }).catch(() => { });\n continue;\n }\n }\n\n // 6. Evaluate the expression\n const result = await sendWs('Runtime.evaluate', {\n expression,\n returnByValue: true,\n awaitPromise: true,\n contextId: executionContextId,\n }, sessionId);\n\n await sendWs('Target.detachFromTarget', { sessionId }).catch(() => { });\n\n const value = result?.result?.value;\n if (value != null) {\n this.log(`[CDP] evaluateInWebviewFrame: success in ${iframe.targetId.substring(0, 12)}`);\n return typeof value === 'string' ? value : JSON.stringify(value);\n }\n } catch (e: any) {\n if (sessionId) {\n await sendWs('Target.detachFromTarget', { sessionId }).catch(() => { });\n }\n this.log(`[CDP] evaluateInWebviewFrame: error in ${iframe.targetId.substring(0, 12)}: ${e.message}`);\n }\n }\n\n this.log('[CDP] evaluateInWebviewFrame: no matching webview found');\n return null;\n } catch (e: any) {\n this.log(`[CDP] evaluateInWebviewFrame error: ${e.message}`);\n return null;\n }\n }\n\n // ─── Agent Webview Multi-Session ─────────────────────────\n\n async discoverAgentWebviews(): Promise<AgentWebviewTarget[]> {\n if (!this.isConnected) return [];\n\n // Retry connection if no Browser WS\n if (!this._browserConnected) {\n await this.connectBrowserWs().catch(() => { });\n }\n\n try {\n // Query targets from Browser-level WS (includes iframes)\n let allTargets: any[] = [];\n if (this._browserConnected) {\n const result = await this.sendBrowser('Target.getTargets');\n allTargets = result?.targetInfos || [];\n } else {\n // Page-level query (when no browser WS, iframes may not be visible)\n const result = await this.sendInternal('Target.getTargets');\n allTargets = result?.targetInfos || [];\n }\n\n const iframes = allTargets.filter((t: any) => t.type === 'iframe');\n const typeMap = new Map<string, number>();\n for (const t of allTargets) {\n typeMap.set(t.type, (typeMap.get(t.type) || 0) + 1);\n }\n const typeSummary = [...typeMap.entries()].map(([k, v]) => `${k}:${v}`).join(',');\n // Log only on change (called every 5s repeatedly, prevent noise)\n const sig = `${allTargets.length}:${iframes.length}:${typeSummary}`;\n if (sig !== this._lastDiscoverSig) {\n this._lastDiscoverSig = sig;\n this.log(`[CDP] discoverAgentWebviews: ${allTargets.length} total [${typeSummary}], ${iframes.length} iframes (browser=${this._browserConnected})`);\n // Detailed webview target logging also only on change\n for (const t of allTargets) {\n if (t.type !== 'page' && t.type !== 'worker' && t.type !== 'service_worker') {\n this.log(`[CDP] target: type=${t.type} url=${(t.url || '').substring(0, 120)}`);\n }\n if ((t.url || '').includes('vscode-webview')) {\n this.log(`[CDP] webview: type=${t.type} url=${(t.url || '').substring(0, 150)}`);\n }\n }\n }\n\n const agents: AgentWebviewTarget[] = [];\n for (const target of allTargets) {\n if (target.type !== 'iframe') continue;\n const url = target.url || '';\n const hasWebview = url.includes('vscode-webview');\n if (!hasWebview) continue;\n\n for (const known of this.extensionProviders) {\n if (known.extensionIdPattern.test(url)) {\n agents.push({\n targetId: target.targetId,\n extensionId: known.extensionId,\n agentType: known.agentType,\n url: url,\n });\n this.log(`[CDP] Found agent: ${known.agentType} (${target.targetId})`);\n break;\n }\n }\n }\n return agents;\n } catch (e) {\n this.log(`[CDP] discoverAgentWebviews error: ${(e as Error).message}`);\n return [];\n }\n }\n\n async attachToAgent(target: AgentWebviewTarget): Promise<string | null> {\n if (!this.isConnected) return null;\n for (const [sid, t] of this.agentSessions) {\n if (t.agentType === target.agentType) return sid;\n }\n try {\n // Attach via Browser WS (iframes can only be attached from browser-level)\n const sendFn = this._browserConnected ? this.sendBrowser.bind(this) : this.sendInternal.bind(this);\n const result = await sendFn('Target.attachToTarget', {\n targetId: target.targetId,\n flatten: true,\n });\n const sessionId = result?.sessionId;\n if (sessionId) {\n this.agentSessions.set(sessionId, target);\n this.log(`[CDP] Attached to ${target.agentType}, session=${sessionId.substring(0, 12)}...`);\n }\n return sessionId || null;\n } catch (e) {\n this.log(`[CDP] attach error (${target.agentType}): ${(e as Error).message}`);\n return null;\n }\n }\n\n async evaluateInSession(sessionId: string, expression: string, timeoutMs = 15000): Promise<unknown> {\n // Flatten mode: if session was opened from same WS, must evaluate via same WS\n const ws = this._browserConnected ? this.browserWs : this.ws;\n const pendingMap = this._browserConnected ? this.browserPending : this.pending;\n const getNextId = () => this._browserConnected ? this.browserMsgId++ : this.msgId++;\n\n if (!ws || ws.readyState !== WebSocket.OPEN) {\n throw new Error('CDP not connected');\n }\n\n return new Promise((resolve, reject) => {\n const id = getNextId();\n pendingMap.set(id, {\n resolve: (result: any) => {\n if (result?.result?.subtype === 'error') {\n reject(new Error(result.result.description));\n } else {\n resolve(result?.result?.value);\n }\n },\n reject,\n });\n ws.send(JSON.stringify({\n id, sessionId,\n method: 'Runtime.evaluate',\n params: { expression, returnByValue: true, awaitPromise: true },\n }));\n setTimeout(() => {\n if (pendingMap.has(id)) {\n pendingMap.delete(id);\n reject(new Error(`CDP agent timeout: ${sessionId.substring(0, 12)}...`));\n }\n }, timeoutMs);\n });\n }\n\n async detachAgent(sessionId: string): Promise<void> {\n try {\n const sendFn = this._browserConnected ? this.sendBrowser.bind(this) : this.sendInternal.bind(this);\n await sendFn('Target.detachFromTarget', { sessionId });\n } catch { }\n this.agentSessions.delete(sessionId);\n }\n\n async detachAllAgents(): Promise<void> {\n for (const sid of Array.from(this.agentSessions.keys())) {\n await this.detachAgent(sid);\n }\n }\n\n getAgentSessions(): Map<string, AgentWebviewTarget> {\n return this.agentSessions;\n }\n\n // ─── Screenshot ──────────────────────────────────────────\n\n async captureScreenshot(opts?: { quality?: number }): Promise<Buffer | null> {\n if (!this.isConnected) return null;\n const quality = opts?.quality ?? 20;\n try {\n // Get viewport size for per-clipping pro (avoids HiDPI bloat)\n let clip: any;\n try {\n const metrics = await this.sendInternal('Page.getLayoutMetrics', {}, 3000);\n const vp = metrics?.cssVisualViewport || metrics?.visualViewport;\n if (vp) {\n clip = {\n x: 0, y: 0,\n width: Math.round(vp.clientWidth || vp.width || 1920),\n height: Math.round(vp.clientHeight || vp.height || 1080),\n scale: 1,\n };\n }\n } catch { /* fallback: no clip */ }\n\n const result = await this.sendInternal('Page.captureScreenshot', {\n format: 'jpeg',\n quality,\n ...(clip ? { clip } : {}),\n optimizeForSpeed: true,\n captureBeyondViewport: false,\n }, 10000);\n if (result?.data) {\n return Buffer.from(result.data, 'base64');\n }\n return null;\n } catch (e) {\n this.log(`[CDP] Screenshot error: ${(e as Error).message}`);\n return null;\n }\n }\n}\n","/**\n * CDP DOM Analysis Tools — DOM dump, query, debug\n *\n * Separated from daemon-commands.ts.\n * Tools for analyzing DOM structure when developing new IDE scripts.\n */\n\nimport type { DaemonCdpManager } from './daemon-cdp.js';\nimport type { CommandResult } from './daemon-commands.js';\n\ntype CdpGetter = (ideType?: string) => DaemonCdpManager | null;\n\n/**\n * CDP DOM analysis handler\n * \n * Uses getCdp from DaemonCommandHandler.\n */\nexport class CdpDomHandlers {\n private getCdp: CdpGetter;\n\n constructor(getCdp: CdpGetter) {\n this.getCdp = getCdp;\n }\n\n /**\n * CDP DOM Dump — IDE's DOM tree retrieve\n * \n * args:\n * selector?: string — CSS selector to dump specific area only (default: All)\n * depth?: number — Dump depth limit (default: 10)\n * attrs?: boolean — Whether to include properties (default: true)\n * maxLength?: number — Max character count (default: 200000)\n * format?: 'html' | 'tree' | 'summary' — Output format (default: 'html')\n * sessionId?: string — Agent webview session ID (if provided, match webview DOM)\n */\n async handleDomDump(args: any): Promise<CommandResult> {\n if (!this.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n\n const selector = args?.selector || 'body';\n const depth = args?.depth || 10;\n const maxLength = args?.maxLength || 200000;\n const format = args?.format || 'html';\n const attrs = args?.attrs !== false;\n const sessionId = args?.sessionId;\n\n try {\n let expression: string;\n\n if (format === 'summary') {\n // Summary mode: extract key structure only (classes, tags, roles)\n expression = `(() => {\n const root = document.querySelector('${selector.replace(/'/g, \"\\\\'\")}');\n if (!root) return JSON.stringify({ error: 'Selector not found: ${selector}' });\n \n function summarize(el, depth, maxD) {\n if (depth > maxD) return { tag: '...', note: 'max depth' };\n const node = {\n tag: el.tagName?.toLowerCase(),\n id: el.id || undefined,\n class: el.className && typeof el.className === 'string' ? el.className.split(' ').filter(c => c).slice(0, 5).join(' ') : undefined,\n role: el.getAttribute?.('role') || undefined,\n 'data-testid': el.getAttribute?.('data-testid') || undefined,\n childCount: el.children?.length || 0,\n };\n if (el.children?.length > 0 && depth < maxD) {\n node.children = Array.from(el.children).slice(0, 30).map(c => summarize(c, depth + 1, maxD));\n }\n return node;\n }\n return JSON.stringify(summarize(root, 0, ${depth}));\n })()`;\n } else if (format === 'tree') {\n // Tree mode: text-based tree view\n expression = `(() => {\n const root = document.querySelector('${selector.replace(/'/g, \"\\\\'\")}');\n if (!root) return 'Selector not found: ${selector}';\n \n function tree(el, indent, depth, maxD) {\n if (depth > maxD) return indent + '...\\\\n';\n let line = indent + '<' + (el.tagName?.toLowerCase() || '?');\n if (el.id) line += ' #' + el.id;\n if (el.className && typeof el.className === 'string') {\n const cls = el.className.trim().split(' ').filter(c => c).slice(0, 3).join('.');\n if (cls) line += ' .' + cls;\n }\n const role = el.getAttribute?.('role');\n if (role) line += ' [role=' + role + ']';\n const testId = el.getAttribute?.('data-testid');\n if (testId) line += ' [data-testid=' + testId + ']';\n line += '> (' + (el.children?.length || 0) + ')\\\\n';\n \n let result = line;\n if (el.children?.length > 0 && depth < maxD) {\n for (let i = 0; i < Math.min(el.children.length, 30); i++) {\n result += tree(el.children[i], indent + ' ', depth + 1, maxD);\n }\n if (el.children.length > 30) result += indent + ' ... +' + (el.children.length - 30) + ' more\\\\n';\n }\n return result;\n }\n return tree(root, '', 0, ${depth});\n })()`;\n } else {\n // HTML mode: full dump via outerHTML\n expression = `(() => {\n const root = document.querySelector('${selector.replace(/'/g, \"\\\\'\")}');\n if (!root) return 'Selector not found: ${selector}';\n let html = root.outerHTML;\n if (html.length > ${maxLength}) {\n html = html.slice(0, ${maxLength}) + '\\\\n<!-- TRUNCATED at ${maxLength} chars -->';\n }\n return html;\n })()`;\n }\n\n let result;\n if (sessionId) {\n result = await this.getCdp()!.evaluateInSession(sessionId, expression);\n } else {\n result = await this.getCdp()!.evaluate(expression, 30000);\n }\n\n // Summary mode JSON parsing\n if (format === 'summary' && typeof result === 'string') {\n try {\n result = JSON.parse(result);\n } catch { /* keep as string */ }\n }\n\n const size = typeof result === 'string' ? result.length : JSON.stringify(result).length;\n return { success: true, result, format, selector, size };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n /**\n * CDP DOM Query — CSS Test selector\n * Check how many elements match selector and what elements they are\n * \n * args:\n * selector: string — CSS selector\n * limit?: number — Max element count to return (default: 20)\n * content?: boolean — Whether to include text content (default: true)\n * sessionId?: string — agent webview session ID\n */\n async handleDomQuery(args: any): Promise<CommandResult> {\n if (!this.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n\n const selector = args?.selector;\n if (!selector) return { success: false, error: 'selector required' };\n const limit = args?.limit || 20;\n const content = args?.content !== false;\n const sessionId = args?.sessionId;\n\n const expression = `(() => {\n try {\n const els = document.querySelectorAll('${selector.replace(/'/g, \"\\\\'\")}');\n const results = [];\n for (let i = 0; i < Math.min(els.length, ${limit}); i++) {\n const el = els[i];\n const item = {\n index: i,\n tag: el.tagName?.toLowerCase(),\n id: el.id || null,\n class: el.className && typeof el.className === 'string' ? el.className.trim().slice(0, 200) : null,\n role: el.getAttribute?.('role') || null,\n 'data-testid': el.getAttribute?.('data-testid') || null,\n rect: (() => { try { const r = el.getBoundingClientRect(); return { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) }; } catch { return null; } })(),\n visible: el.offsetParent !== null || el.offsetWidth > 0,\n };\n ${content ? `item.text = (el.textContent || '').trim().slice(0, 200);` : ''}\n ${content ? `item.value = el.value !== undefined ? String(el.value).slice(0, 200) : undefined;` : ''}\n results.push(item);\n }\n return JSON.stringify({ total: els.length, results });\n } catch(e) {\n return JSON.stringify({ error: e.message });\n }\n })()`;\n\n try {\n let raw;\n if (sessionId) {\n raw = await this.getCdp()!.evaluateInSession(sessionId, expression);\n } else {\n raw = await this.getCdp()!.evaluate(expression, 15000);\n }\n\n const parsed = typeof raw === 'string' ? JSON.parse(raw) : raw;\n return { success: true, ...parsed, selector };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n /**\n * CDP DOM Debug — IDE AI panel specialized analysis\n * Collect all essential info at once when supporting new IDE\n * \n * args:\n * ideType?: string — IDE type hint\n * sessionId?: string — agent webview session ID \n */\n async handleDomDebug(args: any): Promise<CommandResult> {\n if (!this.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n const sessionId = args?.sessionId;\n\n const expression = `(() => {\n const result = {\n url: location.href,\n title: document.title,\n viewport: { w: window.innerWidth, h: window.innerHeight },\n \n // Input field info\n inputs: [],\n // Textarea info\n textareas: [],\n // Contenteditable info\n editables: [],\n // Buttons (send, submit etc)\n buttons: [],\n // iframes (agent webviews)\n iframes: [],\n // role=\"textbox\" info\n textboxes: [],\n };\n\n // Input fields\n document.querySelectorAll('input[type=\"text\"], input:not([type])').forEach((el, i) => {\n if (i >= 10) return;\n result.inputs.push({\n tag: 'input',\n id: el.id || null,\n class: (el.className || '').toString().slice(0, 150),\n placeholder: el.getAttribute('placeholder') || null,\n name: el.name || null,\n value: el.value?.slice(0, 100) || null,\n visible: el.offsetParent !== null,\n rect: (() => { try { const r = el.getBoundingClientRect(); return { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) }; } catch { return null; } })(),\n });\n });\n\n // textarea\n document.querySelectorAll('textarea').forEach((el, i) => {\n if (i >= 10) return;\n result.textareas.push({\n id: el.id || null,\n class: (el.className || '').toString().slice(0, 150),\n placeholder: el.getAttribute('placeholder') || null,\n rows: el.rows,\n value: el.value?.slice(0, 100) || null,\n visible: el.offsetParent !== null,\n rect: (() => { try { const r = el.getBoundingClientRect(); return { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) }; } catch { return null; } })(),\n });\n });\n\n // contenteditable\n document.querySelectorAll('[contenteditable=\"true\"]').forEach((el, i) => {\n if (i >= 10) return;\n result.editables.push({\n tag: el.tagName?.toLowerCase(),\n id: el.id || null,\n class: (el.className || '').toString().slice(0, 150),\n role: el.getAttribute('role') || null,\n text: (el.textContent || '').trim().slice(0, 100),\n visible: el.offsetParent !== null,\n rect: (() => { try { const r = el.getBoundingClientRect(); return { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) }; } catch { return null; } })(),\n });\n });\n\n // role=\"textbox\"\n document.querySelectorAll('[role=\"textbox\"]').forEach((el, i) => {\n if (i >= 10) return;\n result.textboxes.push({\n tag: el.tagName?.toLowerCase(),\n id: el.id || null,\n class: (el.className || '').toString().slice(0, 150),\n 'aria-label': el.getAttribute('aria-label') || null,\n text: (el.textContent || '').trim().slice(0, 100),\n visible: el.offsetParent !== null,\n rect: (() => { try { const r = el.getBoundingClientRect(); return { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) }; } catch { return null; } })(),\n });\n });\n\n // Buttons (send, submit, accept, reject, approve etc)\n const btnKeywords = /send|submit|accept|reject|approve|deny|cancel|confirm|run|execute|apply/i;\n document.querySelectorAll('button, [role=\"button\"], input[type=\"submit\"]').forEach((el, i) => {\n const text = (el.textContent || el.getAttribute('aria-label') || '').trim();\n if (i < 30 && (text.length < 30 || btnKeywords.test(text))) {\n result.buttons.push({\n tag: el.tagName?.toLowerCase(),\n id: el.id || null,\n class: (el.className || '').toString().slice(0, 150),\n text: text.slice(0, 80),\n 'aria-label': el.getAttribute('aria-label') || null,\n disabled: el.disabled || el.getAttribute('disabled') !== null,\n visible: el.offsetParent !== null,\n rect: (() => { try { const r = el.getBoundingClientRect(); return { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) }; } catch { return null; } })(),\n });\n }\n });\n\n // iframes\n document.querySelectorAll('iframe, webview').forEach((el, i) => {\n if (i >= 20) return;\n result.iframes.push({\n tag: el.tagName?.toLowerCase(),\n id: el.id || null,\n class: (el.className || '').toString().slice(0, 150),\n src: el.getAttribute('src')?.slice(0, 200) || null,\n title: el.getAttribute('title') || null,\n visible: el.offsetParent !== null,\n rect: (() => { try { const r = el.getBoundingClientRect(); return { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) }; } catch { return null; } })(),\n });\n });\n\n return JSON.stringify(result);\n })()`;\n\n try {\n let raw;\n if (sessionId) {\n raw = await this.getCdp()!.evaluateInSession(sessionId, expression);\n } else {\n raw = await this.getCdp()!.evaluate(expression, 30000);\n }\n\n const parsed = typeof raw === 'string' ? JSON.parse(raw) : raw;\n return { success: true, ...parsed };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n}\n","/**\n * Daemon Commands — unified command handler\n * \n * Routes all functionality from legacy Extension commands.ts (2452 lines) to Daemon.\n * \n * 3 handling paths:\n * 1. Daemon directly handle (CDP, fs, CLI)\n * 2. Delegate to Extension via IPC (vscode API)\n * 3. P2P signaling relay\n */\n\nimport { DaemonCdpManager } from './daemon-cdp.js';\nimport { CdpDomHandlers } from './daemon-cdp-devtools.js';\nimport { ProviderLoader } from './providers/provider-loader.js';\nimport type { ProviderModule } from './providers/contracts.js';\nimport type { DaemonAgentStreamManager } from './agent-stream/index.js';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\nimport { loadConfig } from './config.js';\nimport { readChatHistory, ChatHistoryWriter } from './chat-history.js';\n\nexport interface CommandResult {\n success: boolean;\n [key: string]: unknown;\n}\n\nexport interface CommandContext {\n cdpManagers: Map<string, DaemonCdpManager>;\n ideType: string;\n adapters: Map<string, any>;\n providerLoader?: ProviderLoader;\n /** UUID instanceId → CDP manager key (ideType) mapping */\n instanceIdMap?: Map<string, string>;\n}\n\nexport class DaemonCommandHandler {\n private ctx: CommandContext;\n private agentStream: DaemonAgentStreamManager | null = null;\n private domHandlers: CdpDomHandlers;\n\n /** Get CDP manager for a specific ideType.\n * Returns null if no match — never falls back to another IDE.\n */\n private getCdp(ideType?: string): DaemonCdpManager | null {\n const key = ideType || this._currentIdeType;\n if (!key) {\n // Suppress repeat warnings — silently return null if no ideType\n return null;\n }\n const m = this.ctx.cdpManagers.get(key.toLowerCase());\n if (m?.isConnected) return m;\n // CDP not connected is debug-only (prevent repeat logs)\n return null;\n }\n\n /** Current IDE type extracted from command args (per-request) */\n private _currentIdeType: string | undefined;\n /** Current provider type — agentType priority, ideType use */\n private _currentProviderType: string | undefined;\n\n private historyWriter: ChatHistoryWriter;\n\n /** Extract ideType from _targetInstance\n * UUID-based: query directly from instanceIdMap\n * Legacy: composite ID parsing ('doId:ide:uuid' → uuid → map lookup)\n */\n private extractIdeType(args: any): string | undefined {\n if (args?._targetInstance) {\n let raw = args._targetInstance as string;\n // Strip composite prefix: 'doId:ide:uuid' → 'uuid'\n const ideMatch = raw.match(/:ide:(.+)$/);\n const cliMatch = raw.match(/:cli:(.+)$/);\n const acpMatch = raw.match(/:acp:(.+)$/);\n if (ideMatch) raw = ideMatch[1];\n else if (cliMatch) raw = cliMatch[1];\n else if (acpMatch) raw = acpMatch[1];\n\n // UUID → ideType mapping lookup (primary)\n if (this.ctx.instanceIdMap?.has(raw)) {\n return this.ctx.instanceIdMap.get(raw)!;\n }\n\n // Legacy fallback: 'type_hash' format (underscore split)\n const lastUnderscore = raw.lastIndexOf('_');\n if (lastUnderscore > 0) return raw.substring(0, lastUnderscore);\n \n // If it's a plain string like 'antigravity' (no match), return it directly\n return raw;\n }\n return undefined;\n }\n\n constructor(ctx: CommandContext) {\n this.ctx = ctx;\n this.domHandlers = new CdpDomHandlers((ideType?) => this.getCdp(ideType));\n this.historyWriter = new ChatHistoryWriter();\n }\n\n /**\n * Get provider module — _currentProviderType (agentType priority) use.\n * Extension: agentType='cline' → provider.type='cline' (category=extension)\n * CLI: ideType='gemini-cli' → provider.type='gemini-cli' (category=cli)\n * IDE: ideType='cursor' → provider.type='cursor' (category=ide)\n */\n private getProvider(overrideType?: string): ProviderModule | undefined {\n const key = overrideType || this._currentProviderType || this._currentIdeType;\n if (!key || !this.ctx.providerLoader) return undefined;\n // Try exact match first, fallback to base type on failure\n // e.g., 'antigravity_remote_vs' → 'antigravity'\n const result = this.ctx.providerLoader.resolve(key);\n if (result) return result;\n // Extract base type from multi-window key: 'antigravity_remote_vs' → 'antigravity'\n const baseType = key.split('_')[0];\n if (baseType !== key) return this.ctx.providerLoader.resolve(baseType);\n return undefined;\n }\n\n /** Get a provider script by name from ProviderLoader.\n * Returns the script string or null. */\n private getProviderScript(scriptName: string, params?: Record<string, string>, ideType?: string): string | null {\n const provider = this.getProvider(ideType);\n if (provider?.scripts) {\n const fn = (provider.scripts as any)[scriptName];\n if (typeof fn === 'function') {\n // If params exist, pass first value as argument\n const firstVal = params ? Object.values(params)[0] : undefined;\n const script = firstVal ? fn(firstVal) : fn();\n if (script) return script;\n }\n }\n return null;\n }\n\n // ─── Category dispatch engine ───────────────────\n\n /**\n * Look up Extension provider webview session ID from AgentStreamManager.\n * provider.type (e.g. 'cline') → ManagedAgent sessionId\n */\n private getExtensionSessionId(provider: ProviderModule): string | null {\n if (provider.category !== 'extension' || !this.agentStream) return null;\n // agentStream.getManagedAgent queries by agentType (= provider.type)\n const managed = this.agentStream.getManagedAgent(provider.type);\n return managed?.sessionId || null;\n }\n\n /**\n * per-category CDP script execute:\n * IDE → cdp.evaluate(script) (main window)\n * Extension → cdp.evaluateInSession(sessionId, script) (webview)\n * CLI → null (separate handling needed)\n */\n private async evaluateProviderScript(\n scriptName: string,\n params?: Record<string, string>,\n timeout = 30000,\n ): Promise<{ result: any; category: string } | null> {\n const provider = this.getProvider();\n const script = this.getProviderScript(scriptName, params);\n if (!script) return null;\n\n const cdp = this.getCdp();\n if (!cdp?.isConnected) return null;\n\n // Extension: evaluateInSession\n if (provider?.category === 'extension') {\n let sessionId = this.getExtensionSessionId(provider);\n // on-demand: activate+sync if no session\n if (!sessionId && this.agentStream) {\n await this.agentStream.switchActiveAgent(cdp, provider.type);\n await this.agentStream.syncAgentSessions(cdp);\n sessionId = this.getExtensionSessionId(provider);\n }\n if (!sessionId) return null;\n const result = await cdp.evaluateInSession(sessionId, script, timeout);\n return { result, category: 'extension' };\n }\n\n // IDE (default): evaluate in main window\n const result = await cdp.evaluate(script, timeout);\n return { result, category: provider?.category || 'ide' };\n }\n\n /**\n * CLI adapter search: provider.type or agentTypeas match\n */\n private getCliAdapter(type?: string): any | null {\n const target = type || this._currentIdeType;\n if (!target || !this.ctx.adapters) return null;\n for (const [key, adapter] of this.ctx.adapters.entries()) {\n if ((adapter as any).cliType === target || key.startsWith(target)) {\n return adapter;\n }\n }\n return null;\n }\n\n setAgentStreamManager(manager: DaemonAgentStreamManager): void {\n this.agentStream = manager;\n }\n\n async handle(cmd: string, args: any): Promise<CommandResult> {\n // Per-request: extract target IDE/provider type from args\n this._currentIdeType = this.extractIdeType(args);\n // Provider type: agentType (for Extension/CLI) priority, fallback to ideType\n this._currentProviderType = args?.agentType || args?.providerType || this._currentIdeType;\n\n // Commands without ideType CDP silently fail (prevent P2P retry spam)\n if (!this._currentIdeType && !this._currentProviderType) {\n const cdpCommands = ['send_chat', 'read_chat', 'list_chats', 'new_chat', 'switch_chat', 'set_mode', 'change_model', 'set_thought_level', 'resolve_action'];\n if (cdpCommands.includes(cmd)) {\n return { success: false, error: 'No ideType specified — cannot route command' };\n }\n }\n switch (cmd) {\n // ─── CDP directly handle ───────────────────\n case 'read_chat': return this.handleReadChat(args);\n case 'chat_history': return this.handleChatHistory(args);\n case 'send_chat': return this.handleSendChat(args);\n case 'list_chats': return this.handleListChats(args);\n case 'new_chat': return this.handleNewChat(args);\n case 'switch_chat': return this.handleSwitchChat(args);\n case 'set_mode': return this.handleSetMode(args);\n case 'change_model': return this.handleChangeModel(args);\n case 'set_thought_level': return this.handleSetThoughtLevel(args);\n case 'resolve_action': return this.handleResolveAction(args);\n case 'cdp_eval': return this.handleCdpEval(args);\n case 'cdp_screenshot':\n case 'screenshot': return this.handleScreenshot(args);\n case 'cdp_command_exec': return this.handleCdpCommand(args);\n case 'cdp_batch': return this.handleCdpBatch(args);\n case 'cdp_remote_action': return this.handleCdpRemoteAction(args);\n case 'cdp_discover_agents': return this.handleDiscoverAgents(args);\n case 'cdp_dom_dump': return this.domHandlers.handleDomDump(args);\n case 'cdp_dom_query': return this.domHandlers.handleDomQuery(args);\n case 'cdp_dom_debug': return this.domHandlers.handleDomDebug(args);\n\n // ─── file directly handle ──────────────────\n case 'file_read': return this.handleFileRead(args);\n case 'file_write': return this.handleFileWrite(args);\n case 'file_list': return this.handleFileList(args);\n case 'file_list_browse': return this.handleFileListBrowse(args);\n\n // ─── vscode API → Extension delegate ────\n case 'vscode_command_exec':\n case 'execute_vscode_command': {\n const resolvedCmd = args?.commandId || args?.command;\n // Intercept CDP-based commands that daemon should handle directly\n if (resolvedCmd === 'adhdev.captureCdpScreenshot') {\n return this.handleScreenshot(args);\n }\n return this.delegateToExtension(resolvedCmd || cmd, args?.args);\n }\n case 'get_open_editors': return this.delegateToExtension('adhdev.getOpenEditors', [args]);\n case 'open_tab': return this.delegateToExtension('vscode.open', [args?.uri || args?.path]);\n case 'close_tab': return this.delegateToExtension('workbench.action.closeActiveEditor', []);\n case 'open_folder': return this.delegateToExtension('vscode.openFolder', [args?.path]);\n case 'open_folder_picker': return this.delegateToExtension('workbench.action.files.openFolder', []);\n case 'open_recent': return this.delegateToExtension('workbench.action.openRecent', []);\n case 'get_commands': return this.delegateToExtension('adhdev.getCommands', []);\n case 'get_recent_workspaces': return this.handleGetRecentWorkspaces(args);\n\n // ─── script manage ───────────────────\n case 'refresh_scripts': return this.handleRefreshScripts(args);\n\n // ─── Agent Stream commands ───────────────\n case 'agent_stream_switch': return this.handleAgentStreamSwitch(args);\n case 'agent_stream_read': return this.handleAgentStreamRead(args);\n case 'agent_stream_send': return this.handleAgentStreamSend(args);\n case 'agent_stream_resolve': return this.handleAgentStreamResolve(args);\n case 'agent_stream_new': return this.handleAgentStreamNew(args);\n case 'agent_stream_list_chats': return this.handleAgentStreamListChats(args);\n case 'agent_stream_switch_session': return this.handleAgentStreamSwitchSession(args);\n case 'agent_stream_focus': return this.handleAgentStreamFocus(args);\n\n // ─── PTY Raw I/O (terminal view) ─────────\n case 'pty_input': return this.handlePtyInput(args);\n case 'pty_resize': return this.handlePtyResize(args);\n\n // ─── Provider Settings ──────────────\n case 'get_provider_settings': return this.handleGetProviderSettings(args);\n case 'set_provider_setting': return this.handleSetProviderSetting(args);\n\n // ─── IDE Extension Settings (per-IDE on/off) ──────────────\n case 'get_ide_extensions': return this.handleGetIdeExtensions(args);\n case 'set_ide_extension': return this.handleSetIdeExtension(args);\n\n // ─── Extension Model / Mode Control ──────────────\n case 'list_extension_models': return await this.handleExtensionScript(args, 'listModels');\n case 'set_extension_model': return await this.handleExtensionScript(args, 'setModel');\n case 'list_extension_modes': return await this.handleExtensionScript(args, 'listModes');\n case 'set_extension_mode': return await this.handleExtensionScript(args, 'setMode');\n\n default:\n return { success: false, error: `Unknown command: ${cmd}` };\n }\n }\n\n // ─── CDP-based chat commands ──────────────────────\n\n private async handleChatHistory(args: any): Promise<CommandResult> {\n const { agentType, offset, limit, instanceId } = args;\n try {\n const provider = this.getProvider(agentType);\n const agentStr = provider?.type || agentType || this._currentIdeType || '';\n const result = readChatHistory(agentStr, offset || 0, limit || 30, instanceId);\n return { success: true, ...result, agent: agentStr };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n private async handleReadChat(args: any): Promise<CommandResult> {\n const provider = this.getProvider();\n const _log = (msg: string) => console.log(`[read_chat] ${msg}`);\n\n // ─── CLI / ACP category: read from adapter ───\n if (provider?.category === 'cli' || provider?.category === 'acp') {\n const adapter = this.getCliAdapter(provider.type);\n if (adapter) {\n _log(`${provider.category} adapter: ${(adapter as any).cliType}`);\n const status = (adapter as any).getStatus?.();\n if (status) {\n return { success: true, messages: status.messages || [], status: status.status, activeModal: status.activeModal };\n }\n }\n return { success: false, error: `${provider.category} adapter not found` };\n }\n\n // ─── Extension category: evaluateInSession ───\n if (provider?.category === 'extension') {\n try {\n const evalResult = await this.evaluateProviderScript('readChat', undefined, 50000);\n if (evalResult?.result) {\n let parsed = evalResult.result;\n if (typeof parsed === 'string') { try { parsed = JSON.parse(parsed); } catch { } }\n if (parsed && typeof parsed === 'object') {\n _log(`Extension OK: ${parsed.messages?.length || 0} msgs`);\n this.historyWriter.appendNewMessages(\n provider.type || 'unknown_extension',\n parsed.messages || [],\n parsed.title,\n args?.instanceId\n );\n return { success: true, ...parsed };\n }\n }\n } catch (e: any) {\n _log(`Extension error: ${e.message}`);\n }\n // Alternative: AgentStreamManager (script fail when)\n if (this.agentStream) {\n const cdp = this.getCdp();\n if (cdp) {\n const streams = await this.agentStream.collectAgentStreams(cdp);\n const stream = streams.find(s => s.agentType === provider.type);\n if (stream) {\n this.historyWriter.appendNewMessages(\n stream.agentType,\n stream.messages || [],\n undefined,\n args?.instanceId\n );\n return { success: true, messages: stream.messages || [], status: stream.status, agentType: stream.agentType };\n }\n }\n }\n return { success: true, messages: [], status: 'idle' };\n }\n\n // ─── IDE category (default): cdp.evaluate ───\n const cdp = this.getCdp();\n if (!cdp?.isConnected) return { success: false, error: 'CDP not connected' };\n\n // webview IDE (Kiro, PearAI) → evaluateInWebviewFrame directly use\n const webviewScript = this.getProviderScript('webviewReadChat') || this.getProviderScript('webview_read_chat');\n if (webviewScript) {\n try {\n const matchText = provider?.webviewMatchText;\n const matchFn = matchText\n ? (body: string) => body.includes(matchText)\n : undefined;\n const raw = await cdp.evaluateInWebviewFrame(webviewScript, matchFn);\n if (raw) {\n let parsed: any = raw;\n if (typeof parsed === 'string') { try { parsed = JSON.parse(parsed); } catch { } }\n if (parsed && typeof parsed === 'object') {\n _log(`Webview OK: ${parsed.messages?.length || 0} msgs`);\n this.historyWriter.appendNewMessages(\n provider?.type || this._currentIdeType || 'unknown_webview',\n parsed.messages || [],\n parsed.title,\n args?.instanceId\n );\n return { success: true, ...parsed };\n }\n }\n } catch (e: any) {\n _log(`Webview readChat error: ${e.message}`);\n }\n return { success: true, messages: [], status: 'idle' };\n }\n\n // Regular IDE (Cursor, Windsurf, Trae etc) → main DOM evaluate\n const script = this.getProviderScript('readChat') || this.getProviderScript('read_chat');\n if (script) {\n try {\n const result = await cdp.evaluate(script, 50000);\n let parsed: any = result;\n if (typeof parsed === 'string') { try { parsed = JSON.parse(parsed); } catch { } }\n if (parsed && typeof parsed === 'object' && parsed.messages?.length > 0) {\n _log(`OK: ${parsed.messages?.length} msgs`);\n this.historyWriter.appendNewMessages(\n provider?.type || this._currentIdeType || 'unknown_ide',\n parsed.messages || [],\n parsed.title,\n args?.instanceId\n );\n return { success: true, ...parsed };\n }\n } catch (e: any) {\n console.log(`[read_chat] Script error: ${e.message}`);\n }\n }\n\n return { success: true, messages: [], status: 'idle' };\n }\n\n private async handleSendChat(args: any): Promise<CommandResult> {\n const text = args?.text || args?.message;\n if (!text) return { success: false, error: 'text required' };\n const _log = (msg: string) => console.log(`[send_chat] ${msg}`);\n const provider = this.getProvider();\n\n // ─── CLI / ACP category: transmit via adapter ───\n if (provider?.category === 'cli' || provider?.category === 'acp') {\n const adapter = this.getCliAdapter(provider.type);\n if (adapter) {\n _log(`${provider.category} adapter: ${(adapter as any).cliType}`);\n try {\n await adapter.sendMessage(text);\n return { success: true, sent: true, method: `${provider.category}-adapter`, targetAgent: (adapter as any).cliType };\n } catch (e: any) {\n return { success: false, error: `${provider.category} send failed: ${e.message}` };\n }\n }\n }\n\n // ─── Extension category: via AgentStreamManager ───\n if (provider?.category === 'extension') {\n _log(`Extension: ${provider.type}`);\n // Method 1: provider sendMessage script via evaluateInSession\n try {\n const evalResult = await this.evaluateProviderScript('sendMessage', { MESSAGE: text }, 30000);\n if (evalResult?.result) {\n let parsed = evalResult.result;\n if (typeof parsed === 'string') { try { parsed = JSON.parse(parsed); } catch { } }\n if (parsed?.sent) {\n _log(`Extension script sent OK`);\n return { success: true, sent: true, method: 'extension-script' };\n }\n if (parsed?.needsTypeAndSend) {\n // Needs typing into Extension internal textarea\n _log(`Extension needsTypeAndSend → AgentStreamManager`);\n }\n }\n } catch (e: any) {\n _log(`Extension script error: ${e.message}`);\n }\n // Method 2: AgentStreamManager\n if (this.agentStream && this.getCdp()) {\n const ok = await this.agentStream.sendToAgent(this.getCdp()!, provider.type, text, this._currentIdeType);\n if (ok) {\n _log(`AgentStreamManager sent OK`);\n return { success: true, sent: true, method: 'agent-stream' };\n }\n }\n return { success: false, error: `Extension '${provider.type}' send failed` };\n }\n\n // ─── IDE category (default): Provider → typeAndSend → script ───\n const targetCdp = this.getCdp();\n if (!targetCdp?.isConnected) {\n _log(`No CDP for ${this._currentIdeType}`);\n return { success: false, error: `CDP for ${this._currentIdeType || 'unknown'} not connected` };\n }\n\n _log(`Targeting IDE: ${this._currentIdeType}`);\n\n // Method 0: webview-based IDE (try webviewSendMessage first)\n // Input fields inside webview iframe cannot be accessed via main frame typeAndSend\n if (provider?.webviewMatchText && provider?.scripts?.webviewSendMessage) {\n try {\n const webviewScript = (provider.scripts as any).webviewSendMessage(text);\n if (webviewScript && targetCdp.evaluateInWebviewFrame) {\n const matchText = provider.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n const wvResult = await targetCdp.evaluateInWebviewFrame(webviewScript, matchFn);\n let wvParsed: any = wvResult;\n if (typeof wvResult === 'string') { try { wvParsed = JSON.parse(wvResult); } catch { } }\n if (wvParsed?.sent) {\n _log(`webviewSendMessage (priority) OK`);\n return { success: true, sent: true, method: 'webview-script-priority' };\n }\n _log(`webviewSendMessage (priority) did not confirm sent, falling through`);\n }\n } catch (e: any) {\n _log(`webviewSendMessage (priority) failed: ${e.message}, falling through`);\n }\n }\n\n // Method 1: use provider.inputMethod if available (main frame input)\n if (provider?.inputMethod === 'cdp-type-and-send' && provider.inputSelector) {\n try {\n const sent = await targetCdp.typeAndSend(provider.inputSelector, text);\n if (sent) {\n _log(`typeAndSend(provider.inputSelector=${provider.inputSelector}) success`);\n return { success: true, sent: true, method: 'typeAndSend-provider' };\n }\n } catch (e: any) {\n _log(`typeAndSend(provider) failed: ${e.message}`);\n }\n }\n\n // Method 2: provider sendMessage script\n const sendScript = this.getProviderScript('sendMessage', { MESSAGE: text });\n if (sendScript) {\n try {\n const result = await targetCdp.evaluate(sendScript, 30000);\n let parsed: any = result;\n if (typeof result === 'string') { try { parsed = JSON.parse(result); } catch { } }\n if (parsed?.sent) {\n _log(`sendMessage script OK`);\n return { success: true, sent: true, method: 'script' };\n }\n // needsTypeAndSend response: typeAndSend using script-specified selector\n if (parsed?.needsTypeAndSend && parsed?.selector) {\n try {\n const sent = await targetCdp.typeAndSend(parsed.selector, text);\n if (sent) {\n _log(`typeAndSend(script.selector=${parsed.selector}) success`);\n return { success: true, sent: true, method: 'typeAndSend-script' };\n }\n } catch (e: any) {\n _log(`typeAndSend(script.selector) failed: ${e.message}`);\n }\n }\n // webviewSendMessage: attempt direct transmission from inside webview iframe\n if (parsed?.needsTypeAndSend && provider?.scripts?.webviewSendMessage) {\n try {\n const webviewScript = (provider.scripts as any).webviewSendMessage(text);\n if (webviewScript && targetCdp.evaluateInWebviewFrame) {\n const matchText = provider.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n const wvResult = await targetCdp.evaluateInWebviewFrame(webviewScript, matchFn);\n let wvParsed: any = wvResult;\n if (typeof wvResult === 'string') { try { wvParsed = JSON.parse(wvResult); } catch { } }\n if (wvParsed?.sent) {\n _log(`webviewSendMessage OK`);\n return { success: true, sent: true, method: 'webview-script' };\n }\n }\n } catch (e: any) {\n _log(`webviewSendMessage failed: ${e.message}`);\n }\n }\n // Coordinate-based fallback: input field inside webview iframe\n if (parsed?.needsTypeAndSend && parsed?.clickCoords) {\n try {\n const { x, y } = parsed.clickCoords;\n const sent = await targetCdp.typeAndSendAt(x, y, text);\n if (sent) {\n _log(`typeAndSendAt(${x},${y}) success`);\n return { success: true, sent: true, method: 'typeAndSendAt-script' };\n }\n } catch (e: any) {\n _log(`typeAndSendAt failed: ${e.message}`);\n }\n }\n } catch (e: any) {\n _log(`sendMessage script failed: ${e.message}`);\n }\n }\n\n _log('All methods failed');\n return { success: false, error: 'No provider method could send the message' };\n }\n\n private async handleListChats(args: any): Promise<CommandResult> {\n const provider = this.getProvider();\n\n // Extension: via AgentStreamManager\n if (provider?.category === 'extension' && this.agentStream && this.getCdp()) {\n try {\n const chats = await this.agentStream.listAgentChats(this.getCdp()!, provider.type);\n console.log(`[list_chats] Extension: ${chats.length} chats`);\n return { success: true, chats };\n } catch (e: any) {\n console.log(`[list_chats] Extension error: ${e.message}`);\n }\n }\n\n // webview IDE\n try {\n const webviewScript = this.getProviderScript('webviewListSessions') || this.getProviderScript('webview_list_sessions');\n if (webviewScript) {\n const matchText = provider?.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n const raw = await this.getCdp()?.evaluateInWebviewFrame?.(webviewScript, matchFn);\n let parsed: any = raw;\n if (typeof parsed === 'string') { try { parsed = JSON.parse(parsed); } catch { } }\n if (parsed?.sessions) {\n console.log(`[list_chats] Webview OK: ${parsed.sessions.length} chats`);\n return { success: true, chats: parsed.sessions };\n }\n }\n } catch (e: any) {\n console.log(`[list_chats] Webview error: ${e.message}`);\n }\n\n // IDE/default: evaluateProviderScript\n try {\n const evalResult = await this.evaluateProviderScript('listSessions');\n if (evalResult) {\n let parsed = evalResult.result;\n if (typeof parsed === 'string') { try { parsed = JSON.parse(parsed); } catch { } }\n if (Array.isArray(parsed)) {\n console.log(`[list_chats] OK: ${parsed.length} chats`);\n return { success: true, chats: parsed };\n }\n }\n } catch (e: any) {\n console.log(`[list_chats] error: ${e.message}`);\n }\n\n return { success: false, error: 'listSessions script not available for this provider' };\n }\n\n private async handleNewChat(args: any): Promise<CommandResult> {\n const provider = this.getProvider();\n\n // Extension: via AgentStreamManager\n if (provider?.category === 'extension' && this.agentStream && this.getCdp()) {\n const ok = await this.agentStream.newAgentSession(this.getCdp()!, provider.type, this._currentIdeType);\n return { success: ok };\n }\n\n // webview IDE\n try {\n const webviewScript = this.getProviderScript('webviewNewSession') || this.getProviderScript('webview_new_session');\n if (webviewScript) {\n const matchText = provider?.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n const raw = await this.getCdp()?.evaluateInWebviewFrame?.(webviewScript, matchFn);\n if (raw) return { success: true, result: raw };\n }\n } catch (e: any) {\n return { success: false, error: `webviewNewSession failed: ${e.message}` };\n }\n\n // IDE/default: evaluateProviderScript\n try {\n const evalResult = await this.evaluateProviderScript('newSession');\n if (evalResult) return { success: true };\n } catch (e: any) {\n return { success: false, error: `newSession failed: ${e.message}` };\n }\n\n return { success: false, error: 'newSession script not available for this provider' };\n }\n\n private async handleSwitchChat(args: any): Promise<CommandResult> {\n const provider = this.getProvider();\n const ideType = this._currentIdeType;\n const sessionId = args?.sessionId || args?.id || args?.chatId;\n if (!sessionId) return { success: false, error: 'sessionId required' };\n console.log(`[switch_chat] sessionId=${sessionId}, ideType=${ideType}`);\n\n // Extension: via AgentStreamManager\n if (provider?.category === 'extension' && this.agentStream && this.getCdp()) {\n const ok = await this.agentStream.switchAgentSession(this.getCdp()!, provider.type, sessionId);\n return { success: ok, result: ok ? 'switched' : 'failed' };\n }\n\n const cdp = this.getCdp(ideType);\n if (!cdp?.isConnected) return { success: false, error: 'CDP not connected' };\n\n // webview IDE\n try {\n const webviewScript = this.getProviderScript('webviewSwitchSession', { SESSION_ID: JSON.stringify(sessionId) });\n if (webviewScript) {\n const matchText = provider?.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n const raw = await cdp.evaluateInWebviewFrame?.(webviewScript, matchFn);\n if (raw) return { success: true, result: raw };\n }\n } catch (e: any) {\n return { success: false, error: `webviewSwitchSession failed: ${e.message}` };\n }\n\n const script = this.getProviderScript('switchSession', { SESSION_ID: JSON.stringify(sessionId) })\n || this.getProviderScript('switch_session', { SESSION_ID: JSON.stringify(sessionId) });\n if (!script) return { success: false, error: 'switch_session script not available' };\n\n try {\n const raw = await cdp.evaluate(script, 15000);\n console.log(`[switch_chat] result:`, raw);\n\n // If script returns coordinates, handle as CDP-level mouse click\n // (Antigravity's QuickInput widget does not respond to DOM events)\n let parsed: any = null;\n try { parsed = typeof raw === 'string' ? JSON.parse(raw) : raw; } catch { }\n\n if (parsed?.action === 'click' && parsed.clickX && parsed.clickY) {\n const x = Math.round(parsed.clickX);\n const y = Math.round(parsed.clickY);\n console.log(`[switch_chat] CDP click at (${x}, ${y}) for \"${parsed.title}\"`);\n await cdp.send('Input.dispatchMouseEvent', {\n type: 'mousePressed', x, y, button: 'left', clickCount: 1\n });\n await cdp.send('Input.dispatchMouseEvent', {\n type: 'mouseReleased', x, y, button: 'left', clickCount: 1\n });\n await new Promise(r => setTimeout(r, 2000));\n\n // Auto-handle workspace selection dialog\n const wsResult = await cdp.evaluate(`\n (() => {\n const inp = Array.from(document.querySelectorAll('input[type=\"text\"]'))\n .find(i => i.offsetWidth > 0 && (i.placeholder || '').includes('Select where'));\n if (!inp) return null;\n const rows = inp.closest('[class*=\"quickInput\"]')?.querySelectorAll('[class*=\"cursor-pointer\"]');\n if (rows && rows.length > 0) {\n const r = rows[0].getBoundingClientRect();\n return JSON.stringify({ x: Math.round(r.left + r.width/2), y: Math.round(r.top + r.height/2) });\n }\n return null;\n })()\n `, 5000);\n if (wsResult) {\n try {\n const ws = JSON.parse(wsResult as string);\n await cdp.send('Input.dispatchMouseEvent', {\n type: 'mousePressed', x: ws.x, y: ws.y, button: 'left', clickCount: 1\n });\n await cdp.send('Input.dispatchMouseEvent', {\n type: 'mouseReleased', x: ws.x, y: ws.y, button: 'left', clickCount: 1\n });\n } catch { }\n }\n return { success: true, result: 'switched' };\n }\n\n if (parsed?.error) {\n return { success: false, error: parsed.error };\n }\n\n return { success: true, result: raw };\n } catch (e: any) {\n console.error(`[switch_chat] error:`, e.message);\n return { success: false, error: e.message };\n }\n }\n\n private async handleSetMode(args: any): Promise<CommandResult> {\n const provider = this.getProvider();\n const mode = args?.mode || 'agent';\n\n // ACP provider → session/set_mode via adapter\n if (provider?.category === 'acp') {\n const adapter = this.getCliAdapter(provider.type);\n if (adapter) {\n const acpInstance = (adapter as any)._acpInstance;\n if (acpInstance && typeof acpInstance.onEvent === 'function') {\n acpInstance.onEvent('set_mode', { mode });\n return { success: true, mode };\n }\n }\n return { success: false, error: 'ACP adapter not found' };\n }\n\n // IDE/Extension: provider script priority (CDP-based)\n // 1. webview setMode (Kiro, PearAI etc)\n const webviewScript = this.getProviderScript('webviewSetMode', { MODE: JSON.stringify(mode) });\n if (webviewScript) {\n const cdp = this.getCdp();\n if (cdp?.isConnected) {\n try {\n const matchText = provider?.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n const raw = await cdp.evaluateInWebviewFrame?.(webviewScript, matchFn);\n let result: any = raw;\n if (typeof raw === 'string') { try { result = JSON.parse(raw); } catch { } }\n if (result?.success) return { success: true, mode, method: 'webview-script' };\n } catch (e: any) {\n console.log(`[set_mode] webview script error: ${e.message}`);\n }\n }\n }\n\n // 2. main frame setMode (Windsurf, Trae, Cursor, Antigravity etc)\n const mainScript = this.getProviderScript('setMode', { MODE: JSON.stringify(mode) });\n if (mainScript) {\n try {\n const evalResult = await this.evaluateProviderScript('setMode', { MODE: JSON.stringify(mode) }, 15000);\n if (evalResult?.result) {\n let parsed = evalResult.result;\n if (typeof parsed === 'string') { try { parsed = JSON.parse(parsed); } catch { } }\n if (parsed?.success) return { success: true, mode, method: 'script' };\n }\n } catch (e: any) {\n console.log(`[set_mode] script error: ${e.message}`);\n }\n }\n\n // 3. Extension fallback\n return this.delegateToExtension(`composerMode.${mode}`, []);\n }\n\n private async handleChangeModel(args: any): Promise<CommandResult> {\n const provider = this.getProvider();\n const model = args?.model;\n\n console.log(`[change_model] model=${model} provider=${provider?.type} category=${provider?.category} ideType=${this._currentIdeType} providerType=${this._currentProviderType}`);\n\n // ACP provider → session/set_config_option via adapter\n if (provider?.category === 'acp') {\n const adapter = this.getCliAdapter(provider.type);\n console.log(`[change_model] ACP adapter found: ${!!adapter}, type=${(adapter as any)?.cliType}, hasAcpInstance=${!!(adapter as any)?._acpInstance}`);\n if (adapter) {\n const acpInstance = (adapter as any)._acpInstance;\n if (acpInstance && typeof acpInstance.onEvent === 'function') {\n acpInstance.onEvent('change_model', { model });\n console.log(`[change_model] Dispatched change_model event to ACP instance`);\n return { success: true, model };\n }\n }\n return { success: false, error: 'ACP adapter not found' };\n }\n\n // IDE/Extension: provider script priority (CDP-based)\n // 1. webview setModel (Kiro, PearAI etc)\n const webviewScript = this.getProviderScript('webviewSetModel', { MODEL: JSON.stringify(model) });\n if (webviewScript) {\n const cdp = this.getCdp();\n if (cdp?.isConnected) {\n try {\n const matchText = provider?.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n const raw = await cdp.evaluateInWebviewFrame?.(webviewScript, matchFn);\n let result: any = raw;\n if (typeof raw === 'string') { try { result = JSON.parse(raw); } catch { } }\n if (result?.success) return { success: true, model, method: 'webview-script' };\n } catch (e: any) {\n console.log(`[change_model] webview script error: ${e.message}`);\n }\n }\n }\n\n // 2. main frame setModel (Windsurf, Trae, Cursor, Antigravity etc)\n const mainScript = this.getProviderScript('setModel', { MODEL: JSON.stringify(model) });\n if (mainScript) {\n try {\n const evalResult = await this.evaluateProviderScript('setModel', { MODEL: JSON.stringify(model) }, 15000);\n if (evalResult?.result) {\n let parsed = evalResult.result;\n if (typeof parsed === 'string') { try { parsed = JSON.parse(parsed); } catch { } }\n if (parsed?.success) return { success: true, model, method: 'script' };\n }\n } catch (e: any) {\n console.log(`[change_model] script error: ${e.message}`);\n }\n }\n\n // 3. Extension fallback (vscode settings)\n const settingsKey = provider?.vscodeCommands?.changeModel;\n if (settingsKey) {\n return this.delegateToExtension('workbench.action.openSettings', [settingsKey]);\n }\n return { success: false, error: 'changeModel not supported by this IDE provider' };\n }\n\n /** set_thought_level — ACP configOption change */\n private async handleSetThoughtLevel(args: any): Promise<CommandResult> {\n const configId = args?.configId;\n const value = args?.value;\n if (!configId || !value) return { success: false, error: 'configId and value required' };\n\n const provider = this.getProvider();\n if (!provider || provider.category !== 'acp') {\n return { success: false, error: 'set_thought_level only for ACP providers' };\n }\n const adapter = this.getCliAdapter(provider.type);\n const acpInstance = adapter?._acpInstance;\n if (!acpInstance) return { success: false, error: 'ACP instance not found' };\n\n try {\n await acpInstance.setConfigOption(configId, value);\n console.log(`[set_thought_level] ${configId}=${value} for ${provider.type}`);\n return { success: true, configId, value };\n } catch (e: any) {\n return { success: false, error: e?.message };\n }\n }\n\n /** resolveAction — unified (common for IDE/Extension) */\n private async handleResolveAction(args: any): Promise<CommandResult> {\n const provider = this.getProvider();\n const action = args?.action || 'approve';\n const button = args?.button || args?.buttonText\n || (action === 'approve' ? 'Accept' : action === 'reject' ? 'Reject' : 'Accept');\n\n console.log(`[resolveAction] action=${action} button=\"${button}\" provider=${provider?.type}`);\n\n // 1. Extension: via AgentStreamManager\n if (provider?.category === 'extension' && this.agentStream && this.getCdp()) {\n const ok = await this.agentStream.resolveAgentAction(\n this.getCdp()!, provider.type, action, this._currentIdeType\n );\n return { success: ok };\n }\n\n // 2. Webview Provider script → returns coords → convert webview frame coords to main document coords for click (complex, so direct click from webview is recommended)\n // However, evaluateInWebviewFrame can perform clicks on behalf.\n if (provider?.scripts?.webviewResolveAction || provider?.scripts?.webview_resolve_action) {\n const script = this.getProviderScript('webviewResolveAction', { action, button, buttonText: button })\n || this.getProviderScript('webview_resolve_action', { action, button, buttonText: button });\n if (script) {\n const cdp = this.getCdp();\n if (cdp?.isConnected) {\n try {\n const matchText = provider?.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n const raw = await cdp.evaluateInWebviewFrame?.(script, matchFn);\n let result: any = raw;\n if (typeof raw === 'string') { try { result = JSON.parse(raw); } catch { } }\n console.log(`[resolveAction] webview script result:`, JSON.stringify(result));\n\n if (result?.resolved) {\n return { success: true, clicked: result.clicked };\n }\n // When returning coords from inside webview, webview iframe offset is needed for CDP click.\n // Therefore, from webview it is recommended that script directly triggers DOM event (Click) and returns {resolved: true, clicked: buttonText}.\n if (result?.found && result.x != null && result.y != null) {\n console.log(`[resolveAction] Webview coordinate click not fully supported via CDP. Click directly in script.`);\n }\n if (result?.found || result?.resolved) return { success: true };\n } catch (e: any) {\n return { success: false, error: `webviewResolveAction failed: ${e.message}` };\n }\n }\n }\n }\n\n // 3. Provider script (Main DOM) → returns coords → CDP mouse click\n if (provider?.scripts?.resolveAction) {\n const script = provider.scripts.resolveAction({ action, button, buttonText: button });\n if (script) {\n const cdp = this.getCdp();\n if (!cdp?.isConnected) return { success: false, error: 'CDP not connected' };\n try {\n const raw = await cdp.evaluate(script, 30000);\n let result: any = raw;\n if (typeof raw === 'string') { try { result = JSON.parse(raw); } catch {} }\n console.log(`[resolveAction] script result:`, JSON.stringify(result));\n\n // Case 1: Script already clicked the button (e.g. Cursor — returns {resolved, clicked})\n if (result?.resolved) {\n console.log(`[resolveAction] script-click resolved — \"${result.clicked}\"`);\n return { success: true, clicked: result.clicked };\n }\n\n // Case 2: Script returned coordinates for CDP mouse click (e.g. Antigravity — {found, x, y})\n if (result?.found && result.x != null && result.y != null) {\n // CDP mouse click (real mouse event)\n const x = result.x;\n const y = result.y;\n await cdp.send('Input.dispatchMouseEvent', {\n type: 'mousePressed', x, y, button: 'left', clickCount: 1\n });\n await cdp.send('Input.dispatchMouseEvent', {\n type: 'mouseReleased', x, y, button: 'left', clickCount: 1\n });\n console.log(`[resolveAction] CDP click at (${x}, ${y}) — \"${result.text}\"`);\n return { success: true, clicked: result.text };\n }\n return { success: false, error: result?.found === false ? `Button not found: ${button}` : 'No coordinates' };\n } catch (e: any) {\n return { success: false, error: `resolveAction failed: ${e.message}` };\n }\n }\n }\n\n return { success: false, error: 'resolveAction script not available for this provider' };\n }\n\n // ─── CDP direct commands ──────────────────────────\n\n private async handleCdpEval(args: any): Promise<CommandResult> {\n if (!this.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n const expression = args?.expression || args?.script;\n if (!expression) return { success: false, error: 'expression required' };\n try {\n const result = await this.getCdp()!.evaluate(expression, 50000);\n return { success: true, result };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n private async handleScreenshot(args: any): Promise<CommandResult> {\n if (!this.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n try {\n const buf = await this.getCdp()!.captureScreenshot();\n if (buf) {\n const b64 = buf.toString('base64');\n return { success: true, result: b64, base64: b64, screenshot: b64, format: 'jpeg' };\n }\n return { success: false, error: 'Screenshot failed' };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n private async handleCdpCommand(args: any): Promise<CommandResult> {\n if (!this.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n const method = args?.method;\n const params = args?.params || {};\n if (!method) return { success: false, error: 'method required' };\n try {\n const result = await this.getCdp()!.sendCdpCommand(method, params);\n return { success: true, result };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n private async handleCdpBatch(args: any): Promise<CommandResult> {\n if (!this.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n const commands = args?.commands as any[];\n const stopOnError = args?.stopOnError !== false;\n if (!commands?.length) return { success: false, error: 'commands array required' };\n\n const results: any[] = [];\n for (const cmd of commands) {\n try {\n const result = await this.getCdp()!.sendCdpCommand(cmd.method, cmd.params || {});\n results.push({ method: cmd.method, success: true, result });\n } catch (e: any) {\n results.push({ method: cmd.method, success: false, error: e.message });\n if (stopOnError) break;\n }\n }\n return { success: true, results };\n }\n\n private async handleCdpRemoteAction(args: any): Promise<CommandResult> {\n if (!this.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n const action = args?.action;\n const params = args?.params || args;\n\n try {\n switch (action) {\n case 'input_key': {\n const { key, modifiers } = params;\n // keyDown + keyUp\n await this.getCdp()!.send('Input.dispatchKeyEvent', {\n type: 'keyDown', key,\n ...(modifiers?.ctrl ? { modifiers: 2 } : {}),\n ...(modifiers?.shift ? { modifiers: 8 } : {}),\n });\n await this.getCdp()!.send('Input.dispatchKeyEvent', { type: 'keyUp', key });\n return { success: true };\n }\n case 'input_click': {\n let { x, y, nx, ny, button: btn } = params;\n // Dashboard sends normalized coordinates (0.0-1.0), convert to pixels\n if ((x === undefined || y === undefined) && nx !== undefined && ny !== undefined) {\n const viewport = await this.getCdp()!.evaluate(\n 'JSON.stringify({ w: window.innerWidth, h: window.innerHeight })'\n ) as string;\n const { w, h } = JSON.parse(viewport);\n x = Math.round(nx * w);\n y = Math.round(ny * h);\n }\n if (x === undefined || y === undefined) {\n return { success: false, error: 'No coordinates provided (x,y or nx,ny required)' };\n }\n await this.getCdp()!.send('Input.dispatchMouseEvent', {\n type: 'mousePressed', x, y, button: btn || 'left', clickCount: 1,\n });\n await this.getCdp()!.send('Input.dispatchMouseEvent', {\n type: 'mouseReleased', x, y, button: btn || 'left', clickCount: 1,\n });\n return { success: true, x, y };\n }\n case 'input_type': {\n const { text } = params;\n for (const char of text || '') {\n await this.getCdp()!.send('Input.dispatchKeyEvent', {\n type: 'keyDown', text: char, key: char,\n });\n await this.getCdp()!.send('Input.dispatchKeyEvent', { type: 'keyUp', key: char });\n }\n return { success: true };\n }\n case 'page_screenshot': return this.handleScreenshot(args);\n case 'page_eval': return this.handleCdpEval(params);\n case 'dom_query': {\n const html = await this.getCdp()!.querySelector(params?.selector);\n return { success: true, html };\n }\n case 'input_wheel': {\n let { x, y, nx, ny, deltaX, deltaY } = params;\n // Normalize coordinates if needed\n if ((x === undefined || y === undefined) && nx !== undefined && ny !== undefined) {\n const viewport = await this.getCdp()!.evaluate(\n 'JSON.stringify({ w: window.innerWidth, h: window.innerHeight })'\n ) as string;\n const { w, h } = JSON.parse(viewport);\n x = Math.round(nx * w);\n y = Math.round(ny * h);\n }\n await this.getCdp()!.send('Input.dispatchMouseEvent', {\n type: 'mouseWheel', x: x || 0, y: y || 0,\n deltaX: deltaX || 0, deltaY: deltaY || 0,\n });\n return { success: true };\n }\n default:\n return { success: false, error: `Unknown remote action: ${action}` };\n }\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n private async handleDiscoverAgents(args: any): Promise<CommandResult> {\n if (!this.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n const agents = await this.getCdp()!.discoverAgentWebviews();\n return { success: true, agents };\n }\n\n // ─── file directly handle ─────────────────────────\n\n private async handleFileRead(args: any): Promise<CommandResult> {\n try {\n const filePath = this.resolveSafePath(args?.path);\n const content = fs.readFileSync(filePath, 'utf-8');\n return { success: true, content, path: filePath };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n private async handleFileWrite(args: any): Promise<CommandResult> {\n try {\n const filePath = this.resolveSafePath(args?.path);\n fs.mkdirSync(path.dirname(filePath), { recursive: true });\n fs.writeFileSync(filePath, args?.content || '', 'utf-8');\n return { success: true, path: filePath };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n private async handleFileList(args: any): Promise<CommandResult> {\n try {\n const dirPath = this.resolveSafePath(args?.path || '.');\n const entries = fs.readdirSync(dirPath, { withFileTypes: true });\n const files = entries.map(e => ({\n name: e.name,\n type: e.isDirectory() ? 'directory' : 'file',\n size: e.isFile() ? fs.statSync(path.join(dirPath, e.name)).size : undefined,\n }));\n return { success: true, files, path: dirPath };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n\n private async handleFileListBrowse(args: any): Promise<CommandResult> {\n return this.handleFileList(args);\n }\n\n private resolveSafePath(requestedPath: string): string {\n const home = os.homedir();\n let resolved: string;\n if (requestedPath.startsWith('~')) {\n resolved = path.join(home, requestedPath.slice(1));\n } else if (path.isAbsolute(requestedPath)) {\n resolved = requestedPath;\n } else {\n resolved = path.resolve(requestedPath);\n }\n return resolved;\n }\n\n // ─── Extension delegate (No longer available — bridge-extension removed) ─────────────\n\n private async delegateToExtension(command: string, args?: any[]): Promise<CommandResult> {\n return { success: false, error: 'Extension not available (bridge-extension removed)' };\n }\n\n // ─── Misc ───────────────────────────────────\n\n private async handleGetRecentWorkspaces(args: any): Promise<CommandResult> {\n // Load recently used CLI folders from config.json\n const config = loadConfig();\n const cliRecent = config.recentCliWorkspaces || [];\n\n // macOS VS Code/Cursor recent workspaces\n try {\n const storageDir = path.join(os.homedir(), 'Library', 'Application Support');\n const candidates = ['Cursor', 'Code', 'VSCodium'];\n for (const app of candidates) {\n const stateFile = path.join(storageDir, app, 'User', 'globalStorage', 'state.vscdb');\n if (fs.existsSync(stateFile)) {\n // Cannot read SQLite directly, delegate to Extension\n // Need to merge CLI recent folders with Extension results, but, \n // In relay architecture where Extension response cannot be received directly (async) \n // Extension's adhdev.getRecentWorkspaces internal logic modification is more complex, so \n // for now we await the call to merge CLI folders from daemon-commands.ts.\n const result = await this.delegateToExtension('adhdev.getRecentWorkspaces', []);\n if (result.success && Array.isArray(result.result)) {\n // Remove duplicates then merge\n const merged = Array.from(new Set([...cliRecent, ...result.result])).slice(0, 20);\n return { success: true, result: merged };\n }\n }\n }\n return { success: true, result: cliRecent };\n } catch {\n return { success: true, result: cliRecent };\n }\n }\n\n private async handleRefreshScripts(_args: any): Promise<CommandResult> {\n // ProviderLoader reload\n if (this.ctx.providerLoader) {\n this.ctx.providerLoader.reload();\n return { success: true };\n }\n return { success: false, error: 'ProviderLoader not initialized' };\n }\n\n // ─── Agent Stream commands ───────────────────────\n\n private async handleAgentStreamSwitch(args: any): Promise<CommandResult> {\n if (!this.agentStream || !this.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || null;\n await this.agentStream.switchActiveAgent(this.getCdp()!, agentType);\n return { success: true, activeAgent: agentType };\n }\n\n private async handleAgentStreamRead(args: any): Promise<CommandResult> {\n if (!this.agentStream || !this.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const streams = await this.agentStream.collectAgentStreams(this.getCdp()!);\n return { success: true, streams };\n }\n\n private async handleAgentStreamSend(args: any): Promise<CommandResult> {\n const agentType = args?.agentType || args?.agent;\n const text = args?.text || args?.message;\n if (!text) return { success: false, error: 'text required' };\n\n // CLI adapter routing: transmit via adapter if agentType matches a CLI adapter\n if (agentType && this.ctx.adapters) {\n for (const [key, adapter] of this.ctx.adapters.entries()) {\n if (adapter.cliType === agentType || key.includes(agentType)) {\n console.log(`[agent_stream_send] Routing to CLI adapter: ${adapter.cliType}`);\n try {\n await adapter.sendMessage(text);\n return { success: true, sent: true, targetAgent: adapter.cliType };\n } catch (e: any) {\n console.log(`[agent_stream_send] CLI adapter failed: ${e.message}`);\n return { success: false, error: `CLI send failed: ${e.message}` };\n }\n }\n }\n }\n\n // CDP-based IDE agent routing (existing logic)\n if (!this.agentStream || !this.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const resolvedAgent = agentType || this.agentStream.activeAgentType;\n if (!resolvedAgent) return { success: false, error: 'agentType required' };\n const ok = await this.agentStream.sendToAgent(this.getCdp()!, resolvedAgent, text, this._currentIdeType);\n return { success: ok };\n }\n\n private async handleAgentStreamResolve(args: any): Promise<CommandResult> {\n if (!this.agentStream || !this.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || this.agentStream.activeAgentType;\n const action = args?.action as 'approve' | 'reject' || 'approve';\n if (!agentType) return { success: false, error: 'agentType required' };\n const ok = await this.agentStream.resolveAgentAction(this.getCdp()!, agentType, action, this._currentIdeType);\n return { success: ok };\n }\n\n private async handleAgentStreamNew(args: any): Promise<CommandResult> {\n if (!this.agentStream || !this.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || this.agentStream.activeAgentType;\n if (!agentType) return { success: false, error: 'agentType required' };\n const ok = await this.agentStream.newAgentSession(this.getCdp()!, agentType, this._currentIdeType);\n return { success: ok };\n }\n\n private async handleAgentStreamListChats(args: any): Promise<CommandResult> {\n if (!this.agentStream || !this.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || this.agentStream.activeAgentType;\n if (!agentType) return { success: false, error: 'agentType required' };\n const chats = await this.agentStream.listAgentChats(this.getCdp()!, agentType);\n return { success: true, chats };\n }\n\n private async handleAgentStreamSwitchSession(args: any): Promise<CommandResult> {\n if (!this.agentStream || !this.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || this.agentStream.activeAgentType;\n const sessionId = args?.sessionId || args?.id;\n if (!agentType || !sessionId) return { success: false, error: 'agentType and sessionId required' };\n const ok = await this.agentStream.switchAgentSession(this.getCdp()!, agentType, sessionId);\n return { success: ok };\n }\n\n private async handleAgentStreamFocus(args: any): Promise<CommandResult> {\n if (!this.agentStream || !this.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || this.agentStream.activeAgentType;\n if (!agentType) return { success: false, error: 'agentType required' };\n // Delegate panel focus to Extension — forward to correct IDE via targetIdeType\n await this.agentStream.ensureAgentPanelOpen(agentType, this._currentIdeType);\n const ok = await this.agentStream.focusAgentEditor(this.getCdp()!, agentType);\n return { success: ok };\n }\n\n // ─── PTY Raw I/O (terminal view) ──────────────────────\n\n private handlePtyInput(args: any): CommandResult {\n const { cliType, data } = args || {};\n if (!data) return { success: false, error: 'data required' };\n\n // Find CLI adapter\n if (this.ctx.adapters) {\n const targetCli = cliType || '';\n // 0. Use first adapter if no cliType\n if (!targetCli && this.ctx.adapters.size > 0) {\n const first = this.ctx.adapters.values().next().value;\n if (first && typeof first.writeRaw === 'function') {\n first.writeRaw(data);\n return { success: true };\n }\n }\n // 1. Direct match by adapter key (e.g. UUID key)\n const directAdapter = this.ctx.adapters.get(targetCli);\n if (directAdapter && typeof directAdapter.writeRaw === 'function') {\n directAdapter.writeRaw(data);\n return { success: true };\n }\n // 2. Exact cliType match\n for (const [, adapter] of this.ctx.adapters) {\n if (adapter.cliType === targetCli && typeof adapter.writeRaw === 'function') {\n adapter.writeRaw(data);\n return { success: true };\n }\n }\n // 3. key prefix match (e.g. targetCli='claude-code_abc' → key starts with 'claude-code')\n for (const [key, adapter] of this.ctx.adapters) {\n if ((key.startsWith(targetCli) || targetCli.startsWith(adapter.cliType)) && typeof adapter.writeRaw === 'function') {\n adapter.writeRaw(data);\n return { success: true };\n }\n }\n }\n return { success: false, error: `CLI adapter not found: ${cliType}` };\n }\n\n private handlePtyResize(args: any): CommandResult {\n const { cliType, cols, rows, force } = args || {};\n if (!cols || !rows) return { success: false, error: 'cols and rows required' };\n\n if (this.ctx.adapters) {\n const targetCli = cliType || '';\n // 0. Use first adapter if no cliType\n if (!targetCli && this.ctx.adapters.size > 0) {\n const first = this.ctx.adapters.values().next().value;\n if (first && typeof first.resize === 'function') {\n if (force) { first.resize(cols - 1, rows); setTimeout(() => first.resize(cols, rows), 50); }\n else { first.resize(cols, rows); }\n return { success: true };\n }\n }\n // 1. Directly match by adapter key\n const directAdapter = this.ctx.adapters.get(targetCli);\n if (directAdapter && typeof directAdapter.resize === 'function') {\n if (force) {\n directAdapter.resize(cols - 1, rows);\n setTimeout(() => directAdapter.resize(cols, rows), 50);\n } else {\n directAdapter.resize(cols, rows);\n }\n return { success: true };\n }\n // 2. Exact cliType match + prefix match\n for (const [key, adapter] of this.ctx.adapters) {\n if ((adapter.cliType === targetCli || key.startsWith(targetCli) || targetCli.startsWith(adapter.cliType)) && typeof adapter.resize === 'function') {\n if (force) {\n adapter.resize(cols - 1, rows);\n setTimeout(() => adapter.resize(cols, rows), 50);\n } else {\n adapter.resize(cols, rows);\n }\n return { success: true };\n }\n }\n }\n return { success: false, error: `CLI adapter not found: ${cliType}` };\n }\n\n // ─── Provider Settings ────────────────────────\n\n private handleGetProviderSettings(args: any): CommandResult {\n const { providerType } = args || {};\n\n if (providerType) {\n const schema = (this.ctx.providerLoader as any)?.getPublicSettings?.(providerType) || [];\n const values = (this.ctx.providerLoader as any)?.getSettings?.(providerType) || {};\n return { success: true, providerType, schema, values };\n }\n\n const allSettings = (this.ctx.providerLoader as any)?.getAllPublicSettings?.() || {};\n const allValues: Record<string, any> = {};\n for (const type of Object.keys(allSettings)) {\n allValues[type] = (this.ctx.providerLoader as any)?.getSettings?.(type) || {};\n }\n return { success: true, settings: allSettings, values: allValues };\n }\n\n private handleSetProviderSetting(args: any): CommandResult {\n const { providerType, key, value } = args || {};\n if (!providerType || !key || value === undefined) {\n return { success: false, error: 'providerType, key, and value are required' };\n }\n\n const result = (this.ctx.providerLoader as any)?.setSetting?.(providerType, key, value);\n if (result) {\n return { success: true, providerType, key, value };\n }\n return { success: false, error: `Failed to set ${providerType}.${key} — invalid key, value, or not a public setting` };\n }\n\n // ─── Extension Script Execution (Model/Mode) ─────\n\n /**\n * Generic handler for executing Extension provider CDP scripts.\n * args: { agentType, ideType?, model?, mode?, ... }\n * scriptName: 'listModels' | 'setModel' | 'listModes' | 'setMode'\n */\n private async handleExtensionScript(args: any, scriptName: string): Promise<CommandResult> {\n const { agentType, ideType } = args || {};\n console.log(`[ExtScript] ${scriptName} agentType=${agentType} ideType=${ideType} _currentIdeType=${this._currentIdeType}`);\n if (!agentType) return { success: false, error: 'agentType is required' };\n\n // Find Provider (agentType is actually target provider.type — could be IDE or Extension)\n const loader = this.ctx.providerLoader;\n if (!loader) return { success: false, error: 'ProviderLoader not initialized' };\n const provider = loader.get(agentType);\n if (!provider) return { success: false, error: `Provider not found: ${agentType}` };\n \n // Check if IDE category and webview script actually exists (e.g. kiro, pearai)\n const webviewScriptName = `webview${scriptName.charAt(0).toUpperCase() + scriptName.slice(1)}`;\n const hasWebviewScript = provider.category === 'ide' &&\n !!(provider.scripts as any)?.[webviewScriptName];\n \n const actualScriptName = hasWebviewScript ? webviewScriptName : scriptName;\n\n if (!provider.scripts?.[actualScriptName as keyof typeof provider.scripts]) {\n return { success: false, error: `Script '${actualScriptName}' not available for ${agentType}` };\n }\n\n // script create\n const scriptFn = provider.scripts[actualScriptName as keyof typeof provider.scripts] as Function;\n const scriptCode = scriptFn(args);\n if (!scriptCode) return { success: false, error: `Script '${actualScriptName}' returned null` };\n\n // Find CDP — _currentIdeType is multi-window key extracted from _targetInstance (e.g. 'antigravity_remote_vs')\n const cdpKey = provider.category === 'ide' ? (this._currentIdeType || agentType) : (this._currentIdeType || ideType);\n console.log(`[ExtScript] provider=${provider.type} category=${provider.category} cdpKey=${cdpKey}`);\n const cdp = this.getCdp(cdpKey);\n if (!cdp?.isConnected) return { success: false, error: `No CDP connection for ${cdpKey || 'any'}` };\n\n try {\n let result: unknown;\n\n if (provider.category === 'extension') {\n // Extension: execute from webview session\n const sessions = cdp.getAgentSessions();\n let targetSessionId: string | null = null;\n for (const [sessionId, target] of sessions) {\n if (target.agentType === agentType) {\n targetSessionId = sessionId;\n break;\n }\n }\n if (!targetSessionId) {\n return { success: false, error: `No active session found for ${agentType}` };\n }\n result = await cdp.evaluateInSession(targetSessionId, scriptCode);\n } else if (hasWebviewScript && cdp.evaluateInWebviewFrame) {\n // IDE webview script execute\n const matchText = provider.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n result = await cdp.evaluateInWebviewFrame(scriptCode, matchFn);\n } else {\n // IDE: execute directly from main CDP page\n result = await cdp.evaluate(scriptCode, 30000);\n }\n\n // JSON parsing attempt\n if (typeof result === 'string') {\n try {\n const parsed = JSON.parse(result);\n return { success: true, ...parsed };\n } catch {\n return { success: true, result };\n }\n }\n return { success: true, result };\n } catch (e: any) {\n return { success: false, error: `Script execution failed: ${e.message}` };\n }\n }\n\n // ─── IDE Extension Settings (per-IDE on/off) ─────\n\n private handleGetIdeExtensions(args: any): CommandResult {\n const { ideType } = args || {};\n const loader = this.ctx.providerLoader as any;\n if (!loader) return { success: false, error: 'ProviderLoader not initialized' };\n\n const allExtProviders = loader.getByCategory?.('extension') || [];\n const config = loadConfig();\n\n if (ideType) {\n // Return extension status of specific IDE\n const extensions = allExtProviders.map((p: any) => ({\n type: p.type,\n name: p.name,\n extensionId: p.extensionId,\n enabled: config.ideSettings?.[ideType]?.extensions?.[p.type]?.enabled === true,\n }));\n return { success: true, ideType, extensions };\n }\n\n // Extension status of all IDEs\n const connectedIdes = [...(this.ctx.cdpManagers?.keys?.() || [])];\n const result: Record<string, any[]> = {};\n for (const ide of connectedIdes) {\n result[ide] = allExtProviders.map((p: any) => ({\n type: p.type,\n name: p.name,\n extensionId: p.extensionId,\n enabled: config.ideSettings?.[ide]?.extensions?.[p.type]?.enabled === true,\n }));\n }\n return { success: true, ides: result };\n }\n\n private handleSetIdeExtension(args: any): CommandResult {\n const { ideType, extensionType, enabled } = args || {};\n if (!ideType || !extensionType || enabled === undefined) {\n return { success: false, error: 'ideType, extensionType, and enabled are required' };\n }\n const loader = this.ctx.providerLoader as any;\n if (!loader?.setIdeExtensionEnabled) {\n return { success: false, error: 'ProviderLoader not initialized' };\n }\n const ok = loader.setIdeExtensionEnabled(ideType, extensionType, !!enabled);\n if (ok) {\n return { success: true, ideType, extensionType, enabled: !!enabled };\n }\n return { success: false, error: 'Failed to save setting' };\n }\n}\n\nfunction home() { return os.homedir(); }\n","/**\n * Chat History Persistence — Persist completed chat messages to local disk\n * \n * Design:\n * - ~/.adhdev/history/{agentType}/YYYY-MM-DD.jsonl\n * - JSONL format (one line = one message, append-friendly)\n * - Track only new messages (hash comparison with previous)\n * - Auto-rotation (delete files older than 30 days)\n * - Async/non-blocking (no impact on chat collection)\n */\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\n\nconst HISTORY_DIR = path.join(os.homedir(), '.adhdev', 'history');\nconst RETAIN_DAYS = 30;\n\ninterface HistoryMessage {\n ts: string; // ISO timestamp\n receivedAt: number; // epoch ms\n role: 'user' | 'assistant' | 'system';\n content: string;\n agent: string; // e.g. 'antigravity', 'cursor', 'gemini-cli'\n instanceId?: string; // IDE instance UUID (distinguishes windows of the same agent type)\n sessionTitle?: string;\n}\n\nexport class ChatHistoryWriter {\n /** Last seen message count per agent (deduplication) */\n private lastSeenCounts = new Map<string, number>();\n /** Last seen message hash per agent (deduplication) */\n private lastSeenHashes = new Map<string, Set<string>>();\n private rotated = false;\n\n /**\n * Append new messages to history\n * \n * @param agentType agent type (e.g. 'antigravity', 'cursor')\n * @param messages Message array received from readChat\n * @param sessionTitle Current session title\n * @param instanceId IDE instance UUID (distinguishes windows of the same agent)\n */\n appendNewMessages(\n agentType: string,\n messages: Array<{ role: string; content: string; receivedAt?: number }>,\n sessionTitle?: string,\n instanceId?: string,\n ): void {\n if (!messages || messages.length === 0) return;\n\n try {\n // dedup key: agentType + instanceId\n const dedupKey = instanceId ? `${agentType}:${instanceId}` : agentType;\n let seenHashes = this.lastSeenHashes.get(dedupKey);\n if (!seenHashes) {\n seenHashes = new Set<string>();\n this.lastSeenHashes.set(dedupKey, seenHashes);\n }\n\n // Filter new messages\n const newMessages: HistoryMessage[] = [];\n for (const msg of messages) {\n const hash = `${msg.role}:${(msg.content || '').slice(0, 50)}`;\n if (seenHashes.has(hash)) continue;\n seenHashes.add(hash);\n newMessages.push({\n ts: new Date(msg.receivedAt || Date.now()).toISOString(),\n receivedAt: msg.receivedAt || Date.now(),\n role: msg.role as 'user' | 'assistant' | 'system',\n content: msg.content || '',\n agent: agentType,\n instanceId,\n sessionTitle,\n });\n }\n\n if (newMessages.length === 0) return;\n\n // Append to file — separate file if instanceId exists\n const dir = path.join(HISTORY_DIR, this.sanitize(agentType));\n fs.mkdirSync(dir, { recursive: true });\n\n const date = new Date().toISOString().slice(0, 10); // YYYY-MM-DD\n const filePrefix = instanceId ? `${this.sanitize(instanceId)}_` : '';\n const filePath = path.join(dir, `${filePrefix}${date}.jsonl`);\n const lines = newMessages.map(m => JSON.stringify(m)).join('\\n') + '\\n';\n fs.appendFileSync(filePath, lines, 'utf-8');\n\n // Detect session switch — reset hash if message count decreases\n const prevCount = this.lastSeenCounts.get(dedupKey) || 0;\n if (messages.length < prevCount * 0.5 && prevCount > 3) {\n seenHashes.clear();\n for (const msg of messages) {\n seenHashes.add(`${msg.role}:${(msg.content || '').slice(0, 50)}`);\n }\n }\n this.lastSeenCounts.set(dedupKey, messages.length);\n\n // Rotate only once on first call\n if (!this.rotated) {\n this.rotated = true;\n this.rotateOldFiles().catch(() => {});\n }\n } catch {\n // Ignore history save failures (must not affect main functionality)\n }\n }\n\n /** Called when agent session is explicitly changed */\n onSessionChange(agentType: string): void {\n this.lastSeenHashes.delete(agentType);\n this.lastSeenCounts.delete(agentType);\n }\n\n /** Delete history files older than 30 days */\n private async rotateOldFiles(): Promise<void> {\n try {\n if (!fs.existsSync(HISTORY_DIR)) return;\n const cutoff = Date.now() - RETAIN_DAYS * 24 * 60 * 60 * 1000;\n\n const agentDirs = fs.readdirSync(HISTORY_DIR, { withFileTypes: true })\n .filter(d => d.isDirectory());\n\n for (const dir of agentDirs) {\n const dirPath = path.join(HISTORY_DIR, dir.name);\n const files = fs.readdirSync(dirPath)\n .filter(f => f.endsWith('.jsonl'));\n\n for (const file of files) {\n const filePath = path.join(dirPath, file);\n const stat = fs.statSync(filePath);\n if (stat.mtimeMs < cutoff) {\n fs.unlinkSync(filePath);\n }\n }\n }\n } catch {\n // Ignore rotate failure\n }\n }\n\n /** Allow only filename-safe characters */\n private sanitize(name: string): string {\n return name.replace(/[^a-zA-Z0-9_-]/g, '_');\n }\n}\n\n/**\n * Read history (static — called from P2P commands)\n * \n * Read JSONL files in reverse order, returning most recent messages first.\n * When instanceId is specified, reads only that instance file.\n * Offset/limit-based paging.\n */\nexport function readChatHistory(\n agentType: string,\n offset: number = 0,\n limit: number = 30,\n instanceId?: string,\n): { messages: HistoryMessage[]; hasMore: boolean } {\n try {\n const sanitized = agentType.replace(/[^a-zA-Z0-9_-]/g, '_');\n const dir = path.join(HISTORY_DIR, sanitized);\n if (!fs.existsSync(dir)) return { messages: [], hasMore: false };\n\n // JSONL file list — only matching prefix if instanceId is specified\n const sanitizedInstance = instanceId?.replace(/[^a-zA-Z0-9_-]/g, '_');\n const files = fs.readdirSync(dir)\n .filter(f => {\n if (!f.endsWith('.jsonl')) return false;\n if (sanitizedInstance) {\n return f.startsWith(`${sanitizedInstance}_`);\n }\n // Without instanceId, only files without prefix (legacy compatible)\n return !f.includes('_') || f.match(/^\\d{4}-\\d{2}-\\d{2}\\.jsonl$/);\n })\n .sort()\n .reverse();\n\n // Read lines from all files (reverse order)\n const allMessages: HistoryMessage[] = [];\n const needed = offset + limit + 1; // hasMore check +1\n\n for (const file of files) {\n if (allMessages.length >= needed) break;\n const filePath = path.join(dir, file);\n const content = fs.readFileSync(filePath, 'utf-8');\n const lines = content.trim().split('\\n').filter(Boolean);\n \n // Parse in reverse order\n for (let i = lines.length - 1; i >= 0; i--) {\n if (allMessages.length >= needed) break;\n try {\n allMessages.push(JSON.parse(lines[i]));\n } catch { /* skip invalid lines */ }\n }\n }\n\n // offset/limit apply\n const sliced = allMessages.slice(offset, offset + limit);\n const hasMore = allMessages.length > offset + limit;\n\n // Sort in chronological order (top→bottom = oldest→newest)\n sliced.reverse();\n\n return { messages: sliced, hasMore };\n } catch {\n return { messages: [], hasMore: false };\n }\n}\n","/**\n * DaemonStatusReporter — status collect & transmit (StatusReport / P2P / StatusEvent)\n *\n * Collect status from ProviderInstanceManager → assemble payload → transmit\n * Each Instance manages its own status/transition. This module only assembles + transmits.\n */\n\nimport * as os from 'os';\nimport * as path from 'path';\nimport { loadConfig } from './config.js';\nimport { LOG } from './daemon-logger.js';\n\n// ─── Daemon dependency interface ──────────────────────\n\nexport interface StatusReporterDeps {\n serverConn: { isConnected(): boolean; sendMessage(type: string, data: any): void; getUserPlan(): string } | null;\n cdpManagers: Map<string, { isConnected: boolean }>;\n p2p: { isConnected: boolean; isAvailable: boolean; connectionState: string; connectedPeerCount: number; screenshotActive: boolean; sendStatus(data: any): void } | null;\n providerLoader: { resolve(type: string): any; getAll(): any[] };\n adapters: Map<string, { cliType: string; cliName: string; workingDir: string; getStatus(): any; getPartialResponse(): string }>;\n detectedIdes: any[];\n ideType: string;\n instanceManager: { collectAllStates(): any[]; collectStatesByCategory(cat: string): any[] };\n}\n\nexport class DaemonStatusReporter {\n private deps: StatusReporterDeps;\n private log: (msg: string) => void;\n\n private lastStatusSentAt = 0;\n private statusPendingThrottle = false;\n private lastP2PStatusHash = '';\n private lastStatusSummary = '';\n\n private statusTimer: NodeJS.Timeout | null = null;\n private p2pTimer: NodeJS.Timeout | null = null;\n\n constructor(deps: StatusReporterDeps, opts?: { logFn?: (msg: string) => void }) {\n this.deps = deps;\n this.log = opts?.logFn || console.log;\n }\n\n // ─── Lifecycle ───────────────────────────────────\n\n startReporting(): void {\n setTimeout(() => {\n this.sendUnifiedStatusReport().catch(e => console.warn('[StatusReport] Initial report failed:', e?.message));\n }, 2000);\n\n const scheduleServerReport = () => {\n this.statusTimer = setTimeout(() => {\n this.sendUnifiedStatusReport().catch(e => console.warn('[StatusReport] Periodic report failed:', e?.message));\n scheduleServerReport();\n }, 30_000);\n };\n scheduleServerReport();\n\n this.p2pTimer = setInterval(() => {\n if (this.deps.p2p?.isConnected) {\n this.sendUnifiedStatusReport({ p2pOnly: true }).catch(e => console.warn('[P2P] Status send failed:', e?.message));\n }\n }, 5_000) as any;\n }\n\n stopReporting(): void {\n if (this.statusTimer) { clearTimeout(this.statusTimer); this.statusTimer = null; }\n if (this.p2pTimer) { clearInterval(this.p2pTimer); this.p2pTimer = null; }\n }\n\n onStatusChange(): void {\n this.throttledReport();\n }\n\n throttledReport(): void {\n const now = Date.now();\n const elapsed = now - this.lastStatusSentAt;\n if (elapsed >= 5_000) {\n this.sendUnifiedStatusReport().catch(e => console.warn('[StatusReport] Throttled report failed:', e?.message));\n } else if (!this.statusPendingThrottle) {\n this.statusPendingThrottle = true;\n setTimeout(() => {\n this.statusPendingThrottle = false;\n this.sendUnifiedStatusReport().catch(e => console.warn('[StatusReport] Deferred report failed:', e?.message));\n }, 5_000 - elapsed);\n }\n }\n\n emitStatusEvent(event: Record<string, unknown>): void {\n LOG.info('StatusEvent', `${event.event} (${event.providerType || event.ideType || ''})`);\n this.deps.serverConn?.sendMessage('status_event', event);\n }\n\n removeAgentTracking(_key: string): void { /* Managed by Instance itself */ }\n\n // (agent-stream polling backward compat)\n updateAgentStreams(_ideType: string, _streams: any[]): void { /* Managed by Instance itself */ }\n\n // ─── Core ────────────────────────────────────────\n\n private ts(): string {\n return new Date().toISOString().slice(11, 23); // HH:mm:ss.SSS\n }\n\n async sendUnifiedStatusReport(opts?: { p2pOnly?: boolean }): Promise<void> {\n const { serverConn, cdpManagers, p2p, providerLoader, adapters } = this.deps;\n if (!serverConn?.isConnected()) return;\n this.lastStatusSentAt = Date.now();\n const now = this.lastStatusSentAt;\n const target = opts?.p2pOnly ? 'P2P' : 'P2P+Server';\n\n const allStates = this.deps.instanceManager.collectAllStates();\n const ideStates = allStates.filter((s: any) => s.category === 'ide');\n const cliStates = allStates.filter((s: any) => s.category === 'cli');\n const acpStates = allStates.filter((s: any) => s.category === 'acp');\n\n // IDE summary\n const ideSummary = ideStates.map((s: any) => {\n const msgs = s.activeChat?.messages?.length || 0;\n const exts = (s.extensions || []).length;\n return `${s.type}(${s.status},${msgs}msg,${exts}ext${s.currentModel ? ',model=' + s.currentModel : ''})`;\n }).join(', ');\n\n // CLI summary\n const cliSummary = cliStates.map((s: any) => `${s.type}(${s.status})`).join(', ');\n // ACP summary\n const acpSummary = acpStates.map((s: any) => `${s.type}(${s.status})`).join(', ');\n\n // P2P-only = 5s heartbeat → DEBUG, P2P+Server = 30s interval → INFO\n const logLevel = opts?.p2pOnly ? 'debug' : 'info';\n const summary = `→${target} IDE: ${ideStates.length} [${ideSummary}] CLI: ${cliStates.length} [${cliSummary}] ACP: ${acpStates.length} [${acpSummary}]`;\n // At DEBUG level, only log on status change (skip identical repeats)\n if (logLevel === 'debug') {\n if (summary !== this.lastStatusSummary) {\n this.lastStatusSummary = summary;\n LOG.debug('StatusReport', summary);\n }\n } else {\n this.lastStatusSummary = summary;\n LOG.info('StatusReport', summary);\n }\n\n // IDE states → managedIdes\n const managedIdes: any[] = ideStates.map((s: any) => ({\n ideType: s.type,\n ideVersion: '',\n instanceId: s.instanceId,\n workspaceFolders: s.workspaceFolders || [],\n activeFile: s.activeFile || null,\n terminals: 0,\n aiAgents: [],\n activeChat: s.activeChat,\n chats: [],\n agentStreams: (s.extensions || []).map((ext: any) => ({\n agentType: ext.type,\n agentName: ext.name,\n extensionId: ext.type,\n status: ext.status || 'idle',\n messages: ext.activeChat?.messages || [],\n inputContent: ext.activeChat?.inputContent || '',\n activeModal: ext.activeChat?.activeModal || null,\n })),\n cdpConnected: s.cdpConnected || false,\n currentModel: s.currentModel,\n currentPlan: s.currentPlan,\n currentAutoApprove: s.currentAutoApprove,\n }));\n\n // Merge/add Extension data\n\n\n // CLI states → managedClis\n const managedClis: any[] = cliStates.map((s: any) => ({\n id: s.instanceId,\n instanceId: s.instanceId,\n cliType: s.type,\n cliName: s.name,\n status: s.status,\n mode: s.mode || 'terminal',\n workingDir: s.workingDir || '',\n activeChat: s.activeChat,\n }));\n\n // ACP states → managedAcps (separated into per-type arrays)\n const managedAcps: any[] = acpStates.map((s: any) => ({\n id: s.instanceId,\n acpType: s.type,\n acpName: s.name,\n status: s.status,\n mode: 'chat',\n workingDir: s.workingDir || '',\n activeChat: s.activeChat,\n currentModel: s.currentModel,\n currentPlan: s.currentPlan,\n acpConfigOptions: s.acpConfigOptions,\n acpModes: s.acpModes,\n }));\n\n\n\n // ═══ Assemble payload (P2P — required data only) ═══\n const payload: Record<string, any> = {\n daemonMode: true,\n machineNickname: loadConfig().machineNickname || null,\n machine: {\n hostname: os.hostname(),\n platform: os.platform(),\n arch: os.arch(),\n cpus: os.cpus().length,\n totalMem: os.totalmem(),\n freeMem: os.freemem(),\n loadavg: os.loadavg(),\n uptime: os.uptime(),\n },\n managedIdes,\n managedClis,\n managedAcps,\n p2p: {\n available: p2p?.isAvailable || false,\n state: p2p?.connectionState || 'unavailable',\n peers: p2p?.connectedPeerCount || 0,\n screenshotActive: p2p?.screenshotActive || false,\n },\n cdpConnected: [...cdpManagers.values()].some(c => c.isConnected),\n connectedExtensions: [],\n detectedIdes: this.deps.detectedIdes || [],\n availableProviders: this.deps.providerLoader.getAll().map((p: any) => ({\n type: p.type, icon: p.icon || '💻', displayName: p.displayName || p.type,\n category: p.category,\n })),\n timestamp: now,\n };\n\n // ═══ P2P transmit ═══\n const p2pSent = this.sendP2PPayload(payload);\n if (p2pSent) {\n LOG.debug('P2P', `sent (${JSON.stringify(payload).length} bytes)`);\n }\n\n // ═══ Server transmit (minimal routing meta only — sanitizeForRelay removes everything else) ═══\n if (opts?.p2pOnly) return;\n const plan = serverConn.getUserPlan();\n if (plan !== 'free') {\n const wsPayload = {\n daemonMode: true,\n machineNickname: payload.machineNickname,\n // managedIdes: server only saves id, type, cdpConnected\n managedIdes: managedIdes.map(ide => ({\n ideType: ide.ideType,\n instanceId: ide.instanceId,\n cdpConnected: ide.cdpConnected,\n })),\n // managedClis: server only saves id, type, name\n managedClis: managedClis.map(c => ({\n id: c.id, cliType: c.cliType, cliName: c.cliName,\n })),\n // managedAcps: server only saves id, type, name\n managedAcps: managedAcps?.map((a: any) => ({\n id: a.id, acpType: a.acpType, acpName: a.acpName,\n })),\n p2p: payload.p2p,\n cdpConnected: payload.cdpConnected,\n timestamp: now,\n };\n serverConn.sendMessage('status_report', wsPayload);\n LOG.debug('Server', `sent status_report (${JSON.stringify(wsPayload).length} bytes)`);\n }\n }\n\n // ─── P2P ─────────────────────────────────────────\n\n private sendP2PPayload(payload: Record<string, any>): boolean {\n const { timestamp: _ts, system: _sys, ...hashTarget } = payload;\n if (hashTarget.machine) {\n const { freeMem: _f, loadavg: _l, uptime: _u, ...stableMachine } = hashTarget.machine as any;\n hashTarget.machine = stableMachine;\n }\n const h = this.simpleHash(JSON.stringify(hashTarget));\n if (h !== this.lastP2PStatusHash) {\n this.lastP2PStatusHash = h;\n this.deps.p2p?.sendStatus(payload);\n return true;\n }\n return false;\n }\n\n private simpleHash(s: string): string {\n let h = 0x811c9dc5;\n for (let i = 0; i < s.length; i++) {\n h ^= s.charCodeAt(i);\n h = (h * 0x01000193) >>> 0;\n }\n return h.toString(36);\n }\n}\n","/**\n * ADHDev Daemon — unified logger (v2)\n * \n * log level: DEBUG < INFO < WARN < ERROR\n * \n * Features:\n * 1. daemonLog(category, msg, level) — explicit per-category logging\n * 2. installGlobalInterceptor() — Auto-intercept console.log (once on daemon start)\n * 3. Recent log ring buffer — for remote transmission via P2P/WS\n * 4. File logging — ~/Library/Logs/adhdev/daemon.log (10MB rolling)\n * \n * use:\n * import { daemonLog, LOG } from './daemon-logger';\n * LOG.info('CDP', 'Connected to cursor on port 9333');\n * LOG.debug('StatusReport', 'P2P heartbeat sent');\n * LOG.warn('IdeInstance', 'onTick error: ...');\n * LOG.error('Server', 'WebSocket disconnected');\n */\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\n\n// ─── Log Level ──────────────────────────────\nexport type LogLevel = 'debug' | 'info' | 'warn' | 'error';\n\nconst LEVEL_NUM: Record<LogLevel, number> = { debug: 0, info: 1, warn: 2, error: 3 };\nconst LEVEL_LABEL: Record<LogLevel, string> = { debug: 'DBG', info: 'INF', warn: 'WRN', error: 'ERR' };\n\nlet currentLevel: LogLevel = 'info';\n\nexport function setLogLevel(level: LogLevel): void {\n currentLevel = level;\n daemonLog('Logger', `Log level set to: ${level}`, 'info');\n}\n\nexport function getLogLevel(): LogLevel { return currentLevel; }\n// ─── File logging (date-based rolling) ──────────────────────────────\nconst LOG_DIR = process.platform === 'darwin'\n ? path.join(os.homedir(), 'Library', 'Logs', 'adhdev')\n : path.join(os.homedir(), '.local', 'share', 'adhdev', 'logs');\n\nconst MAX_LOG_SIZE = 5 * 1024 * 1024; // 5MB per day\nconst MAX_LOG_DAYS = 7; // 7-day retention\n\ntry { fs.mkdirSync(LOG_DIR, { recursive: true }); } catch { }\n\nfunction getDateStr(): string {\n return new Date().toISOString().slice(0, 10); // YYYY-MM-DD\n}\n\nlet currentDate = getDateStr();\nlet currentLogFile = path.join(LOG_DIR, `daemon-${currentDate}.log`);\n\n/** date change detect + old file cleanup */\nfunction checkDateRotation(): void {\n const today = getDateStr();\n if (today !== currentDate) {\n currentDate = today;\n currentLogFile = path.join(LOG_DIR, `daemon-${currentDate}.log`);\n cleanOldLogs();\n }\n}\n\n/** Auto-delete log files older than MAX_LOG_DAYS */\nfunction cleanOldLogs(): void {\n try {\n const files = fs.readdirSync(LOG_DIR).filter(f => f.startsWith('daemon-') && f.endsWith('.log'));\n const cutoff = new Date();\n cutoff.setDate(cutoff.getDate() - MAX_LOG_DAYS);\n const cutoffStr = cutoff.toISOString().slice(0, 10);\n for (const file of files) {\n const dateMatch = file.match(/daemon-(\\d{4}-\\d{2}-\\d{2})/);\n if (dateMatch && dateMatch[1] < cutoffStr) {\n try { fs.unlinkSync(path.join(LOG_DIR, file)); } catch { }\n }\n }\n } catch { }\n}\n\n/** Roll to .1 file when size limit reached within same date */\nfunction rotateSizeIfNeeded(): void {\n try {\n const stat = fs.statSync(currentLogFile);\n if (stat.size > MAX_LOG_SIZE) {\n const backup = currentLogFile.replace('.log', '.1.log');\n try { fs.unlinkSync(backup); } catch { }\n fs.renameSync(currentLogFile, backup);\n }\n } catch { /* file doesn't exist yet */ }\n}\n\n// start when cleanup\ncleanOldLogs();\n// Migrate existing daemon.log, daemon.log.old (if present)\ntry {\n const oldLog = path.join(LOG_DIR, 'daemon.log');\n if (fs.existsSync(oldLog)) {\n const stat = fs.statSync(oldLog);\n const oldDate = stat.mtime.toISOString().slice(0, 10);\n fs.renameSync(oldLog, path.join(LOG_DIR, `daemon-${oldDate}.log`));\n }\n const oldLogBackup = path.join(LOG_DIR, 'daemon.log.old');\n if (fs.existsSync(oldLogBackup)) { fs.unlinkSync(oldLogBackup); }\n} catch { }\n\nlet writeCount = 0;\n\nfunction writeToFile(line: string): void {\n try {\n // Check date change + file size every 1000 writes\n if (++writeCount % 1000 === 0) {\n checkDateRotation();\n rotateSizeIfNeeded();\n }\n fs.appendFileSync(currentLogFile, line + '\\n');\n } catch { }\n}\n\n// ─── Ring buffer (for remote transmission) ─────────────────\nexport interface LogEntry {\n ts: number;\n level: LogLevel;\n category: string;\n message: string;\n}\n\nconst RING_BUFFER_SIZE = 200;\nconst ringBuffer: LogEntry[] = [];\n\n/** Get recent N logs (for remote transmission) */\nexport function getRecentLogs(count = 50, minLevel: LogLevel = 'info'): LogEntry[] {\n const minNum = LEVEL_NUM[minLevel];\n const filtered = ringBuffer.filter(e => LEVEL_NUM[e.level] >= minNum);\n return filtered.slice(-count);\n}\n\n/** Ring buffer current size */\nexport function getLogBufferSize(): number { return ringBuffer.length; }\n\n// ─── Timestamp ─────────────────────────────\nfunction ts(): string {\n return new Date().toISOString().slice(11, 23); // HH:mm:ss.SSS\n}\n\nfunction fullTs(): string {\n return new Date().toISOString();\n}\n\n// ─── Preserve original console ──────────────────────\nconst origConsoleLog = console.log.bind(console);\nconst origConsoleError = console.error.bind(console);\nconst origConsoleWarn = console.warn.bind(console);\n\n// ─── Core logging function ─────────────────────────\n\n/**\n * Explicit per-category logging\n * level filter apply, File logging, Ring buffer save\n */\nexport function daemonLog(category: string, msg: string, level: LogLevel = 'info'): void {\n // Level filter (console output)\n const shouldOutput = LEVEL_NUM[level] >= LEVEL_NUM[currentLevel];\n\n const label = LEVEL_LABEL[level];\n const line = `[${ts()}] [${label}] [${category}] ${msg}`;\n\n // Always record to file (including DEBUG)\n writeToFile(line);\n\n // Always save to ring buffer (for remote transmission)\n ringBuffer.push({ ts: Date.now(), level, category, message: msg });\n if (ringBuffer.length > RING_BUFFER_SIZE) {\n ringBuffer.splice(0, ringBuffer.length - RING_BUFFER_SIZE);\n }\n\n // Apply filter to console output\n if (shouldOutput) {\n origConsoleLog(line);\n }\n}\n\n// ─── Convenience API ────────────────────────────────\n\n/**\n * LOG.info('CDP', 'Connected') — concise logging API\n */\nexport const LOG = {\n debug: (category: string, msg: string) => daemonLog(category, msg, 'debug'),\n info: (category: string, msg: string) => daemonLog(category, msg, 'info'),\n warn: (category: string, msg: string) => daemonLog(category, msg, 'warn'),\n error: (category: string, msg: string) => daemonLog(category, msg, 'error'),\n};\n\n// ─── CDP log factory ──────────────────────\n\n/**\n * CDP log logFn factory\n * Use as DaemonCdpManager's logFn\n */\nexport function cdpLogFn(ideType: string): (msg: string) => void {\n return (msg: string) => {\n // CDP log during heartbeat/repeat log DEBUGas classify\n const isDebug = msg.includes('discoverAgentWebviews:') && !msg.includes('Found agent')\n || msg.includes('[P2P] sent');\n daemonLog(`CDP:${ideType}`, msg, isDebug ? 'debug' : 'info');\n };\n}\n\n// ─── global interceptor ────────────────────────\n\nlet interceptorInstalled = false;\n\n/**\n * console.log/warn/error global interceptor install\n * Prevent recording in places not using daemonLog.\n * daemon start when 1time call.\n */\nexport function installGlobalInterceptor(): void {\n if (interceptorInstalled) return;\n interceptorInstalled = true;\n\n const stripAnsi = (str: string) => str.replace(/\\x1B\\[[0-9;]*m/g, '');\n\n // Ignore lines already recorded via daemonLog (prevent duplicates)\n const isDaemonLogLine = (msg: string) => /\\[(DBG|INF|WRN|ERR)\\]/.test(msg);\n\n console.log = (...args: any[]) => {\n origConsoleLog(...args);\n try {\n const msg = args.map(a => typeof a === 'string' ? a : JSON.stringify(a)).join(' ');\n const clean = stripAnsi(msg);\n // Skip lines not yet recorded via daemonLog\n if (isDaemonLogLine(clean)) return;\n const line = clean.startsWith('[20') ? clean : `[${fullTs()}] ${clean}`;\n writeToFile(line);\n // Also save to ring buffer (auto-detect category)\n const catMatch = clean.match(/\\[([^\\]]+)\\]/);\n ringBuffer.push({\n ts: Date.now(),\n level: 'info',\n category: catMatch?.[1] || 'System',\n message: clean,\n });\n if (ringBuffer.length > RING_BUFFER_SIZE) {\n ringBuffer.splice(0, ringBuffer.length - RING_BUFFER_SIZE);\n }\n } catch { }\n };\n\n console.error = (...args: any[]) => {\n origConsoleError(...args);\n try {\n const msg = args.map(a => typeof a === 'string' ? a : JSON.stringify(a)).join(' ');\n const clean = stripAnsi(msg);\n if (isDaemonLogLine(clean)) return;\n const line = `[${fullTs()}] [ERROR] ${clean}`;\n writeToFile(line);\n ringBuffer.push({ ts: Date.now(), level: 'error', category: 'System', message: clean });\n if (ringBuffer.length > RING_BUFFER_SIZE) {\n ringBuffer.splice(0, ringBuffer.length - RING_BUFFER_SIZE);\n }\n } catch { }\n };\n\n console.warn = (...args: any[]) => {\n origConsoleWarn(...args);\n try {\n const msg = args.map(a => typeof a === 'string' ? a : JSON.stringify(a)).join(' ');\n const clean = stripAnsi(msg);\n if (isDaemonLogLine(clean)) return;\n const line = `[${fullTs()}] [WARN] ${clean}`;\n writeToFile(line);\n ringBuffer.push({ ts: Date.now(), level: 'warn', category: 'System', message: clean });\n if (ringBuffer.length > RING_BUFFER_SIZE) {\n ringBuffer.splice(0, ringBuffer.length - RING_BUFFER_SIZE);\n }\n } catch { }\n };\n\n writeToFile(`\\n=== ADHDev Daemon started at ${fullTs()} ===`);\n writeToFile(`Log file: ${currentLogFile}`);\n writeToFile(`Log level: ${currentLevel}`);\n}\n\n/** current log file path (dateper) */\nexport function getLogPath(): string { return currentLogFile; }\n/** LOG_PATH — backward compat (current date file) */\nexport const LOG_PATH = path.join(LOG_DIR, `daemon-${getDateStr()}.log`);\nexport const LOG_DIR_PATH = LOG_DIR;\n","/**\n * ADHDev Daemon — Command History Logger\n * \n * Record all commands from dashboard/WS/P2P/Extension/API to local file.\n * Per-date JSONL file, 7-day retention, 5MB limit.\n * \n * Purpose:\n * - Debugging: track what command came and when\n * - Audit: record all commands executed from remote\n * - Stats: identify frequently used features\n */\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\n\n// ─── Config ──────────────────────────────────\nconst LOG_DIR = process.platform === 'darwin'\n ? path.join(os.homedir(), 'Library', 'Logs', 'adhdev')\n : path.join(os.homedir(), '.local', 'share', 'adhdev', 'logs');\n\nconst MAX_FILE_SIZE = 5 * 1024 * 1024; // 5MB\nconst MAX_DAYS = 7;\n\ntry { fs.mkdirSync(LOG_DIR, { recursive: true }); } catch { }\n\n// ─── Types ───────────────────────────────────\nexport interface CommandLogEntry {\n ts: string; // ISO timestamp\n cmd: string; // command name\n source: 'ws' | 'p2p' | 'ext' | 'api' | 'standalone' | 'unknown'; // where it came from\n args?: Record<string, unknown>; // command arguments (sensitive values masked)\n success?: boolean; // result\n error?: string; // error message if failed\n durationMs?: number; // execution time\n}\n\n// ─── Sensitive field masking ─────────────────\nconst SENSITIVE_KEYS = new Set([\n 'token', 'password', 'secret', 'apiKey', 'api_key',\n 'connectionToken', 'content', 'message', 'text',\n]);\n\nfunction maskArgs(args: any): Record<string, unknown> | undefined {\n if (!args || typeof args !== 'object') return undefined;\n const masked: Record<string, unknown> = {};\n for (const [key, value] of Object.entries(args)) {\n if (SENSITIVE_KEYS.has(key)) {\n masked[key] = typeof value === 'string'\n ? `[${value.length} chars]`\n : '[masked]';\n } else if (key.startsWith('_')) {\n // internal fields: keep as-is (e.g. _targetType, _targetInstance)\n masked[key] = value;\n } else if (typeof value === 'object' && value !== null) {\n // Don't recurse deeply — just note the type\n masked[key] = Array.isArray(value)\n ? `[Array(${value.length})]`\n : `[Object]`;\n } else {\n masked[key] = value;\n }\n }\n return masked;\n}\n\n// ─── File management ─────────────────────────\nfunction getDateStr(): string {\n return new Date().toISOString().slice(0, 10);\n}\n\nlet currentDate = getDateStr();\nlet currentFile = path.join(LOG_DIR, `commands-${currentDate}.jsonl`);\nlet writeCount = 0;\n\nfunction checkRotation(): void {\n const today = getDateStr();\n if (today !== currentDate) {\n currentDate = today;\n currentFile = path.join(LOG_DIR, `commands-${currentDate}.jsonl`);\n cleanOldFiles();\n }\n}\n\nfunction cleanOldFiles(): void {\n try {\n const files = fs.readdirSync(LOG_DIR).filter(f => f.startsWith('commands-') && f.endsWith('.jsonl'));\n const cutoff = new Date();\n cutoff.setDate(cutoff.getDate() - MAX_DAYS);\n const cutoffStr = cutoff.toISOString().slice(0, 10);\n for (const file of files) {\n const dateMatch = file.match(/commands-(\\d{4}-\\d{2}-\\d{2})/);\n if (dateMatch && dateMatch[1] < cutoffStr) {\n try { fs.unlinkSync(path.join(LOG_DIR, file)); } catch { }\n }\n }\n } catch { }\n}\n\nfunction checkSize(): void {\n try {\n const stat = fs.statSync(currentFile);\n if (stat.size > MAX_FILE_SIZE) {\n const backup = currentFile.replace('.jsonl', '.1.jsonl');\n try { fs.unlinkSync(backup); } catch { }\n fs.renameSync(currentFile, backup);\n }\n } catch { /* file doesn't exist yet */ }\n}\n\n// ─── Noise filter ────────────────────────────\n// These commands are too frequent / low-value to log\nconst SKIP_COMMANDS = new Set([\n 'heartbeat',\n 'status_report',\n]);\n\n// ─── Public API ──────────────────────────────\n\n/**\n * Log a command received from the dashboard/WS/P2P/extension/API.\n * Call this at the entry point of command handling.\n */\nexport function logCommand(entry: CommandLogEntry): void {\n if (SKIP_COMMANDS.has(entry.cmd)) return;\n \n try {\n if (++writeCount % 500 === 0) {\n checkRotation();\n checkSize();\n }\n \n const line = JSON.stringify({\n ts: entry.ts,\n cmd: entry.cmd,\n src: entry.source,\n ...(entry.args ? { args: maskArgs(entry.args) } : {}),\n ...(entry.success !== undefined ? { ok: entry.success } : {}),\n ...(entry.error ? { err: entry.error } : {}),\n ...(entry.durationMs !== undefined ? { ms: entry.durationMs } : {}),\n });\n \n fs.appendFileSync(currentFile, line + '\\n');\n } catch { /* never crash the daemon for logging */ }\n}\n\n/**\n * Read recent command history (for dashboard display / debugging)\n */\nexport function getRecentCommands(count = 50): CommandLogEntry[] {\n try {\n if (!fs.existsSync(currentFile)) return [];\n const content = fs.readFileSync(currentFile, 'utf-8');\n const lines = content.trim().split('\\n').filter(Boolean);\n return lines.slice(-count).map(line => {\n try {\n const parsed = JSON.parse(line);\n return {\n ts: parsed.ts,\n cmd: parsed.cmd,\n source: parsed.src,\n args: parsed.args,\n success: parsed.ok,\n error: parsed.err,\n durationMs: parsed.ms,\n };\n } catch {\n return { ts: '', cmd: 'parse_error', source: 'unknown' as const };\n }\n });\n } catch {\n return [];\n }\n}\n\n/** Current command log file path */\nexport function getCommandLogPath(): string { return currentFile; }\n\n// Initial cleanup\ncleanOldFiles();\n","/**\n * DaemonCliManager — CLI session creation, management, and command handling\n *\n * Separated from adhdev-daemon.ts.\n * CLI cases of createAdapter, startCliSession, stopCliSession, executeDaemonCommand extracted to independent module extract.\n */\n\nimport * as os from 'os';\nimport * as path from 'path';\nimport * as crypto from 'crypto';\nimport chalk from 'chalk';\nimport { ProviderCliAdapter } from './cli-adapters/provider-cli-adapter.js';\nimport { detectCLI } from './cli-detector.js';\nimport { loadConfig, saveConfig, addCliHistory } from './config.js';\nimport { CliProviderInstance } from './providers/cli-provider-instance.js';\nimport { AcpProviderInstance } from './providers/acp-provider-instance.js';\nimport type { ProviderInstanceManager } from './providers/provider-instance-manager.js';\nimport { ProviderLoader } from './providers/provider-loader.js';\nimport type { CliAdapter } from './cli-adapter-types.js';\n\n// ─── external dependency interface ──────────────────────────\n\nexport interface CliManagerDeps {\n /** Server connection — injected into adapter */\n getServerConn(): any | null;\n /** P2P — PTY output transmit */\n getP2p(): { broadcastPtyOutput(key: string, data: string): void } | null;\n /** StatusReporter callback */\n onStatusChange(): void;\n removeAgentTracking(key: string): void;\n /** InstanceManager — register in CLI unified status */\n getInstanceManager(): ProviderInstanceManager | null;\n}\n\ntype CommandResult = { success: boolean;[key: string]: unknown };\n\n// ─── DaemonCliManager ────────────────────────────\n\nexport class DaemonCliManager {\n readonly adapters = new Map<string, CliAdapter>();\n private deps: CliManagerDeps;\n private providerLoader: ProviderLoader;\n\n constructor(deps: CliManagerDeps, providerLoader: ProviderLoader) {\n this.deps = deps;\n this.providerLoader = providerLoader;\n }\n\n // ─── Key create ─────────────────────────────────\n\n getCliKey(cliType: string, dir: string): string {\n const hash = require('crypto').createHash('md5').update(require('path').resolve(dir)).digest('hex').slice(0, 8);\n return `${cliType}_${hash}`;\n }\n\n private createAdapter(cliType: string, workingDir: string, cliArgs?: string[]): CliAdapter {\n // cliType normalize (Resolve alias)\n const normalizedType = this.providerLoader.resolveAlias(cliType);\n\n // Load CLI config from provider.js\n const provider = this.providerLoader.get(normalizedType);\n if (provider && provider.category === 'cli' && provider.patterns && provider.spawn) {\n console.log(chalk.cyan(` 📦 Using provider: ${provider.name} (${provider.type})`));\n return new ProviderCliAdapter(provider as any, workingDir, cliArgs);\n }\n\n throw new Error(`No CLI provider found for '${cliType}'. Create a provider.js in providers/cli/${cliType}/`);\n }\n\n // ─── Session start/management ──────────────────────────────\n\n async startSession(cliType: string, workingDir: string, cliArgs?: string[], initialModel?: string): Promise<void> {\n const trimmed = (workingDir || os.homedir()).trim();\n const resolvedDir = trimmed.startsWith('~')\n ? trimmed.replace(/^~/, os.homedir())\n : path.resolve(trimmed);\n\n // cliType normalize (Resolve alias)\n const normalizedType = this.providerLoader.resolveAlias(cliType);\n const provider = this.providerLoader.getByAlias(cliType);\n\n // Create UUID-based key (allows separate instances even for same type+dir)\n const key = crypto.randomUUID();\n\n // ─── ACP category handle ───\n if (provider && provider.category === 'acp') {\n const instanceManager = this.deps.getInstanceManager();\n if (!instanceManager) throw new Error('InstanceManager not available');\n\n // Check if command is installed\n const spawnCmd = provider.spawn?.command;\n if (spawnCmd) {\n try {\n const { execSync } = require('child_process');\n execSync(`which ${spawnCmd}`, { stdio: 'ignore' });\n } catch {\n const installInfo = provider.install || `Install: check ${provider.displayName || provider.name} documentation`;\n throw new Error(\n `${provider.displayName || provider.name} is not installed.\\n` +\n `Command '${spawnCmd}' not found in PATH.\\n\\n` +\n `${installInfo}`\n );\n }\n }\n\n console.log(chalk.cyan(` 🔌 Starting ACP agent: ${provider.name} (${provider.type}) in ${resolvedDir}`));\n\n const acpInstance = new AcpProviderInstance(provider, resolvedDir, cliArgs);\n await instanceManager.addInstance(key, acpInstance, {\n settings: this.providerLoader.getSettings(normalizedType),\n });\n\n // Register ACP entry in adapter map (getStatus queries from acpInstance in real-time)\n this.adapters.set(key, {\n cliType: normalizedType,\n workingDir: resolvedDir,\n _acpInstance: acpInstance,\n spawn: async () => {},\n shutdown: () => { instanceManager.removeInstance(key); },\n sendMessage: async (text: string) => { acpInstance.onEvent('send_message', { text }); },\n getStatus: () => {\n const state = acpInstance.getState();\n return {\n status: state.status,\n messages: state.activeChat?.messages || [],\n activeModal: state.activeChat?.activeModal || null,\n };\n },\n setOnStatusChange: () => {},\n setOnPtyData: () => {},\n } as any);\n\n console.log(chalk.green(` ✓ ACP agent started: ${provider.name} in ${resolvedDir}`));\n\n // If initialModel exists, change model after session start\n if (initialModel) {\n try {\n await acpInstance.setConfigOption('model', initialModel);\n console.log(chalk.green(` 🤖 Initial model set: ${initialModel}`));\n } catch (e: any) {\n console.warn(`[ACP] Initial model set failed: ${e?.message}`);\n }\n }\n\n try { addCliHistory({ cliType: normalizedType, dir: resolvedDir, cliArgs }); } catch (e) { console.warn('[ACP] History save failed:', (e as Error)?.message); }\n this.deps.onStatusChange();\n return;\n }\n\n // ─── CLI category handling (existing) ───\n const cliInfo = await detectCLI(cliType, this.providerLoader);\n if (!cliInfo) throw new Error(`${cliType} not found`);\n\n console.log(chalk.yellow(` ⚡ Starting CLI ${cliType} in ${resolvedDir}...`));\n if (provider) {\n console.log(chalk.cyan(` 📦 Using provider: ${provider.name} (${provider.type})`));\n }\n\n // If InstanceManager exists, manage as CliProviderInstance unified\n const instanceManager = this.deps.getInstanceManager();\n if (provider && instanceManager) {\n const cliInstance = new CliProviderInstance(provider, resolvedDir, cliArgs, key);\n await instanceManager.addInstance(key, cliInstance, {\n serverConn: this.deps.getServerConn(),\n settings: {},\n onPtyData: (data: string) => {\n this.deps.getP2p()?.broadcastPtyOutput(key, data);\n },\n });\n\n // Keep adapter ref too (backward compat — write, resize etc)\n this.adapters.set(key, cliInstance.getAdapter() as any);\n console.log(chalk.green(` ✓ CLI started: ${cliInfo.displayName} v${cliInfo.version || 'unknown'} in ${resolvedDir}`));\n } else {\n // Fallback: InstanceManager without directly adapter manage\n const adapter = this.createAdapter(cliType, resolvedDir, cliArgs);\n await adapter.spawn();\n\n const serverConn = this.deps.getServerConn();\n if (serverConn && typeof adapter.setServerConn === 'function') {\n adapter.setServerConn(serverConn);\n }\n adapter.setOnStatusChange(() => {\n this.deps.onStatusChange();\n const status = adapter.getStatus?.();\n if (status?.status === 'stopped') {\n setTimeout(() => {\n if (this.adapters.get(key) === adapter) {\n this.adapters.delete(key);\n this.deps.removeAgentTracking(key);\n console.log(chalk.yellow(` 🧹 Auto-cleaned stopped CLI: ${adapter.cliType}`));\n this.deps.onStatusChange();\n }\n }, 3000);\n }\n });\n\n if (typeof adapter.setOnPtyData === 'function') {\n adapter.setOnPtyData((data: string) => {\n this.deps.getP2p()?.broadcastPtyOutput(key, data);\n });\n }\n\n this.adapters.set(key, adapter);\n console.log(chalk.green(` ✓ CLI started: ${cliInfo.displayName} v${cliInfo.version || 'unknown'} in ${resolvedDir}`));\n }\n\n try { addCliHistory({ cliType, dir: resolvedDir, cliArgs }); } catch (e) { console.warn('[CLI] History save failed:', (e as Error)?.message); }\n\n this.deps.onStatusChange();\n }\n\n async stopSession(key: string): Promise<void> {\n const adapter = this.adapters.get(key);\n if (adapter) {\n adapter.shutdown();\n this.adapters.delete(key);\n this.deps.removeAgentTracking(key);\n // Also remove from InstanceManager\n this.deps.getInstanceManager()?.removeInstance(key);\n console.log(chalk.yellow(` 🛑 CLI Agent stopped: ${adapter.cliType} in ${adapter.workingDir}`));\n this.deps.onStatusChange();\n }\n }\n\n shutdownAll(): void {\n for (const adapter of this.adapters.values()) adapter.shutdown();\n this.adapters.clear();\n }\n\n // ─── Adapter search ─────────────────────────────\n\n /**\n * Search for CLI adapter. Priority order:\n * 0. instanceKey (UUID direct match) — extracted from _targetInstance / composite ID\n * 1. agentType + dir (iteration match)\n * 2. agentType fuzzy match (⚠ returns first match when multiple sessions exist)\n */\n findAdapter(agentType: string, opts?: { dir?: string; instanceKey?: string }): { adapter: CliAdapter; key: string } | null {\n // 0. UUID direct match (most accurate)\n if (opts?.instanceKey) {\n let ik = opts.instanceKey;\n // Strip composite prefix: 'doId:cli:uuid' → 'uuid' or 'doId:uuid' → 'uuid'\n const colonIdx = ik.lastIndexOf(':');\n if (colonIdx >= 0) ik = ik.substring(colonIdx + 1);\n const adapter = this.adapters.get(ik);\n if (adapter) return { adapter, key: ik };\n }\n // 1. agentType + dir match\n if (opts?.dir) {\n for (const [k, a] of this.adapters) {\n if (a.cliType === agentType && a.workingDir === opts.dir) {\n return { adapter: a, key: k };\n }\n }\n }\n // 2. Fuzzy match (returns first of multiple sessions — may be inaccurate)\n for (const [k, a] of this.adapters) {\n if (a.cliType === agentType) {\n return { adapter: a, key: k };\n }\n }\n return null;\n }\n\n // ─── CLI command handling ────────────────────────────\n\n async handleCliCommand(cmd: string, args: any): Promise<CommandResult | null> {\n switch (cmd) {\n case 'launch_cli': {\n const cliType = args?.cliType;\n const defaultedToHome = !args?.dir;\n const dir = args?.dir || os.homedir();\n if (!cliType) throw new Error('cliType required');\n\n await this.startSession(cliType, dir, args?.cliArgs, args?.initialModel);\n\n // On startSession success, new UUID key exists in adapters (last added item)\n let newKey: string | null = null;\n for (const [k, adapter] of this.adapters) {\n if (adapter.cliType === cliType && adapter.workingDir === dir) {\n newKey = k; // Last match = just added item\n }\n }\n\n try {\n const config = loadConfig();\n console.log(chalk.cyan(` 📂 Saving recent workspace: ${dir}`));\n const recent = config.recentCliWorkspaces || [];\n if (!recent.includes(dir)) {\n const updated = [dir, ...recent].slice(0, 10);\n saveConfig({ ...config, recentCliWorkspaces: updated });\n console.log(chalk.green(` ✓ Recent workspace saved: ${dir}`));\n }\n } catch (e) {\n console.error(chalk.red(` ✗ Failed to save recent workspace: ${e}`));\n }\n\n return { success: true, cliType, dir, id: newKey, defaultedToHome };\n }\n case 'stop_cli': {\n const cliType = args?.cliType;\n const dir = args?.dir || '';\n if (!cliType) throw new Error('cliType required');\n // UUID (_targetInstance) based search priority\n const found = this.findAdapter(cliType, { instanceKey: args?._targetInstance, dir });\n if (found) {\n await this.stopSession(found.key);\n } else {\n console.log(chalk.yellow(` ⚠ No adapter found for ${cliType}`));\n }\n return { success: true, cliType, dir, stopped: true };\n }\n case 'restart_session': {\n const cliType = args?.cliType || args?.agentType || args?.ideType;\n const dir = args?.dir || process.cwd();\n if (!cliType) throw new Error('cliType required');\n const found = this.findAdapter(cliType, { instanceKey: args?._targetInstance, dir });\n if (found) await this.stopSession(found.key);\n await this.startSession(cliType, dir);\n return { success: true, restarted: true };\n }\n case 'agent_command': {\n const agentType = args?.agentType || args?.cliType;\n const action = args?.action;\n if (!agentType || !action) throw new Error('agentType and action required');\n\n const found = this.findAdapter(agentType, {\n dir: args?.dir,\n instanceKey: args?._targetInstance,\n });\n if (!found) throw new Error(`CLI agent not running: ${agentType}`);\n const { adapter, key } = found;\n\n if (action === 'send_chat') {\n const message = args.message || args.text;\n if (!message) throw new Error('message required for send_chat');\n await adapter.sendMessage(message);\n return { success: true, status: 'generating' };\n } else if (action === 'clear_history') {\n if (typeof (adapter as any).clearHistory === 'function') (adapter as any).clearHistory();\n return { success: true, cleared: true };\n } else if (action === 'stop') {\n await this.stopSession(key);\n return { success: true, stopped: true };\n }\n throw new Error(`Unknown action: ${action}`);\n }\n }\n return null; // Not a CLI command\n }\n}\n","/**\n * ProviderCliAdapter — generic CLI Adapter based on provider.js\n *\n * Replaces individual adapters (gemini-cli.ts, claude-cli.ts, codex-cli.ts).\n * Single engine driven by provider.js patterns, spawn, and cleanOutput.\n *\n * provider.js contract:\n * type: string — 'gemini-cli', 'claude-cli', 'codex-cli', ...\n * name: string — 'Gemini CLI', 'Claude Code', ...\n * category: 'cli'\n * binary: string — binary name\n * spawn: { command, args, shell, env }\n * patterns: { prompt, generating, approval, ready }\n * timeouts?: { idleFinish, generatingIdle, maxResponse, approvalCooldown, ... }\n * cleanOutput(raw, lastUserInput): string\n */\n\nimport * as os from 'os';\nimport { execSync } from 'child_process';\nimport type { CliAdapter } from '../cli-adapter-types.js';\n\nlet pty: any;\ntry {\n pty = require('node-pty');\n} catch {\n console.error('[ProviderCliAdapter] node-pty not found. Install: npm install node-pty@1.0.0');\n}\n\nexport interface CliChatMessage {\n role: 'user' | 'assistant';\n content: string;\n timestamp?: number;\n}\n\nexport interface CliSessionStatus {\n status: 'idle' | 'generating' | 'waiting_approval' | 'error' | 'stopped' | 'starting';\n messages: CliChatMessage[];\n workingDir: string;\n activeModal: { message: string; buttons: string[] } | null;\n}\n\nexport interface CliProviderModule {\n type: string;\n name: string;\n category: 'cli';\n binary: string;\n spawn: {\n command: string;\n args: string[];\n shell: boolean;\n env: Record<string, string>;\n };\n patterns: {\n prompt: RegExp[];\n generating: RegExp[];\n approval: RegExp[];\n ready: RegExp[];\n };\n timeouts?: {\n /** PTY output batch transmit interval (default 50ms) */\n ptyFlush?: number;\n /** Wait for startup dialog auto-proceed (default 300ms) */\n dialogAccept?: number;\n /** Approval detect cooldown (default 2000ms) */\n approvalCooldown?: number;\n /** Check for completion on no-response during generating (default 6000ms) */\n generatingIdle?: number;\n /** Check for completion on no-response (default 5000ms) */\n idleFinish?: number;\n /** Max response wait (default 300000ms = 5min) */\n maxResponse?: number;\n /** shutdown after kill wait (default 1000ms) */\n shutdownGrace?: number;\n };\n cleanOutput(raw: string, lastUserInput?: string): string;\n}\n\nfunction stripAnsi(str: string): string {\n // eslint-disable-next-line no-control-regex\n return str.replace(/\\x1B(?:[@-Z\\\\-_]|\\[[0-?]*[ -/]*[@-~])/g, '')\n .replace(/\\x1B\\][^\\x07]*\\x07/g, '')\n .replace(/\\x1B\\][^\\x1B]*\\x1B\\\\/g, '');\n}\n\nfunction findBinary(name: string): string {\n const isWin = os.platform() === 'win32';\n try {\n const cmd = isWin ? `where ${name}` : `which ${name}`;\n return execSync(cmd, { encoding: 'utf-8', timeout: 5000, stdio: ['pipe', 'pipe', 'pipe'] }).trim().split('\\n')[0].trim();\n } catch {\n return isWin ? `${name}.cmd` : name;\n }\n}\n\nexport class ProviderCliAdapter implements CliAdapter {\n readonly cliType: string;\n readonly cliName: string;\n public workingDir: string;\n\n private provider: CliProviderModule;\n private ptyProcess: any = null;\n private messages: CliChatMessage[] = [];\n private currentStatus: CliSessionStatus['status'] = 'starting';\n private onStatusChange: (() => void) | null = null;\n\n private responseBuffer = '';\n private recentOutputBuffer = '';\n private isWaitingForResponse = false;\n private activeModal: { message: string; buttons: string[] } | null = null;\n private responseTimeout: NodeJS.Timeout | null = null;\n private idleTimeout: NodeJS.Timeout | null = null;\n private ready = false;\n private startupBuffer = '';\n\n // PTY I/O\n private onPtyDataCallback: ((data: string) => void) | null = null;\n private ptyOutputBuffer = '';\n private ptyOutputFlushTimer: NodeJS.Timeout | null = null;\n\n // Server log forwarding\n private serverConn: any = null;\n private logBuffer: { message: string; level: string }[] = [];\n\n // Approval cooldown\n private lastApprovalResolvedAt: number = 0;\n\n // Resolved timeouts (provider defaults + overrides)\n private readonly timeouts: Required<NonNullable<CliProviderModule['timeouts']>>;\n\n constructor(provider: CliProviderModule, workingDir: string, private extraArgs: string[] = []) {\n this.provider = provider;\n this.cliType = provider.type;\n this.cliName = provider.name;\n this.workingDir = workingDir.startsWith('~')\n ? workingDir.replace(/^~/, os.homedir())\n : workingDir;\n\n // Apply timeout overrides from Provider\n const t = provider.timeouts || {};\n this.timeouts = {\n ptyFlush: t.ptyFlush ?? 50,\n dialogAccept: t.dialogAccept ?? 300,\n approvalCooldown: t.approvalCooldown ?? 2000,\n generatingIdle: t.generatingIdle ?? 6000,\n idleFinish: t.idleFinish ?? 5000,\n maxResponse: t.maxResponse ?? 300000,\n shutdownGrace: t.shutdownGrace ?? 1000,\n };\n }\n\n // ─── Lifecycle ─────────────────────────────────\n\n setServerConn(serverConn: any): void {\n this.serverConn = serverConn;\n if (this.serverConn && this.logBuffer.length > 0) {\n this.logBuffer.forEach(log => this.serverConn.sendMessage('log', log));\n this.logBuffer = [];\n }\n }\n\n setOnStatusChange(callback: () => void): void {\n this.onStatusChange = callback;\n }\n\n setOnPtyData(callback: (data: string) => void): void {\n this.onPtyDataCallback = callback;\n }\n\n async spawn(): Promise<void> {\n if (this.ptyProcess) return;\n if (!pty) throw new Error('node-pty is not installed');\n\n const { spawn: spawnConfig } = this.provider;\n const binaryPath = findBinary(spawnConfig.command);\n const isWin = os.platform() === 'win32';\n const allArgs = [...spawnConfig.args, ...this.extraArgs];\n\n console.log(`[${this.cliType}] Spawning in ${this.workingDir}`);\n\n let shellCmd: string;\n let shellArgs: string[];\n\n if (spawnConfig.shell) {\n // Execute via shell (for gemini etc npm shim compat)\n shellCmd = isWin ? 'cmd.exe' : (process.env.SHELL || '/bin/zsh');\n const fullCmd = [binaryPath, ...allArgs].join(' ');\n shellArgs = isWin ? ['/c', fullCmd] : ['-l', '-c', fullCmd];\n } else {\n shellCmd = binaryPath;\n shellArgs = allArgs;\n }\n\n this.ptyProcess = pty.spawn(shellCmd, shellArgs, {\n name: 'xterm-256color',\n cols: 120,\n rows: 40,\n cwd: this.workingDir,\n env: {\n ...process.env,\n ...spawnConfig.env,\n } as Record<string, string>,\n });\n\n this.ptyProcess.onData((data: string) => {\n this.handleOutput(data);\n // PTY output batch transmit (50ms)\n if (this.onPtyDataCallback) {\n this.ptyOutputBuffer += data;\n if (!this.ptyOutputFlushTimer) {\n this.ptyOutputFlushTimer = setTimeout(() => {\n if (this.ptyOutputBuffer && this.onPtyDataCallback) {\n this.onPtyDataCallback(this.ptyOutputBuffer);\n }\n this.ptyOutputBuffer = '';\n this.ptyOutputFlushTimer = null;\n }, this.timeouts.ptyFlush);\n }\n }\n });\n\n this.ptyProcess.onExit(({ exitCode }: { exitCode: number }) => {\n console.log(`[${this.cliType}] Exit code ${exitCode}`);\n this.ptyProcess = null;\n this.currentStatus = 'stopped';\n this.ready = false;\n this.onStatusChange?.();\n });\n\n this.currentStatus = 'starting';\n this.onStatusChange?.();\n }\n\n // ─── Output state machine ────────────────────────────\n\n private handleOutput(rawData: string): void {\n const cleanData = stripAnsi(rawData);\n const { patterns } = this.provider;\n\n // Server log forwarding\n if (cleanData.trim()) {\n if (this.serverConn) {\n this.serverConn.sendMessage('log', { message: cleanData.trim(), level: 'info' });\n } else {\n this.logBuffer.push({ message: cleanData.trim(), level: 'info' });\n }\n }\n\n // Rolling buffer (recent 1000 chars)\n this.recentOutputBuffer = (this.recentOutputBuffer + cleanData).slice(-1000);\n\n // ─── Phase 1: Startup — ready status wait\n if (!this.ready) {\n this.startupBuffer += cleanData;\n\n // Startup dialog auto-proceed (Enter)\n const dialogPatterns = [\n /Do you want to connect/i,\n /Do you trust the files/i,\n ];\n if (dialogPatterns.some(p => p.test(this.startupBuffer))) {\n setTimeout(() => this.ptyProcess?.write('\\r'), this.timeouts.dialogAccept);\n this.startupBuffer = '';\n return;\n }\n\n // Prompt → ready\n if (patterns.prompt.some(p => p.test(this.startupBuffer))) {\n this.ready = true;\n this.currentStatus = 'idle';\n console.log(`[${this.cliType}] ✓ Ready`);\n this.onStatusChange?.();\n }\n return;\n }\n\n // ─── Phase 2: Approval detect\n const hasApproval = patterns.approval.some(p => p.test(this.recentOutputBuffer));\n if (hasApproval && this.currentStatus !== 'waiting_approval') {\n if (this.lastApprovalResolvedAt && (Date.now() - this.lastApprovalResolvedAt) < this.timeouts.approvalCooldown) return;\n\n this.isWaitingForResponse = true;\n this.currentStatus = 'waiting_approval';\n this.recentOutputBuffer = '';\n const ctxLines = cleanData.split('\\n').map(l => l.trim()).filter(l => l && !/^[─═╭╮╰╯│]+$/.test(l));\n this.activeModal = {\n message: ctxLines.slice(-5).join(' ').slice(0, 200) || 'Approval required',\n buttons: ['Allow once', 'Always allow', 'Deny'],\n };\n if (this.idleTimeout) clearTimeout(this.idleTimeout);\n this.onStatusChange?.();\n return;\n }\n\n // ─── Phase 3: Approval release\n if (this.currentStatus === 'waiting_approval') {\n const genResume = patterns.generating.some(p => p.test(cleanData));\n const promptResume = patterns.prompt.some(p => p.test(cleanData));\n if (genResume) {\n this.currentStatus = 'generating';\n this.activeModal = null;\n this.recentOutputBuffer = '';\n this.lastApprovalResolvedAt = Date.now();\n this.onStatusChange?.();\n } else if (promptResume) {\n this.activeModal = null;\n this.recentOutputBuffer = '';\n this.lastApprovalResolvedAt = Date.now();\n this.finishResponse();\n }\n return;\n }\n\n // ─── Phase 4: autonomous generation detection (generating starts without sendMessage)\n if (!this.isWaitingForResponse) {\n if (patterns.generating.some(p => p.test(cleanData))) {\n this.isWaitingForResponse = true;\n this.responseBuffer = '';\n this.currentStatus = 'generating';\n this.onStatusChange?.();\n }\n }\n\n // ─── Phase 5: response collect\n if (this.isWaitingForResponse) {\n this.responseBuffer += cleanData;\n if (this.idleTimeout) clearTimeout(this.idleTimeout);\n\n const stillGenerating = patterns.generating.some(p => p.test(cleanData));\n if (stillGenerating) {\n this.currentStatus = 'generating';\n this.idleTimeout = setTimeout(() => {\n if (this.isWaitingForResponse) this.finishResponse();\n }, this.timeouts.generatingIdle);\n this.onStatusChange?.();\n return;\n }\n\n // Prompt → response complete\n if (patterns.prompt.some(p => p.test(this.responseBuffer))) {\n this.finishResponse();\n } else {\n this.idleTimeout = setTimeout(() => {\n if (this.isWaitingForResponse && this.responseBuffer.trim()) {\n this.finishResponse();\n }\n }, this.timeouts.idleFinish);\n }\n this.onStatusChange?.();\n }\n }\n\n private finishResponse(): void {\n if (this.responseTimeout) { clearTimeout(this.responseTimeout); this.responseTimeout = null; }\n if (this.idleTimeout) { clearTimeout(this.idleTimeout); this.idleTimeout = null; }\n\n const lastUserText = this.messages.filter(m => m.role === 'user').pop()?.content;\n let response = this.provider.cleanOutput(this.responseBuffer, lastUserText);\n\n // Remove user input echo\n if (lastUserText && response) {\n const userTrimmed = lastUserText.trim();\n response = response.split('\\n')\n .filter(l => l.trim() !== userTrimmed)\n .join('\\n').trim();\n }\n\n if (response) {\n this.messages.push({ role: 'assistant', content: response, timestamp: Date.now() });\n if (this.messages.length > 200) this.messages = this.messages.slice(-200);\n console.log(`[${this.cliType}] Response (${response.length} chars)`);\n }\n\n this.responseBuffer = '';\n this.isWaitingForResponse = false;\n this.activeModal = null;\n this.currentStatus = 'idle';\n this.onStatusChange?.();\n }\n\n // ─── Public API (CliAdapter interface) ──────────\n\n getStatus(): CliSessionStatus {\n return {\n status: this.currentStatus,\n messages: [...this.messages],\n workingDir: this.workingDir,\n activeModal: this.activeModal,\n };\n }\n\n async sendMessage(text: string): Promise<void> {\n if (!this.ptyProcess) throw new Error(`${this.cliName} is not running`);\n if (!this.ready) throw new Error(`${this.cliName} not ready (status: ${this.currentStatus})`);\n if (this.isWaitingForResponse) return;\n\n this.messages.push({ role: 'user', content: text, timestamp: Date.now() });\n this.isWaitingForResponse = true;\n this.responseBuffer = '';\n this.currentStatus = 'generating';\n this.onStatusChange?.();\n\n this.ptyProcess.write(text + '\\r');\n\n this.responseTimeout = setTimeout(() => {\n if (this.isWaitingForResponse) this.finishResponse();\n }, this.timeouts.maxResponse);\n }\n\n getPartialResponse(): string {\n if (!this.isWaitingForResponse) return '';\n const partial = this.provider.cleanOutput(this.responseBuffer);\n return partial || (this.isWaitingForResponse ? '(generating...)' : '');\n }\n\n cancel(): void { this.shutdown(); }\n\n shutdown(): void {\n if (this.ptyProcess) {\n this.ptyProcess.write('\\x03');\n setTimeout(() => {\n try { this.ptyProcess?.kill(); } catch { }\n this.ptyProcess = null;\n this.currentStatus = 'stopped';\n this.ready = false;\n this.onStatusChange?.();\n }, this.timeouts.shutdownGrace);\n }\n }\n\n clearHistory(): void {\n this.messages = [];\n this.onStatusChange?.();\n }\n\n isProcessing(): boolean { return this.isWaitingForResponse; }\n isReady(): boolean { return this.ready; }\n\n writeRaw(data: string): void {\n this.ptyProcess?.write(data);\n }\n\n resize(cols: number, rows: number): void {\n if (this.ptyProcess) {\n try { this.ptyProcess.resize(cols, rows); } catch { }\n }\n }\n}\n","/**\n * CliProviderInstance — Runtime instance for CLI Provider\n *\n * Lifecycle layer on top of ProviderCliAdapter.\n * collectCliData() + status transition logic from daemon-status.ts moved here.\n */\n\nimport * as path from 'path';\nimport * as crypto from 'crypto';\nimport type { ProviderModule } from './contracts.js';\nimport type { ProviderInstance, ProviderState, ProviderEvent, InstanceContext } from './provider-instance.js';\nimport { ProviderCliAdapter } from '../cli-adapters/provider-cli-adapter.js';\nimport type { CliProviderModule } from '../cli-adapters/provider-cli-adapter.js';\nimport { StatusMonitor } from './status-monitor.js';\nimport { ChatHistoryWriter } from '../chat-history.js';\n\nexport class CliProviderInstance implements ProviderInstance {\n readonly type: string;\n readonly category = 'cli' as const;\n\n private adapter: ProviderCliAdapter;\n private context: InstanceContext | null = null;\n private events: ProviderEvent[] = [];\n private lastStatus: string = 'starting';\n private generatingStartedAt: number = 0;\n private settings: Record<string, any> = {};\n private monitor: StatusMonitor;\n private historyWriter: ChatHistoryWriter;\n readonly instanceId: string;\n\n constructor(\n private provider: ProviderModule,\n private workingDir: string,\n private cliArgs: string[] = [],\n instanceId?: string,\n ) {\n this.type = provider.type;\n this.instanceId = instanceId || crypto.randomUUID();\n this.adapter = new ProviderCliAdapter(provider as any as CliProviderModule, workingDir, cliArgs);\n this.monitor = new StatusMonitor();\n this.historyWriter = new ChatHistoryWriter();\n }\n\n // ─── Lifecycle ─────────────────────────────────\n\n async init(context: InstanceContext): Promise<void> {\n this.context = context;\n this.settings = context.settings || {};\n this.monitor.updateConfig({\n approvalAlert: this.settings.approvalAlert !== false,\n longGeneratingAlert: this.settings.longGeneratingAlert !== false,\n longGeneratingThresholdSec: this.settings.longGeneratingThresholdSec || 180,\n });\n\n // Server connection\n if (context.serverConn) {\n this.adapter.setServerConn(context.serverConn);\n }\n\n // PTY output callback\n if (context.onPtyData) {\n this.adapter.setOnPtyData(context.onPtyData);\n }\n\n // Emit event on status change\n this.adapter.setOnStatusChange(() => {\n this.detectStatusTransition();\n });\n\n // PTY spawn\n await this.adapter.spawn();\n }\n\n async onTick(): Promise<void> {\n // CLI is event-based so tick is unnecessary\n // Health check etc here if needed\n }\n\n getState(): ProviderState {\n const adapterStatus = this.adapter.getStatus();\n const dirName = this.workingDir.split('/').filter(Boolean).pop() || 'session';\n\n // Message truncate (recent 50, 2000 char limit)\n const recentMessages = adapterStatus.messages.slice(-50).map(m => ({\n role: m.role,\n content: m.content.length > 2000 ? m.content.slice(0, 2000) + '\\n... (truncated)' : m.content,\n timestamp: m.timestamp,\n }));\n\n // generating during partial response add\n const partial = this.adapter.getPartialResponse();\n if (adapterStatus.status === 'generating' && partial) {\n const cleaned = partial.trim();\n if (cleaned && cleaned !== '(generating...)') {\n recentMessages.push({\n role: 'assistant',\n content: (cleaned.length > 2000 ? cleaned.slice(0, 2000) + '...' : cleaned) + '...',\n timestamp: Date.now(),\n });\n }\n }\n\n // Save history\n if (recentMessages.length > 0) {\n const dirName = this.workingDir.split('/').filter(Boolean).pop() || 'session';\n this.historyWriter.appendNewMessages(\n this.type,\n recentMessages,\n `${this.provider.name} · ${dirName}`,\n this.instanceId,\n );\n }\n\n return {\n type: this.type,\n name: this.provider.name,\n category: 'cli',\n status: adapterStatus.status,\n mode: (this.settings.mode as 'terminal' | 'chat') || 'terminal',\n activeChat: {\n id: `${this.type}_${this.workingDir}`,\n title: `${this.provider.name} · ${dirName}`,\n status: adapterStatus.status,\n messages: recentMessages,\n activeModal: adapterStatus.activeModal,\n inputContent: '',\n },\n workingDir: this.workingDir,\n instanceId: this.instanceId,\n lastUpdated: Date.now(),\n settings: this.settings,\n pendingEvents: this.flushEvents(),\n };\n }\n\n onEvent(event: string, data?: any): void {\n if (event === 'send_message' && data?.text) {\n this.adapter.sendMessage(data.text);\n } else if (event === 'server_connected' && data?.serverConn) {\n this.adapter.setServerConn(data.serverConn);\n }\n }\n\n dispose(): void {\n this.adapter.shutdown();\n this.monitor.reset();\n }\n\n // ─── Status transition detection (moved from daemon-status.ts) ──────\n\n private detectStatusTransition(): void {\n const now = Date.now();\n const adapterStatus = this.adapter.getStatus();\n const newStatus = adapterStatus.status;\n const dirName = this.workingDir.split('/').filter(Boolean).pop() || 'session';\n const chatTitle = `${this.provider.name} · ${dirName}`;\n\n if (newStatus !== this.lastStatus) {\n if (this.lastStatus === 'idle' && newStatus === 'generating') {\n this.generatingStartedAt = now;\n this.pushEvent({ event: 'agent:generating_started', chatTitle, timestamp: now });\n } else if (newStatus === 'waiting_approval') {\n if (!this.generatingStartedAt) this.generatingStartedAt = now;\n this.pushEvent({\n event: 'agent:waiting_approval', chatTitle, timestamp: now,\n modalMessage: adapterStatus.activeModal?.message,\n modalButtons: adapterStatus.activeModal?.buttons,\n });\n } else if (newStatus === 'idle' && (this.lastStatus === 'generating' || this.lastStatus === 'waiting_approval')) {\n const duration = this.generatingStartedAt ? Math.round((now - this.generatingStartedAt) / 1000) : 0;\n this.pushEvent({ event: 'agent:generating_completed', chatTitle, duration, timestamp: now });\n this.generatingStartedAt = 0;\n } else if (newStatus === 'stopped') {\n this.pushEvent({ event: 'agent:stopped', chatTitle, timestamp: now });\n }\n this.lastStatus = newStatus;\n }\n\n // Monitor check (cooldown based notification, IDE/CLI common)\n const agentKey = `${this.type}:cli`;\n const monitorEvents = this.monitor.check(agentKey, newStatus, now);\n for (const me of monitorEvents) {\n this.pushEvent({ event: me.type, agentKey: me.agentKey, message: me.message, elapsedSec: me.elapsedSec, timestamp: me.timestamp });\n }\n }\n\n private pushEvent(event: ProviderEvent): void {\n this.events.push(event);\n // Max 50\n if (this.events.length > 50) this.events = this.events.slice(-50);\n }\n\n private flushEvents(): ProviderEvent[] {\n const events = [...this.events];\n this.events = [];\n return events;\n }\n\n // ─── Adapter access (backward compat) ──────────────────\n\n getAdapter(): ProviderCliAdapter {\n return this.adapter;\n }\n\n get cliType(): string { return this.type; }\n get cliName(): string { return this.provider.name; }\n}\n","/**\n * StatusMonitor — status monitoring notification system\n *\n * Common across all Provider categories (IDE/Extension/CLI).\n * - approval wait(waiting_approval) occur when notification\n * - Notification when generating persists for extended duration\n * - all config Provider Settingstoggle possible\n */\n\nexport interface MonitorConfig {\n /** Enable awaiting-approval notification */\n approvalAlert: boolean;\n /** prolonged generating notification enabled */\n longGeneratingAlert: boolean;\n /** Prolonged threshold (seconds) */\n longGeneratingThresholdSec: number;\n /** repeat notification cooldown (seconds) */\n alertCooldownSec: number;\n}\n\nexport const DEFAULT_MONITOR_CONFIG: MonitorConfig = {\n approvalAlert: true,\n longGeneratingAlert: true,\n longGeneratingThresholdSec: 180, // 3minutes\n alertCooldownSec: 60, // 1minutes cooldown\n};\n\nexport interface MonitorEvent {\n type: string;\n agentKey: string;\n timestamp: number;\n elapsedSec?: number;\n message?: string;\n}\n\nexport class StatusMonitor {\n private config: MonitorConfig;\n private lastAlertTime = new Map<string, number>();\n private generatingStartTimes = new Map<string, number>();\n\n constructor(config?: Partial<MonitorConfig>) {\n this.config = { ...DEFAULT_MONITOR_CONFIG, ...config };\n }\n\n /** Config update (called from Provider Settings) */\n updateConfig(partial: Partial<MonitorConfig>): void {\n Object.assign(this.config, partial);\n }\n\n /** current config return */\n getConfig(): MonitorConfig {\n return { ...this.config };\n }\n\n /**\n * Check status transition → return notification event array\n * each onTick()from call.\n */\n check(agentKey: string, status: string, now: number): MonitorEvent[] {\n const events: MonitorEvent[] = [];\n\n // 1. approval wait notification\n if (this.config.approvalAlert && status === 'waiting_approval') {\n if (this.shouldAlert(agentKey + ':approval', now)) {\n events.push({\n type: 'monitor:approval_waiting',\n agentKey,\n timestamp: now,\n message: `${agentKey} is waiting for approval`,\n });\n }\n }\n\n // 2. Detect prolonged generating (identical for IDE/Extension/CLI)\n if (status === 'generating' || status === 'streaming') {\n if (!this.generatingStartTimes.has(agentKey)) {\n this.generatingStartTimes.set(agentKey, now);\n }\n if (this.config.longGeneratingAlert) {\n const startedAt = this.generatingStartTimes.get(agentKey)!;\n const elapsedSec = Math.round((now - startedAt) / 1000);\n if (elapsedSec > this.config.longGeneratingThresholdSec) {\n if (this.shouldAlert(agentKey + ':long_gen', now)) {\n events.push({\n type: 'monitor:long_generating',\n agentKey,\n elapsedSec,\n timestamp: now,\n message: `${agentKey} has been generating for ${Math.round(elapsedSec / 60)}min`,\n });\n }\n }\n }\n } else {\n // Reset timer when switching to non-generating status\n this.generatingStartTimes.delete(agentKey);\n }\n\n return events;\n }\n\n /** Cooldown check — prevent sending the same notification too frequently */\n private shouldAlert(key: string, now: number): boolean {\n const last = this.lastAlertTime.get(key) || 0;\n if (now - last > this.config.alertCooldownSec * 1000) {\n this.lastAlertTime.set(key, now);\n return true;\n }\n return false;\n }\n\n /** Reset (on agent terminate/restart) */\n reset(agentKey?: string): void {\n if (agentKey) {\n this.generatingStartTimes.delete(agentKey);\n // Delete all cooldowns for this key\n for (const k of this.lastAlertTime.keys()) {\n if (k.startsWith(agentKey)) this.lastAlertTime.delete(k);\n }\n } else {\n this.generatingStartTimes.clear();\n this.lastAlertTime.clear();\n }\n }\n}\n","/**\n * AcpProviderInstance — ACP (Agent Client Protocol) Provider runtime instance\n *\n * Spawns ACP agent process and communicates via JSON-RPC over stdio.\n * Structured protocol layer replacing CliProviderInstance PTY parsing.\n *\n * ACP spec: https://agentclientprotocol.com\n * \n * lifecycle:\n * 1. init() → Spawn agent process + ACP initialize handshake\n * 2. onTick() → no-op (ACP event based)\n * 3. getState() → ProviderState return (dashboard for display)\n * 4. onEvent('send_message') → session/prompt transmit\n * 5. dispose() → kill process\n */\n\nimport * as path from 'path';\nimport * as crypto from 'crypto';\nimport { spawn, type ChildProcess } from 'child_process';\nimport { createInterface, type Interface as ReadlineInterface } from 'readline';\nimport type { ProviderModule } from './contracts.js';\nimport type { ProviderInstance, ProviderState, ProviderEvent, InstanceContext } from './provider-instance.js';\nimport { StatusMonitor } from './status-monitor.js';\n\n// ─── ACP JSON-RPC Types ────────────────────────────\n\ninterface JsonRpcRequest {\n jsonrpc: '2.0';\n id: number;\n method: string;\n params?: Record<string, unknown>;\n}\n\ninterface JsonRpcNotification {\n jsonrpc: '2.0';\n method: string;\n params?: Record<string, unknown>;\n}\n\ninterface JsonRpcResponse {\n jsonrpc: '2.0';\n id: number;\n result?: any;\n error?: { code: number; message: string; data?: any };\n}\n\ntype JsonRpcMessage = JsonRpcRequest | JsonRpcNotification | JsonRpcResponse;\n\ninterface AcpMessage {\n role: 'user' | 'assistant' | 'system';\n content: string;\n timestamp?: number;\n}\n\ninterface AcpToolCall {\n id: string;\n name: string;\n status: 'running' | 'completed' | 'failed';\n input?: string;\n output?: string;\n}\n\ninterface AcpConfigOption {\n category: 'model' | 'mode' | 'thought_level' | 'other';\n configId: string;\n currentValue?: string;\n options: { value: string; name: string; description?: string; group?: string }[];\n}\n\ninterface AcpMode {\n id: string;\n name: string;\n description?: string;\n}\n\n// ─── AcpProviderInstance ───────────────────────────\n\nexport class AcpProviderInstance implements ProviderInstance {\n readonly type: string;\n readonly category = 'acp' as const;\n\n private provider: ProviderModule;\n private context: InstanceContext | null = null;\n private settings: Record<string, any> = {};\n private events: ProviderEvent[] = [];\n private monitor: StatusMonitor;\n\n // Process\n private process: ChildProcess | null = null;\n private readline: ReadlineInterface | null = null;\n private requestId = 1;\n private pendingRequests = new Map<number, {\n resolve: (result: any) => void;\n reject: (error: Error) => void;\n timer: NodeJS.Timeout;\n }>();\n\n // State\n private sessionId: string | null = null;\n private messages: AcpMessage[] = [];\n private currentStatus: ProviderState['status'] = 'starting';\n private lastStatus: string = 'starting';\n private generatingStartedAt = 0;\n private agentCapabilities: Record<string, any> = {};\n private currentModel: string | undefined;\n private currentMode: string | undefined;\n private activeToolCalls: AcpToolCall[] = [];\n private stopReason: string | null = null;\n private partialContent = '';\n\n // Error tracking\n private errorMessage: string | null = null;\n private errorReason: 'not_installed' | 'auth_failed' | 'spawn_error' | 'init_failed' | 'crash' | null = null;\n private stderrBuffer: string[] = [];\n private spawnedAt = 0;\n\n // ACP ConfigOptions & Modes (from session/new response or static fallback)\n private configOptions: AcpConfigOption[] = [];\n private availableModes: AcpMode[] = [];\n /** Static config mode — agent doesn't support config/* methods */\n private useStaticConfig = false;\n /** Current config selections (for spawnArgBuilder) */\n private selectedConfig: Record<string, string> = {};\n\n // Config\n private workingDir: string;\n private instanceId: string;\n\n constructor(\n provider: ProviderModule,\n workingDir: string,\n private cliArgs: string[] = [],\n ) {\n this.type = provider.type;\n this.provider = provider;\n this.workingDir = workingDir;\n this.instanceId = crypto.randomUUID();\n\n this.monitor = new StatusMonitor();\n }\n\n // ─── Lifecycle ─────────────────────────────────\n\n async init(context: InstanceContext): Promise<void> {\n this.context = context;\n this.settings = context.settings || {};\n this.monitor.updateConfig({\n approvalAlert: this.settings.approvalAlert !== false,\n longGeneratingAlert: this.settings.longGeneratingAlert !== false,\n longGeneratingThresholdSec: this.settings.longGeneratingThresholdSec || 180,\n });\n\n await this.spawnAgent();\n }\n\n async onTick(): Promise<void> {\n // ACP event based — tick unnecessary\n // Run process health check only\n if (this.process && this.process.exitCode !== null) {\n this.currentStatus = 'stopped';\n this.detectStatusTransition();\n }\n }\n\n getState(): ProviderState {\n const dirName = this.workingDir.split('/').filter(Boolean).pop() || 'session';\n\n // Recent 50 messages, 2000 char limit\n const recentMessages = this.messages.slice(-50).map(m => ({\n role: m.role,\n content: m.content.length > 2000 ? m.content.slice(0, 2000) + '\\n... (truncated)' : m.content,\n timestamp: m.timestamp,\n }));\n\n // generating during partial response add\n if (this.currentStatus === 'generating' && this.partialContent) {\n const cleaned = this.partialContent.trim();\n if (cleaned) {\n recentMessages.push({\n role: 'assistant',\n content: (cleaned.length > 2000 ? cleaned.slice(0, 2000) + '...' : cleaned) + '...',\n timestamp: Date.now(),\n });\n }\n }\n\n return {\n type: this.type,\n name: this.provider.name,\n category: 'acp',\n status: this.currentStatus,\n mode: 'chat',\n activeChat: {\n id: this.sessionId || `${this.type}_${this.workingDir}`,\n title: `${this.provider.name} · ${dirName}`,\n status: this.currentStatus,\n messages: recentMessages,\n activeModal: this.currentStatus === 'waiting_approval' ? {\n message: this.activeToolCalls.find(t => t.status === 'running')?.name || 'Permission requested',\n buttons: ['Approve', 'Reject'],\n } : null,\n inputContent: '',\n },\n workingDir: this.workingDir,\n currentModel: this.currentModel,\n currentPlan: this.currentMode,\n instanceId: this.instanceId,\n lastUpdated: Date.now(),\n settings: this.settings,\n pendingEvents: this.flushEvents(),\n // ACP-specific: expose available models/modes for dashboard\n acpConfigOptions: this.configOptions,\n acpModes: this.availableModes,\n // Error details for dashboard display\n errorMessage: this.errorMessage,\n errorReason: this.errorReason,\n } as any;\n }\n\n onEvent(event: string, data?: any): void {\n if (event === 'send_message' && data?.text) {\n this.sendPrompt(data.text).catch(e =>\n console.warn(`[ACP:${this.type}] sendPrompt error:`, e?.message)\n );\n } else if (event === 'resolve_action') {\n const action = data?.action || 'approve';\n this.resolvePermission(action === 'approve' || action === 'accept')\n .catch(e => console.warn(`[ACP:${this.type}] resolvePermission error:`, e?.message));\n } else if (event === 'cancel') {\n this.cancelSession().catch(e =>\n console.warn(`[ACP:${this.type}] cancel error:`, e?.message)\n );\n } else if (event === 'change_model' && data?.model) {\n this.setConfigOption('model', data.model).catch(e =>\n console.warn(`[ACP:${this.type}] change_model error:`, e?.message)\n );\n } else if (event === 'set_mode' && data?.mode) {\n this.setMode(data.mode).catch(e =>\n console.warn(`[ACP:${this.type}] set_mode error:`, e?.message)\n );\n } else if (event === 'set_thought_level' && data?.level) {\n this.setConfigOption('thought_level', data.level).catch(e =>\n console.warn(`[ACP:${this.type}] set_thought_level error:`, e?.message)\n );\n }\n }\n\n // ─── ACP Config Options & Modes ─────────────────────\n\n private parseConfigOptions(raw: any): void {\n if (!Array.isArray(raw)) return;\n this.configOptions = [];\n for (const opt of raw) {\n const category = opt.category || 'other';\n const configId = opt.configId || opt.id || '';\n const currentValue = opt.currentValue ?? opt.select?.currentValue;\n\n // flatten options (ungrouped + grouped)\n const flatOptions: AcpConfigOption['options'] = [];\n const selectOpts = opt.select?.options || opt.options;\n if (selectOpts) {\n // ungrouped options\n if (Array.isArray(selectOpts.ungrouped)) {\n for (const o of selectOpts.ungrouped) {\n flatOptions.push({ value: o.value, name: o.name || o.value, description: o.description });\n }\n }\n // grouped options\n if (Array.isArray(selectOpts.grouped)) {\n for (const g of selectOpts.grouped) {\n const groupName = g.name || g.group || '';\n for (const o of (Array.isArray(g.options?.ungrouped) ? g.options.ungrouped : (g.options || []))) {\n flatOptions.push({ value: o.value, name: o.name || o.value, description: o.description, group: groupName });\n }\n }\n }\n // direct array\n if (Array.isArray(selectOpts)) {\n for (const o of selectOpts) {\n if (o.value) flatOptions.push({ value: o.value, name: o.name || o.value, description: o.description });\n }\n }\n }\n\n this.configOptions.push({ category: category as any, configId, currentValue, options: flatOptions });\n\n // Auto-set currentModel/currentMode from config\n if (category === 'model' && currentValue) this.currentModel = currentValue;\n }\n }\n\n private parseModes(raw: any): void {\n if (!raw) return;\n // modes: { currentModeId, availableModes: [{ id, name, description }] }\n if (raw.currentModeId) this.currentMode = raw.currentModeId;\n if (Array.isArray(raw.availableModes)) {\n this.availableModes = raw.availableModes.map((m: any) => ({\n id: m.id, name: m.name || m.id, description: m.description,\n }));\n }\n }\n\n async setConfigOption(category: string, value: string): Promise<void> {\n // Find configId for this category\n const opt = this.configOptions.find(c => c.category === category);\n if (!opt) {\n console.warn(`[ACP:${this.type}] No config option for category: ${category}`);\n return;\n }\n\n // Static config mode: update selection and restart process\n if (this.useStaticConfig) {\n opt.currentValue = value;\n this.selectedConfig[opt.configId] = value;\n if (category === 'model') this.currentModel = value;\n if (category === 'mode') this.currentMode = value;\n console.log(`[ACP:${this.type}] Static config ${category} set to: ${value} — restarting agent`);\n await this.restartWithNewConfig();\n return;\n }\n\n try {\n console.log(`[ACP:${this.type}] Sending session/set_config_option: configId=${opt.configId} value=${value} sessionId=${this.sessionId}`);\n const result = await this.sendRequest('session/set_config_option', {\n sessionId: this.sessionId,\n configId: opt.configId,\n value,\n });\n // Update local state\n opt.currentValue = value;\n if (category === 'model') this.currentModel = value;\n // Response may include updated configOptions\n if (result?.configOptions) this.parseConfigOptions(result.configOptions);\n console.log(`[ACP:${this.type}] Config ${category} set to: ${value} | response: ${JSON.stringify(result)?.slice(0, 300)}`);\n } catch (e: any) {\n console.warn(`[ACP:${this.type}] set_config_option failed:`, e?.message);\n }\n }\n\n async setMode(modeId: string): Promise<void> {\n // Static config: mode changes via restart\n if (this.useStaticConfig) {\n const opt = this.configOptions.find(c => c.category === 'mode');\n if (opt) {\n opt.currentValue = modeId;\n this.selectedConfig[opt.configId] = modeId;\n }\n this.currentMode = modeId;\n console.log(`[ACP:${this.type}] Static mode set to: ${modeId} — restarting agent`);\n await this.restartWithNewConfig();\n return;\n }\n\n try {\n await this.sendRequest('session/set_mode', {\n sessionId: this.sessionId,\n modeId,\n });\n this.currentMode = modeId;\n console.log(`[ACP:${this.type}] Mode set to: ${modeId}`);\n } catch (e: any) {\n console.warn(`[ACP:${this.type}] set_mode failed:`, e?.message);\n }\n }\n\n /** Static config: kill process and restart with new args */\n private async restartWithNewConfig(): Promise<void> {\n // Build new args from spawnArgBuilder\n if (this.provider.spawnArgBuilder) {\n this.cliArgs = []; // clear previous extra args\n }\n\n // Kill existing process\n if (this.process) {\n try { this.process.kill('SIGTERM'); } catch { }\n this.process = null;\n }\n if (this.readline) {\n this.readline.close();\n this.readline = null;\n }\n\n // Clear pending\n for (const [, pending] of this.pendingRequests) {\n clearTimeout(pending.timer);\n pending.reject(new Error('Agent restarting'));\n }\n this.pendingRequests.clear();\n this.sessionId = null;\n\n this.currentStatus = 'starting';\n this.detectStatusTransition();\n\n // Re-spawn with updated config\n await this.spawnAgent();\n }\n\n dispose(): void {\n // kill process\n if (this.process) {\n try { this.process.kill('SIGTERM'); } catch { }\n this.process = null;\n }\n if (this.readline) {\n this.readline.close();\n this.readline = null;\n }\n // Pending requests cleanup\n for (const [, req] of this.pendingRequests) {\n clearTimeout(req.timer);\n req.reject(new Error('Instance disposed'));\n }\n this.pendingRequests.clear();\n this.monitor.reset();\n }\n\n // ─── ACP Process Management ──────────────────────\n\n private async spawnAgent(): Promise<void> {\n const spawnConfig = this.provider.spawn;\n if (!spawnConfig) {\n throw new Error(`[ACP:${this.type}] No spawn config defined`);\n }\n\n const command = spawnConfig.command;\n // Static config: create args via spawnArgBuilder (when provider defines it)\n let baseArgs = spawnConfig.args || [];\n if (this.provider.spawnArgBuilder && Object.keys(this.selectedConfig).length > 0) {\n baseArgs = this.provider.spawnArgBuilder(this.selectedConfig);\n }\n const args = [...baseArgs, ...this.cliArgs];\n\n // Auth: each CLI/ACP tool manages its own authentication.\n // ADHDev does NOT inject API keys — tools read their own env vars or config files.\n\n const env = { ...process.env, ...(spawnConfig.env || {}) };\n\n console.log(`[ACP:${this.type}] Spawning: ${command} ${args.join(' ')} in ${this.workingDir}`);\n\n this.spawnedAt = Date.now();\n this.errorMessage = null;\n this.errorReason = null;\n this.stderrBuffer = [];\n\n this.process = spawn(command, args, {\n cwd: this.workingDir,\n env,\n stdio: ['pipe', 'pipe', 'pipe'],\n shell: spawnConfig.shell || false,\n });\n\n // stdout → JSON-RPC message parsing\n this.readline = createInterface({ input: this.process.stdout! });\n this.readline.on('line', (line) => {\n const trimmed = line.trim();\n if (!trimmed) return;\n try {\n const msg: JsonRpcMessage = JSON.parse(trimmed);\n this.handleMessage(msg);\n } catch (e) {\n // Ignore non-JSON output (agent log etc)\n }\n });\n\n // stderr → log + auth failure detection\n const AUTH_ERROR_PATTERNS = [\n /unauthorized|unauthenticated/i,\n /invalid.*(?:api[_ ]?key|token|credential)/i,\n /auth(?:entication|orization).*(?:fail|error|denied|invalid|expired)/i,\n /(?:api[_ ]?key|token).*(?:missing|required|not set|not found|invalid|expired)/i,\n /ENOENT|command not found|not recognized/i,\n /permission denied/i,\n /rate.?limit|quota.?exceeded/i,\n /login.*required|please.*(?:login|authenticate|sign.?in)/i,\n ];\n\n this.process.stderr?.on('data', (data) => {\n const text = data.toString().trim();\n if (!text) return;\n console.log(`[ACP:${this.type}:stderr] ${text.slice(0, 300)}`);\n\n // Maintain stderr buffer (recent 20 lines)\n this.stderrBuffer.push(text);\n if (this.stderrBuffer.length > 20) this.stderrBuffer.shift();\n\n // Auth failure detection\n for (const pattern of AUTH_ERROR_PATTERNS) {\n if (pattern.test(text)) {\n if (/ENOENT|command not found|not recognized/i.test(text)) {\n this.errorReason = 'not_installed';\n this.errorMessage = `Command '${command}' not found. Install: ${(this.provider as any).install || 'check documentation'}`;\n } else {\n this.errorReason = 'auth_failed';\n this.errorMessage = text.slice(0, 300);\n }\n console.warn(`[ACP:${this.type}] Error detected (${this.errorReason}): ${this.errorMessage?.slice(0, 100)}`);\n break;\n }\n }\n });\n\n // kill process detect\n this.process.on('exit', (code, signal) => {\n const elapsed = Date.now() - this.spawnedAt;\n console.log(`[ACP:${this.type}] Process exited: code=${code} signal=${signal} elapsed=${elapsed}ms`);\n\n // Exit code analysis\n if (code !== 0 && code !== null) {\n if (!this.errorReason) {\n if (code === 127) {\n this.errorReason = 'not_installed';\n this.errorMessage = `Command '${command}' not found (exit code 127). Install: ${(this.provider as any).install || 'check documentation'}`;\n } else if (elapsed < 3000) {\n // 3-second crash → likely install/auth issue\n this.errorReason = this.stderrBuffer.length > 0 ? 'crash' : 'spawn_error';\n this.errorMessage = this.stderrBuffer.length > 0\n ? `Agent crashed immediately (exit code ${code}): ${this.stderrBuffer.slice(-3).join(' | ').slice(0, 300)}`\n : `Agent exited immediately with code ${code}. The agent may not be installed correctly.`;\n } else {\n this.errorReason = 'crash';\n this.errorMessage = `Agent exited with code ${code}${this.stderrBuffer.length > 0 ? ': ' + this.stderrBuffer.slice(-1)[0]?.slice(0, 200) : ''}`;\n }\n }\n }\n\n this.currentStatus = this.errorReason ? 'error' : 'stopped';\n this.detectStatusTransition();\n });\n\n this.process.on('error', (err) => {\n console.error(`[ACP:${this.type}] Process spawn error:`, err.message);\n if (err.message.includes('ENOENT')) {\n this.errorReason = 'not_installed';\n this.errorMessage = `Command '${command}' not found. Install: ${(this.provider as any).install || 'check documentation'}`;\n } else {\n this.errorReason = 'spawn_error';\n this.errorMessage = err.message;\n }\n this.currentStatus = 'error';\n this.detectStatusTransition();\n });\n\n // ACP initialize handshake\n await this.initialize();\n }\n\n // ─── ACP Protocol ────────────────────────────────\n\n private async initialize(): Promise<void> {\n try {\n const result = await this.sendRequest('initialize', {\n protocolVersion: 1, // number — some agents like Gemini CLI only allow numbers\n clientInfo: {\n name: 'adhdev',\n version: '0.1.0',\n },\n clientCapabilities: {\n roots: true,\n },\n workspaceFolders: [{\n name: path.basename(this.workingDir),\n uri: `file://${this.workingDir}`,\n }],\n });\n\n this.agentCapabilities = result?.capabilities || {};\n console.log(`[ACP:${this.type}] Initialized. Agent capabilities:`, JSON.stringify(this.agentCapabilities));\n\n // initialized notification transmit\n this.sendNotification('initialized');\n\n // new session create\n await this.createSession();\n } catch (e: any) {\n console.error(`[ACP:${this.type}] Initialize failed:`, e?.message);\n if (!this.errorReason) {\n this.errorReason = 'init_failed';\n this.errorMessage = `ACP handshake failed: ${e?.message}${this.stderrBuffer.length > 0 ? '\\n' + this.stderrBuffer.slice(-2).join('\\n').slice(0, 200) : ''}`;\n }\n this.currentStatus = 'error';\n }\n }\n\n private async createSession(): Promise<void> {\n try {\n const result = await this.sendRequest('session/new', {\n cwd: this.workingDir,\n mcpServers: [],\n });\n this.sessionId = result?.sessionId || null;\n this.currentStatus = 'idle';\n this.messages = [];\n\n // DEBUG: session/new response key check\n console.log(`[ACP:${this.type}] session/new result keys: ${result ? Object.keys(result).join(', ') : 'null'}`);\n if (result?.configOptions) console.log(`[ACP:${this.type}] configOptions: ${JSON.stringify(result.configOptions).slice(0, 500)}`);\n if (result?.modes) console.log(`[ACP:${this.type}] modes: ${JSON.stringify(result.modes).slice(0, 300)}`);\n\n // ACP configOptions parsing (model, thought_level etc)\n this.parseConfigOptions(result?.configOptions);\n\n // ACP modes parsing\n this.parseModes(result?.modes);\n\n // Legacy: models.currentModelId (some agent compat)\n if (!this.currentModel && result?.models?.currentModelId) {\n this.currentModel = result.models.currentModelId;\n }\n\n // ─── Static config fallback (for agents without config/* support) ───\n if (this.configOptions.length === 0 && this.provider.staticConfigOptions?.length) {\n this.useStaticConfig = true;\n for (const sc of this.provider.staticConfigOptions) {\n const defaultVal = this.selectedConfig[sc.configId] || sc.defaultValue || sc.options[0]?.value;\n this.configOptions.push({\n category: sc.category,\n configId: sc.configId,\n currentValue: defaultVal,\n options: sc.options.map(o => ({ ...o })),\n });\n if (defaultVal) {\n this.selectedConfig[sc.configId] = defaultVal;\n if (sc.category === 'model') this.currentModel = defaultVal;\n if (sc.category === 'mode') this.currentMode = defaultVal;\n }\n }\n console.log(`[ACP:${this.type}] Using static configOptions (${this.configOptions.length} options)`);\n }\n\n console.log(`[ACP:${this.type}] Session created: ${this.sessionId}${this.currentModel ? ` (model: ${this.currentModel})` : ''}${this.currentMode ? ` (mode: ${this.currentMode})` : ''}`);\n if (this.configOptions.length > 0) {\n console.log(`[ACP:${this.type}] Config options: ${this.configOptions.map(c => `${c.category}(${c.options.length})`).join(', ')}`);\n }\n } catch (e: any) {\n console.warn(`[ACP:${this.type}] session/new failed:`, e?.message);\n this.currentStatus = 'idle';\n }\n }\n\n async sendPrompt(text: string): Promise<void> {\n // Add user message locally\n this.messages.push({\n role: 'user',\n content: text,\n timestamp: Date.now(),\n });\n\n this.currentStatus = 'generating';\n this.partialContent = '';\n this.detectStatusTransition();\n\n try {\n const result = await this.sendRequest('session/prompt', {\n sessionId: this.sessionId,\n prompt: [{ type: 'text', text }],\n }, 300_000); // 5-minute timeout\n\n // Prompt complete → reflect final message\n if (result?.stopReason) {\n this.stopReason = result.stopReason;\n }\n\n // Use content directly from result if available (when partialContent is empty)\n if (!this.partialContent.trim() && result) {\n let responseText = '';\n if (typeof result.content === 'string') {\n responseText = result.content;\n } else if (Array.isArray(result.content)) {\n responseText = result.content\n .filter((p: any) => p.type === 'text')\n .map((p: any) => p.text || '')\n .join('\\n');\n } else if (result.text) {\n responseText = result.text;\n } else if (result.message?.content) {\n const mc = result.message.content;\n if (typeof mc === 'string') responseText = mc;\n else if (Array.isArray(mc)) responseText = mc.filter((p: any) => p.type === 'text').map((p: any) => p.text || '').join('\\n');\n }\n if (responseText.trim()) {\n this.messages.push({\n role: 'assistant',\n content: responseText.trim(),\n timestamp: Date.now(),\n });\n }\n }\n\n // Use last partial as final message\n if (this.partialContent.trim()) {\n this.messages.push({\n role: 'assistant',\n content: this.partialContent.trim(),\n timestamp: Date.now(),\n });\n this.partialContent = '';\n }\n\n this.currentStatus = 'idle';\n this.detectStatusTransition();\n } catch (e: any) {\n console.warn(`[ACP:${this.type}] prompt error:`, e?.message);\n if (this.partialContent.trim()) {\n this.messages.push({\n role: 'assistant',\n content: this.partialContent.trim(),\n timestamp: Date.now(),\n });\n this.partialContent = '';\n }\n this.currentStatus = 'idle';\n this.detectStatusTransition();\n }\n }\n\n private async cancelSession(): Promise<void> {\n this.sendNotification('session/cancel', {\n sessionId: this.sessionId,\n });\n this.currentStatus = 'idle';\n this.detectStatusTransition();\n }\n\n private permissionResolvers: ((approved: boolean) => void)[] = [];\n\n private async resolvePermission(approved: boolean): Promise<void> {\n const resolver = this.permissionResolvers.shift();\n if (resolver) {\n resolver(approved);\n }\n if (this.currentStatus === 'waiting_approval') {\n this.currentStatus = 'generating';\n this.detectStatusTransition();\n }\n }\n\n // ─── JSON-RPC Transport ──────────────────────────\n\n private sendRequest(method: string, params: Record<string, unknown>, timeoutMs = 30_000): Promise<any> {\n return new Promise((resolve, reject) => {\n if (!this.process?.stdin?.writable) {\n reject(new Error('Process stdin not writable'));\n return;\n }\n\n const id = this.requestId++;\n const msg: JsonRpcRequest = {\n jsonrpc: '2.0',\n id,\n method,\n params,\n };\n\n const timer = setTimeout(() => {\n this.pendingRequests.delete(id);\n reject(new Error(`Request ${method} timed out after ${timeoutMs}ms`));\n }, timeoutMs);\n\n this.pendingRequests.set(id, { resolve, reject, timer });\n\n const line = JSON.stringify(msg) + '\\n';\n this.process.stdin.write(line);\n });\n }\n\n private sendNotification(method: string, params?: Record<string, unknown>): void {\n if (!this.process?.stdin?.writable) return;\n\n const msg: JsonRpcNotification = {\n jsonrpc: '2.0',\n method,\n ...(params && { params }),\n };\n\n const line = JSON.stringify(msg) + '\\n';\n this.process.stdin.write(line);\n }\n\n private handleMessage(msg: JsonRpcMessage): void {\n // Response to our request\n if ('id' in msg && msg.id !== undefined && !('method' in msg && msg.method)) {\n const pending = this.pendingRequests.get(msg.id as number);\n if (pending) {\n clearTimeout(pending.timer);\n this.pendingRequests.delete(msg.id as number);\n const resp = msg as JsonRpcResponse;\n if (resp.error) {\n pending.reject(new Error(`${resp.error.message} (${resp.error.code})`));\n } else {\n pending.resolve(resp.result);\n }\n }\n return;\n }\n\n // Notification from agent\n if ('method' in msg) {\n this.handleNotification(msg as JsonRpcNotification);\n\n // Request from agent (has id + method)\n if ('id' in msg && msg.id !== undefined) {\n this.handleAgentRequest(msg as JsonRpcRequest);\n }\n }\n }\n\n private handleNotification(msg: JsonRpcNotification): void {\n switch (msg.method) {\n case 'session/update': {\n const params = msg.params as any;\n this.handleSessionUpdate(params);\n break;\n }\n default:\n break;\n }\n }\n\n private handleAgentRequest(msg: JsonRpcRequest): void {\n switch (msg.method) {\n case 'fs/readTextFile':\n case 'fs/writeTextFile': {\n // File system access — currently not supported\n this.sendResponse(msg.id, null, {\n code: -32601,\n message: 'File system access not supported by ADHDev client',\n });\n break;\n }\n case 'requestPermission': {\n // Approval request → switch to waiting_approval status\n this.currentStatus = 'waiting_approval';\n this.detectStatusTransition();\n\n // approval wait\n const promise = new Promise<boolean>((resolve) => {\n this.permissionResolvers.push(resolve);\n\n // 5-minute timeout → auto-reject\n setTimeout(() => {\n const idx = this.permissionResolvers.indexOf(resolve);\n if (idx >= 0) {\n this.permissionResolvers.splice(idx, 1);\n resolve(false);\n }\n }, 300_000);\n });\n\n promise.then((approved) => {\n this.sendResponse(msg.id, {\n outcome: approved ? 'approved' : 'denied',\n });\n });\n break;\n }\n case 'terminal/create':\n case 'terminal/output':\n case 'terminal/release':\n case 'terminal/kill':\n case 'terminal/waitForExit': {\n // Terminal access — currently not supported\n this.sendResponse(msg.id, null, {\n code: -32601,\n message: 'Terminal not supported by ADHDev client',\n });\n break;\n }\n default: {\n // Unknown request\n this.sendResponse(msg.id, null, {\n code: -32601,\n message: `Method ${msg.method} not supported`,\n });\n }\n }\n }\n\n private sendResponse(id: number, result: any, error?: { code: number; message: string }): void {\n if (!this.process?.stdin?.writable) return;\n\n const msg: JsonRpcResponse = {\n jsonrpc: '2.0',\n id,\n ...(error ? { error } : { result }),\n };\n\n const line = JSON.stringify(msg) + '\\n';\n this.process.stdin.write(line);\n }\n\n // ─── ACP session/update handle ─────────────────────\n\n private handleSessionUpdate(params: any): void {\n if (!params) return;\n\n // Codex-ACP format: params.update.sessionUpdate === 'agent_message_chunk'\n const update = params.update;\n if (update?.sessionUpdate === 'agent_message_chunk' && update.content) {\n const part = update.content;\n if (part.type === 'text' && part.text) {\n this.partialContent += part.text;\n }\n this.currentStatus = 'generating';\n }\n\n // message delta handle (standard ACP format)\n if (params.messageDelta) {\n const delta = params.messageDelta;\n if (delta.content) {\n for (const part of Array.isArray(delta.content) ? delta.content : [delta.content]) {\n if (part.type === 'text' && part.text) {\n this.partialContent += part.text;\n }\n }\n }\n this.currentStatus = 'generating';\n }\n\n // message complete\n if (params.message) {\n const m = params.message;\n let content = '';\n if (typeof m.content === 'string') {\n content = m.content;\n } else if (Array.isArray(m.content)) {\n content = m.content\n .filter((p: any) => p.type === 'text')\n .map((p: any) => p.text || '')\n .join('\\n');\n }\n\n if (content.trim()) {\n this.messages.push({\n role: m.role || 'assistant',\n content: content.trim(),\n timestamp: Date.now(),\n });\n this.partialContent = '';\n }\n }\n\n // Tool call update\n if (params.toolCallUpdate) {\n const tc = params.toolCallUpdate;\n const existing = this.activeToolCalls.find(t => t.id === tc.id);\n if (existing) {\n if (tc.status) existing.status = tc.status;\n if (tc.output) existing.output = tc.output;\n } else {\n this.activeToolCalls.push({\n id: tc.id || `tc_${Date.now()}`,\n name: tc.name || 'unknown',\n status: tc.status || 'running',\n input: typeof tc.input === 'string' ? tc.input : JSON.stringify(tc.input),\n });\n }\n }\n\n // Stop reason\n if (params.stopReason) {\n this.stopReason = params.stopReason;\n if (params.stopReason !== 'cancelled') {\n this.currentStatus = 'idle';\n }\n this.activeToolCalls = [];\n this.detectStatusTransition();\n }\n\n // Model info (legacy)\n if (params.model) {\n this.currentModel = params.model;\n }\n\n // ACP config_option_update notification\n const upd = params.update || params;\n if (upd?.sessionUpdate === 'config_option_update' && upd.configOptions) {\n this.parseConfigOptions(upd.configOptions);\n }\n // ACP current_mode_update notification\n if (upd?.sessionUpdate === 'current_mode_update' && upd.modeId) {\n this.currentMode = upd.modeId;\n }\n }\n\n // ─── status transition detect ────────────────────────────\n\n private detectStatusTransition(): void {\n const now = Date.now();\n const newStatus = this.currentStatus;\n const dirName = this.workingDir.split('/').filter(Boolean).pop() || 'session';\n const chatTitle = `${this.provider.name} · ${dirName}`;\n\n if (newStatus !== this.lastStatus) {\n if (this.lastStatus === 'idle' && newStatus === 'generating') {\n this.generatingStartedAt = now;\n this.pushEvent({ event: 'agent:generating_started', chatTitle, timestamp: now });\n } else if (newStatus === 'waiting_approval') {\n if (!this.generatingStartedAt) this.generatingStartedAt = now;\n this.pushEvent({\n event: 'agent:waiting_approval', chatTitle, timestamp: now,\n modalMessage: this.activeToolCalls.find(t => t.status === 'running')?.name,\n });\n } else if (newStatus === 'idle' && (this.lastStatus === 'generating' || this.lastStatus === 'waiting_approval')) {\n const duration = this.generatingStartedAt ? Math.round((now - this.generatingStartedAt) / 1000) : 0;\n this.pushEvent({ event: 'agent:generating_completed', chatTitle, duration, timestamp: now });\n this.generatingStartedAt = 0;\n } else if (newStatus === 'stopped') {\n this.pushEvent({ event: 'agent:stopped', chatTitle, timestamp: now });\n }\n this.lastStatus = newStatus;\n }\n\n // Monitor check\n const agentKey = `${this.type}:acp`;\n const monitorEvents = this.monitor.check(agentKey, newStatus, now);\n for (const me of monitorEvents) {\n this.pushEvent({ event: me.type, agentKey: me.agentKey, message: me.message, elapsedSec: me.elapsedSec, timestamp: me.timestamp });\n }\n }\n\n private pushEvent(event: ProviderEvent): void {\n this.events.push(event);\n if (this.events.length > 50) this.events = this.events.slice(-50);\n }\n\n private flushEvents(): ProviderEvent[] {\n const events = [...this.events];\n this.events = [];\n return events;\n }\n\n // ─── external access ─────────────────────────────────\n\n get cliType(): string { return this.type; }\n get cliName(): string { return this.provider.name; }\n\n /** ACP Agent capabilities (available after initialize) */\n getCapabilities(): Record<string, any> { return this.agentCapabilities; }\n}\n","/**\n * ADHDev Launcher — IDE Launch/Relaunch with CDP\n * \n * Launches IDE with Chrome DevTools Protocol (remote-debugging-port).\n * If IDE is already running, terminates it and restarts with CDP option.\n * \n * Pipeline:\n * 1. IDE process detection (already running?)\n * 2. If already running with CDP → reuse as-is\n * 3. If running without CDP → kill process → wait → restart with CDP\n * 4. Not running → start fresh with CDP\n * \n * Usage:\n * adhdev launch — Launch configured IDE with CDP port\n * adhdev launch cursor — Launch Cursor with CDP port\n * adhdev launch --workspace /path — Open specific workspace\n */\n\nimport { execSync, spawn, spawnSync } from 'child_process';\nimport * as net from 'net';\nimport * as os from 'os';\nimport * as path from 'path';\nimport { detectIDEs } from './detector.js';\nimport { IDEInfo } from './detector.js';\nimport { ProviderLoader } from './providers/provider-loader.js';\n\n// ─── Provider-based dynamic IDE infrastructure ────────────────\n// Reads cdpPorts, processNames from provider.js — only create provider.js to add new IDE\n\nlet _providerLoader: ProviderLoader | null = null;\n\nfunction getProviderLoader(): ProviderLoader {\n if (!_providerLoader) {\n _providerLoader = new ProviderLoader({ logFn: () => {} }); // Suppress logs during launch\n _providerLoader.loadAll();\n _providerLoader.registerToDetector(); // IDE provider → detector registry\n }\n return _providerLoader;\n}\n\nfunction getCdpPorts(): Record<string, [number, number]> {\n return getProviderLoader().getCdpPortMap();\n}\n\nfunction getMacAppIdentifiers(): Record<string, string> {\n return getProviderLoader().getMacAppIdentifiers();\n}\n\nfunction getWinProcessNames(): Record<string, string[]> {\n return getProviderLoader().getWinProcessNames();\n}\n\n// ─── Helpers ────────────────────────────────────\n\n/** Find available port (primary → secondary → sequential after) */\nasync function findFreePort(ports: [number, number]): Promise<number> {\n for (const port of ports) {\n const free = await checkPortFree(port);\n if (free) return port;\n }\n // If both ports in use, scan from secondary+1\n let port = ports[1] + 1;\n while (port < ports[1] + 10) {\n if (await checkPortFree(port)) return port;\n port++;\n }\n throw new Error('No free port found');\n}\n\nfunction checkPortFree(port: number): Promise<boolean> {\n return new Promise((resolve) => {\n const server = net.createServer();\n server.unref();\n server.on('error', () => resolve(false));\n server.listen(port, '127.0.0.1', () => {\n server.close(() => resolve(true));\n });\n });\n}\n\n/** Check if CDP responds on port */\nasync function isCdpActive(port: number): Promise<boolean> {\n return new Promise((resolve) => {\n const req = require('http').get(`http://127.0.0.1:${port}/json/version`, {\n timeout: 2000,\n }, (res: any) => {\n let data = '';\n res.on('data', (c: string) => data += c);\n res.on('end', () => {\n try {\n const info = JSON.parse(data);\n resolve(!!info['WebKit-Version'] || !!info['Browser']);\n } catch {\n resolve(false);\n }\n });\n });\n req.on('error', () => resolve(false));\n req.on('timeout', () => { req.destroy(); resolve(false); });\n });\n}\n\n/** Kill IDE process (graceful → force) */\nasync function killIdeProcess(ideId: string): Promise<boolean> {\n const plat = os.platform();\n const appName = getMacAppIdentifiers()[ideId];\n const winProcesses = getWinProcessNames()[ideId];\n\n try {\n if (plat === 'darwin' && appName) {\n // macOS: graceful quit via osascript\n try {\n execSync(`osascript -e 'tell application \"${appName}\" to quit' 2>/dev/null`, {\n timeout: 5000,\n });\n } catch {\n try { execSync(`pkill -f \"${appName}\" 2>/dev/null`); } catch { }\n }\n } else if (plat === 'win32' && winProcesses) {\n // Windows: taskkill for each process name\n for (const proc of winProcesses) {\n try {\n execSync(`taskkill /IM \"${proc}\" /F 2>nul`, { timeout: 5000 });\n } catch { }\n }\n // Process name may differ, so also try via WMIC\n try {\n const exeName = winProcesses[0].replace('.exe', '');\n execSync(`powershell -Command \"Get-Process -Name '${exeName}' -ErrorAction SilentlyContinue | Stop-Process -Force\"`, {\n timeout: 10000,\n });\n } catch { }\n } else {\n try { execSync(`pkill -f \"${ideId}\" 2>/dev/null`); } catch { }\n }\n\n // Wait for process kill (max 15 seconds)\n for (let i = 0; i < 30; i++) {\n await new Promise(r => setTimeout(r, 500));\n if (!isIdeRunning(ideId)) return true;\n }\n\n // Force terminate retry\n if (plat === 'darwin' && appName) {\n try { execSync(`pkill -9 -f \"${appName}\" 2>/dev/null`); } catch { }\n } else if (plat === 'win32' && winProcesses) {\n for (const proc of winProcesses) {\n try { execSync(`taskkill /IM \"${proc}\" /F 2>nul`); } catch { }\n }\n }\n\n await new Promise(r => setTimeout(r, 2000));\n return !isIdeRunning(ideId);\n\n } catch {\n return false;\n }\n}\n\n/** Check if IDE process is running */\nfunction isIdeRunning(ideId: string): boolean {\n const plat = os.platform();\n\n try {\n if (plat === 'darwin') {\n const appName = getMacAppIdentifiers()[ideId];\n if (!appName) return false;\n const result = execSync(`pgrep -f \"${appName}\" 2>/dev/null`, { encoding: 'utf-8' });\n return result.trim().length > 0;\n } else if (plat === 'win32') {\n const winProcesses = getWinProcessNames()[ideId];\n if (!winProcesses) return false;\n // Check each process name\n for (const proc of winProcesses) {\n try {\n const result = execSync(`tasklist /FI \"IMAGENAME eq ${proc}\" /NH 2>nul`, { encoding: 'utf-8' });\n if (result.includes(proc)) return true;\n } catch { }\n }\n // Also check via PowerShell (when tasklist cannot find)\n try {\n const exeName = winProcesses[0].replace('.exe', '');\n const result = execSync(\n `powershell -Command \"(Get-Process -Name '${exeName}' -ErrorAction SilentlyContinue).Count\"`,\n { encoding: 'utf-8', timeout: 5000 }\n );\n return parseInt(result.trim()) > 0;\n } catch { }\n return false;\n } else {\n const result = execSync(`pgrep -f \"${ideId}\" 2>/dev/null`, { encoding: 'utf-8' });\n return result.trim().length > 0;\n }\n } catch {\n return false;\n }\n}\n\n/** Detect currently open workspace path */\nfunction detectCurrentWorkspace(ideId: string): string | undefined {\n const plat = os.platform();\n\n if (plat === 'darwin') {\n try {\n const appName = getMacAppIdentifiers()[ideId];\n if (!appName) return undefined;\n const result = execSync(\n `lsof -c \"${appName}\" 2>/dev/null | grep cwd | head -1 | awk '{print $NF}'`,\n { encoding: 'utf-8', timeout: 3000 }\n );\n const dir = result.trim();\n if (dir && dir !== '/') return dir;\n } catch { }\n } else if (plat === 'win32') {\n // Windows: read IDE recent workspaces from storage.json\n try {\n const fs = require('fs');\n const appNameMap = getMacAppIdentifiers(); // Provider-based dynamic mapping\n const appName = appNameMap[ideId];\n if (appName) {\n const storagePath = path.join(\n process.env.APPDATA || path.join(os.homedir(), 'AppData', 'Roaming'),\n appName, 'storage.json'\n );\n if (fs.existsSync(storagePath)) {\n const data = JSON.parse(fs.readFileSync(storagePath, 'utf-8'));\n // openedPathsList.workspaces3 has recent folders\n const workspaces = data?.openedPathsList?.workspaces3 || data?.openedPathsList?.entries || [];\n if (workspaces.length > 0) {\n const recent = workspaces[0];\n // Can be object { folderUri: 'file:///...' } or string\n const uri = typeof recent === 'string' ? recent : recent?.folderUri;\n if (uri?.startsWith('file:///')) {\n return decodeURIComponent(uri.replace('file:///', ''));\n }\n }\n }\n }\n } catch { }\n }\n\n return undefined;\n}\n\n// ─── Launch Logic ───────────────────────────────\n\nexport interface LaunchOptions {\n ideId?: string;\n workspace?: string;\n newWindow?: boolean;\n}\n\nexport interface LaunchResult {\n success: boolean;\n ideId: string;\n ideName: string;\n port: number;\n action: 'started' | 'restarted' | 'reused' | 'failed';\n message: string;\n error?: string;\n}\n\n/**\n * Execute IDE with CDP port (relaunch pipeline)\n * \n * 1. IDE detect\n * 2. per-fixed IDE CDP port determine\n * 3. CDP not active → reuse\n * 4. IDE execute during but CDP none → terminate → restart with CDP\n * 5. IDE not running → start fresh with CDP\n */\nexport async function launchWithCdp(options: LaunchOptions = {}): Promise<LaunchResult> {\n const platform = os.platform();\n\n // 1. IDE determine\n let targetIde: IDEInfo | undefined;\n const ides = await detectIDEs();\n\n if (options.ideId) {\n targetIde = ides.find(i => i.id === options.ideId && i.installed);\n if (!targetIde) {\n return {\n success: false, ideId: options.ideId, ideName: options.ideId,\n port: 0, action: 'failed',\n message: '', error: `IDE '${options.ideId}' not found or not installed`,\n };\n }\n } else {\n const { loadConfig } = await import('./config.js');\n const config = loadConfig();\n if (config.selectedIde) {\n targetIde = ides.find(i => i.id === config.selectedIde && i.installed);\n }\n if (!targetIde) {\n targetIde = ides.find(i => i.installed);\n }\n if (!targetIde) {\n return {\n success: false, ideId: 'unknown', ideName: 'Unknown',\n port: 0, action: 'failed',\n message: '', error: 'No IDE found. Install VS Code, Cursor, or Antigravity first.',\n };\n }\n }\n\n // 2. per-fixed IDE CDP port determine\n const portPair = getCdpPorts()[targetIde.id] || [9333, 9334];\n\n // 3. Check if CDP is not yet enabled\n for (const port of portPair) {\n if (await isCdpActive(port)) {\n return {\n success: true, ideId: targetIde.id, ideName: targetIde.displayName,\n port, action: 'reused',\n message: `CDP already active on port ${port}`,\n };\n }\n }\n\n // 4. Check if IDE is currently running\n const alreadyRunning = isIdeRunning(targetIde.id);\n const workspace = options.workspace || (alreadyRunning ? detectCurrentWorkspace(targetIde.id) : undefined);\n\n // 5. If IDE is running, terminate it\n if (alreadyRunning) {\n const killed = await killIdeProcess(targetIde.id);\n if (!killed) {\n return {\n success: false, ideId: targetIde.id, ideName: targetIde.displayName,\n port: 0, action: 'failed',\n message: '', error: `Could not stop ${targetIde.displayName}. Close it manually and try again.`,\n };\n }\n // Wait for process full termination\n await new Promise(r => setTimeout(r, 3000));\n }\n\n // 6. Find available port\n const port = await findFreePort(portPair);\n\n // 7. Execute with CDP\n try {\n if (platform === 'darwin') {\n await launchMacOS(targetIde, port, workspace, options.newWindow);\n } else if (platform === 'win32') {\n await launchWindows(targetIde, port, workspace, options.newWindow);\n } else {\n await launchLinux(targetIde, port, workspace, options.newWindow);\n }\n\n // Wait for CDP to enable (max 15 seconds)\n let cdpReady = false;\n for (let i = 0; i < 30; i++) {\n await new Promise(r => setTimeout(r, 500));\n if (await isCdpActive(port)) {\n cdpReady = true;\n break;\n }\n }\n\n return {\n success: true, ideId: targetIde.id, ideName: targetIde.displayName,\n port, action: alreadyRunning ? 'restarted' : 'started',\n message: cdpReady\n ? `${targetIde.displayName} launched with CDP on port ${port}`\n : `${targetIde.displayName} launched (CDP may take a moment to initialize)`,\n };\n } catch (e: any) {\n return {\n success: false, ideId: targetIde.id, ideName: targetIde.displayName,\n port, action: 'failed',\n message: '', error: e?.message || String(e),\n };\n }\n}\n\n// ─── Platform Launch ────────────────────────────\n\nasync function launchMacOS(ide: IDEInfo, port: number, workspace?: string, newWindow?: boolean): Promise<void> {\n const appName = getMacAppIdentifiers()[ide.id];\n\n const args = ['--remote-debugging-port=' + port];\n if (newWindow) args.push('--new-window');\n if (workspace) args.push(workspace);\n\n if (appName) {\n // 'open -a' execution (ensures GUI session)\n const openArgs = ['-a', appName, '--args', ...args];\n spawn('open', openArgs, { detached: true, stdio: 'ignore' }).unref();\n } else if (ide.cliCommand) {\n // CLI based execute\n spawn(ide.cliCommand, args, { detached: true, stdio: 'ignore' }).unref();\n } else {\n throw new Error(`No app identifier or CLI for ${ide.displayName}`);\n }\n}\n\nasync function launchWindows(ide: IDEInfo, port: number, workspace?: string, newWindow?: boolean): Promise<void> {\n const cli = ide.cliCommand;\n if (!cli) {\n throw new Error(`No CLI command for ${ide.displayName}. Please add it to PATH.`);\n }\n\n // Compose arguments for CLI command — IDE CLI wrapper (.cmd) handles Electron execution\n const parts = [`\"${cli}\"`, `--remote-debugging-port=${port}`];\n if (newWindow) parts.push('--new-window');\n if (workspace) parts.push(`\"${workspace}\"`);\n\n const fullCmd = parts.join(' ');\n\n // exec fire-and-forget: delegate to CLI to properly start IDE process\n const { exec: execCmd } = require('child_process');\n execCmd(fullCmd, { windowsHide: true }, () => {\n // IDE process runs independently even after CLI per-terminates wrap\n });\n}\n\nasync function launchLinux(ide: IDEInfo, port: number, workspace?: string, newWindow?: boolean): Promise<void> {\n const cli = ide.cliCommand;\n if (!cli) {\n throw new Error(`No CLI command for ${ide.displayName}. Make sure it's in PATH.`);\n }\n\n const args = ['--remote-debugging-port=' + port];\n if (newWindow) args.push('--new-window');\n if (workspace) args.push(workspace);\n\n spawn(cli, args, { detached: true, stdio: 'ignore' }).unref();\n}\n\nexport function getAvailableIdeIds(): string[] {\n return getProviderLoader().getAvailableIdeTypes();\n}\n","/**\n * ProviderLoader — Provider discovery + OS/version override resolution\n * \n * Role:\n * 1. Load provider.js from _builtin/ directory\n * 2. Load user custom from ~/.adhdev/providers/ (overrides)\n * 3. Apply OS/version overrides (process.platform + detected IDE version)\n * 4. Hot-reload support (fs.watch)\n * \n * Design principles:\n * - Load JS files via require() (CJS compatible)\n * - User custom can override builtin\n * - provider.js files are independent, so load order doesn't matter\n */\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\nimport { registerIDEDefinition } from '../detector.js';\nimport type {\n ProviderModule,\n ProviderCategory,\n ProviderScripts,\n ProviderSettingSchema,\n ResolvedProvider,\n} from './contracts.js';\n\nexport class ProviderLoader {\n private providers = new Map<string, ProviderModule>();\n private builtinDir: string;\n private userDir: string;\n private upstreamDir: string;\n private watchers: fs.FSWatcher[] = [];\n private logFn: (msg: string) => void;\n\n private static readonly GITHUB_TARBALL_URL = 'https://github.com/vilmire/adhdev-providers/archive/refs/heads/main.tar.gz';\n private static readonly META_FILE = '.meta.json';\n\n constructor(options?: {\n builtinDir?: string;\n userDir?: string;\n logFn?: (msg: string) => void;\n }) {\n // Builtin directory: providers/_builtin/ (bundled with npm package)\n this.builtinDir = options?.builtinDir ||\n path.resolve(__dirname, '../providers/_builtin');\n // User custom directory: ~/.adhdev/providers/\n this.userDir = options?.userDir ||\n path.join(os.homedir(), '.adhdev', 'providers');\n // Upstream auto-download directory: ~/.adhdev/providers/.upstream/\n this.upstreamDir = path.join(this.userDir, '.upstream');\n this.logFn = options?.logFn || ((msg) => console.log(msg));\n }\n\n private log(msg: string): void {\n this.logFn(`[ProviderLoader] ${msg}`);\n }\n\n // ─── Public API ────────────────────────────────\n\n /**\n * Load all providers (3-tier priority)\n * 1. _builtin/ (bundled fallback)\n * 2. .upstream/ (GitHub auto-download)\n * 3. User custom (~/.adhdev/providers/ excluding _upstream)\n * Later loads override earlier ones, so user custom always wins.\n */\n loadAll(): void {\n this.providers.clear();\n\n // 1. Load builtin (npm package bundle — lowest priority)\n const builtinCount = this.loadDir(this.builtinDir);\n this.log(`Loaded ${builtinCount} builtin providers`);\n\n // 2. Load upstream (GitHub auto-download — overrides builtin)\n let upstreamCount = 0;\n if (fs.existsSync(this.upstreamDir)) {\n upstreamCount = this.loadDir(this.upstreamDir);\n if (upstreamCount > 0) {\n this.log(`Loaded ${upstreamCount} upstream providers (auto-updated)`);\n }\n }\n\n // 3. Load user custom (excluding _upstream — highest priority, never auto-updated)\n if (fs.existsSync(this.userDir)) {\n const userCount = this.loadDir(this.userDir, ['.upstream']);\n if (userCount > 0) {\n this.log(`Loaded ${userCount} user custom providers (never auto-updated)`);\n }\n }\n\n this.log(`Total: ${this.providers.size} providers [${[...this.providers.keys()].join(', ')}]`);\n\n // ⚠️ Warning: using builtin fallback only, upstream not available\n if (upstreamCount === 0 && builtinCount > 0) {\n this.log(`⚠ Using bundled providers only (upstream not available). Run 'adhdev daemon' with internet to auto-update.`);\n }\n\n // ❌ Error: no providers found anywhere\n if (this.providers.size === 0) {\n this.log(`❌ No providers loaded! Check builtinDir: ${this.builtinDir}`);\n }\n }\n\n /**\n * Get a provider by type\n */\n get(type: string): ProviderModule | undefined {\n return this.providers.get(type);\n }\n\n /**\n * Resolve provider type by alias\n * 'claude' → 'claude-cli', 'codex' → 'codex-cli' etc\n * Returns input as-is if no match found.\n */\n resolveAlias(input: string): string {\n // 1. directly match\n if (this.providers.has(input)) return input;\n // 2. alias match\n for (const p of this.providers.values()) {\n if (p.aliases?.includes(input)) return p.type;\n }\n return input;\n }\n\n /**\n * Get provider with alias resolution (get + alias fallback)\n */\n getByAlias(input: string): ProviderModule | undefined {\n return this.providers.get(this.resolveAlias(input));\n }\n\n /**\n * Build CLI/ACP detection list (replaces cli-detector)\n * Dynamically generated from provider.js spawn.command.\n */\n getCliDetectionList(): { id: string; displayName: string; icon: string; command: string; category: string }[] {\n const result: { id: string; displayName: string; icon: string; command: string; category: string }[] = [];\n for (const p of this.providers.values()) {\n if ((p.category === 'cli' || p.category === 'acp') && p.spawn?.command) {\n result.push({\n id: p.type,\n displayName: p.displayName || p.name,\n icon: p.icon || '🔧',\n command: p.spawn.command,\n category: p.category,\n });\n }\n }\n return result;\n }\n\n /**\n * List providers by category\n */\n getByCategory(cat: ProviderCategory): ProviderModule[] {\n return [...this.providers.values()].filter(p => p.category === cat);\n }\n\n /**\n * Extension Extension providers with extensionIdPattern only\n * (used by discoverAgentWebviews in daemon-cdp.ts)\n */\n getExtensionProviders(): ProviderModule[] {\n return [...this.providers.values()].filter(\n p => p.category === 'extension' && p.extensionIdPattern\n );\n }\n\n /**\n * All loaded providers\n */\n getAll(): ProviderModule[] {\n return [...this.providers.values()];\n }\n\n /**\n * Check if a provider is enabled (per-IDE)\n * Checks ideSettings[ideType].extensions[type].enabled.\n * Default false (disabled) — user must explicitly enable.\n * Always returns true when called without ideType.\n */\n isEnabled(type: string, ideType?: string): boolean {\n if (!ideType) return true;\n try {\n const { loadConfig } = require('../config.js');\n const config = loadConfig();\n const val = config.ideSettings?.[ideType]?.extensions?.[type]?.enabled;\n return val === true; // undefined → false (default inactive)\n } catch {\n return false;\n }\n }\n\n /**\n * Save IDE extension enabled setting\n */\n setIdeExtensionEnabled(ideType: string, extensionType: string, enabled: boolean): boolean {\n try {\n const { loadConfig, saveConfig } = require('../config.js');\n const config = loadConfig();\n if (!config.ideSettings) config.ideSettings = {};\n if (!config.ideSettings[ideType]) config.ideSettings[ideType] = {};\n if (!config.ideSettings[ideType].extensions) config.ideSettings[ideType].extensions = {};\n config.ideSettings[ideType].extensions[extensionType] = { enabled };\n saveConfig(config);\n this.log(`IDE extension setting: ${ideType}.${extensionType}.enabled = ${enabled}`);\n return true;\n } catch (e) {\n this.log(`Failed to save IDE extension setting: ${(e as Error).message}`);\n return false;\n }\n }\n\n /**\n * Return only enabled providers by category (per-IDE)\n */\n getEnabledByCategory(cat: ProviderCategory, ideType?: string): ProviderModule[] {\n return this.getByCategory(cat).filter(p => this.isEnabled(p.type, ideType));\n }\n\n /**\n * Extension Enabled extension providers with extensionIdPattern only (per-IDE)\n */\n getEnabledExtensionProviders(ideType?: string): ProviderModule[] {\n return this.getExtensionProviders().filter(p => this.isEnabled(p.type, ideType));\n }\n\n /**\n * Return CDP port map for IDE providers\n * Used by launch.ts, adhdev-daemon.ts\n */\n getCdpPortMap(): Record<string, [number, number]> {\n const map: Record<string, [number, number]> = {};\n for (const p of this.providers.values()) {\n if (p.category === 'ide' && p.cdpPorts) {\n map[p.type] = p.cdpPorts as [number, number];\n }\n }\n return map;\n }\n\n /**\n * Return IDE process name map (macOS)\n */\n getMacAppIdentifiers(): Record<string, string> {\n const map: Record<string, string> = {};\n for (const p of this.providers.values()) {\n if (p.category === 'ide' && p.processNames?.darwin) {\n map[p.type] = p.processNames.darwin as string;\n }\n }\n return map;\n }\n\n /**\n * Return IDE process name map (Windows)\n */\n getWinProcessNames(): Record<string, string[]> {\n const map: Record<string, string[]> = {};\n for (const p of this.providers.values()) {\n if (p.category === 'ide' && p.processNames?.win32) {\n map[p.type] = p.processNames.win32 as string[];\n }\n }\n return map;\n }\n\n /**\n * Available IDE types (only those with cdpPorts)\n */\n getAvailableIdeTypes(): string[] {\n return [...this.providers.values()]\n .filter(p => p.category === 'ide' && p.cdpPorts)\n .map(p => p.type);\n }\n\n /**\n * Register IDE providers to core/detector registry\n * → Enables detectIDEs() to detect provider.js-based IDEs\n */\n registerToDetector(): number {\n let count = 0;\n for (const p of this.providers.values()) {\n if (p.category === 'ide' && p.cli && p.paths) {\n registerIDEDefinition({\n id: p.type,\n name: p.name,\n displayName: p.displayName || p.name,\n icon: p.icon || '💻',\n extensionSupport: 'full',\n cli: p.cli,\n paths: p.paths as { darwin?: string[]; win32?: string[]; linux?: string[] },\n });\n count++;\n }\n }\n this.log(`Registered ${count} IDE providers to detector`);\n return count;\n }\n\n /**\n * Return final provider with OS/version overrides applied\n */\n resolve(type: string, context?: { os?: string; version?: string }): ResolvedProvider | undefined {\n const base = this.providers.get(type);\n if (!base) return undefined;\n\n const currentOs = context?.os || process.platform;\n const currentVersion = context?.version;\n\n // Deep clone to avoid mutating the original\n const resolved: ResolvedProvider = JSON.parse(JSON.stringify(base));\n // Restore RegExp from original (lost during JSON.parse)\n if (base.extensionIdPattern) {\n resolved.extensionIdPattern = base.extensionIdPattern;\n }\n // Restore script functions (lost during JSON.parse)\n if (base.scripts) {\n resolved.scripts = { ...base.scripts };\n }\n\n // 1. Apply OS override\n if (base.os?.[currentOs]) {\n const osOverride = base.os[currentOs];\n if (osOverride.scripts) {\n resolved.scripts = { ...resolved.scripts, ...osOverride.scripts };\n }\n if (osOverride.inputMethod) resolved.inputMethod = osOverride.inputMethod;\n if (osOverride.inputSelector) resolved.inputSelector = osOverride.inputSelector;\n resolved._resolvedOs = currentOs;\n }\n\n // 2. Apply version override\n if (currentVersion && base.versions) {\n for (const [range, override] of Object.entries(base.versions)) {\n if (this.matchesVersion(currentVersion, range)) {\n if (override.scripts) {\n resolved.scripts = { ...resolved.scripts, ...override.scripts };\n }\n resolved._resolvedVersion = currentVersion;\n }\n }\n }\n\n // 3. Composite override (OS + version)\n if (base.overrides) {\n for (const override of base.overrides) {\n const osMatch = !override.when.os || override.when.os === currentOs;\n const verMatch = !override.when.version || (currentVersion && this.matchesVersion(currentVersion, override.when.version));\n if (osMatch && verMatch && override.scripts) {\n resolved.scripts = { ...resolved.scripts, ...override.scripts };\n }\n }\n }\n\n return resolved;\n }\n\n /**\n * Hot-reload: start watching for file changes\n */\n watch(): void {\n this.stopWatch();\n const watchDir = (dir: string) => {\n if (!fs.existsSync(dir)) {\n // Create directory if missing (so user can drop files)\n try { fs.mkdirSync(dir, { recursive: true }); } catch { return; }\n }\n try {\n const watcher = fs.watch(dir, { recursive: true }, (event, filename) => {\n if (filename?.endsWith('.js') || filename?.endsWith('.json')) {\n this.log(`File changed: ${filename}, reloading...`);\n this.loadAll();\n }\n });\n this.watchers.push(watcher);\n } catch (e) {\n this.log(`Watch failed for ${dir}: ${(e as Error).message}`);\n }\n };\n watchDir(this.builtinDir);\n watchDir(this.userDir);\n }\n\n /**\n * Stop hot-reload\n */\n stopWatch(): void {\n for (const w of this.watchers) {\n try { w.close(); } catch { }\n }\n this.watchers = [];\n }\n\n /**\n * Full reload\n */\n reload(): void {\n this.log('Reloading all providers...');\n // Clear require cache (hot-reload)\n for (const key of Object.keys(require.cache)) {\n if (key.includes('providers') && (key.endsWith('.js') || key.endsWith('.json'))) {\n delete require.cache[key];\n }\n }\n this.loadAll();\n }\n\n // ─── Upstream Auto-Update ─────────────────────────\n\n /**\n * Download latest providers tarball from GitHub → extract to .upstream/\n * - ETag-based change detection (skip if unchanged)\n * - Never touches user custom files in ~/.adhdev/providers/\n * - Runs in background; existing providers are kept on failure\n * \n * @returns Whether an update occurred\n */\n async fetchLatest(): Promise<{ updated: boolean; error?: string }> {\n const https = require('https') as typeof import('https');\n const { execSync } = require('child_process') as typeof import('child_process');\n\n const metaPath = path.join(this.upstreamDir, ProviderLoader.META_FILE);\n let prevEtag = '';\n let prevTimestamp = 0;\n\n // Read previous metadata\n try {\n if (fs.existsSync(metaPath)) {\n const meta = JSON.parse(fs.readFileSync(metaPath, 'utf-8'));\n prevEtag = meta.etag || '';\n prevTimestamp = meta.timestamp || 0;\n }\n } catch { }\n\n // Minimum 30-minute interval (prevent excessive checks)\n const MIN_INTERVAL_MS = 30 * 60 * 1000;\n if (prevTimestamp && (Date.now() - prevTimestamp) < MIN_INTERVAL_MS) {\n this.log('Upstream check skipped (last check < 30min ago)');\n return { updated: false };\n }\n\n try {\n // Step 1: HEAD request to check ETag\n const etag = await new Promise<string>((resolve, reject) => {\n const options = {\n method: 'HEAD',\n hostname: 'github.com',\n path: '/vilmire/adhdev-providers/archive/refs/heads/main.tar.gz',\n headers: { 'User-Agent': 'adhdev-launcher' },\n timeout: 10000,\n };\n\n const req = https.request(options, (res) => {\n // GitHub 302 redirect → follow\n if (res.statusCode === 302 && res.headers.location) {\n const url = new URL(res.headers.location);\n const req2 = https.request({\n method: 'HEAD',\n hostname: url.hostname,\n path: url.pathname + (url.search || ''),\n headers: { 'User-Agent': 'adhdev-launcher' },\n timeout: 10000,\n }, (res2) => {\n resolve(res2.headers.etag || res2.headers['last-modified'] || '');\n });\n req2.on('error', reject);\n req2.on('timeout', () => { req2.destroy(); reject(new Error('timeout')); });\n req2.end();\n } else {\n resolve(res.headers.etag || res.headers['last-modified'] || '');\n }\n });\n req.on('error', reject);\n req.on('timeout', () => { req.destroy(); reject(new Error('timeout')); });\n req.end();\n });\n\n // Compare ETag — skip if unchanged\n if (etag && etag === prevEtag) {\n // Update timestamp only\n this.writeMeta(metaPath, prevEtag, Date.now());\n this.log('Upstream unchanged (ETag match)');\n return { updated: false };\n }\n\n // Step 2: Download + extract\n this.log('Downloading latest providers from GitHub...');\n\n const tmpTar = path.join(os.tmpdir(), `adhdev-providers-${Date.now()}.tar.gz`);\n const tmpExtract = path.join(os.tmpdir(), `adhdev-providers-extract-${Date.now()}`);\n\n // Download tarball\n await this.downloadFile(ProviderLoader.GITHUB_TARBALL_URL, tmpTar);\n\n // Extract\n fs.mkdirSync(tmpExtract, { recursive: true });\n execSync(`tar -xzf \"${tmpTar}\" -C \"${tmpExtract}\"`, { timeout: 30000 });\n\n // Tarball internal structure: adhdev-providers-main/ide/... → strip 1 level\n const extracted = fs.readdirSync(tmpExtract);\n const rootDir = extracted.find(d =>\n fs.statSync(path.join(tmpExtract, d)).isDirectory() && d.startsWith('adhdev-providers')\n );\n if (!rootDir) throw new Error('Unexpected tarball structure');\n\n const sourceDir = path.join(tmpExtract, rootDir);\n\n // .upstream replacement (atomic-ish: rename old → copy new → delete old)\n const backupDir = this.upstreamDir + '.bak';\n if (fs.existsSync(this.upstreamDir)) {\n // Backup\n if (fs.existsSync(backupDir)) fs.rmSync(backupDir, { recursive: true, force: true });\n fs.renameSync(this.upstreamDir, backupDir);\n }\n\n try {\n // Copy new upstream\n this.copyDirRecursive(sourceDir, this.upstreamDir);\n // Save metadata\n this.writeMeta(metaPath, etag || `ts-${Date.now()}`, Date.now());\n // Backup remove\n if (fs.existsSync(backupDir)) fs.rmSync(backupDir, { recursive: true, force: true });\n } catch (e) {\n // Restore backup on copy failure\n if (fs.existsSync(backupDir)) {\n if (fs.existsSync(this.upstreamDir)) fs.rmSync(this.upstreamDir, { recursive: true, force: true });\n fs.renameSync(backupDir, this.upstreamDir);\n }\n throw e;\n }\n\n // Cleanup temp\n try { fs.rmSync(tmpTar, { force: true }); } catch { }\n try { fs.rmSync(tmpExtract, { recursive: true, force: true }); } catch { }\n\n const upstreamCount = this.countProviders(this.upstreamDir);\n this.log(`✅ Upstream updated: ${upstreamCount} providers`);\n\n return { updated: true };\n } catch (e: any) {\n this.log(`⚠ Upstream fetch failed (using existing): ${e?.message}`);\n // Update timestamp even on failure (prevent continuous retries)\n this.writeMeta(metaPath, prevEtag, Date.now());\n return { updated: false, error: e?.message };\n }\n }\n\n /** HTTP(S) file download (follows redirects) */\n private downloadFile(url: string, destPath: string): Promise<void> {\n const https = require('https') as typeof import('https');\n const http = require('http') as typeof import('http');\n\n return new Promise((resolve, reject) => {\n const doRequest = (reqUrl: string, redirectCount = 0) => {\n if (redirectCount > 5) { reject(new Error('Too many redirects')); return; }\n const mod = reqUrl.startsWith('https') ? https : http;\n const req = mod.get(reqUrl, { headers: { 'User-Agent': 'adhdev-launcher' }, timeout: 60000 }, (res) => {\n if (res.statusCode === 301 || res.statusCode === 302) {\n doRequest(res.headers.location!, redirectCount + 1);\n return;\n }\n if (res.statusCode !== 200) {\n reject(new Error(`HTTP ${res.statusCode}`));\n return;\n }\n const ws = fs.createWriteStream(destPath);\n res.pipe(ws);\n ws.on('finish', () => { ws.close(); resolve(); });\n ws.on('error', reject);\n });\n req.on('error', reject);\n req.on('timeout', () => { req.destroy(); reject(new Error('Download timeout')); });\n };\n doRequest(url);\n });\n }\n\n /** Recursive directory copy */\n private copyDirRecursive(src: string, dest: string): void {\n fs.mkdirSync(dest, { recursive: true });\n for (const entry of fs.readdirSync(src, { withFileTypes: true })) {\n const srcPath = path.join(src, entry.name);\n const destPath = path.join(dest, entry.name);\n if (entry.isDirectory()) {\n this.copyDirRecursive(srcPath, destPath);\n } else {\n fs.copyFileSync(srcPath, destPath);\n }\n }\n }\n\n /** .meta.json save */\n private writeMeta(metaPath: string, etag: string, timestamp: number): void {\n try {\n fs.mkdirSync(path.dirname(metaPath), { recursive: true });\n fs.writeFileSync(metaPath, JSON.stringify({\n etag,\n timestamp,\n lastCheck: new Date(timestamp).toISOString(),\n source: ProviderLoader.GITHUB_TARBALL_URL,\n }, null, 2));\n } catch { }\n }\n\n /** Count provider files (provider.js or provider.json) */\n private countProviders(dir: string): number {\n if (!fs.existsSync(dir)) return 0;\n let count = 0;\n const scan = (d: string) => {\n try {\n for (const entry of fs.readdirSync(d, { withFileTypes: true })) {\n if (entry.isDirectory()) scan(path.join(d, entry.name));\n else if (entry.name === 'provider.json') count++;\n }\n } catch { }\n };\n scan(dir);\n return count;\n }\n\n // ─── Provider Settings API ─────────────────────────\n\n /**\n * Get public settings schema for a provider (for dashboard UI rendering)\n */\n getPublicSettings(type: string): ProviderSettingSchema[] {\n const provider = this.providers.get(type);\n if (!provider?.settings) return [];\n return Object.entries(provider.settings)\n .filter(([, def]) => (def as any).public === true)\n .map(([key, def]) => ({ key, ...(def as any) }));\n }\n\n /**\n * Get public settings schema for all providers\n */\n getAllPublicSettings(): Record<string, ProviderSettingSchema[]> {\n const result: Record<string, ProviderSettingSchema[]> = {};\n for (const [type] of this.providers) {\n const settings = this.getPublicSettings(type);\n if (settings.length > 0) result[type] = settings;\n }\n return result;\n }\n\n /**\n * Resolved setting value for a provider (default + user override)\n */\n getSettingValue(type: string, key: string): any {\n const provider = this.providers.get(type);\n const schemaDef = provider?.settings?.[key];\n const defaultVal = schemaDef ? (schemaDef as any).default : undefined;\n\n // Load user-saved value\n try {\n const { loadConfig } = require('../config.js');\n const config = loadConfig();\n const userVal = config.providerSettings?.[type]?.[key];\n return userVal !== undefined ? userVal : defaultVal;\n } catch {\n return defaultVal;\n }\n }\n\n /**\n * All resolved settings for a provider (default + user override)\n */\n getSettings(type: string): Record<string, any> {\n const provider = this.providers.get(type);\n if (!provider?.settings) return {};\n const result: Record<string, any> = {};\n for (const [key, def] of Object.entries(provider.settings)) {\n result[key] = this.getSettingValue(type, key);\n }\n return result;\n }\n\n /**\n * Save provider setting value (writes to config.json)\n */\n setSetting(type: string, key: string, value: any): boolean {\n const provider = this.providers.get(type);\n const schemaDef = provider?.settings?.[key] as any;\n if (!schemaDef) return false;\n\n // Non-public settings cannot be modified externally\n if (!schemaDef.public) return false;\n\n // Type validation\n if (schemaDef.type === 'boolean' && typeof value !== 'boolean') return false;\n if (schemaDef.type === 'number') {\n if (typeof value !== 'number') return false;\n if (schemaDef.min !== undefined && value < schemaDef.min) return false;\n if (schemaDef.max !== undefined && value > schemaDef.max) return false;\n }\n if (schemaDef.type === 'select' && schemaDef.options && !schemaDef.options.includes(value)) return false;\n\n try {\n const { loadConfig, saveConfig } = require('../config.js');\n const config = loadConfig();\n if (!config.providerSettings) config.providerSettings = {};\n if (!config.providerSettings[type]) config.providerSettings[type] = {};\n config.providerSettings[type][key] = value;\n saveConfig(config);\n this.log(`Setting updated: ${type}.${key} = ${JSON.stringify(value)}`);\n return true;\n } catch (e) {\n this.log(`Failed to save setting: ${(e as Error).message}`);\n return false;\n }\n }\n\n // ─── Private ───────────────────────────────────\n\n /**\n * Recursively scan directory to load provider files\n * Supports two formats:\n * 1. provider.json (metadata) + scripts.js (optional CDP scripts)\n * 2. provider.js (legacy — everything in one file)\n * Structure: dir/category/agent-name/provider.{json,js}\n */\n private loadDir(dir: string, excludeDirs?: string[]): number {\n if (!fs.existsSync(dir)) return 0;\n let count = 0;\n\n const scan = (d: string) => {\n let entries: fs.Dirent[];\n try {\n entries = fs.readdirSync(d, { withFileTypes: true });\n } catch {\n return;\n }\n\n // Check if this directory has provider.json\n const hasJson = entries.some(e => e.name === 'provider.json');\n\n if (hasJson) {\n const jsonPath = path.join(d, 'provider.json');\n try {\n const raw = fs.readFileSync(jsonPath, 'utf-8');\n const mod = JSON.parse(raw) as ProviderModule;\n\n if (!mod.type || !mod.name || !mod.category) {\n this.log(`⚠ Invalid provider at ${jsonPath}: missing type/name/category`);\n } else {\n // Restore RegExp fields from JSON (extensionIdPattern)\n if ((mod as any).extensionIdPattern && typeof (mod as any).extensionIdPattern === 'string') {\n const flags = (mod as any).extensionIdPattern_flags || '';\n (mod as any).extensionIdPattern = new RegExp((mod as any).extensionIdPattern, flags);\n delete (mod as any).extensionIdPattern_flags;\n }\n\n // Load scripts.js if exists (IDE/Extension)\n const scriptsPath = path.join(d, 'scripts.js');\n if (fs.existsSync(scriptsPath)) {\n try {\n delete require.cache[require.resolve(scriptsPath)];\n const scripts = require(scriptsPath);\n mod.scripts = scripts;\n } catch (e) {\n this.log(`⚠ Failed to load scripts: ${scriptsPath}: ${(e as Error).message}`);\n }\n }\n\n const existed = this.providers.has(mod.type);\n this.providers.set(mod.type, mod);\n count++;\n this.log(` ${existed ? '🔄' : '✅'} ${mod.type} (${mod.category}) — ${mod.name}`);\n }\n } catch (e) {\n this.log(`⚠ Failed to load ${jsonPath}: ${(e as Error).message}`);\n }\n }\n\n // Continue scanning subdirectories (only for dirs without provider.json)\n if (!hasJson) {\n for (const entry of entries) {\n if (!entry.isDirectory()) continue;\n if (entry.name.startsWith('_') || entry.name.startsWith('.')) continue;\n if (excludeDirs && d === dir && excludeDirs.includes(entry.name)) continue;\n scan(path.join(d, entry.name));\n }\n }\n };\n\n scan(dir);\n return count;\n }\n\n /**\n * Simple semver range matching\n * Supported formats: '>=4.0.0', '<3.0.0', '>=2.1.0'\n */\n private matchesVersion(current: string, range: string): boolean {\n const match = range.match(/^([><=!]+)\\s*(\\d+\\.\\d+\\.\\d+)$/);\n if (!match) return false;\n\n const [, op, target] = match;\n const cmp = this.compareVersions(current, target);\n\n switch (op) {\n case '>=': return cmp >= 0;\n case '>': return cmp > 0;\n case '<=': return cmp <= 0;\n case '<': return cmp < 0;\n case '=':\n case '==': return cmp === 0;\n case '!=': return cmp !== 0;\n default: return false;\n }\n }\n\n private compareVersions(a: string, b: string): number {\n const pa = a.split('.').map(Number);\n const pb = b.split('.').map(Number);\n for (let i = 0; i < Math.max(pa.length, pb.length); i++) {\n const va = pa[i] || 0;\n const vb = pb[i] || 0;\n if (va !== vb) return va - vb;\n }\n return 0;\n }\n}\n","/**\n * ADHDev IPC Protocol — Extension ↔ Daemon communication protocol\n * \n * Message types used when Extension and Daemon communicate via localhost WS.\n * Defined in core package for import from both sides.\n */\n\n// ─── Extension → Daemon ─────────────────────────\n\n/** Extension registers itself with Daemon on first connection */\nexport interface IpcExtRegister {\n type: 'ext:register';\n payload: {\n ideType: string; // 'cursor' | 'vscode' | 'windsurf' | 'antigravity' | ...\n ideVersion: string; // vscode.version\n extensionVersion: string;\n instanceId: string; // machineId + workspace hash\n machineId: string; // vscode.env.machineId\n workspaceFolders: { name: string; path: string }[];\n };\n}\n\n/** Extension periodically send vscode status data */\nexport interface IpcExtStatus {\n type: 'ext:status';\n payload: {\n activeFile: string | null;\n workspaceFolders: { name: string; path: string }[];\n terminals: number;\n aiAgents: { id: string; name: string; status: string; version?: string }[];\n // requestId unnecessary for vscode event type\n };\n}\n\n/** Return Extension vscode command execution result */\nexport interface IpcExtCommandResult {\n type: 'ext:command_result';\n payload: {\n requestId: string;\n success: boolean;\n result?: unknown;\n error?: string;\n };\n}\n\n/** VSCode event occurring from Extension */\nexport interface IpcExtEvent {\n type: 'ext:event';\n payload: {\n event: 'file_changed' | 'terminal_opened' | 'terminal_closed' | 'agent_status_changed';\n data: Record<string, unknown>;\n };\n}\n\n// ─── Daemon → Extension ─────────────────────────\n\n/** Welcome message on Daemon-Extension connection */\nexport interface IpcDaemonWelcome {\n type: 'daemon:welcome';\n payload: {\n daemonVersion: string;\n serverConnected: boolean;\n cdpConnected: boolean;\n localPort: number;\n cliAgents: string[]; // Currently running CLI agents\n };\n}\n\n/** Daemon to Extension vscode Request command execution */\nexport interface IpcDaemonExecuteVscode {\n type: 'daemon:execute_vscode';\n payload: {\n requestId: string;\n command: string; // 'workbench.action.chat.open' etc\n args?: unknown[];\n };\n}\n\n/** Daemon to Extension status data request */\nexport interface IpcDaemonRequestStatus {\n type: 'daemon:request_status';\n payload: {};\n}\n\n/** Daemon notifies Extension about server connection status */\nexport interface IpcDaemonServerState {\n type: 'daemon:server_state';\n payload: {\n connected: boolean;\n serverUrl: string;\n };\n}\n\n/** Daemon to Extension notification display request */\nexport interface IpcDaemonNotify {\n type: 'daemon:notify';\n payload: {\n level: 'info' | 'warning' | 'error';\n message: string;\n };\n}\n\n/** Extension requests Daemon to execute command (e.g. CLI launch) */\nexport interface IpcExtCommand {\n type: 'ext:command';\n payload: {\n command: string;\n args?: any;\n };\n}\n\n// ─── Union Types ─────────────────────────────────\n\nexport type ExtToDaemonMessage =\n | IpcExtRegister\n | IpcExtStatus\n | IpcExtCommandResult\n | IpcExtEvent\n | IpcExtCommand;\n\nexport type DaemonToExtMessage =\n | IpcDaemonWelcome\n | IpcDaemonExecuteVscode\n | IpcDaemonRequestStatus\n | IpcDaemonServerState\n | IpcDaemonNotify;\n\nexport type IpcMessage = ExtToDaemonMessage | DaemonToExtMessage;\n\n// ─── Constants ───────────────────────────────────\n\nexport const DEFAULT_DAEMON_PORT = 19222;\nexport const DAEMON_WS_PATH = '/ipc';\n","/**\n * ProviderStreamAdapter — generic Extension adapter based on provider.js\n * \n * Consolidates ClineAdapter, RooCodeAdapter, ContinueAdapter.\n * Auto-configured using provider.js scripts + metadata.\n */\n\nimport type {\n IAgentStreamAdapter,\n AgentStreamState,\n AgentChatListItem,\n AgentEvaluateFn,\n} from './types.js';\nimport type { ProviderModule } from '../providers/contracts.js';\n\nexport class ProviderStreamAdapter implements IAgentStreamAdapter {\n readonly agentType: string;\n readonly agentName: string;\n readonly extensionId: string;\n readonly extensionIdPattern: RegExp;\n private provider: ProviderModule;\n private lastSuccessState: AgentStreamState | null = null;\n\n constructor(provider: ProviderModule) {\n this.provider = provider;\n this.agentType = provider.type;\n this.agentName = provider.displayName || provider.name;\n this.extensionId = provider.extensionId || provider.type;\n this.extensionIdPattern = provider.extensionIdPattern\n || new RegExp(`extensionId=${this.extensionId.replace(/[.*+?^${}()|[\\]\\\\]/g, '\\\\$&')}`, 'i');\n }\n\n private callScript(name: string, ...args: any[]): string | null {\n const fn = (this.provider.scripts as any)?.[name];\n if (typeof fn !== 'function') return null;\n return fn(...args) || null;\n }\n\n private hasScript(name: string): boolean {\n return typeof (this.provider.scripts as any)?.[name] === 'function';\n }\n\n async readChat(evaluate: AgentEvaluateFn): Promise<AgentStreamState> {\n const script = this.callScript('readChat');\n if (!script) return this.errorState('readChat script not available');\n\n try {\n const raw = await evaluate(script) as string;\n const data = typeof raw === 'string' ? JSON.parse(raw) : raw;\n if (data?.error) {\n const state = this.errorState(data.error);\n if (this.lastSuccessState?.messages?.length) {\n state.messages = this.lastSuccessState.messages;\n }\n return state;\n }\n const state: AgentStreamState = {\n agentType: this.agentType,\n agentName: this.agentName,\n extensionId: this.extensionId,\n status: data.status || 'idle',\n messages: data.messages || [],\n inputContent: data.inputContent || '',\n model: data.model,\n activeModal: data.activeModal,\n };\n if (state.messages.length > 0) {\n this.lastSuccessState = state;\n }\n return state;\n } catch {\n const state = this.errorState(`Failed to parse ${this.agentName} state`);\n if (this.lastSuccessState?.messages?.length) {\n state.messages = this.lastSuccessState.messages;\n }\n return state;\n }\n }\n\n async sendMessage(evaluate: AgentEvaluateFn, text: string): Promise<void> {\n const script = this.callScript('sendMessage', text);\n if (!script) throw new Error(`[${this.agentName}] sendMessage script not available`);\n const result = await evaluate(script) as string;\n if (result && typeof result === 'string' && result.startsWith('error:')) {\n throw new Error(`[${this.agentName}] sendMessage failed: ${result}`);\n }\n }\n\n async resolveAction(evaluate: AgentEvaluateFn, action: string, button?: string): Promise<boolean> {\n const script = this.callScript('resolveAction', { action, button });\n if (!script) return false; // Not supported if provider has no resolveAction\n return (await evaluate(script)) === true;\n }\n\n async newSession(evaluate: AgentEvaluateFn): Promise<void> {\n const script = this.callScript('newSession');\n if (!script) throw new Error(`[${this.agentName}] newSession script not available`);\n const result = await evaluate(script) as string;\n if (result && typeof result === 'string' && result.startsWith('error:')) {\n throw new Error(`[${this.agentName}] newSession failed: ${result}`);\n }\n this.lastSuccessState = null;\n }\n\n async listChats(evaluate: AgentEvaluateFn): Promise<AgentChatListItem[]> {\n const script = this.callScript('listSessions');\n if (!script) return [];\n try {\n const raw = await evaluate(script, 10000) as string;\n const data = typeof raw === 'string' ? JSON.parse(raw) : raw;\n if (data?.error) return [];\n return Array.isArray(data) ? data : [];\n } catch { return []; }\n }\n\n async switchSession(evaluate: AgentEvaluateFn, sessionId: string): Promise<boolean> {\n const script = this.callScript('switchSession', sessionId);\n if (!script) return false;\n return (await evaluate(script, 10000)) === true;\n }\n\n async focusEditor(evaluate: AgentEvaluateFn): Promise<void> {\n const script = this.callScript('focusEditor');\n if (!script) return;\n await evaluate(script);\n }\n\n private errorState(message: string): AgentStreamState {\n return {\n agentType: this.agentType,\n agentName: this.agentName,\n extensionId: this.extensionId,\n status: 'error',\n messages: [],\n inputContent: '',\n };\n }\n}\n","/**\n * DaemonAgentStreamManager — manage agent streams (ported for Daemon)\n * \n * Agent stream manager for extension data collection.\n * All vscode dependencies removed — pure Node.js environment.\n * \n * Panel focus is delegated to Extension via IPC.\n * CDP session management uses DaemonCdpManager directly.\n */\n\nimport { DaemonCdpManager, AgentWebviewTarget } from '../daemon-cdp.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport { ProviderStreamAdapter } from './provider-adapter.js';\nimport type {\n IAgentStreamAdapter,\n AgentStreamState,\n AgentChatListItem,\n AgentEvaluateFn,\n} from './types.js';\n\nexport interface ManagedAgent {\n adapter: IAgentStreamAdapter;\n sessionId: string;\n target: AgentWebviewTarget;\n lastState: AgentStreamState | null;\n lastError: string | null;\n lastHiddenCheckTime: number;\n}\n\nexport class DaemonAgentStreamManager {\n private allAdapters: IAgentStreamAdapter[] = [];\n private managed = new Map<string, ManagedAgent>();\n private enabled = true;\n private logFn: (msg: string) => void;\n private lastDiscoveryTime = 0;\n private discoveryIntervalMs = 10_000;\n\n\n private _activeAgentType: string | null = null;\n\n constructor(logFn?: (msg: string) => void, providerLoader?: ProviderLoader) {\n this.logFn = logFn || console.log;\n\n // Create adapter for all extension providers\n // Per-IDE filtering is handled by each CDP manager via setExtensionProviders\n if (providerLoader) {\n const allExtProviders = providerLoader.getByCategory('extension');\n for (const p of allExtProviders) {\n const adapter = new ProviderStreamAdapter(p);\n this.allAdapters.push(adapter);\n this.logFn(`[AgentStream] Adapter created: ${p.type} (${p.name})`);\n }\n }\n }\n\n setEnabled(enabled: boolean) { this.enabled = enabled; }\n get isEnabled() { return this.enabled; }\n get activeAgentType(): string | null { return this._activeAgentType; }\n\n /** Panel focus based on provider.js focusPanel or extensionId (currently no-op) */\n async ensureAgentPanelOpen(agentType: string, targetIdeType?: string): Promise<void> {\n // Extension was removed, so localServer-based panel focus no longer works\n // Can be replaced with CDP-based focus (future implementation)\n }\n\n async switchActiveAgent(cdp: DaemonCdpManager, agentType: string | null): Promise<void> {\n if (this._activeAgentType === agentType) return;\n\n if (this._activeAgentType) {\n const prev = this.managed.get(this._activeAgentType);\n if (prev) {\n try { await cdp.detachAgent(prev.sessionId); } catch { }\n this.managed.delete(this._activeAgentType);\n this.logFn(`[AgentStream] Deactivated: ${prev.adapter.agentName}`);\n }\n }\n\n this._activeAgentType = agentType;\n this.lastDiscoveryTime = 0;\n this.logFn(`[AgentStream] Active agent: ${agentType || 'none'}`);\n }\n\n /** Agent webview discovery + session connection */\n async syncAgentSessions(cdp: DaemonCdpManager): Promise<void> {\n if (!this.enabled || !this._activeAgentType) return;\n\n const now = Date.now();\n if (this.managed.has(this._activeAgentType) && (now - this.lastDiscoveryTime) < this.discoveryIntervalMs) {\n return;\n }\n this.lastDiscoveryTime = now;\n\n try {\n const targets = await cdp.discoverAgentWebviews();\n const activeTarget = targets.find(t => t.agentType === this._activeAgentType);\n\n if (activeTarget && !this.managed.has(this._activeAgentType)) {\n const adapter = this.allAdapters.find(a => a.agentType === this._activeAgentType);\n if (adapter) {\n const sessionId = await cdp.attachToAgent(activeTarget);\n if (sessionId) {\n this.managed.set(this._activeAgentType, {\n adapter,\n sessionId,\n target: activeTarget,\n lastState: null,\n lastError: null,\n lastHiddenCheckTime: 0,\n });\n this.logFn(`[AgentStream] Connected: ${adapter.agentName}`);\n }\n }\n }\n\n // Cleanup inactive agents\n for (const [type, agent] of this.managed) {\n if (type !== this._activeAgentType) {\n await cdp.detachAgent(agent.sessionId);\n this.managed.delete(type);\n }\n }\n\n this.discoveryIntervalMs = this.managed.has(this._activeAgentType) ? 30_000 : 10_000;\n } catch (e) {\n this.logFn(`[AgentStream] sync error: ${(e as Error).message}`);\n }\n }\n\n /** Collect active agent status */\n async collectAgentStreams(cdp: DaemonCdpManager): Promise<AgentStreamState[]> {\n if (!this.enabled) return [];\n\n const results: AgentStreamState[] = [];\n\n if (this._activeAgentType && this.managed.has(this._activeAgentType)) {\n const agent = this.managed.get(this._activeAgentType)!;\n const type = this._activeAgentType;\n\n const isHidden = agent.lastState?.status === 'panel_hidden';\n const hiddenCacheFresh = isHidden && (Date.now() - agent.lastHiddenCheckTime < 30000);\n\n if (hiddenCacheFresh) {\n results.push(agent.lastState!);\n } else {\n try {\n const evaluate: AgentEvaluateFn = (expr, timeout) =>\n cdp.evaluateInSession(agent.sessionId, expr, timeout);\n const state = await agent.adapter.readChat(evaluate);\n agent.lastState = state;\n agent.lastError = null;\n if (state.status === 'panel_hidden') {\n agent.lastHiddenCheckTime = Date.now();\n }\n results.push(state);\n } catch (e) {\n const errorMsg = (e as Error)?.message || String(e);\n this.logFn(`[AgentStream] readChat(${type}) error: ${errorMsg.slice(0, 200)}`);\n agent.lastError = errorMsg;\n results.push({\n agentType: type,\n agentName: agent.adapter.agentName,\n extensionId: agent.adapter.extensionId,\n status: 'disconnected',\n messages: agent.lastState?.messages || [],\n inputContent: '',\n });\n if (errorMsg.includes('timeout') || errorMsg.includes('not connected') || errorMsg.includes('Session')) {\n try { await cdp.detachAgent(agent.sessionId); } catch { }\n this.managed.delete(type);\n this.lastDiscoveryTime = 0;\n }\n }\n }\n }\n\n return results;\n }\n\n async sendToAgent(cdp: DaemonCdpManager, agentType: string, text: string, targetIdeType?: string): Promise<boolean> {\n await this.ensureAgentPanelOpen(agentType, targetIdeType);\n const agent = this.managed.get(agentType);\n if (!agent) return false;\n try {\n const evaluate: AgentEvaluateFn = (expr, timeout) =>\n cdp.evaluateInSession(agent.sessionId, expr, timeout);\n await agent.adapter.sendMessage(evaluate, text);\n return true;\n } catch (e) {\n this.logFn(`[AgentStream] sendToAgent(${agentType}) error: ${(e as Error).message}`);\n return false;\n }\n }\n\n async resolveAgentAction(cdp: DaemonCdpManager, agentType: string, action: 'approve' | 'reject', targetIdeType?: string): Promise<boolean> {\n await this.ensureAgentPanelOpen(agentType, targetIdeType);\n const agent = this.managed.get(agentType);\n if (!agent) return false;\n try {\n const evaluate: AgentEvaluateFn = (expr, timeout) =>\n cdp.evaluateInSession(agent.sessionId, expr, timeout);\n return await agent.adapter.resolveAction(evaluate, action);\n } catch (e) {\n this.logFn(`[AgentStream] resolveAction(${agentType}) error: ${(e as Error).message}`);\n return false;\n }\n }\n\n async newAgentSession(cdp: DaemonCdpManager, agentType: string, targetIdeType?: string): Promise<boolean> {\n await this.ensureAgentPanelOpen(agentType, targetIdeType);\n const agent = this.managed.get(agentType);\n if (!agent) return false;\n try {\n const evaluate: AgentEvaluateFn = (expr, timeout) =>\n cdp.evaluateInSession(agent.sessionId, expr, timeout);\n await agent.adapter.newSession(evaluate);\n return true;\n } catch (e) {\n this.logFn(`[AgentStream] newSession(${agentType}) error: ${(e as Error).message}`);\n return false;\n }\n }\n\n async listAgentChats(cdp: DaemonCdpManager, agentType: string): Promise<AgentChatListItem[]> {\n let agent = this.managed.get(agentType);\n // on-demand: try activate+sync if not in managed list\n if (!agent) {\n this.logFn(`[AgentStream] listChats: ${agentType} not managed, trying on-demand activation`);\n await this.switchActiveAgent(cdp, agentType);\n await this.syncAgentSessions(cdp);\n agent = this.managed.get(agentType);\n }\n if (!agent || typeof agent.adapter.listChats !== 'function') return [];\n try {\n const evaluate: AgentEvaluateFn = (expr, timeout) =>\n cdp.evaluateInSession(agent!.sessionId, expr, timeout);\n return await agent.adapter.listChats(evaluate);\n } catch (e) {\n this.logFn(`[AgentStream] listChats(${agentType}) error: ${(e as Error).message}`);\n return [];\n }\n }\n\n async switchAgentSession(cdp: DaemonCdpManager, agentType: string, sessionId: string): Promise<boolean> {\n let agent = this.managed.get(agentType);\n if (!agent) {\n this.logFn(`[AgentStream] switchSession: ${agentType} not managed, trying on-demand activation`);\n await this.switchActiveAgent(cdp, agentType);\n await this.syncAgentSessions(cdp);\n agent = this.managed.get(agentType);\n }\n if (!agent || typeof agent.adapter.switchSession !== 'function') return false;\n try {\n const evaluate: AgentEvaluateFn = (expr, timeout) =>\n cdp.evaluateInSession(agent!.sessionId, expr, timeout);\n return await agent.adapter.switchSession(evaluate, sessionId);\n } catch (e) {\n this.logFn(`[AgentStream] switchSession(${agentType}) error: ${(e as Error).message}`);\n return false;\n }\n }\n\n async focusAgentEditor(cdp: DaemonCdpManager, agentType: string): Promise<boolean> {\n const agent = this.managed.get(agentType);\n if (!agent || typeof agent.adapter.focusEditor !== 'function') return false;\n try {\n const evaluate: AgentEvaluateFn = (expr, timeout) =>\n cdp.evaluateInSession(agent.sessionId, expr, timeout);\n await agent.adapter.focusEditor(evaluate);\n return true;\n } catch (e) {\n this.logFn(`[AgentStream] focusEditor(${agentType}) error: ${(e as Error).message}`);\n return false;\n }\n }\n\n getConnectedAgents(): string[] { return Array.from(this.managed.keys()); }\n getManagedAgent(agentType: string): ManagedAgent | undefined { return this.managed.get(agentType); }\n\n async dispose(cdp: DaemonCdpManager): Promise<void> {\n for (const [, agent] of this.managed) {\n try { await cdp.detachAgent(agent.sessionId); } catch { }\n }\n this.managed.clear();\n }\n}\n","/**\n * ProviderInstanceManager — lifecycle management for all ProviderInstances\n *\n * Role:\n * 1. Instance create/delete\n * 2. Tick engine (periodic onTick calls)\n * 3. Collect overall state\n * 4. Event collection and propagation\n */\n\nimport type { ProviderInstance, ProviderState, ProviderEvent, InstanceContext } from './provider-instance.js';\n\nexport class ProviderInstanceManager {\n private instances = new Map<string, ProviderInstance>();\n private tickTimer: NodeJS.Timeout | null = null;\n private tickInterval = 5_000; // default 5seconds\n private eventListeners: ((event: ProviderEvent & { providerType: string }) => void)[] = [];\n\n // ─── Instance manage ──────────────────────────────\n\n /**\n * Instance add and initialize\n */\n async addInstance(id: string, instance: ProviderInstance, context: InstanceContext): Promise<void> {\n if (this.instances.has(id)) {\n console.warn(`[InstanceManager] Instance ${id} already exists, disposing old one`);\n this.instances.get(id)!.dispose();\n }\n this.instances.set(id, instance);\n await instance.init(context);\n }\n\n /**\n * Instance remove\n */\n removeInstance(id: string): void {\n const instance = this.instances.get(id);\n if (instance) {\n instance.dispose();\n this.instances.delete(id);\n }\n }\n\n /**\n * Import by Instance ID\n */\n getInstance(id: string): ProviderInstance | undefined {\n return this.instances.get(id);\n }\n\n /**\n * Per-category Instance list\n */\n getByCategory(category: 'cli' | 'ide' | 'extension' | 'acp'): ProviderInstance[] {\n return [...this.instances.values()].filter(i => i.category === category);\n }\n\n /**\n * All Instance count\n */\n get size(): number {\n return this.instances.size;\n }\n\n // ─── State collect ────────────────────────────────\n\n /**\n * all Instance's current status collect\n * + Propagate pending events to event listeners\n */\n collectAllStates(): ProviderState[] {\n const states: ProviderState[] = [];\n for (const [id, instance] of this.instances) {\n try {\n const state = instance.getState();\n states.push(state);\n\n // pending events propagation\n for (const event of state.pendingEvents) {\n for (const listener of this.eventListeners) {\n listener({ ...event, providerType: instance.type });\n }\n }\n } catch (e) {\n console.warn(`[InstanceManager] Failed to collect state from ${id}:`, (e as Error).message);\n }\n }\n return states;\n }\n\n /**\n * Per-category status collect\n */\n collectStatesByCategory(category: 'cli' | 'ide' | 'extension' | 'acp'): ProviderState[] {\n return this.collectAllStates().filter(s => s.category === category);\n }\n\n // ─── Tick engine ─────────────────────────────────\n\n /**\n * Start tick — periodically call all Instance.onTick() call\n */\n startTicking(intervalMs?: number): void {\n if (this.tickTimer) return;\n this.tickInterval = intervalMs || this.tickInterval;\n\n this.tickTimer = setInterval(async () => {\n for (const [id, instance] of this.instances) {\n try {\n await instance.onTick();\n } catch (e) {\n console.warn(`[InstanceManager] Tick failed for ${id}:`, (e as Error).message);\n }\n }\n }, this.tickInterval);\n }\n\n /**\n * Stop tick\n */\n stopTicking(): void {\n if (this.tickTimer) {\n clearInterval(this.tickTimer);\n this.tickTimer = null;\n }\n }\n\n // ─── event ────────────────────────────────────\n\n /**\n * Register event listener (used for daemon status_event transmission)\n */\n onEvent(listener: (event: ProviderEvent & { providerType: string }) => void): void {\n this.eventListeners.push(listener);\n }\n\n /**\n * Forward event to specific Instance\n */\n sendEvent(id: string, event: string, data?: any): void {\n this.instances.get(id)?.onEvent(event, data);\n }\n\n /**\n * Broadcast event to all Instances\n */\n broadcast(event: string, data?: any): void {\n for (const instance of this.instances.values()) {\n instance.onEvent(event, data);\n }\n }\n\n // ─── cleanup ──────────────────────────────────────\n\n /**\n * All terminate\n */\n disposeAll(): void {\n this.stopTicking();\n for (const [id, instance] of this.instances) {\n try { instance.dispose(); } catch { }\n }\n this.instances.clear();\n this.eventListeners = [];\n }\n}\n","/**\n * IdeProviderInstance — Runtime instance for IDE Provider\n *\n * Within a single IDE:\n * 1. Native chat (readChat via CDP)\n * 2. Extension agents (Cline, Roo Code etc)\n *\n * IDE Instance manages child Extension Instances.\n * Daemon collects all via a single IDE Instance.getState() call.\n */\n\nimport * as os from 'os';\nimport * as crypto from 'crypto';\nimport type { ProviderModule } from './contracts.js';\nimport type { ProviderInstance, ProviderState, ProviderEvent, InstanceContext } from './provider-instance.js';\nimport { ExtensionProviderInstance } from './extension-provider-instance.js';\nimport { StatusMonitor } from './status-monitor.js';\nimport { ChatHistoryWriter } from '../chat-history.js';\n\nexport class IdeProviderInstance implements ProviderInstance {\n readonly type: string;\n readonly category = 'ide' as const;\n\n private provider: ProviderModule;\n private context: InstanceContext | null = null;\n private settings: Record<string, any> = {};\n private events: ProviderEvent[] = [];\n private tickErrorCount = 0;\n\n // Cached status\n private cachedChat: any = null;\n private currentStatus: string = 'idle';\n private lastAgentStatuses = new Map<string, string>();\n private generatingStartedAt = new Map<string, number>();\n private tickBusy = false;\n private monitor: StatusMonitor;\n private historyWriter: ChatHistoryWriter;\n\n // IDE meta\n private ideVersion: string = '';\n private instanceId: string;\n private workspaceFolders: { name: string; path: string }[] = [];\n private activeFile: string | null = null;\n\n // ─── Child Extension Instances ────────────────────\n private extensions = new Map<string, ExtensionProviderInstance>();\n\n constructor(provider: ProviderModule, instanceKey?: string) {\n // type always base provider type (e.g. 'antigravity') — display/script queryin use\n this.type = provider.type;\n this.provider = provider;\n // instanceId UUID — unique identifier for all routing\n this.instanceId = crypto.randomUUID();\n this.monitor = new StatusMonitor();\n this.historyWriter = new ChatHistoryWriter();\n }\n\n // ─── Lifecycle ─────────────────────────────────\n\n async init(context: InstanceContext): Promise<void> {\n this.context = context;\n this.settings = context.settings || {};\n // Sync Monitor config\n this.monitor.updateConfig({\n approvalAlert: this.settings.approvalAlert !== false,\n longGeneratingAlert: this.settings.longGeneratingAlert !== false,\n longGeneratingThresholdSec: this.settings.longGeneratingThresholdSec || 180,\n });\n }\n\n async onTick(): Promise<void> {\n if (!this.context?.cdp?.isConnected || this.tickBusy) return;\n this.tickBusy = true;\n\n try {\n // 1. Native chat read\n await this.readChat();\n\n // 2. Child Extension tick\n for (const [id, ext] of this.extensions) {\n try {\n await ext.onTick();\n } catch (e: any) {\n console.warn(`[IdeInstance:${this.type}] Extension ${id} tick error: ${e?.message}`);\n }\n }\n\n this.tickErrorCount = 0;\n } catch (e: any) {\n this.tickErrorCount++;\n if (this.tickErrorCount <= 3 || this.tickErrorCount % 10 === 0) {\n console.warn(`[IdeInstance:${this.type}] onTick error (${this.tickErrorCount}): ${e?.message || e}`);\n }\n } finally {\n this.tickBusy = false;\n }\n }\n\n getState(): ProviderState {\n const cdp = this.context?.cdp;\n\n // Collect extension status\n const extensionStates: ProviderState[] = [];\n for (const ext of this.extensions.values()) {\n extensionStates.push(ext.getState());\n }\n\n return {\n type: this.type,\n name: this.provider.name,\n category: 'ide',\n status: this.currentStatus as ProviderState['status'],\n activeChat: this.cachedChat ? {\n id: this.cachedChat.id || 'active_session',\n title: this.cachedChat.title || this.type,\n status: this.cachedChat.status || this.currentStatus,\n messages: this.cachedChat.messages || [],\n activeModal: this.cachedChat.activeModal || null,\n inputContent: this.cachedChat.inputContent || '',\n } : null,\n workspaceFolders: this.workspaceFolders,\n activeFile: this.activeFile,\n extensions: extensionStates,\n cdpConnected: cdp?.isConnected || false,\n currentModel: this.cachedChat?.model || undefined,\n currentPlan: this.cachedChat?.mode || undefined,\n currentAutoApprove: this.cachedChat?.autoApprove || undefined,\n instanceId: this.instanceId,\n lastUpdated: Date.now(),\n settings: this.settings,\n pendingEvents: this.flushEvents(),\n };\n }\n\n onEvent(event: string, data?: any): void {\n if (event === 'cdp_connected') {\n // CDP connectiondone\n } else if (event === 'cdp_disconnected') {\n this.cachedChat = null;\n this.currentStatus = 'idle';\n } else if (event === 'extension_data') {\n if (data?.workspaceFolders) this.workspaceFolders = data.workspaceFolders;\n if (data?.activeFile) this.activeFile = data.activeFile;\n if (data?.ideVersion) this.ideVersion = data.ideVersion;\n if (data?.instanceId) this.instanceId = data.instanceId;\n } else if (event === 'stream_update') {\n // Forward to Extension\n const extType = data?.extensionType;\n if (extType && this.extensions.has(extType)) {\n this.extensions.get(extType)!.onEvent('stream_update', data);\n }\n }\n }\n\n dispose(): void {\n this.cachedChat = null;\n this.lastAgentStatuses.clear();\n this.generatingStartedAt.clear();\n this.monitor.reset();\n // Child Extension cleanup\n for (const ext of this.extensions.values()) {\n ext.dispose();\n }\n this.extensions.clear();\n }\n\n // ─── Extension manage ─────────────────────────────\n\n /** Extension Instance add */\n async addExtension(provider: ProviderModule, settings?: Record<string, any>): Promise<void> {\n if (this.extensions.has(provider.type)) return;\n\n const ext = new ExtensionProviderInstance(provider);\n await ext.init({\n cdp: this.context?.cdp,\n serverConn: this.context?.serverConn,\n settings: settings || {},\n });\n ext.onEvent('extension_connected', { ideType: this.type });\n this.extensions.set(provider.type, ext);\n console.log(`[IdeInstance:${this.type}] Extension added: ${provider.type}`);\n }\n\n /** Extension Instance remove */\n removeExtension(type: string): void {\n const ext = this.extensions.get(type);\n if (ext) {\n ext.dispose();\n this.extensions.delete(type);\n }\n }\n\n /** Extension Instance Import */\n getExtension(type: string): ExtensionProviderInstance | undefined {\n return this.extensions.get(type);\n }\n\n /** Child Extension list */\n getExtensionTypes(): string[] {\n return [...this.extensions.keys()];\n }\n\n /** Query UUID instanceId */\n getInstanceId(): string {\n return this.instanceId;\n }\n\n /** all Extension Instance list */\n getExtensionInstances(): ExtensionProviderInstance[] {\n return [...this.extensions.values()];\n }\n\n // ─── CDP readChat ───────────────────────────────\n\n private async readChat(): Promise<void> {\n const { cdp } = this.context!;\n if (!cdp?.isConnected) return;\n\n try {\n let raw: any = null;\n\n // path 1: webview iframe internal (Kiro, PearAI etc)\n const webviewFn = (this.provider.scripts as any)?.webviewReadChat;\n if (typeof webviewFn === 'function' && cdp.evaluateInWebviewFrame) {\n const webviewScript = webviewFn();\n if (webviewScript) {\n const matchText = (this.provider as any).webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n const webviewRaw = await cdp.evaluateInWebviewFrame(webviewScript, matchFn);\n if (webviewRaw) {\n raw = typeof webviewRaw === 'string' ? (() => { try { return JSON.parse(webviewRaw); } catch { return null; } })() : webviewRaw;\n }\n }\n }\n\n // path 2: Main DOM (Cursor, Windsurf, Trae, Antigravity etc)\n if (!raw) {\n const readChatScript = this.getReadChatScript();\n if (!readChatScript) return;\n raw = await cdp.evaluate(readChatScript, 30000) as any;\n if (typeof raw === 'string') {\n try { raw = JSON.parse(raw); } catch { return; }\n }\n }\n\n if (!raw || typeof raw !== 'object') return;\n\n // Modal filter\n let { activeModal } = raw;\n if (activeModal) {\n const w = activeModal.width ?? Infinity;\n const h = activeModal.height ?? Infinity;\n if (w < 80 || h < 40) {\n activeModal = undefined;\n } else {\n activeModal = {\n message: activeModal.message?.slice(0, 300) ?? '',\n buttons: (activeModal.buttons ?? []).filter((t: string) => t.length < 30),\n };\n }\n }\n\n // Assign receivedAt\n const prevMsgs = this.cachedChat?.messages || [];\n const prevByHash = new Map<string, number>();\n for (const pm of prevMsgs) {\n const h = `${pm.role}:${(pm.content || '').slice(0, 100)}`;\n if (pm.receivedAt) prevByHash.set(h, pm.receivedAt);\n }\n const now = Date.now();\n for (const msg of (raw.messages || [])) {\n const h = `${msg.role}:${(msg.content || '').slice(0, 100)}`;\n msg.receivedAt = prevByHash.get(h) || now;\n }\n\n this.cachedChat = { ...raw, activeModal };\n this.detectAgentTransitions(raw, now);\n\n // Save history (new messageonly append)\n // Exclude last incomplete assistant message during generating status\n if (raw.messages?.length > 0) {\n let toSave = raw.messages;\n if (raw.status === 'generating' || raw.status === 'long_generating') {\n // Find and exclude last assistant message\n const lastIdx = toSave.length - 1;\n if (lastIdx >= 0 && toSave[lastIdx].role === 'assistant') {\n toSave = toSave.slice(0, lastIdx);\n }\n }\n if (toSave.length > 0) {\n this.historyWriter.appendNewMessages(\n this.type,\n toSave,\n raw.title,\n this.instanceId,\n );\n }\n }\n\n } catch (e: any) {\n const msg = e?.message || String(e);\n if (msg.includes('Timeout') || msg.includes('timeout') || msg.includes('Target closed')) {\n // CDP timeout — unified logging from onTick\n } else {\n console.warn(`[IdeInstance:${this.type}] readChat internal error: ${msg}`);\n }\n }\n }\n\n private getReadChatScript(): string | null {\n const scripts = this.provider.scripts;\n if (!scripts?.readChat) return null;\n return typeof scripts.readChat === 'function' ? scripts.readChat({}) : scripts.readChat as any;\n }\n\n // ─── status transition detect ─────────────────────────────\n\n private detectAgentTransitions(chatData: any, now: number): void {\n const chatStatus = chatData?.status;\n if (!chatStatus) return;\n\n const agentKey = `${this.type}:native`;\n const agentStatus = (chatStatus === 'streaming' || chatStatus === 'generating') ? 'generating'\n : chatStatus === 'waiting_approval' ? 'waiting_approval'\n : 'idle';\n\n this.currentStatus = agentStatus;\n const lastStatus = this.lastAgentStatuses.get(agentKey) || 'idle';\n\n if (agentStatus !== lastStatus) {\n const chatTitle = chatData.title || this.provider.name;\n\n if (lastStatus === 'idle' && agentStatus === 'generating') {\n this.generatingStartedAt.set(agentKey, now);\n this.pushEvent({ event: 'agent:generating_started', chatTitle, timestamp: now, ideType: this.type });\n } else if (agentStatus === 'waiting_approval') {\n if (!this.generatingStartedAt.has(agentKey)) this.generatingStartedAt.set(agentKey, now);\n this.pushEvent({\n event: 'agent:waiting_approval', chatTitle, timestamp: now, ideType: this.type,\n modalMessage: chatData.activeModal?.message,\n modalButtons: chatData.activeModal?.buttons,\n });\n } else if (agentStatus === 'idle' && (lastStatus === 'generating' || lastStatus === 'waiting_approval')) {\n const startedAt = this.generatingStartedAt.get(agentKey);\n const duration = startedAt ? Math.round((now - startedAt) / 1000) : 0;\n this.pushEvent({ event: 'agent:generating_completed', chatTitle, duration, timestamp: now, ideType: this.type });\n this.generatingStartedAt.delete(agentKey);\n }\n\n this.lastAgentStatuses.set(agentKey, agentStatus);\n }\n\n // Monitor check (cooldown based notification)\n const monitorEvents = this.monitor.check(agentKey, agentStatus, now);\n for (const me of monitorEvents) {\n this.pushEvent({ event: me.type, agentKey: me.agentKey, message: me.message, elapsedSec: me.elapsedSec, timestamp: me.timestamp });\n }\n }\n\n private pushEvent(event: ProviderEvent): void {\n this.events.push(event);\n if (this.events.length > 50) this.events = this.events.slice(-50);\n }\n\n private flushEvents(): ProviderEvent[] {\n const events = [...this.events];\n this.events = [];\n return events;\n }\n\n // ─── external access ─────────────────────────────────\n\n updateCdp(cdp: InstanceContext['cdp']): void {\n if (this.context) this.context.cdp = cdp;\n }\n}\n","/**\n * ExtensionProviderInstance — Runtime instance for Extension Provider\n *\n * Manages IDE extensions (Cline, Roo Code, etc).\n * CDP webview discovery + agent stream collection moved here.\n */\n\nimport type { ProviderModule } from './contracts.js';\nimport type { ProviderInstance, ProviderState, ProviderEvent, InstanceContext } from './provider-instance.js';\nimport { StatusMonitor } from './status-monitor.js';\n\nexport class ExtensionProviderInstance implements ProviderInstance {\n readonly type: string;\n readonly category = 'extension' as const;\n\n private provider: ProviderModule;\n private context: InstanceContext | null = null;\n private settings: Record<string, any> = {};\n private events: ProviderEvent[] = [];\n\n // status\n private currentStatus: string = 'idle';\n private agentStreams: any[] = [];\n private messages: any[] = [];\n private activeModal: any = null;\n private lastAgentStatus: string = 'idle';\n private generatingStartedAt: number = 0;\n private monitor: StatusMonitor;\n\n // meta\n private instanceId: string;\n private ideType: string = '';\n\n constructor(provider: ProviderModule) {\n this.type = provider.type;\n this.provider = provider;\n this.instanceId = crypto.randomUUID();\n this.monitor = new StatusMonitor();\n }\n\n // ─── Lifecycle ──────────────────────────────────\n\n async init(context: InstanceContext): Promise<void> {\n this.context = context;\n this.settings = context.settings || {};\n this.monitor.updateConfig({\n approvalAlert: this.settings.approvalAlert !== false,\n longGeneratingAlert: this.settings.longGeneratingAlert !== false,\n longGeneratingThresholdSec: this.settings.longGeneratingThresholdSec || 180,\n });\n }\n\n async onTick(): Promise<void> {\n // Extension gets data pushed from IDE's CDP agent stream\n // Needed when direct stream collection via CDP is possible\n if (!this.context?.cdp?.isConnected) return;\n\n // Agent stream collect (CDP discoverAgentWebviews etc)\n // Currently handled separately by agent-stream-manager only\n // Can be moved here in the future\n }\n\n getState(): ProviderState {\n return {\n type: this.type,\n name: this.provider.name,\n category: 'extension',\n status: this.currentStatus as ProviderState['status'],\n activeChat: this.messages.length > 0 ? {\n id: `${this.type}_session`,\n title: this.provider.name,\n status: this.currentStatus,\n messages: this.messages,\n activeModal: this.activeModal,\n inputContent: '',\n } : null,\n agentStreams: this.agentStreams,\n instanceId: this.instanceId,\n lastUpdated: Date.now(),\n settings: this.settings,\n pendingEvents: this.flushEvents(),\n };\n }\n\n onEvent(event: string, data?: any): void {\n if (event === 'stream_update') {\n // Reflect data collected from agent-stream-manager\n if (data?.streams) this.agentStreams = data.streams;\n if (data?.messages) this.messages = data.messages;\n if (data?.status) {\n const newStatus = data.status;\n this.detectTransition(newStatus, data);\n this.currentStatus = newStatus;\n }\n } else if (event === 'extension_connected') {\n this.ideType = data?.ideType || '';\n // Maintain instanceId UUID — do not overwrite\n }\n }\n\n dispose(): void {\n this.agentStreams = [];\n this.messages = [];\n this.monitor.reset();\n }\n\n /** Query UUID instanceId */\n getInstanceId(): string {\n return this.instanceId;\n }\n\n // ─── status transition detect ──────────────────────────────\n\n private detectTransition(newStatus: string, data: any): void {\n const now = Date.now();\n const agentStatus = (newStatus === 'streaming' || newStatus === 'generating') ? 'generating'\n : newStatus === 'waiting_approval' ? 'waiting_approval'\n : 'idle';\n\n if (agentStatus !== this.lastAgentStatus) {\n const chatTitle = this.provider.name;\n\n if (this.lastAgentStatus === 'idle' && agentStatus === 'generating') {\n this.generatingStartedAt = now;\n this.pushEvent({ event: 'agent:generating_started', chatTitle, timestamp: now });\n } else if (agentStatus === 'waiting_approval') {\n if (!this.generatingStartedAt) this.generatingStartedAt = now;\n this.pushEvent({ event: 'agent:waiting_approval', chatTitle, timestamp: now });\n } else if (agentStatus === 'idle' && (this.lastAgentStatus === 'generating' || this.lastAgentStatus === 'waiting_approval')) {\n const duration = this.generatingStartedAt ? Math.round((now - this.generatingStartedAt) / 1000) : 0;\n this.pushEvent({ event: 'agent:generating_completed', chatTitle, duration, timestamp: now });\n this.generatingStartedAt = 0;\n }\n\n this.lastAgentStatus = agentStatus;\n }\n\n // Monitor check (cooldown based notification)\n const agentKey = `${this.type}:ext`;\n const monitorEvents = this.monitor.check(agentKey, agentStatus, now);\n for (const me of monitorEvents) {\n this.pushEvent({ event: me.type, agentKey: me.agentKey, message: me.message, elapsedSec: me.elapsedSec, timestamp: me.timestamp });\n }\n }\n\n private pushEvent(event: ProviderEvent): void {\n this.events.push(event);\n if (this.events.length > 50) this.events = this.events.slice(-50);\n }\n\n private flushEvents(): ProviderEvent[] {\n const events = [...this.events];\n this.events = [];\n return events;\n }\n}\n","/**\n * Dev Server — HTTP API for Provider debugging + script development\n * \n * Enabled with `adhdev daemon --dev`\n * Port: 19280 (fixed)\n * \n * API list:\n * GET /api/providers — loaded provider list\n * POST /api/providers/:type/script — specific script execute\n * POST /api/cdp/evaluate — Execute JS expression\n * POST /api/cdp/dom/query — Test selector\n * GET /api/cdp/screenshot — screenshot\n * POST /api/scripts/run — Execute provider script (name + params)\n * GET /api/status — All status (CDP connection, provider etc)\n */\n\nimport * as http from 'http';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\nimport type { ProviderLoader } from '../providers/provider-loader.js';\nimport type { DaemonCdpManager } from '../daemon-cdp.js';\nimport { generateTemplate as genScaffoldTemplate } from './scaffold-template.js';\n\nexport const DEV_SERVER_PORT = 19280;\n\nexport class DevServer {\n private server: http.Server | null = null;\n private providerLoader: ProviderLoader;\n private cdpManagers: Map<string, DaemonCdpManager>;\n private logFn: (msg: string) => void;\n private sseClients: http.ServerResponse[] = [];\n private watchScriptPath: string | null = null;\n private watchScriptName: string | null = null;\n private watchTimer: NodeJS.Timeout | null = null;\n\n constructor(options: {\n providerLoader: ProviderLoader;\n cdpManagers: Map<string, DaemonCdpManager>;\n logFn?: (msg: string) => void;\n }) {\n this.providerLoader = options.providerLoader;\n this.cdpManagers = options.cdpManagers;\n this.logFn = options.logFn || ((msg) => console.log(msg));\n }\n\n private log(msg: string): void {\n this.logFn(`[DevServer] ${msg}`);\n }\n\n async start(port = DEV_SERVER_PORT): Promise<void> {\n this.server = http.createServer(async (req, res) => {\n // CORS\n res.setHeader('Access-Control-Allow-Origin', '*');\n res.setHeader('Access-Control-Allow-Methods', 'GET, POST, OPTIONS');\n res.setHeader('Access-Control-Allow-Headers', 'Content-Type');\n\n if (req.method === 'OPTIONS') {\n res.writeHead(200);\n res.end();\n return;\n }\n\n const url = new URL(req.url || '/', `http://localhost:${port}`);\n const pathname = url.pathname;\n\n try {\n // ─── Routes ───\n if (pathname === '/api/providers' && req.method === 'GET') {\n await this.handleListProviders(req, res);\n } else if (pathname.match(/^\\/api\\/providers\\/([^/]+)\\/script$/) && req.method === 'POST') {\n const type = pathname.match(/^\\/api\\/providers\\/([^/]+)\\/script$/)![1];\n await this.handleRunScript(type, req, res);\n } else if (pathname === '/api/cdp/evaluate' && req.method === 'POST') {\n await this.handleCdpEvaluate(req, res);\n } else if (pathname === '/api/cdp/dom/query' && req.method === 'POST') {\n await this.handleCdpDomQuery(req, res);\n } else if (pathname === '/api/cdp/screenshot' && req.method === 'GET') {\n await this.handleScreenshot(req, res);\n } else if (pathname === '/api/scripts/run' && req.method === 'POST') {\n await this.handleScriptsRun(req, res);\n } else if (pathname === '/api/status' && req.method === 'GET') {\n await this.handleStatus(req, res);\n } else if (pathname === '/api/providers/reload' && req.method === 'POST') {\n await this.handleReload(req, res);\n } else if (pathname === '/api/watch/start' && req.method === 'POST') {\n await this.handleWatchStart(req, res);\n } else if (pathname === '/api/watch/stop' && req.method === 'POST') {\n await this.handleWatchStop(req, res);\n } else if (pathname === '/api/watch/events' && req.method === 'GET') {\n this.handleSSE(req, res);\n } else if (pathname.match(/^\\/api\\/providers\\/([^/]+)\\/files$/) && req.method === 'GET') {\n const type = pathname.match(/^\\/api\\/providers\\/([^/]+)\\/files$/)![1];\n await this.handleListFiles(type, req, res);\n } else if (pathname.match(/^\\/api\\/providers\\/([^/]+)\\/file$/) && req.method === 'GET') {\n const type = pathname.match(/^\\/api\\/providers\\/([^/]+)\\/file$/)![1];\n await this.handleReadFile(type, req, res);\n } else if (pathname.match(/^\\/api\\/providers\\/([^/]+)\\/file$/) && req.method === 'POST') {\n const type = pathname.match(/^\\/api\\/providers\\/([^/]+)\\/file$/)![1];\n await this.handleWriteFile(type, req, res);\n } else if (pathname.match(/^\\/api\\/providers\\/([^/]+)\\/source$/) && req.method === 'GET') {\n const type = pathname.match(/^\\/api\\/providers\\/([^/]+)\\/source$/)![1];\n await this.handleSource(type, req, res);\n } else if (pathname.match(/^\\/api\\/providers\\/([^/]+)\\/save$/) && req.method === 'POST') {\n const type = pathname.match(/^\\/api\\/providers\\/([^/]+)\\/save$/)![1];\n await this.handleSave(type, req, res);\n } else if (pathname === '/api/cdp/dom/inspect' && req.method === 'POST') {\n await this.handleDomInspect(req, res);\n } else if (pathname === '/api/cdp/dom/children' && req.method === 'POST') {\n await this.handleDomChildren(req, res);\n } else if (pathname === '/api/cdp/dom/analyze' && req.method === 'POST') {\n await this.handleDomAnalyze(req, res);\n } else if (pathname === '/api/cdp/targets' && req.method === 'GET') {\n await this.handleCdpTargets(req, res);\n } else if (pathname === '/api/scaffold' && req.method === 'POST') {\n await this.handleScaffold(req, res);\n } else if (pathname.match(/^\\/api\\/providers\\/([^/]+)\\/config$/) && req.method === 'GET') {\n const type = pathname.match(/^\\/api\\/providers\\/([^/]+)\\/config$/)![1];\n await this.handleProviderConfig(type, req, res);\n } else if (pathname.match(/^\\/api\\/providers\\/([^/]+)\\/spawn-test$/) && req.method === 'POST') {\n const type = pathname.match(/^\\/api\\/providers\\/([^/]+)\\/spawn-test$/)![1];\n await this.handleSpawnTest(type, req, res);\n } else if (pathname.startsWith('/assets/') || pathname === '/favicon.ico') {\n await this.serveStaticAsset(pathname, res);\n } else if (pathname === '/' || pathname === '/console' || !pathname.startsWith('/api')) {\n await this.serveConsole(req, res);\n } else {\n this.json(res, 404, { error: 'Not found', endpoints: [\n 'GET / — DevConsole web UI',\n 'GET /api/providers',\n\n 'POST /api/providers/:type/script',\n 'GET /api/providers/:type/source',\n 'POST /api/providers/:type/save',\n 'POST /api/cdp/evaluate',\n 'POST /api/cdp/dom/query',\n 'GET /api/cdp/screenshot',\n 'GET /api/cdp/targets',\n 'GET /api/status',\n 'POST /api/providers/reload',\n 'POST /api/watch/start',\n 'POST /api/watch/stop',\n 'GET /api/watch/events (SSE)',\n 'POST /api/scaffold',\n ]});\n }\n } catch (e: any) {\n this.log(`Error: ${e.message}`);\n this.json(res, 500, { error: e.message });\n }\n });\n\n return new Promise((resolve, reject) => {\n this.server!.listen(port, '127.0.0.1', () => {\n this.log(`Dev server listening on http://127.0.0.1:${port}`);\n resolve();\n });\n this.server!.on('error', (e: any) => {\n if (e.code === 'EADDRINUSE') {\n this.log(`Port ${port} in use, skipping dev server`);\n resolve(); // non-fatal\n } else {\n reject(e);\n }\n });\n });\n }\n\n stop(): void {\n this.server?.close();\n this.server = null;\n }\n\n // ─── Handlers ───\n\n private async handleListProviders(_req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const providers = this.providerLoader.getAll().map(p => {\n const base: any = {\n type: p.type,\n name: p.name,\n category: p.category,\n icon: (p as any).icon || null,\n displayName: (p as any).displayName || p.name,\n };\n\n // IDE/Extension specific\n if (p.category === 'ide' || p.category === 'extension') {\n base.scripts = p.scripts ? Object.keys(p.scripts).filter(k => typeof (p.scripts as any)[k] === 'function') : [];\n base.inputMethod = p.inputMethod || null;\n base.inputSelector = (p as any).inputSelector || null;\n base.extensionId = p.extensionId || null;\n base.cdpPorts = (p as any).cdpPorts || [];\n }\n\n // ACP specific\n if (p.category === 'acp') {\n base.spawn = (p as any).spawn || null;\n base.auth = (p as any).auth || null;\n base.install = (p as any).install || null;\n base.hasSettings = !!(p as any).settings;\n base.settingsCount = (p as any).settings ? Object.keys((p as any).settings).length : 0;\n }\n\n // CLI specific\n if (p.category === 'cli') {\n base.spawn = (p as any).spawn || null;\n base.install = (p as any).install || null;\n }\n\n return base;\n });\n this.json(res, 200, { providers, count: providers.length });\n }\n\n private async handleProviderConfig(type: string, _req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const provider = this.providerLoader.get(type);\n if (!provider) {\n this.json(res, 404, { error: `Provider not found: ${type}` });\n return;\n }\n // Return full config (sans functions being serialized, just keys)\n const config: any = { ...provider };\n // Convert scripts to list of names\n if (config.scripts) {\n config.scriptNames = Object.keys(config.scripts).filter(k => typeof config.scripts[k] === 'function');\n delete config.scripts;\n }\n this.json(res, 200, { type, config });\n }\n\n private async handleSpawnTest(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const provider = this.providerLoader.get(type);\n if (!provider) {\n this.json(res, 404, { error: `Provider not found: ${type}` });\n return;\n }\n\n const spawn = (provider as any).spawn;\n if (!spawn) {\n this.json(res, 400, { error: `Provider ${type} has no spawn config` });\n return;\n }\n\n const { spawn: spawnFn } = await import('child_process');\n const start = Date.now();\n try {\n const child = spawnFn(spawn.command, [...(spawn.args || [])], {\n shell: spawn.shell ?? false,\n timeout: 5000,\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n\n let stdout = '';\n let stderr = '';\n child.stdout?.on('data', (d: Buffer) => { stdout += d.toString().slice(0, 2000); });\n child.stderr?.on('data', (d: Buffer) => { stderr += d.toString().slice(0, 2000); });\n\n // Wait for first output or exit (max 3s)\n await new Promise<void>((resolve) => {\n const timer = setTimeout(() => { child.kill(); resolve(); }, 3000);\n child.on('exit', () => { clearTimeout(timer); resolve(); });\n child.stdout?.once('data', () => { setTimeout(() => { child.kill(); clearTimeout(timer); resolve(); }, 500); });\n });\n\n const elapsed = Date.now() - start;\n this.json(res, 200, {\n success: true,\n command: `${spawn.command} ${(spawn.args || []).join(' ')}`,\n elapsed,\n stdout: stdout.trim(),\n stderr: stderr.trim(),\n exitCode: child.exitCode,\n });\n } catch (e: any) {\n const elapsed = Date.now() - start;\n this.json(res, 200, {\n success: false,\n command: `${spawn.command} ${(spawn.args || []).join(' ')}`,\n elapsed,\n error: e.message,\n });\n }\n }\n\n private async handleRunScript(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { script: scriptName, params, ideType: scriptIdeType } = body;\n\n const provider = this.providerLoader.resolve(type);\n if (!provider) {\n this.json(res, 404, { error: `Provider '${type}' not found` });\n return;\n }\n\n const fn = (provider.scripts as any)?.[scriptName];\n if (typeof fn !== 'function') {\n this.json(res, 400, { error: `Script '${scriptName}' not found in provider '${type}'`, available: provider.scripts ? Object.keys(provider.scripts) : [] });\n return;\n }\n\n const cdp = this.getCdp(scriptIdeType);\n if (!cdp) {\n this.json(res, 503, { error: 'No CDP connection available' });\n return;\n }\n\n try {\n // Pass all params to script (flexible parameter support)\n // Backward compat: legacy single argument scripts (sendMessage(text)) also work\n const scriptCode = params ? fn(params) : fn();\n if (!scriptCode) {\n this.json(res, 500, { error: 'Script function returned null' });\n return;\n }\n\n // Execute webview script via evaluateInWebviewFrame\n const isWebviewScript = scriptName.toLowerCase().includes('webview');\n let raw: any;\n if (isWebviewScript) {\n const matchText = provider.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n raw = await cdp.evaluateInWebviewFrame(scriptCode, matchFn);\n } else {\n raw = await cdp.evaluate(scriptCode, 30000);\n }\n\n let result = raw;\n if (typeof raw === 'string') {\n try { result = JSON.parse(raw); } catch { /* keep */ }\n }\n this.json(res, 200, { type, script: scriptName, result });\n } catch (e: any) {\n this.json(res, 500, { error: `Script execution failed: ${e.message}` });\n }\n }\n\n private async handleCdpEvaluate(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { expression, timeout, ideType } = body;\n if (!expression) {\n this.json(res, 400, { error: 'expression required' });\n return;\n }\n\n const cdp = ideType ? this.cdpManagers.get(ideType) : this.getAnyCdp();\n if (!cdp?.isConnected) {\n this.json(res, 503, { error: 'No CDP connection available' });\n return;\n }\n\n try {\n const raw = await cdp.evaluate(expression, timeout || 30000);\n let result = raw;\n if (typeof raw === 'string') {\n try { result = JSON.parse(raw); } catch { /* keep */ }\n }\n this.json(res, 200, { result });\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n private async handleCdpDomQuery(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { selector, limit = 10, ideType } = body;\n if (!selector) {\n this.json(res, 400, { error: 'selector required' });\n return;\n }\n\n const cdp = this.getCdp(ideType as string);\n if (!cdp) {\n this.json(res, 503, { error: 'No CDP connection available' });\n return;\n }\n\n const expr = `(() => {\n try {\n const els = document.querySelectorAll('${selector.replace(/'/g, \"\\\\'\")}');\n const results = [];\n for (let i = 0; i < Math.min(els.length, ${limit}); i++) {\n const el = els[i];\n results.push({\n index: i,\n tag: el.tagName?.toLowerCase(),\n id: el.id || null,\n class: el.className && typeof el.className === 'string' ? el.className.trim().slice(0, 200) : null,\n role: el.getAttribute?.('role') || null,\n text: (el.textContent || '').trim().slice(0, 100),\n visible: el.offsetParent !== null || el.offsetWidth > 0,\n rect: (() => { try { const r = el.getBoundingClientRect(); return { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) }; } catch { return null; } })()\n });\n }\n return JSON.stringify({ total: els.length, results });\n } catch (e) { return JSON.stringify({ error: e.message }); }\n })()`;\n\n try {\n const raw = await cdp.evaluate(expr, 10000);\n const result = typeof raw === 'string' ? JSON.parse(raw) : raw;\n this.json(res, 200, result);\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n private async handleScreenshot(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const url = new URL(req.url || '/', 'http://localhost');\n const ideType = url.searchParams.get('ideType') || undefined;\n const cdp = this.getCdp(ideType);\n if (!cdp) {\n this.json(res, 503, { error: 'No CDP connection available' });\n return;\n }\n\n try {\n // Get viewport metrics before capturing\n let vpW = 0, vpH = 0;\n try {\n const metrics = await cdp.send('Page.getLayoutMetrics', {}, 3000);\n const vp = metrics?.cssVisualViewport || metrics?.visualViewport;\n if (vp) {\n vpW = Math.round(vp.clientWidth || vp.width || 0);\n vpH = Math.round(vp.clientHeight || vp.height || 0);\n }\n } catch { /* ignore */ }\n\n const buf = await cdp.captureScreenshot();\n if (buf) {\n res.writeHead(200, {\n 'Content-Type': 'image/jpeg',\n 'X-Viewport-Width': String(vpW),\n 'X-Viewport-Height': String(vpH),\n });\n res.end(buf);\n } else {\n this.json(res, 500, { error: 'Screenshot failed' });\n }\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n private async handleScriptsRun(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { type, script: scriptName, params } = body;\n if (!type || !scriptName) {\n this.json(res, 400, { error: 'type and script required' });\n return;\n }\n // Delegate to handleRunScript\n await this.handleRunScript(type, req, res);\n }\n\n private async handleStatus(_req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const providers = this.providerLoader.getAll().map(p => ({\n type: p.type, name: p.name, category: p.category,\n }));\n \n const cdpStatus: Record<string, { connected: boolean }> = {};\n for (const [key, cdp] of this.cdpManagers.entries()) {\n cdpStatus[key] = { connected: cdp.isConnected };\n }\n\n this.json(res, 200, {\n devMode: true,\n providers,\n cdp: cdpStatus,\n uptime: process.uptime(),\n });\n }\n\n private async handleReload(_req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n try {\n this.providerLoader.reload();\n const providers = this.providerLoader.getAll().map(p => ({\n type: p.type, name: p.name, category: p.category,\n }));\n this.json(res, 200, { reloaded: true, providers });\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n // ─── DevConsole SPA ───\n\n private getConsoleDistDir(): string | null {\n // Try to find web-devconsole/dist (Vite build output)\n const candidates = [\n path.resolve(__dirname, '../../web-devconsole/dist'),\n path.resolve(__dirname, '../../../web-devconsole/dist'),\n path.join(process.cwd(), 'packages/web-devconsole/dist'),\n ];\n for (const dir of candidates) {\n if (fs.existsSync(path.join(dir, 'index.html'))) return dir;\n }\n return null;\n }\n\n private async serveConsole(_req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const distDir = this.getConsoleDistDir();\n if (!distDir) {\n this.json(res, 500, { error: 'DevConsole not found. Run: npm run build -w packages/web-devconsole' });\n return;\n }\n const htmlPath = path.join(distDir, 'index.html');\n try {\n const html = fs.readFileSync(htmlPath, 'utf-8');\n res.writeHead(200, { 'Content-Type': 'text/html; charset=utf-8' });\n res.end(html);\n } catch (e: any) {\n this.json(res, 500, { error: `Cannot read index.html: ${e.message}` });\n }\n }\n\n // ─── Static Assets ───\n\n private static MIME_MAP: Record<string, string> = {\n '.css': 'text/css; charset=utf-8',\n '.js': 'application/javascript; charset=utf-8',\n '.png': 'image/png',\n '.svg': 'image/svg+xml',\n '.ico': 'image/x-icon',\n '.woff': 'font/woff',\n '.woff2': 'font/woff2',\n };\n\n private async serveStaticAsset(pathname: string, res: http.ServerResponse): Promise<void> {\n const distDir = this.getConsoleDistDir();\n if (!distDir) {\n this.json(res, 404, { error: 'Not found' });\n return;\n }\n // Prevent directory traversal\n const safePath = path.normalize(pathname).replace(/^\\.\\.\\//, '');\n const filePath = path.join(distDir, safePath);\n if (!filePath.startsWith(distDir)) {\n this.json(res, 403, { error: 'Forbidden' });\n return;\n }\n try {\n const content = fs.readFileSync(filePath);\n const ext = path.extname(filePath);\n const contentType = DevServer.MIME_MAP[ext] || 'application/octet-stream';\n res.writeHead(200, { 'Content-Type': contentType, 'Cache-Control': 'public, max-age=31536000, immutable' });\n res.end(content);\n } catch {\n this.json(res, 404, { error: 'Not found' });\n }\n }\n\n // ─── Watch Mode (SSE) ───\n\n private handleSSE(_req: http.IncomingMessage, res: http.ServerResponse): void {\n res.writeHead(200, {\n 'Content-Type': 'text/event-stream',\n 'Cache-Control': 'no-cache',\n 'Connection': 'keep-alive',\n 'Access-Control-Allow-Origin': '*',\n });\n res.write('data: {\"type\":\"connected\"}\\n\\n');\n this.sseClients.push(res);\n _req.on('close', () => {\n this.sseClients = this.sseClients.filter(c => c !== res);\n });\n }\n\n private sendSSE(data: any): void {\n const msg = `data: ${JSON.stringify(data)}\\n\\n`;\n for (const client of this.sseClients) {\n try { client.write(msg); } catch { /* ignore */ }\n }\n }\n\n private async handleWatchStart(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { type, script: scriptName, interval = 2000 } = body;\n if (!type) {\n this.json(res, 400, { error: 'type required' });\n return;\n }\n\n this.watchScriptPath = type;\n this.watchScriptName = scriptName || 'readChat';\n\n // Stop any existing watch\n if (this.watchTimer) clearInterval(this.watchTimer);\n\n this.log(`Watch started: ${type} → ${this.watchScriptName} (every ${interval}ms)`);\n this.sendSSE({ type: 'watch_started', provider: type, script: this.watchScriptName });\n\n const runWatch = async () => {\n if (!this.watchScriptPath) return;\n const provider = this.providerLoader.resolve(this.watchScriptPath);\n if (!provider) {\n this.sendSSE({ type: 'watch_error', error: `Provider '${this.watchScriptPath}' not found` });\n return;\n }\n const fn = (provider.scripts as any)?.[this.watchScriptName!];\n if (typeof fn !== 'function') {\n this.sendSSE({ type: 'watch_error', error: `Script '${this.watchScriptName}' not found` });\n return;\n }\n const cdp = this.getAnyCdp();\n if (!cdp) {\n this.sendSSE({ type: 'watch_error', error: 'No CDP connection' });\n return;\n }\n try {\n const script = fn();\n const start = Date.now();\n const raw = await cdp.evaluate(script, 15000);\n const elapsed = Date.now() - start;\n let result = raw;\n if (typeof raw === 'string') {\n try { result = JSON.parse(raw); } catch { /* keep */ }\n }\n this.sendSSE({ type: 'watch_result', provider: type, script: this.watchScriptName, result, elapsed });\n } catch (e: any) {\n this.sendSSE({ type: 'watch_error', error: e.message });\n }\n };\n\n // Run immediately then on interval\n runWatch();\n this.watchTimer = setInterval(runWatch, Math.max(interval, 500));\n\n this.json(res, 200, { watching: true, type, script: this.watchScriptName, interval });\n }\n\n private async handleWatchStop(_req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n if (this.watchTimer) {\n clearInterval(this.watchTimer);\n this.watchTimer = null;\n }\n this.watchScriptPath = null;\n this.watchScriptName = null;\n this.sendSSE({ type: 'watch_stopped' });\n this.json(res, 200, { watching: false });\n }\n\n // ─── Provider File Explorer ───\n\n /** Find the provider directory on disk */\n private findProviderDir(type: string): string | null {\n const provider = this.providerLoader.get(type);\n if (!provider) return null;\n const cat = provider.category;\n const builtinDir = (this.providerLoader as any).builtinDir || path.resolve(__dirname, '../providers/_builtin');\n const userDir = path.join(os.homedir(), '.adhdev', 'providers');\n\n // Direct match first\n const directCandidates = [\n path.join(userDir, type),\n path.join(builtinDir, cat, type),\n path.join(builtinDir, type),\n ];\n for (const d of directCandidates) {\n if (fs.existsSync(path.join(d, 'provider.json'))) return d;\n }\n\n // Scan category dir for matching type field\n const catDir = path.join(builtinDir, cat);\n if (fs.existsSync(catDir)) {\n try {\n for (const entry of fs.readdirSync(catDir, { withFileTypes: true })) {\n if (!entry.isDirectory()) continue;\n const jsonPath = path.join(catDir, entry.name, 'provider.json');\n if (fs.existsSync(jsonPath)) {\n try {\n const data = JSON.parse(fs.readFileSync(jsonPath, 'utf-8'));\n if (data.type === type) return path.join(catDir, entry.name);\n } catch { /* skip */ }\n }\n }\n } catch { /* skip */ }\n }\n return null;\n }\n\n /** GET /api/providers/:type/files — list all files in provider directory */\n private async handleListFiles(type: string, _req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const dir = this.findProviderDir(type);\n if (!dir) { this.json(res, 404, { error: `Provider directory not found: ${type}` }); return; }\n\n const files: { path: string; size: number; type: 'file' | 'dir' }[] = [];\n const scan = (d: string, prefix: string) => {\n try {\n for (const entry of fs.readdirSync(d, { withFileTypes: true })) {\n if (entry.name.startsWith('.') || entry.name.endsWith('.bak')) continue;\n const rel = prefix ? `${prefix}/${entry.name}` : entry.name;\n if (entry.isDirectory()) {\n files.push({ path: rel, size: 0, type: 'dir' });\n scan(path.join(d, entry.name), rel);\n } else {\n const stat = fs.statSync(path.join(d, entry.name));\n files.push({ path: rel, size: stat.size, type: 'file' });\n }\n }\n } catch { /* ignore */ }\n };\n scan(dir, '');\n this.json(res, 200, { type, dir, files });\n }\n\n /** GET /api/providers/:type/file?path=scripts.js — read a file */\n private async handleReadFile(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const url = new URL(req.url || '/', 'http://localhost');\n const filePath = url.searchParams.get('path');\n if (!filePath) { this.json(res, 400, { error: 'path query param required' }); return; }\n\n const dir = this.findProviderDir(type);\n if (!dir) { this.json(res, 404, { error: `Provider directory not found: ${type}` }); return; }\n\n // Prevent directory traversal\n const fullPath = path.resolve(dir, path.normalize(filePath));\n if (!fullPath.startsWith(dir)) { this.json(res, 403, { error: 'Forbidden' }); return; }\n if (!fs.existsSync(fullPath) || fs.statSync(fullPath).isDirectory()) {\n this.json(res, 404, { error: `File not found: ${filePath}` }); return;\n }\n\n const content = fs.readFileSync(fullPath, 'utf-8');\n this.json(res, 200, { type, path: filePath, content, lines: content.split('\\n').length });\n }\n\n /** POST /api/providers/:type/file — write a file { path, content } */\n private async handleWriteFile(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { path: filePath, content } = body;\n if (!filePath || typeof content !== 'string') {\n this.json(res, 400, { error: 'path and content required' }); return;\n }\n\n const dir = this.findProviderDir(type);\n if (!dir) { this.json(res, 404, { error: `Provider directory not found: ${type}` }); return; }\n\n const fullPath = path.resolve(dir, path.normalize(filePath));\n if (!fullPath.startsWith(dir)) { this.json(res, 403, { error: 'Forbidden' }); return; }\n\n try {\n if (fs.existsSync(fullPath)) fs.copyFileSync(fullPath, fullPath + '.bak');\n fs.mkdirSync(path.dirname(fullPath), { recursive: true });\n fs.writeFileSync(fullPath, content, 'utf-8');\n this.log(`File saved: ${fullPath} (${content.length} chars)`);\n this.providerLoader.reload();\n this.json(res, 200, { saved: true, path: filePath, chars: content.length });\n } catch (e: any) {\n this.json(res, 500, { error: `Save failed: ${e.message}` });\n }\n }\n\n // ─── Legacy Source/Save compat ───\n\n private async handleSource(type: string, _req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const dir = this.findProviderDir(type);\n if (!dir) { this.json(res, 404, { error: `Provider not found: ${type}` }); return; }\n for (const name of ['scripts.js', 'provider.json']) {\n const p = path.join(dir, name);\n if (fs.existsSync(p)) {\n const source = fs.readFileSync(p, 'utf-8');\n this.json(res, 200, { type, path: p, source, lines: source.split('\\n').length });\n return;\n }\n }\n this.json(res, 404, { error: `Source file not found for '${type}'` });\n }\n\n private async handleSave(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { source } = body;\n if (!source || typeof source !== 'string') {\n this.json(res, 400, { error: 'source (string) required' }); return;\n }\n const dir = this.findProviderDir(type);\n if (!dir) { this.json(res, 404, { error: `Provider not found: ${type}` }); return; }\n // Save to scripts.js if it exists, otherwise provider.json\n const target = fs.existsSync(path.join(dir, 'scripts.js')) ? 'scripts.js' : 'provider.json';\n const targetPath = path.join(dir, target);\n try {\n if (fs.existsSync(targetPath)) fs.copyFileSync(targetPath, targetPath + '.bak');\n fs.writeFileSync(targetPath, source, 'utf-8');\n this.log(`Saved provider: ${targetPath} (${source.length} chars)`);\n this.providerLoader.reload();\n this.json(res, 200, { saved: true, path: targetPath, chars: source.length });\n } catch (e: any) {\n this.json(res, 500, { error: `Save failed: ${e.message}` });\n }\n }\n\n\n\n private async handleCdpTargets(_req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const targets: { ide: string; connected: boolean; port: number }[] = [];\n for (const [ide, cdp] of this.cdpManagers.entries()) {\n targets.push({ ide, connected: cdp.isConnected, port: cdp.getPort() });\n }\n this.json(res, 200, { targets });\n }\n\n // ─── Scaffold ───\n\n private async handleScaffold(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { type, name, category = 'ide', location = 'user',\n cdpPorts, cli, processName, installPath, binary, extensionId } = body;\n if (!type || !name) {\n this.json(res, 400, { error: 'type and name required' });\n return;\n }\n\n const template = this.generateTemplate(type, name, category, { cdpPorts, cli, processName, installPath, binary, extensionId });\n\n let targetDir: string;\n if (location === 'user') {\n targetDir = path.join(os.homedir(), '.adhdev', 'providers', type);\n } else {\n const builtinDir = path.resolve(__dirname, '../providers/_builtin');\n targetDir = path.join(builtinDir, category, type);\n }\n\n const targetFile = path.join(targetDir, 'provider.js');\n\n if (fs.existsSync(targetFile)) {\n this.json(res, 409, { error: `Provider already exists at ${targetFile}`, path: targetFile });\n return;\n }\n\n try {\n fs.mkdirSync(targetDir, { recursive: true });\n fs.writeFileSync(targetFile, template, 'utf-8');\n this.log(`Scaffolded provider: ${targetFile}`);\n this.json(res, 201, { created: true, path: targetFile, type, name, category });\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n private generateTemplate(type: string, name: string, category: string, opts: Record<string, any> = {}): string {\n return genScaffoldTemplate(type, name, category, opts);\n }\n\n // ─── DOM Inspector ───\n\n private async handleDomInspect(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { x, y, selector, ideType } = body;\n const cdp = this.getCdp(ideType);\n if (!cdp) { this.json(res, 503, { error: 'No CDP connection' }); return; }\n\n const selectorArg = selector ? JSON.stringify(selector) : 'null';\n const inspectScript = `(() => {\n function gs(el) {\n if (!el || el === document.body) return 'body';\n if (el.id) return '#' + CSS.escape(el.id);\n let s = el.tagName.toLowerCase();\n if (el.className && typeof el.className === 'string') {\n const cls = el.className.trim().split(/\\\\s+/).filter(c => c && !c.startsWith('_')).slice(0, 3);\n if (cls.length) s += '.' + cls.map(c => CSS.escape(c)).join('.');\n }\n const p = el.parentElement;\n if (p) {\n const sibs = [...p.children].filter(c => c.tagName === el.tagName);\n if (sibs.length > 1) s += ':nth-child(' + ([...p.children].indexOf(el) + 1) + ')';\n }\n return s;\n }\n function gp(el) {\n const parts = [];\n let c = el;\n while (c && c !== document.documentElement) { parts.unshift(gs(c)); c = c.parentElement; }\n return parts;\n }\n function ni(el) {\n if (!el) return null;\n const tag = el.tagName?.toLowerCase() || '#text';\n const attrs = {};\n if (el.attributes) for (const a of el.attributes) if (a.name !== 'class' && a.name !== 'style') attrs[a.name] = a.value?.substring(0, 200);\n const cls = (el.className && typeof el.className === 'string') ? el.className.trim().split(/\\\\s+/).filter(Boolean).slice(0, 10) : [];\n const text = el.textContent?.trim().substring(0, 150) || '';\n const dt = [...(el.childNodes||[])].filter(n=>n.nodeType===3).map(n=>n.textContent.trim()).filter(Boolean).join(' ').substring(0,100);\n const cc = el.children?.length || 0;\n const r = el.getBoundingClientRect?.();\n return { tag, cls, attrs, text, directText: dt, childCount: cc, selector: gs(el), fullSelector: gp(el).join(' > '), rect: r ? {x:Math.round(r.x),y:Math.round(r.y),w:Math.round(r.width),h:Math.round(r.height)} : null };\n }\n const sel = ${selectorArg};\n let el = sel ? document.querySelector(sel) : document.elementFromPoint(${x||0}, ${y||0});\n if (!el) return JSON.stringify({ error: 'No element found' });\n const info = ni(el);\n const ancestors = [];\n let pp = el.parentElement;\n while (pp && pp !== document.documentElement) {\n ancestors.push({ tag: pp.tagName.toLowerCase(), selector: gs(pp), cls: (pp.className && typeof pp.className === 'string') ? pp.className.trim().split(/\\\\s+/).slice(0,3) : [] });\n pp = pp.parentElement;\n }\n const children = [...(el.children||[])].slice(0,50).map(c => ni(c));\n return JSON.stringify({ element: info, ancestors: ancestors.reverse(), children });\n })()`;\n\n try {\n const raw = await cdp.evaluate(inspectScript, 10000);\n let result = raw;\n if (typeof raw === 'string') { try { result = JSON.parse(raw as string); } catch {} }\n this.json(res, 200, result as Record<string, unknown>);\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n private async handleDomChildren(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { selector, ideType } = body;\n const cdp = this.getCdp(ideType);\n if (!cdp) { this.json(res, 503, { error: 'No CDP connection' }); return; }\n if (!selector) { this.json(res, 400, { error: 'selector required' }); return; }\n\n const script = `(() => {\n function gs(el) {\n if (!el || el === document.body) return 'body';\n if (el.id) return '#' + CSS.escape(el.id);\n let s = el.tagName.toLowerCase();\n if (el.className && typeof el.className === 'string') {\n const cls = el.className.trim().split(/\\\\s+/).filter(c => c && !c.startsWith('_')).slice(0, 3);\n if (cls.length) s += '.' + cls.map(c => CSS.escape(c)).join('.');\n }\n const p = el.parentElement;\n if (p) {\n const sibs = [...p.children].filter(c => c.tagName === el.tagName);\n if (sibs.length > 1) s += ':nth-child(' + ([...p.children].indexOf(el) + 1) + ')';\n }\n return s;\n }\n const el = document.querySelector(${JSON.stringify(selector)});\n if (!el) return JSON.stringify({ error: 'Element not found' });\n const children = [...(el.children||[])].slice(0,100).map(c => {\n const tag = c.tagName?.toLowerCase();\n const cls = (c.className && typeof c.className === 'string') ? c.className.trim().split(/\\\\s+/).filter(Boolean).slice(0,10) : [];\n const attrs = {};\n for (const a of c.attributes) if (a.name!=='class'&&a.name!=='style') attrs[a.name] = a.value?.substring(0,200);\n const text = c.textContent?.trim().substring(0,150)||'';\n const dt = [...c.childNodes].filter(n=>n.nodeType===3).map(n=>n.textContent.trim()).filter(Boolean).join(' ').substring(0,100);\n return { tag, cls, attrs, text, directText: dt, childCount: c.children?.length||0, selector: gs(c) };\n });\n return JSON.stringify({ selector: ${JSON.stringify(selector)}, childCount: el.children?.length||0, children });\n })()`;\n\n try {\n const raw = await cdp.evaluate(script, 10000);\n let result = raw;\n if (typeof raw === 'string') { try { result = JSON.parse(raw as string); } catch {} }\n this.json(res, 200, result as Record<string, unknown>);\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n private async handleDomAnalyze(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { ideType, selector, x, y } = body;\n const cdp = this.getCdp(ideType);\n if (!cdp) { this.json(res, 503, { error: 'No CDP connection' }); return; }\n\n const selectorArg = selector ? JSON.stringify(selector) : 'null';\n const analyzeScript = `(() => {\n function gs(el) {\n if (!el || el === document.body) return 'body';\n if (el.id) return '#' + CSS.escape(el.id);\n let s = el.tagName.toLowerCase();\n if (el.className && typeof el.className === 'string') {\n const cls = el.className.trim().split(/\\\\s+/).filter(c => c && !c.startsWith('_')).slice(0, 3);\n if (cls.length) s += '.' + cls.map(c => CSS.escape(c)).join('.');\n }\n return s;\n }\n function fp(el) {\n const parts = [];\n let c = el;\n while (c && c !== document.documentElement) { parts.unshift(gs(c)); c = c.parentElement; }\n return parts.join(' > ');\n }\n function sigOf(el) {\n return el.tagName + '|' + ((el.className && typeof el.className === 'string') ? el.className.trim().split(/\\\\s+/).filter(c => c && !c.startsWith('_')).sort().join('.') : '');\n }\n\n // Find target element\n const sel = ${selectorArg};\n let target = sel ? document.querySelector(sel) : document.elementFromPoint(${x||0}, ${y||0});\n if (!target) return JSON.stringify({ error: 'Element not found' });\n\n const result = {\n target: { tag: target.tagName.toLowerCase(), selector: fp(target), text: (target.textContent||'').trim().substring(0, 200) },\n siblingPattern: null,\n ancestorAnalysis: [],\n subtreeTexts: [],\n };\n\n // 1. Walk UP parents — at each level, find sibling patterns\n let el = target;\n let depth = 0;\n while (el && el !== document.body && depth < 15) {\n const parent = el.parentElement;\n if (!parent) break;\n\n const mySig = sigOf(el);\n const siblings = [...parent.children].filter(c => sigOf(c) === mySig);\n const totalChildren = parent.children.length;\n const childSel = gs(el).replace(/:nth-child\\\\(\\\\d+\\\\)/, '');\n const parentSel = fp(parent);\n\n result.ancestorAnalysis.push({\n depth,\n parentTag: parent.tagName.toLowerCase(),\n parentSelector: parentSel,\n totalChildren,\n matchingSiblings: siblings.length,\n childSelector: childSel,\n fullSelector: parentSel + ' > ' + childSel,\n });\n\n // Best sibling pattern: 3+ matching siblings with text\n if (!result.siblingPattern && siblings.length >= 3) {\n const siblingData = siblings.map((s, i) => {\n const directText = [...s.childNodes].filter(n => n.nodeType === 3).map(n => n.textContent.trim()).filter(Boolean).join(' ').substring(0, 120);\n const allText = (s.textContent || '').trim().substring(0, 200);\n const childCount = s.children?.length || 0;\n const cls = (s.className && typeof s.className === 'string') ? s.className.trim().split(/\\\\s+/).filter(Boolean) : [];\n const attrs = {};\n if (s.attributes) for (const a of s.attributes) {\n if (a.name !== 'class' && a.name !== 'style' && a.value) attrs[a.name] = a.value.substring(0, 100);\n }\n return { index: i, directText, allText, childCount, cls, attrs, tag: s.tagName.toLowerCase() };\n });\n\n // Find common attributes across siblings\n const allAttrs = siblingData.map(s => Object.keys(s.attrs));\n const commonAttrs = allAttrs[0]?.filter(attr => allAttrs.every(a => a.includes(attr))) || [];\n // Find varying attributes (data-*, role, etc)\n const varyingAttrs = {};\n for (const attr of commonAttrs) {\n const values = siblingData.map(s => s.attrs[attr]);\n const unique = [...new Set(values)];\n if (unique.length > 1) varyingAttrs[attr] = unique.slice(0, 5);\n }\n\n result.siblingPattern = {\n count: siblings.length,\n selector: parentSel + ' > ' + childSel,\n parentSelector: parentSel,\n depthFromTarget: depth,\n siblings: siblingData.slice(0, 30),\n commonAttrs,\n varyingAttrs,\n };\n }\n\n el = parent;\n depth++;\n }\n\n // 2. Collect subtree text nodes from target\n const walker = document.createTreeWalker(target, NodeFilter.SHOW_TEXT, null);\n let node;\n while ((node = walker.nextNode()) && result.subtreeTexts.length < 30) {\n const text = node.textContent.trim();\n if (text.length > 2) {\n const parentTag = node.parentElement?.tagName?.toLowerCase() || '';\n const parentCls = (node.parentElement?.className && typeof node.parentElement.className === 'string')\n ? node.parentElement.className.trim().split(/\\\\s+/).filter(Boolean).slice(0,3).join('.') : '';\n result.subtreeTexts.push({\n text: text.substring(0, 150),\n parentTag,\n parentCls,\n parentSelector: gs(node.parentElement),\n });\n }\n }\n\n return JSON.stringify(result);\n })()`;\n\n try {\n const raw = await cdp.evaluate(analyzeScript, 15000);\n let result = raw;\n if (typeof raw === 'string') { try { result = JSON.parse(raw as string); } catch {} }\n this.json(res, 200, result as Record<string, unknown>);\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n /** Get CDP manager — matching IDE when ideType specified, first connected one otherwise */\n private getCdp(ideType?: string): DaemonCdpManager | null {\n if (ideType) {\n const cdp = this.cdpManagers.get(ideType);\n if (cdp?.isConnected) return cdp;\n }\n for (const cdp of this.cdpManagers.values()) {\n if (cdp.isConnected) return cdp;\n }\n return null;\n }\n\n private getAnyCdp(): DaemonCdpManager | null {\n return this.getCdp();\n }\n\n private json(res: http.ServerResponse, status: number, data: any): void {\n res.writeHead(status, { 'Content-Type': 'application/json' });\n res.end(JSON.stringify(data, null, 2));\n }\n\n private async readBody(req: http.IncomingMessage): Promise<any> {\n return new Promise((resolve) => {\n let body = '';\n req.on('data', (chunk) => body += chunk);\n req.on('end', () => {\n try {\n resolve(JSON.parse(body));\n } catch {\n resolve({});\n }\n });\n });\n }\n}\n","/**\n * Provider scaffold template generator\n * Separated generateTemplate from dev-server.ts — for easier complex template literal management.\n */\n\nexport interface ScaffoldOptions {\n cdpPorts?: [number, number];\n cli?: string;\n processName?: string;\n installPath?: string;\n binary?: string;\n extensionId?: string;\n}\n\nexport function generateTemplate(type: string, name: string, category: string, opts: ScaffoldOptions = {}): string {\n const { cdpPorts, cli, processName, installPath, binary, extensionId } = opts;\n\n // ─── CLI category ───\n if (category === 'cli') {\n const bin = binary || type;\n return [\n `/**`,\n ` * ${name} — CLI Provider`,\n ` * @type {import('../../../../src/providers/contracts').ProviderModule}`,\n ` */`,\n `module.exports = {`,\n ` type: '${type}',`,\n ` name: '${name}',`,\n ` category: 'cli',`,\n ` icon: '💻',`,\n ` binary: '${bin}',`,\n ` spawn: {`,\n ` command: '${bin}',`,\n ` args: [],`,\n ` shell: true,`,\n ` },`,\n ` patterns: {`,\n ` prompt: [/^[>$#] /m],`,\n ` generating: [/\\\\.{3}$/, /thinking/i],`,\n ` approval: [/\\\\(y\\\\/n\\\\)/i, /approve/i, /allow/i],`,\n ` ready: [/ready/i],`,\n ` },`,\n ` cleanOutput(raw, lastUserInput) {`,\n ` return raw;`,\n ` },`,\n `};`,\n ``,\n ].join('\\n');\n }\n\n // ─── IDE / Extension category ───\n const isExtension = category === 'extension';\n const L: string[] = [];\n\n L.push(`/**`);\n L.push(` * ${name} — ${isExtension ? 'Extension' : 'IDE'} Provider`);\n L.push(` * @type {import('../../../../src/providers/contracts').ProviderModule}`);\n L.push(` */`);\n L.push(`module.exports = {`);\n L.push(` type: '${type}',`);\n L.push(` name: '${name}',`);\n L.push(` category: '${category}',`);\n L.push(` icon: '${isExtension ? '🧩' : '💻'}',`);\n if (cli) L.push(` cli: '${cli}',`);\n if (cdpPorts) L.push(` cdpPorts: [${cdpPorts[0]}, ${cdpPorts[1]}],`);\n else if (!isExtension) L.push(` cdpPorts: [9222, 9223],`);\n if (processName) L.push(` processNames: { darwin: '${processName}' },`);\n if (installPath) L.push(` paths: { darwin: ['${installPath}'] },`);\n if (isExtension) {\n L.push(` extensionId: '${extensionId || `publisher.${type}`}',`);\n } else {\n L.push(` inputMethod: 'cdp-type-and-send',`);\n L.push(` inputSelector: '[contenteditable=\"true\"][role=\"textbox\"]',`);\n }\n L.push(``);\n L.push(` scripts: {`);\n\n // readChat\n L.push(` readChat(params) {`);\n L.push(` return \\`(() => {`);\n L.push(` const messages = [];`);\n L.push(` let status = 'idle';`);\n L.push(` let activeModal = null;`);\n L.push(` // TODO: Parse chat messages`);\n L.push(` // Detect approval dialogs -> status = 'waiting_approval'`);\n L.push(` return JSON.stringify({ id: 'active', status, title: document.title, messages, inputContent: '', activeModal });`);\n L.push(` })()\\`;`);\n L.push(` },`);\n\n // sendMessage\n L.push(``);\n L.push(` sendMessage(params) {`);\n L.push(` const text = typeof params === 'string' ? params : params?.text;`);\n L.push(` return \\`(async () => {`);\n L.push(` return JSON.stringify({ sent: false, needsTypeAndSend: true, selector: '[contenteditable]' });`);\n L.push(` })()\\`;`);\n L.push(` },`);\n\n // listSessions\n L.push(``);\n L.push(` listSessions(params) {`);\n L.push(` return \\`(async () => { return JSON.stringify([]); })()\\`;`);\n L.push(` },`);\n\n // newSession\n L.push(``);\n L.push(` newSession(params) {`);\n L.push(` return \\`(async () => { return JSON.stringify({ created: true }); })()\\`;`);\n L.push(` },`);\n\n // openPanel\n L.push(``);\n L.push(` openPanel(params) {`);\n L.push(` return \\`(() => { return 'not_found'; })()\\`;`);\n L.push(` },`);\n\n // focusEditor\n L.push(``);\n L.push(` focusEditor(params) {`);\n L.push(` return \\`(() => {`);\n L.push(` const input = document.querySelector('[contenteditable=\"true\"]');`);\n L.push(` if (input) { input.focus(); return 'focused'; }`);\n L.push(` return 'not_found';`);\n L.push(` })()\\`;`);\n L.push(` },`);\n\n // resolveAction\n L.push(``);\n L.push(` resolveAction(params) {`);\n L.push(` const action = typeof params === 'string' ? params : params?.action || 'approve';`);\n L.push(` const buttonText = params?.button || params?.buttonText`);\n L.push(` || (action === 'approve' ? 'Accept' : action === 'reject' ? 'Reject' : action);`);\n L.push(` return \\`(() => {`);\n L.push(` const btns = [...document.querySelectorAll('button, [role=\"button\"]')].filter(b => b.offsetWidth > 0);`);\n L.push(` const target = btns.find(b => (b.textContent||'').trim().toLowerCase().includes(\\${JSON.stringify((buttonText||'').toLowerCase())}));`);\n L.push(` if (target) { target.click(); return JSON.stringify({ resolved: true, clicked: target.textContent.trim() }); }`);\n L.push(` return JSON.stringify({ resolved: false, available: btns.map(b => b.textContent.trim()).filter(Boolean).slice(0, 10) });`);\n L.push(` })()\\`;`);\n L.push(` },`);\n\n // listNotifications\n L.push(``);\n L.push(` listNotifications(params) {`);\n L.push(` return \\`(() => {`);\n L.push(` const toasts = [...document.querySelectorAll('.notifications-toasts .notification-toast, .notification-list-item')];`);\n L.push(` return JSON.stringify(toasts.filter(t => t.offsetWidth > 0).map((t, i) => ({`);\n L.push(` index: i,`);\n L.push(` message: t.querySelector('.notification-list-item-message')?.textContent?.trim() || t.textContent?.trim().substring(0, 200),`);\n L.push(` severity: t.querySelector('.codicon-error') ? 'error' : t.querySelector('.codicon-warning') ? 'warning' : 'info',`);\n L.push(` buttons: [...t.querySelectorAll('.notification-list-item-buttons-container button')].map(b => b.textContent?.trim()).filter(Boolean),`);\n L.push(` })));`);\n L.push(` })()\\`;`);\n L.push(` },`);\n\n // dismissNotification\n L.push(``);\n L.push(` dismissNotification(params) {`);\n L.push(` const idx = typeof params === 'number' ? params : params?.index ?? 0;`);\n L.push(` const button = typeof params === 'string' ? params : params?.button;`);\n L.push(` return \\`(() => {`);\n L.push(` const toasts = [...document.querySelectorAll('.notifications-toasts .notification-toast, .notification-list-item')].filter(t => t.offsetWidth > 0);`);\n L.push(` const toast = toasts[\\${idx}];`);\n L.push(` if (!toast) return JSON.stringify({ dismissed: false, count: toasts.length });`);\n L.push(` if (\\${JSON.stringify(button)}) {`);\n L.push(` const btn = [...toast.querySelectorAll('button')].find(b => b.textContent?.trim().toLowerCase().includes(\\${JSON.stringify((button||'').toLowerCase())}));`);\n L.push(` if (btn) { btn.click(); return JSON.stringify({ dismissed: true, clicked: btn.textContent.trim() }); }`);\n L.push(` }`);\n L.push(` const closeBtn = toast.querySelector('.codicon-notifications-clear, .codicon-close');`);\n L.push(` if (closeBtn) { closeBtn.click(); return JSON.stringify({ dismissed: true }); }`);\n L.push(` return JSON.stringify({ dismissed: false, error: 'Close button not found' });`);\n L.push(` })()\\`;`);\n L.push(` },`);\n\n L.push(` },`);\n L.push(`};`);\n return L.join('\\n') + '\\n';\n}\n","/**\n * ADHDev Launcher — Extension Installer\n * \n * Installs VS Code extensions via CLI commands.\n * Supports installing user-selected AI extensions.\n */\n\nimport { execSync, exec } from 'child_process';\nimport { IDEInfo } from './detector.js';\n\nexport interface ExtensionInfo {\n id: string;\n name: string;\n displayName: string;\n marketplaceId: string;\n description: string;\n category: 'ai-agent' | 'utility';\n icon: string;\n recommended: boolean;\n requiresApiKey?: boolean;\n apiKeyName?: string;\n website?: string;\n vsixUrl?: string; // VSIX download URL (used instead of marketplace)\n}\n\n/** Available extensions catalog */\nexport const EXTENSION_CATALOG: ExtensionInfo[] = [\n // AI Agent extensions\n {\n id: 'roo-code',\n name: 'Roo Code',\n displayName: 'Roo Code (Roo Cline)',\n marketplaceId: 'rooveterinaryinc.roo-cline',\n description: 'Open-source AI coding assistant with multiple modes',\n category: 'ai-agent',\n icon: '🦘',\n recommended: true,\n website: 'https://roocode.com',\n },\n {\n id: 'github-copilot',\n name: 'GitHub Copilot',\n displayName: 'GitHub Copilot',\n marketplaceId: 'github.copilot',\n description: 'AI pair programmer by GitHub',\n category: 'ai-agent',\n icon: '🤖',\n recommended: true,\n requiresApiKey: true,\n apiKeyName: 'GitHub account',\n website: 'https://github.com/features/copilot',\n },\n {\n id: 'copilot-chat',\n name: 'GitHub Copilot Chat',\n displayName: 'GitHub Copilot Chat',\n marketplaceId: 'github.copilot-chat',\n description: 'Chat interface for GitHub Copilot',\n category: 'ai-agent',\n icon: '💬',\n recommended: true,\n requiresApiKey: true,\n apiKeyName: 'GitHub account',\n },\n {\n id: 'cline',\n name: 'Cline',\n displayName: 'Cline',\n marketplaceId: 'saoudrizwan.claude-dev',\n description: 'Autonomous AI coding agent in your IDE',\n category: 'ai-agent',\n icon: '🧠',\n recommended: false,\n requiresApiKey: true,\n apiKeyName: 'Anthropic/OpenAI API key',\n },\n {\n id: 'continue',\n name: 'Continue',\n displayName: 'Continue',\n marketplaceId: 'continue.continue',\n description: 'Open-source AI code assistant with custom models',\n category: 'ai-agent',\n icon: '▶️',\n recommended: false,\n },\n {\n id: 'aider',\n name: 'Aider',\n displayName: 'Aider',\n marketplaceId: 'aider.aider',\n description: 'AI pair programming in your terminal',\n category: 'ai-agent',\n icon: '🔧',\n recommended: false,\n requiresApiKey: true,\n apiKeyName: 'OpenAI/Anthropic API key',\n },\n];\n\nexport interface InstallResult {\n extensionId: string;\n marketplaceId: string;\n success: boolean;\n alreadyInstalled: boolean;\n error?: string;\n}\n\n/**\n * Check if an extension is already installed\n */\nexport function isExtensionInstalled(\n ide: IDEInfo,\n marketplaceId: string\n): boolean {\n if (!ide.cliCommand) return false;\n\n try {\n const result = execSync(`\"${ide.cliCommand}\" --list-extensions`, {\n encoding: 'utf-8',\n timeout: 15000,\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n\n const installed = result\n .trim()\n .split('\\n')\n .map((e) => e.trim().toLowerCase());\n return installed.includes(marketplaceId.toLowerCase());\n } catch {\n return false;\n }\n}\n\n/**\n * Install a single extension\n */\nexport async function installExtension(\n ide: IDEInfo,\n extension: ExtensionInfo\n): Promise<InstallResult> {\n if (!ide.cliCommand) {\n return {\n extensionId: extension.id,\n marketplaceId: extension.marketplaceId,\n success: false,\n alreadyInstalled: false,\n error: `No CLI command found for ${ide.displayName}. Please install it manually.`,\n };\n }\n\n // Check if already installed\n const alreadyInstalled = isExtensionInstalled(ide, extension.marketplaceId);\n if (alreadyInstalled) {\n return {\n extensionId: extension.id,\n marketplaceId: extension.marketplaceId,\n success: true,\n alreadyInstalled: true,\n };\n }\n\n // If VSIX URL is available, download and install\n if (extension.vsixUrl) {\n try {\n const tmpDir = (await import('os')).tmpdir();\n const vsixPath = `${tmpDir}/adhdev-extension-latest.vsix`;\n\n // download\n const res = await fetch(extension.vsixUrl);\n if (res.ok) {\n const buffer = Buffer.from(await res.arrayBuffer());\n const fs = await import('fs');\n fs.writeFileSync(vsixPath, buffer);\n\n // Install VSIX\n return new Promise((resolve) => {\n const cmd = `\"${ide.cliCommand}\" --install-extension \"${vsixPath}\" --force`;\n exec(cmd, { timeout: 60000 }, (error, _stdout, stderr) => {\n resolve({\n extensionId: extension.id,\n marketplaceId: extension.marketplaceId,\n success: !error,\n alreadyInstalled: false,\n error: error ? (stderr || error.message) : undefined,\n });\n });\n });\n }\n // Fall back to marketplace install if VSIX download fails\n } catch (e: any) {\n // Fall back to marketplace install if VSIX download fails\n }\n }\n\n // Install via CLI (marketplace)\n return new Promise((resolve) => {\n const cmd = `\"${ide.cliCommand}\" --install-extension ${extension.marketplaceId} --force`;\n\n exec(cmd, { timeout: 60000 }, (error, stdout, stderr) => {\n if (error) {\n resolve({\n extensionId: extension.id,\n marketplaceId: extension.marketplaceId,\n success: false,\n alreadyInstalled: false,\n error: stderr || error.message,\n });\n } else {\n resolve({\n extensionId: extension.id,\n marketplaceId: extension.marketplaceId,\n success: true,\n alreadyInstalled: false,\n });\n }\n });\n });\n}\n\n/**\n * Install multiple extensions sequentially\n */\nexport async function installExtensions(\n ide: IDEInfo,\n extensions: ExtensionInfo[],\n onProgress?: (current: number, total: number, ext: ExtensionInfo, result: InstallResult) => void\n): Promise<InstallResult[]> {\n const results: InstallResult[] = [];\n\n for (let i = 0; i < extensions.length; i++) {\n const ext = extensions[i];\n const result = await installExtension(ide, ext);\n results.push(result);\n onProgress?.(i + 1, extensions.length, ext, result);\n }\n\n return results;\n}\n\n/**\n * Get AI agent extensions\n */\nexport function getAIExtensions(): ExtensionInfo[] {\n return EXTENSION_CATALOG.filter((e) => e.category === 'ai-agent');\n}\n\n\n\n/**\n * Launch IDE after installation\n */\nexport function launchIDE(ide: IDEInfo, workspacePath?: string): boolean {\n if (!ide.cliCommand) return false;\n\n try {\n const args = workspacePath ? `\"${workspacePath}\"` : '';\n exec(`\"${ide.cliCommand}\" ${args}`, { timeout: 10000 });\n return true;\n } catch {\n return false;\n }\n}\n","/**\n * Server Connection — WebSocket client to ADHDev server\n * \n * Daemon → Server direct WebSocket connection.\n * Handles auth, status reporting, P2P signaling relay, and server commands.\n */\n\nimport WebSocket from 'ws';\n\nexport type MessageType =\n | 'auth' | 'auth_ok' | 'auth_error' | 'machine_evicted'\n | 'status_report' | 'command' | 'command_result' | 'agent_command'\n | 'send_chat' | 'resolve_action'\n | 'status_event' | 'log' | 'error'\n // P2P signaling\n | 'p2p_ready' | 'p2p_offer' | 'p2p_answer' | 'p2p_ice'\n // Direct CDP/file commands\n | 'read_chat' | 'list_chats' | 'new_chat' | 'switch_chat'\n | 'set_mode' | 'change_model' | 'screenshot'\n | 'cdp_eval' | 'cdp_screenshot' | 'cdp_command_exec' | 'cdp_batch'\n | 'cdp_remote_action' | 'cdp_discover_agents'\n | 'file_read' | 'file_write' | 'file_list' | 'file_list_browse'\n | 'terminal_exec' | 'refresh_scripts';\n\nexport interface ServerMessage {\n type: MessageType;\n id?: string;\n source?: string;\n payload: Record<string, unknown>;\n timestamp: number;\n}\n\nexport type ConnectionState = 'disconnected' | 'connecting' | 'authenticating' | 'connected' | 'error';\n\nexport interface ServerConnectionOptions {\n serverUrl: string; // 'https://api.adhf.dev' → 'wss://api.adhf.dev/ws'\n token: string; // connectionToken from config\n cliInfo: {\n type: string; // 'gemini-cli'\n version: string; // gemini --version result\n platform: string; // process.platform\n instanceId: string; // 'gemini-cli_<machineId>'\n };\n}\n\nexport class ServerConnection {\n private ws: WebSocket | null = null;\n private options: ServerConnectionOptions;\n\n getCliInfo(): ServerConnectionOptions['cliInfo'] {\n return this.options.cliInfo;\n }\n private state: ConnectionState = 'disconnected';\n private reconnectAttempts = 0;\n private reconnectTimer: NodeJS.Timeout | null = null;\n private pingTimer: NodeJS.Timeout | null = null;\n private pongTimeout: NodeJS.Timeout | null = null;\n\n private messageHandlers = new Map<string, ((msg: ServerMessage) => void)[]>();\n private stateChangeCallbacks: ((state: ConnectionState) => void)[] = [];\n private userPlan: string = 'free';\n private iceServers: any[] | null = null;\n private planLimits: { maxP2PConnections: number; screenshotIntervalSeconds: number; maxMachines: number } | null = null;\n\n constructor(options: ServerConnectionOptions) {\n this.options = options;\n }\n\n async connect(): Promise<void> {\n if (this.state === 'connected' || this.state === 'connecting') return;\n this.setState('connecting');\n\n try {\n // Server URL conversion: https://api.adhf.dev → wss://api.adhf.dev/ws\n const wsUrl = this.options.serverUrl\n .replace(/^https:\\/\\//, 'wss://')\n .replace(/^http:\\/\\//, 'ws://');\n const fullUrl = wsUrl.endsWith('/ws') ? wsUrl : wsUrl + '/ws';\n\n console.log(`[ServerConn] Connecting to ${fullUrl}...`);\n\n // Important: pass X-ADHDev-IDE and X-ADHDev-Token headers\n // Server /ws endpoint determines instanceId from these headers\n this.ws = new WebSocket(fullUrl, {\n headers: {\n 'X-ADHDev-Token': this.options.token,\n 'X-ADHDev-IDE': JSON.stringify(this.options.cliInfo),\n },\n });\n\n this.ws.on('open', () => this.onOpen());\n this.ws.on('message', (data) => this.onMessage(data.toString()));\n this.ws.on('close', (code, reason) => this.onClose(code, reason.toString()));\n this.ws.on('error', (err) => this.onError(err));\n this.ws.on('pong', () => this.onPong());\n } catch (error) {\n console.error('[ServerConn] Connect failed:', error);\n this.setState('error');\n this.scheduleReconnect();\n }\n }\n\n disconnect(): void {\n this.clearTimers();\n this.reconnectAttempts = 999; // Prevent reconnection\n if (this.ws) {\n this.ws.close(1000, 'User disconnect');\n this.ws = null;\n }\n this.setState('disconnected');\n }\n\n send(message: ServerMessage): boolean {\n if (!this.ws || (this.state !== 'connected' && this.state !== 'authenticating')) {\n return false;\n }\n try {\n this.ws.send(JSON.stringify(message));\n return true;\n } catch {\n return false;\n }\n }\n\n sendMessage(type: MessageType, payload: Record<string, unknown>): boolean {\n return this.send({\n type,\n id: `msg_${Date.now()}_${Math.random().toString(36).substring(2, 8)}`,\n payload,\n timestamp: Date.now(),\n });\n }\n\n on(type: string, handler: (msg: ServerMessage) => void): void {\n if (!this.messageHandlers.has(type)) {\n this.messageHandlers.set(type, []);\n }\n this.messageHandlers.get(type)!.push(handler);\n }\n\n onStateChange(callback: (state: ConnectionState) => void): void {\n this.stateChangeCallbacks.push(callback);\n }\n\n getState(): ConnectionState { return this.state; }\n isConnected(): boolean { return this.state === 'connected'; }\n getUserPlan(): string { return this.userPlan; }\n getIceServers(): any[] | null { return this.iceServers; }\n getPlanLimits() { return this.planLimits; }\n\n // --- Private ---\n\n private onOpen(): void {\n console.log(`[ServerConn] WebSocket open, sending auth...`);\n this.setState('authenticating');\n\n this.send({\n type: 'auth',\n payload: {\n token: this.options.token,\n ide: this.options.cliInfo,\n },\n timestamp: Date.now(),\n });\n }\n\n private onMessage(text: string): void {\n try {\n const message: ServerMessage = JSON.parse(text);\n\n if (message.type === 'auth_ok') {\n this.reconnectAttempts = 0;\n this.userPlan = (message.payload as any).plan || 'free';\n this.iceServers = (message.payload as any).iceServers || null;\n this.planLimits = (message.payload as any).limits || null;\n if (this.iceServers?.length) {\n const hasTurn = this.iceServers.some((s: any) => JSON.stringify(s.urls || '').includes('turn'));\n console.log(`[ServerConn] ICE servers: ${this.iceServers.length} (TURN: ${hasTurn ? '✅' : '❌ STUN only'})`);\n }\n this.setState('connected');\n\n console.log(`[ServerConn] ✓ Authenticated (plan: ${this.userPlan})`);\n this.startHeartbeat();\n } else if (message.type === 'auth_error') {\n console.error('[ServerConn] ✗ Auth failed:', message.payload.reason);\n this.setState('error');\n return;\n }\n\n const handlers = this.messageHandlers.get(message.type);\n if (handlers) {\n handlers.forEach((h) => h(message));\n } else if (message.type !== 'auth_ok') {\n console.log(`[ServerConn] Unhandled message type: ${message.type}`);\n }\n } catch (error) {\n console.error('[ServerConn] Failed to parse message:', error);\n }\n }\n\n private onClose(code: number, reason: string): void {\n console.log(`[ServerConn] WebSocket closed: ${code} ${reason}`);\n this.clearTimers();\n this.ws = null;\n\n // 4011 = evicted by new machine → don't auto-reconnect\n if (code === 4011) {\n console.log(`[ServerConn] ⚠ Evicted by another machine. Not reconnecting.`);\n console.log(`[ServerConn] This connection was released because another machine connected.`);\n this.setState('disconnected');\n return;\n }\n\n if (code !== 1000 && this.reconnectAttempts < 50) {\n this.setState('disconnected');\n this.scheduleReconnect();\n } else {\n this.setState('disconnected');\n }\n }\n\n private onError(error: Error): void {\n console.error('[ServerConn] WebSocket error:', error.message);\n this.setState('error');\n }\n\n private setState(state: ConnectionState): void {\n if (this.state !== state) {\n this.state = state;\n this.stateChangeCallbacks.forEach((cb) => cb(state));\n }\n }\n\n private scheduleReconnect(): void {\n const delay = Math.min(1000 * Math.pow(2, this.reconnectAttempts), 60000);\n this.reconnectAttempts++;\n console.log(`[ServerConn] Reconnecting in ${delay}ms (attempt ${this.reconnectAttempts})...`);\n this.reconnectTimer = setTimeout(() => this.connect(), delay);\n }\n\n private clearTimers(): void {\n if (this.reconnectTimer) { clearTimeout(this.reconnectTimer); this.reconnectTimer = null; }\n this.stopHeartbeat();\n }\n\n // ─── WS Heartbeat (ping/pong) ─────────────────────\n\n private startHeartbeat(): void {\n this.stopHeartbeat();\n // Send WS-level ping every 30s (same cadence as server status report)\n this.pingTimer = setInterval(() => {\n if (!this.ws || this.ws.readyState !== WebSocket.OPEN) return;\n try {\n this.ws.ping();\n // If no pong within 10s, connection is dead → force close\n this.pongTimeout = setTimeout(() => {\n console.log('[ServerConn] ⚠ Pong timeout (10s) — closing zombie WS');\n if (this.ws) {\n this.ws.terminate(); // hard close, triggers 'close' event\n }\n }, 10_000);\n } catch {\n // ping failed — ws already broken\n }\n }, 30_000);\n }\n\n private stopHeartbeat(): void {\n if (this.pingTimer) { clearInterval(this.pingTimer); this.pingTimer = null; }\n if (this.pongTimeout) { clearTimeout(this.pongTimeout); this.pongTimeout = null; }\n }\n\n private onPong(): void {\n // Server responded to our ping — connection is alive\n if (this.pongTimeout) { clearTimeout(this.pongTimeout); this.pongTimeout = null; }\n }\n}\n","/**\n * DaemonP2P — Multi-peer P2P DataChannel (node-datachannel)\n * \n * daemon-p2p: P2P connection manager.\n * No vscode dependency — pure Node.js environment.\n * \n * Daemon directly accesses CDP to relay screenshots/remote control via P2P.\n * No Extension intermediary, reducing latency.\n * \n * Signaling: SDP/ICE exchange via ServerConnection (server WS).\n * Data: Forward screenshot (binary), files, input, commands via DataChannel.\n */\n\nimport { ServerConnection } from './server-connection.js';\nimport * as fs from 'fs';\nimport { readChatHistory } from '@adhdev/daemon-core';\nimport * as path from 'path';\nimport * as os from 'os';\n\n// ─── Types ──────────────────────────────────────\n\nexport type P2PSenderState = 'unavailable' | 'idle' | 'connecting' | 'connected' | 'failed';\n\ninterface DataChannelLike {\n send(data: Buffer | Uint8Array): void;\n sendMessage(data: string): void;\n sendMessageBinary(data: Buffer | Uint8Array): void;\n isOpen(): boolean;\n close(): void;\n onOpen(cb: () => void): void;\n onClosed(cb: () => void): void;\n onError(cb: (err: string) => void): void;\n onMessage(cb: (msg: string | Buffer) => void): void;\n}\n\ninterface PeerConnectionLike {\n createDataChannel(label: string): DataChannelLike;\n setRemoteDescription(sdp: string, type: string): void;\n addRemoteCandidate(candidate: string, mid: string): void;\n onLocalDescription(cb: (sdp: string, type: string) => void): void;\n onLocalCandidate(cb: (candidate: string, mid: string) => void): void;\n onStateChange(cb: (state: string) => void): void;\n close(): void;\n state(): string;\n getSelectedCandidatePair?(): { local: { type: string; address: string }; remote: { type: string; address: string } } | null;\n}\n\ninterface PeerEntry {\n peerId: string;\n pc: PeerConnectionLike;\n screenshotChannel: DataChannelLike | null;\n filesChannel: DataChannelLike | null;\n state: P2PSenderState;\n screenshotActive: boolean;\n screenshotIdeType?: string;\n connectedAt: number;\n /** Queue ICE candidates arriving before SDP answer */\n pendingCandidates: { candidate: string; mid: string }[];\n /** Whether remote description has been set */\n remoteDescriptionSet: boolean;\n /** Timer for auto-cleanup of failed peers */\n failedCleanupTimer?: ReturnType<typeof setTimeout>;\n /** P2P keepalive timer — prevents NAT binding expiry */\n heartbeatTimer?: ReturnType<typeof setInterval>;\n /** Whether this connection goes through TURN relay */\n isRelay: boolean;\n}\n\n// ─── Logger ─────────────────────────────────────\n\nconst logFile = path.join(os.tmpdir(), 'adhdev_daemon_p2p.log');\nconst log = (msg: string) => {\n const line = `[${new Date().toISOString()}] [P2P] ${msg}`;\n console.log(line);\n};\n\n// ─── P2P Sender (Multi-peer) ────────────────────\n\nexport type FileRequest = {\n id: string;\n type: 'read' | 'write' | 'list';\n path: string;\n content?: string;\n};\n\nexport type FileResponse = {\n id: string;\n success: boolean;\n content?: string;\n entries?: { name: string; type: string; size?: number }[];\n error?: string;\n};\n\nexport type InputEvent = {\n action: string;\n params: any;\n _targetInstance?: string;\n};\n\nexport class DaemonP2PSender {\n private serverConn: ServerConnection;\n private peers = new Map<string, PeerEntry>();\n private nodeDatachannel: any = null;\n private stateListeners: ((state: P2PSenderState) => void)[] = [];\n private fileRequestHandler: ((req: FileRequest) => Promise<FileResponse>) | null = null;\n private inputHandler: ((event: InputEvent) => Promise<any>) | null = null;\n private commandHandler: ((commandType: string, data: Record<string, unknown>, id: string) => Promise<{ success: boolean; result?: any; error?: string }>) | null = null;\n private ptyInputHandler: ((cliType: string, data: string) => void) | null = null;\n private ptyResizeHandler: ((cliType: string, cols: number, rows: number) => void) | null = null;\n private _ssDebugDone = false;\n\n // PTY scrollback buffer per cliType (send recent output on reconnect)\n private ptyScrollback = new Map<string, string>();\n private readonly PTY_SCROLLBACK_MAX = 64 * 1024; // 64KB per CLI\n\n get screenshotActive(): boolean {\n for (const peer of this.peers.values()) {\n if (peer.screenshotActive && peer.state === 'connected') return true;\n }\n return false;\n }\n\n /** Get the ideType for the currently active screenshot request */\n get screenshotIdeType(): string | undefined {\n for (const peer of this.peers.values()) {\n if (peer.screenshotActive && peer.state === 'connected' && peer.screenshotIdeType) {\n return peer.screenshotIdeType;\n }\n }\n return undefined;\n }\n\n constructor(serverConn: ServerConnection) {\n this.serverConn = serverConn;\n this.tryLoadNodeDatachannel();\n }\n\n /** node-datachannel Load */\n private tryLoadNodeDatachannel(): void {\n try {\n this.nodeDatachannel = require('node-datachannel');\n const keys = Object.keys(this.nodeDatachannel).join(',');\n log(`node-datachannel loaded ✅ (keys: ${keys.substring(0, 100)})`);\n return;\n } catch (e: any) {\n log(`node-datachannel not found: ${e?.message}`);\n }\n\n // Try from prebuilds\n const platform = process.platform;\n const arch = process.arch;\n const prebuildKey = `${platform}-${arch}`;\n\n try {\n const candidates = [\n path.join(__dirname, 'node_modules', 'node-datachannel'),\n path.join(__dirname, '..', 'node_modules', 'node-datachannel'),\n path.join(__dirname, '..', '..', 'node_modules', 'node-datachannel'),\n ];\n\n for (const candidate of candidates) {\n const prebuildPath = path.join(candidate, 'prebuilds', prebuildKey, 'node_datachannel.node');\n if (fs.existsSync(prebuildPath)) {\n const targetDir = path.join(candidate, 'build', 'Release');\n const targetPath = path.join(targetDir, 'node_datachannel.node');\n fs.mkdirSync(targetDir, { recursive: true });\n fs.copyFileSync(prebuildPath, targetPath);\n\n try { delete require.cache[require.resolve('node-datachannel')]; } catch { }\n this.nodeDatachannel = require('node-datachannel');\n log(`node-datachannel loaded from prebuild (${prebuildKey}) ✅`);\n return;\n }\n }\n } catch (e: any) {\n log(`Prebuild load failed: ${e?.message}`);\n }\n\n log('node-datachannel NOT available — P2P disabled');\n }\n\n get isAvailable(): boolean { return !!this.nodeDatachannel; }\n\n get isConnected(): boolean {\n for (const peer of this.peers.values()) {\n if (peer.state === 'connected' && peer.screenshotChannel) return true;\n }\n return false;\n }\n\n get connectionState(): P2PSenderState {\n if (!this.isAvailable) return 'unavailable';\n if (this.isConnected) return 'connected';\n for (const peer of this.peers.values()) {\n if (peer.state === 'connecting') return 'connecting';\n }\n if (this.peers.size > 0) return 'failed';\n return 'idle';\n }\n\n get connectedPeerCount(): number {\n let count = 0;\n for (const peer of this.peers.values()) {\n if (peer.state === 'connected') count++;\n }\n return count;\n }\n\n /** Any connected peer is using TURN relay? */\n get isUsingRelay(): boolean {\n for (const peer of this.peers.values()) {\n if (peer.state === 'connected' && peer.isRelay) return true;\n }\n return false;\n }\n\n getPeers(): { peerId: string; state: P2PSenderState; screenshotActive: boolean }[] {\n return Array.from(this.peers.values()).map(p => ({\n peerId: p.peerId,\n state: p.state,\n screenshotActive: p.screenshotActive,\n }));\n }\n\n onStateChange(listener: (state: P2PSenderState) => void): void {\n this.stateListeners.push(listener);\n }\n\n private notifyStateChange(): void {\n const state = this.connectionState;\n this.stateListeners.forEach(fn => fn(state));\n }\n\n /** Fetch TURN credentials */\n private async fetchTurnCredentials(): Promise<string[] | null> {\n try {\n const serverUrl = 'https://api.adhf.dev';\n const configPath = path.join(os.homedir(), '.adhdev', 'config.json');\n let token = '';\n try {\n const config = JSON.parse(fs.readFileSync(configPath, 'utf-8'));\n token = config.connectionToken || '';\n } catch { }\n\n const http = require('https');\n const data = await new Promise<string>((resolve, reject) => {\n const req = http.get(`${serverUrl}/api/v1/turn/credentials`, {\n headers: { 'Authorization': `Bearer ${token}` },\n }, (res: any) => {\n let d = '';\n res.on('data', (c: string) => d += c);\n res.on('end', () => resolve(d));\n });\n req.on('error', reject);\n req.setTimeout(5000, () => { req.destroy(); reject(new Error('timeout')); });\n });\n\n const parsed = JSON.parse(data) as { iceServers: any[]; turn: boolean };\n if (!parsed.turn || !parsed.iceServers) return null;\n\n const servers: string[] = [];\n for (const server of parsed.iceServers) {\n const urls = Array.isArray(server.urls) ? server.urls : [server.urls];\n for (const url of urls) {\n if (url.startsWith('stun:')) {\n servers.push(url);\n } else if (url.startsWith('turn:') || url.startsWith('turns:')) {\n if (server.username && server.credential) {\n const cleanUrl = url.split('?')[0];\n const parts = cleanUrl.split(':');\n servers.push(`${parts[0]}:${parts[1]}:${parts[2] || '3478'}:${server.username}:${server.credential}`);\n }\n }\n }\n }\n return servers.length > 0 ? servers : null;\n } catch (e: any) {\n log(`TURN credentials failed: ${e?.message}`);\n return null;\n }\n }\n\n /** P2P connect Start */\n async initiateconnection(peerId?: string): Promise<void> {\n if (!this.nodeDatachannel) {\n log('Cannot initiate — node-datachannel not available');\n return;\n }\n\n // ── maxP2PConnections enforcement (FIFO eviction) ──\n // Evict oldest peer, sending signal before evict so\n // dashboard will not attempt reconnection\n const limits = this.serverConn.getPlanLimits();\n if (limits && limits.maxP2PConnections !== -1) {\n const connectedCount = this.connectedPeerCount;\n if (connectedCount >= limits.maxP2PConnections) {\n let oldestPeer: { id: string; at: number } | null = null;\n for (const [pid, peer] of this.peers) {\n if (peer.state === 'connected') {\n if (!oldestPeer || peer.connectedAt < oldestPeer.at) {\n oldestPeer = { id: pid, at: peer.connectedAt };\n }\n }\n }\n if (oldestPeer) {\n log(`P2P limit reached (${connectedCount}/${limits.maxP2PConnections}). Evicting oldest peer ${oldestPeer.id.slice(0, 12)}…`);\n // Send signal before evict → prevent dashboard reconnection\n const evictedPeer = this.peers.get(oldestPeer.id);\n if (evictedPeer?.filesChannel?.isOpen()) {\n try {\n evictedPeer.filesChannel.sendMessage(JSON.stringify({\n type: 'p2p_evicted',\n reason: 'P2P_LIMIT_REACHED',\n maxconnections: limits.maxP2PConnections,\n }));\n } catch { /* channel may be dead */ }\n }\n this.disconnectPeer(oldestPeer.id);\n }\n }\n }\n\n const pid = peerId || `legacy_${Date.now()}`;\n const existing = this.peers.get(pid);\n if (existing?.state === 'connected') return;\n if (existing?.state === 'connecting') this.disconnectPeer(pid);\n\n log(`initiateconnection() for peer ${pid}...`);\n\n // node-datachannel CJS/ESM export structure may differ by platform\n const mod = this.nodeDatachannel;\n const PeerConnectionCtor = mod.PeerConnection || mod.default?.PeerConnection || mod.default || mod;\n if (!PeerConnectionCtor || typeof PeerConnectionCtor !== 'function') {\n log(`PeerConnection constructor not found in node-datachannel module. Keys: ${Object.keys(mod).join(',')}`);\n return;\n }\n\n let iceServers: string[] = [\n 'stun:stun.cloudflare.com:3478',\n 'stun:stun.l.google.com:19302',\n ];\n // Use TURN credentials from server auth_ok (no separate HTTP call needed)\n const serverIceServers = this.serverConn.getIceServers();\n if (serverIceServers?.length) {\n const converted: string[] = [];\n for (const server of serverIceServers) {\n const urls = Array.isArray(server.urls) ? server.urls : [server.urls];\n for (const url of urls) {\n if (url.startsWith('stun:')) {\n converted.push(url);\n } else if ((url.startsWith('turn:') || url.startsWith('turns:')) && server.username && server.credential) {\n const cleanUrl = url.split('?')[0];\n const parts = cleanUrl.split(':');\n converted.push(`${parts[0]}:${parts[1]}:${parts[2] || '3478'}:${server.username}:${server.credential}`);\n }\n }\n }\n if (converted.length > 0) {\n iceServers = converted;\n const hasTurn = converted.some(s => s.startsWith('turn'));\n log(`ICE servers from auth: ${converted.length} (TURN: ${hasTurn ? '✅' : '❌'})`);\n }\n }\n\n const pc = new PeerConnectionCtor(`ADHDev-Daemon-${pid.substring(0, 8)}`, {\n iceServers,\n }) as PeerConnectionLike;\n\n const entry: PeerEntry = {\n peerId: pid,\n pc,\n screenshotChannel: null,\n filesChannel: null,\n state: 'connecting',\n screenshotActive: false,\n connectedAt: Date.now(),\n pendingCandidates: [],\n remoteDescriptionSet: false,\n isRelay: false,\n };\n this.peers.set(pid, entry);\n this.notifyStateChange();\n\n const timeout = setTimeout(() => {\n const peer = this.peers.get(pid);\n if (peer?.state === 'connecting') {\n log(`connection timeout (15s) for peer ${pid}`);\n peer.state = 'failed';\n this.notifyStateChange();\n }\n }, 15000);\n\n try {\n pc.onLocalDescription((sdp: string, type: string) => {\n log(`onLocalDescription for peer ${pid}: type=${type}`);\n this.serverConn.sendMessage('p2p_offer', { sdp, type, peerId: pid });\n });\n\n pc.onLocalCandidate((candidate: string, mid: string) => {\n this.serverConn.sendMessage('p2p_ice', { candidate, mid, peerId: pid });\n });\n\n pc.onStateChange((pcState: string) => {\n log(`Peer ${pid} state: ${pcState}`);\n const peer = this.peers.get(pid);\n if (!peer) return;\n if (pcState === 'connected') {\n peer.state = 'connected';\n // Detect TURN relay vs STUN direct\n try {\n const pair = pc.getSelectedCandidatePair?.();\n if (pair) {\n const localType = pair.local?.type || 'unknown';\n const remoteType = pair.remote?.type || 'unknown';\n peer.isRelay = localType === 'relay' || remoteType === 'relay';\n log(`Candidate pair: local=${localType} remote=${remoteType} → ${peer.isRelay ? '🔄 TURN RELAY' : '⚡ DIRECT'}`);\n }\n } catch { /* getSelectedCandidatePair not available */ }\n // Clear any failed cleanup timer\n if (peer.failedCleanupTimer) {\n clearTimeout(peer.failedCleanupTimer);\n peer.failedCleanupTimer = undefined;\n }\n // Start P2P heartbeat — prevents NAT binding expiry (especially for TURN relay)\n this.startHeartbeat(pid);\n this.notifyStateChange();\n } else if (pcState === 'failed' || pcState === 'closed') {\n peer.state = 'failed';\n this.notifyStateChange();\n // Auto-cleanup failed peers after 30 seconds\n if (!peer.failedCleanupTimer) {\n peer.failedCleanupTimer = setTimeout(() => {\n const p = this.peers.get(pid);\n if (p?.state === 'failed') {\n log(`Auto-cleanup stale failed peer ${pid}`);\n this.disconnectPeer(pid);\n }\n }, 30000);\n }\n }\n });\n\n // Screenshots DataChannel\n // IMPORTANT: Do NOT assign to entry.screenshotChannel until onOpen fires.\n // The browser's files channel may open first and send screenshot_start,\n // but sendScreenshot will silently fail if this channel isn't truly open.\n const screenshotCh = pc.createDataChannel('screenshots');\n\n screenshotCh.onOpen(() => {\n log(`Screenshots channel OPEN for peer ${pid}`);\n const peer = this.peers.get(pid);\n if (peer) {\n peer.screenshotChannel = screenshotCh;\n peer.state = 'connected';\n this.notifyStateChange();\n // If screenshot_start already arrived via files channel before\n // this channel opened, screenshotActive is already true.\n // Log so we know streaming should begin immediately.\n if (peer.screenshotActive) {\n log(`Screenshots auto-starting for peer ${pid} (was waiting for channel open)`);\n }\n }\n });\n screenshotCh.onClosed(() => {\n log(`Screenshots channel CLOSED for peer ${pid}`);\n const peer = this.peers.get(pid);\n if (peer?.screenshotChannel === screenshotCh) {\n peer.screenshotChannel = null;\n peer.state = 'failed';\n this.notifyStateChange();\n }\n });\n screenshotCh.onError((err: string) => log(`Screenshots error: ${err}`));\n\n // Files DataChannel\n const filesCh = pc.createDataChannel('files');\n entry.filesChannel = filesCh;\n\n filesCh.onOpen(() => {\n log(`Files channel OPEN for peer ${pid}`);\n // Send PTY scrollback (restore terminal content on reconnect)\n setTimeout(() => this.sendPtyScrollback(pid), 100);\n });\n filesCh.onClosed(() => {\n const peer = this.peers.get(pid);\n if (peer?.filesChannel === filesCh) peer.filesChannel = null;\n });\n filesCh.onError((err: string) => log(`Files error: ${err}`));\n filesCh.onMessage((msg: string | Buffer) => this.handleFilesMessage(pid, msg));\n\n } catch (e: any) {\n log(`connection failed for peer ${pid}: ${e?.message}`);\n clearTimeout(timeout);\n const peer = this.peers.get(pid);\n if (peer) peer.state = 'failed';\n this.notifyStateChange();\n }\n }\n\n /** Process files channel message */\n private handleFilesMessage(peerId: string, msg: string | Buffer): void {\n const text = typeof msg === 'string' ? msg : msg.toString('utf-8');\n try {\n const parsed = JSON.parse(text);\n // 'command' type is frequent, skip logging (send_chat etc ~500ms interval)\n if (parsed.type !== 'command' && parsed.type !== 'pty_input' && parsed.type !== 'pty_resize' && parsed.type !== 'ping' && parsed.type !== 'pong') {\n log(`Files message from peer ${peerId}: type=${parsed.type}`);\n }\n\n // P2P keepalive — maintain NAT binding\n if (parsed.type === 'ping') {\n const peer = this.peers.get(peerId);\n if (peer?.filesChannel?.isOpen()) {\n try { peer.filesChannel.sendMessage(JSON.stringify({ type: 'pong', ts: Date.now() })); } catch { }\n }\n return;\n }\n if (parsed.type === 'pong') return; // Response to ping sent by daemon\n\n if (parsed.type === 'screenshot_start') {\n const peer = this.peers.get(peerId);\n if (peer) {\n peer.screenshotActive = true;\n peer.screenshotIdeType = parsed.ideType || undefined;\n log(`screenshot_start: peer=${peerId}, ideType=${parsed.ideType || 'any'}, channelOpen=${!!peer.screenshotChannel}, state=${peer.state}`);\n } else {\n log(`screenshot_start: peer ${peerId} NOT FOUND in peers map!`);\n }\n return;\n }\n if (parsed.type === 'screenshot_stop') {\n const peer = this.peers.get(peerId);\n if (peer) {\n peer.screenshotActive = false;\n log(`screenshot_stop: peer=${peerId}`);\n }\n return;\n }\n if (parsed.type === 'input') {\n this.handleInputEvent(peerId, parsed);\n return;\n }\n if (parsed.type === 'command') {\n this.handleP2PCommand(peerId, parsed);\n return;\n }\n // PTY input (fire-and-forget)\n if (parsed.type === 'pty_input') {\n if (this.ptyInputHandler && parsed.data) {\n this.ptyInputHandler(parsed.cliType || '', parsed.data);\n }\n return;\n }\n // PTY resize\n if (parsed.type === 'pty_resize') {\n if (this.ptyResizeHandler && parsed.cols && parsed.rows) {\n this.ptyResizeHandler(parsed.cliType || '', parsed.cols, parsed.rows);\n }\n return;\n }\n\n // Chat history request\n if (parsed.type === 'chat_history') {\n const { agent, offset, limit, id, instanceId } = parsed;\n const result = readChatHistory(agent || '', offset || 0, limit || 30, instanceId);\n this.sendToPeer(peerId, { type: 'chat_history_result', id, ...result, agent });\n return;\n }\n\n this.handleFileRequest(peerId, parsed as FileRequest);\n } catch (e: any) {\n log(`Parse error from peer ${peerId}: ${e?.message}`);\n }\n }\n\n // ─── Status/screenshot send ─────────────────────\n\n sendStatus(status: Record<string, unknown>): boolean {\n const payload = JSON.stringify({\n type: 'status_report',\n payload: status,\n timestamp: Date.now(),\n });\n let sentAny = false;\n for (const peer of this.peers.values()) {\n if (peer.state !== 'connected' || !peer.filesChannel) continue;\n try { peer.filesChannel.sendMessage(payload); sentAny = true; } catch { }\n }\n return sentAny;\n }\n\n /** Send status_event directly via P2P (generating_started/completed etc.) */\n sendStatusEvent(event: Record<string, unknown>): boolean {\n const payload = JSON.stringify({\n type: 'status_event',\n payload: event,\n timestamp: Date.now(),\n });\n let sentAny = false;\n for (const peer of this.peers.values()) {\n if (peer.state !== 'connected' || !peer.filesChannel) continue;\n try { peer.filesChannel.sendMessage(payload); sentAny = true; } catch { }\n }\n return sentAny;\n }\n\n /** Broadcast PTY output to all connected peers */\n broadcastPtyOutput(cliType: string, data: string): boolean {\n // Update scrollback buffer\n const prev = this.ptyScrollback.get(cliType) || '';\n const updated = prev + data;\n this.ptyScrollback.set(cliType,\n updated.length > this.PTY_SCROLLBACK_MAX\n ? updated.slice(-this.PTY_SCROLLBACK_MAX)\n : updated\n );\n\n const msg = JSON.stringify({ type: 'pty_output', cliType, data });\n let sentAny = false;\n for (const peer of this.peers.values()) {\n if (peer.state !== 'connected' || !peer.filesChannel) continue;\n try { peer.filesChannel.sendMessage(msg); sentAny = true; } catch { }\n }\n return sentAny;\n }\n\n /** Send scrollback on peer connect */\n private sendPtyScrollback(peerId: string): void {\n const peer = this.peers.get(peerId);\n if (!peer?.filesChannel) return;\n for (const [cliType, buffer] of this.ptyScrollback) {\n if (!buffer) continue;\n try {\n peer.filesChannel.sendMessage(JSON.stringify({\n type: 'pty_output',\n cliType,\n data: buffer,\n scrollback: true,\n }));\n log(`Sent PTY scrollback to peer ${peerId}: ${cliType} (${buffer.length} bytes)`);\n } catch { }\n }\n }\n\n sendScreenshot(base64Data: string): boolean {\n const buffer = Buffer.from(base64Data, 'base64');\n return this.sendScreenshotBuffer(buffer);\n }\n\n /** Send screenshot as raw Buffer (no base64 conversion overhead) */\n sendScreenshotBuffer(buffer: Buffer): boolean {\n let sentAny = false;\n let debugOnce = !this._ssDebugDone;\n const CHUNK_SIZE = 60000; // 60KB chunks, under 64KB DataChannel limit\n for (const [pid, peer] of this.peers.entries()) {\n if (debugOnce) {\n log(`sendScreenshot peer=${pid}: state=${peer.state}, hasSsCh=${!!peer.screenshotChannel}, ssActive=${peer.screenshotActive}, chOpen=${peer.screenshotChannel?.isOpen?.() ?? 'N/A'}, bufSize=${buffer.length}`);\n }\n if (peer.state !== 'connected' || !peer.screenshotChannel || !peer.screenshotActive) continue;\n try {\n if (!peer.screenshotChannel.isOpen()) continue;\n // Send header: 4-byte big-endian total length\n const header = Buffer.alloc(4);\n header.writeUInt32BE(buffer.length, 0);\n peer.screenshotChannel.sendMessageBinary(header);\n // Send data in chunks\n for (let offset = 0; offset < buffer.length; offset += CHUNK_SIZE) {\n const chunk = buffer.subarray(offset, Math.min(offset + CHUNK_SIZE, buffer.length));\n peer.screenshotChannel.sendMessageBinary(chunk);\n }\n sentAny = true;\n } catch (e: any) {\n if (debugOnce) log(`sendScreenshot ERROR for peer ${pid}: ${e?.message}`);\n }\n }\n if (debugOnce) this._ssDebugDone = true;\n return sentAny;\n }\n\n // ─── Handler registration ────────────────────────────\n\n onFileRequest(handler: (req: FileRequest) => Promise<FileResponse>): void {\n this.fileRequestHandler = handler;\n }\n\n onInput(handler: (event: InputEvent) => Promise<any>): void {\n this.inputHandler = handler;\n }\n\n onCommand(handler: (commandType: string, data: Record<string, unknown>, id: string) => Promise<{ success: boolean; result?: any; error?: string }>): void {\n this.commandHandler = handler;\n }\n\n onPtyInput(handler: (cliType: string, data: string) => void): void {\n this.ptyInputHandler = handler;\n }\n\n onPtyResize(handler: (cliType: string, cols: number, rows: number) => void): void {\n this.ptyResizeHandler = handler;\n }\n\n // ─── P2P command/input/file handling ────────────────\n\n private async handleP2PCommand(peerId: string, msg: any): Promise<void> {\n const { id, commandType, data } = msg;\n if (!this.commandHandler) {\n this.sendToPeer(peerId, { type: 'command_result', id, success: false, error: 'No handler' });\n return;\n }\n try {\n const result = await this.commandHandler(commandType, data || {}, id);\n this.sendToPeer(peerId, { type: 'command_result', id, ...result });\n } catch (e: any) {\n this.sendToPeer(peerId, { type: 'command_result', id, success: false, error: e?.message });\n }\n }\n\n private async handleInputEvent(peerId: string, msg: any): Promise<void> {\n const { id, action, params } = msg;\n if (!this.inputHandler) {\n this.sendToPeer(peerId, { id, type: 'response', success: false, error: 'No input handler' });\n return;\n }\n try {\n // Include ideType from peer's screenshot session so input goes to correct IDE\n const peer = this.peers.get(peerId);\n const ideType = peer?.screenshotIdeType;\n const result = await this.inputHandler({ action, params, _targetInstance: ideType ? `${ideType}_` : undefined });\n this.sendToPeer(peerId, { id, type: 'response', success: true, result });\n } catch (e: any) {\n this.sendToPeer(peerId, { id, type: 'response', success: false, error: e?.message });\n }\n }\n\n private async handleFileRequest(peerId: string, req: FileRequest): Promise<void> {\n let response: FileResponse;\n if (this.fileRequestHandler) {\n try {\n response = await this.fileRequestHandler(req);\n } catch (e: any) {\n response = { id: req.id, success: false, error: e?.message };\n }\n } else {\n response = { id: req.id, success: false, error: 'No file handler' };\n }\n this.sendToPeer(peerId, response);\n }\n\n private sendToPeer(peerId: string, data: any): void {\n const peer = this.peers.get(peerId);\n if (!peer?.filesChannel) return;\n try { peer.filesChannel.sendMessage(JSON.stringify(data)); } catch { }\n }\n\n // ─── Signaling handling ──────────────────────────\n\n handleSignaling(type: string, payload: any): void {\n const peerId = payload?.peerId;\n\n if (type === 'p2p_ready') {\n log(`p2p_ready from peer ${peerId}`);\n this.initiateconnection(peerId);\n return;\n }\n\n if (type === 'p2p_answer') {\n if (!peerId) {\n log('p2p_answer without peerId — ignoring (multi-peer requires explicit peerId)');\n return;\n }\n const peer = this.peers.get(peerId);\n if (!peer?.pc) {\n log(`p2p_answer for unknown peer ${peerId} — ignoring`);\n return;\n }\n // Only accept answer if we're in the correct signaling state\n const pcState = peer.pc.state();\n if (pcState === 'closed' || pcState === 'failed') {\n log(`p2p_answer ignored: peer ${peerId} PC state is ${pcState}`);\n return;\n }\n try {\n log(`Applying SDP answer for peer ${peerId}`);\n peer.pc.setRemoteDescription(payload.sdp, payload.type);\n peer.remoteDescriptionSet = true;\n // Flush queued ICE candidates\n if (peer.pendingCandidates.length > 0) {\n log(`Flushing ${peer.pendingCandidates.length} queued ICE candidates for peer ${peerId}`);\n for (const c of peer.pendingCandidates) {\n try {\n peer.pc.addRemoteCandidate(c.candidate, c.mid);\n } catch (e: any) {\n log(`Queued ICE candidate error: ${e?.message}`);\n }\n }\n peer.pendingCandidates = [];\n }\n } catch (e: any) {\n log(`p2p_answer setRemoteDescription error for peer ${peerId}: ${e?.message}`);\n }\n return;\n }\n\n if (type === 'p2p_ice') {\n if (!peerId) {\n log('p2p_ice without peerId — ignoring (multi-peer requires explicit peerId)');\n return;\n }\n const peer = this.peers.get(peerId);\n if (peer?.pc && payload.candidate) {\n if (!peer.remoteDescriptionSet) {\n // Queue candidate until remote description is set\n peer.pendingCandidates.push({\n candidate: payload.candidate,\n mid: payload.mid || payload.sdpMid || '0',\n });\n } else {\n try {\n peer.pc.addRemoteCandidate(payload.candidate, payload.mid || payload.sdpMid || '0');\n } catch (e: any) {\n log(`ICE candidate error for peer ${peerId}: ${e?.message}`);\n }\n }\n }\n return;\n }\n }\n\n // getFirstPeer removed — multi-peer requires explicit peerId routing\n\n // ─── connection management ──────────────────────────────\n\n disconnectPeer(peerId: string): void {\n const peer = this.peers.get(peerId);\n if (!peer) return;\n if (peer.failedCleanupTimer) clearTimeout(peer.failedCleanupTimer);\n if (peer.heartbeatTimer) clearInterval(peer.heartbeatTimer);\n if (peer.screenshotChannel) try { peer.screenshotChannel.close(); } catch { }\n if (peer.filesChannel) try { peer.filesChannel.close(); } catch { }\n if (peer.pc) try { peer.pc.close(); } catch { }\n this.peers.delete(peerId);\n this.notifyStateChange();\n log(`Peer ${peerId} disconnected`);\n }\n\n /** P2P keepalive — prevent NAT binding expiration (especially TURN relay) */\n private startHeartbeat(peerId: string): void {\n const peer = this.peers.get(peerId);\n if (!peer) return;\n // Clean up existing heartbeat\n if (peer.heartbeatTimer) clearInterval(peer.heartbeatTimer);\n peer.heartbeatTimer = setInterval(() => {\n const p = this.peers.get(peerId);\n if (!p || p.state !== 'connected') {\n if (p?.heartbeatTimer) clearInterval(p.heartbeatTimer);\n return;\n }\n try {\n if (p.filesChannel?.isOpen()) {\n p.filesChannel.sendMessage(JSON.stringify({ type: 'ping', ts: Date.now() }));\n }\n } catch { }\n }, 15000); // every 15s ping\n }\n\n disconnect(): void {\n for (const peerId of Array.from(this.peers.keys())) {\n this.disconnectPeer(peerId);\n }\n }\n}\n","/**\n * ADHDev Daemon — Unified local hub\n * \n * Roles:\n * 2. Server WS connection (wss://api.adhf.dev) — sole external connection\n * 3. CLI Agent management (PTY) — Gemini, Claude, Codex\n * 4. CDP Manager — IDE DOM parsing, screenshots, agent stream webview\n * 5. Unified status_report — aggregate CDP + CLI data\n */\n\nimport { ServerConnection, ServerMessage } from './server-connection.js';\nimport {\n loadConfig, saveConfig,\n detectIDEs,\n launchWithCdp,\n DaemonCdpManager,\n DevServer,\n DaemonCommandHandler,\n DaemonAgentStreamManager,\n DaemonStatusReporter,\n DaemonCliManager,\n ProviderLoader,\n ProviderInstanceManager,\n IdeProviderInstance,\n DEFAULT_DAEMON_PORT,\n LOG,\n logCommand,\n} from '@adhdev/daemon-core';\nimport { DaemonP2PSender } from './daemon-p2p.js';\nimport * as os from 'os';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as crypto from 'crypto';\nimport chalk from 'chalk';\n\n// Dangerous command patterns\nconst DANGEROUS_PATTERNS = [\n /\\brm\\s+(-[a-z]*f|-[a-z]*r|--force|--recursive)/i,\n /\\bsudo\\b/i,\n /\\bmkfs\\b/i,\n /\\bdd\\s+if=/i,\n /\\b(shutdown|reboot|halt|poweroff)\\b/i,\n /\\bchmod\\s+777/,\n /\\bcurl\\b.*\\|\\s*(sh|bash|zsh)/i,\n /\\bwget\\b.*\\|\\s*(sh|bash|zsh)/i,\n /\\b>\\/dev\\/sd[a-z]/i,\n /\\b:\\/\\)\\s*\\{/,\n];\n\nexport interface AdhdevDaemonOptions {\n /** Local WS server port (default 19222) */\n localPort?: number;\n /** CLI working directory */\n workingDir?: string;\n /** Server URL override */\n serverUrl?: string;\n /** Foreground mode */\n foreground?: boolean;\n /** Dev mode enabled */\n dev?: boolean;\n}\n\nexport class AdhdevDaemon {\n private serverConn: ServerConnection | null = null;\n private cliManager!: DaemonCliManager;\n private cdpManagers = new Map<string, DaemonCdpManager>();\n private cdpDiscoveryTimer: NodeJS.Timeout | null = null;\n private p2p: DaemonP2PSender | null = null;\n private commandHandler: DaemonCommandHandler | null = null;\n private screenshotTimer: NodeJS.Timeout | null = null;\n private providerLoader: ProviderLoader;\n private statusReporter: DaemonStatusReporter | null = null;\n\n private agentStreamManager: DaemonAgentStreamManager | null = null;\n private agentStreamTimer: NodeJS.Timeout | null = null;\n private instanceManager: ProviderInstanceManager;\n private running = false;\n\n private detectedIdes: any[] = [];\n private localPort: number;\n private ideType: string = 'unknown';\n /** UUID instanceId → CDP manager key (ideType) mapping */\n private instanceIdMap = new Map<string, string>();\n\n constructor() {\n this.localPort = 19222;\n this.providerLoader = new ProviderLoader({\n builtinDir: path.join(__dirname, '..', 'providers', '_builtin'),\n });\n this.providerLoader.loadAll();\n\n // Check upstream updates in background (non-blocking daemon start)\n this.providerLoader.fetchLatest().then(({ updated }) => {\n if (updated) {\n this.providerLoader.reload();\n this.providerLoader.registerToDetector();\n console.log('[Daemon] Providers auto-updated from upstream');\n }\n }).catch(() => { /* Keep existing providers on failure */ });\n this.instanceManager = new ProviderInstanceManager();\n this.cliManager = new DaemonCliManager({\n getServerConn: () => this.serverConn,\n getP2p: () => this.p2p,\n onStatusChange: () => this.statusReporter?.onStatusChange(),\n removeAgentTracking: (key) => this.statusReporter?.removeAgentTracking(key),\n getInstanceManager: () => this.instanceManager,\n }, this.providerLoader);\n }\n\n async start(options: AdhdevDaemonOptions = {}): Promise<void> {\n // Install global log interceptor — all console.log also written to file\n try { const { installGlobalInterceptor } = require('./daemon-logger'); installGlobalInterceptor(); } catch { }\n\n this.localPort = options.localPort || DEFAULT_DAEMON_PORT;\n const workingDir = options.workingDir || process.cwd();\n\n // 1. Prevent duplicate execution via PID file\n if (isDaemonRunning()) {\n console.log(chalk.yellow('\\n⚠ ADHDev Daemon is already running.'));\n console.log(chalk.gray(` Stop with: adhdev daemon:stop\\n`));\n return;\n }\n writeDaemonPid(process.pid);\n\n // 2. Load config\n const config = loadConfig();\n if (!config.connectionToken) {\n console.log(chalk.red('\\n✗ No connection token found.'));\n console.log(chalk.gray(' Run `adhdev setup` first.\\n'));\n process.exit(1);\n }\n\n\n // 4. IDE detection\n this.detectedIdes = await detectIDEs();\n\n await this.initCdp();\n\n // 4.7. Initialize CommandHandler\n this.commandHandler = new DaemonCommandHandler({\n cdpManagers: this.cdpManagers,\n ideType: this.ideType,\n adapters: this.cliManager.adapters,\n providerLoader: this.providerLoader,\n instanceIdMap: this.instanceIdMap,\n });\n\n // 4.8. Initialize AgentStreamManager\n this.agentStreamManager = new DaemonAgentStreamManager(\n console.log,\n this.providerLoader,\n );\n // Inject AgentStreamManager into CommandHandler\n this.commandHandler.setAgentStreamManager(this.agentStreamManager);\n\n // Agent stream polling (5s interval) — collect from all CDPs\n // Create timer even without CDP (may be added later via launch_ide)\n this.startAgentStreamPolling();\n\n // 5. Server WS connection\n const machineId = os.hostname().replace(/[^a-zA-Z0-9]/g, '_');\n const machineHash = crypto.createHash('md5').update(os.hostname() + os.homedir()).digest('hex').slice(0, 8);\n const instanceId = `daemon_${machineId}_${machineHash}`;\n\n this.serverConn = new ServerConnection({\n serverUrl: options.serverUrl || config.serverUrl,\n token: config.connectionToken,\n cliInfo: {\n type: 'adhdev-daemon',\n version: '0.2.0',\n platform: os.platform(),\n instanceId,\n },\n });\n\n // CLI session injection is done in startCliSession\n\n // 6.5. Initialize P2P (after serverConn created)\n this.p2p = new DaemonP2PSender(this.serverConn);\n if (this.p2p.isAvailable) {\n console.log(chalk.green(' 🔗 P2P available (node-datachannel)'));\n // P2P input handler → CDP remote action\n this.p2p.onInput(async (event) => {\n if (!this.commandHandler) throw new Error('No command handler');\n return this.commandHandler.handle('cdp_remote_action', event);\n });\n // P2P command handler → DaemonCommandHandler + daemon-level commands\n this.p2p.onCommand(async (cmdType, data, id) => {\n return this.handleP2PCommand(cmdType, data);\n });\n // P2P file handler → DaemonCommandHandler\n this.p2p.onFileRequest(async (req) => {\n if (req.type === 'read') {\n const result = await this.commandHandler!.handle('file_read', { path: req.path });\n return { id: req.id, success: result.success, content: result.content as string, error: result.error as string };\n } else if (req.type === 'write') {\n const result = await this.commandHandler!.handle('file_write', { path: req.path, content: req.content });\n return { id: req.id, success: result.success, error: result.error as string };\n } else {\n const result = await this.commandHandler!.handle('file_list', { path: req.path });\n return { id: req.id, success: result.success, entries: result.files as any, error: result.error as string };\n }\n });\n // P2P PTY input → direct to CLI adapter (no server relay)\n this.p2p.onPtyInput((cliId, data) => {\n // Direct match by adapter key (instanceKey priority)\n const found = this.cliManager.findAdapter(cliId, { instanceKey: cliId });\n if (found && typeof found.adapter.writeRaw === 'function') {\n found.adapter.writeRaw(data);\n }\n });\n // P2P PTY resize → CLI adapter terminal size change\n this.p2p.onPtyResize((cliId, cols, rows) => {\n const found = this.cliManager.findAdapter(cliId, { instanceKey: cliId });\n if (found && typeof found.adapter.resize === 'function') {\n found.adapter.resize(cols, rows);\n }\n });\n // P2P state change → send immediate full status on connected (instant chat display)\n this.p2p.onStateChange((state) => {\n if (state === 'connected') {\n LOG.info('P2P', 'Peer connected → sending immediate full status report');\n this.statusReporter?.sendUnifiedStatusReport().catch(e => LOG.warn('P2P', `Immediate status report failed: ${e?.message}`));\n // Follow-up report after 2s — by then CDP tick will have populated chat titles\n setTimeout(() => {\n this.statusReporter?.sendUnifiedStatusReport().catch(() => {});\n }, 2000);\n }\n });\n // P2P screenshot loop — adaptive FPS + delta detection + TURN-aware quality\n let ssDebugCount = 0;\n let lastScreenshotSize = 0;\n let lastScreenshotHash = 0; // simple FNV hash of first+last 1KB\n let staticFrameCount = 0; // Consecutive identical frame count\n\n // Plan-based screenshotIntervalSeconds enforce\n const planLimits = this.serverConn.getPlanLimits();\n const planMinIntervalMs = (planLimits?.screenshotIntervalSeconds ?? 0) * 1000;\n\n // STUN (direct) vs TURN (relay) quality profile (plan limit applied)\n const PROFILE_DIRECT = {\n minInterval: Math.max(300, planMinIntervalMs),\n maxInterval: Math.max(2000, planMinIntervalMs),\n quality: 25,\n };\n const PROFILE_RELAY = {\n minInterval: Math.max(700, planMinIntervalMs),\n maxInterval: Math.max(3000, planMinIntervalMs),\n quality: 12,\n };\n let currentInterval = PROFILE_DIRECT.maxInterval; // Start: idle state\n const STATIC_THRESHOLD = 3; // N identical frames → idle transition\n\n if (planMinIntervalMs > 0) {\n LOG.info('Screenshot', `Plan limit: min interval ${planMinIntervalMs}ms (${planLimits?.screenshotIntervalSeconds}s)`);\n }\n\n const fnvHash = (buf: Buffer): number => {\n let h = 0x811c9dc5;\n // Hash first 1KB + last 1KB for speed\n const sampleEnd = Math.min(1024, buf.length);\n for (let i = 0; i < sampleEnd; i++) { h ^= buf[i]; h = (h * 0x01000193) >>> 0; }\n if (buf.length > 1024) {\n const start = Math.max(0, buf.length - 1024);\n for (let i = start; i < buf.length; i++) { h ^= buf[i]; h = (h * 0x01000193) >>> 0; }\n }\n return h;\n };\n\n const screenshotTick = async () => {\n if (!this.running) return;\n const active = this.p2p?.screenshotActive;\n const ssIdeType = this.p2p?.screenshotIdeType;\n const cdp = ssIdeType ? this.getCdpFor(ssIdeType) : this.getAnyCdp();\n const isRelay = this.p2p?.isUsingRelay ?? false;\n const profile = isRelay ? PROFILE_RELAY : PROFILE_DIRECT;\n\n if (!active || !cdp) {\n // Not active → slow poll, reset state\n staticFrameCount = 0;\n currentInterval = profile.maxInterval;\n this.screenshotTimer = setTimeout(screenshotTick, currentInterval);\n return;\n }\n ssDebugCount++;\n try {\n const buf = await cdp.captureScreenshot({ quality: profile.quality });\n if (buf) {\n const hash = fnvHash(buf);\n const sizeMatch = buf.length === lastScreenshotSize;\n const hashMatch = hash === lastScreenshotHash;\n\n if (sizeMatch && hashMatch) {\n // Frame unchanged → skip send, slow down\n staticFrameCount++;\n if (staticFrameCount >= STATIC_THRESHOLD) {\n currentInterval = Math.min(currentInterval + 200, profile.maxInterval);\n }\n if (ssDebugCount <= 5 || ssDebugCount % 50 === 0) {\n LOG.debug('Screenshot', `skip (unchanged, static=${staticFrameCount}, interval=${currentInterval}ms, ${isRelay ? 'RELAY' : 'DIRECT'})`);\n }\n } else {\n // Frame changed → send, speed up\n lastScreenshotSize = buf.length;\n lastScreenshotHash = hash;\n staticFrameCount = 0;\n currentInterval = profile.minInterval;\n const sent = this.p2p!.sendScreenshotBuffer(buf);\n if (ssDebugCount <= 3) {\n LOG.debug('Screenshot', `sent: ${buf.length} bytes, delivered=${sent}, interval=${currentInterval}ms, ${isRelay ? 'RELAY' : 'DIRECT'}`);\n }\n }\n } else {\n if (ssDebugCount <= 5) LOG.debug('Screenshot', 'captureScreenshot returned null');\n }\n } catch (e: any) {\n if (ssDebugCount <= 5) LOG.warn('Screenshot', `error: ${e?.message}`);\n }\n this.screenshotTimer = setTimeout(screenshotTick, currentInterval);\n };\n // Start the loop\n this.screenshotTimer = setTimeout(screenshotTick, 1000);\n } else {\n console.log(chalk.gray(' ⚠ P2P unavailable — using server relay'));\n }\n\n // 7. Register server command handlers\n this.registerServerHandlers();\n\n // 8. Server connection state events\n this.serverConn.onStateChange((state) => {\n if (state === 'connected') {\n console.log(chalk.green(' 📡 Connected to ADHDev server'));\n this.statusReporter?.sendUnifiedStatusReport();\n } else if (state === 'disconnected') {\n console.log(chalk.yellow(' ⚠ Server disconnected, will reconnect...'));\n }\n });\n\n // 9. Connect to server\n await this.serverConn.connect();\n\n // 10. Initialize StatusReporter and start reporting\n this.statusReporter = new DaemonStatusReporter({\n serverConn: this.serverConn,\n cdpManagers: this.cdpManagers,\n p2p: this.p2p,\n providerLoader: this.providerLoader,\n adapters: this.cliManager.adapters,\n detectedIdes: this.detectedIdes,\n ideType: this.ideType,\n instanceManager: this.instanceManager,\n });\n this.statusReporter.startReporting();\n\n // Instance Manager: Propagate events as status_event\n this.instanceManager.onEvent((event) => {\n this.statusReporter?.emitStatusEvent(event);\n });\n\n // Instance Manager: Start ticking (IDE readChat etc.)\n this.instanceManager.startTicking(5_000);\n\n // 11. Signal handling\n this.running = true;\n process.on('SIGINT', () => this.stop());\n process.on('SIGTERM', () => this.stop());\n\n // 12. Dev Server (--dev)\n if (options.dev) {\n const devServer = new DevServer({ providerLoader: this.providerLoader, cdpManagers: this.cdpManagers });\n await devServer.start();\n }\n\n // 13. Print banner\n this.printBanner(options, config.serverUrl);\n\n // 13. Keep process running in foreground mode\n if (options.foreground) {\n await new Promise<void>(() => {\n // Intentionally never resolve — wait until SIGINT/SIGTERM\n });\n }\n }\n\n private printBanner(options: AdhdevDaemonOptions, serverUrl: string): void {\n console.log();\n console.log(chalk.bold(' 🌉 ADHDev Daemon'));\n console.log(` ${chalk.bold('Server:')} ${serverUrl}`);\n const cdpStatus = this.cdpManagers.size > 0\n ? `✅ ${[...this.cdpManagers.entries()].map(([k, m]) => `${k}:${m.getPort()}`).join(', ')}`\n : '❌ not connected';\n console.log(` ${chalk.bold('CDP:')} ${cdpStatus}`);\n console.log(` ${chalk.bold('P2P:')} ${this.p2p?.isAvailable ? '✅ available' : '❌ unavailable'}`);\n console.log(` ${chalk.bold('Providers:')} ${this.providerLoader.getAll().length > 0 ? `✅ ${this.providerLoader.getAll().map(p => p.type).join(', ')}` : '❌ not loaded'}`);\n console.log();\n console.log(chalk.gray(' Press Ctrl+C to stop.\\n'));\n }\n\n // ─── Server command handlers ───────────────────────────\n\n private registerServerHandlers(): void {\n if (!this.serverConn) return;\n\n // NOTE: send_chat is handled via directCdpCommands → DaemonCommandHandler\n // CLI adapter chat is handled via handleCommand's 'send_chat' case when _targetType === 'cli'\n\n // Dashboard → command (unified command routing)\n this.serverConn.on('command', async (msg: ServerMessage) => {\n const cmd = (msg.payload as any).command as string;\n const args = (msg.payload as any).args as any;\n await this.handleCommand(msg, cmd, args);\n });\n\n this.serverConn.on('agent_command', async (msg: ServerMessage) => {\n const payload = msg.payload as any;\n await this.handleCommand(msg, payload.action, payload);\n });\n\n this.serverConn.on('resolve_action', async (msg: ServerMessage) => {\n await this.handleCommand(msg, 'resolve_action', msg.payload);\n });\n\n // ─── P2P signaling ───\n for (const sigType of ['p2p_ready', 'p2p_offer', 'p2p_answer', 'p2p_ice'] as const) {\n this.serverConn.on(sigType as any, (msg: ServerMessage) => {\n if (this.p2p) this.p2p.handleSignaling(sigType, msg.payload);\n });\n }\n\n // ─── Chat/screenshot server messages → route to DaemonCommandHandler ───\n const directCdpCommands = [\n 'read_chat', 'send_chat', 'list_chats', 'new_chat',\n 'switch_chat', 'set_mode', 'change_model', 'set_thought_level', 'screenshot',\n 'cdp_eval', 'cdp_screenshot', 'cdp_command_exec', 'cdp_batch',\n 'cdp_remote_action', 'cdp_discover_agents',\n 'file_read', 'file_write', 'file_list', 'file_list_browse',\n 'terminal_exec', 'refresh_scripts',\n // CLI/daemon-local commands (launch, restart, detect, stop)\n 'launch_ide', 'stop_ide', 'restart_ide', 'detect_ides', 'restart_session',\n 'exec_command', 'launch_cli', 'stop_cli',\n // Extension-delegated commands (must be registered to receive WS messages)\n 'vscode_command_exec', 'execute_vscode_command',\n 'get_open_editors', 'open_tab', 'close_tab',\n 'open_folder', 'open_folder_picker', 'open_recent',\n 'get_commands', 'get_recent_workspaces',\n 'open_panel', 'open_file', 'create_terminal', 'close_terminal',\n // Agent stream commands\n 'agent_stream_switch', 'agent_stream_read', 'agent_stream_send',\n 'agent_stream_resolve', 'agent_stream_new', 'agent_stream_list_chats',\n 'agent_stream_switch_session', 'agent_stream_focus',\n // PTY I/O commands (terminal view)\n 'pty_input', 'pty_resize',\n ];\n for (const cmdType of directCdpCommands) {\n this.serverConn.on(cmdType as any, async (msg: ServerMessage) => {\n await this.handleCommand(msg, cmdType, msg.payload);\n });\n }\n }\n\n private async handleCommand(msg: ServerMessage, cmd: string, args: any): Promise<void> {\n LOG.info('Command', `${cmd}${args?._targetInstance ? ` → ${args._targetType}:${(args._targetInstance as string).split('_')[0]}` : ''}`);\n const cmdStart = Date.now();\n const source = (msg as any).ipcWs ? 'ext' : 'ws';\n\n try {\n // vscode API-specific commands → delegate to Extension\n switch (cmd) {\n case 'exec_command': {\n const cmdStr = args?.command;\n if (!cmdStr) throw new Error('Command string required');\n if (DANGEROUS_PATTERNS.some(p => p.test(cmdStr))) {\n logCommand({ ts: new Date().toISOString(), cmd, source, args, success: false, error: 'Blocked', durationMs: Date.now() - cmdStart });\n this.sendResult(msg, false, { error: `Blocked: \"${cmdStr}\"` });\n return;\n }\n const cwd = args?.dir || process.cwd();\n const { exec } = require('child_process');\n exec(cmdStr, { cwd, timeout: 60000 }, (err: any, stdout: string, stderr: string) => {\n if (!this.serverConn) return;\n if (err) this.serverConn.sendMessage('log', { message: `❌ ${err.message}`, level: 'error' });\n else {\n if (stdout) this.serverConn.sendMessage('log', { message: stdout.slice(0, 10000), level: 'info' });\n if (stderr) this.serverConn.sendMessage('log', { message: stderr.slice(0, 5000), level: 'warn' });\n }\n });\n logCommand({ ts: new Date().toISOString(), cmd, source, args, success: true, durationMs: Date.now() - cmdStart });\n this.sendResult(msg, true, { started: true });\n return;\n }\n }\n\n // Execute common daemon command\n const result = await this.executeDaemonCommand(cmd, args);\n\n if (result) {\n logCommand({ ts: new Date().toISOString(), cmd, source, args, success: result.success, durationMs: Date.now() - cmdStart });\n this.sendResult(msg, result.success, result);\n } else if (this.commandHandler) {\n const handlerResult = await this.commandHandler.handle(cmd, args);\n logCommand({ ts: new Date().toISOString(), cmd, source, args, success: handlerResult.success, durationMs: Date.now() - cmdStart });\n this.sendResult(msg, handlerResult.success, handlerResult as any);\n\n // after chat-related commands Quick status sync\n const CHAT_COMMANDS = ['send_chat', 'new_chat', 'switch_chat', 'set_mode', 'change_model', 'agent_stream_send'];\n if (CHAT_COMMANDS.includes(cmd)) {\n setTimeout(() => this.statusReporter?.throttledReport(), 1000);\n setTimeout(() => this.statusReporter?.throttledReport(), 3000);\n }\n } else {\n logCommand({ ts: new Date().toISOString(), cmd, source, args, success: false, error: 'No handler', durationMs: Date.now() - cmdStart });\n this.sendResult(msg, false, { error: `Command handler not initialized: ${cmd}` });\n }\n } catch (e: any) {\n logCommand({ ts: new Date().toISOString(), cmd, source, args, success: false, error: e.message, durationMs: Date.now() - cmdStart });\n console.error(chalk.red(` ✗ Command failed: ${e.message}`));\n this.sendResult(msg, false, { error: e.message });\n }\n }\n\n /** P2P command processing — daemon commands + DaemonCommandHandler */\n private async handleP2PCommand(cmdType: string, data: Record<string, unknown>): Promise<{ success: boolean;[key: string]: unknown }> {\n const cmdStart = Date.now();\n try {\n // P2P-only commands (sensitive data, no server relay)\n switch (cmdType) {\n case 'get_cli_history': {\n const config = loadConfig();\n logCommand({ ts: new Date().toISOString(), cmd: cmdType, source: 'p2p', success: true, durationMs: Date.now() - cmdStart });\n return { success: true, history: config.cliHistory || [] };\n }\n case 'set_machine_nickname': {\n const nickname = (data.nickname as string)?.trim() || null;\n const config = loadConfig();\n config.machineNickname = nickname;\n saveConfig(config);\n logCommand({ ts: new Date().toISOString(), cmd: cmdType, source: 'p2p', args: { nickname }, success: true, durationMs: Date.now() - cmdStart });\n return { success: true, nickname };\n }\n case 'get_command_history': {\n const { getRecentCommands } = require('./daemon-command-log');\n const count = parseInt(data.count as string) || 50;\n const history = getRecentCommands(count);\n return { success: true, history };\n }\n // get_acp_auth / set_acp_auth removed — ADHDev does not manage API keys.\n // Each CLI/ACP tool handles its own auth. ADHDev focuses on install detection + error reporting.\n case 'get_daemon_logs': {\n const count = parseInt(data.lines as string) || 100;\n const minLevel = (data.minLevel as string) || 'info';\n try {\n const { getRecentLogs, LOG_PATH } = require('./daemon-logger');\n // Priority 1: ring buffer (fast and structured)\n const entries = getRecentLogs(count, minLevel);\n if (entries.length > 0) {\n return { success: true, entries, totalBuffered: entries.length };\n }\n // Priority 2: file fallback\n const logFs = require('fs');\n if (logFs.existsSync(LOG_PATH)) {\n const content = logFs.readFileSync(LOG_PATH, 'utf-8');\n const allLines = content.split('\\n');\n const recent = allLines.slice(-count).join('\\n');\n return { success: true, logs: recent, totalLines: allLines.length };\n }\n return { success: true, entries: [], totalBuffered: 0 };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n }\n }\n\n // Common daemon commands\n const result = await this.executeDaemonCommand(cmdType, data);\n if (result) {\n logCommand({ ts: new Date().toISOString(), cmd: cmdType, source: 'p2p', args: data, success: result.success, durationMs: Date.now() - cmdStart });\n return result;\n }\n\n // DaemonCommandHandler\n if (this.commandHandler) {\n const handlerResult = await this.commandHandler.handle(cmdType, data);\n logCommand({ ts: new Date().toISOString(), cmd: cmdType, source: 'p2p', args: data, success: handlerResult.success, durationMs: Date.now() - cmdStart });\n return handlerResult;\n }\n logCommand({ ts: new Date().toISOString(), cmd: cmdType, source: 'p2p', success: false, error: 'Unknown command', durationMs: Date.now() - cmdStart });\n return { success: false, error: `Unknown command: ${cmdType}` };\n } catch (e: any) {\n logCommand({ ts: new Date().toISOString(), cmd: cmdType, source: 'p2p', success: false, error: e.message, durationMs: Date.now() - cmdStart });\n return { success: false, error: e.message };\n }\n }\n\n // ─── Unified Daemon command core ────────────────────────\n\n /**\n * Daemon-level command execution (IDE start/stop/restart, CLI, detect etc.)\n * Called from both server WS and P2P.\n * Returns null = not handled at this level → delegate to CommandHandler\n */\n private async executeDaemonCommand(cmd: string, args: any): Promise<{ success: boolean;[key: string]: unknown } | null> {\n switch (cmd) {\n case 'launch_cli':\n case 'stop_cli':\n case 'agent_command': {\n return this.cliManager.handleCliCommand(cmd, args);\n }\n\n // ─── restart_session: IDE / CLI / ACP unified ───\n case 'restart_session': {\n const targetType = args?.cliType || args?.agentType || args?.ideType;\n if (!targetType) throw new Error('cliType or ideType required');\n\n // Check if IDE (in cdpManagers or provider category is ide)\n const isIde = this.cdpManagers.has(targetType) ||\n this.providerLoader.get(targetType)?.category === 'ide';\n\n if (isIde) {\n // IDE restart: stop → launch\n await this.stopIde(targetType);\n const launchResult = await this.executeDaemonCommand('launch_ide', { ideType: targetType, enableCdp: true });\n return { success: true, restarted: true, ideType: targetType, launch: launchResult };\n }\n\n // CLI/ACP restart: delegate to CliManager\n return this.cliManager.handleCliCommand(cmd, args);\n }\n\n // ─── IDE stop ───\n case 'stop_ide': {\n const ideType = args?.ideType;\n if (!ideType) throw new Error('ideType required');\n await this.stopIde(ideType);\n return { success: true, ideType, stopped: true };\n }\n\n // ─── IDE restart ───\n case 'restart_ide': {\n const ideType = args?.ideType;\n if (!ideType) throw new Error('ideType required');\n await this.stopIde(ideType);\n const launchResult = await this.executeDaemonCommand('launch_ide', { ideType, enableCdp: true });\n return { success: true, ideType, restarted: true, launch: launchResult };\n }\n\n case 'launch_ide': {\n const launchArgs = { ...args, ideId: args?.ideId || args?.ideType };\n const ideKey = launchArgs.ideId;\n LOG.info('LaunchIDE', `target=${ideKey || 'auto'}`);\n const result = await launchWithCdp(launchArgs);\n\n if (result.success && result.port && result.ideId && !this.cdpManagers.has(result.ideId)) {\n console.log(chalk.cyan(`[launch_ide] Connecting CDP for ${result.ideId} on port ${result.port}...`));\n const manager = new DaemonCdpManager(result.port, (msg: string) => {\n console.log(`[CDP:${result.ideId}] ${msg}`);\n });\n const connected = await manager.connect();\n if (connected) {\n // Register Active extension providers for this IDE in CDP manager\n const enabledExtProviders = this.providerLoader.getEnabledExtensionProviders(result.ideId)\n .map(p => ({\n agentType: p.type,\n extensionId: p.extensionId || '',\n extensionIdPattern: p.extensionIdPattern!,\n }));\n manager.setExtensionProviders(enabledExtProviders);\n this.cdpManagers.set(result.ideId, manager);\n console.log(chalk.green(` 🔍 CDP connected: ${result.ideId} (port ${result.port})`));\n console.log(chalk.green(` 📡 CDP: ${this.cdpManagers.size} IDE(s) connected`));\n }\n }\n this.startAgentStreamPolling();\n return { success: result.success, ...result as any };\n }\n case 'detect_ides': {\n this.detectedIdes = await detectIDEs();\n return { success: true, ides: this.detectedIdes };\n }\n }\n\n return null; // Not handled at this level → delegate to CommandHandler\n }\n\n /**\n * IDE stop: CDP disconnect + remove from InstanceManager + clean instanceIdMap\n */\n private async stopIde(ideType: string): Promise<void> {\n // 1. Release CDP manager\n const cdp = this.cdpManagers.get(ideType);\n if (cdp) {\n try { cdp.disconnect(); } catch { /* noop */ }\n this.cdpManagers.delete(ideType);\n LOG.info('StopIDE', `CDP disconnected: ${ideType}`);\n }\n\n // 2. Remove IDE instance from InstanceManager\n const instanceKey = `ide:${ideType}`;\n const ideInstance = this.instanceManager.getInstance(instanceKey) as any;\n if (ideInstance) {\n // Remove IDE and child Extension UUIDs from instanceIdMap\n if (ideInstance.getInstanceId) {\n this.instanceIdMap.delete(ideInstance.getInstanceId());\n }\n if (ideInstance.getExtensionInstances) {\n for (const ext of ideInstance.getExtensionInstances()) {\n if (ext.getInstanceId) this.instanceIdMap.delete(ext.getInstanceId());\n }\n }\n this.instanceManager.removeInstance(instanceKey);\n LOG.info('StopIDE', `Instance removed: ${instanceKey}`);\n }\n\n // 3. Reset AgentStream if linked to this IDE\n if (this._agentStreamCdpIdeType === ideType) {\n this._agentStreamCdpIdeType = null;\n }\n\n // 4. Update status\n this.statusReporter?.onStatusChange();\n console.log(chalk.yellow(` 🛑 IDE stopped: ${ideType}`));\n }\n\n\n private sendResult(msg: ServerMessage, success: boolean, extra?: Record<string, unknown>): void {\n if (!msg.id) return;\n\n // 1. Response from IPC source (Legacy — bridge-extension removed)\n if ((msg as any).ipcWs) {\n // no-op: bridge-extension removed\n }\n\n // 2. Response via server connection\n this.serverConn?.sendMessage('command_result', {\n requestId: msg.id,\n success,\n source: msg.source,\n ...extra,\n });\n }\n\n // ─── Lifecycle ───────────────────────────────\n\n /**\n * Daemon cleanup (release all resources)\n * @param exitProcess If true, exit after cleanup process.exit(0), if false, cleanup only\n */\n async stop(exitProcess = true): Promise<void> {\n if (!this.running) return;\n this.running = false;\n\n console.log(chalk.yellow('\\n Shutting down ADHDev Daemon...'));\n\n // 1. Clear timers first (prevent new tasks)\n if (this.cdpDiscoveryTimer) { clearInterval(this.cdpDiscoveryTimer); this.cdpDiscoveryTimer = null; }\n if (this.screenshotTimer) { clearTimeout(this.screenshotTimer); this.screenshotTimer = null; }\n if (this.agentStreamTimer) { clearInterval(this.agentStreamTimer); this.agentStreamTimer = null; }\n\n // 2. Stop StatusReporter\n if (this.statusReporter) { this.statusReporter.stopReporting(); this.statusReporter = null; }\n\n // 3. Clean up AgentStream (await)\n try {\n const anyCdpStop = this.getAnyCdp();\n if (this.agentStreamManager && anyCdpStop) {\n await this.agentStreamManager.dispose(anyCdpStop);\n }\n } catch (e: any) { console.warn('[AgentStream] Dispose failed:', e?.message); }\n\n // 4. Stop CLIs (await — PTY cleanup)\n try { await this.cliManager.shutdownAll(); } catch { /* noop */ }\n\n // 5. Clean up instances\n try { this.instanceManager.disposeAll(); } catch { /* noop */ }\n\n // 6. Release P2P\n try { this.p2p?.disconnect(); } catch { /* noop */ }\n\n // 7. Release CDP managers\n for (const m of this.cdpManagers.values()) {\n try { m.disconnect(); } catch { /* noop */ }\n }\n this.cdpManagers.clear();\n\n\n // 8. Connect to server Release\n try { this.serverConn?.disconnect(); } catch { /* noop */ }\n\n // 9. Delete PID file\n removeDaemonPid();\n\n console.log(chalk.green(' ✓ ADHDev Daemon stopped.\\n'));\n\n if (exitProcess) {\n process.exit(0);\n }\n }\n\n // ─── CDP management ───────────────────────────────────\n\n /** Return first connected CDP manager */\n private getAnyCdp(): DaemonCdpManager | null {\n for (const m of this.cdpManagers.values()) {\n if (m.isConnected) return m;\n }\n return null;\n }\n\n /** Return CDP manager for specific IDE */\n private getCdpFor(ideType: string): DaemonCdpManager | null {\n return this.cdpManagers.get(ideType.toLowerCase()) || null;\n }\n\n /** Start agent stream polling (idempotent — ignored if already started) */\n private _agentStreamCdpIdeType: string | null = null; // IDE with connected agent\n\n private startAgentStreamPolling(): void {\n if (this.agentStreamTimer) return; // Already running\n this.agentStreamTimer = setInterval(async () => {\n if (!this.agentStreamManager || this.cdpManagers.size === 0) return;\n\n // Every tick, refresh each CDP manager extensionProviders based on config\n // → Config changes from dashboard take effect immediately without restart\n for (const [ideType, cdp] of this.cdpManagers) {\n const enabledExtProviders = this.providerLoader.getEnabledExtensionProviders(ideType)\n .map(p => ({\n agentType: p.type,\n extensionId: p.extensionId || '',\n extensionIdPattern: p.extensionIdPattern!,\n }));\n cdp.setExtensionProviders(enabledExtProviders);\n\n // Dynamically add/remove IDE instance extensions\n const ideInstance = this.instanceManager.getInstance(`ide:${ideType}`) as any;\n if (ideInstance?.getExtensionTypes && ideInstance?.addExtension && ideInstance?.removeExtension) {\n const currentExtTypes = new Set(ideInstance.getExtensionTypes() as string[]);\n const enabledExtTypes = new Set(\n this.providerLoader.getEnabledByCategory('extension', ideType).map((p: any) => p.type)\n );\n\n // Remove disabled extensions\n for (const extType of currentExtTypes) {\n if (!enabledExtTypes.has(extType)) {\n ideInstance.removeExtension(extType);\n LOG.info('AgentStream', `Extension removed: ${extType} (disabled for ${ideType})`);\n }\n }\n\n // Add newly enabled extensions\n for (const extType of enabledExtTypes) {\n if (!currentExtTypes.has(extType)) {\n const extProvider = this.providerLoader.get(extType);\n if (extProvider) {\n const extSettings = this.providerLoader.getSettings(extType);\n ideInstance.addExtension(extProvider, extSettings);\n LOG.info('AgentStream', `Extension added: ${extType} (enabled for ${ideType})`);\n }\n }\n }\n }\n }\n\n // If agent already connected, only operate on that CDP\n if (this._agentStreamCdpIdeType) {\n const cdp = this.cdpManagers.get(this._agentStreamCdpIdeType);\n if (cdp?.isConnected) {\n try {\n await this.agentStreamManager.syncAgentSessions(cdp);\n const streams = await this.agentStreamManager.collectAgentStreams(cdp);\n this.statusReporter?.updateAgentStreams(this._agentStreamCdpIdeType, streams);\n } catch { }\n return;\n }\n // CDP lost — reset\n this._agentStreamCdpIdeType = null;\n }\n\n // Auto-discover: If no activeAgentType, search for agents in each IDE\n if (!this.agentStreamManager.activeAgentType) {\n for (const [ideType, cdp] of this.cdpManagers) {\n if (!cdp.isConnected) continue;\n try {\n const discovered = await cdp.discoverAgentWebviews();\n if (discovered.length > 0) {\n this._agentStreamCdpIdeType = ideType;\n await this.agentStreamManager.switchActiveAgent(cdp, discovered[0].agentType);\n LOG.info('AgentStream', `Auto-activated: ${discovered[0].agentType} (${ideType})`);\n // sync+collect immediately\n await this.agentStreamManager.syncAgentSessions(cdp);\n const streams = await this.agentStreamManager.collectAgentStreams(cdp);\n this.statusReporter?.updateAgentStreams(ideType, streams);\n return;\n }\n } catch { }\n }\n }\n }, 5000);\n }\n\n /**\n * CdpManager initialization common logic — register extension providers, configure ideType, create ProviderInstance\n * @param ideType Provider-based IDE type (e.g., 'antigravity', 'cursor')\n * @param manager Connected CdpManager\n */\n private setupCdpManager(ideType: string, manager: DaemonCdpManager): void {\n // Extension provider Register\n const enabledExtProviders = this.providerLoader.getEnabledExtensionProviders(ideType)\n .map(p => ({\n agentType: p.type,\n extensionId: p.extensionId || '',\n extensionIdPattern: p.extensionIdPattern!,\n }));\n manager.setExtensionProviders(enabledExtProviders);\n\n // Configure first connected IDE as default ideType\n if (this.ideType === 'unknown') {\n this.ideType = ideType;\n }\n\n // IDE ProviderInstance Create\n const ideProvider = this.providerLoader.get(ideType);\n if (ideProvider) {\n // Use managerKey as instanceId (multi-window distinction)\n const managerKey = [...this.cdpManagers.entries()].find(([, m]) => m === manager)?.[0] || ideType;\n const ideInstance = new IdeProviderInstance(ideProvider, managerKey !== ideType ? managerKey : undefined);\n const resolvedSettings = this.providerLoader.getSettings(ideType);\n this.instanceManager.addInstance(`ide:${managerKey}`, ideInstance, {\n cdp: manager,\n serverConn: this.serverConn || undefined,\n settings: resolvedSettings,\n }).then(async () => {\n // UUID → cdpManager key mapping Register\n this.instanceIdMap.set(ideInstance.getInstanceId(), managerKey);\n const extensionProviders = this.providerLoader.getEnabledByCategory('extension', ideType);\n for (const extProvider of extensionProviders) {\n const extSettings = this.providerLoader.getSettings(extProvider.type);\n await ideInstance.addExtension(extProvider, extSettings);\n // Map Extension UUID too (cdp uses parent IDE)\n const extInstances = ideInstance.getExtensionInstances();\n for (const ext of extInstances) {\n this.instanceIdMap.set(ext.getInstanceId(), managerKey);\n }\n }\n }).catch(e => console.warn(`[Instance] Failed to init IDE instance ${managerKey}:`, e?.message));\n }\n }\n\n private async initCdp(): Promise<void> {\n // Per-IDE CDP port — dynamically loaded from provider.js\n const providerCdpMap = this.providerLoader.getCdpPortMap();\n const cdpPortMap: Record<string, number> = {};\n for (const [ide, ports] of Object.entries(providerCdpMap)) {\n cdpPortMap[ide] = ports[0]; // Use primary port\n }\n\n // Sort ports by detected IDE order (running IDEs first)\n const portsToTry: { port: number; ide: string }[] = [];\n for (const ide of this.detectedIdes) {\n const ideKey = ide.id || ide.name?.toLowerCase();\n const port = cdpPortMap[ideKey];\n if (port) portsToTry.push({ port, ide: ideKey });\n }\n // Also add undetected IDE ports (provider-based)\n for (const [ide, port] of Object.entries(cdpPortMap)) {\n if (!portsToTry.find(p => p.port === port)) {\n portsToTry.push({ port, ide });\n }\n }\n\n // enabledIdes filter: if empty array, connect all IDEs\n const enabledIdes = loadConfig().enabledIdes || [];\n const filteredPorts = enabledIdes.length > 0\n ? portsToTry.filter(p => enabledIdes.includes(p.ide))\n : portsToTry;\n\n // Try CDP connect on all ports — per-port multi-window support\n for (const { port, ide } of filteredPorts) {\n // First query all workbench pages on this port\n const allTargets = await DaemonCdpManager.listAllTargets(port);\n\n if (allTargets.length === 0) {\n // If no pages, fallback to existing approach (connect self-discovers)\n const manager = new DaemonCdpManager(port, (msg) => {\n console.log(`[CDP:${ide}] ${msg}`);\n });\n const connected = await manager.connect();\n if (connected) {\n this.cdpManagers.set(ide, manager);\n console.log(chalk.green(` 🔍 CDP connected: ${ide} (port ${port})`));\n this.setupCdpManager(ide, manager);\n }\n continue;\n }\n\n // Create separate CdpManager for each page\n for (let i = 0; i < allTargets.length; i++) {\n const target = allTargets[i];\n // Key: if 1 page use ide type as-is, if 2+ distinguish by workspace name\n let managerKey: string;\n if (allTargets.length === 1) {\n managerKey = ide;\n } else {\n // Extract workspace name from title (e.g. \"remote_vs — index.ts\" → \"remote_vs\")\n const workspaceName = (target.title || '').split(' — ')[0].trim() || `window_${i}`;\n managerKey = `${ide}_${workspaceName}`;\n }\n\n // Skip if already registered\n if (this.cdpManagers.has(managerKey)) continue;\n\n const manager = new DaemonCdpManager(port, (msg) => {\n console.log(`[CDP:${managerKey}] ${msg}`);\n }, target.id);\n\n const connected = await manager.connect();\n if (connected) {\n this.cdpManagers.set(managerKey, manager);\n console.log(chalk.green(` 🔍 CDP connected: ${managerKey} (port ${port}, page \"${target.title}\")`));\n this.setupCdpManager(ide, manager);\n }\n }\n }\n\n if (this.cdpManagers.size > 0) {\n console.log(chalk.green(` 📡 CDP: ${this.cdpManagers.size} IDE(s) connected`));\n } else {\n console.log(chalk.yellow(` ⚠ CDP not available — tried ports: ${portsToTry.map(p => `${p.ide}:${p.port}`).join(', ')}`));\n console.log(chalk.yellow(` IDE may need relaunch with --remote-debugging-port`));\n }\n\n // Periodic agent stream webview search (create timer even without CDP — may be added later)\n this.cdpDiscoveryTimer = setInterval(async () => {\n for (const m of this.cdpManagers.values()) {\n if (m.isConnected) {\n await m.discoverAgentWebviews();\n }\n }\n }, 30000);\n\n // Periodic CDP port scan — auto-detect newly opened IDEs after daemon start\n setInterval(async () => {\n const portMap = this.providerLoader.getCdpPortMap();\n for (const [ide, ports] of Object.entries(portMap)) {\n const primaryPort = ports[0];\n // Skip if manager already connected on this IDE port\n const alreadyConnected = [...this.cdpManagers.entries()].some(([key, m]) =>\n m.isConnected && (key === ide || key.startsWith(ide + '_'))\n );\n if (alreadyConnected) continue;\n\n // Scan for new CDP ports\n const targets = await DaemonCdpManager.listAllTargets(primaryPort);\n if (targets.length === 0) continue;\n\n console.log(chalk.cyan(`[CDP-Scan] Found ${targets.length} page(s) on ${ide}:${primaryPort}`));\n for (let i = 0; i < targets.length; i++) {\n const target = targets[i];\n let managerKey: string;\n if (targets.length === 1) {\n managerKey = ide;\n } else {\n const workspaceName = (target.title || '').split(' — ')[0].trim() || `window_${i}`;\n managerKey = `${ide}_${workspaceName}`;\n }\n if (this.cdpManagers.has(managerKey)) continue;\n\n const manager = new DaemonCdpManager(primaryPort, (msg) => {\n console.log(`[CDP:${managerKey}] ${msg}`);\n }, target.id);\n\n const connected = await manager.connect();\n if (connected) {\n this.cdpManagers.set(managerKey, manager);\n console.log(chalk.green(` 🔍 CDP auto-connected: ${managerKey} (port ${primaryPort}, page \"${target.title}\")`));\n this.setupCdpManager(ide, manager);\n this.startAgentStreamPolling();\n }\n }\n }\n }, 30_000);\n }\n}\n\n// ─── PID management (per-machine, not per-CLI) ──────────\n\nfunction getDaemonPidFile(): string {\n const dir = path.join(os.homedir(), '.adhdev');\n if (!fs.existsSync(dir)) fs.mkdirSync(dir, { recursive: true });\n return path.join(dir, 'daemon.pid');\n}\n\nfunction writeDaemonPid(pid: number): void {\n fs.writeFileSync(getDaemonPidFile(), String(pid), 'utf-8');\n}\n\nfunction removeDaemonPid(): void {\n try { fs.unlinkSync(getDaemonPidFile()); } catch (e) { /* pid file may not exist */ }\n}\n\nexport function isDaemonRunning(): boolean {\n const pidFile = getDaemonPidFile();\n try {\n if (!fs.existsSync(pidFile)) return false;\n const pid = parseInt(fs.readFileSync(pidFile, 'utf-8').trim());\n process.kill(pid, 0);\n return true;\n } catch {\n removeDaemonPid();\n return false;\n }\n}\n\nexport function stopDaemon(): boolean {\n const pidFile = getDaemonPidFile();\n try {\n if (!fs.existsSync(pidFile)) return false;\n const pid = parseInt(fs.readFileSync(pidFile, 'utf-8').trim());\n process.kill(pid, 'SIGTERM');\n removeDaemonPid();\n return true;\n } catch {\n removeDaemonPid();\n return false;\n }\n}\n","// ADHDev CLI entry point (shebang added by tsup)\n\n/**\n * ADHDev CLI — Entry Point\n * \n * Usage:\n * adhdev — Show help\n * adhdev setup — Run the interactive setup wizard\n * adhdev daemon — Start daemon (IDE monitor + agent hub) [MAIN]\n * adhdev launch [ide] — Launch IDE with CDP or start CLI agent\n * adhdev status — Show current setup status\n * adhdev detect — Detect installed IDEs & CLI agents\n * adhdev reset — Reset configuration\n */\n\nimport { Command } from 'commander';\nimport chalk from 'chalk';\nimport { runWizard } from './wizard.js';\nimport {\n detectIDEs,\n detectCLIs,\n loadConfig, resetConfig, isSetupComplete,\n launchWithCdp, getAvailableIdeIds,\n ProviderLoader,\n} from '@adhdev/daemon-core';\nimport { readFileSync } from 'fs';\nimport { join, dirname } from 'path';\n\n// Read version from package.json (works in CJS bundle)\nlet pkgVersion = 'unknown';\ntry {\n // __dirname works in CJS, try multiple possible locations\n const possiblePaths = [\n join(__dirname, '..', 'package.json'),\n join(__dirname, 'package.json'),\n ];\n for (const p of possiblePaths) {\n try {\n const data = JSON.parse(readFileSync(p, 'utf-8'));\n if (data.version) { pkgVersion = data.version; break; }\n } catch { }\n }\n} catch { }\n// Provider builtin path: daemon-cloud/providers/_builtin (submodule)\n// ProviderLoader defaults to daemon-core/providers/_builtin, explicit path needed\nconst BUILTIN_PROVIDERS_DIR = join(dirname(__dirname), 'providers', '_builtin');\n\n// Provider → detector registration (provider.js is sole IDE source without BUILTIN_IDE_DEFINITIONS)\nconst _cliProviderLoader = new ProviderLoader({ builtinDir: BUILTIN_PROVIDERS_DIR, logFn: () => {} });\n_cliProviderLoader.loadAll();\n_cliProviderLoader.registerToDetector();\n\nconst program = new Command();\n\nprogram\n .name('adhdev')\n .description('🌉 ADHDev — Agent Dashboard Hub for your IDE')\n .version(pkgVersion);\n\n// Setup command\nprogram\n .command('setup')\n .description('Run the interactive setup wizard (detect IDEs, login)')\n .option('-f, --force', 'Force re-run setup even if already configured')\n .action(async (options) => {\n await runWizard({ force: options.force });\n });\n\n// Launch command: start IDE with CDP, or launch CLI agent\nprogram\n .command('launch [target]')\n .description('Launch IDE with CDP or start CLI agent (e.g. cursor, gemini, claude)')\n .option('-w, --workspace <path>', 'Workspace/folder to open')\n .option('-n, --new-window', 'Open in a new window')\n .option('-d, --dir <path>', 'Working directory for CLI agent', process.cwd())\n .action(async (targetArg, options) => {\n // CLI agent stream name — dynamically resolved from provider aliases\n const resolvedType = targetArg ? _cliProviderLoader.resolveAlias(targetArg.toLowerCase()) : null;\n const resolvedProvider = resolvedType ? _cliProviderLoader.get(resolvedType) : null;\n const cliType = (resolvedProvider && (resolvedProvider.category === 'cli' || resolvedProvider.category === 'acp'))\n ? resolvedType : null;\n\n // ─── CLI Agent Launch ───\n if (cliType) {\n const workingDir = options.dir || options.workspace || process.cwd();\n const ora = await import('ora');\n const spinner = ora.default(`Launching ${targetArg}...`).start();\n\n try {\n // Check if daemon is running\n const { isDaemonRunning } = await import('./adhdev-daemon.js');\n\n if (isDaemonRunning()) {\n // Send launch_cli command to daemon\n const result = await sendDaemonCommand('launch_cli', {\n cliType,\n dir: require('path').resolve(workingDir),\n });\n spinner.stop();\n\n if (result?.error) {\n console.log(chalk.red(`\\n✗ ${result.error}\\n`));\n process.exit(1);\n }\n\n console.log();\n console.log(chalk.bold(` 🚀 CLI Agent Launched\\n`));\n console.log(` ${chalk.bold('Agent:')} ${targetArg} (${cliType})`);\n console.log(` ${chalk.bold('Dir:')} ${workingDir}`);\n console.log(` ${chalk.bold('Mode:')} via running daemon`);\n console.log();\n console.log(chalk.gray(' Open dashboard: https://app.adhf.dev/dashboard'));\n console.log();\n } else {\n spinner.stop();\n console.log(chalk.yellow(`\\n ⚠ Daemon not running. Starting daemon with ${targetArg}...\\n`));\n\n // Start daemon in foreground\n const { AdhdevDaemon } = await import('./adhdev-daemon.js');\n const daemon = new AdhdevDaemon();\n await daemon.start({\n localPort: 19222,\n foreground: true,\n });\n\n // Start CLI after daemon ready (wait for WS connection)\n setTimeout(async () => {\n try {\n const result = await sendDaemonCommand('launch_cli', {\n cliType,\n dir: require('path').resolve(workingDir),\n });\n if (result?.success) {\n console.log(chalk.green(` ✓ CLI ${targetArg} started`));\n }\n } catch (e: any) {\n console.log(chalk.yellow(` ⚠ CLI auto-start failed: ${e?.message}. Use dashboard to start.`));\n }\n }, 3000);\n }\n } catch (e: any) {\n spinner.stop();\n console.log(chalk.red(`\\n✗ Launch failed: ${e?.message || e}\\n`));\n process.exit(1);\n }\n return;\n }\n\n // ─── IDE Launch (existing logic) ───\n let targetIdeId = targetArg;\n if (!targetIdeId) {\n const ides = await detectIDEs();\n const installed = ides.filter(i => i.installed && i.cliCommand);\n\n if (installed.length === 0) {\n console.log(chalk.red('\\n✗ No supported IDE found.\\n'));\n process.exit(1);\n }\n\n if (installed.length === 1) {\n targetIdeId = installed[0].id;\n } else {\n const inquirer = await import('inquirer');\n const { selectedIde } = await inquirer.default.prompt([\n {\n type: 'list',\n name: 'selectedIde',\n message: 'Which IDE to launch with CDP?',\n choices: installed.map(ide => ({\n name: `${ide.icon} ${ide.displayName}${ide.version ? chalk.gray(` v${ide.version}`) : ''}`,\n value: ide.id,\n })),\n },\n ]);\n targetIdeId = selectedIde;\n }\n }\n\n const ora = await import('ora');\n const spinner = ora.default('Detecting IDE...').start();\n\n try {\n const result = await launchWithCdp({\n ideId: targetIdeId,\n workspace: options.workspace,\n newWindow: options.newWindow,\n });\n\n spinner.stop();\n\n if (!result.success) {\n console.log(chalk.red(`\\n✗ ${result.error}\\n`));\n\n console.log(chalk.gray(' Available IDEs:'));\n const ides = await detectIDEs();\n ides.forEach(ide => {\n if (ide.installed) {\n console.log(` ${chalk.green('✓')} ${ide.icon} ${chalk.bold(ide.id)} — ${ide.displayName}`);\n }\n });\n\n console.log(chalk.gray('\\n Available CLI Agents:'));\n const clis = await detectCLIs(_cliProviderLoader);\n clis.forEach(cli => {\n if (cli.installed) {\n console.log(` ${chalk.green('✓')} ${cli.icon} ${chalk.bold(cli.id)} — ${cli.displayName}`);\n }\n });\n\n console.log(chalk.gray(`\\n Usage: adhdev launch <ide-or-cli>\\n`));\n process.exit(1);\n }\n\n console.log();\n console.log(chalk.bold(' 🚀 IDE Launched with CDP\\n'));\n console.log(` ${chalk.bold('IDE:')} ${result.ideName}`);\n console.log(` ${chalk.bold('CDP:')} ${chalk.cyan(`ws://127.0.0.1:${result.port}`)}`);\n\n switch (result.action) {\n case 'reused':\n console.log(` ${chalk.bold('Action:')} ${chalk.yellow('CDP already active — reusing existing session')}`);\n break;\n case 'restarted':\n console.log(` ${chalk.bold('Action:')} ${chalk.green('✓ Killed existing process → Restarted with CDP')}`);\n break;\n case 'started':\n console.log(` ${chalk.bold('Action:')} ${chalk.green('✓ Started fresh with CDP')}`);\n break;\n }\n\n console.log();\n console.log(chalk.gray(' Daemon will auto-detect and connect via CDP.'));\n console.log(chalk.gray(` Test: curl http://127.0.0.1:${result.port}/json/version\\n`));\n\n } catch (e: any) {\n spinner.stop();\n console.log(chalk.red(`\\n✗ Launch failed: ${e?.message || e}\\n`));\n process.exit(1);\n }\n });\n\n// Status command\nprogram\n .command('status')\n .description('Show current ADHDev setup status')\n .action(async () => {\n const config = loadConfig();\n\n console.log(chalk.bold('\\n🌉 ADHDev Status\\n'));\n\n if (!config.setupCompleted) {\n console.log(chalk.yellow(' Status: Not configured'));\n console.log(chalk.gray(' Run `adhdev setup` to get started.\\n'));\n return;\n }\n\n // Display multiple IDEs\n const ideList = config.configuredIdes?.length\n ? config.configuredIdes\n : config.selectedIde ? [config.selectedIde] : [];\n\n console.log(` ${chalk.bold('Status:')} ${chalk.green('✓ Configured')}`);\n if (ideList.length > 0) {\n // Also check actual install status\n const ides = await detectIDEs();\n console.log(` ${chalk.bold('IDEs:')}`);\n for (const ideId of ideList) {\n const ide = ides.find(i => i.id === ideId);\n if (ide?.installed) {\n const ver = ide.version ? chalk.gray(` v${ide.version}`) : '';\n console.log(` ${chalk.green('✓')} ${ide.icon} ${ide.displayName}${ver}`);\n } else {\n console.log(` ${chalk.yellow('?')} ${ideId}`);\n }\n }\n }\n\n const clis = await detectCLIs(_cliProviderLoader);\n const installedClis = clis.filter(c => c.installed);\n if (installedClis.length > 0) {\n console.log(` ${chalk.bold('CLI Agents:')}`);\n installedClis.forEach(cli => {\n const ver = cli.version ? chalk.gray(` v${cli.version}`) : '';\n console.log(` ${chalk.green('✓')} ${cli.icon} ${cli.displayName}${ver}`);\n });\n }\n\n console.log(` ${chalk.bold('Extensions:')} ${config.installedExtensions.length} installed`);\n config.installedExtensions.forEach((ext) => {\n console.log(chalk.gray(` • ${ext}`));\n });\n console.log(` ${chalk.bold('User:')} ${config.userEmail || chalk.gray('not logged in')}`);\n console.log(` ${chalk.bold('Auto-connect:')} ${config.autoConnect ? chalk.green('enabled') : chalk.gray('disabled')}`);\n console.log(` ${chalk.bold('Server:')} ${config.serverUrl}`);\n console.log(` ${chalk.bold('Setup date:')} ${config.setupDate || 'unknown'}`);\n console.log();\n });\n\n// Detect command\nprogram\n .command('detect')\n .description('Detect installed IDEs on your system')\n .action(async () => {\n console.log(chalk.bold('\\n🔍 Detecting installed IDEs...\\n'));\n\n const ides = await detectIDEs();\n\n ides.forEach((ide) => {\n if (ide.installed) {\n const version = ide.version ? chalk.gray(` v${ide.version}`) : '';\n console.log(` ${chalk.green('✓')} ${ide.icon} ${chalk.bold(ide.displayName)}${version}`);\n if (ide.cliCommand) {\n console.log(chalk.gray(` CLI: ${ide.cliCommand}`));\n }\n if (ide.path) {\n console.log(chalk.gray(` Path: ${ide.path}`));\n }\n } else {\n console.log(` ${chalk.gray('✗')} ${ide.icon} ${chalk.gray(ide.displayName)} — not found`);\n }\n });\n\n console.log(chalk.bold('\\n🔍 Detecting installed CLI Agents...\\n'));\n const clis = await detectCLIs(_cliProviderLoader);\n clis.forEach((cli) => {\n if (cli.installed) {\n const version = cli.version ? chalk.gray(` v${cli.version}`) : '';\n console.log(` ${chalk.green('✓')} ${cli.icon} ${chalk.bold(cli.displayName)}${version}`);\n console.log(chalk.gray(` Path: ${cli.path}`));\n } else {\n console.log(` ${chalk.gray('✗')} ${cli.icon} ${chalk.gray(cli.displayName)} — not found`);\n }\n });\n\n console.log();\n });\n\n// Reset command\nprogram\n .command('reset')\n .description('Reset ADHDev configuration')\n .action(async () => {\n const inquirer = await import('inquirer');\n const { confirm } = await inquirer.default.prompt([\n {\n type: 'confirm',\n name: 'confirm',\n message: 'Are you sure you want to reset ADHDev configuration?',\n default: false,\n },\n ]);\n\n if (confirm) {\n resetConfig();\n console.log(chalk.green('\\n✓ Configuration reset successfully.'));\n console.log(chalk.gray(' Run `adhdev setup` to reconfigure.\\n'));\n }\n });\n\n// ─── Daemon commands (unified hub) ─────────────────────\n\nprogram\n .command('daemon')\n .description('🚀 Start ADHDev Daemon — unified hub for IDE monitoring, agent management, and remote control')\n .option('-p, --port <port>', 'Local WS server port', '19222')\n .option('--server <url>', 'Override server URL for testing')\n .option('--dev', 'Enable Dev Mode — HTTP API on :19280 for script debugging')\n .action(async (options) => {\n const { AdhdevDaemon } = await import('./adhdev-daemon.js');\n const daemon = new AdhdevDaemon();\n await daemon.start({\n localPort: parseInt(options.port) || 19222,\n serverUrl: options.server,\n foreground: true,\n dev: options.dev || false,\n });\n });\n\nprogram\n .command('daemon:status')\n .description('Check ADHDev Daemon status')\n .action(async () => {\n const { isDaemonRunning } = await import('./adhdev-daemon.js');\n if (isDaemonRunning()) {\n console.log(chalk.green(`\\n ✓ ADHDev Daemon is running.\\n`));\n } else {\n console.log(chalk.gray(`\\n ✗ ADHDev Daemon is not running.`));\n console.log(chalk.gray(` Start with: adhdev daemon\\n`));\n }\n });\n\nprogram\n .command('daemon:stop')\n .description('Stop ADHDev Daemon')\n .action(async () => {\n const { stopDaemon } = await import('./adhdev-daemon.js');\n if (stopDaemon()) {\n console.log(chalk.green(`\\n ✓ ADHDev Daemon stopped.\\n`));\n } else {\n console.log(chalk.gray(`\\n ✗ No running daemon found.\\n`));\n }\n });\n\nprogram\n .command('daemon:restart')\n .description('Restart ADHDev Daemon (stop → start)')\n .option('-p, --port <port>', 'Local WS server port', '19222')\n .option('--server <url>', 'Override server URL')\n .option('--dev', 'Enable Dev Mode')\n .action(async (options) => {\n const { stopDaemon, isDaemonRunning } = await import('./adhdev-daemon.js');\n const { spawn } = await import('child_process');\n\n // 1. Stop existing daemon\n if (isDaemonRunning()) {\n console.log(chalk.yellow('\\n Stopping existing daemon...'));\n stopDaemon();\n // Wait for old process to fully exit\n await new Promise(r => setTimeout(r, 2000));\n }\n\n // 2. Spawn new daemon as background process\n console.log(chalk.cyan(' Starting new daemon...'));\n const args = ['daemon', '-p', options.port || '19222'];\n if (options.server) args.push('--server', options.server);\n if (options.dev) args.push('--dev');\n\n const child = spawn(process.execPath, [process.argv[1], ...args], {\n detached: true,\n stdio: 'ignore',\n env: { ...process.env },\n });\n child.unref();\n\n // 3. Verify it started\n await new Promise(r => setTimeout(r, 3000));\n if (isDaemonRunning()) {\n console.log(chalk.green(` ✓ ADHDev Daemon restarted (PID: ${child.pid})\\n`));\n } else {\n console.log(chalk.red(` ✗ Daemon failed to start. Check logs: ~/.adhdev/daemon.log\\n`));\n process.exit(1);\n }\n });\n\nprogram\n .command('daemon:upgrade')\n .description('Upgrade ADHDev to latest version and restart daemon')\n .option('--no-restart', 'Upgrade only, skip daemon restart')\n .action(async (options) => {\n const { isDaemonRunning, stopDaemon } = await import('./adhdev-daemon.js');\n const { execSync, spawn } = await import('child_process');\n const fsMod = await import('fs');\n const pathMod = await import('path');\n\n console.log(chalk.bold('\\n 🔄 ADHDev Upgrade\\n'));\n\n // Detect install method\n const adhdevPath = process.argv[1];\n const realPath = fsMod.realpathSync(adhdevPath);\n const isLinked = realPath.includes('.openclaw') || realPath.includes('/src/');\n const currentVersion = pkgVersion;\n\n console.log(` ${chalk.bold('Current:')} v${currentVersion}`);\n console.log(` ${chalk.bold('Install:')} ${isLinked ? 'npm link (dev)' : 'npm global'}`);\n\n if (isLinked) {\n // Dev: git pull + npm run build + npm link\n const projectRoot = pathMod.resolve(pathMod.dirname(realPath), '..');\n const launcherDir = pathMod.join(projectRoot);\n console.log(` ${chalk.bold('Path:')} ${launcherDir}`);\n console.log(chalk.cyan('\\n Pulling latest...'));\n try {\n // Find the git root (go up until we find .git)\n let gitRoot = launcherDir;\n while (!fsMod.existsSync(pathMod.join(gitRoot, '.git')) && gitRoot !== '/') {\n gitRoot = pathMod.dirname(gitRoot);\n }\n execSync('git pull --rebase', { cwd: gitRoot, stdio: 'inherit' });\n console.log(chalk.cyan('\\n Building...'));\n execSync('npm run build', { cwd: launcherDir, stdio: 'inherit' });\n execSync('npm link', { cwd: launcherDir, stdio: 'inherit' });\n console.log(chalk.green('\\n ✓ Build complete'));\n } catch (e: any) {\n console.log(chalk.red(`\\n ✗ Build failed: ${e?.message}\\n`));\n process.exit(1);\n }\n } else {\n // Production: npm update\n console.log(chalk.cyan('\\n Checking for updates...'));\n try {\n const latest = execSync('npm view adhdev version', { encoding: 'utf-8' }).trim();\n console.log(` ${chalk.bold('Latest:')} v${latest}`);\n\n if (latest === currentVersion) {\n console.log(chalk.green('\\n ✓ Already on latest version.\\n'));\n if (!options.restart) return;\n } else {\n console.log(chalk.cyan(`\\n Upgrading v${currentVersion} → v${latest}...`));\n execSync('npm install -g adhdev@latest', { stdio: 'inherit' });\n console.log(chalk.green('\\n ✓ Upgrade complete'));\n }\n } catch (e: any) {\n console.log(chalk.red(`\\n ✗ Upgrade failed: ${e?.message}\\n`));\n process.exit(1);\n }\n }\n\n // Restart daemon if running\n if (options.restart !== false && isDaemonRunning()) {\n console.log(chalk.yellow('\\n Restarting daemon...'));\n stopDaemon();\n await new Promise(r => setTimeout(r, 2000));\n\n const child = spawn(process.execPath, [process.argv[1], 'daemon', '-p', '19222'], {\n detached: true,\n stdio: 'ignore',\n env: { ...process.env },\n });\n child.unref();\n\n await new Promise(r => setTimeout(r, 3000));\n if (isDaemonRunning()) {\n console.log(chalk.green(` ✓ Daemon restarted with new version\\n`));\n } else {\n console.log(chalk.yellow(` ⚠ Daemon not detected. Start manually: adhdev daemon\\n`));\n }\n } else if (options.restart !== false) {\n console.log(chalk.gray('\\n Daemon was not running. Start with: adhdev daemon\\n'));\n } else {\n console.log(chalk.green('\\n ✓ Upgrade complete (daemon not restarted)\\n'));\n }\n });\n\n// ─── CDP Debug CLI ─────────────────────────────────\n\n/** Send a command to the running daemon via local WS and get the result */\nasync function sendDaemonCommand(cmd: string, args: any = {}, port = 19222): Promise<any> {\n const WebSocket = (await import('ws')).default;\n const { DAEMON_WS_PATH } = await import('@adhdev/daemon-core');\n\n return new Promise((resolve, reject) => {\n const wsUrl = `ws://127.0.0.1:${port}${DAEMON_WS_PATH || '/daemon'}`;\n const ws = new WebSocket(wsUrl);\n const timeout = setTimeout(() => {\n ws.close();\n reject(new Error('Timeout: no response from daemon after 15s'));\n }, 15000);\n\n ws.on('open', () => {\n // Register as a CLI debug client\n ws.send(JSON.stringify({\n type: 'ext:register',\n payload: {\n ideType: 'cli-debug',\n ideVersion: '1.0.0',\n extensionVersion: '1.0.0',\n instanceId: `cli-debug-${Date.now()}`,\n machineId: 'cli',\n },\n }));\n // Small delay to let registration complete\n setTimeout(() => {\n // Daemon expects commands via server relay, but we can use cdp_eval directly\n // by sending a custom message that the handleMessage can process\n ws.send(JSON.stringify({\n type: 'ext:command',\n payload: { command: cmd, args, messageId: `cli-${Date.now()}` },\n }));\n }, 200);\n });\n\n ws.on('message', (data: any) => {\n try {\n const msg = JSON.parse(data.toString());\n // Look for command result\n if (msg.type === 'daemon:command_result' || msg.type === 'command_result') {\n clearTimeout(timeout);\n ws.close();\n resolve(msg.payload?.result || msg.payload || msg);\n }\n } catch { /* ignore non-JSON */ }\n });\n\n ws.on('error', (e: any) => {\n clearTimeout(timeout);\n reject(new Error(`Cannot connect to daemon at port ${port}: ${e.message}\\nIs 'adhdev daemon' running?`));\n });\n\n ws.on('close', () => {\n clearTimeout(timeout);\n });\n });\n}\n\n/** Direct CDP connection for standalone use (no daemon needed) */\nasync function directCdpEval(expression: string, port = 9222): Promise<any> {\n const http = await import('http');\n\n // Find a target\n const targets: any[] = await new Promise((resolve, reject) => {\n http.get(`http://127.0.0.1:${port}/json`, (res) => {\n let data = '';\n res.on('data', (c) => data += c);\n res.on('end', () => { try { resolve(JSON.parse(data)); } catch { reject(new Error('Invalid JSON')); } });\n }).on('error', (e) => reject(new Error(`Cannot reach CDP at port ${port}: ${e.message}`)));\n });\n\n const isNonMain = (title: string) => !title || /extension-output|ADHDev CDP|Debug Console|Output\\s*$|Launchpad/i.test(title);\n const pages = targets.filter((t: any) => (t.type === 'page' || t.type === 'Page') && t.webSocketDebuggerUrl);\n const mainPages = pages.filter((t: any) => !isNonMain(t.title || ''));\n const target = (mainPages.length > 0 ? mainPages[0] : pages[0]) || targets[0];\n if (!target?.webSocketDebuggerUrl) throw new Error('No CDP target found');\n\n const WebSocket = (await import('ws')).default;\n return new Promise((resolve, reject) => {\n const ws = new WebSocket(target.webSocketDebuggerUrl);\n const timeout = setTimeout(() => { ws.close(); reject(new Error('CDP timeout')); }, 15000);\n let id = 1;\n\n ws.on('open', () => {\n const stripped = expression.replace(/\\/\\*[\\s\\S]*?\\*\\//g, '').trimStart();\n const isAsync = stripped.startsWith('(async');\n ws.send(JSON.stringify({\n id: id++,\n method: 'Runtime.evaluate',\n params: { expression, returnByValue: true, awaitPromise: isAsync },\n }));\n });\n\n ws.on('message', (data: any) => {\n const msg = JSON.parse(data.toString());\n if (msg.id) {\n clearTimeout(timeout);\n ws.close();\n if (msg.result?.result?.value !== undefined) {\n resolve(msg.result.result.value);\n } else if (msg.result?.exceptionDetails) {\n reject(new Error(msg.result.exceptionDetails.text));\n } else {\n resolve(msg.result);\n }\n }\n });\n\n ws.on('error', (e: any) => {\n clearTimeout(timeout);\n reject(new Error(`CDP connection failed: ${e.message}`));\n });\n });\n}\n\n// ─── Provider commands (debug + management) ─────────────────\n\nconst provider = program\n .command('provider')\n .description('🔌 Provider management — list, test, reload providers');\n\nprovider\n .command('list')\n .description('List all loaded providers')\n .option('-j, --json', 'Output raw JSON')\n .action(async (options) => {\n try {\n const { ProviderLoader } = await import('@adhdev/daemon-core');\n const loader = new ProviderLoader({ builtinDir: BUILTIN_PROVIDERS_DIR });\n loader.loadAll();\n const providers = loader.getAll();\n\n if (options.json) {\n console.log(JSON.stringify(providers.map(p => ({\n type: p.type, name: p.name, category: p.category,\n scripts: p.scripts ? Object.keys(p.scripts).filter(k => typeof (p.scripts as any)[k] === 'function') : [],\n extensionId: p.extensionId || null,\n inputMethod: p.inputMethod || null,\n })), null, 2));\n return;\n }\n\n console.log(chalk.bold('\\n🔌 ADHDev Providers\\n'));\n\n const categories = ['ide', 'extension', 'cli', 'acp'] as const;\n for (const cat of categories) {\n const catProviders = providers.filter(p => p.category === cat);\n if (catProviders.length === 0) continue;\n\n const icons: Record<string, string> = { ide: '💻', extension: '🧩', cli: '⌨️ ', acp: '🔌' };\n console.log(` ${icons[cat] || ''} ${chalk.bold(cat.toUpperCase())} (${catProviders.length})`);\n\n for (const p of catProviders) {\n const scripts = p.scripts ? Object.keys(p.scripts).filter(k => typeof (p.scripts as any)[k] === 'function') : [];\n console.log(` ${chalk.green('✓')} ${chalk.bold(p.type)} — ${p.name}`);\n console.log(chalk.gray(` scripts: ${scripts.join(', ')}`));\n if (p.extensionId) console.log(chalk.gray(` extensionId: ${p.extensionId}`));\n if (p.inputMethod) console.log(chalk.gray(` inputMethod: ${p.inputMethod}`));\n }\n console.log();\n }\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\n\n// ─── CDP debugging ──────────────────\n\n\nprovider\n .command('reload')\n .description('Hot-reload all providers (requires daemon --dev)')\n .action(async () => {\n try {\n const http = await import('http');\n const result: any = await new Promise((resolve, reject) => {\n const req = http.request({\n hostname: '127.0.0.1', port: 19280,\n path: '/api/providers/reload',\n method: 'POST',\n headers: { 'Content-Type': 'application/json', 'Content-Length': '2' },\n }, (res) => {\n let data = '';\n res.on('data', (c) => data += c);\n res.on('end', () => { try { resolve(JSON.parse(data)); } catch { resolve({ raw: data }); } });\n });\n req.on('error', () => reject(new Error('DevServer not reachable. Run: adhdev daemon --dev')));\n req.write('{}');\n req.end();\n });\n\n if (result.reloaded) {\n console.log(chalk.green(`\\n ✓ Providers reloaded: ${result.providers?.length || 0} loaded\\n`));\n for (const p of (result.providers || [])) {\n console.log(` ${chalk.green('✓')} ${p.type} (${p.category}) — ${p.name}`);\n }\n console.log();\n } else {\n console.log(chalk.red(`\\n ✗ Reload failed: ${result.error || 'unknown'}\\n`));\n }\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\nprovider\n .command('create <type>')\n .description('Scaffold a new provider.js from template')\n .option('-n, --name <name>', 'Display name')\n .option('-c, --category <cat>', 'Category: ide, extension, cli', 'ide')\n .option('--builtin', 'Create in builtin directory (default: ~/.adhdev/providers/)')\n .action(async (type, options) => {\n try {\n const name = options.name || type.split('-').map((s: string) => s[0].toUpperCase() + s.slice(1)).join(' ');\n const category = options.category;\n const location = options.builtin ? 'builtin' : 'user';\n\n const http = await import('http');\n const result: any = await new Promise((resolve, reject) => {\n const postData = JSON.stringify({ type, name, category, location });\n const req = http.request({\n hostname: '127.0.0.1', port: 19280,\n path: '/api/scaffold',\n method: 'POST',\n headers: { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(postData) },\n }, (res) => {\n let data = '';\n res.on('data', (c) => data += c);\n res.on('end', () => { try { resolve(JSON.parse(data)); } catch { resolve({ raw: data }); } });\n });\n req.on('error', () => {\n // Fallback: create locally without DevServer\n reject(new Error('DevServer not reachable'));\n });\n req.write(postData);\n req.end();\n }).catch(async () => {\n // Offline scaffold (no daemon needed)\n const pathMod = await import('path');\n const fsMod = await import('fs');\n const osMod = await import('os');\n\n let targetDir: string;\n if (location === 'builtin') {\n targetDir = pathMod.resolve(__dirname, '../providers/_builtin', category, type);\n } else {\n targetDir = pathMod.join(osMod.homedir(), '.adhdev', 'providers', type);\n }\n const targetFile = pathMod.join(targetDir, 'provider.js');\n if (fsMod.existsSync(targetFile)) {\n return { error: `Provider already exists at ${targetFile}`, path: targetFile };\n }\n\n const isExtension = category === 'extension';\n const template = `/**\n * ${name} — Provider\n */\nmodule.exports = {\n type: '${type}',\n name: '${name}',\n category: '${category}',\n${isExtension ? ` extensionId: 'publisher.${type}',\\n extensionIdPattern: /extensionId=publisher\\\\\\\\.${type}/i,` : ` inputMethod: 'cdp-type-and-send',\\n inputSelector: '[contenteditable=\"true\"]',`}\n\n scripts: {\n readChat() { return \\`(() => { return JSON.stringify({ messages: [], status: 'idle', title: document.title }); })()\\`; },\n sendMessage(text) { return \\`(async () => { return JSON.stringify({ sent: false, needsTypeAndSend: true }); })()\\`; },\n listSessions() { return \\`(async () => { return JSON.stringify([]); })()\\`; },\n },\n};\n`;\n fsMod.mkdirSync(targetDir, { recursive: true });\n fsMod.writeFileSync(targetFile, template, 'utf-8');\n return { created: true, path: targetFile, type, name, category };\n });\n\n if (result.error) {\n console.log(chalk.red(`\\n ✗ ${result.error}\\n`));\n if (result.path) console.log(chalk.gray(` Path: ${result.path}\\n`));\n process.exit(1);\n }\n\n console.log(chalk.green(`\\n ✓ Provider scaffolded!\\n`));\n console.log(` ${chalk.bold('Type:')} ${result.type}`);\n console.log(` ${chalk.bold('Name:')} ${result.name}`);\n console.log(` ${chalk.bold('Category:')} ${result.category}`);\n console.log(` ${chalk.bold('Path:')} ${chalk.cyan(result.path)}`);\n console.log();\n console.log(chalk.gray(' Next steps:'));\n console.log(chalk.gray(` 1. Edit ${result.path}`));\n console.log(chalk.gray(' 2. Run: adhdev provider reload'));\n console.log(chalk.gray(` 3. Test: adhdev provider test ${type}`));\n console.log(chalk.gray(' 4. Open DevConsole: http://127.0.0.1:19280'));\n console.log();\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\nprovider\n .command('run <type> <script>')\n .description('Run a specific provider script (requires daemon --dev)')\n .option('-p, --param <value>', 'Parameter value (for sendMessage, switchSession, etc.)')\n .option('-j, --json', 'Output raw JSON')\n .action(async (type, script, options) => {\n try {\n const http = await import('http');\n const postData = JSON.stringify({\n script,\n params: options.param ? { text: options.param, sessionId: options.param, buttonText: options.param } : {},\n });\n const result: any = await new Promise((resolve, reject) => {\n const req = http.request({\n hostname: '127.0.0.1', port: 19280,\n path: `/api/providers/${type}/script`,\n method: 'POST',\n headers: { 'Content-Type': 'application/json', 'Content-Length': Buffer.byteLength(postData) },\n }, (res) => {\n let data = '';\n res.on('data', (c) => data += c);\n res.on('end', () => { try { resolve(JSON.parse(data)); } catch { resolve({ raw: data }); } });\n });\n req.on('error', () => reject(new Error('DevServer not reachable. Run: adhdev daemon --dev')));\n req.write(postData);\n req.end();\n });\n\n if (options.json) {\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n if (result.error) {\n console.log(chalk.red(`\\n ✗ ${result.error}\\n`));\n if (result.available) console.log(chalk.gray(` Available scripts: ${result.available.join(', ')}\\n`));\n process.exit(1);\n }\n\n console.log(chalk.bold(`\\n▶ ${chalk.cyan(type)} → ${chalk.yellow(script)}\\n`));\n const output = result.result !== undefined ? result.result : result;\n console.log(typeof output === 'string' ? output : JSON.stringify(output, null, 2));\n console.log();\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\nprovider\n .command('source <type>')\n .description('View source code of a provider')\n .action(async (type) => {\n try {\n const http = await import('http');\n const result: any = await new Promise((resolve, reject) => {\n http.get(`http://127.0.0.1:19280/api/providers/${type}/source`, (res) => {\n let data = '';\n res.on('data', (c) => data += c);\n res.on('end', () => { try { resolve(JSON.parse(data)); } catch { resolve({ raw: data }); } });\n }).on('error', () => {\n // Offline: try to read directly\n reject(new Error('Use --offline or start daemon --dev'));\n });\n }).catch(async () => {\n const pathMod = await import('path');\n const fsMod = await import('fs');\n const osMod = await import('os');\n\n const possiblePaths = [\n pathMod.join(osMod.homedir(), '.adhdev', 'providers', type, 'provider.js'),\n pathMod.resolve(__dirname, '../providers/_builtin/ide', type, 'provider.js'),\n pathMod.resolve(__dirname, '../providers/_builtin/extension', type, 'provider.js'),\n ];\n for (const p of possiblePaths) {\n if (fsMod.existsSync(p)) {\n return { type, path: p, source: fsMod.readFileSync(p, 'utf-8') };\n }\n }\n return { error: `Provider '${type}' not found` };\n });\n\n if (result.error) {\n console.log(chalk.red(`\\n ✗ ${result.error}\\n`));\n process.exit(1);\n }\n\n console.log(chalk.bold(`\\n📄 ${type} — ${result.path}\\n`));\n console.log(result.source);\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\nconst cdp = program\n .command('cdp')\n .description('🔍 CDP debugging tools — analyze IDE DOM for script development');\n\ncdp\n .command('debug')\n .description('Analyze IDE AI panel — find inputs, buttons, textareas, iframes')\n .option('-p, --port <port>', 'CDP port (direct mode)', '9222')\n .option('-d, --daemon', 'Use running daemon instead of direct CDP')\n .option('--session <id>', 'Agent webview session ID')\n .option('-j, --json', 'Output raw JSON')\n .action(async (options) => {\n try {\n let result: any;\n if (options.daemon) {\n result = await sendDaemonCommand('cdp_dom_debug', { sessionId: options.session });\n } else {\n // Direct CDP — run the debug expression\n const expression = `(() => {\n const result = { url: location.href, title: document.title, viewport: { w: window.innerWidth, h: window.innerHeight }, inputs: [], textareas: [], editables: [], buttons: [], iframes: [], textboxes: [] };\n document.querySelectorAll('input[type=\"text\"], input:not([type])').forEach((el, i) => { if (i >= 10) return; result.inputs.push({ id: el.id||null, class: (el.className||'').toString().slice(0,150), placeholder: el.getAttribute('placeholder')||null, visible: el.offsetParent!==null, rect: (() => { try { const r=el.getBoundingClientRect(); return {x:Math.round(r.x),y:Math.round(r.y),w:Math.round(r.width),h:Math.round(r.height)}; } catch{return null;} })() }); });\n document.querySelectorAll('textarea').forEach((el, i) => { if (i >= 10) return; result.textareas.push({ id: el.id||null, class: (el.className||'').toString().slice(0,150), placeholder: el.getAttribute('placeholder')||null, rows: el.rows, visible: el.offsetParent!==null }); });\n document.querySelectorAll('[contenteditable=\"true\"]').forEach((el, i) => { if (i >= 10) return; result.editables.push({ tag: el.tagName?.toLowerCase(), id: el.id||null, class: (el.className||'').toString().slice(0,150), role: el.getAttribute('role')||null, text: (el.textContent||'').trim().slice(0,100), visible: el.offsetParent!==null }); });\n document.querySelectorAll('[role=\"textbox\"]').forEach((el, i) => { if (i >= 10) return; result.textboxes.push({ tag: el.tagName?.toLowerCase(), id: el.id||null, class: (el.className||'').toString().slice(0,150), text: (el.textContent||'').trim().slice(0,100), visible: el.offsetParent!==null }); });\n const btnKw = /send|submit|accept|reject|approve|deny|cancel|confirm|run|execute|apply/i;\n document.querySelectorAll('button, [role=\"button\"]').forEach((el, i) => { const text=(el.textContent||el.getAttribute('aria-label')||'').trim(); if(i<30&&(text.length<30||btnKw.test(text))) result.buttons.push({ tag: el.tagName?.toLowerCase(), text: text.slice(0,80), disabled: el.disabled||el.getAttribute('disabled')!==null, visible: el.offsetParent!==null }); });\n document.querySelectorAll('iframe, webview').forEach((el, i) => { if (i >= 20) return; result.iframes.push({ tag: el.tagName?.toLowerCase(), src: el.getAttribute('src')?.slice(0,200)||null, title: el.getAttribute('title')||null }); });\n return JSON.stringify(result);\n })()`;\n const raw = await directCdpEval(expression, parseInt(options.port));\n result = typeof raw === 'string' ? JSON.parse(raw) : raw;\n }\n\n if (options.json) {\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n // Pretty print\n console.log(chalk.bold('\\n🔍 CDP DOM Debug\\n'));\n console.log(` ${chalk.bold('URL:')} ${result.url || 'N/A'}`);\n console.log(` ${chalk.bold('Title:')} ${result.title || 'N/A'}`);\n if (result.viewport) console.log(` ${chalk.bold('Viewport:')} ${result.viewport.w}×${result.viewport.h}`);\n\n const sections = [\n { key: 'inputs', label: '📝 Inputs', fields: ['id', 'placeholder', 'class'] },\n { key: 'textareas', label: '📝 Textareas', fields: ['id', 'placeholder', 'rows'] },\n { key: 'editables', label: '✏️ ContentEditable', fields: ['tag', 'role', 'class', 'text'] },\n { key: 'textboxes', label: '📦 role=\"textbox\"', fields: ['tag', 'class', 'text'] },\n { key: 'buttons', label: '🔘 Buttons', fields: ['text', 'disabled'] },\n { key: 'iframes', label: '🖼 Iframes/Webviews', fields: ['tag', 'src', 'title'] },\n ];\n\n for (const { key, label, fields } of sections) {\n const items = result[key] || [];\n if (items.length === 0) continue;\n console.log(`\\n ${chalk.bold(label)} (${items.length})`);\n for (const item of items) {\n const vis = item.visible === false ? chalk.red(' [hidden]') : '';\n const parts = fields.map(f => item[f] ? `${f}=${chalk.cyan(String(item[f]).slice(0, 60))}` : null).filter(Boolean);\n console.log(` ${chalk.gray('•')} ${parts.join(' ')}${vis}`);\n }\n }\n console.log();\n\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\ncdp\n .command('dump [selector]')\n .description('Dump DOM tree (default: body)')\n .option('-p, --port <port>', 'CDP port (direct mode)', '9222')\n .option('-d, --daemon', 'Use running daemon')\n .option('-f, --format <fmt>', 'Format: html, tree, summary', 'tree')\n .option('--depth <n>', 'Max depth', '6')\n .option('--session <id>', 'Agent webview session ID')\n .option('-o, --output <file>', 'Save to file')\n .action(async (selector, options) => {\n try {\n const sel = selector || 'body';\n const depth = parseInt(options.depth) || 6;\n let result: any;\n\n if (options.daemon) {\n const resp = await sendDaemonCommand('cdp_dom_dump', {\n selector: sel, format: options.format, depth, sessionId: options.session,\n });\n result = resp?.result || resp;\n } else {\n // Direct CDP with tree format\n let expr: string;\n if (options.format === 'tree') {\n expr = `(() => { const root = document.querySelector('${sel.replace(/'/g, \"\\\\'\")}'); if (!root) return 'Not found: ${sel}'; function tree(el, indent, d, maxD) { if (d > maxD) return indent + '...\\\\n'; let line = indent + '<' + (el.tagName?.toLowerCase()||'?'); if (el.id) line += ' #' + el.id; if (el.className && typeof el.className === 'string') { const cls = el.className.trim().split(' ').filter(c=>c).slice(0,3).join('.'); if(cls) line += ' .' + cls; } const role = el.getAttribute?.('role'); if(role) line += ' [role=' + role + ']'; line += '> (' + (el.children?.length||0) + ')\\\\n'; let r = line; if (el.children?.length > 0 && d < maxD) { for (let i = 0; i < Math.min(el.children.length, 30); i++) { r += tree(el.children[i], indent + ' ', d+1, maxD); } if (el.children.length > 30) r += indent + ' ... +' + (el.children.length-30) + ' more\\\\n'; } return r; } return tree(root, '', 0, ${depth}); })()`;\n } else if (options.format === 'summary') {\n expr = `(() => { const root = document.querySelector('${sel.replace(/'/g, \"\\\\'\")}'); if (!root) return JSON.stringify({error:'Not found'}); function s(el, d, maxD) { if (d > maxD) return {tag:'...',note:'max depth'}; const n = {tag:el.tagName?.toLowerCase(),id:el.id||undefined,class:el.className&&typeof el.className==='string'?el.className.split(' ').filter(c=>c).slice(0,5).join(' '):undefined,role:el.getAttribute?.('role')||undefined,childCount:el.children?.length||0}; if (el.children?.length > 0 && d < maxD) { n.children = Array.from(el.children).slice(0,30).map(c=>s(c,d+1,maxD)); } return n; } return JSON.stringify(s(root,0,${depth})); })()`;\n } else {\n expr = `(() => { const root = document.querySelector('${sel.replace(/'/g, \"\\\\'\")}'); if (!root) return 'Not found: ${sel}'; let html = root.outerHTML; if (html.length > 200000) html = html.slice(0, 200000) + '\\\\n<!-- TRUNCATED -->'; return html; })()`;\n }\n result = await directCdpEval(expr, parseInt(options.port));\n if (options.format === 'summary' && typeof result === 'string') {\n try { result = JSON.parse(result); } catch { /* keep */ }\n }\n }\n\n const output = typeof result === 'string' ? result : JSON.stringify(result, null, 2);\n\n if (options.output) {\n const fs = await import('fs');\n fs.writeFileSync(options.output, output, 'utf-8');\n console.log(chalk.green(`\\n ✓ Saved to ${options.output} (${output.length} chars)\\n`));\n } else {\n console.log(output);\n }\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\ncdp\n .command('query <selector>')\n .description('Test a CSS selector — count matches, show elements')\n .option('-p, --port <port>', 'CDP port (direct mode)', '9222')\n .option('-d, --daemon', 'Use running daemon')\n .option('-l, --limit <n>', 'Max results', '10')\n .option('--session <id>', 'Agent webview session ID')\n .option('-j, --json', 'Output raw JSON')\n .action(async (selector, options) => {\n try {\n const limit = parseInt(options.limit) || 10;\n let result: any;\n\n if (options.daemon) {\n result = await sendDaemonCommand('cdp_dom_query', {\n selector, limit, sessionId: options.session,\n });\n } else {\n const expr = `(() => { try { const els = document.querySelectorAll('${selector.replace(/'/g, \"\\\\'\")}'); const results = []; for (let i = 0; i < Math.min(els.length, ${limit}); i++) { const el = els[i]; results.push({ index: i, tag: el.tagName?.toLowerCase(), id: el.id||null, class: el.className&&typeof el.className==='string'?el.className.trim().slice(0,200):null, role: el.getAttribute?.('role')||null, text: (el.textContent||'').trim().slice(0,100), visible: el.offsetParent!==null||el.offsetWidth>0, rect: (()=>{try{const r=el.getBoundingClientRect();return{x:Math.round(r.x),y:Math.round(r.y),w:Math.round(r.width),h:Math.round(r.height)};}catch{return null;}})() }); } return JSON.stringify({ total: els.length, results }); } catch(e) { return JSON.stringify({ error: e.message }); } })()`;\n const raw = await directCdpEval(expr, parseInt(options.port));\n result = typeof raw === 'string' ? JSON.parse(raw) : raw;\n }\n\n if (options.json) {\n console.log(JSON.stringify(result, null, 2));\n return;\n }\n\n const total = result.total || 0;\n console.log(chalk.bold(`\\n🔍 Selector: ${chalk.cyan(selector)}`));\n console.log(` Matches: ${total === 0 ? chalk.red('0') : chalk.green(total)}\\n`);\n\n for (const item of (result.results || [])) {\n const vis = item.visible === false ? chalk.red(' [hidden]') : chalk.green(' [visible]');\n const rect = item.rect ? chalk.gray(` ${item.rect.x},${item.rect.y} ${item.rect.w}×${item.rect.h}`) : '';\n console.log(` ${chalk.yellow(`[${item.index}]`)} <${chalk.bold(item.tag)}>${vis}${rect}`);\n if (item.id) console.log(` id: ${chalk.cyan(item.id)}`);\n if (item.class) console.log(` class: ${chalk.gray(item.class.slice(0, 80))}`);\n if (item.text) console.log(` text: \"${chalk.white(item.text.slice(0, 80))}\"`);\n if (item.role) console.log(` role: ${chalk.magenta(item.role)}`);\n }\n console.log();\n\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\ncdp\n .command('eval <expression>')\n .description('Execute JavaScript expression via CDP')\n .option('-p, --port <port>', 'CDP port', '9222')\n .option('-d, --daemon', 'Use running daemon')\n .action(async (expression, options) => {\n try {\n let result;\n if (options.daemon) {\n const resp = await sendDaemonCommand('cdp_eval', { expression });\n result = resp?.result !== undefined ? resp.result : resp;\n } else {\n result = await directCdpEval(expression, parseInt(options.port));\n }\n const output = typeof result === 'string' ? result : JSON.stringify(result, null, 2);\n console.log(output);\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\ncdp\n .command('screenshot')\n .description('Capture IDE screenshot')\n .option('-p, --port <port>', 'CDP port', '9222')\n .option('-o, --output <file>', 'Output file path', '/tmp/cdp_screenshot.jpg')\n .action(async (options) => {\n try {\n const http = await import('http');\n const targets: any[] = await new Promise((resolve, reject) => {\n http.get(`http://127.0.0.1:${options.port}/json`, (res) => {\n let data = '';\n res.on('data', (c) => data += c);\n res.on('end', () => { try { resolve(JSON.parse(data)); } catch { reject(new Error('Invalid JSON')); } });\n }).on('error', (e) => reject(e));\n });\n\n const isNonMain = (title: string) => !title || /extension-output|ADHDev CDP|Debug Console|Output\\s*$|Launchpad/i.test(title);\n const pages = targets.filter((t: any) => (t.type === 'page' || t.type === 'Page') && t.webSocketDebuggerUrl);\n const mainPages = pages.filter((t: any) => !isNonMain(t.title || ''));\n const target = (mainPages.length > 0 ? mainPages[0] : pages[0]) || targets[0];\n if (!target?.webSocketDebuggerUrl) throw new Error('No CDP target');\n\n const WebSocket = (await import('ws')).default;\n const ws = new WebSocket(target.webSocketDebuggerUrl);\n\n await new Promise<void>((resolve, reject) => {\n ws.on('open', () => {\n ws.send(JSON.stringify({ id: 1, method: 'Page.captureScreenshot', params: { format: 'jpeg', quality: 50 } }));\n });\n ws.on('message', async (data: any) => {\n const msg = JSON.parse(data.toString());\n if (msg.id === 1 && msg.result?.data) {\n const fs = await import('fs');\n fs.writeFileSync(options.output, Buffer.from(msg.result.data, 'base64'));\n console.log(chalk.green(`\\n ✓ Screenshot saved to ${options.output}\\n`));\n ws.close();\n resolve();\n }\n });\n ws.on('error', (e: any) => reject(e));\n });\n } catch (e: any) {\n console.error(chalk.red(`\\n✗ ${e.message}\\n`));\n process.exit(1);\n }\n });\n\n// No args → show help (not setup)\nif (process.argv.length <= 2) {\n program.outputHelp();\n console.log();\n console.log(chalk.gray(' Quick start:'));\n console.log(chalk.gray(' adhdev daemon — Start unified daemon (Required)'));\n console.log(chalk.gray(' adhdev launch cursor — Launch IDE with CDP (e.g. cursor, windsurf)'));\n console.log(chalk.gray(' adhdev launch claude — Launch CLI agent (e.g. gemini, claude)'));\n console.log(chalk.gray(' adhdev setup — First-time setup & configuration'));\n console.log(chalk.gray(' adhdev status — Check current setup'));\n console.log();\n} else {\n program.parseAsync(process.argv).catch((err: any) => {\n console.error(chalk.red(`\\n✗ ${err.message}`));\n process.exit(1);\n });\n}\n\n","/**\n * ADHDev Launcher — Interactive Setup Wizard\n * \n * Two modes:\n * 1. Quick Setup — auto-detect IDE, login, done\n * 2. Custom Setup — choose IDE, choose AI extensions, install, login, done\n */\n\nimport chalk from 'chalk';\nimport inquirer from 'inquirer';\nimport ora from 'ora';\nimport openBrowser from 'open';\nimport {\n detectIDEs, type IDEInfo, ProviderLoader,\n loadConfig, isSetupComplete, markSetupComplete, updateConfig,\n getAIExtensions, installExtensions, launchIDE,\n type InstallerExtensionInfo as ExtensionInfo,\n} from '@adhdev/daemon-core';\nimport { join, dirname } from 'path';\n\n// Provider builtin path: daemon-cloud/providers/_builtin (submodule)\n// During tsup CJS build __dirname = daemon-cloud/dist/\nconst BUILTIN_PROVIDERS_DIR = join(__dirname, '..', 'providers', '_builtin');\n\nconst SERVER_URL = 'https://api.adhf.dev';\n\nconst LOGO = `\n${chalk.cyan('╔══════════════════════════════════════════╗')}\n${chalk.cyan('║')} ${chalk.bold.white('🌉 ADHDev Setup Wizard')} ${chalk.cyan('║')}\n${chalk.cyan('║')} ${chalk.gray('Agent Dashboard Hub for your IDE')} ${chalk.cyan('║')}\n${chalk.cyan('╚══════════════════════════════════════════╝')}\n`;\n\nconst DIVIDER = chalk.gray('─'.repeat(44));\n\n/**\n * Main wizard flow\n */\nexport async function runWizard(options: { force?: boolean } = {}): Promise<void> {\n // Provider → detector registration (provider.js is sole IDE source without BUILTIN_IDE_DEFINITIONS)\n const loader = new ProviderLoader({ builtinDir: BUILTIN_PROVIDERS_DIR, logFn: () => {} });\n loader.loadAll();\n loader.registerToDetector();\n\n console.log(LOGO);\n\n // Check if already set up\n if (isSetupComplete() && !options.force) {\n const config = loadConfig();\n console.log(chalk.green('✓') + ' ADHDev is already set up!');\n // Display multiple IDEs\n const ides = config.configuredIdes?.length\n ? config.configuredIdes.join(', ')\n : config.selectedIde || 'none';\n console.log(chalk.gray(` IDEs: ${ides}`));\n console.log(chalk.gray(` User: ${config.userEmail || 'not logged in'}`));\n console.log(chalk.gray(` Extensions: ${config.installedExtensions.length} installed`));\n console.log();\n\n const { action } = await inquirer.prompt([\n {\n type: 'list',\n name: 'action',\n message: 'What would you like to do?',\n choices: [\n { name: '🚀 Start Daemon (connect IDEs & monitor agents)', value: 'start-daemon' },\n { name: '🔄 Reconfigure (run setup again)', value: 'reconfigure' },\n { name: '🔧 Install/Update CLI (adhdev command)', value: 'install-cli' },\n { name: '🔐 Re-login', value: 'relogin' },\n { name: '❌ Exit', value: 'exit' },\n ],\n },\n ]);\n\n if (action === 'exit') return;\n if (action === 'start-daemon') {\n await startDaemonFlow();\n return;\n }\n if (action === 'relogin') {\n await loginFlow();\n return;\n }\n if (action === 'install-cli') {\n await installCliOnly();\n return;\n }\n // reconfigure falls through to full wizard\n }\n\n // Choose mode\n const { mode } = await inquirer.prompt([\n {\n type: 'list',\n name: 'mode',\n message: 'Setup mode:',\n choices: [\n { name: `🚀 ${chalk.bold('Quick Setup')} — Auto-detect IDEs, login ${chalk.gray('(recommended)')}`, value: 'quick' },\n { name: `⚙️ ${chalk.bold('Custom Setup')} — Choose IDE, AI extensions, and more`, value: 'custom' },\n { name: `🔧 ${chalk.bold('CLI Only')} — Install adhdev command globally`, value: 'cli-only' },\n ],\n },\n ]);\n\n if (mode === 'quick') {\n await quickSetup();\n } else if (mode === 'cli-only') {\n await installCliOnly();\n } else {\n await customSetup();\n }\n}\n\n// ── Quick Setup ──\n\nasync function quickSetup(): Promise<void> {\n console.log(chalk.bold('\\n🚀 Quick Setup\\n'));\n\n // Step 1: Detect ALL IDEs\n const spinner = ora('Detecting installed IDEs...').start();\n const ides = await detectIDEs();\n const installedIDEs = ides.filter(i => i.installed && i.cliCommand);\n spinner.stop();\n\n if (installedIDEs.length === 0) {\n console.log(chalk.red('✗ No supported IDE with CLI found.'));\n console.log(chalk.gray(' Supported: VS Code, Cursor, Antigravity, Windsurf, VSCodium'));\n return;\n }\n\n // Show all detected IDEs\n console.log(chalk.green(`Found ${installedIDEs.length} IDE(s):\\n`));\n installedIDEs.forEach(ide => {\n const version = ide.version ? chalk.gray(` v${ide.version}`) : '';\n console.log(` ${chalk.green('✓')} ${ide.icon} ${chalk.bold(ide.displayName)}${version}`);\n });\n console.log();\n\n // Step 2: Select IDEs (checkbox for multi-select)\n let selectedIDEs: IDEInfo[];\n if (installedIDEs.length === 1) {\n selectedIDEs = installedIDEs;\n console.log(chalk.gray(` Auto-selected: ${installedIDEs[0].displayName}\\n`));\n } else {\n const { selectedIdeIds } = await inquirer.prompt([\n {\n type: 'checkbox',\n name: 'selectedIdeIds',\n message: 'Select IDEs to set up (Space to toggle, Enter to confirm):',\n choices: installedIDEs.map(ide => ({\n name: `${ide.icon} ${ide.displayName}${ide.version ? chalk.gray(` v${ide.version}`) : ''}`,\n value: ide.id,\n checked: true, // All selected by default\n })),\n validate: (input: string[]) => input.length > 0 ? true : 'Select at least one IDE',\n },\n ]);\n selectedIDEs = installedIDEs.filter(i => selectedIdeIds.includes(i.id));\n }\n\n\n // Step 3: Login\n console.log(DIVIDER);\n const loginResult = await loginFlow();\n\n if (!loginResult) {\n console.log(chalk.yellow('⚠ Setup completed without login. You can login later with `adhdev setup`.'));\n }\n\n // Step 4: Inject token into ALL selected IDEs\n if (loginResult?.connectionToken) {\n for (const ide of selectedIDEs) {\n await injectTokenToIDE(ide, loginResult.connectionToken);\n }\n }\n\n // Save config (ALL selected IDEs)\n const ideIds = selectedIDEs.map(i => i.id);\n markSetupComplete(ideIds, ['adhdev']);\n if (loginResult) {\n updateConfig({\n connectionToken: loginResult.connectionToken,\n userEmail: loginResult.email,\n userName: loginResult.name,\n });\n }\n\n // Summary\n console.log(DIVIDER);\n console.log(chalk.bold('\\n🎉 Setup Complete!\\n'));\n if (selectedIDEs.length === 1) {\n console.log(` ${chalk.bold('IDE:')} ${selectedIDEs[0].icon} ${selectedIDEs[0].displayName}`);\n } else {\n console.log(` ${chalk.bold('IDEs:')} ${selectedIDEs.map(i => `${i.icon} ${i.displayName}`).join(', ')}`);\n }\n console.log(` ${chalk.bold('User:')} ${loginResult?.email || 'not logged in'}`);\n console.log(` ${chalk.bold('Status:')} ${chalk.green('Ready to connect')}`);\n console.log();\n\n console.log(chalk.gray(' Commands:'));\n console.log(chalk.gray(' adhdev daemon — Start the main daemon (required for all features)'));\n console.log(chalk.gray(' adhdev launch <ide> — Launch an IDE with remote control (e.g. cursor)'));\n console.log(chalk.gray(' adhdev launch <agent> — Start a CLI agent via daemon (e.g. gemini, claude)'));\n console.log(chalk.gray(' adhdev cdp — Interactive CDP debug console'));\n console.log(chalk.gray(' adhdev status — Check setup status'));\n console.log(chalk.gray(' adhdev setup — Reconfigure ADHDev'));\n console.log();\n\n // Install CLI globally\n await installCliOnly();\n\n // Offer to start daemon\n await startDaemonFlow();\n}\n\n// ── Custom Setup ──\n\nasync function customSetup(): Promise<void> {\n // Step 1: Detect IDEs\n console.log(chalk.bold('\\n📍 Step 1/4 — Detecting installed IDEs...\\n'));\n const spinner = ora('Scanning your system...').start();\n\n const ides = await detectIDEs();\n const installedIDEs = ides.filter(i => i.installed);\n\n spinner.stop();\n\n if (installedIDEs.length === 0) {\n console.log(chalk.yellow('⚠ No supported IDEs found.'));\n return;\n }\n\n console.log(chalk.green(`Found ${installedIDEs.length} IDE(s):\\n`));\n installedIDEs.forEach(ide => {\n const version = ide.version ? chalk.gray(` v${ide.version}`) : '';\n const cli = ide.cliCommand ? chalk.gray(` (CLI: ✓)`) : chalk.yellow(` (CLI: ✗ manual install)`);\n console.log(` ${ide.icon} ${chalk.bold(ide.displayName)}${version}${cli}`);\n });\n console.log();\n\n // Step 2: Select IDE\n console.log(DIVIDER);\n console.log(chalk.bold('\\n📍 Step 2/4 — Select your primary IDE\\n'));\n\n const { selectedIdeId } = await inquirer.prompt([\n {\n type: 'list',\n name: 'selectedIdeId',\n message: 'Which IDE?',\n choices: installedIDEs.map(ide => ({\n name: `${ide.icon} ${ide.displayName}${ide.version ? chalk.gray(` v${ide.version}`) : ''}`,\n value: ide.id,\n })),\n },\n ]);\n\n const selectedIDE = installedIDEs.find(i => i.id === selectedIdeId)!;\n\n // Step 3: Select & install extensions\n console.log(DIVIDER);\n console.log(chalk.bold('\\n📍 Step 3/4 — Choose AI extensions\\n'));\n\n const aiExtensions = getAIExtensions();\n const { selectedExtIds } = await inquirer.prompt([\n {\n type: 'checkbox',\n name: 'selectedExtIds',\n message: 'Select AI extensions:',\n choices: aiExtensions.map(ext => ({\n name: `${ext.icon} ${ext.displayName} — ${chalk.gray(ext.description)}`,\n value: ext.id,\n checked: ext.recommended,\n })),\n },\n ]);\n\n const selectedAIExts = aiExtensions.filter(e => selectedExtIds.includes(e.id));\n const allExtensions = selectedAIExts;\n\n console.log(chalk.bold('\\n📍 Step 4/4 — Installing extensions\\n'));\n\n if (selectedIDE.cliCommand) {\n await installExtensions(\n selectedIDE,\n allExtensions,\n (current, total, ext, result) => {\n const status = result.alreadyInstalled\n ? chalk.blue('already installed')\n : result.success\n ? chalk.green('installed ✓')\n : chalk.red(`failed ✗`);\n console.log(` [${current}/${total}] ${ext.icon} ${ext.displayName} — ${status}`);\n }\n );\n } else {\n console.log(chalk.yellow('⚠ No CLI — install manually:'));\n allExtensions.forEach(ext => {\n console.log(chalk.gray(` ${ext.icon} ${ext.displayName}: ${ext.marketplaceId}`));\n });\n }\n\n // Step 5: Login\n console.log(DIVIDER);\n const loginResult = await loginFlow();\n\n if (loginResult?.connectionToken) {\n await injectTokenToIDE(selectedIDE, loginResult.connectionToken);\n }\n\n markSetupComplete(selectedIdeId, allExtensions.map(e => e.id));\n if (loginResult) {\n updateConfig({\n connectionToken: loginResult.connectionToken,\n userEmail: loginResult.email,\n userName: loginResult.name,\n });\n }\n\n // Summary\n console.log(DIVIDER);\n console.log(chalk.bold('\\n🎉 Setup Complete!\\n'));\n console.log(` ${chalk.bold('IDE:')} ${selectedIDE.icon} ${selectedIDE.displayName}`);\n console.log(` ${chalk.bold('Extensions:')} ${allExtensions.length} installed`);\n console.log(` ${chalk.bold('User:')} ${loginResult?.email || 'not logged in'}`);\n console.log(` ${chalk.bold('Status:')} ${chalk.green('Ready to connect')}`);\n console.log();\n\n // Offer to start daemon\n await startDaemonFlow();\n\n console.log(chalk.gray('\\nThank you for using ADHDev! 🌉\\n'));\n}\n\n// ── Login Flow (CLI Device Flow) ──\n\ninterface LoginResult {\n connectionToken: string;\n email?: string;\n name?: string;\n}\n\nasync function loginFlow(): Promise<LoginResult | null> {\n console.log(chalk.bold('\\n🔐 Login to ADHDev\\n'));\n\n const { wantLogin } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'wantLogin',\n message: 'Sign in to connect IDE to your ADHDev account?',\n default: true,\n },\n ]);\n\n if (!wantLogin) return null;\n\n // Step 1: Init device flow\n const spinner = ora('Generating authentication code...').start();\n let deviceCode: string;\n let userCode: string;\n let verificationUrl: string;\n\n try {\n const res = await fetch(`${SERVER_URL}/auth/cli/init`, { method: 'POST' });\n if (!res.ok) {\n spinner.fail('Failed to connect to server');\n return null;\n }\n const data = await res.json() as {\n deviceCode: string;\n userCode: string;\n verificationUrl: string;\n };\n deviceCode = data.deviceCode;\n userCode = data.userCode;\n verificationUrl = data.verificationUrl;\n spinner.stop();\n } catch (e: any) {\n spinner.fail(`Server error: ${e.message}`);\n return null;\n }\n\n // Step 2: Show code and open browser\n console.log();\n console.log(chalk.cyan(' ┌─────────────────────────────────┐'));\n console.log(chalk.cyan(' │') + ` Your code: ${chalk.bold.white(userCode)} ` + chalk.cyan('│'));\n console.log(chalk.cyan(' └─────────────────────────────────┘'));\n console.log();\n console.log(chalk.gray(` Opening: ${verificationUrl}`));\n console.log();\n\n try {\n await openBrowser(verificationUrl);\n console.log(chalk.green(' ✓ Browser opened — please sign in and approve'));\n } catch {\n console.log(chalk.yellow(` ⚠ Could not open browser. Visit: ${verificationUrl}`));\n }\n\n // Step 3: Poll for completion\n const pollSpinner = ora('Waiting for authentication...').start();\n const startTime = Date.now();\n const timeout = 300_000; // 5 minutes\n\n while (Date.now() - startTime < timeout) {\n await new Promise(r => setTimeout(r, 3000));\n\n try {\n const res = await fetch(`${SERVER_URL}/auth/cli/poll`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify({ deviceCode }),\n });\n\n if (res.status === 410) {\n pollSpinner.fail('Authentication code expired. Please try again.');\n return null;\n }\n\n const data = await res.json() as {\n status: string;\n connectionToken?: string;\n user?: { email?: string; name?: string };\n };\n\n if (data.status === 'completed' && data.connectionToken) {\n pollSpinner.succeed(`Authenticated as ${chalk.bold(data.user?.email || 'user')}`);\n return {\n connectionToken: data.connectionToken,\n email: data.user?.email,\n name: data.user?.name,\n };\n }\n } catch {\n // Network error — retry\n }\n }\n\n pollSpinner.fail('Authentication timed out');\n return null;\n}\n\n// ── Token Injection ──\n\nasync function injectTokenToIDE(ide: IDEInfo, connectionToken: string): Promise<void> {\n if (!ide.cliCommand) return;\n\n try {\n const os = await import('os');\n const fs = await import('fs');\n const path = await import('path');\n const platform = os.platform();\n const home = os.homedir();\n\n // Per-OS settings.json path mapping mapping\n const getSettingsPath = (appName: string): string => {\n if (platform === 'darwin') {\n return path.join(home, 'Library', 'Application Support', appName, 'User', 'settings.json');\n } else if (platform === 'win32') {\n return path.join(process.env.APPDATA || path.join(home, 'AppData', 'Roaming'), appName, 'User', 'settings.json');\n } else {\n // Linux\n return path.join(home, '.config', appName, 'User', 'settings.json');\n }\n };\n\n // Provider-based dynamic mapping\n const loader = new ProviderLoader({ builtinDir: BUILTIN_PROVIDERS_DIR, logFn: () => {} });\n loader.loadAll();\n const appNameMap = loader.getMacAppIdentifiers();\n\n const appName = appNameMap[ide.id];\n if (!appName) return;\n\n const settingsPath = getSettingsPath(appName);\n\n let settings: Record<string, any> = {};\n if (fs.existsSync(settingsPath)) {\n try {\n settings = JSON.parse(fs.readFileSync(settingsPath, 'utf-8'));\n } catch { settings = {}; }\n } else {\n fs.mkdirSync(path.dirname(settingsPath), { recursive: true });\n }\n\n settings['adhdev.connectionToken'] = connectionToken;\n settings['adhdev.autoConnect'] = true;\n\n fs.writeFileSync(settingsPath, JSON.stringify(settings, null, 4), 'utf-8');\n console.log(chalk.green(' ✓ Connection token saved to IDE settings'));\n } catch (e: any) {\n console.log(chalk.yellow(` ⚠ Could not inject token: ${e.message}`));\n console.log(chalk.gray(` You can set it manually: adhdev.connectionToken = ${connectionToken}`));\n }\n}\n\n// ── Start Daemon Flow ──\n\nasync function startDaemonFlow(): Promise<void> {\n const { isDaemonRunning } = await import('./adhdev-daemon.js');\n\n if (isDaemonRunning()) {\n console.log(chalk.green(' ✓ Daemon is already running'));\n console.log(chalk.gray(' Dashboard: https://app.adhf.dev/dashboard\\n'));\n return;\n }\n\n const { startDaemon } = await inquirer.prompt([\n {\n type: 'confirm',\n name: 'startDaemon',\n message: 'Start the ADHDev Daemon now? (Required for all agent/IDE routing features)',\n default: true,\n },\n ]);\n\n if (!startDaemon) {\n console.log(chalk.gray(' Start later: adhdev daemon\\n'));\n return;\n }\n\n const daemonSpinner = ora('Starting daemon...').start();\n\n try {\n const { AdhdevDaemon } = await import('./adhdev-daemon.js');\n const daemon = new AdhdevDaemon();\n\n // Start in background (nohup)\n const { execSync } = await import('child_process');\n const os = await import('os');\n const path = await import('path');\n const logPath = path.join(os.homedir(), '.adhdev', 'daemon.log');\n\n // Start adhdev daemon in background\n try {\n execSync(`nohup adhdev daemon > \"${logPath}\" 2>&1 &`, {\n timeout: 3000,\n stdio: 'ignore',\n });\n } catch {\n // nohup Try direct start on failure\n daemon.start({ localPort: 19222, foreground: false }).catch(() => {});\n }\n\n // Wait briefly then verify\n await new Promise(r => setTimeout(r, 2000));\n\n if (isDaemonRunning()) {\n daemonSpinner.succeed('Daemon started');\n console.log(chalk.gray(' Dashboard: https://app.adhf.dev/dashboard'));\n console.log(chalk.gray(` Logs: ${logPath}`));\n } else {\n daemonSpinner.succeed('Daemon starting in background');\n console.log(chalk.gray(' Dashboard: https://app.adhf.dev/dashboard'));\n console.log(chalk.gray(` Logs: ${logPath}`));\n }\n console.log();\n } catch (e: any) {\n daemonSpinner.fail(`Daemon start failed: ${e?.message || 'Unknown'}`);\n console.log(chalk.gray(' Manual: adhdev daemon\\n'));\n }\n}\n\n// ── Add Extensions Flow ──\n\nasync function addExtensionsFlow(): Promise<void> {\n const config = loadConfig();\n const ides = await detectIDEs();\n const selectedIDE = ides.find(i => i.id === config.selectedIde);\n\n if (!selectedIDE || !selectedIDE.installed) {\n console.log(chalk.yellow('⚠ Previously selected IDE not found.'));\n return;\n }\n\n const aiExtensions = getAIExtensions();\n const notInstalled = aiExtensions.filter(e => !config.installedExtensions.includes(e.id));\n\n if (notInstalled.length === 0) {\n console.log(chalk.green('✓ All extensions already installed!'));\n return;\n }\n\n const { selectedExtIds } = await inquirer.prompt([\n {\n type: 'checkbox',\n name: 'selectedExtIds',\n message: 'Select extensions to install:',\n choices: notInstalled.map(ext => ({\n name: `${ext.icon} ${ext.displayName}`,\n value: ext.id,\n })),\n },\n ]);\n\n if (selectedExtIds.length === 0) return;\n\n const extensions = notInstalled.filter(e => selectedExtIds.includes(e.id));\n await installExtensions(selectedIDE, extensions, (current, total, ext, result) => {\n const status = result.success ? chalk.green('installed ✓') : chalk.red('failed ✗');\n console.log(` [${current}/${total}] ${ext.icon} ${ext.displayName} — ${status}`);\n });\n\n updateConfig({\n installedExtensions: [...config.installedExtensions, ...selectedExtIds],\n });\n\n console.log(chalk.green('\\n✓ Extensions added!'));\n}\n\n// ── CLI Install ──\n\nasync function installCliOnly(): Promise<void> {\n const { execSync: execSyncLocal } = await import('child_process');\n\n // Check current global install status (short timeout)\n let currentVersion: string | null = null;\n try {\n const result = execSyncLocal('npm list -g adhdev --json 2>/dev/null || npm list -g adhdev --json 2>nul', {\n encoding: 'utf-8',\n timeout: 5000,\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n const parsed = JSON.parse(result);\n currentVersion = parsed.dependencies?.adhdev?.version || null;\n } catch { }\n\n // Detect npx environment (auto global install if running via npx)\n const isNpx = process.env.npm_execpath?.includes('npx') ||\n process.argv[1]?.includes('npx') ||\n process.argv[1]?.includes('_npx');\n\n console.log(chalk.bold('\\n🔧 ADHDev CLI\\n'));\n console.log(chalk.gray(' The `adhdev` command lets you:'));\n console.log(chalk.gray(' • Start the main daemon (adhdev daemon)'));\n console.log(chalk.gray(' • Launch IDE with CDP (adhdev launch <ide>)'));\n console.log(chalk.gray(' • Start CLI agents (adhdev launch <agent>)'));\n console.log(chalk.gray(' • CDP Debugging Console (adhdev cdp)'));\n console.log(chalk.gray(' • Check setup status (adhdev status)'));\n console.log();\n\n if (currentVersion) {\n console.log(chalk.green(` ✓ Currently installed: v${currentVersion}`));\n if (!isNpx) {\n const { doUpdate } = await inquirer.prompt([{\n type: 'confirm',\n name: 'doUpdate',\n message: 'Update to latest version?',\n default: true,\n }]);\n if (!doUpdate) return;\n } else {\n console.log(chalk.gray(' Updating to latest...'));\n }\n } else {\n console.log(chalk.yellow(' ✗ Not installed globally'));\n if (!isNpx) {\n const { doInstall } = await inquirer.prompt([{\n type: 'confirm',\n name: 'doInstall',\n message: 'Install adhdev CLI globally? (npm install -g adhdev)',\n default: true,\n }]);\n if (!doInstall) {\n console.log(chalk.gray('\\n You can install later: npm install -g adhdev\\n'));\n return;\n }\n } else {\n console.log(chalk.gray(' Installing globally...'));\n }\n }\n\n const installSpinner = ora('Installing adhdev CLI...').start();\n\n try {\n execSyncLocal('npm install -g adhdev@latest', {\n encoding: 'utf-8',\n timeout: 60000,\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n\n // Verify version after install\n let newVersion = 'latest';\n try {\n newVersion = execSyncLocal('adhdev --version 2>/dev/null || adhdev --version 2>nul', {\n encoding: 'utf-8', timeout: 5000, stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n } catch { }\n\n installSpinner.succeed(`adhdev CLI ${currentVersion ? 'updated' : 'installed'} ✓ (v${newVersion})`);\n console.log(chalk.gray(' Try: adhdev daemon'));\n console.log(chalk.gray(' adhdev status'));\n console.log();\n } catch (e: any) {\n installSpinner.fail('Install failed');\n console.log(chalk.yellow(` Error: ${e?.message?.split('\\n')[0] || 'Unknown'}`));\n\n const osModule = await import('os');\n if (osModule.platform() === 'win32') {\n console.log(chalk.gray(' On Windows, run PowerShell as Administrator'));\n }\n console.log(chalk.gray(' Manual: npm install -g adhdev@latest'));\n console.log();\n }\n}\n"],"mappings":"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","names":["__export","isSetupComplete","loadConfig","markSetupComplete","resetConfig","saveConfig","updateConfig","import_path","import_fs","__esm","DEFAULT_DAEMON_PORT","DaemonAgentStreamManager","DaemonCdpManager","DaemonCliManager","DaemonCommandHandler","DaemonStatusReporter","DevServer","IdeProviderInstance","LOG","ProviderInstanceManager","ProviderLoader","detectCLIs","detectIDEs","getAIExtensions","getAvailableIdeIds","installExtensions","launchIDE","launchWithCdp","logCommand","readChatHistory","module","import_os","import_fs2","os","dirname","import_child_process","__toESM","platform","import_ws","resolve","WebSocket","reject","fs","path","os2","provider","cdp","result","fs2","path2","os3","path3","fs3","stripAnsi","LOG_DIR","getDateStr","currentDate","writeCount","crypto","import_chalk","log","crypto2","dirName","chalk","instanceManager","execSync","http","port","state","spawn","body","WebSocket","platform","pid","import_daemon_core","os","fs","path","crypto","chalk","cdp","import_chalk","import_chalk","import_daemon_core","chalk","inquirer","ora","openBrowser","os","fs","path","platform","appName","isDaemonRunning","AdhdevDaemon","chalk","inquirer","ora","import_daemon_core","import_path","BUILTIN_PROVIDERS_DIR","ora","spinner","isDaemonRunning","chalk","AdhdevDaemon","inquirer","stopDaemon","WebSocket","ProviderLoader","fs"]}
|