@adhdev/daemon-core 0.5.7 → 0.5.16

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/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/config/workspaces.ts","../src/config/config.ts","../src/index.ts","../src/config/workspace-activity.ts","../src/detection/ide-detector.ts","../src/detection/cli-detector.ts","../src/system/host-memory.ts","../src/cdp/manager.ts","../src/logging/logger.ts","../src/cdp/devtools.ts","../src/providers/ide-provider-instance.ts","../src/providers/status-monitor.ts","../src/providers/extension-provider-instance.ts","../src/config/chat-history.ts","../src/cdp/setup.ts","../src/cdp/scanner.ts","../src/cdp/initializer.ts","../src/commands/handler.ts","../src/commands/chat-commands.ts","../src/commands/cdp-commands.ts","../src/commands/stream-commands.ts","../src/commands/workspace-commands.ts","../src/launch.ts","../src/providers/provider-loader.ts","../src/commands/router.ts","../src/logging/command-log.ts","../src/status/reporter.ts","../src/commands/cli-manager.ts","../src/cli-adapters/provider-cli-adapter.ts","../src/providers/cli-provider-instance.ts","../src/providers/acp-provider-instance.ts","../src/providers/contracts.ts","../src/ipc-protocol.ts","../src/agent-stream/provider-adapter.ts","../src/agent-stream/manager.ts","../src/agent-stream/poller.ts","../src/providers/provider-instance-manager.ts","../src/providers/version-archive.ts","../src/daemon/dev-server.ts","../src/daemon/scaffold-template.ts","../src/installer.ts","../src/boot/daemon-lifecycle.ts"],"sourcesContent":["/**\n * Saved workspaces — shared by IDE launch, CLI, ACP (daemon-local).\n */\n\nimport * as fs from 'fs';\nimport * as os from 'os';\nimport * as path from 'path';\nimport { randomUUID } from 'crypto';\nimport type { ADHDevConfig } from './config.js';\n\nexport interface WorkspaceEntry {\n id: string;\n path: string;\n label?: string;\n addedAt: number;\n}\n\nconst MAX_WORKSPACES = 50;\n\nexport function expandPath(p: string): string {\n const t = (p || '').trim();\n if (!t) return '';\n if (t.startsWith('~')) return path.join(os.homedir(), t.slice(1).replace(/^\\//, ''));\n return path.resolve(t);\n}\n\nexport function validateWorkspacePath(absPath: string): { ok: true } | { ok: false; error: string } {\n try {\n if (!absPath) return { ok: false, error: 'Path required' };\n if (!fs.existsSync(absPath)) return { ok: false, error: 'Path does not exist' };\n const st = fs.statSync(absPath);\n if (!st.isDirectory()) return { ok: false, error: 'Not a directory' };\n return { ok: true };\n } catch (e: any) {\n return { ok: false, error: e?.message || 'Invalid path' };\n }\n}\n\n/** Default workspace label from path */\nexport function defaultWorkspaceLabel(absPath: string): string {\n const base = path.basename(absPath) || absPath;\n return base;\n}\n\n/**\n * Ensure config.workspaces exists; seed from recentCliWorkspaces once (same paths).\n */\nexport function migrateWorkspacesFromRecent(config: ADHDevConfig): ADHDevConfig {\n if (!config.workspaces) config.workspaces = [];\n if (config.workspaces.length > 0) return config;\n\n const recent = config.recentCliWorkspaces || [];\n const now = Date.now();\n for (const raw of recent) {\n const abs = expandPath(raw);\n if (!abs || validateWorkspacePath(abs).ok !== true) continue;\n if (config.workspaces.some(w => path.resolve(w.path) === abs)) continue;\n config.workspaces.push({\n id: randomUUID(),\n path: abs,\n label: defaultWorkspaceLabel(abs),\n addedAt: now,\n });\n if (config.workspaces.length >= MAX_WORKSPACES) break;\n }\n return config;\n}\n\nexport function getDefaultWorkspacePath(config: ADHDevConfig): string | null {\n const id = config.defaultWorkspaceId;\n if (!id) return null;\n const w = (config.workspaces || []).find(x => x.id === id);\n if (!w) return null;\n const abs = expandPath(w.path);\n if (validateWorkspacePath(abs).ok !== true) return null;\n return abs;\n}\n\nexport function getWorkspaceState(config: ADHDevConfig): {\n workspaces: WorkspaceEntry[];\n defaultWorkspaceId: string | null;\n defaultWorkspacePath: string | null;\n} {\n const workspaces = [...(config.workspaces || [])].sort((a, b) => b.addedAt - a.addedAt);\n const defaultWorkspacePath = getDefaultWorkspacePath(config);\n return {\n workspaces,\n defaultWorkspaceId: config.defaultWorkspaceId ?? null,\n defaultWorkspacePath,\n };\n}\n\nexport type LaunchDirectorySource = 'dir' | 'workspaceId' | 'defaultWorkspace' | 'home';\n\nexport type ResolveLaunchDirectoryResult =\n | { ok: true; path: string; source: LaunchDirectorySource }\n | { ok: false; code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED'; message: string };\n\n/**\n * Resolve cwd for CLI/ACP. No implicit default workspace or home — caller must pass\n * useDefaultWorkspace or useHome (or an explicit dir / workspaceId).\n */\nexport function resolveLaunchDirectory(\n args: {\n dir?: string;\n workspaceId?: string;\n useDefaultWorkspace?: boolean;\n useHome?: boolean;\n } | undefined,\n config: ADHDevConfig,\n): ResolveLaunchDirectoryResult {\n const a = args || {};\n if (a.dir != null && String(a.dir).trim()) {\n const abs = expandPath(String(a.dir).trim());\n if (abs && validateWorkspacePath(abs).ok === true) {\n return { ok: true, path: abs, source: 'dir' };\n }\n return {\n ok: false,\n code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED',\n message: abs ? 'Directory path is not valid or does not exist' : 'Invalid directory path',\n };\n }\n if (a.workspaceId) {\n const w = (config.workspaces || []).find(x => x.id === a.workspaceId);\n if (w) {\n const abs = expandPath(w.path);\n if (validateWorkspacePath(abs).ok === true) {\n return { ok: true, path: abs, source: 'workspaceId' };\n }\n }\n return {\n ok: false,\n code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED',\n message: 'Saved workspace not found or path is no longer valid',\n };\n }\n if (a.useDefaultWorkspace === true) {\n const d = getDefaultWorkspacePath(config);\n if (d) return { ok: true, path: d, source: 'defaultWorkspace' };\n return {\n ok: false,\n code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED',\n message: 'No default workspace is set',\n };\n }\n if (a.useHome === true) {\n return { ok: true, path: os.homedir(), source: 'home' };\n }\n return {\n ok: false,\n code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED',\n message: 'Choose a directory, saved workspace, default workspace, or home before launching.',\n };\n}\n\n/**\n * IDE folder from explicit args only (`workspace`, `workspaceId`, or `useDefaultWorkspace: true`).\n */\nexport function resolveIdeWorkspaceFromArgs(\n args: {\n workspace?: string;\n workspaceId?: string;\n useDefaultWorkspace?: boolean;\n } | undefined,\n config: ADHDevConfig,\n): string | undefined {\n const ar = args || {};\n if (ar.workspace) {\n const abs = expandPath(ar.workspace);\n if (abs && validateWorkspacePath(abs).ok === true) return abs;\n }\n if (ar.workspaceId) {\n const w = (config.workspaces || []).find(x => x.id === ar.workspaceId);\n if (w) {\n const abs = expandPath(w.path);\n if (validateWorkspacePath(abs).ok === true) return abs;\n }\n }\n if (ar.useDefaultWorkspace === true) {\n return getDefaultWorkspacePath(config) || undefined;\n }\n return undefined;\n}\n\n/**\n * IDE launch folder — same saved workspaces + default as CLI/ACP.\n * After explicit `workspace` / `workspaceId` / `useDefaultWorkspace: true`, falls back to\n * config default workspace when set. Pass `useDefaultWorkspace: false` to open IDE without that folder.\n */\nexport function resolveIdeLaunchWorkspace(\n args: {\n workspace?: string;\n workspaceId?: string;\n useDefaultWorkspace?: boolean;\n } | undefined,\n config: ADHDevConfig,\n): string | undefined {\n const direct = resolveIdeWorkspaceFromArgs(args, config);\n if (direct) return direct;\n if (args?.useDefaultWorkspace === false) return undefined;\n return getDefaultWorkspacePath(config) || undefined;\n}\n\nexport function findWorkspaceByPath(config: ADHDevConfig, rawPath: string): WorkspaceEntry | undefined {\n const abs = path.resolve(expandPath(rawPath));\n if (!abs) return undefined;\n return (config.workspaces || []).find(w => path.resolve(expandPath(w.path)) === abs);\n}\n\nexport function addWorkspaceEntry(config: ADHDevConfig, rawPath: string, label?: string): { config: ADHDevConfig; entry: WorkspaceEntry } | { error: string } {\n const abs = expandPath(rawPath);\n const v = validateWorkspacePath(abs);\n if (!v.ok) return { error: v.error };\n\n const list = [...(config.workspaces || [])];\n if (list.some(w => path.resolve(w.path) === abs)) {\n return { error: 'Workspace already in list' };\n }\n if (list.length >= MAX_WORKSPACES) {\n return { error: `Maximum ${MAX_WORKSPACES} workspaces` };\n }\n const entry: WorkspaceEntry = {\n id: randomUUID(),\n path: abs,\n label: (label || '').trim() || defaultWorkspaceLabel(abs),\n addedAt: Date.now(),\n };\n list.push(entry);\n return { config: { ...config, workspaces: list }, entry };\n}\n\nexport function removeWorkspaceEntry(config: ADHDevConfig, id: string): { config: ADHDevConfig } | { error: string } {\n const list = (config.workspaces || []).filter(w => w.id !== id);\n if (list.length === (config.workspaces || []).length) return { error: 'Workspace not found' };\n let defaultWorkspaceId = config.defaultWorkspaceId;\n if (defaultWorkspaceId === id) defaultWorkspaceId = null;\n return { config: { ...config, workspaces: list, defaultWorkspaceId } };\n}\n\nexport function setDefaultWorkspaceId(config: ADHDevConfig, id: string | null): { config: ADHDevConfig } | { error: string } {\n if (id === null) {\n return { config: { ...config, defaultWorkspaceId: null } };\n }\n const w = (config.workspaces || []).find(x => x.id === id);\n if (!w) return { error: 'Workspace not found' };\n const abs = expandPath(w.path);\n if (validateWorkspacePath(abs).ok !== true) return { error: 'Workspace path is no longer valid' };\n return { config: { ...config, defaultWorkspaceId: id } };\n}\n","/**\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';\nimport { migrateWorkspacesFromRecent } from './workspaces.js';\nimport type { WorkspaceEntry } from './workspaces.js';\nimport type { WorkspaceActivityEntry } from './workspace-activity.js';\nexport type { WorkspaceEntry } from './workspaces.js';\nexport type { WorkspaceActivityEntry } from './workspace-activity.js';\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 /** Saved workspaces for IDE/CLI/ACP launch (daemon-local) */\n workspaces?: WorkspaceEntry[];\n /** Default workspace id (from workspaces[]) — never used implicitly for launch */\n defaultWorkspaceId?: string | null;\n\n /** Recently used workspaces (IDE / CLI / ACP / default) for quick resume */\n recentWorkspaceActivity?: WorkspaceActivityEntry[];\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 workspaces: [],\n defaultWorkspaceId: null,\n recentWorkspaceActivity: [],\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 const merged = { ...DEFAULT_CONFIG, ...parsed } as ADHDevConfig & { activeWorkspaceId?: string | null };\n if (merged.defaultWorkspaceId == null && merged.activeWorkspaceId != null) {\n (merged as ADHDevConfig).defaultWorkspaceId = merged.activeWorkspaceId;\n }\n delete (merged as any).activeWorkspaceId;\n const hadStoredWorkspaces = Array.isArray(parsed.workspaces) && parsed.workspaces.length > 0;\n migrateWorkspacesFromRecent(merged);\n if (!hadStoredWorkspaces && (merged.workspaces?.length || 0) > 0) {\n try {\n saveConfig(merged);\n } catch { /* ignore */ }\n }\n return merged;\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/config.js';\nexport { getWorkspaceState } from './config/workspaces.js';\nexport { getWorkspaceActivity } from './config/workspace-activity.js';\nexport type { WorkspaceEntry } from './config/workspaces.js';\n\n// ── Detection ──\nexport { detectIDEs } from './detection/ide-detector.js';\nexport type { IDEInfo } from './detection/ide-detector.js';\nexport { detectCLIs } from './detection/cli-detector.js';\nexport { getHostMemorySnapshot } from './system/host-memory.js';\nexport type { HostMemorySnapshot } from './system/host-memory.js';\n\n// ── CDP ──\nexport { DaemonCdpManager } from './cdp/manager.js';\nexport { CdpDomHandlers } from './cdp/devtools.js';\nexport { setupIdeInstance, registerExtensionProviders, connectCdpManager, probeCdpPort } from './cdp/setup.js';\nexport type { CdpSetupContext, SetupIdeInstanceOptions } from './cdp/setup.js';\nexport { DaemonCdpScanner } from './cdp/scanner.js';\nexport type { CdpScannerOptions } from './cdp/scanner.js';\nexport { DaemonCdpInitializer } from './cdp/initializer.js';\nexport type { CdpInitializerConfig } from './cdp/initializer.js';\n\n// ── Commands ──\nexport { DaemonCommandHandler } from './commands/handler.js';\nexport type { CommandResult, CommandContext } from './commands/handler.js';\nexport { DaemonCommandRouter } from './commands/router.js';\nexport type { CommandRouterDeps, CommandRouterResult } from './commands/router.js';\n\n// ── Status ──\nexport { DaemonStatusReporter } from './status/reporter.js';\n\n// ── Logger ──\nexport { LOG, installGlobalInterceptor, setLogLevel, getLogLevel, getRecentLogs } from './logging/logger.js';\nexport type { ScopedLogger, LogLevel, LogEntry } from './logging/logger.js';\nexport { logCommand, getRecentCommands } from './logging/command-log.js';\n\n// ── CLI Management ──\nexport { DaemonCliManager } from './commands/cli-manager.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 './config/chat-history.js';\n\n// ── Agent Stream ──\nexport { DaemonAgentStreamManager } from './agent-stream/index.js';\nexport { AgentStreamPoller } from './agent-stream/index.js';\nexport type { AgentStreamPollerDeps } 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, CdpTargetFilter } from './providers/contracts.js';\nexport { VersionArchive, detectAllVersions } from './providers/version-archive.js';\nexport type { ProviderVersionInfo, VersionHistory } from './providers/version-archive.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// ── Boot / Lifecycle ──\nexport { initDaemonComponents, shutdownDaemonComponents } from './boot/daemon-lifecycle.js';\nexport type { DaemonInitConfig, DaemonComponents } from './boot/daemon-lifecycle.js';\n\n","/**\n * Recent workspace activity — quick \"pick up where you left off\" (daemon-local).\n */\n\nimport * as path from 'path';\nimport type { ADHDevConfig } from './config.js';\nimport { expandPath } from './workspaces.js';\n\nexport interface WorkspaceActivityEntry {\n path: string;\n lastUsedAt: number;\n /** `active` legacy — same meaning as default */\n kind?: 'ide' | 'cli' | 'acp' | 'default' | 'active';\n /** IDE id or CLI/ACP provider type */\n agentType?: string;\n}\n\nconst MAX_ACTIVITY = 30;\n\nexport function normWorkspacePath(p: string): string {\n try {\n return path.resolve(expandPath(p));\n } catch {\n return path.resolve(p);\n }\n}\n\n/**\n * Append or bump a path to the front of recent activity (returns new config object).\n */\nexport function appendWorkspaceActivity(\n config: ADHDevConfig,\n rawPath: string,\n meta?: { kind?: WorkspaceActivityEntry['kind']; agentType?: string },\n): ADHDevConfig {\n const abs = normWorkspacePath(rawPath);\n if (!abs) return config;\n\n const prev = config.recentWorkspaceActivity || [];\n const filtered = prev.filter(e => normWorkspacePath(e.path) !== abs);\n const entry: WorkspaceActivityEntry = {\n path: abs,\n lastUsedAt: Date.now(),\n kind: meta?.kind,\n agentType: meta?.agentType,\n };\n const recentWorkspaceActivity = [entry, ...filtered].slice(0, MAX_ACTIVITY);\n return { ...config, recentWorkspaceActivity };\n}\n\nexport function getWorkspaceActivity(config: ADHDevConfig, limit = 20): WorkspaceActivityEntry[] {\n const list = [...(config.recentWorkspaceActivity || [])];\n list.sort((a, b) => b.lastUsedAt - a.lastUsedAt);\n return list.slice(0, limit);\n}\n\nexport function removeActivityForPath(config: ADHDevConfig, rawPath: string): ADHDevConfig {\n const n = normWorkspacePath(rawPath);\n return {\n ...config,\n recentWorkspaceActivity: (config.recentWorkspaceActivity || []).filter(\n e => normWorkspacePath(e.path) !== n,\n ),\n };\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 * Uses parallel execution for fast detection across many providers.\n */\n\nimport { exec } 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 category?: string;\n}\n\n/** Run a shell command with timeout, returning stdout or null on failure */\nfunction execAsync(cmd: string, timeoutMs = 5000): Promise<string | null> {\n return new Promise((resolve) => {\n const child = exec(cmd, { encoding: 'utf-8', timeout: timeoutMs }, (err, stdout) => {\n if (err || !stdout?.trim()) {\n resolve(null);\n } else {\n resolve(stdout.trim());\n }\n });\n // Safety: kill on timeout\n child.on('error', () => resolve(null));\n });\n}\n\n/**\n * Detect all CLI/ACP agents (parallel)\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 // Run all `which` checks in parallel\n const results = await Promise.all(\n cliList.map(async (cli): Promise<CLIInfo> => {\n try {\n const pathResult = await execAsync(`${whichCmd} ${cli.command} 2>/dev/null`);\n if (!pathResult) return { ...cli, installed: false };\n\n const firstPath = pathResult.split('\\n')[0];\n\n // Get version (parallel with other checks)\n let version: string | undefined;\n try {\n const versionResult = await execAsync(`${cli.command} --version 2>/dev/null`, 3000);\n if (versionResult) {\n // Extract version number (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 }\n } catch { }\n\n return { ...cli, installed: true, version, path: firstPath };\n } catch {\n return { ...cli, installed: false };\n }\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 * Host memory metrics — macOS-aware \"available\" memory.\n *\n * Node's os.freemem() on darwin reports only the tiny truly-free pool; most RAM\n * sits in inactive/file-backed cache that the OS can reclaim. Dashboard \"used %\"\n * based on (total - freemem) looks ~99% almost always — misleading.\n *\n * On macOS we parse `vm_stat` and approximate available bytes as:\n * (free + inactive + speculative + purgeable [+ file_backed]) × page size\n * (aligned with common Activity Monitor–style interpretations.)\n */\n\nimport * as os from 'os';\nimport { execSync } from 'child_process';\n\nexport interface HostMemorySnapshot {\n totalMem: number;\n /** Raw kernel \"free\" — small on macOS; kept for debugging / API compat */\n freeMem: number;\n /** Use this for UI \"used %\" — on darwin from vm_stat; else equals freeMem */\n availableMem: number;\n}\n\nfunction parseDarwinAvailableBytes(totalMem: number): number | null {\n if (os.platform() !== 'darwin') return null;\n try {\n const out = execSync('vm_stat', {\n encoding: 'utf-8',\n timeout: 4000,\n maxBuffer: 256 * 1024,\n });\n const pageSizeMatch = out.match(/page size of (\\d+)\\s*bytes/i);\n const pageSize = pageSizeMatch ? parseInt(pageSizeMatch[1], 10) : 4096;\n\n const counts: Record<string, number> = {};\n for (const line of out.split('\\n')) {\n const m = line.match(/^\\s*Pages\\s+([^:]+):\\s+([\\d,]+)\\s*\\.?/);\n if (!m) continue;\n const key = m[1].trim().toLowerCase().replace(/\\s+/g, '_');\n const n = parseInt(m[2].replace(/,/g, ''), 10);\n if (!Number.isNaN(n)) counts[key] = n;\n }\n\n const free = counts['free'] ?? 0;\n const inactive = counts['inactive'] ?? 0;\n const speculative = counts['speculative'] ?? 0;\n const purgeable = counts['purgeable'] ?? 0;\n const fileBacked = counts['file_backed'] ?? 0;\n\n const availPages = free + inactive + speculative + purgeable + fileBacked;\n const bytes = availPages * pageSize;\n if (!Number.isFinite(bytes) || bytes < 0) return null;\n return Math.min(bytes, totalMem);\n } catch {\n return null;\n }\n}\n\nexport function getHostMemorySnapshot(): HostMemorySnapshot {\n const totalMem = os.totalmem();\n const freeMem = os.freemem();\n const darwinAvail = parseDarwinAvailableBytes(totalMem);\n const availableMem = darwinAvail != null ? darwinAvail : freeMem;\n return { totalMem, freeMem, availableMem };\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';\nimport { LOG } from '../logging/logger.js';\nimport type { CdpTargetFilter } from '../providers/contracts.js';\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 private _targetFilter: CdpTargetFilter; // Provider-configurable target selection\n\n constructor(port = 9333, logFn?: (msg: string) => void, targetId?: string, targetFilter?: CdpTargetFilter) {\n this.port = port;\n this._targetId = targetId || null;\n this._targetFilter = targetFilter || {};\n this.logFn = logFn || ((msg) => {\n LOG.info('CDP', msg);\n });\n }\n\n /** Set target filter (can be updated after construction) */\n setTargetFilter(filter: CdpTargetFilter): void {\n this._targetFilter = filter;\n }\n\n /**\n * Check if a page title should be excluded (non-main page).\n * Uses provider-configured titleExcludes, falls back to default pattern.\n */\n private isNonMainTitle(title: string): boolean {\n if (!title) return true;\n const pattern = this._targetFilter.titleExcludes\n || 'extension-output|ADHDev CDP|Debug Console|Output\\\\s*$|Launchpad';\n return new RegExp(pattern, 'i').test(title);\n }\n\n /**\n * Check if a page URL matches the main window criteria.\n * Uses provider-configured urlIncludes/urlExcludes.\n */\n private isMainPageUrl(url: string | undefined): boolean {\n if (!url) return true; // no URL filter = accept all\n const { urlIncludes, urlExcludes } = this._targetFilter;\n if (urlIncludes && !url.includes(urlIncludes)) return false;\n if (urlExcludes) {\n for (const exc of urlExcludes) {\n if (url.includes(exc)) return false;\n }\n }\n return true;\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 // Filter using default target filter (static — no provider filter available)\n const defaultExclude = /extension-output|ADHDev CDP|Debug Console|Output\\s*$|Launchpad/i;\n const isNonMain = (title: string) => !title || defaultExclude.test(title);\n const mainPages = pages.filter(t =>\n !isNonMain(t.title || '') &&\n t.url?.includes('workbench.html') &&\n !t.url?.includes('agent')\n );\n const fallbackPages = pages.filter(t => !isNonMain(t.title || ''));\n resolve(mainPages.length > 0 ? mainPages : fallbackPages);\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 mainPages = pages.filter(t => !this.isNonMainTitle(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: 'webp',\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 * 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 * Scoped logger instance for a specific component.\n * Created via LOG.forComponent('CDP:cursor').\n */\nexport interface ScopedLogger {\n debug: (msg: string) => void;\n info: (msg: string) => void;\n warn: (msg: string) => void;\n error: (msg: string) => void;\n /** Returns a plain (msg: string) => void function at the given level.\n * Useful as logFn callback for ProviderLoader, DaemonStatusReporter, etc. */\n asLogFn: (level?: LogLevel) => (msg: string) => void;\n}\n\n/**\n * LOG — unified logging API\n *\n * Usage:\n * LOG.info('CDP', 'Connected to cursor on port 9333');\n * LOG.debug('StatusReport', 'P2P heartbeat sent');\n *\n * Component-scoped logger:\n * const log = LOG.forComponent('ACP:cursor');\n * log.info('Session created');\n * log.debug('Heartbeat');\n *\n * As callback for external components:\n * new ProviderLoader({ logFn: LOG.forComponent('Provider').asLogFn() });\n * new DaemonStatusReporter({ logFn: LOG.forComponent('Status').asLogFn() });\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 * Create a scoped logger for a specific component.\n * Category is baked in so callers only pass the message.\n */\n forComponent(category: string): ScopedLogger {\n return {\n debug: (msg: string) => daemonLog(category, msg, 'debug'),\n info: (msg: string) => daemonLog(category, msg, 'info'),\n warn: (msg: string) => daemonLog(category, msg, 'warn'),\n error: (msg: string) => daemonLog(category, msg, 'error'),\n asLogFn: (level: LogLevel = 'info') => (msg: string) => daemonLog(category, msg, level),\n };\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 * 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 './manager.js';\nimport type { CommandResult } from '../commands/handler.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 * 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 '../config/chat-history.js';\nimport { LOG } from '../logging/logger.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 LOG.warn('IdeInstance', `[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 LOG.warn('IdeInstance', `[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 LOG.info('IdeInstance', `[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 // Filter messages by provider settings (showThinking, showToolCalls, showTerminal)\n if (raw.messages?.length > 0) {\n const hiddenKinds = new Set<string>();\n if (this.settings.showThinking === false) hiddenKinds.add('thought');\n if (this.settings.showToolCalls === false) hiddenKinds.add('tool');\n if (this.settings.showTerminal === false) hiddenKinds.add('terminal');\n if (hiddenKinds.size > 0) {\n raw.messages = raw.messages.filter((m: any) => !hiddenKinds.has(m.kind));\n }\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 LOG.warn('IdeInstance', `[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 * 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 * 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 * 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 * DaemonCdpSetup — Shared CDP initialization helpers\n *\n * Extracted from daemon-cloud/adhdev-daemon.ts setupCdpManager()\n * and daemon-standalone/index.ts inline CDP setup logic.\n *\n * Used by both daemon-cloud and daemon-standalone to ensure\n * consistent CDP → ProviderInstance registration.\n */\n\nimport { DaemonCdpManager } from './manager.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport { IdeProviderInstance } from '../providers/ide-provider-instance.js';\nimport type { ProviderModule } from '../providers/contracts.js';\n\nexport interface CdpSetupContext {\n providerLoader: ProviderLoader;\n instanceManager: ProviderInstanceManager;\n cdpManagers: Map<string, DaemonCdpManager>;\n /** UUID instanceId → CDP manager key mapping */\n instanceIdMap: Map<string, string>;\n /** Server connection (optional, cloud-only) */\n serverConn?: any;\n}\n\nexport interface SetupIdeInstanceOptions {\n /** Provider-based IDE type (e.g., 'antigravity', 'cursor') */\n ideType: string;\n /** Connected CDP manager */\n manager: DaemonCdpManager;\n /** CDP manager key (for multi-window: 'antigravity_remote_vs', single: 'antigravity') */\n managerKey?: string;\n /** Provider settings override */\n settings?: Record<string, any>;\n}\n\n/**\n * Register extension providers on a CDP manager.\n * Common pattern used during CDP init and periodic scans.\n */\nexport function registerExtensionProviders(\n providerLoader: ProviderLoader,\n manager: DaemonCdpManager,\n ideType: string,\n): void {\n const enabledExtProviders = providerLoader.getEnabledExtensionProviders(ideType)\n .map((p: any) => ({\n agentType: p.type,\n extensionId: p.extensionId || '',\n extensionIdPattern: p.extensionIdPattern!,\n }));\n manager.setExtensionProviders(enabledExtProviders);\n}\n\n/**\n * Setup a CDP-connected IDE as a ProviderInstance.\n *\n * Performs:\n * 1. providerLoader.resolve() to get scripts\n * 2. Create IdeProviderInstance\n * 3. Register in InstanceManager\n * 4. Register enabled extensions\n * 5. Update instanceIdMap (IDE + extension UUIDs)\n *\n * @returns The created IdeProviderInstance, or null if provider not found\n */\nexport async function setupIdeInstance(\n ctx: CdpSetupContext,\n opts: SetupIdeInstanceOptions,\n): Promise<IdeProviderInstance | null> {\n const { providerLoader, instanceManager, instanceIdMap } = ctx;\n const { ideType, manager, settings } = opts;\n const managerKey = opts.managerKey || ideType;\n\n // 1. Register extension providers on CDP manager\n registerExtensionProviders(providerLoader, manager, ideType);\n\n // 2. Resolve provider with scripts\n const ideProvider = providerLoader.resolve(ideType);\n if (!ideProvider) return null;\n\n // 3. Create IdeProviderInstance\n const ideInstance = new IdeProviderInstance(\n ideProvider,\n managerKey !== ideType ? managerKey : undefined,\n );\n\n // 4. Register in InstanceManager\n const resolvedSettings = settings || providerLoader.getSettings(ideType);\n await instanceManager.addInstance(`ide:${managerKey}`, ideInstance, {\n cdp: manager,\n serverConn: ctx.serverConn,\n settings: resolvedSettings,\n });\n\n // 5. Map IDE instance UUID → manager key\n instanceIdMap.set(ideInstance.getInstanceId(), managerKey);\n\n // 6. Register enabled extensions\n const extensionProviders = providerLoader.getEnabledByCategory('extension', ideType);\n for (const extProvider of extensionProviders) {\n const extSettings = providerLoader.getSettings(extProvider.type);\n await ideInstance.addExtension(extProvider, extSettings);\n // Map extension UUIDs too (CDP uses parent IDE)\n for (const ext of ideInstance.getExtensionInstances()) {\n instanceIdMap.set(ext.getInstanceId(), managerKey);\n }\n }\n\n return ideInstance;\n}\n\n/**\n * Create and connect a DaemonCdpManager for a given port.\n *\n * @returns Connected manager or null if connection failed\n */\nexport async function connectCdpManager(\n port: number,\n ideType: string,\n logFn: (msg: string) => void,\n providerLoader: ProviderLoader,\n targetId?: string,\n): Promise<DaemonCdpManager | null> {\n const provider = providerLoader.getMeta(ideType);\n const manager = new DaemonCdpManager(\n port,\n logFn,\n targetId,\n (provider as any)?.targetFilter,\n );\n const connected = await manager.connect();\n return connected ? manager : null;\n}\n\n/**\n * Probe a CDP port to check if it's listening.\n * @returns true if CDP is available on this port\n */\nexport async function probeCdpPort(port: number, timeoutMs = 1000): Promise<boolean> {\n try {\n const probe = await fetch(`http://localhost:${port}/json/version`, {\n signal: AbortSignal.timeout(timeoutMs),\n }).then(r => r.json()).catch(() => null);\n return !!probe;\n } catch {\n return false;\n }\n}\n","/**\n * DaemonCdpScanner — Periodic CDP port scanning & auto-connect\n *\n * Extracted from daemon-cloud initCdp() and daemon-standalone initCdp().\n * Provides a unified approach to:\n * 1. Initial CDP port discovery\n * 2. Periodic scanning for newly launched IDEs\n * 3. Multi-window support (multiple pages on same port)\n */\n\nimport { DaemonCdpManager } from './manager.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport { connectCdpManager, probeCdpPort, registerExtensionProviders, setupIdeInstance, type CdpSetupContext } from './setup.js';\nimport { LOG } from '../logging/logger.js';\n\nexport interface CdpScannerOptions {\n /** Context for setup operations */\n ctx: CdpSetupContext;\n /** Log function for per-IDE CDP logs */\n logFn?: (ideType: string) => (msg: string) => void;\n /** Whether to support multi-window (multiple pages per port) */\n multiWindow?: boolean;\n /** Scan interval in ms (default: 30000) */\n scanIntervalMs?: number;\n /** Callback when a new CDP connection is established */\n onConnected?: (ideType: string, managerKey: string, manager: DaemonCdpManager) => void;\n}\n\nexport class DaemonCdpScanner {\n private ctx: CdpSetupContext;\n private opts: CdpScannerOptions;\n private scanTimer: NodeJS.Timeout | null = null;\n private discoveryTimer: NodeJS.Timeout | null = null;\n\n constructor(opts: CdpScannerOptions) {\n this.ctx = opts.ctx;\n this.opts = opts;\n }\n\n /**\n * Initial CDP discovery — connect to all available IDEs.\n * Supports both single-window and multi-window modes.\n */\n async initialScan(enabledIdes?: string[]): Promise<void> {\n const portMap = this.ctx.providerLoader.getCdpPortMap();\n const portsToTry: { port: number; ide: string }[] = [];\n\n for (const [ide, ports] of Object.entries(portMap)) {\n portsToTry.push({ port: ports[0], ide });\n }\n\n // Apply enabledIdes filter if provided\n const filtered = enabledIdes?.length\n ? portsToTry.filter(p => enabledIdes.includes(p.ide))\n : portsToTry;\n\n for (const { port, ide } of filtered) {\n if (this.opts.multiWindow) {\n await this.connectMultiWindow(port, ide);\n } else {\n await this.connectSingleWindow(port, ide);\n }\n }\n }\n\n /**\n * Start periodic scanning for newly launched IDEs.\n */\n startPeriodicScan(): void {\n if (this.scanTimer) return;\n const interval = this.opts.scanIntervalMs || 30_000;\n\n this.scanTimer = setInterval(async () => {\n const portMap = this.ctx.providerLoader.getCdpPortMap();\n for (const [ide, ports] of Object.entries(portMap)) {\n const primaryPort = ports[0];\n // Skip if already connected\n const alreadyConnected = [...this.ctx.cdpManagers.entries()].some(([key, m]) =>\n m.isConnected && (key === ide || key.startsWith(ide + '_'))\n );\n if (alreadyConnected) continue;\n\n if (this.opts.multiWindow) {\n await this.connectMultiWindow(primaryPort, ide);\n } else {\n await this.connectSingleWindow(primaryPort, ide);\n }\n }\n }, interval);\n }\n\n /**\n * Start periodic agent webview discovery on all connected CDPs.\n */\n startWebviewDiscovery(intervalMs = 30_000): void {\n if (this.discoveryTimer) return;\n this.discoveryTimer = setInterval(async () => {\n for (const m of this.ctx.cdpManagers.values()) {\n if (m.isConnected) {\n await m.discoverAgentWebviews();\n }\n }\n }, intervalMs);\n }\n\n /**\n * Stop all timers.\n */\n stop(): void {\n if (this.scanTimer) { clearInterval(this.scanTimer); this.scanTimer = null; }\n if (this.discoveryTimer) { clearInterval(this.discoveryTimer); this.discoveryTimer = null; }\n }\n\n // ── Internal ────────────────────────────\n\n private getLogFn(ideType: string): (msg: string) => void {\n if (this.opts.logFn) return this.opts.logFn(ideType);\n return (msg: string) => LOG.info(`CDP:${ideType}`, msg);\n }\n\n /**\n * Single-window connection (standalone mode).\n * One CDP manager per IDE, first working port wins.\n */\n private async connectSingleWindow(port: number, ide: string): Promise<void> {\n if (this.ctx.cdpManagers.has(ide)) return;\n const available = await probeCdpPort(port);\n if (!available) return;\n\n const manager = await connectCdpManager(\n port, ide, this.getLogFn(ide), this.ctx.providerLoader,\n );\n if (!manager) return;\n\n registerExtensionProviders(this.ctx.providerLoader, manager, ide);\n this.ctx.cdpManagers.set(ide, manager);\n LOG.info('CDP', `Connected: ${ide} (port ${port})`);\n\n // Setup IDE instance\n await setupIdeInstance(this.ctx, { ideType: ide, manager });\n this.opts.onConnected?.(ide, ide, manager);\n }\n\n /**\n * Multi-window connection (cloud mode).\n * Multiple CDP managers per IDE — one per workbench page.\n */\n private async connectMultiWindow(port: number, ide: string): Promise<void> {\n const allTargets = await DaemonCdpManager.listAllTargets(port);\n\n if (allTargets.length === 0) {\n // Fallback: single-window approach\n await this.connectSingleWindow(port, ide);\n return;\n }\n\n for (let i = 0; i < allTargets.length; i++) {\n const target = allTargets[i];\n let managerKey: string;\n if (allTargets.length === 1) {\n managerKey = ide;\n } else {\n const workspaceName = (target.title || '').split(' — ')[0].trim() || `window_${i}`;\n managerKey = `${ide}_${workspaceName}`;\n }\n\n if (this.ctx.cdpManagers.has(managerKey)) continue;\n\n const manager = await connectCdpManager(\n port, ide, this.getLogFn(managerKey), this.ctx.providerLoader, target.id,\n );\n if (!manager) continue;\n\n this.ctx.cdpManagers.set(managerKey, manager);\n LOG.info('CDP', `Connected: ${managerKey} (port ${port}, page \"${target.title}\")`);\n\n await setupIdeInstance(this.ctx, {\n ideType: ide,\n manager,\n managerKey,\n });\n this.opts.onConnected?.(ide, managerKey, manager);\n }\n }\n}\n","/**\n * DaemonCdpInitializer — Unified CDP initialization + periodic scanning\n *\n * Replaces initCdp() in both cloud and standalone daemons.\n *\n * Features:\n * 1. Initial connection: connectAll() — multi-window aware\n * 2. Periodic scan: startPeriodicScan() — auto-detect newly opened IDEs\n * 3. Discovery: startDiscovery() — periodic agent webview discovery\n */\n\nimport { DaemonCdpManager } from './manager.js';\nimport { registerExtensionProviders } from './setup.js';\nimport { probeCdpPort } from './setup.js';\nimport type { ProviderLoader } from '../providers/provider-loader.js';\nimport { LOG } from '../logging/logger.js';\n\n// ─── Config ───\n\nexport interface CdpInitializerConfig {\n providerLoader: ProviderLoader;\n cdpManagers: Map<string, DaemonCdpManager>;\n /** Filter: only connect these IDEs (empty/undefined = all) */\n enabledIdes?: string[];\n /** Callback when a new CDP manager is connected */\n onConnected?: (ideType: string, manager: DaemonCdpManager, managerKey: string) => void | Promise<void>;\n}\n\nexport class DaemonCdpInitializer {\n private config: CdpInitializerConfig;\n private scanTimer: NodeJS.Timeout | null = null;\n private discoveryTimer: NodeJS.Timeout | null = null;\n\n constructor(config: CdpInitializerConfig) {\n this.config = config;\n }\n\n // ─── Initial connection ───\n\n /**\n * Connect to all detected IDEs.\n * Multi-window aware: creates separate CdpManager per workbench page.\n */\n async connectAll(detectedIdes: any[]): Promise<void> {\n const { providerLoader, cdpManagers, enabledIdes } = this.config;\n const providerCdpMap = providerLoader.getCdpPortMap();\n\n // Build port list sorted by detected IDE order\n const portsToTry: { port: number; ide: string }[] = [];\n for (const ide of detectedIdes) {\n if (!ide.installed) continue;\n const ideKey = ide.id || ide.name?.toLowerCase();\n const ports = providerCdpMap[ideKey];\n if (ports) portsToTry.push({ port: ports[0], ide: ideKey });\n }\n // Add undetected IDE ports (provider-based)\n for (const [ide, ports] of Object.entries(providerCdpMap)) {\n if (!portsToTry.find(p => p.port === ports[0])) {\n portsToTry.push({ port: ports[0], ide });\n }\n }\n\n // Filter by enabledIdes\n const filtered = enabledIdes?.length\n ? portsToTry.filter(p => enabledIdes.includes(p.ide))\n : portsToTry;\n\n for (const { port, ide } of filtered) {\n await this.connectIdePort(port, ide);\n }\n\n // Summary\n if (cdpManagers.size > 0) {\n LOG.info('CDP', `${cdpManagers.size} IDE(s) connected: ${[...cdpManagers.entries()].map(([k, m]) => `${k}:${m.getPort()}`).join(', ')}`);\n } else {\n LOG.warn('CDP', `No IDEs connected — tried: ${filtered.map(p => `${p.ide}:${p.port}`).join(', ')}`);\n }\n }\n\n // ─── Per-port connection (multi-window aware) ───\n\n /**\n * Connect to a single IDE port.\n * Tries multi-window first (listAllTargets), falls back to direct connect.\n */\n private async connectIdePort(port: number, ide: string): Promise<void> {\n const { providerLoader, cdpManagers } = this.config;\n\n // 1. Try multi-window: list all workbench pages on this port\n const targets = await DaemonCdpManager.listAllTargets(port);\n\n if (targets.length === 0) {\n // Fallback: direct single connection (probeCdpPort first)\n if (!await probeCdpPort(port)) return;\n const provider = providerLoader.getMeta(ide);\n const manager = new DaemonCdpManager(\n port,\n LOG.forComponent(`CDP:${ide}`).asLogFn(),\n undefined,\n (provider as any)?.targetFilter,\n );\n const connected = await manager.connect();\n if (connected) {\n registerExtensionProviders(providerLoader, manager, ide);\n cdpManagers.set(ide, manager);\n LOG.info('CDP', `Connected: ${ide} (port ${port})`);\n await this.config.onConnected?.(ide, manager, ide);\n }\n return;\n }\n\n // 2. Multi-window: create separate CdpManager per page\n for (let i = 0; i < targets.length; i++) {\n const target = targets[i];\n // Key: single page = ide type as-is, multi-page = ide_workspaceName\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\n if (cdpManagers.has(managerKey)) continue;\n\n const provider = providerLoader.getMeta(ide);\n const manager = new DaemonCdpManager(\n port,\n LOG.forComponent(`CDP:${managerKey}`).asLogFn(),\n target.id,\n (provider as any)?.targetFilter,\n );\n\n const connected = await manager.connect();\n if (connected) {\n registerExtensionProviders(providerLoader, manager, ide);\n cdpManagers.set(managerKey, manager);\n LOG.info('CDP', `Connected: ${managerKey} (port ${port}${targets.length > 1 ? `, page \"${target.title}\"` : ''})`);\n await this.config.onConnected?.(ide, manager, managerKey);\n }\n }\n }\n\n // ─── Periodic scanning ───\n\n /**\n * Start periodic scanning for newly opened IDEs.\n * Idempotent — ignored if already started.\n */\n startPeriodicScan(intervalMs = 30_000): void {\n if (this.scanTimer) return;\n\n this.scanTimer = setInterval(async () => {\n const { providerLoader, cdpManagers } = this.config;\n const portMap = providerLoader.getCdpPortMap();\n\n for (const [ide, ports] of Object.entries(portMap)) {\n const primaryPort = ports[0];\n\n // Skip if already connected\n const alreadyConnected = [...cdpManagers.entries()].some(([key, m]) =>\n m.isConnected && (key === ide || key.startsWith(ide + '_'))\n );\n if (alreadyConnected) continue;\n\n await this.connectIdePort(primaryPort, ide);\n }\n }, intervalMs);\n }\n\n /**\n * Start periodic agent webview discovery.\n */\n startDiscovery(intervalMs = 30_000): void {\n if (this.discoveryTimer) return;\n\n this.discoveryTimer = setInterval(async () => {\n for (const m of this.config.cdpManagers.values()) {\n if (m.isConnected) {\n await m.discoverAgentWebviews();\n }\n }\n }, intervalMs);\n }\n\n /** Stop all timers */\n stop(): void {\n if (this.scanTimer) { clearInterval(this.scanTimer); this.scanTimer = null; }\n if (this.discoveryTimer) { clearInterval(this.discoveryTimer); this.discoveryTimer = null; }\n }\n}\n","/**\n * Daemon Commands — unified command handler\n * \n * Routes all functionality from legacy Extension commands.ts to Daemon.\n * \n * Command implementations are split into sub-modules:\n * - chat-commands.ts — Chat I/O, session management, mode/model control\n * - cdp-commands.ts — CDP eval, screenshot, batch, remote actions, file ops\n * - stream-commands.ts — Agent stream, PTY I/O, provider settings, extension scripts\n */\n\nimport { DaemonCdpManager } from '../cdp/manager.js';\nimport { CdpDomHandlers } from '../cdp/devtools.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport type { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport type { ProviderModule } from '../providers/contracts.js';\nimport type { DaemonAgentStreamManager } from '../agent-stream/index.js';\nimport { loadConfig } from '../config/config.js';\nimport { ChatHistoryWriter } from '../config/chat-history.js';\nimport { LOG } from '../logging/logger.js';\n\n// Sub-module imports\nimport * as Chat from './chat-commands.js';\nimport * as Cdp from './cdp-commands.js';\nimport * as Stream from './stream-commands.js';\nimport * as WorkspaceCmd from './workspace-commands.js';\nimport { getWorkspaceState } from '../config/workspaces.js';\nimport { getWorkspaceActivity } from '../config/workspace-activity.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 /** ProviderInstanceManager — for runtime settings propagation */\n instanceManager?: ProviderInstanceManager;\n /** UUID instanceId → CDP manager key (ideType) mapping */\n instanceIdMap?: Map<string, string>;\n}\n\n/**\n * Shared helpers interface — passed to sub-module command functions\n * for accessing CDP, providers, agent streams, and other handler-owned state.\n */\nexport interface CommandHelpers {\n getCdp(ideType?: string): DaemonCdpManager | null;\n getProvider(overrideType?: string): ProviderModule | undefined;\n getProviderScript(scriptName: string, params?: Record<string, string>, ideType?: string): string | null;\n evaluateProviderScript(scriptName: string, params?: Record<string, string>, timeout?: number): Promise<{ result: any; category: string } | null>;\n getCliAdapter(type?: string): any | null;\n readonly currentIdeType: string | undefined;\n readonly currentProviderType: string | undefined;\n readonly agentStream: DaemonAgentStreamManager | null;\n readonly ctx: CommandContext;\n readonly historyWriter: ChatHistoryWriter;\n}\n\nexport class DaemonCommandHandler implements CommandHelpers {\n private _ctx: CommandContext;\n private _agentStream: DaemonAgentStreamManager | null = null;\n private domHandlers: CdpDomHandlers;\n private _historyWriter: ChatHistoryWriter;\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 constructor(ctx: CommandContext) {\n this._ctx = ctx;\n this.domHandlers = new CdpDomHandlers((ideType?) => this.getCdp(ideType));\n this._historyWriter = new ChatHistoryWriter();\n }\n\n // ─── CommandHelpers implementation ─────────────────\n\n get ctx(): CommandContext { return this._ctx; }\n get agentStream(): DaemonAgentStreamManager | null { return this._agentStream; }\n get historyWriter(): ChatHistoryWriter { return this._historyWriter; }\n get currentIdeType(): string | undefined { return this._currentIdeType; }\n get currentProviderType(): string | undefined { return this._currentProviderType; }\n\n /** Get CDP manager for a specific ideType.\n * Returns null if no match — never falls back to another IDE. */\n getCdp(ideType?: string): DaemonCdpManager | null {\n const key = ideType || this._currentIdeType;\n if (!key) return null;\n const m = this._ctx.cdpManagers.get(key.toLowerCase());\n if (m?.isConnected) return m;\n return null;\n }\n\n /**\n * Get provider module — _currentProviderType (agentType priority) use.\n */\n getProvider(overrideType?: string): ProviderModule | undefined {\n const key = overrideType || this._currentProviderType || this._currentIdeType;\n if (!key || !this._ctx.providerLoader) return undefined;\n const result = this._ctx.providerLoader.resolve(key);\n if (result) return result;\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 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 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 /**\n * per-category CDP script execute:\n * IDE → cdp.evaluate(script) (main window)\n * Extension → cdp.evaluateInSession(sessionId, script) (webview)\n */\n 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 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 /** CLI adapter search */\n 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 // ─── Private helpers ──────────────────────────────\n\n private getExtensionSessionId(provider: ProviderModule): string | null {\n if (provider.category !== 'extension' || !this._agentStream) return null;\n const managed = this._agentStream.getManagedAgent(provider.type);\n return managed?.sessionId || null;\n }\n\n /** Extract ideType from _targetInstance */\n private extractIdeType(args: any): string | undefined {\n // Also accept explicit ideType from args (agentType for extensions)\n if (args?.ideType && this._ctx.cdpManagers.has(args.ideType)) {\n return args.ideType;\n }\n\n if (args?._targetInstance) {\n let raw = args._targetInstance as string;\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 if (this._ctx.instanceIdMap?.has(raw)) {\n return this._ctx.instanceIdMap.get(raw)!;\n }\n\n // Direct CDP manager key match (e.g. \"cursor\", \"antigravity\")\n if (this._ctx.cdpManagers.has(raw)) {\n return raw;\n }\n\n // Fallback: if no structured format matched and raw looks like a machine ID\n // (e.g. \"standalone_hostname\"), find first available connected CDP\n if (!ideMatch && !cliMatch && !acpMatch) {\n for (const [key, mgr] of this._ctx.cdpManagers.entries()) {\n if (mgr.isConnected) return key;\n }\n }\n\n // Legacy: strip trailing _N suffix (e.g. \"cursor_1\" → \"cursor\")\n const lastUnderscore = raw.lastIndexOf('_');\n if (lastUnderscore > 0) {\n const stripped = raw.substring(0, lastUnderscore);\n if (this._ctx.cdpManagers.has(stripped)) return stripped;\n }\n return raw;\n }\n return undefined;\n }\n\n setAgentStreamManager(manager: DaemonAgentStreamManager): void {\n this._agentStream = manager;\n }\n\n // ─── Command Dispatcher ──────────────────────────\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 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\n try {\n return await this.dispatch(cmd, args);\n } catch (e: any) {\n LOG.error('Command', `[${cmd}] Unhandled error: ${e?.message || e}`);\n return { success: false, error: `Internal error: ${e?.message || 'unknown'}` };\n }\n }\n\n private async dispatch(cmd: string, args: any): Promise<CommandResult> {\n switch (cmd) {\n // ─── Chat commands (chat-commands.ts) ───────────────\n case 'read_chat': return Chat.handleReadChat(this, args);\n case 'chat_history': return Chat.handleChatHistory(this, args);\n case 'send_chat': return Chat.handleSendChat(this, args);\n case 'list_chats': return Chat.handleListChats(this, args);\n case 'new_chat': return Chat.handleNewChat(this, args);\n case 'switch_chat': return Chat.handleSwitchChat(this, args);\n case 'set_mode': return Chat.handleSetMode(this, args);\n case 'change_model': return Chat.handleChangeModel(this, args);\n case 'set_thought_level': return Chat.handleSetThoughtLevel(this, args);\n case 'resolve_action': return Chat.handleResolveAction(this, args);\n\n // ─── CDP commands (cdp-commands.ts) ───────────────\n case 'cdp_eval': return Cdp.handleCdpEval(this, args);\n case 'cdp_screenshot':\n case 'screenshot': return Cdp.handleScreenshot(this, args);\n case 'cdp_command_exec': return Cdp.handleCdpCommand(this, args);\n case 'cdp_batch': return Cdp.handleCdpBatch(this, args);\n case 'cdp_remote_action': return Cdp.handleCdpRemoteAction(this, args);\n case 'cdp_discover_agents': return Cdp.handleDiscoverAgents(this, 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 commands (cdp-commands.ts) ──────────────\n case 'file_read': return Cdp.handleFileRead(this, args);\n case 'file_write': return Cdp.handleFileWrite(this, args);\n case 'file_list': return Cdp.handleFileList(this, args);\n case 'file_list_browse': return Cdp.handleFileListBrowse(this, args);\n\n // ─── VSCode API commands (not available) ────\n case 'vscode_command_exec':\n case 'execute_vscode_command': {\n const resolvedCmd = args?.commandId || args?.command;\n if (resolvedCmd === 'adhdev.captureCdpScreenshot') {\n return Cdp.handleScreenshot(this, args);\n }\n return { success: false, error: `VSCode command not available: ${resolvedCmd || cmd}` };\n }\n case 'get_open_editors':\n case 'open_tab':\n case 'close_tab':\n case 'open_folder':\n case 'open_folder_picker':\n case 'open_recent':\n case 'get_commands':\n return { success: false, error: `${cmd} requires bridge-extension (removed)` };\n case 'get_recent_workspaces': return this.handleGetRecentWorkspaces(args);\n case 'get_cli_history': {\n const config = loadConfig();\n return { success: true, history: config.cliHistory || [] };\n }\n\n case 'workspace_list': return WorkspaceCmd.handleWorkspaceList();\n case 'workspace_add': return WorkspaceCmd.handleWorkspaceAdd(args);\n case 'workspace_remove': return WorkspaceCmd.handleWorkspaceRemove(args);\n case 'workspace_set_default':\n case 'workspace_set_active':\n return WorkspaceCmd.handleWorkspaceSetDefault(args);\n\n // ─── Script manage ───────────────────\n case 'refresh_scripts': return this.handleRefreshScripts(args);\n\n // ─── Stream commands (stream-commands.ts) ───────────\n case 'agent_stream_switch': return Stream.handleAgentStreamSwitch(this, args);\n case 'agent_stream_read': return Stream.handleAgentStreamRead(this, args);\n case 'agent_stream_send': return Stream.handleAgentStreamSend(this, args);\n case 'agent_stream_resolve': return Stream.handleAgentStreamResolve(this, args);\n case 'agent_stream_new': return Stream.handleAgentStreamNew(this, args);\n case 'agent_stream_list_chats': return Stream.handleAgentStreamListChats(this, args);\n case 'agent_stream_switch_session': return Stream.handleAgentStreamSwitchSession(this, args);\n case 'agent_stream_focus': return Stream.handleAgentStreamFocus(this, args);\n\n // ─── PTY Raw I/O (stream-commands.ts) ─────────\n case 'pty_input': return Stream.handlePtyInput(this, args);\n case 'pty_resize': return Stream.handlePtyResize(this, args);\n\n // ─── Provider Settings (stream-commands.ts) ──────────\n case 'get_provider_settings': return Stream.handleGetProviderSettings(this, args);\n case 'set_provider_setting': return Stream.handleSetProviderSetting(this, args);\n\n // ─── IDE Extension Settings (stream-commands.ts) ──────────\n case 'get_ide_extensions': return Stream.handleGetIdeExtensions(this, args);\n case 'set_ide_extension': return Stream.handleSetIdeExtension(this, args);\n\n // ─── Extension Model / Mode Control (stream-commands.ts) ──────────\n case 'list_extension_models': return Stream.handleExtensionScript(this, args, 'listModels');\n case 'set_extension_model': return Stream.handleExtensionScript(this, args, 'setModel');\n case 'list_extension_modes': return Stream.handleExtensionScript(this, args, 'listModes');\n case 'set_extension_mode': return Stream.handleExtensionScript(this, args, 'setMode');\n\n default:\n return { success: false, error: `Unknown command: ${cmd}` };\n }\n }\n\n // ─── Misc (kept in handler — too small to extract) ───────\n\n private async handleGetRecentWorkspaces(_args: any): Promise<CommandResult> {\n const config = loadConfig();\n const cliRecent = config.recentCliWorkspaces || [];\n const ws = getWorkspaceState(config);\n return {\n success: true,\n result: cliRecent,\n workspaces: ws.workspaces,\n defaultWorkspaceId: ws.defaultWorkspaceId,\n defaultWorkspacePath: ws.defaultWorkspacePath,\n activity: getWorkspaceActivity(config, 25),\n };\n }\n\n private async handleRefreshScripts(_args: any): Promise<CommandResult> {\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","/**\n * Chat Commands — readChat, sendChat, listChats, newChat, switchChat,\n * setMode, changeModel, setThoughtLevel, resolveAction, chatHistory\n */\n\nimport type { CommandResult, CommandHelpers } from './handler.js';\nimport { readChatHistory } from '../config/chat-history.js';\nimport { LOG } from '../logging/logger.js';\n\nexport async function handleChatHistory(h: CommandHelpers, args: any): Promise<CommandResult> {\n const { agentType, offset, limit, instanceId } = args;\n try {\n const provider = h.getProvider(agentType);\n const agentStr = provider?.type || agentType || h.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\nexport async function handleReadChat(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const _log = (msg: string) => LOG.debug('Command', `[read_chat] ${msg}`);\n\n // CLI / ACP category: read from adapter\n if (provider?.category === 'cli' || provider?.category === 'acp') {\n const adapter = h.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 h.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 h.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 (h.agentStream) {\n const cdp = h.getCdp();\n if (cdp) {\n const streams = await h.agentStream.collectAgentStreams(cdp);\n const stream = streams.find((s: any) => s.agentType === provider.type);\n if (stream) {\n h.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 = h.getCdp();\n if (!cdp?.isConnected) return { success: false, error: 'CDP not connected' };\n\n // webview IDE (Kiro, PearAI) → evaluateInWebviewFrame directly use\n const webviewScript = h.getProviderScript('webviewReadChat') || h.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 h.historyWriter.appendNewMessages(\n provider?.type || h.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 = h.getProviderScript('readChat') || h.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 h.historyWriter.appendNewMessages(\n provider?.type || h.currentIdeType || 'unknown_ide',\n parsed.messages || [],\n parsed.title,\n args?.instanceId\n );\n return { success: true, ...parsed };\n }\n } catch (e: any) {\n LOG.info('Command', `[read_chat] Script error: ${e.message}`);\n }\n }\n\n return { success: true, messages: [], status: 'idle' };\n}\n\nexport async function handleSendChat(h: CommandHelpers, 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) => LOG.debug('Command', `[send_chat] ${msg}`);\n const provider = h.getProvider();\n\n // CLI / ACP category: transmit via adapter\n if (provider?.category === 'cli' || provider?.category === 'acp') {\n const adapter = h.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 h.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 _log(`Extension needsTypeAndSend → AgentStreamManager`);\n }\n }\n } catch (e: any) {\n _log(`Extension script error: ${e.message}`);\n }\n // Method 2: AgentStreamManager\n if (h.agentStream && h.getCdp()) {\n const ok = await h.agentStream.sendToAgent(h.getCdp()!, provider.type, text, h.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 = h.getCdp();\n if (!targetCdp?.isConnected) {\n _log(`No CDP for ${h.currentIdeType}`);\n return { success: false, error: `CDP for ${h.currentIdeType || 'unknown'} not connected` };\n }\n\n _log(`Targeting IDE: ${h.currentIdeType}`);\n\n // Method 0: webview-based IDE (try webviewSendMessage first)\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 = h.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\nexport async function handleListChats(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n\n // Extension: via AgentStreamManager\n if (provider?.category === 'extension' && h.agentStream && h.getCdp()) {\n try {\n const chats = await h.agentStream.listAgentChats(h.getCdp()!, provider.type);\n LOG.info('Command', `[list_chats] Extension: ${chats.length} chats`);\n return { success: true, chats };\n } catch (e: any) {\n LOG.info('Command', `[list_chats] Extension error: ${e.message}`);\n }\n }\n\n // webview IDE\n try {\n const webviewScript = h.getProviderScript('webviewListSessions') || h.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 h.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 LOG.info('Command', `[list_chats] Webview OK: ${parsed.sessions.length} chats`);\n return { success: true, chats: parsed.sessions };\n }\n }\n } catch (e: any) {\n LOG.info('Command', `[list_chats] Webview error: ${e.message}`);\n }\n\n // IDE/default: evaluateProviderScript\n try {\n const evalResult = await h.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 LOG.info('Command', `[list_chats] OK: ${parsed.length} chats`);\n return { success: true, chats: parsed };\n }\n }\n } catch (e: any) {\n LOG.info('Command', `[list_chats] error: ${e.message}`);\n }\n\n return { success: false, error: 'listSessions script not available for this provider' };\n}\n\nexport async function handleNewChat(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n\n if (provider?.category === 'extension' && h.agentStream && h.getCdp()) {\n const ok = await h.agentStream.newAgentSession(h.getCdp()!, provider.type, h.currentIdeType);\n return { success: ok };\n }\n\n // webview IDE\n try {\n const webviewScript = h.getProviderScript('webviewNewSession') || h.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 h.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 try {\n const evalResult = await h.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\nexport async function handleSwitchChat(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const ideType = h.currentIdeType;\n const sessionId = args?.sessionId || args?.id || args?.chatId;\n if (!sessionId) return { success: false, error: 'sessionId required' };\n LOG.info('Command', `[switch_chat] sessionId=${sessionId}, ideType=${ideType}`);\n\n if (provider?.category === 'extension' && h.agentStream && h.getCdp()) {\n const ok = await h.agentStream.switchAgentSession(h.getCdp()!, provider.type, sessionId);\n return { success: ok, result: ok ? 'switched' : 'failed' };\n }\n\n const cdp = h.getCdp(ideType);\n if (!cdp?.isConnected) return { success: false, error: 'CDP not connected' };\n\n // webview IDE\n try {\n const webviewScript = h.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 = h.getProviderScript('switchSession', { SESSION_ID: JSON.stringify(sessionId) })\n || h.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 LOG.info('Command', `[switch_chat] result: ${raw}`);\n\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 LOG.info('Command', `[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) return { success: false, error: parsed.error };\n return { success: true, result: raw };\n } catch (e: any) {\n LOG.error('Command', `[switch_chat] error: ${e.message}`);\n return { success: false, error: e.message };\n }\n}\n\nexport async function handleSetMode(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const mode = args?.mode || 'agent';\n\n // ACP provider\n if (provider?.category === 'acp') {\n const adapter = h.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 // 1. webview setMode\n const webviewScript = h.getProviderScript('webviewSetMode', { MODE: JSON.stringify(mode) });\n if (webviewScript) {\n const cdp = h.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 LOG.info('Command', `[set_mode] webview script error: ${e.message}`);\n }\n }\n }\n\n // 2. main frame setMode\n const mainScript = h.getProviderScript('setMode', { MODE: JSON.stringify(mode) });\n if (mainScript) {\n try {\n const evalResult = await h.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 LOG.info('Command', `[set_mode] script error: ${e.message}`);\n }\n }\n\n return { success: false, error: `setMode '${mode}' not supported by this provider` };\n}\n\nexport async function handleChangeModel(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const model = args?.model;\n\n LOG.info('Command', `[change_model] model=${model} provider=${provider?.type} category=${provider?.category} ideType=${h.currentIdeType} providerType=${h.currentProviderType}`);\n\n // ACP provider\n if (provider?.category === 'acp') {\n const adapter = h.getCliAdapter(provider.type);\n LOG.info('Command', `[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 LOG.info('Command', `[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 // 1. webview setModel\n const webviewScript = h.getProviderScript('webviewSetModel', { MODEL: JSON.stringify(model) });\n if (webviewScript) {\n const cdp = h.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 LOG.info('Command', `[change_model] webview script error: ${e.message}`);\n }\n }\n }\n\n // 2. main frame setModel\n const mainScript = h.getProviderScript('setModel', { MODEL: JSON.stringify(model) });\n if (mainScript) {\n try {\n const evalResult = await h.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 LOG.info('Command', `[change_model] script error: ${e.message}`);\n }\n }\n\n return { success: false, error: 'changeModel not supported by this IDE provider' };\n}\n\nexport async function handleSetThoughtLevel(h: CommandHelpers, 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 = h.getProvider();\n if (!provider || provider.category !== 'acp') {\n return { success: false, error: 'set_thought_level only for ACP providers' };\n }\n const adapter = h.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 LOG.info('Command', `[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\nexport async function handleResolveAction(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const action = args?.action || 'approve';\n const button = args?.button || args?.buttonText\n || (action === 'approve' ? 'Accept' : action === 'reject' ? 'Reject' : 'Accept');\n\n LOG.info('Command', `[resolveAction] action=${action} button=\"${button}\" provider=${provider?.type}`);\n\n // 0. CLI / ACP category: navigate approval dialog via PTY arrow keys + Enter\n if (provider?.category === 'cli') {\n const adapter = h.getCliAdapter(provider.type);\n if (!adapter) return { success: false, error: 'CLI adapter not running' };\n const status = (adapter as any).getStatus?.();\n if (status?.status !== 'waiting_approval') {\n return { success: false, error: 'Not in approval state' };\n }\n const buttons: string[] = status.activeModal?.buttons || ['Allow once', 'Always allow', 'Deny'];\n // Resolve button index: explicit buttonIndex arg → button text match → action fallback\n let buttonIndex = typeof args?.buttonIndex === 'number' ? args.buttonIndex : -1;\n if (buttonIndex < 0) {\n const btnLower = button.toLowerCase();\n buttonIndex = buttons.findIndex(b => b.toLowerCase().includes(btnLower));\n }\n if (buttonIndex < 0) {\n if (action === 'reject' || action === 'deny') {\n buttonIndex = buttons.findIndex(b => /deny|reject|no/i.test(b));\n if (buttonIndex < 0) buttonIndex = buttons.length - 1;\n } else if (action === 'always' || /always/i.test(button)) {\n buttonIndex = buttons.findIndex(b => /always/i.test(b));\n if (buttonIndex < 0) buttonIndex = 1;\n } else {\n buttonIndex = 0; // approve → first option (default selected)\n }\n }\n if (typeof (adapter as any).resolveModal === 'function') {\n (adapter as any).resolveModal(buttonIndex);\n } else {\n const keys = '\\x1B[B'.repeat(Math.max(0, buttonIndex)) + '\\r';\n (adapter as any).writeRaw?.(keys);\n }\n LOG.info('Command', `[resolveAction] CLI PTY → buttonIndex=${buttonIndex} \"${buttons[buttonIndex] ?? '?'}\"`);\n return { success: true, buttonIndex, button: buttons[buttonIndex] ?? button };\n }\n\n // 1. Extension: via AgentStreamManager\n if (provider?.category === 'extension' && h.agentStream && h.getCdp()) {\n const ok = await h.agentStream.resolveAgentAction(\n h.getCdp()!, provider.type, action, h.currentIdeType\n );\n return { success: ok };\n }\n\n // 2. Webview Provider script\n if (provider?.scripts?.webviewResolveAction || provider?.scripts?.webview_resolve_action) {\n const script = h.getProviderScript('webviewResolveAction', { action, button, buttonText: button })\n || h.getProviderScript('webview_resolve_action', { action, button, buttonText: button });\n if (script) {\n const cdp = h.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 LOG.info('Command', `[resolveAction] webview script result: ${JSON.stringify(result)}`);\n\n if (result?.resolved) return { success: true, clicked: result.clicked };\n if (result?.found && result.x != null && result.y != null) {\n LOG.info('Command', `[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 = h.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 LOG.info('Command', `[resolveAction] script result: ${JSON.stringify(result)}`);\n\n if (result?.resolved) {\n LOG.info('Command', `[resolveAction] script-click resolved — \"${result.clicked}\"`);\n return { success: true, clicked: result.clicked };\n }\n if (result?.found && result.x != null && result.y != null) {\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 LOG.info('Command', `[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 Commands — cdpEval, screenshot, cdpCommand, cdpBatch, cdpRemoteAction,\n * discoverAgents, file operations\n */\n\nimport type { CommandResult, CommandHelpers } from './handler.js';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\n\n// ─── CDP direct commands ──────────────────────────\n\nexport async function handleCdpEval(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.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 h.getCdp()!.evaluate(expression, 50000);\n return { success: true, result };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n}\n\nexport async function handleScreenshot(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n try {\n const buf = await h.getCdp()!.captureScreenshot();\n if (buf) {\n const b64 = buf.toString('base64');\n return { success: true, result: b64, base64: b64, screenshot: b64, format: 'webp' };\n }\n return { success: false, error: 'Screenshot failed' };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n}\n\nexport async function handleCdpCommand(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.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 h.getCdp()!.sendCdpCommand(method, params);\n return { success: true, result };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n}\n\nexport async function handleCdpBatch(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.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 h.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\nexport async function handleCdpRemoteAction(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.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 await h.getCdp()!.send('Input.dispatchKeyEvent', {\n type: 'keyDown', key,\n ...(modifiers?.ctrl ? { modifiers: 2 } : {}),\n ...(modifiers?.shift ? { modifiers: 8 } : {}),\n });\n await h.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 if ((x === undefined || y === undefined) && nx !== undefined && ny !== undefined) {\n const viewport = await h.getCdp()!.evaluate(\n 'JSON.stringify({ w: window.innerWidth, h: window.innerHeight })'\n ) as string;\n const { w, h: vh } = JSON.parse(viewport);\n x = Math.round(nx * w);\n y = Math.round(ny * vh);\n }\n if (x === undefined || y === undefined) {\n return { success: false, error: 'No coordinates provided (x,y or nx,ny required)' };\n }\n await h.getCdp()!.send('Input.dispatchMouseEvent', {\n type: 'mousePressed', x, y, button: btn || 'left', clickCount: 1,\n });\n await h.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 h.getCdp()!.send('Input.dispatchKeyEvent', {\n type: 'keyDown', text: char, key: char,\n });\n await h.getCdp()!.send('Input.dispatchKeyEvent', { type: 'keyUp', key: char });\n }\n return { success: true };\n }\n case 'page_screenshot': return handleScreenshot(h, args);\n case 'page_eval': return handleCdpEval(h, params);\n case 'dom_query': {\n const html = await h.getCdp()!.querySelector(params?.selector);\n return { success: true, html };\n }\n case 'input_wheel': {\n let { x, y, nx, ny, deltaX, deltaY } = params;\n if ((x === undefined || y === undefined) && nx !== undefined && ny !== undefined) {\n const viewport = await h.getCdp()!.evaluate(\n 'JSON.stringify({ w: window.innerWidth, h: window.innerHeight })'\n ) as string;\n const { w, h: vh } = JSON.parse(viewport);\n x = Math.round(nx * w);\n y = Math.round(ny * vh);\n }\n await h.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\nexport async function handleDiscoverAgents(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n const agents = await h.getCdp()!.discoverAgentWebviews();\n return { success: true, agents };\n}\n\n// ─── File commands ─────────────────────────────\n\nfunction 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\nexport async function handleFileRead(h: CommandHelpers, args: any): Promise<CommandResult> {\n try {\n const filePath = 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\nexport async function handleFileWrite(h: CommandHelpers, args: any): Promise<CommandResult> {\n try {\n const filePath = 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\nexport async function handleFileList(h: CommandHelpers, args: any): Promise<CommandResult> {\n try {\n const dirPath = 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\nexport async function handleFileListBrowse(h: CommandHelpers, args: any): Promise<CommandResult> {\n return handleFileList(h, args);\n}\n","/**\n * Stream Commands — Agent Stream, PTY I/O, Provider Settings,\n * IDE Extension Settings, Extension Script Execution\n */\n\nimport type { CommandResult, CommandHelpers } from './handler.js';\nimport type { ProviderLoader } from '../providers/provider-loader.js';\nimport { loadConfig } from '../config/config.js';\nimport { LOG } from '../logging/logger.js';\n\n// ─── Agent Stream commands ───────────────────────\n\nexport async function handleAgentStreamSwitch(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || null;\n await h.agentStream.switchActiveAgent(h.getCdp()!, agentType);\n return { success: true, activeAgent: agentType };\n}\n\nexport async function handleAgentStreamRead(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const streams = await h.agentStream.collectAgentStreams(h.getCdp()!);\n return { success: true, streams };\n}\n\nexport async function handleAgentStreamSend(h: CommandHelpers, 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\n if (agentType && h.ctx.adapters) {\n for (const [key, adapter] of h.ctx.adapters.entries()) {\n if (adapter.cliType === agentType || key.includes(agentType)) {\n LOG.info('Command', `[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 LOG.info('Command', `[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\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const resolvedAgent = agentType || h.agentStream.activeAgentType;\n if (!resolvedAgent) return { success: false, error: 'agentType required' };\n const ok = await h.agentStream.sendToAgent(h.getCdp()!, resolvedAgent, text, h.currentIdeType);\n return { success: ok };\n}\n\nexport async function handleAgentStreamResolve(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.agentStream.activeAgentType;\n const action = args?.action as 'approve' | 'reject' || 'approve';\n if (!agentType) return { success: false, error: 'agentType required' };\n const ok = await h.agentStream.resolveAgentAction(h.getCdp()!, agentType, action, h.currentIdeType);\n return { success: ok };\n}\n\nexport async function handleAgentStreamNew(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.agentStream.activeAgentType;\n if (!agentType) return { success: false, error: 'agentType required' };\n const ok = await h.agentStream.newAgentSession(h.getCdp()!, agentType, h.currentIdeType);\n return { success: ok };\n}\n\nexport async function handleAgentStreamListChats(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.agentStream.activeAgentType;\n if (!agentType) return { success: false, error: 'agentType required' };\n const chats = await h.agentStream.listAgentChats(h.getCdp()!, agentType);\n return { success: true, chats };\n}\n\nexport async function handleAgentStreamSwitchSession(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.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 h.agentStream.switchAgentSession(h.getCdp()!, agentType, sessionId);\n return { success: ok };\n}\n\nexport async function handleAgentStreamFocus(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.agentStream.activeAgentType;\n if (!agentType) return { success: false, error: 'agentType required' };\n await h.agentStream.ensureAgentPanelOpen(agentType, h.currentIdeType);\n const ok = await h.agentStream.focusAgentEditor(h.getCdp()!, agentType);\n return { success: ok };\n}\n\n// ─── PTY Raw I/O ──────────────────────────────────\n\nexport function handlePtyInput(h: CommandHelpers, args: any): CommandResult {\n const { cliType, data } = args || {};\n if (!data) return { success: false, error: 'data required' };\n\n if (h.ctx.adapters) {\n const targetCli = cliType || '';\n if (!targetCli && h.ctx.adapters.size > 0) {\n const first = h.ctx.adapters.values().next().value;\n if (first && typeof first.writeRaw === 'function') {\n first.writeRaw(data);\n return { success: true };\n }\n }\n const directAdapter = h.ctx.adapters.get(targetCli);\n if (directAdapter && typeof directAdapter.writeRaw === 'function') {\n directAdapter.writeRaw(data);\n return { success: true };\n }\n for (const [, adapter] of h.ctx.adapters) {\n if (adapter.cliType === targetCli && typeof adapter.writeRaw === 'function') {\n adapter.writeRaw(data);\n return { success: true };\n }\n }\n for (const [key, adapter] of h.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\nexport function handlePtyResize(h: CommandHelpers, 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 (h.ctx.adapters) {\n const targetCli = cliType || '';\n if (!targetCli && h.ctx.adapters.size > 0) {\n const first = h.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 const directAdapter = h.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 for (const [key, adapter] of h.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\nexport function handleGetProviderSettings(h: CommandHelpers, args: any): CommandResult {\n const loader = h.ctx.providerLoader as ProviderLoader | undefined;\n const { providerType } = args || {};\n if (providerType) {\n const schema = loader?.getPublicSettings(providerType) || [];\n const values = loader?.getSettings(providerType) || {};\n return { success: true, providerType, schema, values };\n }\n const allSettings = loader?.getAllPublicSettings() || {};\n const allValues: Record<string, any> = {};\n for (const type of Object.keys(allSettings)) {\n allValues[type] = loader?.getSettings(type) || {};\n }\n return { success: true, settings: allSettings, values: allValues };\n}\n\nexport function handleSetProviderSetting(h: CommandHelpers, args: any): CommandResult {\n const loader = h.ctx.providerLoader as ProviderLoader | undefined;\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 const result = loader?.setSetting(providerType, key, value);\n if (result) {\n if (h.ctx.instanceManager) {\n const allSettings = loader?.getSettings(providerType) || {};\n const updated = h.ctx.instanceManager.updateInstanceSettings(providerType, allSettings);\n LOG.info('Command', `[set_provider_setting] ${providerType}.${key}=${JSON.stringify(value)} → ${updated} instance(s) updated`);\n }\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\nexport async function handleExtensionScript(h: CommandHelpers, args: any, scriptName: string): Promise<CommandResult> {\n const { agentType, ideType } = args || {};\n LOG.info('Command', `[ExtScript] ${scriptName} agentType=${agentType} ideType=${ideType} _currentIdeType=${h.currentIdeType}`);\n if (!agentType) return { success: false, error: 'agentType is required' };\n\n const loader = h.ctx.providerLoader;\n if (!loader) return { success: false, error: 'ProviderLoader not initialized' };\n const provider = loader.resolve(agentType);\n if (!provider) return { success: false, error: `Provider not found: ${agentType}` };\n\n const webviewScriptName = `webview${scriptName.charAt(0).toUpperCase() + scriptName.slice(1)}`;\n const hasWebviewScript = provider.category === 'ide' &&\n !!provider.scripts?.[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 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 const cdpKey = provider.category === 'ide' ? (h.currentIdeType || agentType) : (h.currentIdeType || ideType);\n LOG.info('Command', `[ExtScript] provider=${provider.type} category=${provider.category} cdpKey=${cdpKey}`);\n const cdp = h.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 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 const matchText = provider.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n result = await cdp.evaluateInWebviewFrame(scriptCode, matchFn);\n } else {\n result = await cdp.evaluate(scriptCode, 30000);\n }\n\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\nexport function handleGetIdeExtensions(h: CommandHelpers, args: any): CommandResult {\n const { ideType } = args || {};\n const loader = h.ctx.providerLoader as ProviderLoader | undefined;\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 const extensions = allExtProviders.map(p => ({\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 const connectedIdes = [...(h.ctx.cdpManagers?.keys?.() || [])];\n const result: Record<string, any[]> = {};\n for (const ide of connectedIdes) {\n result[ide] = allExtProviders.map(p => ({\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\nexport function handleSetIdeExtension(h: CommandHelpers, 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 = h.ctx.providerLoader as ProviderLoader | undefined;\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 * workspace_* commands — list/add/remove/default (config.json)\n */\n\nimport { loadConfig, saveConfig } from '../config/config.js';\nimport * as W from '../config/workspaces.js';\nimport { appendWorkspaceActivity, getWorkspaceActivity, removeActivityForPath } from '../config/workspace-activity.js';\n\nexport type WorkspaceCommandResult = { success: boolean;[key: string]: unknown };\n\nexport function handleWorkspaceList(): WorkspaceCommandResult {\n const config = loadConfig();\n const state = W.getWorkspaceState(config);\n return {\n success: true,\n workspaces: state.workspaces,\n defaultWorkspaceId: state.defaultWorkspaceId,\n defaultWorkspacePath: state.defaultWorkspacePath,\n legacyRecentPaths: config.recentCliWorkspaces || [],\n activity: getWorkspaceActivity(config, 25),\n };\n}\n\nexport function handleWorkspaceAdd(args: any): WorkspaceCommandResult {\n const rawPath = (args?.path || args?.dir || '').trim();\n const label = (args?.label || '').trim() || undefined;\n if (!rawPath) return { success: false, error: 'path required' };\n\n const config = loadConfig();\n const result = W.addWorkspaceEntry(config, rawPath, label);\n if ('error' in result) return { success: false, error: result.error };\n\n let cfg = appendWorkspaceActivity(result.config, result.entry.path, {});\n saveConfig(cfg);\n const state = W.getWorkspaceState(cfg);\n return { success: true, entry: result.entry, ...state, activity: getWorkspaceActivity(cfg, 25) };\n}\n\nexport function handleWorkspaceRemove(args: any): WorkspaceCommandResult {\n const id = (args?.id || '').trim();\n if (!id) return { success: false, error: 'id required' };\n\n const config = loadConfig();\n const removed = (config.workspaces || []).find(w => w.id === id);\n const result = W.removeWorkspaceEntry(config, id);\n if ('error' in result) return { success: false, error: result.error };\n\n let cfg = result.config;\n if (removed) {\n cfg = removeActivityForPath(cfg, removed.path);\n }\n saveConfig(cfg);\n const state = W.getWorkspaceState(cfg);\n return { success: true, removedId: id, ...state, activity: getWorkspaceActivity(cfg, 25) };\n}\n\nexport function handleWorkspaceSetDefault(args: any): WorkspaceCommandResult {\n const clear = args?.clear === true || args?.id === null || args?.id === '';\n if (clear) {\n const config = loadConfig();\n const result = W.setDefaultWorkspaceId(config, null);\n if ('error' in result) return { success: false, error: result.error };\n saveConfig(result.config);\n const state = W.getWorkspaceState(result.config);\n return {\n success: true,\n ...state,\n activity: getWorkspaceActivity(result.config, 25),\n };\n }\n\n const pathArg = (args?.path != null && String(args.path).trim()) ? String(args.path).trim() : '';\n const idArg = args?.id !== undefined && args?.id !== null && String(args.id).trim()\n ? String(args.id).trim()\n : '';\n\n if (!pathArg && !idArg) {\n return { success: false, error: 'id or path required (or clear: true)' };\n }\n\n let config = loadConfig();\n let nextId: string;\n\n if (pathArg) {\n let w = W.findWorkspaceByPath(config, pathArg);\n if (!w) {\n const add = W.addWorkspaceEntry(config, pathArg);\n if ('error' in add) return { success: false, error: add.error };\n config = add.config;\n w = add.entry;\n }\n nextId = w.id;\n } else {\n nextId = idArg;\n }\n\n const result = W.setDefaultWorkspaceId(config, nextId);\n if ('error' in result) return { success: false, error: result.error };\n\n let out = result.config;\n const ap = W.getDefaultWorkspacePath(out);\n if (ap) {\n out = appendWorkspaceActivity(out, ap, { kind: 'default' });\n }\n saveConfig(out);\n const state = W.getWorkspaceState(out);\n return { success: true, ...state, activity: getWorkspaceActivity(out, 25) };\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 './detection/ide-detector.js';\nimport { IDEInfo } from './detection/ide-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 workspace paths\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/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 '../detection/ide-detector.js';\nimport { LOG } from '../logging/logger.js';\nimport { VersionArchive } from './version-archive.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 builtinDirs: string[];\n private userDir: string;\n private upstreamDir: string;\n private watchers: fs.FSWatcher[] = [];\n private logFn: (msg: string) => void;\n private versionArchive: VersionArchive | null = null;\n private scriptsCache = new Map<string, Record<string, any>>();\n\n /** Inject VersionArchive so resolve() can auto-detect installed versions */\n setVersionArchive(archive: VersionArchive): void {\n this.versionArchive = archive;\n }\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 | string[];\n userDir?: string;\n logFn?: (msg: string) => void;\n }) {\n // Builtin directories: providers/_builtin/\n if (options?.builtinDir) {\n this.builtinDirs = Array.isArray(options.builtinDir) ? options.builtinDir : [options.builtinDir];\n } else {\n this.builtinDirs = [path.resolve(__dirname, '../providers/_builtin')];\n }\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 || LOG.forComponent('Provider').asLogFn();\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, or multiple array dirs)\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 let builtinCount = 0;\n for (const dir of this.builtinDirs) {\n if (fs.existsSync(dir)) {\n builtinCount += this.loadDir(dir);\n }\n }\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 builtinDirs.`);\n }\n }\n\n /**\n * Get raw provider metadata by type (NO scripts loaded).\n * Use resolve() when you need scripts (readChat, listModels, etc).\n * @deprecated Use getMeta() for metadata or resolve() for scripts.\n */\n get(type: string): ProviderModule | undefined {\n return this.providers.get(type);\n }\n\n /**\n * Get raw provider metadata by type (NO scripts loaded).\n * Safe for: category checks, icon, displayName, targetFilter, cdpPorts.\n * NOT safe for: script execution (readChat, listModels, sendMessage).\n * Use resolve() when scripts are needed.\n */\n getMeta(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/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/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 * Script resolution order:\n * 1. compatibility array (new format — preferred)\n * Provider.json defines: \"compatibility\": [{ \"ideVersion\": \">=1.107.0\", \"scriptDir\": \"scripts/1.107\" }]\n * First matching range wins. Fallback: defaultScriptDir.\n * 2. versions field (legacy format — backward compat)\n * \"versions\": { \"< 1.107.0\": { \"__dir\": \"scripts/legacy\" } }\n * 3. Root scripts.js (original format — no versioning)\n *\n * Version source: context.version → VersionArchive → undefined\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 this.versionArchive?.getLatest(type) ??\n undefined;\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-based script selection\n if (currentVersion) {\n resolved._resolvedVersion = currentVersion;\n\n // --- New format: compatibility array ---\n if (Array.isArray((base as any).compatibility)) {\n const compat = (base as any).compatibility as { ideVersion: string; scriptDir: string }[];\n let matched = false;\n\n for (const entry of compat) {\n if (this.matchesVersion(currentVersion, entry.ideVersion)) {\n const loaded = this.loadScriptsFromDir(type, entry.scriptDir);\n if (loaded) {\n resolved.scripts = loaded;\n this.log(` [compatibility] ${type} v${currentVersion} → ${entry.scriptDir}`);\n matched = true;\n }\n break; // first match wins\n }\n }\n\n // No compatibility match → defaultScriptDir\n if (!matched && (base as any).defaultScriptDir) {\n const loaded = this.loadScriptsFromDir(type, (base as any).defaultScriptDir);\n if (loaded) {\n resolved.scripts = loaded;\n this.log(` [compatibility] ${type} v${currentVersion} → default: ${(base as any).defaultScriptDir}`);\n }\n resolved._versionWarning = `Version ${currentVersion} not in compatibility matrix. Using default scripts.`;\n }\n\n // --- Legacy format: versions field ---\n } else if (base.versions) {\n for (const [range, override] of Object.entries(base.versions)) {\n if (!this.matchesVersion(currentVersion, range)) continue;\n\n const dirOverride = (override as any).__dir as string | undefined;\n if (dirOverride) {\n const loaded = this.loadScriptsFromDir(type, dirOverride);\n if (loaded) {\n resolved.scripts = loaded;\n this.log(` [version override] ${type} ${range} → ${dirOverride}`);\n }\n } else if (override.scripts) {\n resolved.scripts = { ...resolved.scripts, ...override.scripts };\n }\n }\n }\n } else if (Array.isArray((base as any).compatibility) && (base as any).defaultScriptDir) {\n // No version detected but compatibility format → use defaultScriptDir\n const loaded = this.loadScriptsFromDir(type, (base as any).defaultScriptDir);\n if (loaded) {\n resolved.scripts = loaded;\n this.log(` [compatibility] ${type} no version detected → default: ${(base as any).defaultScriptDir}`);\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 * Load scripts from a scriptDir within a provider directory.\n * Tries scripts.js first, then individual .js files.\n */\n private loadScriptsFromDir(type: string, scriptDir: string): Record<string, any> | null {\n const providerDir = this.findProviderDir(type);\n if (!providerDir) {\n this.log(` [loadScriptsFromDir] ${type}: providerDir not found`);\n return null;\n }\n\n const dir = path.join(providerDir, scriptDir);\n if (!fs.existsSync(dir)) {\n this.log(` [loadScriptsFromDir] ${type}: dir not found: ${dir}`);\n return null;\n }\n\n // Return cached scripts if available (cleared on reload/watch)\n const cached = this.scriptsCache.get(dir);\n if (cached) return cached;\n\n // Try scripts.js first\n const scriptsJs = path.join(dir, 'scripts.js');\n if (fs.existsSync(scriptsJs)) {\n try {\n delete require.cache[require.resolve(scriptsJs)];\n const loaded = require(scriptsJs);\n this.log(` [loadScriptsFromDir] ${type}: loaded scripts.js from ${dir} (${Object.keys(loaded).length} exports)`);\n this.scriptsCache.set(dir, loaded);\n return loaded;\n } catch (e) {\n this.log(` ⚠ scripts.js load failed: ${scriptsJs}: ${(e as Error).message}`);\n }\n }\n\n // Fallback: build from individual .js files\n const result = this.buildScriptWrappersFromDir(dir) as Record<string, any>;\n this.log(` [loadScriptsFromDir] ${type}: built wrappers from ${dir} (${Object.keys(result).length} scripts)`);\n this.scriptsCache.set(dir, result);\n return result;\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 this.builtinDirs.forEach(dir => watchDir(dir));\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 caches\n this.scriptsCache.clear();\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/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/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 * Find the on-disk directory for a provider by type.\n * Checks builtinDir, upstreamDir, userDir in order.\n */\n private findProviderDir(type: string): string | null {\n const provider = this.providers.get(type);\n if (!provider) return null;\n const cat = provider.category;\n\n const searchRoots = [this.userDir, this.upstreamDir, ...this.builtinDirs];\n for (const root of searchRoots) {\n if (!fs.existsSync(root)) continue;\n // Direct: root/type or root/cat/type\n for (const candidate of [path.join(root, type), path.join(root, cat, type)]) {\n if (fs.existsSync(path.join(candidate, 'provider.json'))) return candidate;\n }\n // Scan category dir for type match\n const catDir = path.join(root, 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 }\n return null;\n }\n\n /**\n * Build a scripts function map from individual .js files in a directory.\n * Each file is wrapped as: (params?) => fs.readFileSync(filePath, 'utf-8')\n * (template substitution is NOT applied here — scripts.js handles that)\n */\n private buildScriptWrappersFromDir(dir: string): Partial<ProviderScripts> {\n // Use a dedicated scripts.js in the alt dir if present\n const scriptsJs = path.join(dir, 'scripts.js');\n if (fs.existsSync(scriptsJs)) {\n try {\n delete require.cache[require.resolve(scriptsJs)];\n return require(scriptsJs);\n } catch { /* fall through to individual file loading */ }\n }\n\n // Individual files: list_models.js → scripts.listModels, etc.\n const toCamel = (name: string) =>\n name.replace(/_([a-z])/g, (_, c) => c.toUpperCase());\n\n const result: Partial<ProviderScripts> = {};\n try {\n for (const file of fs.readdirSync(dir)) {\n if (!file.endsWith('.js')) continue;\n const scriptName = toCamel(file.replace('.js', ''));\n const filePath = path.join(dir, file);\n (result as any)[scriptName] = (..._args: any[]): string => {\n try { return fs.readFileSync(filePath, 'utf-8'); } catch { return ''; }\n };\n }\n } catch { /* ignore */ }\n return result;\n }\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 // Skip for compatibility-format providers — scripts loaded lazily in resolve()\n const hasCompatibility = Array.isArray((mod as any).compatibility);\n const scriptsPath = path.join(d, 'scripts.js');\n if (!hasCompatibility && 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 // Identify source tier for debugging\n const source = d.startsWith(this.userDir) && !d.includes('.upstream')\n ? 'user' : d.startsWith(this.upstreamDir) ? 'upstream' : 'builtin';\n const overrideWarning = existed && source === 'user' ? ' ⚠ OVERRIDES builtin/upstream' : '';\n this.log(` ${existed ? '🔄' : '✅'} ${mod.type} (${mod.category}) — ${mod.name} [${source}]${overrideWarning}`);\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 * DaemonCommandRouter — Unified command routing for daemon-level commands\n *\n * Extracted from cloud daemon's executeDaemonCommand() logic.\n * Used by both daemon-cloud and daemon-standalone.\n *\n * Routing flow:\n * 1. Daemon-level commands (launch_ide, stop_ide, restart_ide, etc.) → handled here\n * 2. CLI/ACP commands → delegated to cliManager\n * 3. Everything else → delegated to commandHandler.handle()\n */\n\nimport { DaemonCdpManager } from '../cdp/manager.js';\nimport { registerExtensionProviders } from '../cdp/setup.js';\nimport { DaemonCommandHandler } from './handler.js';\nimport { DaemonCliManager } from './cli-manager.js';\nimport type { ProviderLoader } from '../providers/provider-loader.js';\nimport type { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport { launchWithCdp } from '../launch.js';\nimport { loadConfig, saveConfig, updateConfig } from '../config/config.js';\nimport { resolveIdeLaunchWorkspace } from '../config/workspaces.js';\nimport { appendWorkspaceActivity } from '../config/workspace-activity.js';\nimport { detectIDEs } from '../detection/ide-detector.js';\nimport { LOG } from '../logging/logger.js';\nimport { logCommand } from '../logging/command-log.js';\nimport { getRecentLogs, LOG_PATH } from '../logging/logger.js';\nimport * as fs from 'fs';\n\n// ─── Types ───\n\nexport interface CommandRouterDeps {\n commandHandler: DaemonCommandHandler;\n cliManager: DaemonCliManager;\n cdpManagers: Map<string, DaemonCdpManager>;\n providerLoader: ProviderLoader;\n instanceManager: ProviderInstanceManager;\n /** Reference to detected IDEs array (mutable — router updates it) */\n detectedIdes: { value: any[] };\n /** UUID instanceId → CDP manager key mapping */\n instanceIdMap: Map<string, string>;\n /** Callback for CDP manager creation after launch_ide (cloud: setupCdpManager, standalone: no-op) */\n onCdpManagerCreated?: (ideType: string, manager: DaemonCdpManager) => void;\n /** Callback after IDE connected (e.g., startAgentStreamPolling) */\n onIdeConnected?: () => void;\n /** Callback after status change (stop_ide, restart) */\n onStatusChange?: () => void;\n /** Callback after chat-related commands (cloud: throttled report) */\n onPostChatCommand?: () => void;\n /** Get a connected CDP manager (for agent stream reset check) */\n getCdpLogFn?: (ideType: string) => (msg: string) => void;\n}\n\nexport interface CommandRouterResult {\n success: boolean;\n [key: string]: unknown;\n}\n\n// Commands that trigger post-chat status updates\nconst CHAT_COMMANDS = [\n 'send_chat', 'new_chat', 'switch_chat', 'set_mode',\n 'change_model', 'agent_stream_send',\n];\n\nexport class DaemonCommandRouter {\n private deps: CommandRouterDeps;\n\n constructor(deps: CommandRouterDeps) {\n this.deps = deps;\n }\n\n /**\n * Unified command routing.\n * Returns result for all commands:\n * 1. Daemon-level commands (launch_ide, stop_ide, etc.)\n * 2. CLI commands (launch_cli, stop_cli, agent_command)\n * 3. DaemonCommandHandler delegation (CDP/agent-stream/file commands)\n *\n * @param cmd Command name\n * @param args Command arguments\n * @param source Log source ('ws' | 'p2p' | 'standalone' | etc.)\n */\n async execute(cmd: string, args: any, source: string = 'unknown'): Promise<CommandRouterResult> {\n const cmdStart = Date.now();\n\n try {\n // 1. Try daemon-level command\n const daemonResult = await this.executeDaemonCommand(cmd, args);\n if (daemonResult) {\n logCommand({ ts: new Date().toISOString(), cmd, source: source as any, args, success: daemonResult.success, durationMs: Date.now() - cmdStart });\n return daemonResult;\n }\n\n // 2. Delegate to DaemonCommandHandler\n const handlerResult = await this.deps.commandHandler.handle(cmd, args);\n logCommand({ ts: new Date().toISOString(), cmd, source: source as any, args, success: handlerResult.success, durationMs: Date.now() - cmdStart });\n\n // 3. Post-chat command callback\n if (CHAT_COMMANDS.includes(cmd) && this.deps.onPostChatCommand) {\n this.deps.onPostChatCommand();\n }\n\n return handlerResult;\n } catch (e: any) {\n logCommand({ ts: new Date().toISOString(), cmd, source: source as any, args, success: false, error: e.message, durationMs: Date.now() - cmdStart });\n throw e;\n }\n }\n\n // ─── Daemon-level command core ───────────────────\n\n /**\n * Daemon-level command execution (IDE start/stop/restart, CLI, detect, logs).\n * Returns null if not handled at this level → caller delegates to CommandHandler.\n */\n private async executeDaemonCommand(cmd: string, args: any): Promise<CommandRouterResult | null> {\n switch (cmd) {\n // ─── CLI / ACP commands ───\n case 'launch_cli':\n case 'stop_cli':\n case 'agent_command': {\n return this.deps.cliManager.handleCliCommand(cmd, args);\n }\n\n // ─── Logs ───\n case 'get_logs': {\n const count = parseInt(args?.count) || parseInt(args?.lines) || 100;\n const minLevel = args?.minLevel || 'info';\n const sinceTs = args?.since || 0;\n\n try {\n // Priority 1: ring buffer (fast and structured)\n let logs = getRecentLogs(count, minLevel);\n if (sinceTs > 0) {\n logs = logs.filter((l: any) => l.ts > sinceTs);\n }\n if (logs.length > 0) {\n return { success: true, logs, totalBuffered: logs.length };\n }\n // Priority 2: file fallback\n if (fs.existsSync(LOG_PATH)) {\n const content = fs.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, logs: [], totalBuffered: 0 };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\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.deps.cdpManagers.has(targetType) ||\n this.deps.providerLoader.getMeta(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.deps.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 // ─── IDE launch + CDP connect ───\n case 'launch_ide': {\n const ideKey = args?.ideId || args?.ideType;\n const resolvedWorkspace = resolveIdeLaunchWorkspace(\n {\n workspace: args?.workspace,\n workspaceId: args?.workspaceId,\n useDefaultWorkspace: args?.useDefaultWorkspace,\n },\n loadConfig(),\n );\n const launchArgs = {\n ideId: ideKey,\n workspace: resolvedWorkspace,\n newWindow: args?.newWindow,\n };\n LOG.info('LaunchIDE', `target=${ideKey || 'auto'}`);\n const result = await launchWithCdp(launchArgs);\n\n if (result.success && result.port && result.ideId && !this.deps.cdpManagers.has(result.ideId)) {\n const logFn = this.deps.getCdpLogFn\n ? this.deps.getCdpLogFn(result.ideId)\n : LOG.forComponent(`CDP:${result.ideId}`).asLogFn();\n const provider = this.deps.providerLoader.getMeta(result.ideId);\n const manager = new DaemonCdpManager(result.port, logFn, undefined, (provider as any)?.targetFilter);\n const connected = await manager.connect();\n if (connected) {\n // Register active extension providers for this IDE in CDP manager\n registerExtensionProviders(this.deps.providerLoader, manager, result.ideId);\n this.deps.cdpManagers.set(result.ideId, manager);\n LOG.info('CDP', `Connected: ${result.ideId} (port ${result.port})`);\n LOG.info('CDP', `${this.deps.cdpManagers.size} IDE(s) connected`);\n\n // Notify consumer (cloud: setupCdpManager, standalone: setupIdeInstance)\n this.deps.onCdpManagerCreated?.(result.ideId, manager);\n }\n }\n this.deps.onIdeConnected?.();\n if (result.success && resolvedWorkspace) {\n try {\n saveConfig(appendWorkspaceActivity(loadConfig(), resolvedWorkspace, {\n kind: 'ide',\n agentType: result.ideId,\n }));\n } catch { /* ignore activity persist errors */ }\n }\n return { success: result.success, ...result as any };\n }\n\n // ─── IDE detection ───\n case 'detect_ides': {\n this.deps.detectedIdes.value = await detectIDEs();\n return { success: true, ides: this.deps.detectedIdes.value };\n }\n\n // ─── Machine Settings ───\n case 'set_machine_nickname': {\n const nickname = args?.nickname;\n updateConfig({ machineNickname: nickname || null });\n return { success: true };\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.deps.cdpManagers.get(ideType);\n if (cdp) {\n try { cdp.disconnect(); } catch { /* noop */ }\n this.deps.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.deps.instanceManager.getInstance(instanceKey) as any;\n if (ideInstance) {\n // Remove IDE and child Extension UUIDs from instanceIdMap\n if (ideInstance.getInstanceId) {\n this.deps.instanceIdMap.delete(ideInstance.getInstanceId());\n }\n if (ideInstance.getExtensionInstances) {\n for (const ext of ideInstance.getExtensionInstances()) {\n if (ext.getInstanceId) this.deps.instanceIdMap.delete(ext.getInstanceId());\n }\n }\n this.deps.instanceManager.removeInstance(instanceKey);\n LOG.info('StopIDE', `Instance removed: ${instanceKey}`);\n }\n\n // 3. Notify consumer for status update\n this.deps.onStatusChange?.();\n LOG.info('StopIDE', `IDE stopped: ${ideType}`);\n }\n}\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 * 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/config.js';\nimport { getWorkspaceState } from '../config/workspaces.js';\nimport { getHostMemorySnapshot } from '../system/host-memory.js';\nimport { getWorkspaceActivity } from '../config/workspace-activity.js';\nimport { LOG } from '../logging/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 || LOG.forComponent('Status').asLogFn();\n }\n\n // ─── Lifecycle ───────────────────────────────────\n\n startReporting(): void {\n setTimeout(() => {\n this.sendUnifiedStatusReport().catch(e => LOG.warn('Status', `Initial report failed: ${e?.message}`));\n }, 2000);\n\n const scheduleServerReport = () => {\n this.statusTimer = setTimeout(() => {\n this.sendUnifiedStatusReport().catch(e => LOG.warn('Status', `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 => LOG.warn('Status', `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 => LOG.warn('Status', `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 => LOG.warn('Status', `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 /** Reset P2P dedup hash — forces next send to transmit even if content unchanged */\n resetP2PHash(): void {\n this.lastP2PStatusHash = '';\n }\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 // Skip identical repeats at any level to reduce log noise\n const summaryChanged = summary !== this.lastStatusSummary;\n if (summaryChanged) {\n this.lastStatusSummary = summary;\n if (logLevel === 'debug') {\n LOG.debug('StatusReport', summary);\n } else {\n LOG.info('StatusReport', summary);\n }\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 const cfg = loadConfig();\n const wsState = getWorkspaceState(cfg);\n const memSnap = getHostMemorySnapshot();\n\n // ═══ Assemble payload (P2P — required data only) ═══\n const payload: Record<string, any> = {\n daemonMode: true,\n machineNickname: cfg.machineNickname || null,\n workspaces: wsState.workspaces,\n defaultWorkspaceId: wsState.defaultWorkspaceId,\n defaultWorkspacePath: wsState.defaultWorkspacePath,\n workspaceActivity: getWorkspaceActivity(cfg, 15),\n machine: {\n hostname: os.hostname(),\n platform: os.platform(),\n arch: os.arch(),\n cpus: os.cpus().length,\n totalMem: memSnap.totalMem,\n freeMem: memSnap.freeMem,\n availableMem: memSnap.availableMem,\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 defaultWorkspaceId: wsState.defaultWorkspaceId,\n workspaceCount: (wsState.workspaces || []).length,\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, availableMem: _a, 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 * 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 '../detection/cli-detector.js';\nimport { loadConfig, saveConfig, addCliHistory } from '../config/config.js';\nimport { getWorkspaceState, resolveLaunchDirectory } from '../config/workspaces.js';\nimport { appendWorkspaceActivity } from '../config/workspace-activity.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';\nimport { LOG } from '../logging/logger.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 persistRecentDir(cliType: string, dir: string): void {\n try {\n const normalizedType = this.providerLoader.resolveAlias(cliType);\n const provider = this.providerLoader.getByAlias(cliType);\n const actKind = provider?.category === 'acp' ? 'acp' : 'cli';\n let next = loadConfig();\n console.log(chalk.cyan(` 📂 Saving recent workspace: ${dir}`));\n const recent = next.recentCliWorkspaces || [];\n if (!recent.includes(dir)) {\n next = { ...next, recentCliWorkspaces: [dir, ...recent].slice(0, 10) };\n }\n next = appendWorkspaceActivity(next, dir, { kind: actKind, agentType: normalizedType });\n saveConfig(next);\n console.log(chalk.green(` ✓ Recent workspace saved: ${dir}`));\n } catch (e) {\n console.error(chalk.red(` ✗ Failed to save recent workspace: ${e}`));\n }\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.getMeta(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 || '').trim();\n if (!trimmed) throw new Error('working directory required');\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 LOG.warn('CLI', `[ACP] Initial model set failed: ${e?.message}`);\n }\n }\n\n try { addCliHistory({ cliType: normalizedType, dir: resolvedDir, cliArgs }); } catch (e) { LOG.warn('CLI', `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 try {\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 } catch (spawnErr: any) {\n // Spawn failed — cleanup and propagate error\n LOG.error('CLI', `[${cliType}] Spawn failed: ${spawnErr?.message}`);\n instanceManager.removeInstance(key);\n throw new Error(`Failed to start ${cliInfo.displayName}: ${spawnErr?.message}`);\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\n // Monitor for stopped/error → auto-cleanup\n const checkStopped = setInterval(() => {\n try {\n const adapter = this.adapters.get(key);\n if (!adapter) { clearInterval(checkStopped); return; }\n const status = adapter.getStatus?.();\n if (status?.status === 'stopped' || status?.status === 'error') {\n clearInterval(checkStopped);\n setTimeout(() => {\n if (this.adapters.has(key)) {\n this.adapters.delete(key);\n this.deps.removeAgentTracking(key);\n instanceManager.removeInstance(key);\n LOG.info('CLI', `🧹 Auto-cleaned ${status.status} CLI: ${cliType}`);\n this.deps.onStatusChange();\n }\n }, 5000);\n }\n } catch { /* ignore */ }\n }, 3000);\n } else {\n // Fallback: InstanceManager without directly adapter manage\n const adapter = this.createAdapter(cliType, resolvedDir, cliArgs);\n try {\n await adapter.spawn();\n } catch (spawnErr: any) {\n LOG.error('CLI', `[${cliType}] Spawn failed: ${spawnErr?.message}`);\n throw new Error(`Failed to start ${cliInfo.displayName}: ${spawnErr?.message}`);\n }\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' || status?.status === 'error') {\n setTimeout(() => {\n if (this.adapters.get(key) === adapter) {\n this.adapters.delete(key);\n this.deps.removeAgentTracking(key);\n LOG.info('CLI', `🧹 Auto-cleaned ${status.status} 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) { LOG.warn('CLI', `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 try {\n adapter.shutdown();\n } catch (e: any) {\n LOG.warn('CLI', `Shutdown error for ${adapter.cliType}: ${e?.message} (force-cleaning)`);\n }\n // Always cleanup regardless of shutdown success\n this.adapters.delete(key);\n this.deps.removeAgentTracking(key);\n this.deps.getInstanceManager()?.removeInstance(key);\n LOG.info('CLI', `🛑 Agent stopped: ${adapter.cliType} in ${adapter.workingDir}`);\n this.deps.onStatusChange();\n } else {\n // Adapter not found — try InstanceManager direct removal\n const im = this.deps.getInstanceManager();\n if (im) {\n im.removeInstance(key);\n this.deps.removeAgentTracking(key);\n LOG.warn('CLI', `🧹 Force-removed orphan entry: ${key}`);\n this.deps.onStatusChange();\n }\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 config = loadConfig();\n const resolved = resolveLaunchDirectory(\n {\n dir: args?.dir,\n workspaceId: args?.workspaceId,\n useDefaultWorkspace: args?.useDefaultWorkspace === true,\n useHome: args?.useHome === true,\n },\n config,\n );\n if (!resolved.ok) {\n const ws = getWorkspaceState(config);\n return {\n success: false,\n error: resolved.message,\n code: resolved.code,\n workspaces: ws.workspaces,\n defaultWorkspacePath: ws.defaultWorkspacePath,\n };\n }\n const dir = resolved.path;\n const launchSource = resolved.source;\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 this.persistRecentDir(cliType, dir);\n\n return { success: true, cliType, dir, id: newKey, launchSource };\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 cfg = loadConfig();\n const rdir = resolveLaunchDirectory(\n {\n dir: args?.dir,\n workspaceId: args?.workspaceId,\n useDefaultWorkspace: args?.useDefaultWorkspace === true,\n useHome: args?.useHome === true,\n },\n cfg,\n );\n if (!rdir.ok) {\n const ws = getWorkspaceState(cfg);\n return {\n success: false,\n error: rdir.message,\n code: rdir.code,\n workspaces: ws.workspaces,\n defaultWorkspacePath: ws.defaultWorkspacePath,\n };\n }\n const dir = rdir.path;\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 this.persistRecentDir(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 * as path from 'path';\nimport { execSync } from 'child_process';\nimport type { CliAdapter } from '../cli-adapter-types.js';\nimport { LOG } from '../logging/logger.js';\n\nlet pty: any;\ntry {\n pty = require('node-pty');\n // node-pty@1.1.0 ships spawn-helper without +x on macOS — fix it\n if (os.platform() !== 'win32') {\n try {\n const fs = require('fs');\n const ptyDir = path.dirname(require.resolve('node-pty'));\n const arch = os.arch() === 'arm64' ? 'darwin-arm64' : 'darwin-x64';\n const helper = path.join(ptyDir, 'prebuilds', arch, 'spawn-helper');\n if (fs.existsSync(helper)) {\n const stat = fs.statSync(helper);\n if (!(stat.mode & 0o111)) {\n fs.chmodSync(helper, stat.mode | 0o755);\n LOG.info('CLI', '[node-pty] Fixed spawn-helper permissions');\n }\n }\n } catch { /* best-effort */ }\n }\n} catch {\n LOG.error('CLI', '[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\n/** True if file starts with a UTF-8 BOM then #!, or plain #!. */\nfunction isScriptBinary(binaryPath: string): boolean {\n if (!path.isAbsolute(binaryPath)) return false;\n try {\n const fs = require('fs');\n const resolved = fs.realpathSync(binaryPath);\n const head = Buffer.alloc(8);\n const fd = fs.openSync(resolved, 'r');\n fs.readSync(fd, head, 0, 8, 0);\n fs.closeSync(fd);\n let i = 0;\n if (head[0] === 0xef && head[1] === 0xbb && head[2] === 0xbf) i = 3;\n return head[i] === 0x23 && head[i + 1] === 0x21; // '#!'\n } catch {\n return false;\n }\n}\n\n/** True only for Mach-O / ELF — npm shims and shell scripts return false. */\nfunction looksLikeMachOOrElf(filePath: string): boolean {\n if (!path.isAbsolute(filePath)) return false;\n try {\n const fs = require('fs');\n const resolved = fs.realpathSync(filePath);\n const buf = Buffer.alloc(8);\n const fd = fs.openSync(resolved, 'r');\n fs.readSync(fd, buf, 0, 8, 0);\n fs.closeSync(fd);\n let i = 0;\n if (buf[0] === 0xef && buf[1] === 0xbb && buf[2] === 0xbf) i = 3;\n const b = buf.subarray(i);\n if (b.length < 4) return false;\n // ELF\n if (b[0] === 0x7f && b[1] === 0x45 && b[2] === 0x4c && b[3] === 0x46) return true;\n const le = b.readUInt32LE(0);\n const be = b.readUInt32BE(0);\n const magics = [0xfeedface, 0xfeedfacf, 0xcafebabe, 0xbebafeca];\n return magics.some(m => m === le || m === be);\n } catch {\n return false;\n }\n}\n\nfunction shSingleQuote(arg: string): string {\n if (/^[a-zA-Z0-9@%_+=:,./-]+$/.test(arg)) return arg;\n return `'${arg.replace(/'/g, `'\\\\''`)}'`;\n}\n\n/**\n * provider.json stores regex placeholders as `{}` — JSON.parse leaves plain objects,\n * so `.test` is missing and the PTY handler throws on first output. Coerce to RegExp\n * (including `{ \"source\": \"...\", \"flags\": \"i\" }`) or fall back to generic TUIs (Claude Code, etc.).\n */\nfunction parsePatternEntry(x: unknown): RegExp | null {\n if (x instanceof RegExp) return x;\n if (x && typeof x === 'object' && typeof (x as { source?: string }).source === 'string') {\n try {\n const s = x as { source: string; flags?: string };\n return new RegExp(s.source, s.flags || '');\n } catch {\n return null;\n }\n }\n return null;\n}\n\nfunction coercePatternArray(raw: unknown, fallbacks: RegExp[]): RegExp[] {\n if (!Array.isArray(raw)) return [...fallbacks];\n const parsed = raw.map(parsePatternEntry).filter((r): r is RegExp => r != null);\n return parsed.length > 0 ? parsed : [...fallbacks];\n}\n\n/** Defaults tuned for Claude Code / similar agent CLIs when provider.json patterns are empty. */\nconst FALLBACK_PROMPT: RegExp[] = [\n /Type your message/i,\n /^>\\s*$/m, // '>' alone on its own line\n /[›➤]\\s*$/,\n /for shortcuts/i,\n /\\?\\s*for help/i,\n /Press enter/i,\n // NOTE: removed /^[\\s\\u2500-\\u257f]*>\\s*$/m — the box-drawing char range is too wide and\n // can match dialog-clearing ANSI output, causing false prompt detection in approval state.\n];\n\nconst FALLBACK_GENERATING: RegExp[] = [\n /[\\u2800-\\u28ff]/, // Braille spinner blocks (universal TUI)\n /esc to (cancel|interrupt|stop)/i, // Common TUI generation status line\n /generating\\.\\.\\./i,\n /Claude is (?:thinking|processing|working)/i, // Specific Claude Code status\n];\n\nconst FALLBACK_APPROVAL: RegExp[] = [\n /Allow\\s+once/i,\n /Always\\s+allow/i,\n /\\(y\\/n\\)/i,\n /\\[Y\\/n\\]/i,\n /Run\\s+this\\s+command/i,\n // NOTE: removed /Do you want to (?:run|execute|allow)/i — too broad, matches AI explanation\n // text like \"Do you want to allow this feature?\" causing false approval notifications.\n];\n\nfunction defaultCleanOutput(raw: string, _lastUserInput?: string): string {\n return stripAnsi(raw).trim();\n}\n\nexport function normalizeCliProviderForRuntime(raw: any): CliProviderModule {\n const patterns = raw?.patterns || {};\n return {\n ...raw,\n patterns: {\n prompt: coercePatternArray(patterns.prompt, FALLBACK_PROMPT),\n generating: coercePatternArray(patterns.generating, FALLBACK_GENERATING),\n approval: coercePatternArray(patterns.approval, FALLBACK_APPROVAL),\n ready: coercePatternArray(patterns.ready, []),\n },\n cleanOutput: typeof raw?.cleanOutput === 'function' ? raw.cleanOutput : defaultCleanOutput,\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 // Approval state machine\n private approvalTransitionBuffer: string = '';\n private approvalExitTimeout: NodeJS.Timeout | null = null;\n\n // Resize redraw suppression\n private resizeSuppressUntil: 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 = normalizeCliProviderForRuntime(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 LOG.info('CLI', `[${this.cliType}] Spawning in ${this.workingDir}`);\n\n let shellCmd: string;\n let shellArgs: string[];\n const useShellUnix = !isWin && (\n !!spawnConfig.shell\n || !path.isAbsolute(binaryPath)\n || isScriptBinary(binaryPath)\n || !looksLikeMachOOrElf(binaryPath)\n );\n const useShell = isWin ? !!spawnConfig.shell : useShellUnix;\n\n if (useShell) {\n // Execute via shell (npm shims, shebang scripts, anything that is not a bare Mach-O/ELF)\n if (!spawnConfig.shell && !isWin) {\n LOG.info('CLI', `[${this.cliType}] Using login shell (script shim or non-native binary)`);\n }\n shellCmd = isWin ? 'cmd.exe' : (process.env.SHELL || '/bin/zsh');\n const fullCmd = [binaryPath, ...allArgs].map(shSingleQuote).join(' ');\n shellArgs = isWin ? ['/c', fullCmd] : ['-l', '-c', fullCmd];\n } else {\n shellCmd = binaryPath;\n shellArgs = allArgs;\n }\n\n const ptyOpts = {\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 try {\n this.ptyProcess = pty.spawn(shellCmd, shellArgs, ptyOpts);\n } catch (err: any) {\n const msg = err?.message || String(err);\n if (!isWin && !useShell && /posix_spawn|spawn/i.test(msg)) {\n LOG.warn('CLI', `[${this.cliType}] Direct spawn failed (${msg}), retrying via login shell`);\n shellCmd = process.env.SHELL || '/bin/zsh';\n const fullCmd = [binaryPath, ...allArgs].map(shSingleQuote).join(' ');\n shellArgs = ['-l', '-c', fullCmd];\n this.ptyProcess = pty.spawn(shellCmd, shellArgs, ptyOpts);\n } else {\n throw err;\n }\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 LOG.info('CLI', `[${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 // Suppress output processing briefly after resize to avoid false triggers from screen redraws\n if (Date.now() < this.resizeSuppressUntil) return;\n\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 LOG.info('CLI', `[${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 // Capture context before clearing (recentOutputBuffer still has content here)\n const ctxLines = this.recentOutputBuffer.split('\\n')\n .map(l => l.trim())\n .filter(l => l && !/^[─═╭╮╰╯│]+$/.test(l));\n this.isWaitingForResponse = true;\n this.currentStatus = 'waiting_approval';\n this.recentOutputBuffer = '';\n this.approvalTransitionBuffer = '';\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 // Safety timeout — if stuck in waiting_approval, auto-exit after 60s\n if (this.approvalExitTimeout) clearTimeout(this.approvalExitTimeout);\n this.approvalExitTimeout = setTimeout(() => {\n if (this.currentStatus === 'waiting_approval') {\n LOG.warn('CLI', `[${this.cliType}] Approval timeout — auto-exiting waiting_approval`);\n this.activeModal = null;\n this.lastApprovalResolvedAt = Date.now();\n this.recentOutputBuffer = '';\n this.approvalTransitionBuffer = '';\n this.approvalExitTimeout = null;\n this.currentStatus = this.isWaitingForResponse ? 'generating' : 'idle';\n this.onStatusChange?.();\n }\n }, 60000);\n this.onStatusChange?.();\n return;\n }\n\n // ─── Phase 3: Approval release\n // Accumulate chunks into approvalTransitionBuffer — the approval dialog clears via ANSI\n // sequences that strip to nothing, so we can't rely on a single cleanData chunk matching.\n if (this.currentStatus === 'waiting_approval') {\n this.approvalTransitionBuffer = (this.approvalTransitionBuffer + cleanData).slice(-500);\n const genResume = patterns.generating.some(p => p.test(this.approvalTransitionBuffer));\n const promptResume = patterns.prompt.some(p => p.test(this.approvalTransitionBuffer));\n if (genResume) {\n if (this.approvalExitTimeout) { clearTimeout(this.approvalExitTimeout); this.approvalExitTimeout = null; }\n this.currentStatus = 'generating';\n this.activeModal = null;\n this.recentOutputBuffer = '';\n this.approvalTransitionBuffer = '';\n this.lastApprovalResolvedAt = Date.now();\n this.onStatusChange?.();\n } else if (promptResume) {\n if (this.approvalExitTimeout) { clearTimeout(this.approvalExitTimeout); this.approvalExitTimeout = null; }\n this.activeModal = null;\n this.recentOutputBuffer = '';\n this.approvalTransitionBuffer = '';\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 // Only check the LAST 2 lines of cleanData — the prompt appears at the very end of the\n // output stream. Checking the full chunk causes false positives when response content\n // has '>' in code blocks, shell examples, or mid-response lines.\n const trailingLines = cleanData.split('\\n').slice(-2).join('\\n');\n if (patterns.prompt.some(p => p.test(trailingLines))) {\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 if (this.approvalExitTimeout) { clearTimeout(this.approvalExitTimeout); this.approvalExitTimeout = 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 LOG.info('CLI', `[${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.approvalExitTimeout) { clearTimeout(this.approvalExitTimeout); this.approvalExitTimeout = null; }\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 /**\n * Resolve an approval modal by navigating to the button at `buttonIndex` and pressing Enter.\n * Index 0 = first option (already selected by default — just Enter).\n * Index N = press Arrow Down N times, then Enter.\n */\n resolveModal(buttonIndex: number): void {\n if (!this.ptyProcess || this.currentStatus !== 'waiting_approval') return;\n const DOWN = '\\x1B[B'; // Arrow Down\n const keys = DOWN.repeat(Math.max(0, buttonIndex)) + '\\r';\n this.ptyProcess.write(keys);\n }\n\n resize(cols: number, rows: number): void {\n if (this.ptyProcess) {\n try {\n this.ptyProcess.resize(cols, rows);\n // Suppress output for 300ms after resize — PTY redraws the screen and\n // the redrawn content (spinners, status text) would falsely trigger generating detection\n this.resizeSuppressUntil = Date.now() + 300;\n } 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 '../config/chat-history.js';\nimport { LOG } from '../logging/logger.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 LOG.info('CLI', `[${this.type}] status: ${this.lastStatus} → ${newStatus}`);\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 const modal = adapterStatus.activeModal;\n LOG.info('CLI', `[${this.type}] approval modal: \"${modal?.message?.slice(0, 80) ?? 'none'}\"`);\n this.pushEvent({\n event: 'agent:waiting_approval', chatTitle, timestamp: now,\n modalMessage: modal?.message,\n modalButtons: modal?.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 LOG.info('CLI', `[${this.type}] completed in ${duration}s`);\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 * AcpProviderInstance — ACP (Agent Client Protocol) Provider runtime instance\n *\n * Spawns ACP agent process and communicates via the official ACP SDK.\n * Uses ClientSideConnection + ndJsonStream for structured protocol communication.\n *\n * ACP spec: https://agentclientprotocol.com\n * ACP SDK: @agentclientprotocol/sdk@0.16.1\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 { Readable, Writable } from 'stream';\nimport { spawn, type ChildProcess } from 'child_process';\nimport {\n ClientSideConnection,\n ndJsonStream,\n RequestError,\n PROTOCOL_VERSION,\n type Client,\n type Agent,\n type SessionNotification,\n type RequestPermissionRequest,\n type RequestPermissionResponse,\n type WriteTextFileRequest,\n type WriteTextFileResponse,\n type ReadTextFileRequest,\n type ReadTextFileResponse,\n type CreateTerminalRequest,\n type CreateTerminalResponse,\n type TerminalOutputRequest,\n type TerminalOutputResponse,\n type ReleaseTerminalRequest,\n type ReleaseTerminalResponse,\n type WaitForTerminalExitRequest,\n type WaitForTerminalExitResponse,\n type KillTerminalRequest,\n type KillTerminalResponse,\n type SessionUpdate,\n type ToolCallStatus,\n} from '@agentclientprotocol/sdk';\nimport type { ProviderModule, ContentBlock, ToolCallInfo, ToolCallContent as TCC, ToolKind, ToolCallStatus as TCS } from './contracts.js';\nimport { normalizeContent, flattenContent } from './contracts.js';\nimport type { ProviderInstance, ProviderState, ProviderEvent, InstanceContext } from './provider-instance.js';\nimport { StatusMonitor } from './status-monitor.js';\nimport { LOG } from '../logging/logger.js';\n\n// ─── Internal Display Types (dashboard용) ────────────────────────────\n\ninterface AcpMessage {\n role: 'user' | 'assistant' | 'system';\n /** Rich content blocks (ACP standard) or plain text (legacy) */\n content: string | ContentBlock[];\n timestamp?: number;\n /** Tool calls associated with this message */\n toolCalls?: ToolCallInfo[];\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 private readonly log = LOG.forComponent('ACP');\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 connection: ClientSideConnection | null = null;\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 /** Rich content blocks accumulated during streaming */\n private partialBlocks: ContentBlock[] = [];\n /** Tool calls collected during current turn */\n private turnToolCalls: ToolCallInfo[] = [];\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\n const recentMessages = this.messages.slice(-50).map(m => {\n const content = this.truncateContent(m.content);\n return {\n role: m.role,\n content,\n timestamp: m.timestamp,\n toolCalls: m.toolCalls,\n };\n });\n\n // generating during partial response add\n if (this.currentStatus === 'generating' && (this.partialContent || this.partialBlocks.length > 0)) {\n const blocks = this.buildPartialBlocks();\n if (blocks.length > 0) {\n recentMessages.push({\n role: 'assistant',\n content: blocks,\n timestamp: Date.now(),\n toolCalls: this.turnToolCalls.length > 0 ? [...this.turnToolCalls] : undefined,\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 this.log.warn(`[${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 => this.log.warn(`[${this.type}] resolvePermission error: ${e?.message}`));\n } else if (event === 'cancel') {\n this.cancelSession().catch(e =>\n this.log.warn(`[${this.type}] cancel error: ${e?.message}`)\n );\n } else if (event === 'change_model' && data?.model) {\n this.setConfigOption('model', data.model).catch(e =>\n this.log.warn(`[${this.type}] change_model error: ${e?.message}`)\n );\n } else if (event === 'set_mode' && data?.mode) {\n this.setMode(data.mode).catch(e =>\n this.log.warn(`[${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 this.log.warn(`[${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 this.log.warn(`[${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 this.log.info(`[${this.type}] Static config ${category} set to: ${value} — restarting agent`);\n await this.restartWithNewConfig();\n return;\n }\n\n if (!this.connection || !this.sessionId) {\n this.log.warn(`[${this.type}] Cannot set config: no active connection/session`);\n return;\n }\n\n try {\n this.log.info(`[${this.type}] Sending session/set_config_option: configId=${opt.configId} value=${value} sessionId=${this.sessionId}`);\n const result = await this.connection.setSessionConfigOption({\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 this.log.info(`[${this.type}] Config ${category} set to: ${value} | response: ${JSON.stringify(result)?.slice(0, 300)}`);\n } catch (e: any) {\n this.log.warn(`[${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 this.log.info(`[${this.type}] Static mode set to: ${modeId} — restarting agent`);\n await this.restartWithNewConfig();\n return;\n }\n\n if (!this.connection || !this.sessionId) {\n this.log.warn(`[${this.type}] Cannot set mode: no active connection/session`);\n return;\n }\n\n try {\n await this.connection.setSessionMode({\n sessionId: this.sessionId,\n modeId,\n });\n this.currentMode = modeId;\n this.log.info(`[${this.type}] Mode set to: ${modeId}`);\n } catch (e: any) {\n this.log.warn(`[${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 this.connection = null;\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 /** Update settings at runtime (called when user changes settings from dashboard) */\n updateSettings(newSettings: Record<string, any>): void {\n this.settings = { ...this.settings, ...newSettings };\n this.monitor.updateConfig({\n approvalAlert: this.settings.approvalAlert !== false,\n longGeneratingAlert: this.settings.longGeneratingAlert !== false,\n longGeneratingThresholdSec: this.settings.longGeneratingThresholdSec || 180,\n });\n this.log.info(`[${this.type}] Settings updated: ${Object.keys(newSettings).join(', ')}`);\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 this.connection = null;\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 this.log.info(`[${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 // 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 this.log.debug(`[${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 this.log.warn(`[${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 this.log.info(`[${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 this.log.error(`[${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 // ─── SDK Connection Setup ────────────────────────\n // Convert Node.js streams to Web Streams for ndJsonStream\n const webStdin = Writable.toWeb(this.process.stdin!) as WritableStream<Uint8Array>;\n const webStdout = Readable.toWeb(this.process.stdout!) as ReadableStream<Uint8Array>;\n const stream = ndJsonStream(webStdin, webStdout);\n\n // Create ClientSideConnection with our Client implementation\n this.connection = new ClientSideConnection((_agent: Agent) => this.createClient(), stream);\n\n // Listen for connection close\n this.connection.signal.addEventListener('abort', () => {\n this.log.info(`[${this.type}] ACP connection closed`);\n });\n\n // ACP initialize handshake\n await this.initialize();\n }\n\n // ─── Client Interface Implementation ────────────────────\n\n private createClient(): Client {\n return {\n requestPermission: async (params: RequestPermissionRequest): Promise<RequestPermissionResponse> => {\n // Update active tool calls from the request\n const tc = params.toolCall;\n const existing = this.activeToolCalls.find(t => t.id === tc.toolCallId);\n if (existing) {\n existing.status = 'running';\n if (tc.title) existing.name = tc.title;\n } else {\n this.activeToolCalls.push({\n id: tc.toolCallId,\n name: tc.title || 'unknown',\n status: 'running',\n input: tc.rawInput ? (typeof tc.rawInput === 'string' ? tc.rawInput : JSON.stringify(tc.rawInput)) : undefined,\n });\n }\n\n // ─── Auto-approve: skip user confirmation ───\n if (this.settings.autoApprove) {\n this.log.info(`[${this.type}] Auto-approving: ${tc.title || tc.toolCallId}`);\n const allowOption = params.options.find(o => o.kind === 'allow_once') || params.options.find(o => o.kind === 'allow_always');\n if (allowOption) {\n return { outcome: { outcome: 'selected', optionId: allowOption.optionId } };\n }\n return { outcome: { outcome: 'selected', optionId: params.options[0]?.optionId || '' } };\n }\n\n // Approval request → switch to waiting_approval status\n this.currentStatus = 'waiting_approval';\n this.detectStatusTransition();\n\n // Wait for user approval\n const approved = await new Promise<boolean>((resolve) => {\n this.permissionResolvers.push(resolve);\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 if (approved) {\n // Find the \"allow\" option (allow_once or allow_always)\n const allowOption = params.options.find(o => o.kind === 'allow_once') || params.options.find(o => o.kind === 'allow_always');\n if (allowOption) {\n return { outcome: { outcome: 'selected', optionId: allowOption.optionId } };\n }\n // Fallback: use first option\n return { outcome: { outcome: 'selected', optionId: params.options[0]?.optionId || '' } };\n } else {\n // Find the \"reject\" option\n const rejectOption = params.options.find(o => o.kind === 'reject_once') || params.options.find(o => o.kind === 'reject_always');\n if (rejectOption) {\n return { outcome: { outcome: 'selected', optionId: rejectOption.optionId } };\n }\n return { outcome: { outcome: 'cancelled' } };\n }\n },\n\n sessionUpdate: async (params: SessionNotification): Promise<void> => {\n this.handleSessionUpdate(params);\n },\n\n // File system — not supported\n readTextFile: async (_params: ReadTextFileRequest): Promise<ReadTextFileResponse> => {\n throw RequestError.methodNotFound('fs/read_text_file');\n },\n writeTextFile: async (_params: WriteTextFileRequest): Promise<WriteTextFileResponse> => {\n throw RequestError.methodNotFound('fs/write_text_file');\n },\n\n // Terminal — not supported\n createTerminal: async (_params: CreateTerminalRequest): Promise<CreateTerminalResponse> => {\n throw RequestError.methodNotFound('terminal/create');\n },\n terminalOutput: async (_params: TerminalOutputRequest): Promise<TerminalOutputResponse> => {\n throw RequestError.methodNotFound('terminal/output');\n },\n releaseTerminal: async (_params: ReleaseTerminalRequest): Promise<ReleaseTerminalResponse> => {\n throw RequestError.methodNotFound('terminal/release');\n },\n waitForTerminalExit: async (_params: WaitForTerminalExitRequest): Promise<WaitForTerminalExitResponse> => {\n throw RequestError.methodNotFound('terminal/wait_for_exit');\n },\n killTerminal: async (_params: KillTerminalRequest): Promise<KillTerminalResponse> => {\n throw RequestError.methodNotFound('terminal/kill');\n },\n };\n }\n\n // ─── ACP Protocol (via SDK) ────────────────────────────\n\n private async initialize(): Promise<void> {\n if (!this.connection) return;\n\n try {\n const result = await this.connection.initialize({\n protocolVersion: PROTOCOL_VERSION,\n clientCapabilities: {},\n });\n\n this.agentCapabilities = result?.agentCapabilities || {};\n this.log.info(`[${this.type}] Initialized. Agent capabilities: ${JSON.stringify(this.agentCapabilities)}`);\n\n // new session create\n await this.createSession();\n } catch (e: any) {\n this.log.error(`[${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 if (!this.connection) return;\n\n try {\n const result = await this.connection.newSession({\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 this.log.info(`[${this.type}] session/new result keys: ${result ? Object.keys(result).join(', ') : 'null'}`);\n if (result?.configOptions) this.log.debug(`[${this.type}] configOptions: ${JSON.stringify(result.configOptions).slice(0, 500)}`);\n if (result?.modes) this.log.debug(`[${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 this.log.info(`[${this.type}] Using static configOptions (${this.configOptions.length} options)`);\n }\n\n this.log.info(`[${this.type}] Session created: ${this.sessionId}${this.currentModel ? ` (model: ${this.currentModel})` : ''}${this.currentMode ? ` (mode: ${this.currentMode})` : ''}`);\n if (this.configOptions.length > 0) {\n this.log.info(`[${this.type}] Config options: ${this.configOptions.map(c => `${c.category}(${c.options.length})`).join(', ')}`);\n }\n } catch (e: any) {\n this.log.warn(`[${this.type}] session/new failed: ${e?.message}`);\n this.currentStatus = 'idle';\n }\n }\n\n async sendPrompt(text: string, contentBlocks?: ContentBlock[]): Promise<void> {\n if (!this.connection || !this.sessionId) {\n this.log.warn(`[${this.type}] Cannot send prompt: no active connection/session`);\n return;\n }\n\n // Build prompt content\n let promptParts: any[];\n if (contentBlocks && contentBlocks.length > 0) {\n // Rich content — forward ContentBlock[] as ACP prompt parts\n promptParts = contentBlocks.map(b => {\n if (b.type === 'text') return { type: 'text', text: (b as any).text };\n if (b.type === 'image') return { type: 'image', data: (b as any).data, mimeType: (b as any).mimeType };\n if (b.type === 'resource_link') return { type: 'resource_link', uri: (b as any).uri, name: (b as any).name };\n if (b.type === 'resource') return { type: 'resource', resource: (b as any).resource };\n return { type: 'text', text: flattenContent([b]) };\n });\n } else {\n promptParts = [{ type: 'text', text }];\n }\n\n // Add user message locally (store as ContentBlock[])\n this.messages.push({\n role: 'user',\n content: contentBlocks && contentBlocks.length > 0 ? contentBlocks : text,\n timestamp: Date.now(),\n });\n\n this.currentStatus = 'generating';\n this.partialContent = '';\n this.partialBlocks = [];\n this.turnToolCalls = [];\n this.detectStatusTransition();\n this.log.info(`[${this.type}] Sending prompt: \"${text.slice(0, 100)}\" (${promptParts.length} parts)`);\n\n try {\n const result = await this.connection.prompt({\n sessionId: this.sessionId,\n prompt: promptParts,\n });\n\n // Prompt complete → reflect final message\n if (result?.stopReason) {\n this.stopReason = result.stopReason;\n }\n this.log.info(`[${this.type}] Prompt completed: stopReason=${result?.stopReason} partialContent=${this.partialContent.length} chars partialBlocks=${this.partialBlocks.length}`);\n\n // Build final assistant message with rich content\n this.finalizeAssistantMessage();\n\n this.currentStatus = 'idle';\n this.detectStatusTransition();\n } catch (e: any) {\n this.log.warn(`[${this.type}] prompt error: ${e?.message}`);\n this.finalizeAssistantMessage();\n this.currentStatus = 'idle';\n this.detectStatusTransition();\n }\n }\n\n private async cancelSession(): Promise<void> {\n if (!this.connection || !this.sessionId) return;\n\n await this.connection.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 // ─── ACP session/update handle ─────────────────────\n\n private handleSessionUpdate(params: SessionNotification): void {\n if (!params) return;\n\n const update = params.update as SessionUpdate & Record<string, any>;\n this.log.debug(`[${this.type}] sessionUpdate: ${update.sessionUpdate} | keys=${Object.keys(update).join(',')}`);\n\n switch (update.sessionUpdate) {\n case 'agent_message_chunk': {\n const content = update.content;\n if (content?.type === 'text' && (content as any).text) {\n this.partialContent += (content as any).text;\n } else if (content?.type === 'image') {\n // Collect image block\n this.partialBlocks.push({\n type: 'image',\n data: (content as any).data || '',\n mimeType: (content as any).mimeType || 'image/png',\n uri: (content as any).uri,\n });\n } else if (content?.type === 'resource_link') {\n this.partialBlocks.push({\n type: 'resource_link',\n uri: (content as any).uri || '',\n name: (content as any).name || 'resource',\n title: (content as any).title,\n mimeType: (content as any).mimeType,\n size: (content as any).size,\n });\n } else if (content?.type === 'resource') {\n this.partialBlocks.push({\n type: 'resource',\n resource: (content as any).resource,\n });\n }\n this.currentStatus = 'generating';\n break;\n }\n case 'agent_thought_chunk':\n case 'user_message_chunk': {\n // Track but don't display thought chunks as main content\n break;\n }\n case 'tool_call': {\n // New tool call — collect as ToolCallInfo\n const tcId = (update as any).toolCallId || `tc_${Date.now()}`;\n const tcTitle = (update as any).title || 'unknown';\n const tcKind = (update as any).kind as ToolKind | undefined;\n const tcStatus = this.mapToolCallStatus((update as any).status);\n \n this.activeToolCalls.push({\n id: tcId,\n name: tcTitle,\n status: tcStatus,\n input: (update as any).rawInput ? (typeof (update as any).rawInput === 'string' ? (update as any).rawInput : JSON.stringify((update as any).rawInput)) : undefined,\n });\n \n // Also collect as ToolCallInfo for rich content\n const acpStatus = (update as any).status as string || 'in_progress';\n this.turnToolCalls.push({\n toolCallId: tcId,\n title: tcTitle,\n kind: tcKind,\n status: acpStatus as TCS,\n rawInput: (update as any).rawInput,\n content: this.convertToolCallContent((update as any).content),\n locations: (update as any).locations,\n });\n break;\n }\n case 'tool_call_update': {\n // Update existing tool call\n const toolCallId = (update as any).toolCallId;\n const existing = this.activeToolCalls.find(t => t.id === toolCallId);\n if (existing) {\n if ((update as any).status) existing.status = this.mapToolCallStatus((update as any).status);\n if ((update as any).rawOutput) existing.output = typeof (update as any).rawOutput === 'string' ? (update as any).rawOutput : JSON.stringify((update as any).rawOutput);\n }\n // Update ToolCallInfo too\n const tcInfo = this.turnToolCalls.find(t => t.toolCallId === toolCallId);\n if (tcInfo) {\n if ((update as any).status) tcInfo.status = (update as any).status as TCS;\n if ((update as any).rawOutput) tcInfo.rawOutput = (update as any).rawOutput;\n if ((update as any).content) tcInfo.content = this.convertToolCallContent((update as any).content);\n if ((update as any).locations) tcInfo.locations = (update as any).locations;\n }\n break;\n }\n case 'current_mode_update': {\n this.currentMode = (update as any).currentModeId;\n break;\n }\n case 'config_option_update': {\n if ((update as any).configOptions) {\n this.parseConfigOptions((update as any).configOptions);\n }\n break;\n }\n case 'plan':\n case 'available_commands_update':\n case 'session_info_update':\n case 'usage_update':\n // Noted but no specific handling needed\n break;\n default:\n // Unknown update type — try legacy parsing for backward compatibility\n this.handleLegacyUpdate(update as any);\n break;\n }\n }\n\n /** Handle legacy session/update formats (pre-standardization compat) */\n private handleLegacyUpdate(params: any): void {\n // Legacy: messageDelta 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 // Legacy: 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 // Legacy: toolCallUpdate\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 // Legacy: stopReason\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 // Legacy: model info\n if (params.model) {\n this.currentModel = params.model;\n }\n }\n\n /** Map SDK ToolCallStatus to internal status */\n private mapToolCallStatus(status?: ToolCallStatus | string): 'running' | 'completed' | 'failed' {\n switch (status) {\n case 'completed': return 'completed';\n case 'failed': return 'failed';\n case 'pending':\n case 'in_progress':\n default: return 'running';\n }\n }\n\n // ─── Rich Content Helpers ────────────────────────────\n\n /** Truncate content for transport (text: 2000 chars, images preserved) */\n private truncateContent(content: string | ContentBlock[]): string | ContentBlock[] {\n if (typeof content === 'string') {\n return content.length > 2000 ? content.slice(0, 2000) + '\\n... (truncated)' : content;\n }\n return content.map(b => {\n if (b.type === 'text' && b.text.length > 2000) {\n return { ...b, text: b.text.slice(0, 2000) + '\\n... (truncated)' };\n }\n return b;\n });\n }\n\n /** Build ContentBlock[] from current partial state */\n private buildPartialBlocks(): ContentBlock[] {\n const blocks: ContentBlock[] = [];\n if (this.partialContent.trim()) {\n blocks.push({ type: 'text', text: this.partialContent.trim() + '...' });\n }\n blocks.push(...this.partialBlocks);\n return blocks;\n }\n\n /** Finalize streaming content into an assistant message */\n private finalizeAssistantMessage(): void {\n const blocks = this.buildPartialBlocks();\n // Remove trailing '...' from text blocks for final message\n const finalBlocks = blocks.map(b => {\n if (b.type === 'text' && b.text.endsWith('...')) {\n return { ...b, text: b.text.slice(0, -3) };\n }\n return b;\n }).filter(b => b.type !== 'text' || (b as any).text.trim());\n\n if (finalBlocks.length > 0) {\n this.messages.push({\n role: 'assistant',\n content: finalBlocks.length === 1 && finalBlocks[0].type === 'text'\n ? (finalBlocks[0] as any).text // single text → string (backward compat)\n : finalBlocks,\n timestamp: Date.now(),\n toolCalls: this.turnToolCalls.length > 0 ? [...this.turnToolCalls] : undefined,\n });\n }\n this.partialContent = '';\n this.partialBlocks = [];\n this.turnToolCalls = [];\n }\n\n /** Convert ACP ToolCallContent[] to our ToolCallContent[] */\n private convertToolCallContent(acpContent?: any[]): TCC[] | undefined {\n if (!acpContent || !Array.isArray(acpContent)) return undefined;\n return acpContent.map((c: any) => {\n if (c.type === 'diff') {\n return { type: 'diff' as const, path: c.path || '', oldText: c.oldText, newText: c.newText || '' };\n }\n if (c.type === 'terminal') {\n return { type: 'terminal' as const, terminalId: c.terminalId || '' };\n }\n // type: 'content' or unknown\n return { type: 'content' as const, content: c.content || { type: 'text' as const, text: JSON.stringify(c) } };\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 * Provider Output Contracts — Output contracts all providers must conform to\n * \n * Design principles:\n * - Only output format is standardized; implementation is free\n * - Common across all categories (cli, ide, extension)\n * - User custom providers use the same contracts\n */\n\n// ─── readChat() return value ───────────────────────────\n\nexport interface ReadChatResult {\n messages: ChatMessage[];\n status: AgentStatus;\n activeModal?: ModalInfo | null;\n /** IDE/Extension only: session info */\n id?: string;\n title?: string;\n /** Extension only: additional metadata */\n agentType?: string;\n agentName?: string;\n extensionId?: string;\n /** Status metadata */\n isVisible?: boolean;\n isWelcomeScreen?: boolean;\n inputContent?: string;\n model?: string;\n mode?: string;\n autoApprove?: string;\n}\n\nexport interface ChatMessage {\n role: 'user' | 'assistant' | 'system';\n /** Plain text (legacy) or rich content blocks (ACP standard) */\n content: string | ContentBlock[];\n /** Optional: unique message ID */\n id?: string;\n /** Optional: order index */\n index?: number;\n /** Optional: timestamp */\n timestamp?: number;\n /** Optional: receivedAt (assigned by daemon) */\n receivedAt?: number;\n /** Optional: tool calls associated with this message */\n toolCalls?: ToolCallInfo[];\n /** Optional: fiber metadata */\n _type?: string;\n _sub?: string;\n}\n\nexport type AgentStatus = \n | 'idle' \n | 'generating' \n | 'waiting_approval' \n | 'error' \n | 'panel_hidden'\n | 'streaming';\n\nexport interface ModalInfo {\n message: string;\n buttons: string[];\n width?: number;\n height?: number;\n}\n\n// ─── Rich Content Types (ACP Standard) ─────────────────\n// Based on ACP SDK v0.16.1 schema types.\n// All provider categories (ACP, IDE, Extension, CLI) use these as output standard.\n\n/**\n * ContentBlock — ACP ContentBlock union type\n * Represents displayable content in messages, tool call results, etc.\n */\nexport type ContentBlock =\n | TextBlock\n | ImageBlock\n | AudioBlock\n | ResourceLinkBlock\n | ResourceBlock;\n\n/** Text content — ACP TextContent */\nexport interface TextBlock {\n type: 'text';\n text: string;\n annotations?: ContentAnnotations;\n}\n\n/** Image content — ACP ImageContent */\nexport interface ImageBlock {\n type: 'image';\n data: string; // base64-encoded\n mimeType: string; // 'image/png', 'image/jpeg', etc.\n uri?: string; // optional URL reference\n annotations?: ContentAnnotations;\n}\n\n/** Audio content — ACP AudioContent */\nexport interface AudioBlock {\n type: 'audio';\n data: string; // base64-encoded\n mimeType: string;\n annotations?: ContentAnnotations;\n}\n\n/** Resource link (file reference) — ACP ResourceLink */\nexport interface ResourceLinkBlock {\n type: 'resource_link';\n uri: string;\n name: string;\n title?: string;\n description?: string;\n mimeType?: string;\n size?: number;\n annotations?: ContentAnnotations;\n}\n\n/** Embedded resource (inline file) — ACP EmbeddedResource */\nexport interface ResourceBlock {\n type: 'resource';\n resource: TextResourceContents | BlobResourceContents;\n annotations?: ContentAnnotations;\n}\n\nexport interface TextResourceContents {\n uri: string;\n text: string;\n mimeType?: string;\n}\n\nexport interface BlobResourceContents {\n uri: string;\n blob: string; // base64-encoded\n mimeType?: string;\n}\n\nexport interface ContentAnnotations {\n audience?: ('user' | 'assistant')[];\n priority?: number; // 0.0 ~ 1.0\n}\n\n// ─── Tool Call Types (ACP Standard) ─────────────────────\n\n/** Tool call info — ACP ToolCall */\nexport interface ToolCallInfo {\n toolCallId: string;\n title: string;\n kind?: ToolKind;\n status?: ToolCallStatus;\n rawInput?: unknown;\n rawOutput?: unknown;\n content?: ToolCallContent[];\n locations?: ToolCallLocation[];\n}\n\nexport type ToolKind = 'read' | 'edit' | 'delete' | 'move' | 'search' | 'execute' | 'think' | 'fetch' | 'switch_mode' | 'other';\nexport type ToolCallStatus = 'pending' | 'in_progress' | 'completed' | 'failed';\n\n/** Content produced by a tool call — ACP ToolCallContent */\nexport type ToolCallContent =\n | { type: 'content'; content: ContentBlock }\n | { type: 'diff'; path: string; oldText?: string; newText: string }\n | { type: 'terminal'; terminalId: string };\n\nexport interface ToolCallLocation {\n path: string;\n line?: number;\n}\n\n// ─── Content Helpers ────────────────────────────────────\n\n/** Normalize content: string → ContentBlock[] */\nexport function normalizeContent(content: string | ContentBlock[]): ContentBlock[] {\n if (typeof content === 'string') {\n return [{ type: 'text', text: content }];\n }\n return content;\n}\n\n/** Flatten ContentBlock[] → string (backward compat / plain-text extraction) */\nexport function flattenContent(content: string | ContentBlock[]): string {\n if (typeof content === 'string') return content;\n return content\n .filter((b): b is TextBlock => b.type === 'text')\n .map(b => b.text)\n .join('\\n');\n}\n\n/** SendMessage params — supports rich content (ACP PromptRequest compatible) */\nexport interface SendMessageParams {\n /** Shortcut: text-only message */\n text?: string;\n /** Rich content blocks (ACP ContentBlock[]) */\n prompt?: ContentBlock[];\n}\n\n// ─── sendMessage() return value ────────────────────────\n\nexport interface SendMessageResult {\n sent: boolean;\n error?: string;\n /** When CDP Input API is needed (Lexical editor etc) */\n needsTypeAndSend?: boolean;\n selector?: string;\n}\n\n// ─── listSessions() return value ───────────────────────\n\nexport interface ListSessionsResult {\n sessions: SessionInfo[];\n}\n\nexport interface SessionInfo {\n id: string;\n title: string;\n time?: string;\n}\n\n// ─── switchSession() return value ──────────────────────\n\nexport interface SwitchSessionResult {\n switched: boolean;\n /** When CDP click coordinates are needed (Antigravity QuickInput etc) */\n action?: 'click';\n clickX?: number;\n clickY?: number;\n error?: string;\n}\n\n// ─── resolveAction() return value ──────────────────────\n// Two methods supported:\n\n/**\n * Method 1: Script-Click — script calls el.click() directly\n * Cursor Suitable for IDEs using div.cursor-pointer elements.\n */\nexport interface ResolveActionScriptClick {\n resolved: boolean; // true = click succeeded\n clicked?: string; // clicked button text\n available?: string[]; // available buttons when resolved=false\n error?: string;\n}\n\n/**\n * Method 2: Coordinate-Click — returns coordinates, daemon performs CDP mouse click\n * Antigravity Suitable for IDEs where el.click() does not work.\n */\nexport interface ResolveActionCoordinateClick {\n found: boolean; // true = button found\n text?: string; // button text\n x?: number; // click X coordinate\n y?: number; // click Y coordinate\n w?: number; // button width\n h?: number; // button height\n}\n\nexport type ResolveActionResult = ResolveActionScriptClick | ResolveActionCoordinateClick;\n\n\n// ─── Provider Module type ────────────────────────\n\nexport type ProviderCategory = 'cli' | 'ide' | 'extension' | 'acp';\n\n/**\n * Type of object exported by module.exports in provider.js.\n * \n * Each provider.js is fully independent and does not import other providers.\n * Helpers (_helpers/) can be optionally used.\n */\n/**\n * Provider-configurable CDP target filter.\n * Used by DaemonCdpManager to select the correct page/tab to connect to.\n * Without this, the manager uses a hardcoded default filter.\n */\nexport interface CdpTargetFilter {\n /** URL must include this string (e.g. 'workbench.html') */\n urlIncludes?: string;\n /** URL must NOT include any of these strings */\n urlExcludes?: string[];\n /** Page title regex pattern for titles to EXCLUDE (e.g. 'Debug Console|Output') */\n titleExcludes?: string;\n}\n\nexport interface ProviderModule {\n /** Unique identifier (e.g. 'cline', 'cursor', 'gemini-cli') */\n type: string;\n /** Display name (e.g. 'Cline', 'Cursor') */\n name: string;\n /** Category: determines execution method */\n category: ProviderCategory;\n /** Alias list — allows users to invoke by alternate names (e.g. ['claude', 'claude-code']) */\n aliases?: string[];\n\n // ─── IDE infrastructure (used by launch/daemon) ───\n /** CDP ports [primary, secondary] (IDE category only) */\n cdpPorts?: [number, number];\n /** CDP target filter — controls which page/tab to connect to (IDE category only) */\n targetFilter?: CdpTargetFilter;\n /** CLI command (e.g. 'cursor', 'code') */\n cli?: string;\n /** Display icon */\n icon?: string;\n /** Display name (short name) */\n displayName?: string;\n /** Install instructions (shown when command is missing) */\n install?: string;\n /** Custom version detection command (e.g. 'cursor --version', 'claude -v') */\n versionCommand?: string;\n /** Versions tested by provider maintainer (informational) */\n testedVersions?: string[];\n /** Per-OS process names — used by launch.ts to detect/kill IDE processes */\n processNames?: {\n darwin?: string;\n win32?: string[];\n linux?: string[];\n [key: string]: string | string[] | undefined;\n };\n /** Per-OS install paths — used by detector.ts to detect IDE installation */\n paths?: {\n darwin?: string[];\n win32?: string[];\n linux?: string[];\n [key: string]: string[] | undefined;\n };\n\n // ─── Extension category only ───\n extensionId?: string;\n extensionIdPattern?: RegExp;\n\n // ─── CLI category only ───\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 cleanOutput?: (raw: string, lastUserInput?: string) => string;\n\n // ─── CDP scripts (ide/extension category) ───\n scripts?: ProviderScripts;\n\n // ─── VS Code Commands (Extension IPC via) ───\n vscodeCommands?: {\n focusPanel?: string;\n openPanel?: string;\n [key: string]: string | undefined;\n };\n\n // ─── Input method (IDE category — Lexical editor etc) ───\n inputMethod?: 'cdp-type-and-send' | 'script';\n inputSelector?: string;\n\n // ─── Webview chat (IDE category — chat UI is in webview iframe) ───\n /** webview iframe match text (must be contained in body) */\n webviewMatchText?: string;\n\n // ─── Per-OS overrides ───\n os?: {\n [platform: string]: Partial<Pick<ProviderModule, 'scripts' | 'inputMethod' | 'inputSelector'>>;\n };\n\n // ─── Per-version overrides ───\n /** Key: semver range string (e.g. '< 1.107.0', '>= 2.0.0') */\n versions?: {\n [versionRange: string]: Partial<Pick<ProviderModule, 'scripts'>> & {\n /**\n * Load scripts from a subdirectory instead of scripts.js root.\n * Path is relative to the provider directory (e.g. 'scripts/legacy').\n * The subdirectory should contain its own scripts.js or individual .js files.\n */\n __dir?: string;\n };\n };\n\n // ─── Composite override (OS + version) ───\n overrides?: Array<{\n when: { os?: string; version?: string };\n scripts?: Partial<ProviderScripts>;\n /** Load scripts from a subdirectory for this OS+version combination */\n __dir?: string;\n }>;\n\n // ─── Provider Settings (variables controllable from dashboard) ───\n settings?: Record<string, ProviderSettingDef>;\n\n // ─── ACP Static Config (for agents without config/* support) ───\n /** Static options used when agent does not provide configOptions */\n staticConfigOptions?: Array<{\n category: 'model' | 'mode' | 'thought_level' | 'other';\n configId: string;\n defaultValue?: string;\n options: Array<{ value: string; name: string; description?: string; group?: string }>;\n }>;\n /** Function to convert selected config values to spawn args (applied via process restart when config/* not supported) */\n spawnArgBuilder?: (config: Record<string, string>) => string[];\n\n // ─── ACP Authentication (auth method definitions) ───\n /** ACP agent auth methods (multiple supported — in priority order) */\n auth?: AcpAuthMethod[];\n}\n\n// ─── ACP Auth Types ─────────────────────────────────\n\n/** ACP auth method — based on ACP official spec */\nexport type AcpAuthMethod = AcpAuthEnvVar | AcpAuthAgent | AcpAuthTerminal;\n\n/** Environment variable-based auth (API keys etc) */\nexport interface AcpAuthEnvVar {\n type: 'env_var';\n id: string;\n name: string;\n vars: Array<{\n name: string;\n label?: string;\n secret?: boolean; // default true\n optional?: boolean; // default false\n }>;\n link?: string; // Key issuance URL\n}\n\n/** Agent self-auth (OAuth, browser-based etc) */\nexport interface AcpAuthAgent {\n type: 'agent';\n id: string;\n name: string;\n description?: string;\n}\n\n/** Terminal command-based auth (runs setup command) */\nexport interface AcpAuthTerminal {\n type: 'terminal';\n id: string;\n name: string;\n description?: string;\n args?: string[];\n env?: Record<string, string>;\n}\n\n/**\n * CDP script functions.\n * Each function takes a params object and returns a JS code string for CDP evaluate.\n * The JS execution result must conform to the Output Contract.\n * \n * Custom scripts can be added via index signature in addition to built-in scripts.\n * All scripts can receive params: Record<string, any>,\n * backward compatible with legacy single-argument style (e.g. sendMessage(text)).\n */\nexport interface ProviderScripts {\n // ─── Core ───\n readChat?: (params?: Record<string, any>) => string;\n sendMessage?: (params?: Record<string, any>) => string;\n listSessions?: (params?: Record<string, any>) => string;\n switchSession?: (params?: Record<string, any>) => string;\n newSession?: (params?: Record<string, any>) => string;\n\n // ─── UI Control ───\n focusEditor?: (params?: Record<string, any>) => string;\n openPanel?: (params?: Record<string, any>) => string;\n\n // ─── Model / Mode Control ───\n /** List available models → { models: string[], current: string } */\n listModels?: (params?: Record<string, any>) => string;\n /** Change model → { success: boolean } */\n setModel?: (params?: Record<string, any>) => string;\n /** List available modes → { modes: string[], current: string } */\n listModes?: (params?: Record<string, any>) => string;\n /** Change mode → { success: boolean } */\n setMode?: (params?: Record<string, any>) => string;\n\n // ─── Modal/Approval ───\n /** params: { action: 'approve'|'reject'|'custom', button?: string } */\n resolveAction?: (params?: Record<string, any>) => string;\n\n // ─── Notifications ───\n listNotifications?: (params?: Record<string, any>) => string;\n dismissNotification?: (params?: Record<string, any>) => string;\n\n // ─── Custom Scripts (user-defined) ───\n [scriptName: string]: ((params?: Record<string, any>) => string) | undefined;\n}\n\n\n/**\n * ProviderLoader.resolve() result: Final provider with OS/version overrides applied\n */\nexport interface ResolvedProvider extends ProviderModule {\n /** OS applied during resolve */\n _resolvedOs?: string;\n /** Version applied during resolve */\n _resolvedVersion?: string;\n /** Warning when detected version is not in compatibility matrix */\n _versionWarning?: string;\n}\n\n// ─── Provider Settings ─────────────────────────────────\n\n/** Setting variable definition declared by provider */\nexport interface ProviderSettingDef {\n type: 'boolean' | 'number' | 'string' | 'select';\n default: any;\n /** true = controllable from dashboard UI */\n public: boolean;\n /** UI label */\n label?: string;\n /** UI description */\n description?: string;\n /** Minimum value for number type */\n min?: number;\n /** Maximum value for number type */\n max?: number;\n /** Options for select type */\n options?: string[];\n}\n\n/** Public settings schema (for dashboard transmission) */\nexport interface ProviderSettingSchema extends ProviderSettingDef {\n key: string;\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 '../cdp/manager.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport { ProviderStreamAdapter } from './provider-adapter.js';\nimport { LOG } from '../logging/logger.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 || LOG.forComponent('AgentStream').asLogFn();\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 * AgentStreamPoller — Periodic agent stream polling + extension dynamic management\n *\n * Extracted from cloud daemon's startAgentStreamPolling() logic.\n * Used by both daemon-cloud and daemon-standalone.\n *\n * Responsibilities:\n * 1. Refresh extension providers in CDP managers (config changes take effect immediately)\n * 2. Dynamically add/remove IDE instance extensions based on enabled state\n * 3. Sync agent sessions + collect agent streams\n * 4. Auto-discover agents in connected IDEs\n */\n\nimport type { DaemonCdpManager } from '../cdp/manager.js';\nimport type { DaemonAgentStreamManager } from './manager.js';\nimport type { ProviderLoader } from '../providers/provider-loader.js';\nimport type { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport { registerExtensionProviders } from '../cdp/setup.js';\nimport { LOG } from '../logging/logger.js';\nimport type { AgentStreamState } from './types.js';\n\n// ─── Types ───\n\nexport interface AgentStreamPollerDeps {\n agentStreamManager: DaemonAgentStreamManager;\n providerLoader: ProviderLoader;\n instanceManager: ProviderInstanceManager;\n cdpManagers: Map<string, DaemonCdpManager>;\n /** Callback when agent streams are updated */\n onStreamsUpdated?: (ideType: string, streams: AgentStreamState[]) => void;\n}\n\nexport class AgentStreamPoller {\n private deps: AgentStreamPollerDeps;\n private _activeIdeType: string | null = null;\n private timer: NodeJS.Timeout | null = null;\n\n constructor(deps: AgentStreamPollerDeps) {\n this.deps = deps;\n }\n\n /** Currently active IDE type for agent streaming */\n get activeIde(): string | null {\n return this._activeIdeType;\n }\n\n /** Reset active IDE tracking (e.g., when IDE is stopped) */\n resetActiveIde(ideType: string): void {\n if (this._activeIdeType === ideType) {\n this._activeIdeType = null;\n }\n }\n\n /** Start polling (idempotent — ignored if already started) */\n start(intervalMs = 5000): void {\n if (this.timer) return; // Already running\n\n this.timer = setInterval(async () => {\n await this.tick();\n }, intervalMs);\n }\n\n /** Stop polling */\n stop(): void {\n if (this.timer) {\n clearInterval(this.timer);\n this.timer = null;\n }\n }\n\n /** Single poll tick — can also be called manually */\n private async tick(): Promise<void> {\n const {\n agentStreamManager,\n providerLoader,\n instanceManager,\n cdpManagers,\n } = this.deps;\n\n if (!agentStreamManager || cdpManagers.size === 0) return;\n\n // ─── Phase 1: Refresh extension providers + IDE instance extensions ───\n for (const [ideType, cdp] of cdpManagers) {\n // 1a. Refresh CDP manager's extension providers from config\n registerExtensionProviders(providerLoader, cdp, ideType);\n\n // 1b. Dynamically add/remove IDE instance extensions\n const ideInstance = 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 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 = providerLoader.getMeta(extType);\n if (extProvider) {\n const extSettings = 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 // ─── Phase 2: Agent session sync + collect ───\n\n // If agent already connected to a specific IDE, only operate on that CDP\n if (this._activeIdeType) {\n const cdp = cdpManagers.get(this._activeIdeType);\n if (cdp?.isConnected) {\n try {\n await agentStreamManager.syncAgentSessions(cdp);\n const streams = await agentStreamManager.collectAgentStreams(cdp);\n this.deps.onStreamsUpdated?.(this._activeIdeType, streams);\n } catch { }\n return;\n }\n // CDP lost — reset\n this._activeIdeType = null;\n }\n\n // ─── Phase 3: Auto-discover agents ───\n if (!agentStreamManager.activeAgentType) {\n for (const [ideType, cdp] of cdpManagers) {\n if (!cdp.isConnected) continue;\n try {\n const discovered = await cdp.discoverAgentWebviews();\n if (discovered.length > 0) {\n this._activeIdeType = ideType;\n await agentStreamManager.switchActiveAgent(cdp, discovered[0].agentType);\n LOG.info('AgentStream', `Auto-activated: ${discovered[0].agentType} (${ideType})`);\n // sync+collect immediately\n await agentStreamManager.syncAgentSessions(cdp);\n const streams = await agentStreamManager.collectAgentStreams(cdp);\n this.deps.onStreamsUpdated?.(ideType, streams);\n return;\n }\n } catch { }\n }\n }\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';\nimport { LOG } from '../logging/logger.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 LOG.warn('InstanceMgr', `[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 LOG.warn('InstanceMgr', `[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 LOG.warn('InstanceMgr', `[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 /**\n * Update settings for all instances of a given provider type.\n * Called when user changes settings from dashboard.\n */\n updateInstanceSettings(providerType: string, settings: Record<string, any>): number {\n let updated = 0;\n for (const instance of this.instances.values()) {\n if (instance.type === providerType && typeof instance.updateSettings === 'function') {\n instance.updateSettings(settings);\n updated++;\n }\n }\n return updated;\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 * Provider Version Detection & Archiving\n *\n * Detects installed versions for all provider categories (IDE, CLI, ACP, Extension).\n * Archives version history to ~/.adhdev/version-history.json for compatibility tracking.\n *\n * Usage:\n * const archive = new VersionArchive();\n * const results = await detectAllVersions(providerLoader, archive);\n */\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\nimport { execSync } from 'child_process';\nimport { platform } from 'os';\nimport type { ProviderLoader } from './provider-loader.js';\n\n// ─── Types ──────────────────────────────────────\n\nexport interface ProviderVersionInfo {\n type: string;\n name: string;\n category: string;\n installed: boolean;\n version: string | null;\n path: string | null;\n binary: string | null;\n detectedAt: string; // ISO timestamp\n /**\n * Set when the detected version is NOT listed in provider.json testedVersions.\n * Means scripts may not work correctly with this version.\n */\n warning?: string;\n}\n\nexport interface VersionHistoryEntry {\n version: string;\n detectedAt: string;\n os: string;\n}\n\nexport interface VersionHistory {\n [providerType: string]: VersionHistoryEntry[];\n}\n\n// ─── Version Archive ──────────────────────────────\n\nconst ARCHIVE_PATH = path.join(os.homedir(), '.adhdev', 'version-history.json');\nconst MAX_ENTRIES_PER_PROVIDER = 20;\n\nexport class VersionArchive {\n private history: VersionHistory = {};\n\n constructor() {\n this.load();\n }\n\n private load(): void {\n try {\n if (fs.existsSync(ARCHIVE_PATH)) {\n this.history = JSON.parse(fs.readFileSync(ARCHIVE_PATH, 'utf-8'));\n }\n } catch {\n this.history = {};\n }\n }\n\n /** Record a detected version (deduplicates same version) */\n record(type: string, version: string): void {\n if (!this.history[type]) this.history[type] = [];\n\n const entries = this.history[type];\n const last = entries[entries.length - 1];\n\n // Skip if same version as last entry\n if (last && last.version === version) return;\n\n entries.push({\n version,\n detectedAt: new Date().toISOString(),\n os: platform(),\n });\n\n // Trim old entries\n if (entries.length > MAX_ENTRIES_PER_PROVIDER) {\n this.history[type] = entries.slice(-MAX_ENTRIES_PER_PROVIDER);\n }\n\n this.save();\n }\n\n /** Get version history for a provider */\n getHistory(type: string): VersionHistoryEntry[] {\n return this.history[type] || [];\n }\n\n /** Get latest known version for a provider */\n getLatest(type: string): string | null {\n const entries = this.history[type];\n return entries?.length ? entries[entries.length - 1].version : null;\n }\n\n /** Get full archive */\n getAll(): VersionHistory {\n return { ...this.history };\n }\n\n private save(): void {\n try {\n fs.mkdirSync(path.dirname(ARCHIVE_PATH), { recursive: true });\n fs.writeFileSync(ARCHIVE_PATH, JSON.stringify(this.history, null, 2));\n } catch { /* ignore write errors */ }\n }\n}\n\n// ─── Version Detection ──────────────────────────────\n\nfunction runCommand(cmd: string, timeout = 10000): string | null {\n try {\n return execSync(cmd, {\n encoding: 'utf-8',\n timeout,\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n } catch {\n return null;\n }\n}\n\nfunction findBinary(name: string): string | null {\n const cmd = platform() === 'win32' ? `where ${name}` : `which ${name}`;\n const result = runCommand(cmd, 5000);\n return result ? result.split('\\n')[0] : null;\n}\n\n/** Extract version string from CLI output */\nfunction parseVersion(raw: string): string {\n // Common patterns: \"1.2.3\", \"v1.2.3\", \"tool 1.2.3\", \"tool version 1.2.3\"\n const match = raw.match(/v?(\\d+\\.\\d+(?:\\.\\d+)?(?:-[a-zA-Z0-9.]+)?)/);\n return match ? match[1] : raw.split('\\n')[0].substring(0, 100);\n}\n\nfunction getVersion(binary: string, versionCommand?: string): string | null {\n // Custom version command from provider.json\n if (versionCommand) {\n const raw = runCommand(versionCommand);\n return raw ? parseVersion(raw) : null;\n }\n\n // Default: try --version, then -V, then -v\n for (const flag of ['--version', '-V', '-v']) {\n const raw = runCommand(`\"${binary}\" ${flag}`);\n if (raw && raw.length < 500) return parseVersion(raw);\n }\n return null;\n}\n\nfunction checkPathExists(paths: string[]): string | null {\n for (const p of paths) {\n if (p.includes('*')) {\n const home = os.homedir();\n const resolved = p.replace(/\\*/g, home.split(path.sep).pop() || '');\n if (fs.existsSync(resolved)) return resolved;\n } else {\n if (fs.existsSync(p)) return p;\n }\n }\n return null;\n}\n\n/** macOS: Get app version from Info.plist */\nfunction getMacAppVersion(appPath: string): string | null {\n if (platform() !== 'darwin' || !appPath.endsWith('.app')) return null;\n const plistPath = path.join(appPath, 'Contents', 'Info.plist');\n if (!fs.existsSync(plistPath)) return null;\n const raw = runCommand(`/usr/libexec/PlistBuddy -c \"Print CFBundleShortVersionString\" \"${plistPath}\"`);\n return raw || null;\n}\n\n/**\n * Detect versions for all loaded providers\n */\nexport async function detectAllVersions(\n loader: ProviderLoader,\n archive?: VersionArchive,\n): Promise<ProviderVersionInfo[]> {\n const results: ProviderVersionInfo[] = [];\n const currentOs = platform() as string;\n\n for (const provider of loader.getAll()) {\n const info: ProviderVersionInfo = {\n type: provider.type,\n name: provider.name,\n category: provider.category,\n installed: false,\n version: null,\n path: null,\n binary: null,\n detectedAt: new Date().toISOString(),\n };\n\n const versionCommand = (provider as any).versionCommand;\n\n if (provider.category === 'ide') {\n // IDE: check app path + CLI\n const osPaths = provider.paths?.[currentOs] || [];\n const appPath = checkPathExists(osPaths);\n const cliBin = provider.cli ? findBinary(provider.cli) : null;\n\n // Also check bundled CLI inside .app for macOS\n let resolvedBin = cliBin;\n if (!resolvedBin && appPath && currentOs === 'darwin') {\n const bundled = path.join(appPath, 'Contents', 'Resources', 'app', 'bin', provider.cli || '');\n if (provider.cli && fs.existsSync(bundled)) resolvedBin = bundled;\n }\n\n info.installed = !!(appPath || resolvedBin);\n info.path = appPath || null;\n info.binary = resolvedBin || null;\n\n // Version: try CLI first, then plist\n if (resolvedBin) {\n info.version = getVersion(resolvedBin, versionCommand);\n }\n if (!info.version && appPath) {\n info.version = getMacAppVersion(appPath);\n }\n\n } else if (provider.category === 'cli' || provider.category === 'acp') {\n // CLI/ACP: check binary\n const bin = provider.binary || provider.spawn?.command || provider.cli || provider.type;\n const binPath = findBinary(bin);\n info.installed = !!binPath;\n info.binary = binPath || null;\n\n if (binPath) {\n info.version = getVersion(binPath, versionCommand);\n }\n\n } else if (provider.category === 'extension') {\n // Extension: version detection via `code --list-extensions --show-versions`\n // This is more complex and depends on the host IDE — skip for now\n // Could be detected at runtime via CDP\n info.installed = false; // Cannot reliably detect without IDE context\n info.version = null;\n }\n\n // Archive the version if detected\n if (info.version && archive) {\n archive.record(provider.type, info.version);\n }\n\n // Check testedVersions — warn if installed version is not documented\n if (info.version && info.installed) {\n const testedVersions: string[] = (provider as any).testedVersions || [];\n if (testedVersions.length > 0 && !testedVersions.includes(info.version)) {\n info.warning = `Version ${info.version} is not in testedVersions [${testedVersions.join(', ')}]. Scripts may not work correctly.`;\n }\n }\n\n results.push(info);\n }\n\n return results;\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 { ChildProcess } from 'child_process';\nimport type { DaemonCdpManager } from '../cdp/manager.js';\nimport { generateTemplate as genScaffoldTemplate, generateFiles as genScaffoldFiles } from './scaffold-template.js';\nimport { VersionArchive, detectAllVersions } from '../providers/version-archive.js';\nimport { LOG } from '../logging/logger.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 // Auto-implement state\n private autoImplProcess: ChildProcess | null = null;\n private autoImplSSEClients: http.ServerResponse[] = [];\n private autoImplStatus: { running: boolean; type: string | null; progress: any[] } = { running: false, type: null, progress: [] };\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 || LOG.forComponent('DevServer').asLogFn();\n }\n\n private log(msg: string): void {\n this.logFn(`[DevServer] ${msg}`);\n }\n\n // ─── Route Table ─────────────────────────────────────\n private readonly routes: {\n method: string;\n pattern: string | RegExp;\n handler: (req: http.IncomingMessage, res: http.ServerResponse, params?: string[]) => Promise<void> | void;\n }[] = [\n // Static routes\n { method: 'GET', pattern: '/api/providers', handler: (q, s) => this.handleListProviders(q, s) },\n { method: 'GET', pattern: '/api/providers/versions', handler: (q, s) => this.handleDetectVersions(q, s) },\n { method: 'POST', pattern: '/api/providers/reload', handler: (q, s) => this.handleReload(q, s) },\n { method: 'POST', pattern: '/api/cdp/evaluate', handler: (q, s) => this.handleCdpEvaluate(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/query', handler: (q, s) => this.handleCdpDomQuery(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/inspect', handler: (q, s) => this.handleDomInspect(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/children', handler: (q, s) => this.handleDomChildren(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/analyze', handler: (q, s) => this.handleDomAnalyze(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/find-text', handler: (q, s) => this.handleFindByText(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/find-common', handler: (q, s) => this.handleFindCommon(q, s) },\n { method: 'GET', pattern: '/api/cdp/screenshot', handler: (q, s) => this.handleScreenshot(q, s) },\n { method: 'GET', pattern: '/api/cdp/targets', handler: (q, s) => this.handleCdpTargets(q, s) },\n { method: 'POST', pattern: '/api/scripts/run', handler: (q, s) => this.handleScriptsRun(q, s) },\n { method: 'GET', pattern: '/api/status', handler: (q, s) => this.handleStatus(q, s) },\n { method: 'POST', pattern: '/api/watch/start', handler: (q, s) => this.handleWatchStart(q, s) },\n { method: 'POST', pattern: '/api/watch/stop', handler: (q, s) => this.handleWatchStop(q, s) },\n { method: 'GET', pattern: '/api/watch/events', handler: (q, s) => this.handleSSE(q, s) },\n { method: 'POST', pattern: '/api/scaffold', handler: (q, s) => this.handleScaffold(q, s) },\n // Dynamic routes (provider :type param)\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/script$/, handler: (q, s, p) => this.handleRunScript(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/files$/, handler: (q, s, p) => this.handleListFiles(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/file$/, handler: (q, s, p) => this.handleReadFile(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/file$/, handler: (q, s, p) => this.handleWriteFile(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/source$/, handler: (q, s, p) => this.handleSource(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/save$/, handler: (q, s, p) => this.handleSave(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/config$/, handler: (q, s, p) => this.handleProviderConfig(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/dom-context$/, handler: (q, s, p) => this.handleDomContext(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/auto-implement$/, handler: (q, s, p) => this.handleAutoImplement(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/auto-implement\\/cancel$/,handler: (q, s, p) => this.handleAutoImplCancel(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/auto-implement\\/status$/,handler: (q, s, p) => this.handleAutoImplSSE(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/spawn-test$/, handler: (q, s, p) => this.handleSpawnTest(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/validate$/, handler: (q, s, p) => this.handleValidate(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/acp-chat$/, handler: (q, s, p) => this.handleAcpChat(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/script-hints$/, handler: (q, s, p) => this.handleScriptHints(p![0], q, s) },\n ];\n\n private matchRoute(method: string, pathname: string): { handler: (req: http.IncomingMessage, res: http.ServerResponse, params?: string[]) => Promise<void> | void; params?: string[] } | null {\n for (const route of this.routes) {\n if (route.method !== method) continue;\n if (typeof route.pattern === 'string') {\n if (pathname === route.pattern) return { handler: route.handler };\n } else {\n const m = pathname.match(route.pattern);\n if (m) return { handler: route.handler, params: m.slice(1) };\n }\n }\n return null;\n }\n\n private getEndpointList(): string[] {\n return this.routes.map(r => {\n const path = typeof r.pattern === 'string'\n ? r.pattern\n : r.pattern.source.replace(/\\\\\\//g, '/').replace(/\\(\\[.*?\\]\\+\\)/g, ':type').replace(/[\\^$]/g, '');\n return `${r.method.padEnd(5)} ${path}`;\n });\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 // ─── Route Table ───\n const route = this.matchRoute(req.method || 'GET', pathname);\n if (route) {\n await route.handler(req, res, route.params);\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: this.getEndpointList() });\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.resolve(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.resolve(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/webp',\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.getMeta(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 private async handleScriptHints(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\n // Find scripts.js in the provider dir (may be versioned)\n let scriptsPath = '';\n const directScripts = path.join(dir, 'scripts.js');\n if (fs.existsSync(directScripts)) {\n scriptsPath = directScripts;\n } else {\n // Check versioned scripts dirs\n const scriptsDir = path.join(dir, 'scripts');\n if (fs.existsSync(scriptsDir)) {\n const versions = fs.readdirSync(scriptsDir).filter(d => {\n return fs.statSync(path.join(scriptsDir, d)).isDirectory();\n }).sort().reverse();\n for (const ver of versions) {\n const p = path.join(scriptsDir, ver, 'scripts.js');\n if (fs.existsSync(p)) { scriptsPath = p; break; }\n }\n }\n }\n\n if (!scriptsPath) {\n this.json(res, 200, { hints: {} });\n return;\n }\n\n try {\n const source = fs.readFileSync(scriptsPath, 'utf-8');\n const hints: Record<string, { template: Record<string, any>; description: string }> = {};\n\n // Parse exported functions and extract param usage\n const funcRegex = /module\\.exports\\.(\\w+)\\s*=\\s*function\\s+\\w+\\s*\\(params\\)/g;\n let match;\n while ((match = funcRegex.exec(source)) !== null) {\n const name = match[1];\n // Find the function body (rough: from match to next module.exports or end)\n const startIdx = match.index;\n const nextFunc = source.indexOf('module.exports.', startIdx + 1);\n const funcBody = source.substring(startIdx, nextFunc > 0 ? nextFunc : source.length);\n\n const paramFields: Record<string, any> = {};\n\n // Pattern 1: params?.xxx or params.xxx\n const dotRegex = /params\\?\\.([a-zA-Z_]+)|params\\.([a-zA-Z_]+)/g;\n let dm;\n while ((dm = dotRegex.exec(funcBody)) !== null) {\n const field = dm[1] || dm[2];\n if (field === 'length') continue;\n if (!(field in paramFields)) {\n // Infer type from context\n if (/index|count|port|timeout/i.test(field)) paramFields[field] = 0;\n else if (/action|text|title|message|model|mode|button|name|filter/i.test(field)) paramFields[field] = '';\n else paramFields[field] = '';\n }\n }\n\n // Pattern 2: typeof params === 'string' ? params : params?.xxx\n const typeofRegex = /typeof params === 'string' \\? params : params\\?\\.([a-zA-Z_]+)/g;\n let tm;\n while ((tm = typeofRegex.exec(funcBody)) !== null) {\n const field = tm[1];\n if (!(field in paramFields)) paramFields[field] = '';\n }\n\n // Pattern 3: typeof params === 'number' ? params : params?.xxx\n const numRegex = /typeof params === 'number' \\? params : params\\?\\.([a-zA-Z_]+)/g;\n let nm;\n while ((nm = numRegex.exec(funcBody)) !== null) {\n const field = nm[1];\n if (!(field in paramFields)) paramFields[field] = 0;\n }\n\n // Determine description from function name\n const descriptions: Record<string, string> = {\n readChat: 'No params required',\n sendMessage: 'Text to send to the chat',\n listSessions: 'No params required',\n switchSession: 'Switch by index or title',\n newSession: 'No params required',\n focusEditor: 'No params required',\n openPanel: 'No params required',\n resolveAction: 'Approve/reject action buttons',\n listNotifications: 'Optional message filter',\n dismissNotification: 'Dismiss by index, message, or button',\n listModels: 'No params required',\n setModel: 'Model name to select',\n listModes: 'No params required',\n setMode: 'Mode name to select',\n };\n\n hints[name] = {\n template: Object.keys(paramFields).length > 0 ? paramFields : {},\n description: descriptions[name] || (Object.keys(paramFields).length > 0 ? 'Params: ' + Object.keys(paramFields).join(', ') : 'No params'),\n };\n }\n\n this.json(res, 200, { hints });\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n // ─── Validate provider.json ───\n private async handleValidate(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { content } = body;\n const errors: string[] = [];\n const warnings: string[] = [];\n try {\n const config = typeof content === 'string' ? JSON.parse(content) : content;\n // Required fields\n if (!config.type) errors.push('Missing required field: type');\n if (!config.name) errors.push('Missing required field: name');\n if (!config.category) errors.push('Missing required field: category');\n else if (!['ide', 'extension', 'cli', 'acp'].includes(config.category)) errors.push(`Invalid category: ${config.category}`);\n // Category-specific\n if (config.category === 'ide' || config.category === 'extension') {\n if (!config.cdpPorts || !Array.isArray(config.cdpPorts) || config.cdpPorts.length === 0)\n warnings.push('IDE/Extension providers should have cdpPorts');\n if (config.category === 'extension' && !config.extensionId)\n warnings.push('Extension providers should have extensionId');\n }\n if (config.category === 'acp' || config.category === 'cli') {\n if (!config.spawn) errors.push('ACP/CLI providers must have spawn config');\n else {\n if (!config.spawn.command) errors.push('spawn.command is required');\n }\n }\n // Settings validation\n if (config.settings) {\n for (const [key, val] of Object.entries(config.settings)) {\n const s = val as any;\n if (!s.type) errors.push(`settings.${key}: missing type`);\n else if (!['boolean', 'number', 'string', 'select'].includes(s.type))\n errors.push(`settings.${key}: invalid type '${s.type}'`);\n if (s.default === undefined) warnings.push(`settings.${key}: no default value`);\n if (s.type === 'number' && s.min !== undefined && s.max !== undefined && s.min > s.max)\n errors.push(`settings.${key}: min (${s.min}) > max (${s.max})`);\n if (s.type === 'select' && (!s.options || !Array.isArray(s.options) || s.options.length === 0))\n errors.push(`settings.${key}: select type requires options[]`);\n }\n }\n // Port conflicts\n if (config.cdpPorts && Array.isArray(config.cdpPorts)) {\n const allProviders = this.providerLoader.getAll();\n for (const port of config.cdpPorts) {\n const conflict = allProviders.find(p => p.type !== type && (p as any).cdpPorts?.includes(port));\n if (conflict) warnings.push(`CDP port ${port} conflicts with provider '${conflict.type}'`);\n }\n }\n this.json(res, 200, { valid: errors.length === 0, errors, warnings });\n } catch (e: any) {\n this.json(res, 200, { valid: false, errors: [`Invalid JSON: ${e.message}`], warnings: [] });\n }\n }\n\n // ─── ACP Chat Test ───\n private async handleAcpChat(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { message, timeout = 30000 } = body;\n if (!message) { this.json(res, 400, { error: 'message required' }); return; }\n const provider = this.providerLoader.getMeta(type);\n if (!provider) { this.json(res, 404, { error: `Provider not found: ${type}` }); return; }\n const spawn = (provider as any).spawn;\n if (!spawn) { this.json(res, 400, { error: `Provider ${type} has no spawn config` }); return; }\n\n const { spawn: spawnFn } = await import('child_process');\n const start = Date.now();\n try {\n const args = [...(spawn.args || []), message];\n const child = spawnFn(spawn.command, args, {\n shell: spawn.shell ?? false,\n timeout: timeout,\n stdio: ['pipe', 'pipe', 'pipe'],\n env: { ...process.env, ...(spawn.env || {}) },\n });\n\n let stdout = '';\n let stderr = '';\n child.stdout?.on('data', (d: Buffer) => { stdout += d.toString(); });\n child.stderr?.on('data', (d: Buffer) => { stderr += d.toString(); });\n\n await new Promise<void>((resolve) => {\n const timer = setTimeout(() => { child.kill(); resolve(); }, timeout);\n child.on('exit', () => { clearTimeout(timer); resolve(); });\n });\n\n const elapsed = Date.now() - start;\n this.json(res, 200, {\n success: true,\n message,\n response: stdout.trim(),\n stderr: stderr.trim(),\n exitCode: child.exitCode,\n elapsed,\n });\n } catch (e: any) {\n this.json(res, 200, {\n success: false,\n message,\n error: e.message,\n elapsed: Date.now() - start,\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, version } = body;\n if (!type || !name) {\n this.json(res, 400, { error: 'type and name required' });\n return;\n }\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 jsonPath = path.join(targetDir, 'provider.json');\n if (fs.existsSync(jsonPath)) {\n this.json(res, 409, { error: `Provider already exists at ${targetDir}`, path: targetDir });\n return;\n }\n\n try {\n const result = genScaffoldFiles(type, name, category, { cdpPorts, cli, processName, installPath, binary, extensionId, version });\n fs.mkdirSync(targetDir, { recursive: true });\n fs.writeFileSync(jsonPath, result['provider.json'], 'utf-8');\n const createdFiles = ['provider.json'];\n\n // Write per-function script files (new structure)\n if (result.files) {\n for (const [relPath, content] of Object.entries(result.files)) {\n const fullPath = path.join(targetDir, relPath);\n fs.mkdirSync(path.dirname(fullPath), { recursive: true });\n fs.writeFileSync(fullPath, content, 'utf-8');\n createdFiles.push(relPath);\n }\n }\n\n this.log(`Scaffolded provider: ${targetDir} (${createdFiles.length} files)`);\n this.json(res, 201, { created: true, path: targetDir, files: createdFiles, type, name, category });\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n // ─── Version Detection ───\n\n private async handleDetectVersions(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n try {\n const archive = new VersionArchive();\n const results = await detectAllVersions(this.providerLoader, archive);\n const installed = results.filter(r => r.installed);\n const notInstalled = results.filter(r => !r.installed);\n this.json(res, 200, {\n total: results.length,\n installed: installed.length,\n providers: results,\n history: archive.getAll(),\n });\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\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 private async handleFindCommon(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { include, exclude, ideType } = body;\n if (!Array.isArray(include) || include.length === 0) { this.json(res, 400, { error: 'include[] is required' }); return; }\n const cdp = this.getCdp(ideType);\n if (!cdp) { this.json(res, 503, { error: 'No CDP connection' }); return; }\n\n const script = `(() => {\n const includes = ${JSON.stringify(include)};\n const excludes = ${JSON.stringify(exclude || [])};\n\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 sig(el) {\n return el.tagName + '|' + ((el.className && typeof el.className === 'string') ? el.className.trim() : '');\n }\n\n // Step 1: For each include, find all matching leaf elements\n const includeMatches = includes.map(text => {\n const lower = text.toLowerCase();\n const found = [];\n const walker = document.createTreeWalker(document.body, NodeFilter.SHOW_TEXT, {\n acceptNode: n => n.textContent.toLowerCase().includes(lower) ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_REJECT\n });\n let node;\n while ((node = walker.nextNode()) && found.length < 5) {\n if (node.parentElement) found.push(node.parentElement);\n }\n return found;\n });\n\n if (includeMatches.some(m => m.length === 0)) {\n const missing = includes.filter((_, i) => includeMatches[i].length === 0);\n return JSON.stringify({ results: [], message: 'Text not found: ' + missing.join(', ') });\n }\n\n // Step 2: Find LCA for each combination of include elements\n // For each pair of include[0] element and include[1] element, find their LCA\n // Then within the LCA, find the direct-child subtree branch for each\n const containers = [];\n const seen = new Set();\n\n function findLCA(el1, el2) {\n const ancestors1 = new Set();\n let c = el1;\n while (c) { ancestors1.add(c); c = c.parentElement; }\n c = el2;\n while (c) { if (ancestors1.has(c)) return c; c = c.parentElement; }\n return document.body;\n }\n\n function findDirectChildContaining(parent, descendant) {\n let c = descendant;\n while (c && c.parentElement !== parent) c = c.parentElement;\n return c;\n }\n\n // Try all combinations (first 3 matches per include)\n for (const el1 of includeMatches[0].slice(0, 3)) {\n for (let ii = 1; ii < includeMatches.length; ii++) {\n for (const el2 of includeMatches[ii].slice(0, 3)) {\n if (el1 === el2) continue;\n const lca = findLCA(el1, el2);\n if (!lca || lca === document.body || lca === document.documentElement) continue;\n\n // Find which direct child of LCA contains each include element\n const child1 = findDirectChildContaining(lca, el1);\n const child2 = findDirectChildContaining(lca, el2);\n if (!child1 || !child2 || child1 === child2) continue;\n\n const lcaSel = fp(lca);\n if (seen.has(lcaSel)) continue;\n seen.add(lcaSel);\n\n // Check exclude\n if (excludes.length > 0) {\n const lcaText = (lca.textContent || '').toLowerCase();\n if (excludes.some(ex => lcaText.includes(ex.toLowerCase()))) continue;\n }\n\n // Are child1 and child2 same tag? (relaxed — ignore classes)\n const tag1 = child1.tagName;\n const tag2 = child2.tagName;\n\n // Bubble up: walk up from LCA, find the best list container\n // (the one with most repeating same-tag children)\n let container = lca;\n let bestContainer = lca;\n let bestListCount = 0;\n for (let up = 0; up < 10; up++) {\n const p = container.parentElement;\n if (!p || p === document.body || p === document.documentElement) break;\n // Check how many same-tag siblings 'container' has in parent\n const myTag = container.tagName;\n const sibCount = [...p.children].filter(c => c.tagName === myTag).length;\n if (sibCount > bestListCount) {\n bestListCount = sibCount;\n bestContainer = p;\n }\n container = p;\n }\n container = bestListCount >= 3 ? bestContainer : lca;\n\n const allChildren = [...container.children];\n const childTag = tag1 === tag2 ? tag1 : (allChildren.length > 0 ? allChildren[0].tagName : '');\n const sameTagCount = allChildren.filter(c => c.tagName === childTag).length;\n const isList = sameTagCount >= 3 && sameTagCount >= allChildren.length * 0.4;\n\n // Gather all same-tag children as list items\n const listItems = isList \n ? allChildren.filter(c => c.tagName === childTag)\n : allChildren;\n\n // Filter rendered items (skip virtual scroll placeholders)\n const rendered = listItems.filter(c => (c.innerText || '').trim().length > 0);\n const placeholderCount = listItems.length - rendered.length;\n\n const containerSel = fp(container);\n if (seen.has(containerSel)) continue;\n seen.add(containerSel);\n\n const r = container.getBoundingClientRect();\n containers.push({\n selector: containerSel,\n tag: container.tagName.toLowerCase(),\n childCount: allChildren.length,\n listItemCount: listItems.length,\n renderedCount: rendered.length,\n placeholderCount,\n isList,\n rect: { w: Math.round(r.width), h: Math.round(r.height) },\n depth: containerSel.split(' > ').length,\n items: rendered.slice(0, 30).map((el, i) => {\n const fullText = (el.innerText || el.textContent || '').trim();\n // Find snippet around first matched include text\n let text = fullText.substring(0, 200);\n const matched = [];\n for (const inc of includes) {\n const idx = fullText.toLowerCase().indexOf(inc.toLowerCase());\n if (idx >= 0) {\n matched.push(inc);\n if (matched.length === 1) {\n // Show snippet around first match\n const start = Math.max(0, idx - 30);\n const end = Math.min(fullText.length, idx + inc.length + 80);\n text = (start > 0 ? '...' : '') + fullText.substring(start, end) + (end < fullText.length ? '...' : '');\n }\n }\n }\n return {\n index: i,\n tag: el.tagName.toLowerCase(),\n cls: (el.className && typeof el.className === 'string') ? el.className.trim().split(/\\\\s+/).slice(0, 2).join(' ') : '',\n text,\n matchedIncludes: matched,\n childCount: el.children.length,\n h: Math.round(el.getBoundingClientRect().height),\n };\n }),\n });\n }\n }\n }\n\n // Sort: list containers first (more items = better), then by depth\n containers.sort((a, b) => {\n if (a.isList !== b.isList) return a.isList ? -1 : 1;\n return b.listItemCount - a.listItemCount || b.depth - a.depth;\n });\n\n return JSON.stringify({\n results: containers.slice(0, 10),\n includeCount: includes.length,\n excludeCount: excludes.length,\n });\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 handleFindByText(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { text, ideType, containerSelector } = body;\n if (!text || typeof text !== 'string') { this.json(res, 400, { error: 'text is required' }); return; }\n const cdp = this.getCdp(ideType);\n if (!cdp) { this.json(res, 503, { error: 'No CDP connection' }); return; }\n\n const containerArg = containerSelector ? JSON.stringify(containerSelector) : 'null';\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 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 parentSig(el) {\n // Signature: tag+class chain up 3 levels\n const parts = [];\n let c = el;\n for (let i = 0; i < 3 && c; i++) { parts.push(gs(c)); c = c.parentElement; }\n return parts.join(' < ');\n }\n\n const searchText = ${JSON.stringify(text)}.toLowerCase();\n const container = ${containerArg} ? document.querySelector(${containerArg}) : document.body;\n if (!container) return JSON.stringify({ error: 'Container not found' });\n\n const matches = [];\n const seen = new Set();\n\n // Find all text nodes containing the search text\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_TEXT, {\n acceptNode: n => n.textContent.toLowerCase().includes(searchText) ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_REJECT\n });\n let node;\n while ((node = walker.nextNode()) && matches.length < 50) {\n // Walk up to find the most specific visible element\n let el = node.parentElement;\n if (!el) continue;\n\n // Skip hidden elements\n const r = el.getBoundingClientRect();\n if (r.width === 0 && r.height === 0) continue;\n\n const selector = fp(el);\n if (seen.has(selector)) continue;\n seen.add(selector);\n\n // Walk up parent chain — record each level's selector + sibling count\n const ancestors = [];\n let cur = el;\n let pLvl = cur.parentElement;\n for (let lvl = 0; lvl < 10 && pLvl && pLvl !== document.body; lvl++) {\n const mySig = cur.tagName + '|' + ((cur.className && typeof cur.className === 'string') ? cur.className.trim().split(/\\\\s+/).sort().join('.') : '');\n const sibs = [...pLvl.children].filter(c => {\n const sig = c.tagName + '|' + ((c.className && typeof c.className === 'string') ? c.className.trim().split(/\\\\s+/).sort().join('.') : '');\n return sig === mySig;\n });\n const childSel = gs(cur).replace(/:nth-child\\\\(\\\\d+\\\\)/, '');\n ancestors.push({\n parentSelector: fp(pLvl),\n childSelector: childSel,\n fullSelector: fp(pLvl) + ' > ' + childSel,\n siblingCount: sibs.length,\n parentTag: pLvl.tagName.toLowerCase(),\n });\n cur = pLvl;\n pLvl = pLvl.parentElement;\n }\n\n const directText = (node.textContent || '').trim().substring(0, 200);\n const allText = (node.parentElement.textContent || '').trim().substring(0, 300);\n const tag = node.parentElement.tagName.toLowerCase();\n const cls = (node.parentElement.className && typeof node.parentElement.className === 'string')\n ? node.parentElement.className.trim().split(/\\\\s+/).filter(Boolean) : [];\n\n matches.push({\n selector,\n tag,\n cls,\n directText,\n allText,\n ancestors,\n rect: { w: Math.round(r.width), h: Math.round(r.height) },\n depth: selector.split(' > ').length,\n });\n }\n\n // Sort: prefer elements with more siblings in ancestry, then fewer depth\n matches.sort((a, b) => {\n const aMax = Math.max(1, ...a.ancestors.map(x => x.siblingCount));\n const bMax = Math.max(1, ...b.ancestors.map(x => x.siblingCount));\n return (bMax - aMax) || (a.depth - b.depth);\n });\n\n return JSON.stringify({ query: ${JSON.stringify(text)}, matches, total: matches.length });\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 // ─── Phase 1: DOM Context API ───\n\n private async handleDomContext(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { ideType } = body;\n const provider = this.providerLoader.resolve(type);\n if (!provider) { this.json(res, 404, { error: `Provider not found: ${type}` }); return; }\n\n const cdp = this.getCdp(ideType || type);\n if (!cdp) { this.json(res, 503, { error: 'No CDP connection available. Target IDE must be running with CDP enabled.' }); return; }\n\n try {\n // 1. Capture screenshot\n let screenshot: string | null = null;\n try {\n const buf = await cdp.captureScreenshot();\n if (buf) screenshot = buf.toString('base64');\n } catch { /* screenshot optional */ }\n\n // 2. Collect DOM snapshot\n const domScript = `(() => {\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 rect(el) {\n 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) }; }\n catch { return null; }\n }\n\n const result = { contentEditables: [], chatContainers: [], buttons: [], sidebars: [], dropdowns: [], inputs: [] };\n\n // Content editables + textareas + inputs\n document.querySelectorAll('[contenteditable], textarea, input[type=\"text\"], input:not([type])').forEach(el => {\n if (el.offsetWidth === 0 && el.offsetHeight === 0) return;\n result.contentEditables.push({\n selector: fp(el),\n tag: el.tagName.toLowerCase(),\n contenteditable: el.getAttribute('contenteditable'),\n role: el.getAttribute('role'),\n ariaLabel: el.getAttribute('aria-label'),\n placeholder: el.getAttribute('placeholder'),\n rect: rect(el),\n visible: el.offsetParent !== null || el.offsetWidth > 0,\n });\n });\n\n // Chat containers — large divs with scroll\n document.querySelectorAll('div, section, main').forEach(el => {\n const style = getComputedStyle(el);\n const isScrollable = style.overflowY === 'auto' || style.overflowY === 'scroll';\n const r = el.getBoundingClientRect();\n if (!isScrollable || r.height < 200 || r.width < 200) return;\n const childCount = el.children.length;\n if (childCount < 2) return;\n result.chatContainers.push({\n selector: fp(el),\n childCount,\n rect: { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) },\n hasScrollable: true,\n scrollTop: Math.round(el.scrollTop),\n scrollHeight: Math.round(el.scrollHeight),\n });\n });\n\n // Buttons\n document.querySelectorAll('button, [role=\"button\"]').forEach(el => {\n if (el.offsetWidth === 0 && el.offsetHeight === 0) return;\n const text = (el.textContent || '').trim().substring(0, 80);\n if (!text && !el.getAttribute('aria-label')) return;\n result.buttons.push({\n text,\n ariaLabel: el.getAttribute('aria-label'),\n selector: fp(el),\n rect: rect(el),\n disabled: el.disabled || el.getAttribute('aria-disabled') === 'true',\n });\n });\n\n // Sidebars — panels on left/right edges\n document.querySelectorAll('[class*=\"sidebar\"], [class*=\"side-bar\"], [class*=\"panel\"], [role=\"complementary\"], [role=\"navigation\"], aside').forEach(el => {\n if (el.offsetWidth === 0 && el.offsetHeight === 0) return;\n const r = el.getBoundingClientRect();\n if (r.width < 50 || r.height < 200) return;\n result.sidebars.push({\n selector: fp(el),\n position: r.x < window.innerWidth / 3 ? 'left' : r.x > window.innerWidth * 2 / 3 ? 'right' : 'center',\n rect: { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) },\n childCount: el.children.length,\n });\n });\n\n // Dropdowns — select, popover, menu patterns\n document.querySelectorAll('select, [role=\"listbox\"], [role=\"menu\"], [role=\"combobox\"], [class*=\"dropdown\"], [class*=\"popover\"]').forEach(el => {\n result.dropdowns.push({\n selector: fp(el),\n tag: el.tagName.toLowerCase(),\n role: el.getAttribute('role'),\n visible: el.offsetParent !== null || el.offsetWidth > 0,\n rect: rect(el),\n });\n });\n\n return JSON.stringify(result);\n })()`;\n\n const raw = await cdp.evaluate(domScript, 15000);\n let domSnapshot: any = {};\n if (typeof raw === 'string') { try { domSnapshot = JSON.parse(raw); } catch { domSnapshot = { raw }; } }\n else domSnapshot = raw;\n\n this.json(res, 200, {\n screenshot: screenshot ? `base64:${screenshot}` : null,\n domSnapshot,\n pageTitle: await cdp.evaluate('document.title', 3000).catch(() => ''),\n pageUrl: await cdp.evaluate('window.location.href', 3000).catch(() => ''),\n providerType: type,\n timestamp: new Date().toISOString(),\n });\n } catch (e: any) {\n this.json(res, 500, { error: `DOM context collection failed: ${e.message}` });\n }\n }\n\n // ─── Phase 2: Auto-Implement Backend ───\n\n private async handleAutoImplement(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { agent = 'claude-cli', functions, reference = 'antigravity', model } = body;\n if (!functions || !Array.isArray(functions) || functions.length === 0) {\n this.json(res, 400, { error: 'functions[] is required (e.g. [\"readChat\", \"sendMessage\"])' });\n return;\n }\n\n if (this.autoImplStatus.running) {\n this.json(res, 409, { error: 'Auto-implement already in progress', type: this.autoImplStatus.type });\n return;\n }\n\n const provider = this.providerLoader.resolve(type);\n if (!provider) { this.json(res, 404, { error: `Provider not found: ${type}` }); return; }\n\n const providerDir = this.findProviderDir(type);\n if (!providerDir) { this.json(res, 404, { error: `Provider directory not found: ${type}` }); return; }\n\n try {\n // 1. Collect DOM context\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'analyzing', message: 'DOM 구조 수집 중...' } });\n\n let domContext: any = null;\n const cdp = this.getCdp(type);\n if (cdp) {\n try {\n const domScript = `(() => {\n function fp(el) {\n if (!el || el === document.body) return 'body';\n const parts = [];\n let c = el;\n while (c && c !== document.documentElement) {\n let s = c.tagName.toLowerCase();\n if (c.id) s = '#' + c.id;\n else if (c.className && typeof c.className === 'string') {\n const cls = c.className.trim().split(/\\\\s+/).filter(x => x && !x.startsWith('_')).slice(0, 2);\n if (cls.length) s += '.' + cls.join('.');\n }\n parts.unshift(s);\n c = c.parentElement;\n }\n return parts.join(' > ');\n }\n const r = {};\n // Content editables\n r.editables = [...document.querySelectorAll('[contenteditable], textarea, input')].filter(e => e.offsetWidth > 0).slice(0, 10).map(e => ({\n selector: fp(e), tag: e.tagName.toLowerCase(), ce: e.getAttribute('contenteditable'), role: e.getAttribute('role'), ph: e.getAttribute('placeholder')\n }));\n // Scroll containers\n r.scrollContainers = [...document.querySelectorAll('div, section')].filter(e => {\n const s = getComputedStyle(e); const b = e.getBoundingClientRect();\n return (s.overflowY === 'auto' || s.overflowY === 'scroll') && b.height > 200 && e.children.length > 2;\n }).slice(0, 5).map(e => ({ selector: fp(e), children: e.children.length, h: Math.round(e.getBoundingClientRect().height) }));\n // Buttons\n r.buttons = [...document.querySelectorAll('button, [role=\"button\"]')].filter(e => e.offsetWidth > 0).slice(0, 20).map(e => ({\n text: (e.textContent||'').trim().substring(0, 60), selector: fp(e), label: e.getAttribute('aria-label')\n }));\n return JSON.stringify(r);\n })()`;\n const raw = await cdp.evaluate(domScript, 10000);\n domContext = typeof raw === 'string' ? JSON.parse(raw) : raw;\n } catch (e: any) {\n this.log(`DOM context collection failed (non-fatal): ${e.message}`);\n }\n }\n\n // 2. Load reference scripts\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'loading_reference', message: `레퍼런스 스크립트 로드 중 (${reference})...` } });\n\n let referenceScripts: Record<string, string> = {};\n const builtinDir = (this.providerLoader as any).builtinDir || path.resolve(__dirname, '../providers/_builtin');\n const refDir = path.join(builtinDir, 'ide', reference);\n if (fs.existsSync(refDir)) {\n // Find latest versioned scripts dir\n const scriptsDir = path.join(refDir, 'scripts');\n if (fs.existsSync(scriptsDir)) {\n const versions = fs.readdirSync(scriptsDir).filter((d: string) => {\n try { return fs.statSync(path.join(scriptsDir, d)).isDirectory(); } catch { return false; }\n }).sort().reverse();\n if (versions.length > 0) {\n const latestDir = path.join(scriptsDir, versions[0]);\n for (const file of fs.readdirSync(latestDir)) {\n if (file.endsWith('.js')) {\n try {\n referenceScripts[file] = fs.readFileSync(path.join(latestDir, file), 'utf-8');\n } catch { /* skip */ }\n }\n }\n }\n }\n }\n\n // 3. Build the prompt\n const prompt = this.buildAutoImplPrompt(type, provider, providerDir, functions, domContext, referenceScripts);\n\n // 4. Write prompt to temp file (avoids shell escaping issues with special chars)\n const tmpDir = path.join(os.tmpdir(), 'adhdev-autoimpl');\n if (!fs.existsSync(tmpDir)) fs.mkdirSync(tmpDir, { recursive: true });\n const promptFile = path.join(tmpDir, `prompt-${type}-${Date.now()}.md`);\n fs.writeFileSync(promptFile, prompt, 'utf-8');\n this.log(`Auto-implement prompt written to ${promptFile} (${prompt.length} chars)`);\n\n // 5. Determine agent command from provider spawn config\n const agentProvider = this.providerLoader.resolve(agent) || this.providerLoader.getMeta(agent);\n const spawn = (agentProvider as any)?.spawn;\n if (!spawn?.command) {\n try { fs.unlinkSync(promptFile); } catch { /* ignore */ }\n this.json(res, 400, { error: `Agent '${agent}' has no spawn config. Select a CLI provider with a spawn configuration.` });\n return;\n }\n\n const agentCategory = (agentProvider as any)?.category;\n\n // ─── ACP Agent: use ACP SDK (JSON-RPC protocol) ───\n if (agentCategory === 'acp') {\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'spawning', message: `ACP 에이전트 실행 중: ${spawn.command} ${(spawn.args || []).join(' ')}` } });\n this.autoImplStatus = { running: true, type, progress: [] };\n\n // Dynamic import ACP SDK\n const { ClientSideConnection, ndJsonStream, PROTOCOL_VERSION } = await import('@agentclientprotocol/sdk');\n const { Readable, Writable } = await import('stream');\n const { spawn: spawnFn } = await import('child_process');\n\n // Add model override to spawn args if specified\n const acpArgs = [...(spawn.args || [])];\n if (model) {\n acpArgs.push('--model', model);\n this.log(`Auto-implement ACP using model: ${model}`);\n }\n\n const child = spawnFn(spawn.command, acpArgs, {\n cwd: providerDir,\n stdio: ['pipe', 'pipe', 'pipe'],\n shell: spawn.shell ?? false,\n env: { ...process.env, ...(spawn.env || {}) },\n });\n this.autoImplProcess = child;\n\n // stderr → stream to SSE\n child.stderr?.on('data', (d: Buffer) => {\n const chunk = d.toString();\n this.sendAutoImplSSE({ event: 'output', data: { chunk, stream: 'stderr' } });\n });\n\n // Setup ACP connection via SDK\n const webStdin = Writable.toWeb(child.stdin!) as WritableStream<Uint8Array>;\n const webStdout = Readable.toWeb(child.stdout!) as ReadableStream<Uint8Array>;\n const stream = ndJsonStream(webStdin, webStdout);\n\n const connection = new ClientSideConnection((_agent: any) => ({\n // Auto-approve all tool calls for auto-implement\n requestPermission: async (params: any) => {\n const allowOpt = params.options?.find((o: any) => o.kind === 'allow_once') || params.options?.[0];\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `[ACP] Auto-approved: ${params.toolCall?.title || 'tool call'}\\n`, stream: 'stdout' } });\n return { outcome: { outcome: 'selected', optionId: allowOpt?.optionId || '' } };\n },\n sessionUpdate: async (params: any) => {\n const update = params?.update;\n if (!update) return;\n // Stream meaningful output only (skip thought chunks — they're too verbose)\n switch (update.sessionUpdate) {\n case 'agent_message_chunk':\n if (update.content?.text) {\n this.sendAutoImplSSE({ event: 'output', data: { chunk: update.content.text, stream: 'stdout' } });\n }\n break;\n case 'tool_call':\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `\\n🔧 [Tool] ${update.title || 'unknown'}\\n`, stream: 'stdout' } });\n break;\n case 'tool_call_update':\n if (update.status === 'completed' || update.status === 'failed') {\n const label = update.status === 'completed' ? '✅' : '❌';\n const out = update.rawOutput ? (typeof update.rawOutput === 'string' ? update.rawOutput : JSON.stringify(update.rawOutput)) : '';\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `${label} Result: ${out.slice(0, 1000)}\\n`, stream: 'stdout' } });\n }\n break;\n case 'agent_thought_chunk':\n // Skip — too verbose for auto-implement UI\n break;\n default:\n break;\n }\n },\n // Not used for auto-implement\n readTextFile: async () => { throw new Error('not supported'); },\n writeTextFile: async () => { throw new Error('not supported'); },\n createTerminal: async () => { throw new Error('not supported'); },\n terminalOutput: async () => { throw new Error('not supported'); },\n releaseTerminal: async () => { throw new Error('not supported'); },\n waitForTerminalExit: async () => { throw new Error('not supported'); },\n killTerminal: async () => { throw new Error('not supported'); },\n }), stream);\n\n child.on('exit', (code) => {\n this.autoImplProcess = null;\n this.autoImplStatus.running = false;\n const success = code === 0;\n this.sendAutoImplSSE({ event: 'complete', data: { success, exitCode: code, functions, message: success ? '✅ ACP Auto-implement 완료' : `❌ ACP 에이전트 종료 (code: ${code})` } });\n try { this.providerLoader.reload(); } catch { /* ignore */ }\n try { fs.unlinkSync(promptFile); } catch { /* ignore */ }\n this.log(`Auto-implement (ACP) ${success ? 'completed' : 'failed'}: ${type} (exit: ${code})`);\n });\n\n // ACP handshake flow (async, runs in background)\n (async () => {\n try {\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'initializing', message: 'ACP initialize...' } });\n await connection.initialize({ protocolVersion: PROTOCOL_VERSION, clientCapabilities: {} });\n\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'session', message: 'ACP session 생성 중...' } });\n const session = await connection.newSession({ cwd: providerDir, mcpServers: [] });\n const sessionId = session?.sessionId;\n if (!sessionId) throw new Error('No sessionId returned from session/new');\n\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'prompting', message: `프롬프트 전송 중 (${prompt.length} chars)...` } });\n await connection.prompt({\n sessionId,\n prompt: [{ type: 'text', text: prompt }],\n });\n\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_done', status: 'complete', message: '✅ ACP 프롬프트 처리 완료' } });\n } catch (e: any) {\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `[ACP Error] ${e.message}\\n`, stream: 'stderr' } });\n this.log(`Auto-implement ACP error: ${e.message}`);\n // Process exit will trigger the 'complete' SSE event\n if (child.exitCode === null) { child.kill('SIGTERM'); }\n }\n })();\n\n this.json(res, 202, {\n started: true, type, agent: spawn.command, functions, providerDir,\n message: 'ACP Auto-implement started. Connect to SSE for progress.',\n sseUrl: `/api/providers/${type}/auto-implement/status`,\n });\n return;\n }\n\n // ─── CLI Agent: stdin pipe approach ───\n const command: string = spawn.command;\n // Strip interactive-only flags for auto-implement (non-interactive mode)\n const interactiveFlags = ['--yolo', '--interactive', '-i'];\n const baseArgs: string[] = [...(spawn.args || [])].filter((a: string) => !interactiveFlags.includes(a));\n let args: string[];\n let useStdin = true;\n\n if (command === 'claude') {\n // Claude Code: --print mode, skip permissions for non-interactive auto-implement\n args = [...baseArgs, '--print', '--dangerously-skip-permissions', '--add-dir', providerDir];\n useStdin = true;\n } else if (command === 'gemini') {\n // Gemini CLI: -p (non-interactive mode) with stdin piped prompt\n // -p \"\" means \"non-interactive mode, read prompt from stdin\"\n // -y for yolo (auto-approve all), -s false for no sandbox\n args = [...baseArgs, '-p', '', '-y', '-s', 'false'];\n if (model) {\n args.push('-m', model);\n }\n useStdin = true;\n } else {\n // Codex CLI, etc: pipe prompt via stdin\n args = [...baseArgs];\n }\n\n // 5.5. Check agent binary exists\n const { execSync } = await import('child_process');\n try {\n execSync(`which ${command}`, { stdio: 'pipe' });\n } catch {\n try { fs.unlinkSync(promptFile); } catch { /* ignore */ }\n this.json(res, 400, { error: `Agent binary '${command}' not found on PATH. Install it first: ${(agentProvider as any)?.install || 'check provider docs'}` });\n return;\n }\n\n // 6. Spawn CLI agent via shell pipe (avoids Node.js stdin deadlock on large prompts)\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'spawning', message: `에이전트 실행 중: ${command} ${args.join(' ')} (prompt: ${prompt.length} chars)` } });\n\n this.autoImplStatus = { running: true, type, progress: [] };\n\n const { spawn: spawnFn } = await import('child_process');\n // Shell pipe: cat promptFile | command args...\n // This avoids Node.js stdin buffer deadlock and ensures proper EOF signaling\n const escapedArgs = args.map(a => `'${a.replace(/'/g, \"'\\\\''\")}'`).join(' ');\n const shellCmd = `cat '${promptFile}' | ${command} ${escapedArgs}`;\n this.log(`Auto-implement spawn: ${shellCmd}`);\n const child = spawnFn('sh', ['-c', shellCmd], {\n cwd: providerDir,\n shell: false,\n timeout: 900000, // 15 min timeout\n stdio: ['ignore', 'pipe', 'pipe'],\n env: { ...process.env, ...(spawn.env || {}) },\n });\n this.autoImplProcess = child;\n child.on('error', (err) => {\n this.log(`Auto-implement spawn error: ${err.message}`);\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `[Spawn Error] ${err.message}\\n`, stream: 'stderr' } });\n });\n\n let stdout = '';\n let stderr = '';\n child.stdout?.on('data', (d: Buffer) => {\n const chunk = d.toString();\n stdout += chunk;\n this.sendAutoImplSSE({ event: 'output', data: { chunk, stream: 'stdout' } });\n });\n child.stderr?.on('data', (d: Buffer) => {\n const chunk = d.toString();\n stderr += chunk;\n this.sendAutoImplSSE({ event: 'output', data: { chunk, stream: 'stderr' } });\n });\n\n child.on('exit', (code) => {\n this.autoImplProcess = null;\n this.autoImplStatus.running = false;\n const success = code === 0;\n this.sendAutoImplSSE({\n event: 'complete',\n data: {\n success,\n exitCode: code,\n functions,\n message: success ? '✅ Auto-implement 완료' : `❌ 에이전트 종료 (code: ${code})`,\n },\n });\n // Reload providers to pick up new scripts\n try { this.providerLoader.reload(); } catch { /* ignore */ }\n // Cleanup temp prompt file\n try { fs.unlinkSync(promptFile); } catch { /* ignore */ }\n this.log(`Auto-implement ${success ? 'completed' : 'failed'}: ${type} (exit: ${code})`);\n });\n\n this.json(res, 202, {\n started: true,\n type,\n agent: command,\n functions,\n providerDir,\n message: 'Auto-implement started. Connect to SSE for progress.',\n sseUrl: `/api/providers/${type}/auto-implement/status`,\n });\n } catch (e: any) {\n this.autoImplStatus.running = false;\n this.json(res, 500, { error: `Auto-implement failed: ${e.message}` });\n }\n }\n\n private buildAutoImplPrompt(\n type: string,\n provider: any,\n providerDir: string,\n functions: string[],\n domContext: any,\n referenceScripts: Record<string, string>,\n ): string {\n const lines: string[] = [];\n\n // ── System instructions ──\n lines.push('You are implementing browser automation scripts for an IDE provider.');\n lines.push('Be concise. Do NOT explain your reasoning. Just edit files directly.');\n lines.push('');\n\n // ── Target ──\n lines.push(`# Target: ${provider.name || type} (${type})`);\n lines.push(`Provider directory: \\`${providerDir}\\``);\n lines.push('');\n\n // ── Existing target files (inline, so no reading needed) ──\n lines.push('## Current Target Files');\n lines.push('These are the files you need to EDIT. They contain TODO stubs — replace them with working implementations.');\n lines.push('');\n\n const scriptsDir = path.join(providerDir, 'scripts');\n if (fs.existsSync(scriptsDir)) {\n const versions = fs.readdirSync(scriptsDir).filter((d: string) => {\n try { return fs.statSync(path.join(scriptsDir, d)).isDirectory(); } catch { return false; }\n }).sort().reverse();\n if (versions.length > 0) {\n const vDir = path.join(scriptsDir, versions[0]);\n lines.push(`Scripts version directory: \\`${vDir}\\``);\n lines.push('');\n for (const file of fs.readdirSync(vDir)) {\n if (file.endsWith('.js')) {\n try {\n const content = fs.readFileSync(path.join(vDir, file), 'utf-8');\n lines.push(`### \\`${file}\\``);\n lines.push('```javascript');\n lines.push(content);\n lines.push('```');\n lines.push('');\n } catch { /* skip */ }\n }\n }\n }\n }\n\n // ── DOM context ──\n if (domContext) {\n lines.push('## Live DOM Analysis (from CDP)');\n lines.push('Use these selectors in your implementations:');\n lines.push('```json');\n lines.push(JSON.stringify(domContext, null, 2));\n lines.push('```');\n lines.push('');\n }\n\n // ── Reference implementation ──\n const funcToFile: Record<string, string> = {\n readChat: 'read_chat.js', sendMessage: 'send_message.js',\n resolveAction: 'resolve_action.js', listSessions: 'list_sessions.js',\n listChats: 'list_chats.js', switchSession: 'switch_session.js',\n newSession: 'new_session.js', focusEditor: 'focus_editor.js',\n openPanel: 'open_panel.js', listModels: 'list_models.js',\n listModes: 'list_modes.js', setModel: 'set_model.js', setMode: 'set_mode.js',\n };\n\n if (Object.keys(referenceScripts).length > 0) {\n lines.push('## Reference Implementation (from Antigravity provider)');\n lines.push('These are WORKING scripts from another IDE. Adapt the PATTERNS (not selectors) for the target IDE.');\n lines.push('');\n for (const fn of functions) {\n const fileName = funcToFile[fn];\n if (fileName && referenceScripts[fileName]) {\n lines.push(`### ${fn} → \\`${fileName}\\``);\n lines.push('```javascript');\n lines.push(referenceScripts[fileName]);\n lines.push('```');\n lines.push('');\n }\n }\n if (referenceScripts['scripts.js']) {\n lines.push('### Router → `scripts.js`');\n lines.push('```javascript');\n lines.push(referenceScripts['scripts.js']);\n lines.push('```');\n lines.push('');\n }\n }\n\n // ── Task ──\n lines.push('## Task');\n lines.push(`Edit files in \\`${providerDir}\\` to implement: **${functions.join(', ')}**`);\n lines.push('');\n\n // ── Rules ──\n lines.push('## Rules');\n lines.push('1. **Scripts WITHOUT params** → IIFE: `(() => { ... })()`');\n lines.push('2. **Scripts WITH params** → arrow: `(params) => { ... }` — router calls `(${script})(${JSON.stringify(params)})`');\n lines.push('3. Use CSS selectors from the DOM analysis above');\n lines.push('4. Always wrap in try-catch, return `JSON.stringify(result)`');\n lines.push('5. Do NOT modify `scripts.js` router — only edit individual `*.js` files');\n lines.push('6. All scripts run in the browser (CDP evaluate) — use DOM APIs only');\n lines.push('');\n\n // ── Output contracts ──\n lines.push('## Required Return Format');\n lines.push('| Function | Return JSON |');\n lines.push('|---|---|');\n lines.push('| readChat | `{ id, status, title, messages: [{role, content, index, kind?, meta?}], inputContent, activeModal }` — optional `kind`: standard, thought, tool, terminal; optional `meta`: e.g. `{ label, isRunning }` for dashboard |');\n lines.push('| sendMessage | `{ sent: false, needsTypeAndSend: true, selector }` |');\n lines.push('| resolveAction | `{ resolved: true/false, clicked? }` |');\n lines.push('| listSessions | `{ sessions: [{ id, title, active, index }] }` |');\n lines.push('| switchSession | `{ switched: true/false }` |');\n lines.push('| newSession | `{ created: true/false }` |');\n lines.push('| listModels | `{ models: [{ name, id }], current }` |');\n lines.push('| setModel | `{ success: true/false }` |');\n lines.push('| listModes | `{ modes: [{ name, id }], current }` |');\n lines.push('| setMode | `{ success: true/false }` |');\n lines.push('| focusEditor | `{ focused: true/false }` |');\n lines.push('| openPanel | `{ opened: true/false }` |');\n lines.push('');\n\n lines.push('## Action');\n lines.push('1. Edit the script files to implement working code');\n lines.push('2. After editing, TEST each function using the DevConsole API (see below)');\n lines.push('3. If a test fails, fix the implementation and re-test');\n lines.push('');\n\n // ── DevConsole API for verification ──\n lines.push('## DevConsole API (for testing)');\n lines.push(`The DevConsole is running at \\`http://127.0.0.1:${DEV_SERVER_PORT}\\`. Use these HTTP APIs to test your implementations.`);\n lines.push('');\n lines.push('### Run a script against the live IDE');\n lines.push('```bash');\n lines.push(`curl -X POST http://127.0.0.1:${DEV_SERVER_PORT}/api/providers/${type}/scripts/run \\\\`);\n lines.push(` -H \"Content-Type: application/json\" \\\\`);\n lines.push(` -d '{\"script\": \"readChat\"}'`);\n lines.push('```');\n lines.push('Replace `\"readChat\"` with any function name. For functions with params:');\n lines.push('```bash');\n lines.push(`curl -X POST http://127.0.0.1:${DEV_SERVER_PORT}/api/providers/${type}/scripts/run \\\\`);\n lines.push(` -H \"Content-Type: application/json\" \\\\`);\n lines.push(` -d '{\"script\": \"sendMessage\", \"params\": {\"text\": \"hello\"}}'`);\n lines.push('```');\n lines.push('');\n lines.push('### Evaluate raw JS in the IDE (CDP)');\n lines.push('```bash');\n lines.push(`curl -X POST http://127.0.0.1:${DEV_SERVER_PORT}/api/cdp/evaluate \\\\`);\n lines.push(` -H \"Content-Type: application/json\" \\\\`);\n lines.push(` -d '{\"expression\": \"document.title\", \"ideType\": \"${type}\"}'`);\n lines.push('```');\n lines.push('');\n lines.push('### Reload provider (after editing files)');\n lines.push('```bash');\n lines.push(`curl -X POST http://127.0.0.1:${DEV_SERVER_PORT}/api/providers/reload`);\n lines.push('```');\n lines.push('**IMPORTANT**: After editing script files, you MUST call reload before running scripts.');\n lines.push('');\n lines.push('### Workflow: Edit → Reload → Test → Fix');\n lines.push('1. Edit the `.js` file');\n lines.push('2. `curl POST /api/providers/reload`');\n lines.push(`3. \\`curl POST /api/providers/${type}/scripts/run -d '{\"script\":\"readChat\"}'\\``);\n lines.push('4. Check the response — if error, fix and repeat from step 1');\n lines.push('');\n lines.push('Start NOW. Edit files, then test each one.');\n\n return lines.join('\\n');\n }\n\n private handleAutoImplSSE(type: string, 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: ${JSON.stringify({ type: 'connected', running: this.autoImplStatus.running, providerType: type })}\\n\\n`);\n\n // Replay existing progress\n for (const p of this.autoImplStatus.progress) {\n res.write(`event: ${p.event}\\ndata: ${JSON.stringify(p.data)}\\n\\n`);\n }\n\n this.autoImplSSEClients.push(res);\n req.on('close', () => {\n this.autoImplSSEClients = this.autoImplSSEClients.filter(c => c !== res);\n });\n }\n\n private handleAutoImplCancel(_type: string, _req: http.IncomingMessage, res: http.ServerResponse): void {\n if (this.autoImplProcess) {\n this.autoImplProcess.kill('SIGTERM');\n setTimeout(() => { if (this.autoImplProcess) this.autoImplProcess.kill('SIGKILL'); }, 3000);\n this.sendAutoImplSSE({ event: 'complete', data: { success: false, exitCode: -1, message: '⛔ 사용자에 의해 중단됨' } });\n this.autoImplProcess = null;\n this.autoImplStatus.running = false;\n this.json(res, 200, { cancelled: true });\n } else {\n this.autoImplStatus.running = false;\n this.json(res, 200, { cancelled: false, message: 'No running process' });\n }\n }\n\n private sendAutoImplSSE(msg: { event: string; data: any }): void {\n this.autoImplStatus.progress.push(msg);\n const payload = `event: ${msg.event}\\ndata: ${JSON.stringify(msg.data)}\\n\\n`;\n for (const client of this.autoImplSSEClients) {\n try { client.write(payload); } catch { /* ignore */ }\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 * Generates provider.json + scripts/ directory structure (Antigravity pattern).\n *\n * New pattern:\n * - Scripts WITHOUT params: self-invoking IIFE — (() => { ... })()\n * - Scripts WITH params: function expression — (params) => { ... }\n * Router invokes: `(${script})(${JSON.stringify(params)})`\n * - Each function is a separate .js file in scripts/<version>/\n * - scripts.js router loads + invokes individual files\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 version?: string;\n}\n\nexport interface ScaffoldResult {\n 'provider.json': string;\n files?: Record<string, string>;\n}\n\nexport function generateTemplate(type: string, name: string, category: string, opts: ScaffoldOptions = {}): string {\n const result = generateFiles(type, name, category, opts);\n return result['provider.json'];\n}\n\n/**\n * Generate provider.json + per-function script files.\n * Returns a map of relative paths -> file contents.\n */\nexport function generateFiles(type: string, name: string, category: string, opts: ScaffoldOptions = {}): ScaffoldResult {\n const { cdpPorts, cli, processName, installPath, binary, extensionId, version = '0.1' } = opts;\n\n // ─── CLI / ACP: provider.json only ───\n if (category === 'cli' || category === 'acp') {\n const bin = binary || type;\n const meta: Record<string, any> = {\n type,\n name,\n category,\n icon: '💻',\n binary: bin,\n spawn: {\n command: bin,\n args: [],\n shell: true,\n },\n patterns: {\n prompt: ['^[>$#] '],\n generating: ['\\\\.{3}$', 'thinking'],\n approval: ['\\\\(y\\\\/n\\\\)', 'approve', 'allow'],\n ready: ['ready'],\n },\n };\n return { 'provider.json': JSON.stringify(meta, null, 2) + '\\n' };\n }\n\n // ─── IDE / Extension: provider.json + scripts/ directory ───\n const isExtension = category === 'extension';\n const scriptDir = `scripts/${version}`;\n\n const meta: Record<string, any> = {\n type,\n name,\n category,\n displayName: name,\n icon: isExtension ? '🧩' : '💻',\n };\n if (cli) meta.cli = cli;\n if (cdpPorts) meta.cdpPorts = cdpPorts;\n else if (!isExtension) meta.cdpPorts = [9222, 9223];\n if (processName) meta.processNames = { darwin: processName };\n if (installPath) meta.paths = { darwin: [installPath] };\n if (isExtension) {\n meta.extensionId = extensionId || `publisher.${type}`;\n meta.extensionIdPattern = `${extensionId || type}`;\n } else {\n meta.inputMethod = 'cdp-type-and-send';\n meta.inputSelector = '[contenteditable=\"true\"][role=\"textbox\"]';\n meta.providerVersion = '1.0.0';\n meta.compatibility = [\n { ideVersion: `>=${version}.0`, scriptDir },\n ];\n meta.defaultScriptDir = scriptDir;\n }\n\n // ─── Individual script files ───\n const files: Record<string, string> = {};\n\n // Router (scripts.js)\n files[`${scriptDir}/scripts.js`] = `/**\n * ${name} CDP Scripts — Router\n *\n * Loads individual .js files and invokes with params.\n * Pattern:\n * - No-params scripts: loaded as-is (IIFE)\n * - With-params scripts: \\`(\\${script})(\\${JSON.stringify(params)})\\`\n */\n\n'use strict';\n\nconst fs = require('fs');\nconst path = require('path');\n\nfunction load(name) {\n try { return fs.readFileSync(path.join(__dirname, name), 'utf-8'); }\n catch { return null; }\n}\n\nfunction withParams(name, params) {\n const script = load(name);\n if (!script) return null;\n return \\`(\\${script})(\\${JSON.stringify(params)})\\`;\n}\n\n// ─── Core (no params — IIFE) ───\n\nmodule.exports.readChat = () => load('read_chat.js');\nmodule.exports.sendMessage = () => load('send_message.js');\nmodule.exports.listSessions = () => load('list_sessions.js');\nmodule.exports.newSession = () => load('new_session.js');\nmodule.exports.focusEditor = () => load('focus_editor.js');\nmodule.exports.openPanel = () => load('open_panel.js');\nmodule.exports.listModels = () => load('list_models.js');\nmodule.exports.listModes = () => load('list_modes.js');\n\n// ─── With params (function expression) ───\n\nmodule.exports.switchSession = (params) => {\n const index = typeof params === 'number' ? params : params?.index ?? 0;\n const title = typeof params === 'string' ? params : params?.title || null;\n return withParams('switch_session.js', { index, title });\n};\n\nmodule.exports.resolveAction = (params) => {\n const action = typeof params === 'string' ? params : params?.action || 'approve';\n const buttonText = params?.button || params?.buttonText\n || (action === 'approve' ? 'Accept' : action === 'reject' ? 'Reject' : action);\n return withParams('resolve_action.js', { buttonText });\n};\n\nmodule.exports.setModel = (params) => {\n const model = typeof params === 'string' ? params : params?.model;\n return withParams('set_model.js', { model });\n};\n\nmodule.exports.setMode = (params) => {\n const mode = typeof params === 'string' ? params : params?.mode;\n return withParams('set_mode.js', { mode });\n};\n`;\n\n // read_chat.js — most complex, stub with detailed TODO\n files[`${scriptDir}/read_chat.js`] = `/**\n * ${name} — read_chat\n *\n * Extract chat messages, status, and approval state from DOM.\n *\n * TODO: Identify via CDP/DevConsole:\n * 1. Chat container selector\n * 2. User message selector + class pattern\n * 3. Assistant message selector + class pattern\n * 4. Status detection (generating/idle/waiting_approval)\n * 5. Approval dialog detection (buttons, modal)\n * 6. Input field selector\n *\n * → { id, status, title, messages[], inputContent, activeModal }\n */\n(() => {\n try {\n const messages = [];\n let status = 'idle';\n let activeModal = null;\n\n // TODO: Query chat container and extract messages\n // Example:\n // document.querySelectorAll('.chat-message').forEach(el => {\n // const role = el.classList.contains('user') ? 'user' : 'assistant';\n // messages.push({ role, content: el.innerText.trim(), index: messages.length });\n // });\n\n // TODO: Detect generating state\n // TODO: Detect approval dialogs -> status = 'waiting_approval'\n\n const inputEl = document.querySelector('[contenteditable=\"true\"]');\n const inputContent = inputEl?.innerText?.trim() || '';\n\n return JSON.stringify({\n id: 'active',\n status,\n title: document.title,\n messages,\n inputContent,\n activeModal,\n });\n } catch(e) {\n return JSON.stringify({ id: '', status: 'error', messages: [], error: e.message });\n }\n})()\n`;\n\n // send_message.js\n files[`${scriptDir}/send_message.js`] = `/**\n * ${name} — send_message\n *\n * For cdp-type-and-send IDEs: returns selector for daemon to type into.\n * → { sent: false, needsTypeAndSend: true, selector }\n */\n(() => {\n try {\n const input = document.querySelector('${meta.inputSelector || '[contenteditable=\"true\"]'}');\n if (!input) return JSON.stringify({ sent: false, error: 'Input not found' });\n return JSON.stringify({\n sent: false,\n needsTypeAndSend: true,\n selector: '${meta.inputSelector || '[contenteditable=\"true\"]'}',\n });\n } catch(e) {\n return JSON.stringify({ sent: false, error: e.message });\n }\n})()\n`;\n\n // list_sessions.js\n files[`${scriptDir}/list_sessions.js`] = `/**\n * ${name} — list_sessions\n *\n * TODO: Query session/chat list from sidebar.\n * → { sessions: [{ id, title, active, index }] }\n */\n(() => {\n try {\n const sessions = [];\n // TODO: Find session list container and parse items\n return JSON.stringify({ sessions });\n } catch(e) {\n return JSON.stringify({ sessions: [], error: e.message });\n }\n})()\n`;\n\n // switch_session.js\n files[`${scriptDir}/switch_session.js`] = `/**\n * ${name} — switch_session\n *\n * params.index: number, params.title: string|null\n * TODO: Click on session in sidebar by title or index.\n * → { switched: true/false }\n */\n(params) => {\n try {\n // TODO: Find session list and click target\n return JSON.stringify({ switched: false, error: 'Not implemented' });\n } catch(e) {\n return JSON.stringify({ switched: false, error: e.message });\n }\n}\n`;\n\n // new_session.js\n files[`${scriptDir}/new_session.js`] = `/**\n * ${name} — new_session\n *\n * TODO: Click \"New Chat\" button.\n * → { created: true/false }\n */\n(() => {\n try {\n const btn = document.querySelector('[aria-label*=\"New Chat\"], [aria-label*=\"New Composer\"]');\n if (btn) { btn.click(); return JSON.stringify({ created: true }); }\n return JSON.stringify({ created: false, error: 'New Chat button not found' });\n } catch(e) {\n return JSON.stringify({ created: false, error: e.message });\n }\n})()\n`;\n\n // focus_editor.js\n files[`${scriptDir}/focus_editor.js`] = `/**\n * ${name} — focus_editor\n */\n(() => {\n try {\n const input = document.querySelector('${meta.inputSelector || '[contenteditable=\"true\"]'}');\n if (input) { input.focus(); return 'focused'; }\n return 'not_found';\n } catch(e) { return 'error'; }\n})()\n`;\n\n // open_panel.js\n files[`${scriptDir}/open_panel.js`] = `/**\n * ${name} — open_panel\n *\n * TODO: Open chat/AI panel if not visible.\n */\n(() => {\n try {\n // TODO: Check if panel visible, if not find toggle button\n return 'not_found';\n } catch(e) { return 'error'; }\n})()\n`;\n\n // resolve_action.js\n files[`${scriptDir}/resolve_action.js`] = `/**\n * ${name} — resolve_action\n *\n * params.buttonText: string — button text to find and click.\n * → { resolved: true/false, clicked? }\n */\n(params) => {\n try {\n const btns = [...document.querySelectorAll('button, [role=\"button\"]')].filter(b => b.offsetWidth > 0);\n const searchText = (params.buttonText || '').toLowerCase();\n const target = btns.find(b => (b.textContent||'').trim().toLowerCase().includes(searchText));\n if (target) {\n target.click();\n return JSON.stringify({ resolved: true, clicked: target.textContent.trim() });\n }\n return JSON.stringify({ resolved: false, available: btns.map(b => b.textContent.trim()).filter(Boolean).slice(0, 10) });\n } catch(e) { return JSON.stringify({ resolved: false, error: e.message }); }\n}\n`;\n\n // list_models.js\n files[`${scriptDir}/list_models.js`] = `/**\n * ${name} — list_models\n *\n * TODO: Open model dropdown and extract model list.\n * → { models[], current }\n */\n(() => {\n try {\n return JSON.stringify({ models: [], current: '' });\n } catch(e) { return JSON.stringify({ models: [], current: '', error: e.message }); }\n})()\n`;\n\n // list_modes.js\n files[`${scriptDir}/list_modes.js`] = `/**\n * ${name} — list_modes\n *\n * TODO: Open mode dropdown and extract mode list.\n * → { modes[], current }\n */\n(() => {\n try {\n return JSON.stringify({ modes: [], current: '' });\n } catch(e) { return JSON.stringify({ modes: [], current: '', error: e.message }); }\n})()\n`;\n\n // set_model.js\n files[`${scriptDir}/set_model.js`] = `/**\n * ${name} — set_model\n *\n * params.model: string\n * TODO: Open model dropdown and select target model.\n * → { success: true/false }\n */\nasync (params) => {\n try {\n return JSON.stringify({ success: false, error: 'Not implemented' });\n } catch(e) { return JSON.stringify({ success: false, error: e.message }); }\n}\n`;\n\n // set_mode.js\n files[`${scriptDir}/set_mode.js`] = `/**\n * ${name} — set_mode\n *\n * params.mode: string\n * TODO: Open mode dropdown and select target mode.\n * → { success: true/false }\n */\nasync (params) => {\n try {\n return JSON.stringify({ success: false, error: 'Not implemented' });\n } catch(e) { return JSON.stringify({ success: false, error: e.message }); }\n}\n`;\n\n return {\n 'provider.json': JSON.stringify(meta, null, 2) + '\\n',\n files,\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 './detection/ide-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 * Daemon Lifecycle — Shared init + shutdown for cloud/standalone\n *\n * initDaemonComponents(): Creates all core daemon components in correct order.\n * shutdownDaemonComponents(): Graceful shutdown of all components.\n *\n * Transport-specific setup (ServerConnection, P2P, HTTP/WS) remains in each daemon.\n */\n\nimport { DaemonCdpManager } from '../cdp/manager.js';\nimport { DaemonCdpInitializer, type CdpInitializerConfig } from '../cdp/initializer.js';\nimport { setupIdeInstance, type CdpSetupContext } from '../cdp/setup.js';\nimport { DaemonCommandHandler } from '../commands/handler.js';\nimport { DaemonCommandRouter, type CommandRouterDeps } from '../commands/router.js';\nimport { DaemonCliManager } from '../commands/cli-manager.js';\nimport { DaemonAgentStreamManager } from '../agent-stream/manager.js';\nimport { AgentStreamPoller } from '../agent-stream/poller.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport { detectIDEs } from '../detection/ide-detector.js';\nimport { installGlobalInterceptor, LOG } from '../logging/logger.js';\nimport { loadConfig } from '../config/config.js';\n\n// ─── Init Config ───\n\nexport interface DaemonInitConfig {\n /** ProviderLoader log function */\n providerLogFn?: (msg: string) => void;\n\n /** CLI Manager deps (transport-specific) */\n cliManagerDeps: {\n getServerConn: () => any;\n getP2p: () => any;\n onStatusChange: () => void;\n removeAgentTracking: (key: string) => void;\n };\n\n /** CDP config */\n enabledIdes?: string[];\n\n /** Router transport-specific callbacks */\n onStatusChange?: () => void;\n onPostChatCommand?: () => void;\n getCdpLogFn?: (ideType: string) => (msg: string) => void;\n\n /** Additional callback after CDP manager created (transport-specific extras) */\n onCdpManagerSetup?: (ideType: string, manager: DaemonCdpManager, managerKey: string) => void | Promise<void>;\n\n /** Poller callback (transport-specific) */\n onStreamsUpdated?: (ideType: string, streams: any[]) => void;\n\n /** Instance ticking interval (ms), default 5000 */\n tickIntervalMs?: number;\n\n /** CDP scan interval (ms), default 30000 */\n cdpScanIntervalMs?: number;\n}\n\n// ─── Result ───\n\nexport interface DaemonComponents {\n providerLoader: ProviderLoader;\n instanceManager: ProviderInstanceManager;\n cliManager: DaemonCliManager;\n commandHandler: DaemonCommandHandler;\n agentStreamManager: DaemonAgentStreamManager;\n router: DaemonCommandRouter;\n poller: AgentStreamPoller;\n cdpInitializer: DaemonCdpInitializer;\n cdpManagers: Map<string, DaemonCdpManager>;\n instanceIdMap: Map<string, string>;\n detectedIdes: { value: any[] };\n}\n\n// ─── Init ───\n\n/**\n * Initialize all daemon core components.\n * Shared by both cloud and standalone daemons.\n *\n * Order:\n * 1. Global log interceptor\n * 2. ProviderLoader\n * 3. InstanceManager + CliManager\n * 4. Detect IDEs\n * 5. CdpInitializer → connectAll + periodic scan + discovery\n * 6. CommandHandler + AgentStreamManager\n * 7. Router + Poller\n * 8. Start instance ticking\n */\nexport async function initDaemonComponents(config: DaemonInitConfig): Promise<DaemonComponents> {\n // 1. Global log interceptor\n installGlobalInterceptor();\n\n // 2. ProviderLoader\n const providerLoader = new ProviderLoader({\n logFn: config.providerLogFn,\n });\n providerLoader.loadAll();\n providerLoader.registerToDetector();\n\n // 3. Shared state\n const instanceManager = new ProviderInstanceManager();\n const cdpManagers = new Map<string, DaemonCdpManager>();\n const instanceIdMap = new Map<string, string>();\n const detectedIdesRef = { value: [] as any[] };\n\n // 4. CLI Manager\n const cliManager = new DaemonCliManager({\n ...config.cliManagerDeps,\n getInstanceManager: () => instanceManager,\n }, providerLoader);\n\n // 5. Detect IDEs\n LOG.info('Init', 'Detecting IDEs...');\n detectedIdesRef.value = await detectIDEs();\n const installed = detectedIdesRef.value.filter((i: any) => i.installed);\n LOG.info('Init', `Found ${installed.length} IDE(s): ${installed.map((i: any) => i.id).join(', ') || 'none'}`);\n\n // 6. CDP Initializer — connect + register instances\n const cdpSetupContext: CdpSetupContext = {\n providerLoader,\n instanceManager,\n cdpManagers,\n instanceIdMap,\n };\n\n const cdpInitializer = new DaemonCdpInitializer({\n providerLoader,\n cdpManagers,\n enabledIdes: config.enabledIdes || loadConfig().enabledIdes || undefined,\n onConnected: async (ideType, manager, managerKey) => {\n // Register IDE instance (shared logic)\n await setupIdeInstance(cdpSetupContext, { ideType, manager, managerKey });\n // Transport-specific extras\n await config.onCdpManagerSetup?.(ideType, manager, managerKey);\n },\n });\n await cdpInitializer.connectAll(detectedIdesRef.value);\n cdpInitializer.startPeriodicScan(config.cdpScanIntervalMs ?? 30_000);\n cdpInitializer.startDiscovery(30_000);\n\n // 7. CommandHandler\n const commandHandler = new DaemonCommandHandler({\n cdpManagers,\n ideType: 'unknown',\n adapters: cliManager.adapters,\n providerLoader,\n instanceManager,\n instanceIdMap,\n });\n\n // 8. AgentStreamManager\n const agentStreamManager = new DaemonAgentStreamManager(\n LOG.forComponent('AgentStream').asLogFn(),\n providerLoader,\n );\n commandHandler.setAgentStreamManager(agentStreamManager);\n\n // 9. Router + Poller (with internal cross-wiring)\n // Note: poller is declared first so router's onIdeConnected closure captures it\n let poller: AgentStreamPoller;\n\n const router = new DaemonCommandRouter({\n commandHandler,\n cliManager,\n cdpManagers,\n providerLoader,\n instanceManager,\n detectedIdes: detectedIdesRef,\n instanceIdMap,\n onCdpManagerCreated: async (ideType: string, manager: DaemonCdpManager) => {\n // For launch_ide: register instance + extension providers\n await setupIdeInstance(cdpSetupContext, { ideType, manager });\n await config.onCdpManagerSetup?.(ideType, manager, ideType);\n },\n onIdeConnected: () => poller?.start(),\n onStatusChange: config.onStatusChange,\n onPostChatCommand: config.onPostChatCommand,\n getCdpLogFn: config.getCdpLogFn || ((ideType: string) => LOG.forComponent(`CDP:${ideType}`).asLogFn()),\n });\n\n poller = new AgentStreamPoller({\n agentStreamManager,\n providerLoader,\n instanceManager,\n cdpManagers,\n onStreamsUpdated: config.onStreamsUpdated,\n });\n poller.start();\n\n // 10. Start instance ticking\n instanceManager.startTicking(config.tickIntervalMs ?? 5_000);\n\n return {\n providerLoader,\n instanceManager,\n cliManager,\n commandHandler,\n agentStreamManager,\n router,\n poller,\n cdpInitializer,\n cdpManagers,\n instanceIdMap,\n detectedIdes: detectedIdesRef,\n };\n}\n\n// ─── Shutdown ───\n\n/**\n * Graceful shutdown of all daemon components.\n * Shared by both cloud and standalone daemons.\n *\n * Order:\n * 1. Stop timers (poller, cdpInitializer)\n * 2. Dispose agent stream\n * 3. Shutdown CLIs\n * 4. Dispose instances\n * 5. Disconnect CDPs\n */\nexport async function shutdownDaemonComponents(components: DaemonComponents): Promise<void> {\n const {\n poller, cdpInitializer, agentStreamManager,\n cliManager, instanceManager, cdpManagers,\n } = components;\n\n // 1. Stop timers\n poller.stop();\n cdpInitializer.stop();\n\n // 2. Dispose agent stream\n try {\n const anyCdp = [...cdpManagers.values()].find(m => m.isConnected);\n if (agentStreamManager && anyCdp) {\n await agentStreamManager.dispose(anyCdp);\n }\n } catch (e: any) { LOG.warn('Shutdown', `AgentStream dispose: ${e?.message}`); }\n\n // 3. Shutdown CLIs\n try { await cliManager.shutdownAll(); } catch { /* noop */ }\n\n // 4. Dispose instances\n try { instanceManager.disposeAll(); } catch { /* noop */ }\n\n // 5. Disconnect CDPs\n for (const m of cdpManagers.values()) {\n try { m.disconnect(); } catch { /* noop */ }\n }\n cdpManagers.clear();\n}\n"],"mappings":"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","names":["path","import_fs","import_os","os","dirname","import_child_process","os","resolve","platform","os","import_child_process","fs","path","os","stripAnsi","resolve","WebSocket","reject","crypto","fs","path","os","cdp","fs","path","os","config","result","state","result","import_child_process","os","path","fs","path","os","loadConfig","saveConfig","execSync","resolve","http","port","resolve","fs","platform","loadConfig","fs","path","os","LOG_DIR","getDateStr","currentDate","writeCount","fs","os","os","path","crypto","os","path","import_child_process","fs","arch","crypto","dirName","import_child_process","resolve","chalk","instanceManager","execSync","state","fs","path","os","import_child_process","import_os","findBinary","checkPathExists","http","fs","path","os","meta","path","resolve","spawn","body","ClientSideConnection","ndJsonStream","PROTOCOL_VERSION","Readable","Writable","spawnFn","child","execSync","import_child_process","fs","resolve"]}
1
+ {"version":3,"sources":["../src/config/workspaces.ts","../src/config/config.ts","../src/index.ts","../src/config/workspace-activity.ts","../src/detection/ide-detector.ts","../src/detection/cli-detector.ts","../src/system/host-memory.ts","../src/cdp/manager.ts","../src/logging/logger.ts","../src/cdp/devtools.ts","../src/providers/ide-provider-instance.ts","../src/providers/status-monitor.ts","../src/providers/extension-provider-instance.ts","../src/config/chat-history.ts","../src/cdp/setup.ts","../src/cdp/scanner.ts","../src/cdp/initializer.ts","../src/commands/handler.ts","../src/commands/chat-commands.ts","../src/commands/cdp-commands.ts","../src/commands/stream-commands.ts","../src/commands/workspace-commands.ts","../src/launch.ts","../src/providers/provider-loader.ts","../src/commands/router.ts","../src/logging/command-log.ts","../src/status/reporter.ts","../src/commands/cli-manager.ts","../src/cli-adapters/provider-cli-adapter.ts","../src/providers/cli-provider-instance.ts","../src/providers/acp-provider-instance.ts","../src/providers/contracts.ts","../src/ipc-protocol.ts","../src/agent-stream/provider-adapter.ts","../src/agent-stream/manager.ts","../src/agent-stream/poller.ts","../src/providers/provider-instance-manager.ts","../src/providers/version-archive.ts","../src/daemon/dev-server.ts","../src/daemon/scaffold-template.ts","../src/installer.ts","../src/boot/daemon-lifecycle.ts"],"sourcesContent":["/**\n * Saved workspaces — shared by IDE launch, CLI, ACP (daemon-local).\n */\n\nimport * as fs from 'fs';\nimport * as os from 'os';\nimport * as path from 'path';\nimport { randomUUID } from 'crypto';\nimport type { ADHDevConfig } from './config.js';\n\nexport interface WorkspaceEntry {\n id: string;\n path: string;\n label?: string;\n addedAt: number;\n}\n\nconst MAX_WORKSPACES = 50;\n\nexport function expandPath(p: string): string {\n const t = (p || '').trim();\n if (!t) return '';\n if (t.startsWith('~')) return path.join(os.homedir(), t.slice(1).replace(/^\\//, ''));\n return path.resolve(t);\n}\n\nexport function validateWorkspacePath(absPath: string): { ok: true } | { ok: false; error: string } {\n try {\n if (!absPath) return { ok: false, error: 'Path required' };\n if (!fs.existsSync(absPath)) return { ok: false, error: 'Path does not exist' };\n const st = fs.statSync(absPath);\n if (!st.isDirectory()) return { ok: false, error: 'Not a directory' };\n return { ok: true };\n } catch (e: any) {\n return { ok: false, error: e?.message || 'Invalid path' };\n }\n}\n\n/** Default workspace label from path */\nexport function defaultWorkspaceLabel(absPath: string): string {\n const base = path.basename(absPath) || absPath;\n return base;\n}\n\n/**\n * Ensure config.workspaces exists; seed from recentCliWorkspaces once (same paths).\n */\nexport function migrateWorkspacesFromRecent(config: ADHDevConfig): ADHDevConfig {\n if (!config.workspaces) config.workspaces = [];\n if (config.workspaces.length > 0) return config;\n\n const recent = config.recentCliWorkspaces || [];\n const now = Date.now();\n for (const raw of recent) {\n const abs = expandPath(raw);\n if (!abs || validateWorkspacePath(abs).ok !== true) continue;\n if (config.workspaces.some(w => path.resolve(w.path) === abs)) continue;\n config.workspaces.push({\n id: randomUUID(),\n path: abs,\n label: defaultWorkspaceLabel(abs),\n addedAt: now,\n });\n if (config.workspaces.length >= MAX_WORKSPACES) break;\n }\n return config;\n}\n\nexport function getDefaultWorkspacePath(config: ADHDevConfig): string | null {\n const id = config.defaultWorkspaceId;\n if (!id) return null;\n const w = (config.workspaces || []).find(x => x.id === id);\n if (!w) return null;\n const abs = expandPath(w.path);\n if (validateWorkspacePath(abs).ok !== true) return null;\n return abs;\n}\n\nexport function getWorkspaceState(config: ADHDevConfig): {\n workspaces: WorkspaceEntry[];\n defaultWorkspaceId: string | null;\n defaultWorkspacePath: string | null;\n} {\n const workspaces = [...(config.workspaces || [])].sort((a, b) => b.addedAt - a.addedAt);\n const defaultWorkspacePath = getDefaultWorkspacePath(config);\n return {\n workspaces,\n defaultWorkspaceId: config.defaultWorkspaceId ?? null,\n defaultWorkspacePath,\n };\n}\n\nexport type LaunchDirectorySource = 'dir' | 'workspaceId' | 'defaultWorkspace' | 'home';\n\nexport type ResolveLaunchDirectoryResult =\n | { ok: true; path: string; source: LaunchDirectorySource }\n | { ok: false; code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED'; message: string };\n\n/**\n * Resolve cwd for CLI/ACP. No implicit default workspace or home — caller must pass\n * useDefaultWorkspace or useHome (or an explicit dir / workspaceId).\n */\nexport function resolveLaunchDirectory(\n args: {\n dir?: string;\n workspaceId?: string;\n useDefaultWorkspace?: boolean;\n useHome?: boolean;\n } | undefined,\n config: ADHDevConfig,\n): ResolveLaunchDirectoryResult {\n const a = args || {};\n if (a.dir != null && String(a.dir).trim()) {\n const abs = expandPath(String(a.dir).trim());\n if (abs && validateWorkspacePath(abs).ok === true) {\n return { ok: true, path: abs, source: 'dir' };\n }\n return {\n ok: false,\n code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED',\n message: abs ? 'Directory path is not valid or does not exist' : 'Invalid directory path',\n };\n }\n if (a.workspaceId) {\n const w = (config.workspaces || []).find(x => x.id === a.workspaceId);\n if (w) {\n const abs = expandPath(w.path);\n if (validateWorkspacePath(abs).ok === true) {\n return { ok: true, path: abs, source: 'workspaceId' };\n }\n }\n return {\n ok: false,\n code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED',\n message: 'Saved workspace not found or path is no longer valid',\n };\n }\n if (a.useDefaultWorkspace === true) {\n const d = getDefaultWorkspacePath(config);\n if (d) return { ok: true, path: d, source: 'defaultWorkspace' };\n return {\n ok: false,\n code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED',\n message: 'No default workspace is set',\n };\n }\n if (a.useHome === true) {\n return { ok: true, path: os.homedir(), source: 'home' };\n }\n return {\n ok: false,\n code: 'WORKSPACE_LAUNCH_CONTEXT_REQUIRED',\n message: 'Choose a directory, saved workspace, default workspace, or home before launching.',\n };\n}\n\n/**\n * IDE folder from explicit args only (`workspace`, `workspaceId`, or `useDefaultWorkspace: true`).\n */\nexport function resolveIdeWorkspaceFromArgs(\n args: {\n workspace?: string;\n workspaceId?: string;\n useDefaultWorkspace?: boolean;\n } | undefined,\n config: ADHDevConfig,\n): string | undefined {\n const ar = args || {};\n if (ar.workspace) {\n const abs = expandPath(ar.workspace);\n if (abs && validateWorkspacePath(abs).ok === true) return abs;\n }\n if (ar.workspaceId) {\n const w = (config.workspaces || []).find(x => x.id === ar.workspaceId);\n if (w) {\n const abs = expandPath(w.path);\n if (validateWorkspacePath(abs).ok === true) return abs;\n }\n }\n if (ar.useDefaultWorkspace === true) {\n return getDefaultWorkspacePath(config) || undefined;\n }\n return undefined;\n}\n\n/**\n * IDE launch folder — same saved workspaces + default as CLI/ACP.\n * After explicit `workspace` / `workspaceId` / `useDefaultWorkspace: true`, falls back to\n * config default workspace when set. Pass `useDefaultWorkspace: false` to open IDE without that folder.\n */\nexport function resolveIdeLaunchWorkspace(\n args: {\n workspace?: string;\n workspaceId?: string;\n useDefaultWorkspace?: boolean;\n } | undefined,\n config: ADHDevConfig,\n): string | undefined {\n const direct = resolveIdeWorkspaceFromArgs(args, config);\n if (direct) return direct;\n if (args?.useDefaultWorkspace === false) return undefined;\n return getDefaultWorkspacePath(config) || undefined;\n}\n\nexport function findWorkspaceByPath(config: ADHDevConfig, rawPath: string): WorkspaceEntry | undefined {\n const abs = path.resolve(expandPath(rawPath));\n if (!abs) return undefined;\n return (config.workspaces || []).find(w => path.resolve(expandPath(w.path)) === abs);\n}\n\nexport function addWorkspaceEntry(config: ADHDevConfig, rawPath: string, label?: string): { config: ADHDevConfig; entry: WorkspaceEntry } | { error: string } {\n const abs = expandPath(rawPath);\n const v = validateWorkspacePath(abs);\n if (!v.ok) return { error: v.error };\n\n const list = [...(config.workspaces || [])];\n if (list.some(w => path.resolve(w.path) === abs)) {\n return { error: 'Workspace already in list' };\n }\n if (list.length >= MAX_WORKSPACES) {\n return { error: `Maximum ${MAX_WORKSPACES} workspaces` };\n }\n const entry: WorkspaceEntry = {\n id: randomUUID(),\n path: abs,\n label: (label || '').trim() || defaultWorkspaceLabel(abs),\n addedAt: Date.now(),\n };\n list.push(entry);\n return { config: { ...config, workspaces: list }, entry };\n}\n\nexport function removeWorkspaceEntry(config: ADHDevConfig, id: string): { config: ADHDevConfig } | { error: string } {\n const list = (config.workspaces || []).filter(w => w.id !== id);\n if (list.length === (config.workspaces || []).length) return { error: 'Workspace not found' };\n let defaultWorkspaceId = config.defaultWorkspaceId;\n if (defaultWorkspaceId === id) defaultWorkspaceId = null;\n return { config: { ...config, workspaces: list, defaultWorkspaceId } };\n}\n\nexport function setDefaultWorkspaceId(config: ADHDevConfig, id: string | null): { config: ADHDevConfig } | { error: string } {\n if (id === null) {\n return { config: { ...config, defaultWorkspaceId: null } };\n }\n const w = (config.workspaces || []).find(x => x.id === id);\n if (!w) return { error: 'Workspace not found' };\n const abs = expandPath(w.path);\n if (validateWorkspacePath(abs).ok !== true) return { error: 'Workspace path is no longer valid' };\n return { config: { ...config, defaultWorkspaceId: id } };\n}\n","/**\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';\nimport { migrateWorkspacesFromRecent } from './workspaces.js';\nimport type { WorkspaceEntry } from './workspaces.js';\nimport type { WorkspaceActivityEntry } from './workspace-activity.js';\nexport type { WorkspaceEntry } from './workspaces.js';\nexport type { WorkspaceActivityEntry } from './workspace-activity.js';\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 /** Saved workspaces for IDE/CLI/ACP launch (daemon-local) */\n workspaces?: WorkspaceEntry[];\n /** Default workspace id (from workspaces[]) — never used implicitly for launch */\n defaultWorkspaceId?: string | null;\n\n /** Recently used workspaces (IDE / CLI / ACP / default) for quick resume */\n recentWorkspaceActivity?: WorkspaceActivityEntry[];\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 workspaces: [],\n defaultWorkspaceId: null,\n recentWorkspaceActivity: [],\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 const merged = { ...DEFAULT_CONFIG, ...parsed } as ADHDevConfig & { activeWorkspaceId?: string | null };\n if (merged.defaultWorkspaceId == null && merged.activeWorkspaceId != null) {\n (merged as ADHDevConfig).defaultWorkspaceId = merged.activeWorkspaceId;\n }\n delete (merged as any).activeWorkspaceId;\n const hadStoredWorkspaces = Array.isArray(parsed.workspaces) && parsed.workspaces.length > 0;\n migrateWorkspacesFromRecent(merged);\n if (!hadStoredWorkspaces && (merged.workspaces?.length || 0) > 0) {\n try {\n saveConfig(merged);\n } catch { /* ignore */ }\n }\n return merged;\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 ChatMessage,\n ExtensionInfo,\n CommandResult as CoreCommandResult,\n ProviderConfig,\n DaemonEvent,\n StatusResponse,\n SystemInfo,\n DetectedIde,\n ProviderInfo,\n AgentEntry,\n} from './types.js';\n\n// ── Shared Types (cross-package) ──\nexport type {\n ManagedIdeEntry,\n ManagedCliEntry,\n ManagedAcpEntry,\n ManagedAgentStream,\n AvailableProviderInfo,\n AcpConfigOption,\n AcpMode,\n StatusReportPayload,\n MachineInfo,\n DetectedIdeInfo,\n WorkspaceEntry,\n WorkspaceActivity,\n ProviderStatus,\n ProviderErrorReason,\n ActiveChatData,\n IdeProviderState,\n CliProviderState,\n AcpProviderState,\n ExtensionProviderState,\n} from './shared-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/config.js';\nexport { getWorkspaceState } from './config/workspaces.js';\nexport { getWorkspaceActivity } from './config/workspace-activity.js';\n\n// ── Detection ──\nexport { detectIDEs } from './detection/ide-detector.js';\nexport type { IDEInfo } from './detection/ide-detector.js';\nexport { detectCLIs } from './detection/cli-detector.js';\nexport { getHostMemorySnapshot } from './system/host-memory.js';\nexport type { HostMemorySnapshot } from './system/host-memory.js';\n\n// ── CDP ──\nexport { DaemonCdpManager } from './cdp/manager.js';\nexport { CdpDomHandlers } from './cdp/devtools.js';\nexport { setupIdeInstance, registerExtensionProviders, connectCdpManager, probeCdpPort } from './cdp/setup.js';\nexport type { CdpSetupContext, SetupIdeInstanceOptions } from './cdp/setup.js';\nexport { DaemonCdpScanner } from './cdp/scanner.js';\nexport type { CdpScannerOptions } from './cdp/scanner.js';\nexport { DaemonCdpInitializer } from './cdp/initializer.js';\nexport type { CdpInitializerConfig } from './cdp/initializer.js';\n\n// ── Commands ──\nexport { DaemonCommandHandler } from './commands/handler.js';\nexport type { CommandResult, CommandContext } from './commands/handler.js';\nexport { DaemonCommandRouter } from './commands/router.js';\nexport type { CommandRouterDeps, CommandRouterResult } from './commands/router.js';\n\n// ── Status ──\nexport { DaemonStatusReporter } from './status/reporter.js';\n\n// ── Logger ──\nexport { LOG, installGlobalInterceptor, setLogLevel, getLogLevel, getRecentLogs } from './logging/logger.js';\nexport type { ScopedLogger, LogLevel, LogEntry } from './logging/logger.js';\nexport { logCommand, getRecentCommands } from './logging/command-log.js';\n\n// ── CLI Management ──\nexport { DaemonCliManager } from './commands/cli-manager.js';\n\n// ── Launch ──\nexport { launchWithCdp, getAvailableIdeIds, killIdeProcess, isIdeRunning } from './launch.js';\n\n// ── IPC ──\nexport { DEFAULT_DAEMON_PORT, DAEMON_WS_PATH } from './ipc-protocol.js';\n\n// ── Chat History ──\nexport { readChatHistory } from './config/chat-history.js';\n\n// ── Agent Stream ──\nexport { DaemonAgentStreamManager } from './agent-stream/index.js';\nexport { AgentStreamPoller } from './agent-stream/index.js';\nexport type { AgentStreamPollerDeps } 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, CdpTargetFilter } from './providers/contracts.js';\nexport { VersionArchive, detectAllVersions } from './providers/version-archive.js';\nexport type { ProviderVersionInfo, VersionHistory } from './providers/version-archive.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// ── Boot / Lifecycle ──\nexport { initDaemonComponents, shutdownDaemonComponents } from './boot/daemon-lifecycle.js';\nexport type { DaemonInitConfig, DaemonComponents } from './boot/daemon-lifecycle.js';\n\n","/**\n * Recent workspace activity — quick \"pick up where you left off\" (daemon-local).\n */\n\nimport * as path from 'path';\nimport type { ADHDevConfig } from './config.js';\nimport { expandPath } from './workspaces.js';\n\nexport interface WorkspaceActivityEntry {\n path: string;\n lastUsedAt: number;\n /** `active` legacy — same meaning as default */\n kind?: 'ide' | 'cli' | 'acp' | 'default' | 'active';\n /** IDE id or CLI/ACP provider type */\n agentType?: string;\n}\n\nconst MAX_ACTIVITY = 30;\n\nexport function normWorkspacePath(p: string): string {\n try {\n return path.resolve(expandPath(p));\n } catch {\n return path.resolve(p);\n }\n}\n\n/**\n * Append or bump a path to the front of recent activity (returns new config object).\n */\nexport function appendWorkspaceActivity(\n config: ADHDevConfig,\n rawPath: string,\n meta?: { kind?: WorkspaceActivityEntry['kind']; agentType?: string },\n): ADHDevConfig {\n const abs = normWorkspacePath(rawPath);\n if (!abs) return config;\n\n const prev = config.recentWorkspaceActivity || [];\n const filtered = prev.filter(e => normWorkspacePath(e.path) !== abs);\n const entry: WorkspaceActivityEntry = {\n path: abs,\n lastUsedAt: Date.now(),\n kind: meta?.kind,\n agentType: meta?.agentType,\n };\n const recentWorkspaceActivity = [entry, ...filtered].slice(0, MAX_ACTIVITY);\n return { ...config, recentWorkspaceActivity };\n}\n\nexport function getWorkspaceActivity(config: ADHDevConfig, limit = 20): WorkspaceActivityEntry[] {\n const list = [...(config.recentWorkspaceActivity || [])];\n list.sort((a, b) => b.lastUsedAt - a.lastUsedAt);\n return list.slice(0, limit);\n}\n\nexport function removeActivityForPath(config: ADHDevConfig, rawPath: string): ADHDevConfig {\n const n = normWorkspacePath(rawPath);\n return {\n ...config,\n recentWorkspaceActivity: (config.recentWorkspaceActivity || []).filter(\n e => normWorkspacePath(e.path) !== n,\n ),\n };\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 const home = homedir();\n for (const p of paths) {\n if (p.includes('*')) {\n // Wildcard expansion: replace `*` with the current user's home folder name\n // e.g. \"C:\\Users\\*\\AppData\\...\" → \"C:\\Users\\vilmi\\AppData\\...\"\n const username = home.split(/[\\\\/]/).pop() || '';\n const resolved = p.replace('*', username);\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 * Uses parallel execution for fast detection across many providers.\n */\n\nimport { exec } 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 category?: string;\n}\n\n/** Run a shell command with timeout, returning stdout or null on failure */\nfunction execAsync(cmd: string, timeoutMs = 5000): Promise<string | null> {\n return new Promise((resolve) => {\n const child = exec(cmd, { encoding: 'utf-8', timeout: timeoutMs }, (err, stdout) => {\n if (err || !stdout?.trim()) {\n resolve(null);\n } else {\n resolve(stdout.trim());\n }\n });\n // Safety: kill on timeout\n child.on('error', () => resolve(null));\n });\n}\n\n/**\n * Detect all CLI/ACP agents (parallel)\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 // Run all `which` checks in parallel\n const results = await Promise.all(\n cliList.map(async (cli): Promise<CLIInfo> => {\n try {\n const pathResult = await execAsync(`${whichCmd} ${cli.command} 2>/dev/null`);\n if (!pathResult) return { ...cli, installed: false };\n\n const firstPath = pathResult.split('\\n')[0];\n\n // Get version (parallel with other checks)\n let version: string | undefined;\n try {\n const versionResult = await execAsync(`${cli.command} --version 2>/dev/null`, 3000);\n if (versionResult) {\n // Extract version number (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 }\n } catch { }\n\n return { ...cli, installed: true, version, path: firstPath };\n } catch {\n return { ...cli, installed: false };\n }\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 * Host memory metrics — macOS-aware \"available\" memory.\n *\n * Node's os.freemem() on darwin reports only the tiny truly-free pool; most RAM\n * sits in inactive/file-backed cache that the OS can reclaim. Dashboard \"used %\"\n * based on (total - freemem) looks ~99% almost always — misleading.\n *\n * On macOS we parse `vm_stat` and approximate available bytes as:\n * (free + inactive + speculative + purgeable [+ file_backed]) × page size\n * (aligned with common Activity Monitor–style interpretations.)\n */\n\nimport * as os from 'os';\nimport { execSync } from 'child_process';\n\nexport interface HostMemorySnapshot {\n totalMem: number;\n /** Raw kernel \"free\" — small on macOS; kept for debugging / API compat */\n freeMem: number;\n /** Use this for UI \"used %\" — on darwin from vm_stat; else equals freeMem */\n availableMem: number;\n}\n\nfunction parseDarwinAvailableBytes(totalMem: number): number | null {\n if (os.platform() !== 'darwin') return null;\n try {\n const out = execSync('vm_stat', {\n encoding: 'utf-8',\n timeout: 4000,\n maxBuffer: 256 * 1024,\n });\n const pageSizeMatch = out.match(/page size of (\\d+)\\s*bytes/i);\n const pageSize = pageSizeMatch ? parseInt(pageSizeMatch[1], 10) : 4096;\n\n const counts: Record<string, number> = {};\n for (const line of out.split('\\n')) {\n const m = line.match(/^\\s*Pages\\s+([^:]+):\\s+([\\d,]+)\\s*\\.?/);\n if (!m) continue;\n const key = m[1].trim().toLowerCase().replace(/\\s+/g, '_');\n const n = parseInt(m[2].replace(/,/g, ''), 10);\n if (!Number.isNaN(n)) counts[key] = n;\n }\n\n const free = counts['free'] ?? 0;\n const inactive = counts['inactive'] ?? 0;\n const speculative = counts['speculative'] ?? 0;\n const purgeable = counts['purgeable'] ?? 0;\n const fileBacked = counts['file_backed'] ?? 0;\n\n const availPages = free + inactive + speculative + purgeable + fileBacked;\n const bytes = availPages * pageSize;\n if (!Number.isFinite(bytes) || bytes < 0) return null;\n return Math.min(bytes, totalMem);\n } catch {\n return null;\n }\n}\n\nexport function getHostMemorySnapshot(): HostMemorySnapshot {\n const totalMem = os.totalmem();\n const freeMem = os.freemem();\n const darwinAvail = parseDarwinAvailableBytes(totalMem);\n const availableMem = darwinAvail != null ? darwinAvail : freeMem;\n return { totalMem, freeMem, availableMem };\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';\nimport { LOG } from '../logging/logger.js';\nimport type { CdpTargetFilter } from '../providers/contracts.js';\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 private _targetFilter: CdpTargetFilter; // Provider-configurable target selection\n\n constructor(port = 9333, logFn?: (msg: string) => void, targetId?: string, targetFilter?: CdpTargetFilter) {\n this.port = port;\n this._targetId = targetId || null;\n this._targetFilter = targetFilter || {};\n this.logFn = logFn || ((msg) => {\n LOG.info('CDP', msg);\n });\n }\n\n /** Set target filter (can be updated after construction) */\n setTargetFilter(filter: CdpTargetFilter): void {\n this._targetFilter = filter;\n }\n\n /**\n * Check if a page title should be excluded (non-main page).\n * Uses provider-configured titleExcludes, falls back to default pattern.\n */\n private isNonMainTitle(title: string): boolean {\n if (!title) return true;\n const pattern = this._targetFilter.titleExcludes\n || 'extension-output|ADHDev CDP|Debug Console|Output\\\\s*$|Launchpad';\n return new RegExp(pattern, 'i').test(title);\n }\n\n /**\n * Check if a page URL matches the main window criteria.\n * Uses provider-configured urlIncludes/urlExcludes.\n */\n private isMainPageUrl(url: string | undefined): boolean {\n if (!url) return true; // no URL filter = accept all\n const { urlIncludes, urlExcludes } = this._targetFilter;\n if (urlIncludes && !url.includes(urlIncludes)) return false;\n if (urlExcludes) {\n for (const exc of urlExcludes) {\n if (url.includes(exc)) return false;\n }\n }\n return true;\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 // Filter using default target filter (static — no provider filter available)\n const defaultExclude = /extension-output|ADHDev CDP|Debug Console|Output\\s*$|Launchpad/i;\n const isNonMain = (title: string) => !title || defaultExclude.test(title);\n const mainPages = pages.filter(t =>\n !isNonMain(t.title || '') &&\n t.url?.includes('workbench.html') &&\n !t.url?.includes('agent')\n );\n const fallbackPages = pages.filter(t => !isNonMain(t.title || ''));\n resolve(mainPages.length > 0 ? mainPages : fallbackPages);\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 mainPages = pages.filter(t => !this.isNonMainTitle(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: 'webp',\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 * 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 * Scoped logger instance for a specific component.\n * Created via LOG.forComponent('CDP:cursor').\n */\nexport interface ScopedLogger {\n debug: (msg: string) => void;\n info: (msg: string) => void;\n warn: (msg: string) => void;\n error: (msg: string) => void;\n /** Returns a plain (msg: string) => void function at the given level.\n * Useful as logFn callback for ProviderLoader, DaemonStatusReporter, etc. */\n asLogFn: (level?: LogLevel) => (msg: string) => void;\n}\n\n/**\n * LOG — unified logging API\n *\n * Usage:\n * LOG.info('CDP', 'Connected to cursor on port 9333');\n * LOG.debug('StatusReport', 'P2P heartbeat sent');\n *\n * Component-scoped logger:\n * const log = LOG.forComponent('ACP:cursor');\n * log.info('Session created');\n * log.debug('Heartbeat');\n *\n * As callback for external components:\n * new ProviderLoader({ logFn: LOG.forComponent('Provider').asLogFn() });\n * new DaemonStatusReporter({ logFn: LOG.forComponent('Status').asLogFn() });\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 * Create a scoped logger for a specific component.\n * Category is baked in so callers only pass the message.\n */\n forComponent(category: string): ScopedLogger {\n return {\n debug: (msg: string) => daemonLog(category, msg, 'debug'),\n info: (msg: string) => daemonLog(category, msg, 'info'),\n warn: (msg: string) => daemonLog(category, msg, 'warn'),\n error: (msg: string) => daemonLog(category, msg, 'error'),\n asLogFn: (level: LogLevel = 'info') => (msg: string) => daemonLog(category, msg, level),\n };\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 * 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 './manager.js';\nimport type { CommandResult } from '../commands/handler.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 * 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 '../config/chat-history.js';\nimport { LOG } from '../logging/logger.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 workspace: string = '';\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 LOG.warn('IdeInstance', `[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 LOG.warn('IdeInstance', `[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 workspace: this.workspace || null,\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 connection done\n } else if (event === 'cdp_disconnected') {\n this.cachedChat = null;\n this.currentStatus = 'idle';\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 LOG.info('IdeInstance', `[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 /** Set workspace from daemon launch context */\n setWorkspace(workspace: string): void {\n this.workspace = workspace;\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 // Filter messages by provider settings (showThinking, showToolCalls, showTerminal)\n if (raw.messages?.length > 0) {\n const hiddenKinds = new Set<string>();\n if (this.settings.showThinking === false) hiddenKinds.add('thought');\n if (this.settings.showToolCalls === false) hiddenKinds.add('tool');\n if (this.settings.showTerminal === false) hiddenKinds.add('terminal');\n if (hiddenKinds.size > 0) {\n raw.messages = raw.messages.filter((m: any) => !hiddenKinds.has(m.kind));\n }\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 LOG.warn('IdeInstance', `[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 * 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 * 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 * 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 * DaemonCdpSetup — Shared CDP initialization helpers\n *\n * Extracted from daemon-cloud/adhdev-daemon.ts setupCdpManager()\n * and daemon-standalone/index.ts inline CDP setup logic.\n *\n * Used by both daemon-cloud and daemon-standalone to ensure\n * consistent CDP → ProviderInstance registration.\n */\n\nimport { DaemonCdpManager } from './manager.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport { IdeProviderInstance } from '../providers/ide-provider-instance.js';\nimport type { ProviderModule } from '../providers/contracts.js';\n\nexport interface CdpSetupContext {\n providerLoader: ProviderLoader;\n instanceManager: ProviderInstanceManager;\n cdpManagers: Map<string, DaemonCdpManager>;\n /** UUID instanceId → CDP manager key mapping */\n instanceIdMap: Map<string, string>;\n /** Server connection (optional, cloud-only) */\n serverConn?: any;\n}\n\nexport interface SetupIdeInstanceOptions {\n /** Provider-based IDE type (e.g., 'antigravity', 'cursor') */\n ideType: string;\n /** Connected CDP manager */\n manager: DaemonCdpManager;\n /** CDP manager key (for multi-window: 'antigravity_remote_vs', single: 'antigravity') */\n managerKey?: string;\n /** Provider settings override */\n settings?: Record<string, any>;\n}\n\n/**\n * Register extension providers on a CDP manager.\n * Common pattern used during CDP init and periodic scans.\n */\nexport function registerExtensionProviders(\n providerLoader: ProviderLoader,\n manager: DaemonCdpManager,\n ideType: string,\n): void {\n const enabledExtProviders = providerLoader.getEnabledExtensionProviders(ideType)\n .map((p: any) => ({\n agentType: p.type,\n extensionId: p.extensionId || '',\n extensionIdPattern: p.extensionIdPattern!,\n }));\n manager.setExtensionProviders(enabledExtProviders);\n}\n\n/**\n * Setup a CDP-connected IDE as a ProviderInstance.\n *\n * Performs:\n * 1. providerLoader.resolve() to get scripts\n * 2. Create IdeProviderInstance\n * 3. Register in InstanceManager\n * 4. Register enabled extensions\n * 5. Update instanceIdMap (IDE + extension UUIDs)\n *\n * @returns The created IdeProviderInstance, or null if provider not found\n */\nexport async function setupIdeInstance(\n ctx: CdpSetupContext,\n opts: SetupIdeInstanceOptions,\n): Promise<IdeProviderInstance | null> {\n const { providerLoader, instanceManager, instanceIdMap } = ctx;\n const { ideType, manager, settings } = opts;\n const managerKey = opts.managerKey || ideType;\n\n // 1. Register extension providers on CDP manager\n registerExtensionProviders(providerLoader, manager, ideType);\n\n // 2. Resolve provider with scripts\n const ideProvider = providerLoader.resolve(ideType);\n if (!ideProvider) return null;\n\n // 3. Create IdeProviderInstance\n const ideInstance = new IdeProviderInstance(\n ideProvider,\n managerKey !== ideType ? managerKey : undefined,\n );\n\n // 4. Register in InstanceManager\n const resolvedSettings = settings || providerLoader.getSettings(ideType);\n await instanceManager.addInstance(`ide:${managerKey}`, ideInstance, {\n cdp: manager,\n serverConn: ctx.serverConn,\n settings: resolvedSettings,\n });\n\n // 5. Map IDE instance UUID → manager key\n instanceIdMap.set(ideInstance.getInstanceId(), managerKey);\n\n // 6. Register enabled extensions\n const extensionProviders = providerLoader.getEnabledByCategory('extension', ideType);\n for (const extProvider of extensionProviders) {\n const extSettings = providerLoader.getSettings(extProvider.type);\n await ideInstance.addExtension(extProvider, extSettings);\n // Map extension UUIDs too (CDP uses parent IDE)\n for (const ext of ideInstance.getExtensionInstances()) {\n instanceIdMap.set(ext.getInstanceId(), managerKey);\n }\n }\n\n return ideInstance;\n}\n\n/**\n * Create and connect a DaemonCdpManager for a given port.\n *\n * @returns Connected manager or null if connection failed\n */\nexport async function connectCdpManager(\n port: number,\n ideType: string,\n logFn: (msg: string) => void,\n providerLoader: ProviderLoader,\n targetId?: string,\n): Promise<DaemonCdpManager | null> {\n const provider = providerLoader.getMeta(ideType);\n const manager = new DaemonCdpManager(\n port,\n logFn,\n targetId,\n (provider as any)?.targetFilter,\n );\n const connected = await manager.connect();\n return connected ? manager : null;\n}\n\n/**\n * Probe a CDP port to check if it's listening.\n * @returns true if CDP is available on this port\n */\nexport async function probeCdpPort(port: number, timeoutMs = 1000): Promise<boolean> {\n try {\n const probe = await fetch(`http://localhost:${port}/json/version`, {\n signal: AbortSignal.timeout(timeoutMs),\n }).then(r => r.json()).catch(() => null);\n return !!probe;\n } catch {\n return false;\n }\n}\n","/**\n * DaemonCdpScanner — Periodic CDP port scanning & auto-connect\n *\n * Extracted from daemon-cloud initCdp() and daemon-standalone initCdp().\n * Provides a unified approach to:\n * 1. Initial CDP port discovery\n * 2. Periodic scanning for newly launched IDEs\n * 3. Multi-window support (multiple pages on same port)\n */\n\nimport { DaemonCdpManager } from './manager.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport { connectCdpManager, probeCdpPort, registerExtensionProviders, setupIdeInstance, type CdpSetupContext } from './setup.js';\nimport { LOG } from '../logging/logger.js';\n\nexport interface CdpScannerOptions {\n /** Context for setup operations */\n ctx: CdpSetupContext;\n /** Log function for per-IDE CDP logs */\n logFn?: (ideType: string) => (msg: string) => void;\n /** Whether to support multi-window (multiple pages per port) */\n multiWindow?: boolean;\n /** Scan interval in ms (default: 30000) */\n scanIntervalMs?: number;\n /** Callback when a new CDP connection is established */\n onConnected?: (ideType: string, managerKey: string, manager: DaemonCdpManager) => void;\n}\n\nexport class DaemonCdpScanner {\n private ctx: CdpSetupContext;\n private opts: CdpScannerOptions;\n private scanTimer: NodeJS.Timeout | null = null;\n private discoveryTimer: NodeJS.Timeout | null = null;\n\n constructor(opts: CdpScannerOptions) {\n this.ctx = opts.ctx;\n this.opts = opts;\n }\n\n /**\n * Initial CDP discovery — connect to all available IDEs.\n * Supports both single-window and multi-window modes.\n */\n async initialScan(enabledIdes?: string[]): Promise<void> {\n const portMap = this.ctx.providerLoader.getCdpPortMap();\n const portsToTry: { port: number; ide: string }[] = [];\n\n for (const [ide, ports] of Object.entries(portMap)) {\n portsToTry.push({ port: ports[0], ide });\n }\n\n // Apply enabledIdes filter if provided\n const filtered = enabledIdes?.length\n ? portsToTry.filter(p => enabledIdes.includes(p.ide))\n : portsToTry;\n\n for (const { port, ide } of filtered) {\n if (this.opts.multiWindow) {\n await this.connectMultiWindow(port, ide);\n } else {\n await this.connectSingleWindow(port, ide);\n }\n }\n }\n\n /**\n * Start periodic scanning for newly launched IDEs.\n */\n startPeriodicScan(): void {\n if (this.scanTimer) return;\n const interval = this.opts.scanIntervalMs || 30_000;\n\n this.scanTimer = setInterval(async () => {\n const portMap = this.ctx.providerLoader.getCdpPortMap();\n for (const [ide, ports] of Object.entries(portMap)) {\n const primaryPort = ports[0];\n // Skip if already connected\n const alreadyConnected = [...this.ctx.cdpManagers.entries()].some(([key, m]) =>\n m.isConnected && (key === ide || key.startsWith(ide + '_'))\n );\n if (alreadyConnected) continue;\n\n if (this.opts.multiWindow) {\n await this.connectMultiWindow(primaryPort, ide);\n } else {\n await this.connectSingleWindow(primaryPort, ide);\n }\n }\n }, interval);\n }\n\n /**\n * Start periodic agent webview discovery on all connected CDPs.\n */\n startWebviewDiscovery(intervalMs = 30_000): void {\n if (this.discoveryTimer) return;\n this.discoveryTimer = setInterval(async () => {\n for (const m of this.ctx.cdpManagers.values()) {\n if (m.isConnected) {\n await m.discoverAgentWebviews();\n }\n }\n }, intervalMs);\n }\n\n /**\n * Stop all timers.\n */\n stop(): void {\n if (this.scanTimer) { clearInterval(this.scanTimer); this.scanTimer = null; }\n if (this.discoveryTimer) { clearInterval(this.discoveryTimer); this.discoveryTimer = null; }\n }\n\n // ── Internal ────────────────────────────\n\n private getLogFn(ideType: string): (msg: string) => void {\n if (this.opts.logFn) return this.opts.logFn(ideType);\n return (msg: string) => LOG.info(`CDP:${ideType}`, msg);\n }\n\n /**\n * Single-window connection (standalone mode).\n * One CDP manager per IDE, first working port wins.\n */\n private async connectSingleWindow(port: number, ide: string): Promise<void> {\n if (this.ctx.cdpManagers.has(ide)) return;\n const available = await probeCdpPort(port);\n if (!available) return;\n\n const manager = await connectCdpManager(\n port, ide, this.getLogFn(ide), this.ctx.providerLoader,\n );\n if (!manager) return;\n\n registerExtensionProviders(this.ctx.providerLoader, manager, ide);\n this.ctx.cdpManagers.set(ide, manager);\n LOG.info('CDP', `Connected: ${ide} (port ${port})`);\n\n // Setup IDE instance\n await setupIdeInstance(this.ctx, { ideType: ide, manager });\n this.opts.onConnected?.(ide, ide, manager);\n }\n\n /**\n * Multi-window connection (cloud mode).\n * Multiple CDP managers per IDE — one per workbench page.\n */\n private async connectMultiWindow(port: number, ide: string): Promise<void> {\n const allTargets = await DaemonCdpManager.listAllTargets(port);\n\n if (allTargets.length === 0) {\n // Fallback: single-window approach\n await this.connectSingleWindow(port, ide);\n return;\n }\n\n for (let i = 0; i < allTargets.length; i++) {\n const target = allTargets[i];\n let managerKey: string;\n if (allTargets.length === 1) {\n managerKey = ide;\n } else {\n const workspaceName = (target.title || '').split(' — ')[0].trim() || `window_${i}`;\n managerKey = `${ide}_${workspaceName}`;\n }\n\n if (this.ctx.cdpManagers.has(managerKey)) continue;\n\n const manager = await connectCdpManager(\n port, ide, this.getLogFn(managerKey), this.ctx.providerLoader, target.id,\n );\n if (!manager) continue;\n\n this.ctx.cdpManagers.set(managerKey, manager);\n LOG.info('CDP', `Connected: ${managerKey} (port ${port}, page \"${target.title}\")`);\n\n await setupIdeInstance(this.ctx, {\n ideType: ide,\n manager,\n managerKey,\n });\n this.opts.onConnected?.(ide, managerKey, manager);\n }\n }\n}\n","/**\n * DaemonCdpInitializer — Unified CDP initialization + periodic scanning\n *\n * Replaces initCdp() in both cloud and standalone daemons.\n *\n * Features:\n * 1. Initial connection: connectAll() — multi-window aware\n * 2. Periodic scan: startPeriodicScan() — auto-detect newly opened IDEs\n * 3. Discovery: startDiscovery() — periodic agent webview discovery\n */\n\nimport { DaemonCdpManager } from './manager.js';\nimport { registerExtensionProviders } from './setup.js';\nimport { probeCdpPort } from './setup.js';\nimport type { ProviderLoader } from '../providers/provider-loader.js';\nimport { LOG } from '../logging/logger.js';\n\n// ─── Config ───\n\nexport interface CdpInitializerConfig {\n providerLoader: ProviderLoader;\n cdpManagers: Map<string, DaemonCdpManager>;\n /** Filter: only connect these IDEs (empty/undefined = all) */\n enabledIdes?: string[];\n /** Callback when a new CDP manager is connected */\n onConnected?: (ideType: string, manager: DaemonCdpManager, managerKey: string) => void | Promise<void>;\n}\n\nexport class DaemonCdpInitializer {\n private config: CdpInitializerConfig;\n private scanTimer: NodeJS.Timeout | null = null;\n private discoveryTimer: NodeJS.Timeout | null = null;\n\n constructor(config: CdpInitializerConfig) {\n this.config = config;\n }\n\n // ─── Initial connection ───\n\n /**\n * Connect to all detected IDEs.\n * Multi-window aware: creates separate CdpManager per workbench page.\n */\n async connectAll(detectedIdes: any[]): Promise<void> {\n const { providerLoader, cdpManagers, enabledIdes } = this.config;\n const providerCdpMap = providerLoader.getCdpPortMap();\n\n // Build port list sorted by detected IDE order\n const portsToTry: { port: number; ide: string }[] = [];\n for (const ide of detectedIdes) {\n if (!ide.installed) continue;\n const ideKey = ide.id || ide.name?.toLowerCase();\n const ports = providerCdpMap[ideKey];\n if (ports) portsToTry.push({ port: ports[0], ide: ideKey });\n }\n // Add undetected IDE ports (provider-based)\n for (const [ide, ports] of Object.entries(providerCdpMap)) {\n if (!portsToTry.find(p => p.port === ports[0])) {\n portsToTry.push({ port: ports[0], ide });\n }\n }\n\n // Filter by enabledIdes\n const filtered = enabledIdes?.length\n ? portsToTry.filter(p => enabledIdes.includes(p.ide))\n : portsToTry;\n\n for (const { port, ide } of filtered) {\n await this.connectIdePort(port, ide);\n }\n\n // Summary\n if (cdpManagers.size > 0) {\n LOG.info('CDP', `${cdpManagers.size} IDE(s) connected: ${[...cdpManagers.entries()].map(([k, m]) => `${k}:${m.getPort()}`).join(', ')}`);\n } else {\n LOG.warn('CDP', `No IDEs connected — tried: ${filtered.map(p => `${p.ide}:${p.port}`).join(', ')}`);\n }\n }\n\n // ─── Per-port connection (multi-window aware) ───\n\n /**\n * Connect to a single IDE port.\n * Tries multi-window first (listAllTargets), falls back to direct connect.\n */\n private async connectIdePort(port: number, ide: string): Promise<void> {\n const { providerLoader, cdpManagers } = this.config;\n\n // 1. Try multi-window: list all workbench pages on this port\n const targets = await DaemonCdpManager.listAllTargets(port);\n\n if (targets.length === 0) {\n // Fallback: direct single connection (probeCdpPort first)\n if (!await probeCdpPort(port)) return;\n const provider = providerLoader.getMeta(ide);\n const manager = new DaemonCdpManager(\n port,\n LOG.forComponent(`CDP:${ide}`).asLogFn(),\n undefined,\n (provider as any)?.targetFilter,\n );\n const connected = await manager.connect();\n if (connected) {\n registerExtensionProviders(providerLoader, manager, ide);\n cdpManagers.set(ide, manager);\n LOG.info('CDP', `Connected: ${ide} (port ${port})`);\n await this.config.onConnected?.(ide, manager, ide);\n }\n return;\n }\n\n // 2. Multi-window: create separate CdpManager per page\n for (let i = 0; i < targets.length; i++) {\n const target = targets[i];\n // Key: single page = ide type as-is, multi-page = ide_workspaceName\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\n if (cdpManagers.has(managerKey)) continue;\n\n const provider = providerLoader.getMeta(ide);\n const manager = new DaemonCdpManager(\n port,\n LOG.forComponent(`CDP:${managerKey}`).asLogFn(),\n target.id,\n (provider as any)?.targetFilter,\n );\n\n const connected = await manager.connect();\n if (connected) {\n registerExtensionProviders(providerLoader, manager, ide);\n cdpManagers.set(managerKey, manager);\n LOG.info('CDP', `Connected: ${managerKey} (port ${port}${targets.length > 1 ? `, page \"${target.title}\"` : ''})`);\n await this.config.onConnected?.(ide, manager, managerKey);\n }\n }\n }\n\n // ─── Periodic scanning ───\n\n /**\n * Start periodic scanning for newly opened IDEs.\n * Idempotent — ignored if already started.\n */\n startPeriodicScan(intervalMs = 30_000): void {\n if (this.scanTimer) return;\n\n this.scanTimer = setInterval(async () => {\n const { providerLoader, cdpManagers } = this.config;\n const portMap = providerLoader.getCdpPortMap();\n\n for (const [ide, ports] of Object.entries(portMap)) {\n const primaryPort = ports[0];\n\n // Skip if already connected\n const alreadyConnected = [...cdpManagers.entries()].some(([key, m]) =>\n m.isConnected && (key === ide || key.startsWith(ide + '_'))\n );\n if (alreadyConnected) continue;\n\n await this.connectIdePort(primaryPort, ide);\n }\n }, intervalMs);\n }\n\n /**\n * Start periodic agent webview discovery.\n */\n startDiscovery(intervalMs = 30_000): void {\n if (this.discoveryTimer) return;\n\n this.discoveryTimer = setInterval(async () => {\n for (const m of this.config.cdpManagers.values()) {\n if (m.isConnected) {\n await m.discoverAgentWebviews();\n }\n }\n }, intervalMs);\n }\n\n /** Stop all timers */\n stop(): void {\n if (this.scanTimer) { clearInterval(this.scanTimer); this.scanTimer = null; }\n if (this.discoveryTimer) { clearInterval(this.discoveryTimer); this.discoveryTimer = null; }\n }\n}\n","/**\n * Daemon Commands — unified command handler\n * \n * Routes all functionality from legacy Extension commands.ts to Daemon.\n * \n * Command implementations are split into sub-modules:\n * - chat-commands.ts — Chat I/O, session management, mode/model control\n * - cdp-commands.ts — CDP eval, screenshot, batch, remote actions, file ops\n * - stream-commands.ts — Agent stream, PTY I/O, provider settings, extension scripts\n */\n\nimport { DaemonCdpManager } from '../cdp/manager.js';\nimport { CdpDomHandlers } from '../cdp/devtools.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport type { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport type { ProviderModule } from '../providers/contracts.js';\nimport type { DaemonAgentStreamManager } from '../agent-stream/index.js';\nimport { loadConfig } from '../config/config.js';\nimport { ChatHistoryWriter } from '../config/chat-history.js';\nimport { LOG } from '../logging/logger.js';\n\n// Sub-module imports\nimport * as Chat from './chat-commands.js';\nimport * as Cdp from './cdp-commands.js';\nimport * as Stream from './stream-commands.js';\nimport * as WorkspaceCmd from './workspace-commands.js';\nimport { getWorkspaceState } from '../config/workspaces.js';\nimport { getWorkspaceActivity } from '../config/workspace-activity.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 /** ProviderInstanceManager — for runtime settings propagation */\n instanceManager?: ProviderInstanceManager;\n /** UUID instanceId → CDP manager key (ideType) mapping */\n instanceIdMap?: Map<string, string>;\n}\n\n/**\n * Shared helpers interface — passed to sub-module command functions\n * for accessing CDP, providers, agent streams, and other handler-owned state.\n */\nexport interface CommandHelpers {\n getCdp(ideType?: string): DaemonCdpManager | null;\n getProvider(overrideType?: string): ProviderModule | undefined;\n getProviderScript(scriptName: string, params?: Record<string, string>, ideType?: string): string | null;\n evaluateProviderScript(scriptName: string, params?: Record<string, string>, timeout?: number): Promise<{ result: any; category: string } | null>;\n getCliAdapter(type?: string): any | null;\n readonly currentIdeType: string | undefined;\n readonly currentProviderType: string | undefined;\n readonly agentStream: DaemonAgentStreamManager | null;\n readonly ctx: CommandContext;\n readonly historyWriter: ChatHistoryWriter;\n}\n\nexport class DaemonCommandHandler implements CommandHelpers {\n private _ctx: CommandContext;\n private _agentStream: DaemonAgentStreamManager | null = null;\n private domHandlers: CdpDomHandlers;\n private _historyWriter: ChatHistoryWriter;\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 constructor(ctx: CommandContext) {\n this._ctx = ctx;\n this.domHandlers = new CdpDomHandlers((ideType?) => this.getCdp(ideType));\n this._historyWriter = new ChatHistoryWriter();\n }\n\n // ─── CommandHelpers implementation ─────────────────\n\n get ctx(): CommandContext { return this._ctx; }\n get agentStream(): DaemonAgentStreamManager | null { return this._agentStream; }\n get historyWriter(): ChatHistoryWriter { return this._historyWriter; }\n get currentIdeType(): string | undefined { return this._currentIdeType; }\n get currentProviderType(): string | undefined { return this._currentProviderType; }\n\n /** Get CDP manager for a specific ideType.\n * Returns null if no match — never falls back to another IDE. */\n getCdp(ideType?: string): DaemonCdpManager | null {\n const key = ideType || this._currentIdeType;\n if (!key) return null;\n const m = this._ctx.cdpManagers.get(key.toLowerCase());\n if (m?.isConnected) return m;\n return null;\n }\n\n /**\n * Get provider module — _currentProviderType (agentType priority) use.\n */\n getProvider(overrideType?: string): ProviderModule | undefined {\n const key = overrideType || this._currentProviderType || this._currentIdeType;\n if (!key || !this._ctx.providerLoader) return undefined;\n const result = this._ctx.providerLoader.resolve(key);\n if (result) return result;\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 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 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 /**\n * per-category CDP script execute:\n * IDE → cdp.evaluate(script) (main window)\n * Extension → cdp.evaluateInSession(sessionId, script) (webview)\n */\n 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 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 /** CLI adapter search */\n 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 // ─── Private helpers ──────────────────────────────\n\n private getExtensionSessionId(provider: ProviderModule): string | null {\n if (provider.category !== 'extension' || !this._agentStream) return null;\n const managed = this._agentStream.getManagedAgent(provider.type);\n return managed?.sessionId || null;\n }\n\n /** Extract ideType from _targetInstance */\n private extractIdeType(args: any): string | undefined {\n // Also accept explicit ideType from args (agentType for extensions)\n if (args?.ideType && this._ctx.cdpManagers.has(args.ideType)) {\n return args.ideType;\n }\n\n if (args?._targetInstance) {\n let raw = args._targetInstance as string;\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 if (this._ctx.instanceIdMap?.has(raw)) {\n return this._ctx.instanceIdMap.get(raw)!;\n }\n\n // Direct CDP manager key match (e.g. \"cursor\", \"antigravity\")\n if (this._ctx.cdpManagers.has(raw)) {\n return raw;\n }\n\n // Fallback: if no structured format matched and raw looks like a machine ID\n // (e.g. \"standalone_hostname\"), find first available connected CDP\n if (!ideMatch && !cliMatch && !acpMatch) {\n for (const [key, mgr] of this._ctx.cdpManagers.entries()) {\n if (mgr.isConnected) return key;\n }\n }\n\n // Legacy: strip trailing _N suffix (e.g. \"cursor_1\" → \"cursor\")\n const lastUnderscore = raw.lastIndexOf('_');\n if (lastUnderscore > 0) {\n const stripped = raw.substring(0, lastUnderscore);\n if (this._ctx.cdpManagers.has(stripped)) return stripped;\n }\n return raw;\n }\n return undefined;\n }\n\n setAgentStreamManager(manager: DaemonAgentStreamManager): void {\n this._agentStream = manager;\n }\n\n // ─── Command Dispatcher ──────────────────────────\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 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\n try {\n return await this.dispatch(cmd, args);\n } catch (e: any) {\n LOG.error('Command', `[${cmd}] Unhandled error: ${e?.message || e}`);\n return { success: false, error: `Internal error: ${e?.message || 'unknown'}` };\n }\n }\n\n private async dispatch(cmd: string, args: any): Promise<CommandResult> {\n switch (cmd) {\n // ─── Chat commands (chat-commands.ts) ───────────────\n case 'read_chat': return Chat.handleReadChat(this, args);\n case 'chat_history': return Chat.handleChatHistory(this, args);\n case 'send_chat': return Chat.handleSendChat(this, args);\n case 'list_chats': return Chat.handleListChats(this, args);\n case 'new_chat': return Chat.handleNewChat(this, args);\n case 'switch_chat': return Chat.handleSwitchChat(this, args);\n case 'set_mode': return Chat.handleSetMode(this, args);\n case 'change_model': return Chat.handleChangeModel(this, args);\n case 'set_thought_level': return Chat.handleSetThoughtLevel(this, args);\n case 'resolve_action': return Chat.handleResolveAction(this, args);\n\n // ─── CDP commands (cdp-commands.ts) ───────────────\n case 'cdp_eval': return Cdp.handleCdpEval(this, args);\n case 'cdp_screenshot':\n case 'screenshot': return Cdp.handleScreenshot(this, args);\n case 'cdp_command_exec': return Cdp.handleCdpCommand(this, args);\n case 'cdp_batch': return Cdp.handleCdpBatch(this, args);\n case 'cdp_remote_action': return Cdp.handleCdpRemoteAction(this, args);\n case 'cdp_discover_agents': return Cdp.handleDiscoverAgents(this, 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 commands (cdp-commands.ts) ──────────────\n case 'file_read': return Cdp.handleFileRead(this, args);\n case 'file_write': return Cdp.handleFileWrite(this, args);\n case 'file_list': return Cdp.handleFileList(this, args);\n case 'file_list_browse': return Cdp.handleFileListBrowse(this, args);\n\n // ─── VSCode API commands (not available) ────\n case 'vscode_command_exec':\n case 'execute_vscode_command': {\n const resolvedCmd = args?.commandId || args?.command;\n if (resolvedCmd === 'adhdev.captureCdpScreenshot') {\n return Cdp.handleScreenshot(this, args);\n }\n return { success: false, error: `VSCode command not available: ${resolvedCmd || cmd}` };\n }\n case 'get_open_editors':\n case 'open_tab':\n case 'close_tab':\n case 'open_folder':\n case 'open_folder_picker':\n case 'open_recent':\n case 'get_commands':\n return { success: false, error: `${cmd} requires bridge-extension (removed)` };\n case 'get_recent_workspaces': return this.handleGetRecentWorkspaces(args);\n case 'get_cli_history': {\n const config = loadConfig();\n return { success: true, history: config.cliHistory || [] };\n }\n\n case 'workspace_list': return WorkspaceCmd.handleWorkspaceList();\n case 'workspace_add': return WorkspaceCmd.handleWorkspaceAdd(args);\n case 'workspace_remove': return WorkspaceCmd.handleWorkspaceRemove(args);\n case 'workspace_set_default':\n case 'workspace_set_active':\n return WorkspaceCmd.handleWorkspaceSetDefault(args);\n\n // ─── Script manage ───────────────────\n case 'refresh_scripts': return this.handleRefreshScripts(args);\n\n // ─── Stream commands (stream-commands.ts) ───────────\n case 'agent_stream_switch': return Stream.handleAgentStreamSwitch(this, args);\n case 'agent_stream_read': return Stream.handleAgentStreamRead(this, args);\n case 'agent_stream_send': return Stream.handleAgentStreamSend(this, args);\n case 'agent_stream_resolve': return Stream.handleAgentStreamResolve(this, args);\n case 'agent_stream_new': return Stream.handleAgentStreamNew(this, args);\n case 'agent_stream_list_chats': return Stream.handleAgentStreamListChats(this, args);\n case 'agent_stream_switch_session': return Stream.handleAgentStreamSwitchSession(this, args);\n case 'agent_stream_focus': return Stream.handleAgentStreamFocus(this, args);\n\n // ─── PTY Raw I/O (stream-commands.ts) ─────────\n case 'pty_input': return Stream.handlePtyInput(this, args);\n case 'pty_resize': return Stream.handlePtyResize(this, args);\n\n // ─── Provider Settings (stream-commands.ts) ──────────\n case 'get_provider_settings': return Stream.handleGetProviderSettings(this, args);\n case 'set_provider_setting': return Stream.handleSetProviderSetting(this, args);\n\n // ─── IDE Extension Settings (stream-commands.ts) ──────────\n case 'get_ide_extensions': return Stream.handleGetIdeExtensions(this, args);\n case 'set_ide_extension': return Stream.handleSetIdeExtension(this, args);\n\n // ─── Extension Model / Mode Control (stream-commands.ts) ──────────\n case 'list_extension_models': return Stream.handleExtensionScript(this, args, 'listModels');\n case 'set_extension_model': return Stream.handleExtensionScript(this, args, 'setModel');\n case 'list_extension_modes': return Stream.handleExtensionScript(this, args, 'listModes');\n case 'set_extension_mode': return Stream.handleExtensionScript(this, args, 'setMode');\n\n default:\n return { success: false, error: `Unknown command: ${cmd}` };\n }\n }\n\n // ─── Misc (kept in handler — too small to extract) ───────\n\n private async handleGetRecentWorkspaces(_args: any): Promise<CommandResult> {\n const config = loadConfig();\n const cliRecent = config.recentCliWorkspaces || [];\n const ws = getWorkspaceState(config);\n return {\n success: true,\n result: cliRecent,\n workspaces: ws.workspaces,\n defaultWorkspaceId: ws.defaultWorkspaceId,\n defaultWorkspacePath: ws.defaultWorkspacePath,\n activity: getWorkspaceActivity(config, 25),\n };\n }\n\n private async handleRefreshScripts(_args: any): Promise<CommandResult> {\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","/**\n * Chat Commands — readChat, sendChat, listChats, newChat, switchChat,\n * setMode, changeModel, setThoughtLevel, resolveAction, chatHistory\n */\n\nimport type { CommandResult, CommandHelpers } from './handler.js';\nimport { readChatHistory } from '../config/chat-history.js';\nimport { LOG } from '../logging/logger.js';\n\nexport async function handleChatHistory(h: CommandHelpers, args: any): Promise<CommandResult> {\n const { agentType, offset, limit, instanceId } = args;\n try {\n const provider = h.getProvider(agentType);\n const agentStr = provider?.type || agentType || h.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\nexport async function handleReadChat(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const _log = (msg: string) => LOG.debug('Command', `[read_chat] ${msg}`);\n\n // CLI / ACP category: read from adapter\n if (provider?.category === 'cli' || provider?.category === 'acp') {\n const adapter = h.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 h.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 h.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 (h.agentStream) {\n const cdp = h.getCdp();\n if (cdp) {\n const streams = await h.agentStream.collectAgentStreams(cdp);\n const stream = streams.find((s: any) => s.agentType === provider.type);\n if (stream) {\n h.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 = h.getCdp();\n if (!cdp?.isConnected) return { success: false, error: 'CDP not connected' };\n\n // webview IDE (Kiro, PearAI) → evaluateInWebviewFrame directly use\n const webviewScript = h.getProviderScript('webviewReadChat') || h.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 h.historyWriter.appendNewMessages(\n provider?.type || h.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 = h.getProviderScript('readChat') || h.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 h.historyWriter.appendNewMessages(\n provider?.type || h.currentIdeType || 'unknown_ide',\n parsed.messages || [],\n parsed.title,\n args?.instanceId\n );\n return { success: true, ...parsed };\n }\n } catch (e: any) {\n LOG.info('Command', `[read_chat] Script error: ${e.message}`);\n }\n }\n\n return { success: true, messages: [], status: 'idle' };\n}\n\nexport async function handleSendChat(h: CommandHelpers, 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) => LOG.debug('Command', `[send_chat] ${msg}`);\n const provider = h.getProvider();\n\n // CLI / ACP category: transmit via adapter\n if (provider?.category === 'cli' || provider?.category === 'acp') {\n const adapter = h.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 h.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 _log(`Extension needsTypeAndSend → AgentStreamManager`);\n }\n }\n } catch (e: any) {\n _log(`Extension script error: ${e.message}`);\n }\n // Method 2: AgentStreamManager\n if (h.agentStream && h.getCdp()) {\n const ok = await h.agentStream.sendToAgent(h.getCdp()!, provider.type, text, h.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 = h.getCdp();\n if (!targetCdp?.isConnected) {\n _log(`No CDP for ${h.currentIdeType}`);\n return { success: false, error: `CDP for ${h.currentIdeType || 'unknown'} not connected` };\n }\n\n _log(`Targeting IDE: ${h.currentIdeType}`);\n\n // Method 0: webview-based IDE (try webviewSendMessage first)\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 = h.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\nexport async function handleListChats(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n\n // Extension: via AgentStreamManager\n if (provider?.category === 'extension' && h.agentStream && h.getCdp()) {\n try {\n const chats = await h.agentStream.listAgentChats(h.getCdp()!, provider.type);\n LOG.info('Command', `[list_chats] Extension: ${chats.length} chats`);\n return { success: true, chats };\n } catch (e: any) {\n LOG.info('Command', `[list_chats] Extension error: ${e.message}`);\n }\n }\n\n // webview IDE\n try {\n const webviewScript = h.getProviderScript('webviewListSessions') || h.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 h.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 LOG.info('Command', `[list_chats] Webview OK: ${parsed.sessions.length} chats`);\n return { success: true, chats: parsed.sessions };\n }\n }\n } catch (e: any) {\n LOG.info('Command', `[list_chats] Webview error: ${e.message}`);\n }\n\n // IDE/default: evaluateProviderScript\n try {\n const evalResult = await h.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 LOG.info('Command', `[list_chats] OK: ${parsed.length} chats`);\n return { success: true, chats: parsed };\n }\n }\n } catch (e: any) {\n LOG.info('Command', `[list_chats] error: ${e.message}`);\n }\n\n return { success: false, error: 'listSessions script not available for this provider' };\n}\n\nexport async function handleNewChat(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n\n if (provider?.category === 'extension' && h.agentStream && h.getCdp()) {\n const ok = await h.agentStream.newAgentSession(h.getCdp()!, provider.type, h.currentIdeType);\n return { success: ok };\n }\n\n // webview IDE\n try {\n const webviewScript = h.getProviderScript('webviewNewSession') || h.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 h.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 try {\n const evalResult = await h.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\nexport async function handleSwitchChat(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const ideType = h.currentIdeType;\n const sessionId = args?.sessionId || args?.id || args?.chatId;\n if (!sessionId) return { success: false, error: 'sessionId required' };\n LOG.info('Command', `[switch_chat] sessionId=${sessionId}, ideType=${ideType}`);\n\n if (provider?.category === 'extension' && h.agentStream && h.getCdp()) {\n const ok = await h.agentStream.switchAgentSession(h.getCdp()!, provider.type, sessionId);\n return { success: ok, result: ok ? 'switched' : 'failed' };\n }\n\n const cdp = h.getCdp(ideType);\n if (!cdp?.isConnected) return { success: false, error: 'CDP not connected' };\n\n // webview IDE\n try {\n const webviewScript = h.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 = h.getProviderScript('switchSession', { SESSION_ID: JSON.stringify(sessionId) })\n || h.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 LOG.info('Command', `[switch_chat] result: ${raw}`);\n\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 LOG.info('Command', `[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) return { success: false, error: parsed.error };\n return { success: true, result: raw };\n } catch (e: any) {\n LOG.error('Command', `[switch_chat] error: ${e.message}`);\n return { success: false, error: e.message };\n }\n}\n\nexport async function handleSetMode(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const mode = args?.mode || 'agent';\n\n // ACP provider\n if (provider?.category === 'acp') {\n const adapter = h.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 // 1. webview setMode\n const webviewScript = h.getProviderScript('webviewSetMode', { MODE: JSON.stringify(mode) });\n if (webviewScript) {\n const cdp = h.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 LOG.info('Command', `[set_mode] webview script error: ${e.message}`);\n }\n }\n }\n\n // 2. main frame setMode\n const mainScript = h.getProviderScript('setMode', { MODE: JSON.stringify(mode) });\n if (mainScript) {\n try {\n const evalResult = await h.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 LOG.info('Command', `[set_mode] script error: ${e.message}`);\n }\n }\n\n return { success: false, error: `setMode '${mode}' not supported by this provider` };\n}\n\nexport async function handleChangeModel(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const model = args?.model;\n\n LOG.info('Command', `[change_model] model=${model} provider=${provider?.type} category=${provider?.category} ideType=${h.currentIdeType} providerType=${h.currentProviderType}`);\n\n // ACP provider\n if (provider?.category === 'acp') {\n const adapter = h.getCliAdapter(provider.type);\n LOG.info('Command', `[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 LOG.info('Command', `[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 // 1. webview setModel\n const webviewScript = h.getProviderScript('webviewSetModel', { MODEL: JSON.stringify(model) });\n if (webviewScript) {\n const cdp = h.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 LOG.info('Command', `[change_model] webview script error: ${e.message}`);\n }\n }\n }\n\n // 2. main frame setModel\n const mainScript = h.getProviderScript('setModel', { MODEL: JSON.stringify(model) });\n if (mainScript) {\n try {\n const evalResult = await h.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 LOG.info('Command', `[change_model] script error: ${e.message}`);\n }\n }\n\n return { success: false, error: 'changeModel not supported by this IDE provider' };\n}\n\nexport async function handleSetThoughtLevel(h: CommandHelpers, 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 = h.getProvider();\n if (!provider || provider.category !== 'acp') {\n return { success: false, error: 'set_thought_level only for ACP providers' };\n }\n const adapter = h.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 LOG.info('Command', `[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\nexport async function handleResolveAction(h: CommandHelpers, args: any): Promise<CommandResult> {\n const provider = h.getProvider();\n const action = args?.action || 'approve';\n const button = args?.button || args?.buttonText\n || (action === 'approve' ? 'Accept' : action === 'reject' ? 'Reject' : 'Accept');\n\n LOG.info('Command', `[resolveAction] action=${action} button=\"${button}\" provider=${provider?.type}`);\n\n // 0. CLI / ACP category: navigate approval dialog via PTY arrow keys + Enter\n if (provider?.category === 'cli') {\n const adapter = h.getCliAdapter(provider.type);\n if (!adapter) return { success: false, error: 'CLI adapter not running' };\n const status = (adapter as any).getStatus?.();\n if (status?.status !== 'waiting_approval') {\n return { success: false, error: 'Not in approval state' };\n }\n const buttons: string[] = status.activeModal?.buttons || ['Allow once', 'Always allow', 'Deny'];\n // Resolve button index: explicit buttonIndex arg → button text match → action fallback\n let buttonIndex = typeof args?.buttonIndex === 'number' ? args.buttonIndex : -1;\n if (buttonIndex < 0) {\n const btnLower = button.toLowerCase();\n buttonIndex = buttons.findIndex(b => b.toLowerCase().includes(btnLower));\n }\n if (buttonIndex < 0) {\n if (action === 'reject' || action === 'deny') {\n buttonIndex = buttons.findIndex(b => /deny|reject|no/i.test(b));\n if (buttonIndex < 0) buttonIndex = buttons.length - 1;\n } else if (action === 'always' || /always/i.test(button)) {\n buttonIndex = buttons.findIndex(b => /always/i.test(b));\n if (buttonIndex < 0) buttonIndex = 1;\n } else {\n buttonIndex = 0; // approve → first option (default selected)\n }\n }\n if (typeof (adapter as any).resolveModal === 'function') {\n (adapter as any).resolveModal(buttonIndex);\n } else {\n const keys = '\\x1B[B'.repeat(Math.max(0, buttonIndex)) + '\\r';\n (adapter as any).writeRaw?.(keys);\n }\n LOG.info('Command', `[resolveAction] CLI PTY → buttonIndex=${buttonIndex} \"${buttons[buttonIndex] ?? '?'}\"`);\n return { success: true, buttonIndex, button: buttons[buttonIndex] ?? button };\n }\n\n // 1. Extension: via AgentStreamManager\n if (provider?.category === 'extension' && h.agentStream && h.getCdp()) {\n const ok = await h.agentStream.resolveAgentAction(\n h.getCdp()!, provider.type, action, h.currentIdeType\n );\n return { success: ok };\n }\n\n // 2. Webview Provider script\n if (provider?.scripts?.webviewResolveAction || provider?.scripts?.webview_resolve_action) {\n const script = h.getProviderScript('webviewResolveAction', { action, button, buttonText: button })\n || h.getProviderScript('webview_resolve_action', { action, button, buttonText: button });\n if (script) {\n const cdp = h.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 LOG.info('Command', `[resolveAction] webview script result: ${JSON.stringify(result)}`);\n\n if (result?.resolved) return { success: true, clicked: result.clicked };\n if (result?.found && result.x != null && result.y != null) {\n LOG.info('Command', `[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 = h.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 LOG.info('Command', `[resolveAction] script result: ${JSON.stringify(result)}`);\n\n if (result?.resolved) {\n LOG.info('Command', `[resolveAction] script-click resolved — \"${result.clicked}\"`);\n return { success: true, clicked: result.clicked };\n }\n if (result?.found && result.x != null && result.y != null) {\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 LOG.info('Command', `[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 Commands — cdpEval, screenshot, cdpCommand, cdpBatch, cdpRemoteAction,\n * discoverAgents, file operations\n */\n\nimport type { CommandResult, CommandHelpers } from './handler.js';\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\n\n// ─── CDP direct commands ──────────────────────────\n\nexport async function handleCdpEval(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.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 h.getCdp()!.evaluate(expression, 50000);\n return { success: true, result };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n}\n\nexport async function handleScreenshot(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n try {\n const buf = await h.getCdp()!.captureScreenshot();\n if (buf) {\n const b64 = buf.toString('base64');\n return { success: true, result: b64, base64: b64, screenshot: b64, format: 'webp' };\n }\n return { success: false, error: 'Screenshot failed' };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n}\n\nexport async function handleCdpCommand(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.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 h.getCdp()!.sendCdpCommand(method, params);\n return { success: true, result };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\n}\n\nexport async function handleCdpBatch(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.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 h.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\nexport async function handleCdpRemoteAction(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.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 await h.getCdp()!.send('Input.dispatchKeyEvent', {\n type: 'keyDown', key,\n ...(modifiers?.ctrl ? { modifiers: 2 } : {}),\n ...(modifiers?.shift ? { modifiers: 8 } : {}),\n });\n await h.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 if ((x === undefined || y === undefined) && nx !== undefined && ny !== undefined) {\n const viewport = await h.getCdp()!.evaluate(\n 'JSON.stringify({ w: window.innerWidth, h: window.innerHeight })'\n ) as string;\n const { w, h: vh } = JSON.parse(viewport);\n x = Math.round(nx * w);\n y = Math.round(ny * vh);\n }\n if (x === undefined || y === undefined) {\n return { success: false, error: 'No coordinates provided (x,y or nx,ny required)' };\n }\n await h.getCdp()!.send('Input.dispatchMouseEvent', {\n type: 'mousePressed', x, y, button: btn || 'left', clickCount: 1,\n });\n await h.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 h.getCdp()!.send('Input.dispatchKeyEvent', {\n type: 'keyDown', text: char, key: char,\n });\n await h.getCdp()!.send('Input.dispatchKeyEvent', { type: 'keyUp', key: char });\n }\n return { success: true };\n }\n case 'page_screenshot': return handleScreenshot(h, args);\n case 'page_eval': return handleCdpEval(h, params);\n case 'dom_query': {\n const html = await h.getCdp()!.querySelector(params?.selector);\n return { success: true, html };\n }\n case 'input_wheel': {\n let { x, y, nx, ny, deltaX, deltaY } = params;\n if ((x === undefined || y === undefined) && nx !== undefined && ny !== undefined) {\n const viewport = await h.getCdp()!.evaluate(\n 'JSON.stringify({ w: window.innerWidth, h: window.innerHeight })'\n ) as string;\n const { w, h: vh } = JSON.parse(viewport);\n x = Math.round(nx * w);\n y = Math.round(ny * vh);\n }\n await h.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\nexport async function handleDiscoverAgents(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.getCdp()?.isConnected) return { success: false, error: 'CDP not connected' };\n const agents = await h.getCdp()!.discoverAgentWebviews();\n return { success: true, agents };\n}\n\n// ─── File commands ─────────────────────────────\n\nfunction 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\nexport async function handleFileRead(h: CommandHelpers, args: any): Promise<CommandResult> {\n try {\n const filePath = 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\nexport async function handleFileWrite(h: CommandHelpers, args: any): Promise<CommandResult> {\n try {\n const filePath = 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\nexport async function handleFileList(h: CommandHelpers, args: any): Promise<CommandResult> {\n try {\n const dirPath = 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\nexport async function handleFileListBrowse(h: CommandHelpers, args: any): Promise<CommandResult> {\n return handleFileList(h, args);\n}\n","/**\n * Stream Commands — Agent Stream, PTY I/O, Provider Settings,\n * IDE Extension Settings, Extension Script Execution\n */\n\nimport type { CommandResult, CommandHelpers } from './handler.js';\nimport type { ProviderLoader } from '../providers/provider-loader.js';\nimport { loadConfig } from '../config/config.js';\nimport { LOG } from '../logging/logger.js';\n\n// ─── Agent Stream commands ───────────────────────\n\nexport async function handleAgentStreamSwitch(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || null;\n await h.agentStream.switchActiveAgent(h.getCdp()!, agentType);\n return { success: true, activeAgent: agentType };\n}\n\nexport async function handleAgentStreamRead(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const streams = await h.agentStream.collectAgentStreams(h.getCdp()!);\n return { success: true, streams };\n}\n\nexport async function handleAgentStreamSend(h: CommandHelpers, 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\n if (agentType && h.ctx.adapters) {\n for (const [key, adapter] of h.ctx.adapters.entries()) {\n if (adapter.cliType === agentType || key.includes(agentType)) {\n LOG.info('Command', `[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 LOG.info('Command', `[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\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const resolvedAgent = agentType || h.agentStream.activeAgentType;\n if (!resolvedAgent) return { success: false, error: 'agentType required' };\n const ok = await h.agentStream.sendToAgent(h.getCdp()!, resolvedAgent, text, h.currentIdeType);\n return { success: ok };\n}\n\nexport async function handleAgentStreamResolve(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.agentStream.activeAgentType;\n const action = args?.action as 'approve' | 'reject' || 'approve';\n if (!agentType) return { success: false, error: 'agentType required' };\n const ok = await h.agentStream.resolveAgentAction(h.getCdp()!, agentType, action, h.currentIdeType);\n return { success: ok };\n}\n\nexport async function handleAgentStreamNew(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.agentStream.activeAgentType;\n if (!agentType) return { success: false, error: 'agentType required' };\n const ok = await h.agentStream.newAgentSession(h.getCdp()!, agentType, h.currentIdeType);\n return { success: ok };\n}\n\nexport async function handleAgentStreamListChats(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.agentStream.activeAgentType;\n if (!agentType) return { success: false, error: 'agentType required' };\n const chats = await h.agentStream.listAgentChats(h.getCdp()!, agentType);\n return { success: true, chats };\n}\n\nexport async function handleAgentStreamSwitchSession(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.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 h.agentStream.switchAgentSession(h.getCdp()!, agentType, sessionId);\n return { success: ok };\n}\n\nexport async function handleAgentStreamFocus(h: CommandHelpers, args: any): Promise<CommandResult> {\n if (!h.agentStream || !h.getCdp()) return { success: false, error: 'AgentStream or CDP not available' };\n const agentType = args?.agentType || args?.agent || h.agentStream.activeAgentType;\n if (!agentType) return { success: false, error: 'agentType required' };\n await h.agentStream.ensureAgentPanelOpen(agentType, h.currentIdeType);\n const ok = await h.agentStream.focusAgentEditor(h.getCdp()!, agentType);\n return { success: ok };\n}\n\n// ─── PTY Raw I/O ──────────────────────────────────\n\nexport function handlePtyInput(h: CommandHelpers, args: any): CommandResult {\n const { cliType, data } = args || {};\n if (!data) return { success: false, error: 'data required' };\n\n if (h.ctx.adapters) {\n const targetCli = cliType || '';\n if (!targetCli && h.ctx.adapters.size > 0) {\n const first = h.ctx.adapters.values().next().value;\n if (first && typeof first.writeRaw === 'function') {\n first.writeRaw(data);\n return { success: true };\n }\n }\n const directAdapter = h.ctx.adapters.get(targetCli);\n if (directAdapter && typeof directAdapter.writeRaw === 'function') {\n directAdapter.writeRaw(data);\n return { success: true };\n }\n for (const [, adapter] of h.ctx.adapters) {\n if (adapter.cliType === targetCli && typeof adapter.writeRaw === 'function') {\n adapter.writeRaw(data);\n return { success: true };\n }\n }\n for (const [key, adapter] of h.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\nexport function handlePtyResize(h: CommandHelpers, 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 (h.ctx.adapters) {\n const targetCli = cliType || '';\n if (!targetCli && h.ctx.adapters.size > 0) {\n const first = h.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 const directAdapter = h.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 for (const [key, adapter] of h.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\nexport function handleGetProviderSettings(h: CommandHelpers, args: any): CommandResult {\n const loader = h.ctx.providerLoader as ProviderLoader | undefined;\n const { providerType } = args || {};\n if (providerType) {\n const schema = loader?.getPublicSettings(providerType) || [];\n const values = loader?.getSettings(providerType) || {};\n return { success: true, providerType, schema, values };\n }\n const allSettings = loader?.getAllPublicSettings() || {};\n const allValues: Record<string, any> = {};\n for (const type of Object.keys(allSettings)) {\n allValues[type] = loader?.getSettings(type) || {};\n }\n return { success: true, settings: allSettings, values: allValues };\n}\n\nexport function handleSetProviderSetting(h: CommandHelpers, args: any): CommandResult {\n const loader = h.ctx.providerLoader as ProviderLoader | undefined;\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 const result = loader?.setSetting(providerType, key, value);\n if (result) {\n if (h.ctx.instanceManager) {\n const allSettings = loader?.getSettings(providerType) || {};\n const updated = h.ctx.instanceManager.updateInstanceSettings(providerType, allSettings);\n LOG.info('Command', `[set_provider_setting] ${providerType}.${key}=${JSON.stringify(value)} → ${updated} instance(s) updated`);\n }\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\nexport async function handleExtensionScript(h: CommandHelpers, args: any, scriptName: string): Promise<CommandResult> {\n const { agentType, ideType } = args || {};\n LOG.info('Command', `[ExtScript] ${scriptName} agentType=${agentType} ideType=${ideType} _currentIdeType=${h.currentIdeType}`);\n if (!agentType) return { success: false, error: 'agentType is required' };\n\n const loader = h.ctx.providerLoader;\n if (!loader) return { success: false, error: 'ProviderLoader not initialized' };\n const provider = loader.resolve(agentType);\n if (!provider) return { success: false, error: `Provider not found: ${agentType}` };\n\n const webviewScriptName = `webview${scriptName.charAt(0).toUpperCase() + scriptName.slice(1)}`;\n const hasWebviewScript = provider.category === 'ide' &&\n !!provider.scripts?.[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 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 const cdpKey = provider.category === 'ide' ? (h.currentIdeType || agentType) : (h.currentIdeType || ideType);\n LOG.info('Command', `[ExtScript] provider=${provider.type} category=${provider.category} cdpKey=${cdpKey}`);\n const cdp = h.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 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 const matchText = provider.webviewMatchText;\n const matchFn = matchText ? (body: string) => body.includes(matchText) : undefined;\n result = await cdp.evaluateInWebviewFrame(scriptCode, matchFn);\n } else {\n result = await cdp.evaluate(scriptCode, 30000);\n }\n\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\nexport function handleGetIdeExtensions(h: CommandHelpers, args: any): CommandResult {\n const { ideType } = args || {};\n const loader = h.ctx.providerLoader as ProviderLoader | undefined;\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 const extensions = allExtProviders.map(p => ({\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 const connectedIdes = [...(h.ctx.cdpManagers?.keys?.() || [])];\n const result: Record<string, any[]> = {};\n for (const ide of connectedIdes) {\n result[ide] = allExtProviders.map(p => ({\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\nexport function handleSetIdeExtension(h: CommandHelpers, 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 = h.ctx.providerLoader as ProviderLoader | undefined;\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 * workspace_* commands — list/add/remove/default (config.json)\n */\n\nimport { loadConfig, saveConfig } from '../config/config.js';\nimport * as W from '../config/workspaces.js';\nimport { appendWorkspaceActivity, getWorkspaceActivity, removeActivityForPath } from '../config/workspace-activity.js';\n\nexport type WorkspaceCommandResult = { success: boolean;[key: string]: unknown };\n\nexport function handleWorkspaceList(): WorkspaceCommandResult {\n const config = loadConfig();\n const state = W.getWorkspaceState(config);\n return {\n success: true,\n workspaces: state.workspaces,\n defaultWorkspaceId: state.defaultWorkspaceId,\n defaultWorkspacePath: state.defaultWorkspacePath,\n legacyRecentPaths: config.recentCliWorkspaces || [],\n activity: getWorkspaceActivity(config, 25),\n };\n}\n\nexport function handleWorkspaceAdd(args: any): WorkspaceCommandResult {\n const rawPath = (args?.path || args?.dir || '').trim();\n const label = (args?.label || '').trim() || undefined;\n if (!rawPath) return { success: false, error: 'path required' };\n\n const config = loadConfig();\n const result = W.addWorkspaceEntry(config, rawPath, label);\n if ('error' in result) return { success: false, error: result.error };\n\n let cfg = appendWorkspaceActivity(result.config, result.entry.path, {});\n saveConfig(cfg);\n const state = W.getWorkspaceState(cfg);\n return { success: true, entry: result.entry, ...state, activity: getWorkspaceActivity(cfg, 25) };\n}\n\nexport function handleWorkspaceRemove(args: any): WorkspaceCommandResult {\n const id = (args?.id || '').trim();\n if (!id) return { success: false, error: 'id required' };\n\n const config = loadConfig();\n const removed = (config.workspaces || []).find(w => w.id === id);\n const result = W.removeWorkspaceEntry(config, id);\n if ('error' in result) return { success: false, error: result.error };\n\n let cfg = result.config;\n if (removed) {\n cfg = removeActivityForPath(cfg, removed.path);\n }\n saveConfig(cfg);\n const state = W.getWorkspaceState(cfg);\n return { success: true, removedId: id, ...state, activity: getWorkspaceActivity(cfg, 25) };\n}\n\nexport function handleWorkspaceSetDefault(args: any): WorkspaceCommandResult {\n const clear = args?.clear === true || args?.id === null || args?.id === '';\n if (clear) {\n const config = loadConfig();\n const result = W.setDefaultWorkspaceId(config, null);\n if ('error' in result) return { success: false, error: result.error };\n saveConfig(result.config);\n const state = W.getWorkspaceState(result.config);\n return {\n success: true,\n ...state,\n activity: getWorkspaceActivity(result.config, 25),\n };\n }\n\n const pathArg = (args?.path != null && String(args.path).trim()) ? String(args.path).trim() : '';\n const idArg = args?.id !== undefined && args?.id !== null && String(args.id).trim()\n ? String(args.id).trim()\n : '';\n\n if (!pathArg && !idArg) {\n return { success: false, error: 'id or path required (or clear: true)' };\n }\n\n let config = loadConfig();\n let nextId: string;\n\n if (pathArg) {\n let w = W.findWorkspaceByPath(config, pathArg);\n if (!w) {\n const add = W.addWorkspaceEntry(config, pathArg);\n if ('error' in add) return { success: false, error: add.error };\n config = add.config;\n w = add.entry;\n }\n nextId = w.id;\n } else {\n nextId = idArg;\n }\n\n const result = W.setDefaultWorkspaceId(config, nextId);\n if ('error' in result) return { success: false, error: result.error };\n\n let out = result.config;\n const ap = W.getDefaultWorkspacePath(out);\n if (ap) {\n out = appendWorkspaceActivity(out, ap, { kind: 'default' });\n }\n saveConfig(out);\n const state = W.getWorkspaceState(out);\n return { success: true, ...state, activity: getWorkspaceActivity(out, 25) };\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 './detection/ide-detector.js';\nimport { IDEInfo } from './detection/ide-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) */\nexport async 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 */\nexport function 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 workspace paths\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/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 '../detection/ide-detector.js';\nimport { LOG } from '../logging/logger.js';\nimport { VersionArchive } from './version-archive.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 builtinDirs: string[];\n private userDir: string;\n private upstreamDir: string;\n private watchers: fs.FSWatcher[] = [];\n private logFn: (msg: string) => void;\n private versionArchive: VersionArchive | null = null;\n private scriptsCache = new Map<string, Record<string, any>>();\n\n /** Inject VersionArchive so resolve() can auto-detect installed versions */\n setVersionArchive(archive: VersionArchive): void {\n this.versionArchive = archive;\n }\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 | string[];\n userDir?: string;\n logFn?: (msg: string) => void;\n }) {\n // Builtin directories: providers/_builtin/\n if (options?.builtinDir) {\n this.builtinDirs = Array.isArray(options.builtinDir) ? options.builtinDir : [options.builtinDir];\n } else {\n this.builtinDirs = [path.resolve(__dirname, '../providers/_builtin')];\n }\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 || LOG.forComponent('Provider').asLogFn();\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, or multiple array dirs)\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 let builtinCount = 0;\n for (const dir of this.builtinDirs) {\n if (fs.existsSync(dir)) {\n builtinCount += this.loadDir(dir);\n }\n }\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 builtinDirs.`);\n }\n }\n\n /**\n * Get raw provider metadata by type (NO scripts loaded).\n * Use resolve() when you need scripts (readChat, listModels, etc).\n * @deprecated Use getMeta() for metadata or resolve() for scripts.\n */\n get(type: string): ProviderModule | undefined {\n return this.providers.get(type);\n }\n\n /**\n * Get raw provider metadata by type (NO scripts loaded).\n * Safe for: category checks, icon, displayName, targetFilter, cdpPorts.\n * NOT safe for: script execution (readChat, listModels, sendMessage).\n * Use resolve() when scripts are needed.\n */\n getMeta(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/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/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 * Script resolution order:\n * 1. compatibility array (new format — preferred)\n * Provider.json defines: \"compatibility\": [{ \"ideVersion\": \">=1.107.0\", \"scriptDir\": \"scripts/1.107\" }]\n * First matching range wins. Fallback: defaultScriptDir.\n * 2. versions field (legacy format — backward compat)\n * \"versions\": { \"< 1.107.0\": { \"__dir\": \"scripts/legacy\" } }\n * 3. Root scripts.js (original format — no versioning)\n *\n * Version source: context.version → VersionArchive → undefined\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 this.versionArchive?.getLatest(type) ??\n undefined;\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-based script selection\n if (currentVersion) {\n resolved._resolvedVersion = currentVersion;\n\n // --- New format: compatibility array ---\n if (Array.isArray((base as any).compatibility)) {\n const compat = (base as any).compatibility as { ideVersion: string; scriptDir: string }[];\n let matched = false;\n\n for (const entry of compat) {\n if (this.matchesVersion(currentVersion, entry.ideVersion)) {\n const loaded = this.loadScriptsFromDir(type, entry.scriptDir);\n if (loaded) {\n resolved.scripts = loaded;\n this.log(` [compatibility] ${type} v${currentVersion} → ${entry.scriptDir}`);\n matched = true;\n }\n break; // first match wins\n }\n }\n\n // No compatibility match → defaultScriptDir\n if (!matched && (base as any).defaultScriptDir) {\n const loaded = this.loadScriptsFromDir(type, (base as any).defaultScriptDir);\n if (loaded) {\n resolved.scripts = loaded;\n this.log(` [compatibility] ${type} v${currentVersion} → default: ${(base as any).defaultScriptDir}`);\n }\n resolved._versionWarning = `Version ${currentVersion} not in compatibility matrix. Using default scripts.`;\n }\n\n // --- Legacy format: versions field ---\n } else if (base.versions) {\n for (const [range, override] of Object.entries(base.versions)) {\n if (!this.matchesVersion(currentVersion, range)) continue;\n\n const dirOverride = (override as any).__dir as string | undefined;\n if (dirOverride) {\n const loaded = this.loadScriptsFromDir(type, dirOverride);\n if (loaded) {\n resolved.scripts = loaded;\n this.log(` [version override] ${type} ${range} → ${dirOverride}`);\n }\n } else if (override.scripts) {\n resolved.scripts = { ...resolved.scripts, ...override.scripts };\n }\n }\n }\n } else if (Array.isArray((base as any).compatibility) && (base as any).defaultScriptDir) {\n // No version detected but compatibility format → use defaultScriptDir\n const loaded = this.loadScriptsFromDir(type, (base as any).defaultScriptDir);\n if (loaded) {\n resolved.scripts = loaded;\n this.log(` [compatibility] ${type} no version detected → default: ${(base as any).defaultScriptDir}`);\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 * Load scripts from a scriptDir within a provider directory.\n * Tries scripts.js first, then individual .js files.\n */\n private loadScriptsFromDir(type: string, scriptDir: string): Record<string, any> | null {\n const providerDir = this.findProviderDir(type);\n if (!providerDir) {\n this.log(` [loadScriptsFromDir] ${type}: providerDir not found`);\n return null;\n }\n\n const dir = path.join(providerDir, scriptDir);\n if (!fs.existsSync(dir)) {\n this.log(` [loadScriptsFromDir] ${type}: dir not found: ${dir}`);\n return null;\n }\n\n // Return cached scripts if available (cleared on reload/watch)\n const cached = this.scriptsCache.get(dir);\n if (cached) return cached;\n\n // Try scripts.js first\n const scriptsJs = path.join(dir, 'scripts.js');\n if (fs.existsSync(scriptsJs)) {\n try {\n delete require.cache[require.resolve(scriptsJs)];\n const loaded = require(scriptsJs);\n this.log(` [loadScriptsFromDir] ${type}: loaded scripts.js from ${dir} (${Object.keys(loaded).length} exports)`);\n this.scriptsCache.set(dir, loaded);\n return loaded;\n } catch (e) {\n this.log(` ⚠ scripts.js load failed: ${scriptsJs}: ${(e as Error).message}`);\n }\n }\n\n // Fallback: build from individual .js files\n const result = this.buildScriptWrappersFromDir(dir) as Record<string, any>;\n this.log(` [loadScriptsFromDir] ${type}: built wrappers from ${dir} (${Object.keys(result).length} scripts)`);\n this.scriptsCache.set(dir, result);\n return result;\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 this.builtinDirs.forEach(dir => watchDir(dir));\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 caches\n this.scriptsCache.clear();\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/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/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 * Find the on-disk directory for a provider by type.\n * Checks builtinDir, upstreamDir, userDir in order.\n */\n private findProviderDir(type: string): string | null {\n const provider = this.providers.get(type);\n if (!provider) return null;\n const cat = provider.category;\n\n const searchRoots = [this.userDir, this.upstreamDir, ...this.builtinDirs];\n for (const root of searchRoots) {\n if (!fs.existsSync(root)) continue;\n // Direct: root/type or root/cat/type\n for (const candidate of [path.join(root, type), path.join(root, cat, type)]) {\n if (fs.existsSync(path.join(candidate, 'provider.json'))) return candidate;\n }\n // Scan category dir for type match\n const catDir = path.join(root, 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 }\n return null;\n }\n\n /**\n * Build a scripts function map from individual .js files in a directory.\n * Each file is wrapped as: (params?) => fs.readFileSync(filePath, 'utf-8')\n * (template substitution is NOT applied here — scripts.js handles that)\n */\n private buildScriptWrappersFromDir(dir: string): Partial<ProviderScripts> {\n // Use a dedicated scripts.js in the alt dir if present\n const scriptsJs = path.join(dir, 'scripts.js');\n if (fs.existsSync(scriptsJs)) {\n try {\n delete require.cache[require.resolve(scriptsJs)];\n return require(scriptsJs);\n } catch { /* fall through to individual file loading */ }\n }\n\n // Individual files: list_models.js → scripts.listModels, etc.\n const toCamel = (name: string) =>\n name.replace(/_([a-z])/g, (_, c) => c.toUpperCase());\n\n const result: Partial<ProviderScripts> = {};\n try {\n for (const file of fs.readdirSync(dir)) {\n if (!file.endsWith('.js')) continue;\n const scriptName = toCamel(file.replace('.js', ''));\n const filePath = path.join(dir, file);\n (result as any)[scriptName] = (..._args: any[]): string => {\n try { return fs.readFileSync(filePath, 'utf-8'); } catch { return ''; }\n };\n }\n } catch { /* ignore */ }\n return result;\n }\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 // Skip for compatibility-format providers — scripts loaded lazily in resolve()\n const hasCompatibility = Array.isArray((mod as any).compatibility);\n const scriptsPath = path.join(d, 'scripts.js');\n if (!hasCompatibility && 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 // Identify source tier for debugging\n const source = d.startsWith(this.userDir) && !d.includes('.upstream')\n ? 'user' : d.startsWith(this.upstreamDir) ? 'upstream' : 'builtin';\n const overrideWarning = existed && source === 'user' ? ' ⚠ OVERRIDES builtin/upstream' : '';\n this.log(` ${existed ? '🔄' : '✅'} ${mod.type} (${mod.category}) — ${mod.name} [${source}]${overrideWarning}`);\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 * DaemonCommandRouter — Unified command routing for daemon-level commands\n *\n * Extracted from cloud daemon's executeDaemonCommand() logic.\n * Used by both daemon-cloud and daemon-standalone.\n *\n * Routing flow:\n * 1. Daemon-level commands (launch_ide, stop_ide, restart_ide, etc.) → handled here\n * 2. CLI/ACP commands → delegated to cliManager\n * 3. Everything else → delegated to commandHandler.handle()\n */\n\nimport { DaemonCdpManager } from '../cdp/manager.js';\nimport { registerExtensionProviders } from '../cdp/setup.js';\nimport { DaemonCommandHandler } from './handler.js';\nimport { DaemonCliManager } from './cli-manager.js';\nimport type { ProviderLoader } from '../providers/provider-loader.js';\nimport type { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport { launchWithCdp, killIdeProcess, isIdeRunning } from '../launch.js';\nimport { loadConfig, saveConfig, updateConfig } from '../config/config.js';\nimport { resolveIdeLaunchWorkspace } from '../config/workspaces.js';\nimport { appendWorkspaceActivity } from '../config/workspace-activity.js';\nimport { detectIDEs } from '../detection/ide-detector.js';\nimport { LOG } from '../logging/logger.js';\nimport { logCommand } from '../logging/command-log.js';\nimport { getRecentLogs, LOG_PATH } from '../logging/logger.js';\nimport * as fs from 'fs';\n\n// ─── Types ───\n\nexport interface CommandRouterDeps {\n commandHandler: DaemonCommandHandler;\n cliManager: DaemonCliManager;\n cdpManagers: Map<string, DaemonCdpManager>;\n providerLoader: ProviderLoader;\n instanceManager: ProviderInstanceManager;\n /** Reference to detected IDEs array (mutable — router updates it) */\n detectedIdes: { value: any[] };\n /** UUID instanceId → CDP manager key mapping */\n instanceIdMap: Map<string, string>;\n /** Callback for CDP manager creation after launch_ide (cloud: setupCdpManager, standalone: no-op) */\n onCdpManagerCreated?: (ideType: string, manager: DaemonCdpManager) => void;\n /** Callback after IDE connected (e.g., startAgentStreamPolling) */\n onIdeConnected?: () => void;\n /** Callback after status change (stop_ide, restart) */\n onStatusChange?: () => void;\n /** Callback after chat-related commands (cloud: throttled report) */\n onPostChatCommand?: () => void;\n /** Get a connected CDP manager (for agent stream reset check) */\n getCdpLogFn?: (ideType: string) => (msg: string) => void;\n}\n\nexport interface CommandRouterResult {\n success: boolean;\n [key: string]: unknown;\n}\n\n// Commands that trigger post-chat status updates\nconst CHAT_COMMANDS = [\n 'send_chat', 'new_chat', 'switch_chat', 'set_mode',\n 'change_model', 'agent_stream_send',\n];\n\nexport class DaemonCommandRouter {\n private deps: CommandRouterDeps;\n\n constructor(deps: CommandRouterDeps) {\n this.deps = deps;\n }\n\n /**\n * Unified command routing.\n * Returns result for all commands:\n * 1. Daemon-level commands (launch_ide, stop_ide, etc.)\n * 2. CLI commands (launch_cli, stop_cli, agent_command)\n * 3. DaemonCommandHandler delegation (CDP/agent-stream/file commands)\n *\n * @param cmd Command name\n * @param args Command arguments\n * @param source Log source ('ws' | 'p2p' | 'standalone' | etc.)\n */\n async execute(cmd: string, args: any, source: string = 'unknown'): Promise<CommandRouterResult> {\n const cmdStart = Date.now();\n\n try {\n // 1. Try daemon-level command\n const daemonResult = await this.executeDaemonCommand(cmd, args);\n if (daemonResult) {\n logCommand({ ts: new Date().toISOString(), cmd, source: source as any, args, success: daemonResult.success, durationMs: Date.now() - cmdStart });\n return daemonResult;\n }\n\n // 2. Delegate to DaemonCommandHandler\n const handlerResult = await this.deps.commandHandler.handle(cmd, args);\n logCommand({ ts: new Date().toISOString(), cmd, source: source as any, args, success: handlerResult.success, durationMs: Date.now() - cmdStart });\n\n // 3. Post-chat command callback\n if (CHAT_COMMANDS.includes(cmd) && this.deps.onPostChatCommand) {\n this.deps.onPostChatCommand();\n }\n\n return handlerResult;\n } catch (e: any) {\n logCommand({ ts: new Date().toISOString(), cmd, source: source as any, args, success: false, error: e.message, durationMs: Date.now() - cmdStart });\n throw e;\n }\n }\n\n // ─── Daemon-level command core ───────────────────\n\n /**\n * Daemon-level command execution (IDE start/stop/restart, CLI, detect, logs).\n * Returns null if not handled at this level → caller delegates to CommandHandler.\n */\n private async executeDaemonCommand(cmd: string, args: any): Promise<CommandRouterResult | null> {\n switch (cmd) {\n // ─── CLI / ACP commands ───\n case 'launch_cli':\n case 'stop_cli':\n case 'agent_command': {\n return this.deps.cliManager.handleCliCommand(cmd, args);\n }\n\n // ─── Logs ───\n case 'get_logs': {\n const count = parseInt(args?.count) || parseInt(args?.lines) || 100;\n const minLevel = args?.minLevel || 'info';\n const sinceTs = args?.since || 0;\n\n try {\n // Priority 1: ring buffer (fast and structured)\n let logs = getRecentLogs(count, minLevel);\n if (sinceTs > 0) {\n logs = logs.filter((l: any) => l.ts > sinceTs);\n }\n if (logs.length > 0) {\n return { success: true, logs, totalBuffered: logs.length };\n }\n // Priority 2: file fallback\n if (fs.existsSync(LOG_PATH)) {\n const content = fs.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, logs: [], totalBuffered: 0 };\n } catch (e: any) {\n return { success: false, error: e.message };\n }\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.deps.cdpManagers.has(targetType) ||\n this.deps.providerLoader.getMeta(targetType)?.category === 'ide';\n\n if (isIde) {\n // IDE restart: stop (with process kill) → launch\n await this.stopIde(targetType, true);\n const launchResult = await this.executeDaemonCommand('launch_ide', { ideType: targetType, enableCdp: true, workspace: args?.workspace });\n return { success: true, restarted: true, ideType: targetType, launch: launchResult };\n }\n\n // CLI/ACP restart: delegate to CliManager\n return this.deps.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 const killProcess = args?.killProcess !== false; // default true\n await this.stopIde(ideType, killProcess);\n return { success: true, ideType, stopped: true, processKilled: killProcess };\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, true); // always kill process on restart\n const launchResult = await this.executeDaemonCommand('launch_ide', { ideType, enableCdp: true, workspace: args?.workspace });\n return { success: true, ideType, restarted: true, launch: launchResult };\n }\n\n // ─── IDE launch + CDP connect ───\n case 'launch_ide': {\n const ideKey = args?.ideId || args?.ideType;\n const resolvedWorkspace = resolveIdeLaunchWorkspace(\n {\n workspace: args?.workspace,\n workspaceId: args?.workspaceId,\n useDefaultWorkspace: args?.useDefaultWorkspace,\n },\n loadConfig(),\n );\n const launchArgs = {\n ideId: ideKey,\n workspace: resolvedWorkspace,\n newWindow: args?.newWindow,\n };\n LOG.info('LaunchIDE', `target=${ideKey || 'auto'}`);\n const result = await launchWithCdp(launchArgs);\n\n if (result.success && result.port && result.ideId && !this.deps.cdpManagers.has(result.ideId)) {\n const logFn = this.deps.getCdpLogFn\n ? this.deps.getCdpLogFn(result.ideId)\n : LOG.forComponent(`CDP:${result.ideId}`).asLogFn();\n const provider = this.deps.providerLoader.getMeta(result.ideId);\n const manager = new DaemonCdpManager(result.port, logFn, undefined, (provider as any)?.targetFilter);\n const connected = await manager.connect();\n if (connected) {\n // Register active extension providers for this IDE in CDP manager\n registerExtensionProviders(this.deps.providerLoader, manager, result.ideId);\n this.deps.cdpManagers.set(result.ideId, manager);\n LOG.info('CDP', `Connected: ${result.ideId} (port ${result.port})`);\n LOG.info('CDP', `${this.deps.cdpManagers.size} IDE(s) connected`);\n\n // Notify consumer (cloud: setupCdpManager, standalone: setupIdeInstance)\n this.deps.onCdpManagerCreated?.(result.ideId, manager);\n }\n }\n this.deps.onIdeConnected?.();\n if (result.success && resolvedWorkspace) {\n try {\n saveConfig(appendWorkspaceActivity(loadConfig(), resolvedWorkspace, {\n kind: 'ide',\n agentType: result.ideId,\n }));\n } catch { /* ignore activity persist errors */ }\n }\n return { success: result.success, ...result as any };\n }\n\n // ─── Detect IDEs ───\n case 'detect_ides': {\n const results = await detectIDEs();\n this.deps.detectedIdes.value = results;\n return { success: true, detectedInfo: results };\n }\n\n // ─── Set User Name ───\n case 'set_user_name': {\n const name = args?.userName;\n if (!name || typeof name !== 'string') throw new Error('userName required');\n updateConfig({ userName: name });\n return { success: true, userName: name };\n }\n\n // ─── Daemon Self-Upgrade ───\n case 'daemon_upgrade': {\n LOG.info('Upgrade', 'Remote upgrade requested from dashboard');\n try {\n const { execSync } = await import('child_process');\n\n // Check latest version\n const latest = execSync('npm view adhdev version', { encoding: 'utf-8', timeout: 10000 }).trim();\n LOG.info('Upgrade', `Latest available: v${latest}`);\n\n // Install latest\n execSync('npm install -g adhdev@latest', {\n encoding: 'utf-8',\n timeout: 60000,\n stdio: ['pipe', 'pipe', 'pipe'],\n });\n LOG.info('Upgrade', `✅ Upgraded to v${latest}`);\n\n // Schedule restart after response is sent\n setTimeout(() => {\n LOG.info('Upgrade', 'Restarting daemon with new version...');\n const { spawn } = require('child_process');\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 process.exit(0);\n }, 3000);\n\n return { success: true, upgraded: true, version: latest };\n } catch (e: any) {\n LOG.error('Upgrade', `Failed: ${e.message}`);\n return { success: false, error: e.message };\n }\n }\n\n // ─── Machine Settings ───\n case 'set_machine_nickname': {\n const nickname = args?.nickname;\n updateConfig({ machineNickname: nickname || null });\n return { success: true };\n }\n\n default:\n break;\n }\n\n return null; // Not handled at this level → delegate to CommandHandler\n }\n\n /**\n * IDE stop: CDP disconnect + InstanceManager cleanup + optionally kill OS process\n */\n private async stopIde(ideType: string, killProcess: boolean = false): Promise<void> {\n // 1. Release CDP manager(s) — handle multi-instance (e.g. \"cursor\" and \"cursor_workspace\")\n const cdpKeysToRemove: string[] = [];\n for (const key of this.deps.cdpManagers.keys()) {\n if (key === ideType || key.startsWith(`${ideType}_`)) {\n cdpKeysToRemove.push(key);\n }\n }\n for (const key of cdpKeysToRemove) {\n const cdp = this.deps.cdpManagers.get(key);\n if (cdp) {\n try { cdp.disconnect(); } catch { /* noop */ }\n this.deps.cdpManagers.delete(key);\n LOG.info('StopIDE', `CDP disconnected: ${key}`);\n }\n }\n\n // 2. Remove IDE instance(s) from InstanceManager\n const keysToRemove: string[] = [];\n for (const key of (this.deps.instanceManager as any).instances?.keys?.() || []) {\n if (key === `ide:${ideType}` || (typeof key === 'string' && key.startsWith(`ide:${ideType}_`))) {\n keysToRemove.push(key);\n }\n }\n for (const instanceKey of keysToRemove) {\n const ideInstance = this.deps.instanceManager.getInstance(instanceKey) as any;\n if (ideInstance) {\n // Remove IDE and child Extension UUIDs from instanceIdMap\n if (ideInstance.getInstanceId) {\n this.deps.instanceIdMap.delete(ideInstance.getInstanceId());\n }\n if (ideInstance.getExtensionInstances) {\n for (const ext of ideInstance.getExtensionInstances()) {\n if (ext.getInstanceId) this.deps.instanceIdMap.delete(ext.getInstanceId());\n }\n }\n this.deps.instanceManager.removeInstance(instanceKey);\n LOG.info('StopIDE', `Instance removed: ${instanceKey}`);\n }\n }\n // Fallback: single instance key\n if (keysToRemove.length === 0) {\n const instanceKey = `ide:${ideType}`;\n const ideInstance = this.deps.instanceManager.getInstance(instanceKey) as any;\n if (ideInstance) {\n if (ideInstance.getInstanceId) {\n this.deps.instanceIdMap.delete(ideInstance.getInstanceId());\n }\n if (ideInstance.getExtensionInstances) {\n for (const ext of ideInstance.getExtensionInstances()) {\n if (ext.getInstanceId) this.deps.instanceIdMap.delete(ext.getInstanceId());\n }\n }\n this.deps.instanceManager.removeInstance(instanceKey);\n LOG.info('StopIDE', `Instance removed: ${instanceKey}`);\n }\n }\n\n // 3. Kill OS process if requested\n if (killProcess) {\n const running = isIdeRunning(ideType);\n if (running) {\n LOG.info('StopIDE', `Killing IDE process: ${ideType}`);\n const killed = await killIdeProcess(ideType);\n if (killed) {\n LOG.info('StopIDE', `✅ Process killed: ${ideType}`);\n } else {\n LOG.warn('StopIDE', `⚠ Could not kill process: ${ideType} (may need manual intervention)`);\n }\n } else {\n LOG.info('StopIDE', `Process not running: ${ideType}`);\n }\n }\n\n // 4. Notify consumer for status update\n this.deps.onStatusChange?.();\n LOG.info('StopIDE', `IDE stopped: ${ideType} (processKill=${killProcess})`);\n }\n}\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 * 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/config.js';\nimport { getWorkspaceState } from '../config/workspaces.js';\nimport { getHostMemorySnapshot } from '../system/host-memory.js';\nimport { getWorkspaceActivity } from '../config/workspace-activity.js';\nimport { LOG } from '../logging/logger.js';\nimport type { ManagedIdeEntry, ManagedCliEntry, ManagedAcpEntry } from '../shared-types.js';\nimport type {\n ProviderState,\n IdeProviderState,\n CliProviderState,\n AcpProviderState,\n ExtensionProviderState,\n} from '../providers/provider-instance.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 daemonVersion?: string;\n instanceManager: { collectAllStates(): ProviderState[]; collectStatesByCategory(cat: string): ProviderState[] };\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 || LOG.forComponent('Status').asLogFn();\n }\n\n // ─── Lifecycle ───────────────────────────────────\n\n startReporting(): void {\n setTimeout(() => {\n this.sendUnifiedStatusReport().catch(e => LOG.warn('Status', `Initial report failed: ${e?.message}`));\n }, 2000);\n\n const scheduleServerReport = () => {\n this.statusTimer = setTimeout(() => {\n this.sendUnifiedStatusReport().catch(e => LOG.warn('Status', `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 => LOG.warn('Status', `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 => LOG.warn('Status', `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 => LOG.warn('Status', `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 /** Reset P2P dedup hash — forces next send to transmit even if content unchanged */\n resetP2PHash(): void {\n this.lastP2PStatusHash = '';\n }\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): s is IdeProviderState => s.category === 'ide');\n const cliStates = allStates.filter((s): s is CliProviderState => s.category === 'cli');\n const acpStates = allStates.filter((s): s is AcpProviderState => s.category === 'acp');\n\n // IDE summary\n const ideSummary = ideStates.map((s) => {\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) => `${s.type}(${s.status})`).join(', ');\n // ACP summary\n const acpSummary = acpStates.map((s) => `${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 // Skip identical repeats at any level to reduce log noise\n const summaryChanged = summary !== this.lastStatusSummary;\n if (summaryChanged) {\n this.lastStatusSummary = summary;\n if (logLevel === 'debug') {\n LOG.debug('StatusReport', summary);\n } else {\n LOG.info('StatusReport', summary);\n }\n }\n\n // IDE states → managedIdes\n const managedIdes: ManagedIdeEntry[] = ideStates.map((s) => ({\n ideType: s.type,\n ideVersion: '',\n instanceId: s.instanceId,\n workspace: s.workspace || null,\n terminals: 0,\n aiAgents: [],\n activeChat: s.activeChat,\n chats: [],\n agentStreams: s.extensions.map((ext) => ({\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,\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: ManagedCliEntry[] = cliStates.map((s) => ({\n id: s.instanceId,\n instanceId: s.instanceId,\n cliType: s.type,\n cliName: s.name,\n status: s.status,\n mode: s.mode,\n workspace: s.workspace || '',\n activeChat: s.activeChat,\n }));\n\n // ACP states → managedAcps\n const managedAcps: ManagedAcpEntry[] = acpStates.map((s) => ({\n id: s.instanceId,\n acpType: s.type,\n acpName: s.name,\n status: s.status,\n mode: s.mode,\n workspace: s.workspace || '',\n activeChat: s.activeChat,\n currentModel: s.currentModel,\n currentPlan: s.currentPlan,\n acpConfigOptions: s.acpConfigOptions,\n acpModes: s.acpModes,\n errorMessage: s.errorMessage,\n errorReason: s.errorReason,\n }));\n\n\n\n const cfg = loadConfig();\n const wsState = getWorkspaceState(cfg);\n const memSnap = getHostMemorySnapshot();\n\n // ═══ Assemble payload (P2P — required data only) ═══\n const payload: Record<string, any> = {\n daemonMode: true,\n version: this.deps.daemonVersion || 'unknown',\n machineNickname: cfg.machineNickname || null,\n workspaces: wsState.workspaces,\n defaultWorkspaceId: wsState.defaultWorkspaceId,\n defaultWorkspacePath: wsState.defaultWorkspacePath,\n workspaceActivity: getWorkspaceActivity(cfg, 15),\n machine: {\n hostname: os.hostname(),\n platform: os.platform(),\n arch: os.arch(),\n cpus: os.cpus().length,\n totalMem: memSnap.totalMem,\n freeMem: memSnap.freeMem,\n availableMem: memSnap.availableMem,\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 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 defaultWorkspaceId: wsState.defaultWorkspaceId,\n workspaceCount: (wsState.workspaces || []).length,\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 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, availableMem: _a, 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 * 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 '../detection/cli-detector.js';\nimport { loadConfig, saveConfig, addCliHistory } from '../config/config.js';\nimport { getWorkspaceState, resolveLaunchDirectory } from '../config/workspaces.js';\nimport { appendWorkspaceActivity } from '../config/workspace-activity.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';\nimport { LOG } from '../logging/logger.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 persistRecentDir(cliType: string, dir: string): void {\n try {\n const normalizedType = this.providerLoader.resolveAlias(cliType);\n const provider = this.providerLoader.getByAlias(cliType);\n const actKind = provider?.category === 'acp' ? 'acp' : 'cli';\n let next = loadConfig();\n console.log(chalk.cyan(` 📂 Saving recent workspace: ${dir}`));\n const recent = next.recentCliWorkspaces || [];\n if (!recent.includes(dir)) {\n next = { ...next, recentCliWorkspaces: [dir, ...recent].slice(0, 10) };\n }\n next = appendWorkspaceActivity(next, dir, { kind: actKind, agentType: normalizedType });\n saveConfig(next);\n console.log(chalk.green(` ✓ Recent workspace saved: ${dir}`));\n } catch (e) {\n console.error(chalk.red(` ✗ Failed to save recent workspace: ${e}`));\n }\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.getMeta(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 || '').trim();\n if (!trimmed) throw new Error('working directory required');\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 LOG.warn('CLI', `[ACP] Initial model set failed: ${e?.message}`);\n }\n }\n\n try { addCliHistory({ cliType: normalizedType, dir: resolvedDir, cliArgs }); } catch (e) { LOG.warn('CLI', `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 try {\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 } catch (spawnErr: any) {\n // Spawn failed — cleanup and propagate error\n LOG.error('CLI', `[${cliType}] Spawn failed: ${spawnErr?.message}`);\n instanceManager.removeInstance(key);\n throw new Error(`Failed to start ${cliInfo.displayName}: ${spawnErr?.message}`);\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\n // Monitor for stopped/error → auto-cleanup\n const checkStopped = setInterval(() => {\n try {\n const adapter = this.adapters.get(key);\n if (!adapter) { clearInterval(checkStopped); return; }\n const status = adapter.getStatus?.();\n if (status?.status === 'stopped' || status?.status === 'error') {\n clearInterval(checkStopped);\n setTimeout(() => {\n if (this.adapters.has(key)) {\n this.adapters.delete(key);\n this.deps.removeAgentTracking(key);\n instanceManager.removeInstance(key);\n LOG.info('CLI', `🧹 Auto-cleaned ${status.status} CLI: ${cliType}`);\n this.deps.onStatusChange();\n }\n }, 5000);\n }\n } catch { /* ignore */ }\n }, 3000);\n } else {\n // Fallback: InstanceManager without directly adapter manage\n const adapter = this.createAdapter(cliType, resolvedDir, cliArgs);\n try {\n await adapter.spawn();\n } catch (spawnErr: any) {\n LOG.error('CLI', `[${cliType}] Spawn failed: ${spawnErr?.message}`);\n throw new Error(`Failed to start ${cliInfo.displayName}: ${spawnErr?.message}`);\n }\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' || status?.status === 'error') {\n setTimeout(() => {\n if (this.adapters.get(key) === adapter) {\n this.adapters.delete(key);\n this.deps.removeAgentTracking(key);\n LOG.info('CLI', `🧹 Auto-cleaned ${status.status} 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) { LOG.warn('CLI', `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 try {\n adapter.shutdown();\n } catch (e: any) {\n LOG.warn('CLI', `Shutdown error for ${adapter.cliType}: ${e?.message} (force-cleaning)`);\n }\n // Always cleanup regardless of shutdown success\n this.adapters.delete(key);\n this.deps.removeAgentTracking(key);\n this.deps.getInstanceManager()?.removeInstance(key);\n LOG.info('CLI', `🛑 Agent stopped: ${adapter.cliType} in ${adapter.workingDir}`);\n this.deps.onStatusChange();\n } else {\n // Adapter not found — try InstanceManager direct removal\n const im = this.deps.getInstanceManager();\n if (im) {\n im.removeInstance(key);\n this.deps.removeAgentTracking(key);\n LOG.warn('CLI', `🧹 Force-removed orphan entry: ${key}`);\n this.deps.onStatusChange();\n }\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 config = loadConfig();\n const resolved = resolveLaunchDirectory(\n {\n dir: args?.dir,\n workspaceId: args?.workspaceId,\n useDefaultWorkspace: args?.useDefaultWorkspace === true,\n useHome: args?.useHome === true,\n },\n config,\n );\n if (!resolved.ok) {\n const ws = getWorkspaceState(config);\n return {\n success: false,\n error: resolved.message,\n code: resolved.code,\n workspaces: ws.workspaces,\n defaultWorkspacePath: ws.defaultWorkspacePath,\n };\n }\n const dir = resolved.path;\n const launchSource = resolved.source;\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 this.persistRecentDir(cliType, dir);\n\n return { success: true, cliType, dir, id: newKey, launchSource };\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 cfg = loadConfig();\n const rdir = resolveLaunchDirectory(\n {\n dir: args?.dir,\n workspaceId: args?.workspaceId,\n useDefaultWorkspace: args?.useDefaultWorkspace === true,\n useHome: args?.useHome === true,\n },\n cfg,\n );\n if (!rdir.ok) {\n const ws = getWorkspaceState(cfg);\n return {\n success: false,\n error: rdir.message,\n code: rdir.code,\n workspaces: ws.workspaces,\n defaultWorkspacePath: ws.defaultWorkspacePath,\n };\n }\n const dir = rdir.path;\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 this.persistRecentDir(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 * as path from 'path';\nimport { execSync } from 'child_process';\nimport type { CliAdapter } from '../cli-adapter-types.js';\nimport { LOG } from '../logging/logger.js';\n\nlet pty: any;\ntry {\n pty = require('node-pty');\n // node-pty@1.1.0 ships spawn-helper without +x on macOS — fix it\n if (os.platform() !== 'win32') {\n try {\n const fs = require('fs');\n const ptyDir = path.dirname(require.resolve('node-pty'));\n const arch = os.arch() === 'arm64' ? 'darwin-arm64' : 'darwin-x64';\n const helper = path.join(ptyDir, 'prebuilds', arch, 'spawn-helper');\n if (fs.existsSync(helper)) {\n const stat = fs.statSync(helper);\n if (!(stat.mode & 0o111)) {\n fs.chmodSync(helper, stat.mode | 0o755);\n LOG.info('CLI', '[node-pty] Fixed spawn-helper permissions');\n }\n }\n } catch { /* best-effort */ }\n }\n} catch {\n LOG.error('CLI', '[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\n/** True if file starts with a UTF-8 BOM then #!, or plain #!. */\nfunction isScriptBinary(binaryPath: string): boolean {\n if (!path.isAbsolute(binaryPath)) return false;\n try {\n const fs = require('fs');\n const resolved = fs.realpathSync(binaryPath);\n const head = Buffer.alloc(8);\n const fd = fs.openSync(resolved, 'r');\n fs.readSync(fd, head, 0, 8, 0);\n fs.closeSync(fd);\n let i = 0;\n if (head[0] === 0xef && head[1] === 0xbb && head[2] === 0xbf) i = 3;\n return head[i] === 0x23 && head[i + 1] === 0x21; // '#!'\n } catch {\n return false;\n }\n}\n\n/** True only for Mach-O / ELF — npm shims and shell scripts return false. */\nfunction looksLikeMachOOrElf(filePath: string): boolean {\n if (!path.isAbsolute(filePath)) return false;\n try {\n const fs = require('fs');\n const resolved = fs.realpathSync(filePath);\n const buf = Buffer.alloc(8);\n const fd = fs.openSync(resolved, 'r');\n fs.readSync(fd, buf, 0, 8, 0);\n fs.closeSync(fd);\n let i = 0;\n if (buf[0] === 0xef && buf[1] === 0xbb && buf[2] === 0xbf) i = 3;\n const b = buf.subarray(i);\n if (b.length < 4) return false;\n // ELF\n if (b[0] === 0x7f && b[1] === 0x45 && b[2] === 0x4c && b[3] === 0x46) return true;\n const le = b.readUInt32LE(0);\n const be = b.readUInt32BE(0);\n const magics = [0xfeedface, 0xfeedfacf, 0xcafebabe, 0xbebafeca];\n return magics.some(m => m === le || m === be);\n } catch {\n return false;\n }\n}\n\nfunction shSingleQuote(arg: string): string {\n if (/^[a-zA-Z0-9@%_+=:,./-]+$/.test(arg)) return arg;\n return `'${arg.replace(/'/g, `'\\\\''`)}'`;\n}\n\n/**\n * provider.json stores regex placeholders as `{}` — JSON.parse leaves plain objects,\n * so `.test` is missing and the PTY handler throws on first output. Coerce to RegExp\n * (including `{ \"source\": \"...\", \"flags\": \"i\" }`) or fall back to generic TUIs (Claude Code, etc.).\n */\nfunction parsePatternEntry(x: unknown): RegExp | null {\n if (x instanceof RegExp) return x;\n if (x && typeof x === 'object' && typeof (x as { source?: string }).source === 'string') {\n try {\n const s = x as { source: string; flags?: string };\n return new RegExp(s.source, s.flags || '');\n } catch {\n return null;\n }\n }\n return null;\n}\n\nfunction coercePatternArray(raw: unknown, fallbacks: RegExp[]): RegExp[] {\n if (!Array.isArray(raw)) return [...fallbacks];\n const parsed = raw.map(parsePatternEntry).filter((r): r is RegExp => r != null);\n return parsed.length > 0 ? parsed : [...fallbacks];\n}\n\n/** Defaults tuned for Claude Code / similar agent CLIs when provider.json patterns are empty. */\nconst FALLBACK_PROMPT: RegExp[] = [\n /Type your message/i,\n /^>\\s*$/m, // '>' alone on its own line\n /[›❯]\\s*[\\r\\n]/, // prompt char followed by line ending (ANSI-stripped may not have $ at end)\n /[›❯]\\s*$/m, // prompt char at end of line (multiline)\n /for\\s*shortcuts/i, // Claude Code prompt (ANSI strip may remove spaces → 'forshortcuts')\n /\\?\\s*for\\s*help/i,\n /Press enter/i,\n];\n\nconst FALLBACK_GENERATING: RegExp[] = [\n /[\\u2800-\\u28ff]/, // Braille spinner blocks (universal TUI)\n /esc to (cancel|interrupt|stop)/i, // Common TUI generation status line\n /generating\\.\\.\\./i,\n /Claude is (?:thinking|processing|working)/i, // Specific Claude Code status\n];\n\nconst FALLBACK_APPROVAL: RegExp[] = [\n /Allow\\s*once/i, // ANSI strip may remove spaces\n /Always\\s*allow/i,\n /\\(y\\/n\\)/i,\n /\\[Y\\/n\\]/i,\n /Run\\s*this\\s*command/i,\n /Allow\\s*tool/i, // Claude Code v2 approval\n /Yes,?\\s*don'?t\\s*ask/i, // \"Yes, don't ask again\" (Claude Code)\n /Deny/i, // Deny button presence = approval dialog\n];\n\nfunction defaultCleanOutput(raw: string, _lastUserInput?: string): string {\n return stripAnsi(raw).trim();\n}\n\nexport function normalizeCliProviderForRuntime(raw: any): CliProviderModule {\n const patterns = raw?.patterns || {};\n return {\n ...raw,\n patterns: {\n prompt: coercePatternArray(patterns.prompt, FALLBACK_PROMPT),\n generating: coercePatternArray(patterns.generating, FALLBACK_GENERATING),\n approval: coercePatternArray(patterns.approval, FALLBACK_APPROVAL),\n ready: coercePatternArray(patterns.ready, []),\n },\n cleanOutput: typeof raw?.cleanOutput === 'function' ? raw.cleanOutput : defaultCleanOutput,\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 // Approval state machine\n private approvalTransitionBuffer: string = '';\n private approvalExitTimeout: NodeJS.Timeout | null = null;\n\n // Resize redraw suppression\n private resizeSuppressUntil: number = 0;\n\n // Debug: status transition history\n private statusHistory: { status: string; at: number; trigger?: string }[] = [];\n\n private setStatus(status: CliSessionStatus['status'], trigger?: string): void {\n const prev = this.currentStatus;\n if (prev === status) return;\n this.currentStatus = status;\n this.statusHistory.push({ status, at: Date.now(), trigger });\n if (this.statusHistory.length > 50) this.statusHistory.shift();\n LOG.info('CLI', `[${this.cliType}] status: ${prev} → ${status}${trigger ? ` (${trigger})` : ''}`);\n }\n\n // Resolved timeouts (provider defaults + overrides)\n private readonly timeouts: Required<NonNullable<CliProviderModule['timeouts']>>;\n\n // Provider approval key mapping (e.g. { 0: '1', 1: '2', 2: '3' }) — loaded from provider.json\n private readonly approvalKeys: Record<number, string>;\n\n constructor(provider: CliProviderModule, workingDir: string, private extraArgs: string[] = []) {\n this.provider = normalizeCliProviderForRuntime(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 // Load approval key mapping from provider (e.g. approvalKeys: {\"0\":\"1\",\"1\":\"2\",\"2\":\"3\"})\n const rawKeys = (provider as any).approvalKeys;\n this.approvalKeys = (rawKeys && typeof rawKeys === 'object') ? rawKeys : {};\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 LOG.info('CLI', `[${this.cliType}] Spawning in ${this.workingDir}`);\n\n let shellCmd: string;\n let shellArgs: string[];\n const useShellUnix = !isWin && (\n !!spawnConfig.shell\n || !path.isAbsolute(binaryPath)\n || isScriptBinary(binaryPath)\n || !looksLikeMachOOrElf(binaryPath)\n );\n const useShell = isWin ? !!spawnConfig.shell : useShellUnix;\n\n if (useShell) {\n // Execute via shell (npm shims, shebang scripts, anything that is not a bare Mach-O/ELF)\n if (!spawnConfig.shell && !isWin) {\n LOG.info('CLI', `[${this.cliType}] Using login shell (script shim or non-native binary)`);\n }\n shellCmd = isWin ? 'cmd.exe' : (process.env.SHELL || '/bin/zsh');\n const fullCmd = [binaryPath, ...allArgs].map(shSingleQuote).join(' ');\n shellArgs = isWin ? ['/c', fullCmd] : ['-l', '-c', fullCmd];\n } else {\n shellCmd = binaryPath;\n shellArgs = allArgs;\n }\n\n const ptyOpts = {\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 try {\n this.ptyProcess = pty.spawn(shellCmd, shellArgs, ptyOpts);\n } catch (err: any) {\n const msg = err?.message || String(err);\n if (!isWin && !useShell && /posix_spawn|spawn/i.test(msg)) {\n LOG.warn('CLI', `[${this.cliType}] Direct spawn failed (${msg}), retrying via login shell`);\n shellCmd = process.env.SHELL || '/bin/zsh';\n const fullCmd = [binaryPath, ...allArgs].map(shSingleQuote).join(' ');\n shellArgs = ['-l', '-c', fullCmd];\n this.ptyProcess = pty.spawn(shellCmd, shellArgs, ptyOpts);\n } else {\n throw err;\n }\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 LOG.info('CLI', `[${this.cliType}] Exit code ${exitCode}`);\n this.ptyProcess = null;\n this.setStatus('stopped', 'pty_exit');\n this.ready = false;\n this.onStatusChange?.();\n });\n\n this.setStatus('starting', 'spawn');\n this.onStatusChange?.();\n }\n\n // ─── Output state machine ────────────────────────────\n\n private handleOutput(rawData: string): void {\n // Suppress output processing briefly after resize to avoid false triggers from screen redraws\n if (Date.now() < this.resizeSuppressUntil) return;\n\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 LOG.info('CLI', `[${this.cliType}] startup chunk (${cleanData.length} chars): ${cleanData.slice(0, 200).replace(/\\n/g, '\\\\n')}`);\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 /Quick safety check/i,\n /Is this a project/i,\n /Enter to confirm/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.setStatus('idle', 'prompt_matched');\n LOG.info('CLI', `[${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 // Capture context before clearing (recentOutputBuffer still has content here)\n const ctxLines = this.recentOutputBuffer.split('\\n')\n .map(l => l.trim())\n .filter(l => l && !/^[─═╭╮╰╯│]+$/.test(l));\n this.isWaitingForResponse = true;\n this.setStatus('waiting_approval', 'approval_pattern');\n this.recentOutputBuffer = '';\n this.approvalTransitionBuffer = '';\n this.activeModal = {\n message: ctxLines.slice(-5).join(' ').slice(0, 200) || 'Approval required',\n buttons: this.cliType === 'claude-cli'\n ? ['Yes (y)', 'Always allow (a)', 'Deny (Esc)']\n : ['Allow once', 'Always allow', 'Deny'],\n };\n if (this.idleTimeout) clearTimeout(this.idleTimeout);\n // Safety timeout — if stuck in waiting_approval, auto-exit after 60s\n if (this.approvalExitTimeout) clearTimeout(this.approvalExitTimeout);\n this.approvalExitTimeout = setTimeout(() => {\n if (this.currentStatus === 'waiting_approval') {\n LOG.warn('CLI', `[${this.cliType}] Approval timeout — auto-exiting waiting_approval`);\n this.activeModal = null;\n this.lastApprovalResolvedAt = Date.now();\n this.recentOutputBuffer = '';\n this.approvalTransitionBuffer = '';\n this.approvalExitTimeout = null;\n this.setStatus(this.isWaitingForResponse ? 'generating' : 'idle', 'approval_cleared');\n this.onStatusChange?.();\n }\n }, 60000);\n this.onStatusChange?.();\n return;\n }\n\n // ─── Phase 3: Approval release\n // Accumulate chunks into approvalTransitionBuffer — the approval dialog clears via ANSI\n // sequences that strip to nothing, so we can't rely on a single cleanData chunk matching.\n if (this.currentStatus === 'waiting_approval') {\n this.approvalTransitionBuffer = (this.approvalTransitionBuffer + cleanData).slice(-500);\n const genResume = patterns.generating.some(p => p.test(this.approvalTransitionBuffer));\n const promptResume = patterns.prompt.some(p => p.test(this.approvalTransitionBuffer));\n if (genResume) {\n if (this.approvalExitTimeout) { clearTimeout(this.approvalExitTimeout); this.approvalExitTimeout = null; }\n this.setStatus('generating', 'approval_gen_resume');\n this.activeModal = null;\n this.recentOutputBuffer = '';\n this.approvalTransitionBuffer = '';\n this.lastApprovalResolvedAt = Date.now();\n this.onStatusChange?.();\n } else if (promptResume) {\n if (this.approvalExitTimeout) { clearTimeout(this.approvalExitTimeout); this.approvalExitTimeout = null; }\n this.activeModal = null;\n this.recentOutputBuffer = '';\n this.approvalTransitionBuffer = '';\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.setStatus('generating', 'autonomous_gen');\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.setStatus('generating', 'still_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 // Only check the LAST 2 lines of cleanData — the prompt appears at the very end of the\n // output stream. Checking the full chunk causes false positives when response content\n // has '>' in code blocks, shell examples, or mid-response lines.\n const trailingLines = cleanData.split('\\n').slice(-2).join('\\n');\n if (patterns.prompt.some(p => p.test(trailingLines))) {\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 if (this.approvalExitTimeout) { clearTimeout(this.approvalExitTimeout); this.approvalExitTimeout = 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 LOG.info('CLI', `[${this.cliType}] Response (${response.length} chars)`);\n }\n\n this.responseBuffer = '';\n this.isWaitingForResponse = false;\n this.activeModal = null;\n this.setStatus('idle', 'response_finished');\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.setStatus('generating', 'sendMessage');\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.approvalExitTimeout) { clearTimeout(this.approvalExitTimeout); this.approvalExitTimeout = null; }\n if (this.ptyProcess) {\n this.ptyProcess.write('\\x03');\n setTimeout(() => {\n try { this.ptyProcess?.kill(); } catch { }\n this.ptyProcess = null;\n this.setStatus('stopped', 'stop_cmd');\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 /**\n * Resolve an approval modal by navigating to the button at `buttonIndex` and pressing Enter.\n * Index 0 = first option (already selected by default — just Enter).\n * Index N = press Arrow Down N times, then Enter.\n */\n resolveModal(buttonIndex: number): void {\n if (!this.ptyProcess || this.currentStatus !== 'waiting_approval') return;\n // Use provider-defined approval keys if available\n // Each provider.json can define: { \"approvalKeys\": { \"0\": \"1\", \"1\": \"2\", \"2\": \"3\" } }\n if (buttonIndex in this.approvalKeys) {\n this.ptyProcess.write(this.approvalKeys[buttonIndex]);\n } else {\n // Generic fallback: Arrow Down to navigate + Enter to select\n const DOWN = '\\x1B[B';\n const keys = DOWN.repeat(Math.max(0, buttonIndex)) + '\\r';\n this.ptyProcess.write(keys);\n }\n }\n\n resize(cols: number, rows: number): void {\n if (this.ptyProcess) {\n try {\n this.ptyProcess.resize(cols, rows);\n // Suppress output for 300ms after resize — PTY redraws the screen and\n // the redrawn content (spinners, status text) would falsely trigger generating detection\n this.resizeSuppressUntil = Date.now() + 300;\n } catch { }\n }\n }\n\n /**\n * Full debug state — exposes all internal buffers, status, and patterns for debugging.\n * Used by DevServer /api/cli/debug endpoint.\n */\n getDebugState(): Record<string, any> {\n return {\n type: this.cliType,\n name: this.cliName,\n status: this.currentStatus,\n ready: this.ready,\n workingDir: this.workingDir,\n messages: this.messages.slice(-20),\n messageCount: this.messages.length,\n // Buffers\n startupBuffer: this.startupBuffer.slice(-500),\n recentOutputBuffer: this.recentOutputBuffer.slice(-500),\n responseBuffer: this.responseBuffer.slice(-500),\n approvalTransitionBuffer: this.approvalTransitionBuffer.slice(-500),\n // State\n isWaitingForResponse: this.isWaitingForResponse,\n activeModal: this.activeModal,\n lastApprovalResolvedAt: this.lastApprovalResolvedAt,\n resizeSuppressUntil: this.resizeSuppressUntil,\n // Provider patterns (serialized)\n patterns: {\n prompt: this.provider.patterns.prompt.map(p => p.toString()),\n generating: this.provider.patterns.generating.map(p => p.toString()),\n approval: this.provider.patterns.approval.map(p => p.toString()),\n ready: this.provider.patterns.ready.map(p => p.toString()),\n },\n // Status history\n statusHistory: this.statusHistory.slice(-30),\n // Timeouts config\n timeouts: this.timeouts,\n // PTY alive\n ptyAlive: !!this.ptyProcess,\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 '../config/chat-history.js';\nimport { LOG } from '../logging/logger.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 generatingDebounceTimer: NodeJS.Timeout | null = null;\n private generatingDebouncePending: { chatTitle: string; timestamp: number } | null = null;\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 workspace: 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 LOG.info('CLI', `[${this.type}] status: ${this.lastStatus} → ${newStatus}`);\n if (this.lastStatus === 'idle' && newStatus === 'generating') {\n this.generatingStartedAt = now;\n // Defer the generating_started event — if idle comes back within 1s,\n // the whole started→completed pair was a false positive from PTY noise\n if (this.generatingDebounceTimer) clearTimeout(this.generatingDebounceTimer);\n this.generatingDebouncePending = { chatTitle, timestamp: now };\n this.generatingDebounceTimer = setTimeout(() => {\n if (this.generatingDebouncePending) {\n this.pushEvent({ event: 'agent:generating_started', ...this.generatingDebouncePending });\n this.generatingDebouncePending = null;\n }\n this.generatingDebounceTimer = null;\n }, 1000);\n } else if (newStatus === 'waiting_approval') {\n // Flush pending generating_started if debounce still pending\n if (this.generatingDebouncePending) {\n if (this.generatingDebounceTimer) { clearTimeout(this.generatingDebounceTimer); this.generatingDebounceTimer = null; }\n this.pushEvent({ event: 'agent:generating_started', ...this.generatingDebouncePending });\n this.generatingDebouncePending = null;\n }\n if (!this.generatingStartedAt) this.generatingStartedAt = now;\n const modal = adapterStatus.activeModal;\n LOG.info('CLI', `[${this.type}] approval modal: \"${modal?.message?.slice(0, 80) ?? 'none'}\"`);\n this.pushEvent({\n event: 'agent:waiting_approval', chatTitle, timestamp: now,\n modalMessage: modal?.message,\n modalButtons: modal?.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 // If debounce still pending (generating lasted < 1s), cancel both events\n if (this.generatingDebouncePending) {\n LOG.info('CLI', `[${this.type}] suppressed short generating (${now - this.generatingStartedAt}ms)`);\n if (this.generatingDebounceTimer) { clearTimeout(this.generatingDebounceTimer); this.generatingDebounceTimer = null; }\n this.generatingDebouncePending = null;\n } else {\n LOG.info('CLI', `[${this.type}] completed in ${duration}s`);\n this.pushEvent({ event: 'agent:generating_completed', chatTitle, duration, timestamp: now });\n }\n this.generatingStartedAt = 0;\n } else if (newStatus === 'stopped') {\n // Cancel any pending debounce\n if (this.generatingDebounceTimer) { clearTimeout(this.generatingDebounceTimer); this.generatingDebounceTimer = null; }\n this.generatingDebouncePending = null;\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 * AcpProviderInstance — ACP (Agent Client Protocol) Provider runtime instance\n *\n * Spawns ACP agent process and communicates via the official ACP SDK.\n * Uses ClientSideConnection + ndJsonStream for structured protocol communication.\n *\n * ACP spec: https://agentclientprotocol.com\n * ACP SDK: @agentclientprotocol/sdk@0.16.1\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 { Readable, Writable } from 'stream';\nimport { spawn, type ChildProcess } from 'child_process';\nimport {\n ClientSideConnection,\n ndJsonStream,\n RequestError,\n PROTOCOL_VERSION,\n type Client,\n type Agent,\n type SessionNotification,\n type RequestPermissionRequest,\n type RequestPermissionResponse,\n type WriteTextFileRequest,\n type WriteTextFileResponse,\n type ReadTextFileRequest,\n type ReadTextFileResponse,\n type CreateTerminalRequest,\n type CreateTerminalResponse,\n type TerminalOutputRequest,\n type TerminalOutputResponse,\n type ReleaseTerminalRequest,\n type ReleaseTerminalResponse,\n type WaitForTerminalExitRequest,\n type WaitForTerminalExitResponse,\n type KillTerminalRequest,\n type KillTerminalResponse,\n type SessionUpdate,\n type ToolCallStatus,\n type SessionConfigOption,\n} from '@agentclientprotocol/sdk';\nimport type { ProviderModule, ContentBlock, ToolCallInfo, ToolCallContent as TCC, ToolKind, ToolCallStatus as TCS } from './contracts.js';\nimport { normalizeContent, flattenContent } from './contracts.js';\nimport type { ProviderInstance, ProviderState, AcpProviderState, ProviderErrorReason, ProviderEvent, InstanceContext } from './provider-instance.js';\nimport { StatusMonitor } from './status-monitor.js';\nimport { LOG } from '../logging/logger.js';\n\n// ─── Internal Display Types (dashboard용) ────────────────────────────\n\ninterface AcpMessage {\n role: 'user' | 'assistant' | 'system';\n /** Rich content blocks (ACP standard) or plain text (legacy) */\n content: string | ContentBlock[];\n timestamp?: number;\n /** Tool calls associated with this message */\n toolCalls?: ToolCallInfo[];\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 private readonly log = LOG.forComponent('ACP');\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 connection: ClientSideConnection | null = null;\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 /** Rich content blocks accumulated during streaming */\n private partialBlocks: ContentBlock[] = [];\n /** Tool calls collected during current turn */\n private turnToolCalls: ToolCallInfo[] = [];\n\n // Error tracking\n private errorMessage: string | null = null;\n private errorReason: ProviderErrorReason | 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(): AcpProviderState {\n const dirName = this.workingDir.split('/').filter(Boolean).pop() || 'session';\n\n // Recent 50 messages\n const recentMessages = this.messages.slice(-50).map(m => {\n const content = this.truncateContent(m.content);\n return {\n role: m.role,\n content,\n timestamp: m.timestamp,\n toolCalls: m.toolCalls,\n };\n });\n\n // generating during partial response add\n if (this.currentStatus === 'generating' && (this.partialContent || this.partialBlocks.length > 0)) {\n const blocks = this.buildPartialBlocks();\n if (blocks.length > 0) {\n recentMessages.push({\n role: 'assistant',\n content: blocks,\n timestamp: Date.now(),\n toolCalls: this.turnToolCalls.length > 0 ? [...this.turnToolCalls] : undefined,\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 workspace: 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 || undefined,\n errorReason: this.errorReason || undefined,\n };\n }\n\n onEvent(event: string, data?: any): void {\n if (event === 'send_message' && data?.text) {\n this.sendPrompt(data.text).catch(e =>\n this.log.warn(`[${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 => this.log.warn(`[${this.type}] resolvePermission error: ${e?.message}`));\n } else if (event === 'cancel') {\n this.cancelSession().catch(e =>\n this.log.warn(`[${this.type}] cancel error: ${e?.message}`)\n );\n } else if (event === 'change_model' && data?.model) {\n this.setConfigOption('model', data.model).catch(e =>\n this.log.warn(`[${this.type}] change_model error: ${e?.message}`)\n );\n } else if (event === 'set_mode' && data?.mode) {\n this.setMode(data.mode).catch(e =>\n this.log.warn(`[${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 this.log.warn(`[${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 'model' | 'mode' | 'thought_level' | 'other', 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 this.log.warn(`[${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 this.log.info(`[${this.type}] Static config ${category} set to: ${value} — restarting agent`);\n await this.restartWithNewConfig();\n return;\n }\n\n if (!this.connection || !this.sessionId) {\n this.log.warn(`[${this.type}] Cannot set config: no active connection/session`);\n return;\n }\n\n try {\n this.log.info(`[${this.type}] Sending session/set_config_option: configId=${opt.configId} value=${value} sessionId=${this.sessionId}`);\n const result = await this.connection.setSessionConfigOption({\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 this.log.info(`[${this.type}] Config ${category} set to: ${value} | response: ${JSON.stringify(result)?.slice(0, 300)}`);\n } catch (e: any) {\n this.log.warn(`[${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 this.log.info(`[${this.type}] Static mode set to: ${modeId} — restarting agent`);\n await this.restartWithNewConfig();\n return;\n }\n\n if (!this.connection || !this.sessionId) {\n this.log.warn(`[${this.type}] Cannot set mode: no active connection/session`);\n return;\n }\n\n try {\n await this.connection.setSessionMode({\n sessionId: this.sessionId,\n modeId,\n });\n this.currentMode = modeId;\n this.log.info(`[${this.type}] Mode set to: ${modeId}`);\n } catch (e: any) {\n this.log.warn(`[${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 this.connection = null;\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 /** Update settings at runtime (called when user changes settings from dashboard) */\n updateSettings(newSettings: Record<string, any>): void {\n this.settings = { ...this.settings, ...newSettings };\n this.monitor.updateConfig({\n approvalAlert: this.settings.approvalAlert !== false,\n longGeneratingAlert: this.settings.longGeneratingAlert !== false,\n longGeneratingThresholdSec: this.settings.longGeneratingThresholdSec || 180,\n });\n this.log.info(`[${this.type}] Settings updated: ${Object.keys(newSettings).join(', ')}`);\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 this.connection = null;\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 this.log.info(`[${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 // 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 this.log.debug(`[${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.install || 'check documentation'}`;\n } else {\n this.errorReason = 'auth_failed';\n this.errorMessage = text.slice(0, 300);\n }\n this.log.warn(`[${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 this.log.info(`[${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.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 this.log.error(`[${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.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 // ─── SDK Connection Setup ────────────────────────\n // Convert Node.js streams to Web Streams for ndJsonStream\n const webStdin = Writable.toWeb(this.process.stdin!) as WritableStream<Uint8Array>;\n const webStdout = Readable.toWeb(this.process.stdout!) as ReadableStream<Uint8Array>;\n const stream = ndJsonStream(webStdin, webStdout);\n\n // Create ClientSideConnection with our Client implementation\n this.connection = new ClientSideConnection((_agent: Agent) => this.createClient(), stream);\n\n // Listen for connection close\n this.connection.signal.addEventListener('abort', () => {\n this.log.info(`[${this.type}] ACP connection closed`);\n });\n\n // ACP initialize handshake\n await this.initialize();\n }\n\n // ─── Client Interface Implementation ────────────────────\n\n private createClient(): Client {\n return {\n requestPermission: async (params: RequestPermissionRequest): Promise<RequestPermissionResponse> => {\n // Update active tool calls from the request\n const tc = params.toolCall;\n const existing = this.activeToolCalls.find(t => t.id === tc.toolCallId);\n if (existing) {\n existing.status = 'running';\n if (tc.title) existing.name = tc.title;\n } else {\n this.activeToolCalls.push({\n id: tc.toolCallId,\n name: tc.title || 'unknown',\n status: 'running',\n input: tc.rawInput ? (typeof tc.rawInput === 'string' ? tc.rawInput : JSON.stringify(tc.rawInput)) : undefined,\n });\n }\n\n // ─── Auto-approve: skip user confirmation ───\n if (this.settings.autoApprove) {\n this.log.info(`[${this.type}] Auto-approving: ${tc.title || tc.toolCallId}`);\n const allowOption = params.options.find(o => o.kind === 'allow_once') || params.options.find(o => o.kind === 'allow_always');\n if (allowOption) {\n return { outcome: { outcome: 'selected', optionId: allowOption.optionId } };\n }\n return { outcome: { outcome: 'selected', optionId: params.options[0]?.optionId || '' } };\n }\n\n // Approval request → switch to waiting_approval status\n this.currentStatus = 'waiting_approval';\n this.detectStatusTransition();\n\n // Wait for user approval\n const approved = await new Promise<boolean>((resolve) => {\n this.permissionResolvers.push(resolve);\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 if (approved) {\n // Find the \"allow\" option (allow_once or allow_always)\n const allowOption = params.options.find(o => o.kind === 'allow_once') || params.options.find(o => o.kind === 'allow_always');\n if (allowOption) {\n return { outcome: { outcome: 'selected', optionId: allowOption.optionId } };\n }\n // Fallback: use first option\n return { outcome: { outcome: 'selected', optionId: params.options[0]?.optionId || '' } };\n } else {\n // Find the \"reject\" option\n const rejectOption = params.options.find(o => o.kind === 'reject_once') || params.options.find(o => o.kind === 'reject_always');\n if (rejectOption) {\n return { outcome: { outcome: 'selected', optionId: rejectOption.optionId } };\n }\n return { outcome: { outcome: 'cancelled' } };\n }\n },\n\n sessionUpdate: async (params: SessionNotification): Promise<void> => {\n this.handleSessionUpdate(params);\n },\n\n // File system — not supported\n readTextFile: async (_params: ReadTextFileRequest): Promise<ReadTextFileResponse> => {\n throw RequestError.methodNotFound('fs/read_text_file');\n },\n writeTextFile: async (_params: WriteTextFileRequest): Promise<WriteTextFileResponse> => {\n throw RequestError.methodNotFound('fs/write_text_file');\n },\n\n // Terminal — not supported\n createTerminal: async (_params: CreateTerminalRequest): Promise<CreateTerminalResponse> => {\n throw RequestError.methodNotFound('terminal/create');\n },\n terminalOutput: async (_params: TerminalOutputRequest): Promise<TerminalOutputResponse> => {\n throw RequestError.methodNotFound('terminal/output');\n },\n releaseTerminal: async (_params: ReleaseTerminalRequest): Promise<ReleaseTerminalResponse> => {\n throw RequestError.methodNotFound('terminal/release');\n },\n waitForTerminalExit: async (_params: WaitForTerminalExitRequest): Promise<WaitForTerminalExitResponse> => {\n throw RequestError.methodNotFound('terminal/wait_for_exit');\n },\n killTerminal: async (_params: KillTerminalRequest): Promise<KillTerminalResponse> => {\n throw RequestError.methodNotFound('terminal/kill');\n },\n };\n }\n\n // ─── ACP Protocol (via SDK) ────────────────────────────\n\n private async initialize(): Promise<void> {\n if (!this.connection) return;\n\n try {\n const result = await this.connection.initialize({\n protocolVersion: PROTOCOL_VERSION,\n clientCapabilities: {},\n });\n\n this.agentCapabilities = result?.agentCapabilities || {};\n this.log.info(`[${this.type}] Initialized. Agent capabilities: ${JSON.stringify(this.agentCapabilities)}`);\n\n // new session create\n await this.createSession();\n } catch (e: any) {\n this.log.error(`[${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 if (!this.connection) return;\n\n try {\n const result = await this.connection.newSession({\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 this.log.info(`[${this.type}] session/new result keys: ${result ? Object.keys(result).join(', ') : 'null'}`);\n if (result?.configOptions) this.log.debug(`[${this.type}] configOptions: ${JSON.stringify(result.configOptions).slice(0, 500)}`);\n if (result?.modes) this.log.debug(`[${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 this.log.info(`[${this.type}] Using static configOptions (${this.configOptions.length} options)`);\n }\n\n this.log.info(`[${this.type}] Session created: ${this.sessionId}${this.currentModel ? ` (model: ${this.currentModel})` : ''}${this.currentMode ? ` (mode: ${this.currentMode})` : ''}`);\n if (this.configOptions.length > 0) {\n this.log.info(`[${this.type}] Config options: ${this.configOptions.map(c => `${c.category}(${c.options.length})`).join(', ')}`);\n }\n } catch (e: any) {\n this.log.warn(`[${this.type}] session/new failed: ${e?.message}`);\n this.currentStatus = 'idle';\n }\n }\n\n async sendPrompt(text: string, contentBlocks?: ContentBlock[]): Promise<void> {\n if (!this.connection || !this.sessionId) {\n this.log.warn(`[${this.type}] Cannot send prompt: no active connection/session`);\n return;\n }\n\n // Build prompt content\n let promptParts: any[];\n if (contentBlocks && contentBlocks.length > 0) {\n // Rich content — forward ContentBlock[] as ACP prompt parts\n promptParts = contentBlocks.map(b => {\n if (b.type === 'text') return { type: 'text', text: b.text };\n if (b.type === 'image') return { type: 'image', data: b.data, mimeType: b.mimeType };\n if (b.type === 'resource_link') return { type: 'resource_link', uri: b.uri, name: b.name };\n if (b.type === 'resource') return { type: 'resource', resource: b.resource };\n return { type: 'text', text: flattenContent([b]) };\n });\n } else {\n promptParts = [{ type: 'text', text }];\n }\n\n // Add user message locally (store as ContentBlock[])\n this.messages.push({\n role: 'user',\n content: contentBlocks && contentBlocks.length > 0 ? contentBlocks : text,\n timestamp: Date.now(),\n });\n\n this.currentStatus = 'generating';\n this.partialContent = '';\n this.partialBlocks = [];\n this.turnToolCalls = [];\n this.detectStatusTransition();\n this.log.info(`[${this.type}] Sending prompt: \"${text.slice(0, 100)}\" (${promptParts.length} parts)`);\n\n try {\n const result = await this.connection.prompt({\n sessionId: this.sessionId,\n prompt: promptParts,\n });\n\n // Prompt complete → reflect final message\n if (result?.stopReason) {\n this.stopReason = result.stopReason;\n }\n this.log.info(`[${this.type}] Prompt completed: stopReason=${result?.stopReason} partialContent=${this.partialContent.length} chars partialBlocks=${this.partialBlocks.length}`);\n\n // Build final assistant message with rich content\n this.finalizeAssistantMessage();\n\n this.currentStatus = 'idle';\n this.detectStatusTransition();\n } catch (e: any) {\n this.log.warn(`[${this.type}] prompt error: ${e?.message}`);\n this.finalizeAssistantMessage();\n this.currentStatus = 'idle';\n this.detectStatusTransition();\n }\n }\n\n private async cancelSession(): Promise<void> {\n if (!this.connection || !this.sessionId) return;\n\n await this.connection.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 // ─── ACP session/update handle ─────────────────────\n\n private handleSessionUpdate(params: SessionNotification): void {\n if (!params) return;\n\n const update = params.update;\n this.log.debug(`[${this.type}] sessionUpdate: ${update.sessionUpdate}`);\n\n switch (update.sessionUpdate) {\n case 'agent_message_chunk': {\n const content = update.content;\n if (content.type === 'text') {\n this.partialContent += content.text;\n } else if (content.type === 'image') {\n this.partialBlocks.push({\n type: 'image',\n data: content.data,\n mimeType: content.mimeType,\n });\n } else if (content.type === 'resource_link') {\n this.partialBlocks.push({\n type: 'resource_link',\n uri: content.uri,\n name: content.name || 'resource',\n title: content.title ?? undefined,\n mimeType: content.mimeType ?? undefined,\n });\n } else if (content.type === 'resource') {\n this.partialBlocks.push({\n type: 'resource',\n resource: content.resource,\n });\n }\n this.currentStatus = 'generating';\n break;\n }\n case 'agent_thought_chunk':\n case 'user_message_chunk': {\n // Track but don't display thought chunks as main content\n break;\n }\n case 'tool_call': {\n // New tool call — ACP SDK ToolCall has all fields typed\n const tcId = update.toolCallId || `tc_${Date.now()}`;\n const tcTitle = update.title || 'unknown';\n const tcKind = update.kind as ToolKind | undefined;\n const tcStatus = this.mapToolCallStatus(update.status);\n \n this.activeToolCalls.push({\n id: tcId,\n name: tcTitle,\n status: tcStatus,\n input: update.rawInput ? (typeof update.rawInput === 'string' ? update.rawInput : JSON.stringify(update.rawInput)) : undefined,\n });\n \n // Also collect as ToolCallInfo for rich content\n const acpStatus = update.status || 'in_progress';\n this.turnToolCalls.push({\n toolCallId: tcId,\n title: tcTitle,\n kind: tcKind,\n status: acpStatus as TCS,\n rawInput: update.rawInput,\n content: this.convertToolCallContent(update.content),\n locations: update.locations,\n });\n break;\n }\n case 'tool_call_update': {\n // Update existing tool call — ACP SDK ToolCallUpdate typed\n const toolCallId = update.toolCallId;\n const existing = this.activeToolCalls.find(t => t.id === toolCallId);\n if (existing) {\n if (update.status) existing.status = this.mapToolCallStatus(update.status);\n if (update.rawOutput) existing.output = typeof update.rawOutput === 'string' ? update.rawOutput : JSON.stringify(update.rawOutput);\n }\n // Update ToolCallInfo too\n const tcInfo = this.turnToolCalls.find(t => t.toolCallId === toolCallId);\n if (tcInfo) {\n if (update.status) tcInfo.status = update.status as TCS;\n if (update.rawOutput) tcInfo.rawOutput = update.rawOutput;\n if (update.content) tcInfo.content = this.convertToolCallContent(update.content);\n if (update.locations) tcInfo.locations = update.locations;\n }\n break;\n }\n case 'current_mode_update': {\n this.currentMode = update.currentModeId;\n break;\n }\n case 'config_option_update': {\n if (update.configOptions) {\n this.parseConfigOptions(update.configOptions);\n }\n break;\n }\n case 'plan':\n case 'available_commands_update':\n case 'session_info_update':\n case 'usage_update':\n // Noted but no specific handling needed\n break;\n default:\n // Unknown update type — try legacy parsing for backward compatibility\n this.handleLegacyUpdate(update);\n break;\n }\n }\n\n /** Handle legacy session/update formats (pre-standardization compat) */\n private handleLegacyUpdate(params: any): void {\n // Legacy: messageDelta 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 // Legacy: 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 // Legacy: toolCallUpdate\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 // Legacy: stopReason\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 // Legacy: model info\n if (params.model) {\n this.currentModel = params.model;\n }\n }\n\n /** Map SDK ToolCallStatus to internal status */\n private mapToolCallStatus(status?: ToolCallStatus | string): 'running' | 'completed' | 'failed' {\n switch (status) {\n case 'completed': return 'completed';\n case 'failed': return 'failed';\n case 'pending':\n case 'in_progress':\n default: return 'running';\n }\n }\n\n // ─── Rich Content Helpers ────────────────────────────\n\n /** Truncate content for transport (text: 2000 chars, images preserved) */\n private truncateContent(content: string | ContentBlock[]): string | ContentBlock[] {\n if (typeof content === 'string') {\n return content.length > 2000 ? content.slice(0, 2000) + '\\n... (truncated)' : content;\n }\n return content.map(b => {\n if (b.type === 'text' && b.text.length > 2000) {\n return { ...b, text: b.text.slice(0, 2000) + '\\n... (truncated)' };\n }\n return b;\n });\n }\n\n /** Build ContentBlock[] from current partial state */\n private buildPartialBlocks(): ContentBlock[] {\n const blocks: ContentBlock[] = [];\n if (this.partialContent.trim()) {\n blocks.push({ type: 'text', text: this.partialContent.trim() + '...' });\n }\n blocks.push(...this.partialBlocks);\n return blocks;\n }\n\n /** Finalize streaming content into an assistant message */\n private finalizeAssistantMessage(): void {\n const blocks = this.buildPartialBlocks();\n // Remove trailing '...' from text blocks for final message\n const finalBlocks = blocks.map(b => {\n if (b.type === 'text' && b.text.endsWith('...')) {\n return { ...b, text: b.text.slice(0, -3) };\n }\n return b;\n }).filter(b => b.type !== 'text' || (b.type === 'text' && b.text.trim()));\n\n if (finalBlocks.length > 0) {\n this.messages.push({\n role: 'assistant',\n content: finalBlocks.length === 1 && finalBlocks[0].type === 'text'\n ? (finalBlocks[0] as {type: 'text', text: string}).text // single text → string (backward compat)\n : finalBlocks,\n timestamp: Date.now(),\n toolCalls: this.turnToolCalls.length > 0 ? [...this.turnToolCalls] : undefined,\n });\n }\n this.partialContent = '';\n this.partialBlocks = [];\n this.turnToolCalls = [];\n }\n\n /** Convert ACP ToolCallContent[] to our ToolCallContent[] */\n private convertToolCallContent(acpContent?: any[]): TCC[] | undefined {\n if (!acpContent || !Array.isArray(acpContent)) return undefined;\n return acpContent.map((c: any) => {\n if (c.type === 'diff') {\n return { type: 'diff' as const, path: c.path || '', oldText: c.oldText, newText: c.newText || '' };\n }\n if (c.type === 'terminal') {\n return { type: 'terminal' as const, terminalId: c.terminalId || '' };\n }\n // type: 'content' or unknown\n return { type: 'content' as const, content: c.content || { type: 'text' as const, text: JSON.stringify(c) } };\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 * Provider Output Contracts — Output contracts all providers must conform to\n * \n * Design principles:\n * - Only output format is standardized; implementation is free\n * - Common across all categories (cli, ide, extension)\n * - User custom providers use the same contracts\n */\n\n// ─── readChat() return value ───────────────────────────\n\nexport interface ReadChatResult {\n messages: ChatMessage[];\n status: AgentStatus;\n activeModal?: ModalInfo | null;\n /** IDE/Extension only: session info */\n id?: string;\n title?: string;\n /** Extension only: additional metadata */\n agentType?: string;\n agentName?: string;\n extensionId?: string;\n /** Status metadata */\n isVisible?: boolean;\n isWelcomeScreen?: boolean;\n inputContent?: string;\n model?: string;\n autoApprove?: string;\n}\n\nimport type { ChatMessage } from '../types.js';\nexport type { ChatMessage };\n\nexport type AgentStatus = \n | 'idle' \n | 'generating' \n | 'waiting_approval' \n | 'error' \n | 'panel_hidden'\n | 'streaming';\n\nexport interface ModalInfo {\n message: string;\n buttons: string[];\n width?: number;\n height?: number;\n}\n\n// ─── Rich Content Types (ACP Standard) ─────────────────\n// Based on ACP SDK v0.16.1 schema types.\n// All provider categories (ACP, IDE, Extension, CLI) use these as output standard.\n\n/**\n * ContentBlock — ACP ContentBlock union type\n * Represents displayable content in messages, tool call results, etc.\n */\nexport type ContentBlock =\n | TextBlock\n | ImageBlock\n | AudioBlock\n | ResourceLinkBlock\n | ResourceBlock;\n\n/** Text content — ACP TextContent */\nexport interface TextBlock {\n type: 'text';\n text: string;\n annotations?: ContentAnnotations;\n}\n\n/** Image content — ACP ImageContent */\nexport interface ImageBlock {\n type: 'image';\n data: string; // base64-encoded\n mimeType: string; // 'image/png', 'image/jpeg', etc.\n uri?: string; // optional URL reference\n annotations?: ContentAnnotations;\n}\n\n/** Audio content — ACP AudioContent */\nexport interface AudioBlock {\n type: 'audio';\n data: string; // base64-encoded\n mimeType: string;\n annotations?: ContentAnnotations;\n}\n\n/** Resource link (file reference) — ACP ResourceLink */\nexport interface ResourceLinkBlock {\n type: 'resource_link';\n uri: string;\n name: string;\n title?: string;\n description?: string;\n mimeType?: string;\n size?: number;\n annotations?: ContentAnnotations;\n}\n\n/** Embedded resource (inline file) — ACP EmbeddedResource */\nexport interface ResourceBlock {\n type: 'resource';\n resource: TextResourceContents | BlobResourceContents;\n annotations?: ContentAnnotations;\n}\n\nexport interface TextResourceContents {\n uri: string;\n text: string;\n mimeType?: string | null;\n}\n\nexport interface BlobResourceContents {\n uri: string;\n blob: string; // base64-encoded\n mimeType?: string | null;\n}\n\nexport interface ContentAnnotations {\n audience?: ('user' | 'assistant')[];\n priority?: number; // 0.0 ~ 1.0\n}\n\n// ─── Tool Call Types (ACP Standard) ─────────────────────\n\n/** Tool call info — ACP ToolCall */\nexport interface ToolCallInfo {\n toolCallId: string;\n title: string;\n kind?: ToolKind;\n status?: ToolCallStatus;\n rawInput?: unknown;\n rawOutput?: unknown;\n content?: ToolCallContent[];\n locations?: ToolCallLocation[];\n}\n\nexport type ToolKind = 'read' | 'edit' | 'delete' | 'move' | 'search' | 'execute' | 'think' | 'fetch' | 'switch_mode' | 'other';\nexport type ToolCallStatus = 'pending' | 'in_progress' | 'completed' | 'failed';\n\n/** Content produced by a tool call — ACP ToolCallContent */\nexport type ToolCallContent =\n | { type: 'content'; content: ContentBlock }\n | { type: 'diff'; path: string; oldText?: string; newText: string }\n | { type: 'terminal'; terminalId: string };\n\nexport interface ToolCallLocation {\n path: string;\n line?: number | null;\n}\n\n// ─── Content Helpers ────────────────────────────────────\n\n/** Normalize content: string → ContentBlock[] */\nexport function normalizeContent(content: string | ContentBlock[]): ContentBlock[] {\n if (typeof content === 'string') {\n return [{ type: 'text', text: content }];\n }\n return content;\n}\n\n/** Flatten ContentBlock[] → string (backward compat / plain-text extraction) */\nexport function flattenContent(content: string | ContentBlock[]): string {\n if (typeof content === 'string') return content;\n return content\n .filter((b): b is TextBlock => b.type === 'text')\n .map(b => b.text)\n .join('\\n');\n}\n\n/** SendMessage params — supports rich content (ACP PromptRequest compatible) */\nexport interface SendMessageParams {\n /** Shortcut: text-only message */\n text?: string;\n /** Rich content blocks (ACP ContentBlock[]) */\n prompt?: ContentBlock[];\n}\n\n// ─── sendMessage() return value ────────────────────────\n\nexport interface SendMessageResult {\n sent: boolean;\n error?: string;\n /** When CDP Input API is needed (Lexical editor etc) */\n needsTypeAndSend?: boolean;\n selector?: string;\n}\n\n// ─── listSessions() return value ───────────────────────\n\nexport interface ListSessionsResult {\n sessions: SessionInfo[];\n}\n\nexport interface SessionInfo {\n id: string;\n title: string;\n time?: string;\n}\n\n// ─── switchSession() return value ──────────────────────\n\nexport interface SwitchSessionResult {\n switched: boolean;\n /** When CDP click coordinates are needed (Antigravity QuickInput etc) */\n action?: 'click';\n clickX?: number;\n clickY?: number;\n error?: string;\n}\n\n// ─── resolveAction() return value ──────────────────────\n// Two methods supported:\n\n/**\n * Method 1: Script-Click — script calls el.click() directly\n * Cursor Suitable for IDEs using div.cursor-pointer elements.\n */\nexport interface ResolveActionScriptClick {\n resolved: boolean; // true = click succeeded\n clicked?: string; // clicked button text\n available?: string[]; // available buttons when resolved=false\n error?: string;\n}\n\n/**\n * Method 2: Coordinate-Click — returns coordinates, daemon performs CDP mouse click\n * Antigravity Suitable for IDEs where el.click() does not work.\n */\nexport interface ResolveActionCoordinateClick {\n found: boolean; // true = button found\n text?: string; // button text\n x?: number; // click X coordinate\n y?: number; // click Y coordinate\n w?: number; // button width\n h?: number; // button height\n}\n\nexport type ResolveActionResult = ResolveActionScriptClick | ResolveActionCoordinateClick;\n\n\n// ─── Provider Module type ────────────────────────\n\nexport type ProviderCategory = 'cli' | 'ide' | 'extension' | 'acp';\n\n/**\n * Type of object exported by module.exports in provider.js.\n * \n * Each provider.js is fully independent and does not import other providers.\n * Helpers (_helpers/) can be optionally used.\n */\n/**\n * Provider-configurable CDP target filter.\n * Used by DaemonCdpManager to select the correct page/tab to connect to.\n * Without this, the manager uses a hardcoded default filter.\n */\nexport interface CdpTargetFilter {\n /** URL must include this string (e.g. 'workbench.html') */\n urlIncludes?: string;\n /** URL must NOT include any of these strings */\n urlExcludes?: string[];\n /** Page title regex pattern for titles to EXCLUDE (e.g. 'Debug Console|Output') */\n titleExcludes?: string;\n}\n\nexport interface ProviderModule {\n /** Unique identifier (e.g. 'cline', 'cursor', 'gemini-cli') */\n type: string;\n /** Display name (e.g. 'Cline', 'Cursor') */\n name: string;\n /** Category: determines execution method */\n category: ProviderCategory;\n /** Alias list — allows users to invoke by alternate names (e.g. ['claude', 'claude-code']) */\n aliases?: string[];\n\n // ─── IDE infrastructure (used by launch/daemon) ───\n /** CDP ports [primary, secondary] (IDE category only) */\n cdpPorts?: [number, number];\n /** CDP target filter — controls which page/tab to connect to (IDE category only) */\n targetFilter?: CdpTargetFilter;\n /** CLI command (e.g. 'cursor', 'code') */\n cli?: string;\n /** Display icon */\n icon?: string;\n /** Display name (short name) */\n displayName?: string;\n /** Install instructions (shown when command is missing) */\n install?: string;\n /** Custom version detection command (e.g. 'cursor --version', 'claude -v') */\n versionCommand?: string;\n /** Versions tested by provider maintainer (informational) */\n testedVersions?: string[];\n /** Per-OS process names — used by launch.ts to detect/kill IDE processes */\n processNames?: {\n darwin?: string;\n win32?: string[];\n linux?: string[];\n [key: string]: string | string[] | undefined;\n };\n /** Per-OS install paths — used by detector.ts to detect IDE installation */\n paths?: {\n darwin?: string[];\n win32?: string[];\n linux?: string[];\n [key: string]: string[] | undefined;\n };\n\n // ─── Extension category only ───\n extensionId?: string;\n extensionIdPattern?: RegExp;\n\n // ─── CLI category only ───\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 cleanOutput?: (raw: string, lastUserInput?: string) => string;\n\n // ─── CDP scripts (ide/extension category) ───\n scripts?: ProviderScripts;\n\n // ─── VS Code Commands (Extension IPC via) ───\n vscodeCommands?: {\n focusPanel?: string;\n openPanel?: string;\n [key: string]: string | undefined;\n };\n\n // ─── Input method (IDE category — Lexical editor etc) ───\n inputMethod?: 'cdp-type-and-send' | 'script';\n inputSelector?: string;\n\n // ─── Webview chat (IDE category — chat UI is in webview iframe) ───\n /** webview iframe match text (must be contained in body) */\n webviewMatchText?: string;\n\n // ─── Per-OS overrides ───\n os?: {\n [platform: string]: Partial<Pick<ProviderModule, 'scripts' | 'inputMethod' | 'inputSelector'>>;\n };\n\n // ─── Per-version overrides ───\n /** Key: semver range string (e.g. '< 1.107.0', '>= 2.0.0') */\n versions?: {\n [versionRange: string]: Partial<Pick<ProviderModule, 'scripts'>> & {\n /**\n * Load scripts from a subdirectory instead of scripts.js root.\n * Path is relative to the provider directory (e.g. 'scripts/legacy').\n * The subdirectory should contain its own scripts.js or individual .js files.\n */\n __dir?: string;\n };\n };\n\n // ─── Composite override (OS + version) ───\n overrides?: Array<{\n when: { os?: string; version?: string };\n scripts?: Partial<ProviderScripts>;\n /** Load scripts from a subdirectory for this OS+version combination */\n __dir?: string;\n }>;\n\n // ─── Provider Settings (variables controllable from dashboard) ───\n settings?: Record<string, ProviderSettingDef>;\n\n // ─── ACP Static Config (for agents without config/* support) ───\n /** Static options used when agent does not provide configOptions */\n staticConfigOptions?: Array<{\n category: 'model' | 'mode' | 'thought_level' | 'other';\n configId: string;\n defaultValue?: string;\n options: Array<{ value: string; name: string; description?: string; group?: string }>;\n }>;\n /** Function to convert selected config values to spawn args (applied via process restart when config/* not supported) */\n spawnArgBuilder?: (config: Record<string, string>) => string[];\n\n // ─── ACP Authentication (auth method definitions) ───\n /** ACP agent auth methods (multiple supported — in priority order) */\n auth?: AcpAuthMethod[];\n}\n\n// ─── ACP Auth Types ─────────────────────────────────\n\n/** ACP auth method — based on ACP official spec */\nexport type AcpAuthMethod = AcpAuthEnvVar | AcpAuthAgent | AcpAuthTerminal;\n\n/** Environment variable-based auth (API keys etc) */\nexport interface AcpAuthEnvVar {\n type: 'env_var';\n id: string;\n name: string;\n vars: Array<{\n name: string;\n label?: string;\n secret?: boolean; // default true\n optional?: boolean; // default false\n }>;\n link?: string; // Key issuance URL\n}\n\n/** Agent self-auth (OAuth, browser-based etc) */\nexport interface AcpAuthAgent {\n type: 'agent';\n id: string;\n name: string;\n description?: string;\n}\n\n/** Terminal command-based auth (runs setup command) */\nexport interface AcpAuthTerminal {\n type: 'terminal';\n id: string;\n name: string;\n description?: string;\n args?: string[];\n env?: Record<string, string>;\n}\n\n/**\n * CDP script functions.\n * Each function takes a params object and returns a JS code string for CDP evaluate.\n * The JS execution result must conform to the Output Contract.\n * \n * Custom scripts can be added via index signature in addition to built-in scripts.\n * All scripts can receive params: Record<string, any>,\n * backward compatible with legacy single-argument style (e.g. sendMessage(text)).\n */\nexport interface ProviderScripts {\n // ─── Core ───\n readChat?: (params?: Record<string, any>) => string;\n sendMessage?: (params?: Record<string, any>) => string;\n listSessions?: (params?: Record<string, any>) => string;\n switchSession?: (params?: Record<string, any>) => string;\n newSession?: (params?: Record<string, any>) => string;\n\n // ─── UI Control ───\n focusEditor?: (params?: Record<string, any>) => string;\n openPanel?: (params?: Record<string, any>) => string;\n\n // ─── Model / Mode Control ───\n /** List available models → { models: string[], current: string } */\n listModels?: (params?: Record<string, any>) => string;\n /** Change model → { success: boolean } */\n setModel?: (params?: Record<string, any>) => string;\n /** List available modes → { modes: string[], current: string } */\n listModes?: (params?: Record<string, any>) => string;\n /** Change mode → { success: boolean } */\n setMode?: (params?: Record<string, any>) => string;\n\n // ─── Modal/Approval ───\n /** params: { action: 'approve'|'reject'|'custom', button?: string } */\n resolveAction?: (params?: Record<string, any>) => string;\n\n // ─── Notifications ───\n listNotifications?: (params?: Record<string, any>) => string;\n dismissNotification?: (params?: Record<string, any>) => string;\n\n // ─── Custom Scripts (user-defined) ───\n [scriptName: string]: ((params?: Record<string, any>) => string) | undefined;\n}\n\n\n/**\n * ProviderLoader.resolve() result: Final provider with OS/version overrides applied\n */\nexport interface ResolvedProvider extends ProviderModule {\n /** OS applied during resolve */\n _resolvedOs?: string;\n /** Version applied during resolve */\n _resolvedVersion?: string;\n /** Warning when detected version is not in compatibility matrix */\n _versionWarning?: string;\n}\n\n// ─── Provider Settings ─────────────────────────────────\n\n/** Setting variable definition declared by provider */\nexport interface ProviderSettingDef {\n type: 'boolean' | 'number' | 'string' | 'select';\n default: any;\n /** true = controllable from dashboard UI */\n public: boolean;\n /** UI label */\n label?: string;\n /** UI description */\n description?: string;\n /** Minimum value for number type */\n min?: number;\n /** Maximum value for number type */\n max?: number;\n /** Options for select type */\n options?: string[];\n}\n\n/** Public settings schema (for dashboard transmission) */\nexport interface ProviderSettingSchema extends ProviderSettingDef {\n key: string;\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 '../cdp/manager.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport { ProviderStreamAdapter } from './provider-adapter.js';\nimport { LOG } from '../logging/logger.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 || LOG.forComponent('AgentStream').asLogFn();\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 * AgentStreamPoller — Periodic agent stream polling + extension dynamic management\n *\n * Extracted from cloud daemon's startAgentStreamPolling() logic.\n * Used by both daemon-cloud and daemon-standalone.\n *\n * Responsibilities:\n * 1. Refresh extension providers in CDP managers (config changes take effect immediately)\n * 2. Dynamically add/remove IDE instance extensions based on enabled state\n * 3. Sync agent sessions + collect agent streams\n * 4. Auto-discover agents in connected IDEs\n */\n\nimport type { DaemonCdpManager } from '../cdp/manager.js';\nimport type { DaemonAgentStreamManager } from './manager.js';\nimport type { ProviderLoader } from '../providers/provider-loader.js';\nimport type { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport { registerExtensionProviders } from '../cdp/setup.js';\nimport { LOG } from '../logging/logger.js';\nimport type { AgentStreamState } from './types.js';\n\n// ─── Types ───\n\nexport interface AgentStreamPollerDeps {\n agentStreamManager: DaemonAgentStreamManager;\n providerLoader: ProviderLoader;\n instanceManager: ProviderInstanceManager;\n cdpManagers: Map<string, DaemonCdpManager>;\n /** Callback when agent streams are updated */\n onStreamsUpdated?: (ideType: string, streams: AgentStreamState[]) => void;\n}\n\nexport class AgentStreamPoller {\n private deps: AgentStreamPollerDeps;\n private _activeIdeType: string | null = null;\n private timer: NodeJS.Timeout | null = null;\n\n constructor(deps: AgentStreamPollerDeps) {\n this.deps = deps;\n }\n\n /** Currently active IDE type for agent streaming */\n get activeIde(): string | null {\n return this._activeIdeType;\n }\n\n /** Reset active IDE tracking (e.g., when IDE is stopped) */\n resetActiveIde(ideType: string): void {\n if (this._activeIdeType === ideType) {\n this._activeIdeType = null;\n }\n }\n\n /** Start polling (idempotent — ignored if already started) */\n start(intervalMs = 5000): void {\n if (this.timer) return; // Already running\n\n this.timer = setInterval(async () => {\n await this.tick();\n }, intervalMs);\n }\n\n /** Stop polling */\n stop(): void {\n if (this.timer) {\n clearInterval(this.timer);\n this.timer = null;\n }\n }\n\n /** Single poll tick — can also be called manually */\n private async tick(): Promise<void> {\n const {\n agentStreamManager,\n providerLoader,\n instanceManager,\n cdpManagers,\n } = this.deps;\n\n if (!agentStreamManager || cdpManagers.size === 0) return;\n\n // ─── Phase 1: Refresh extension providers + IDE instance extensions ───\n for (const [ideType, cdp] of cdpManagers) {\n // 1a. Refresh CDP manager's extension providers from config\n registerExtensionProviders(providerLoader, cdp, ideType);\n\n // 1b. Dynamically add/remove IDE instance extensions\n const ideInstance = 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 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 = providerLoader.getMeta(extType);\n if (extProvider) {\n const extSettings = 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 // ─── Phase 2: Agent session sync + collect ───\n\n // If agent already connected to a specific IDE, only operate on that CDP\n if (this._activeIdeType) {\n const cdp = cdpManagers.get(this._activeIdeType);\n if (cdp?.isConnected) {\n try {\n await agentStreamManager.syncAgentSessions(cdp);\n const streams = await agentStreamManager.collectAgentStreams(cdp);\n this.deps.onStreamsUpdated?.(this._activeIdeType, streams);\n } catch { }\n return;\n }\n // CDP lost — reset\n this._activeIdeType = null;\n }\n\n // ─── Phase 3: Auto-discover agents ───\n if (!agentStreamManager.activeAgentType) {\n for (const [ideType, cdp] of cdpManagers) {\n if (!cdp.isConnected) continue;\n try {\n const discovered = await cdp.discoverAgentWebviews();\n if (discovered.length > 0) {\n this._activeIdeType = ideType;\n await agentStreamManager.switchActiveAgent(cdp, discovered[0].agentType);\n LOG.info('AgentStream', `Auto-activated: ${discovered[0].agentType} (${ideType})`);\n // sync+collect immediately\n await agentStreamManager.syncAgentSessions(cdp);\n const streams = await agentStreamManager.collectAgentStreams(cdp);\n this.deps.onStreamsUpdated?.(ideType, streams);\n return;\n }\n } catch { }\n }\n }\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';\nimport { LOG } from '../logging/logger.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 LOG.warn('InstanceMgr', `[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 LOG.warn('InstanceMgr', `[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 LOG.warn('InstanceMgr', `[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 /**\n * Update settings for all instances of a given provider type.\n * Called when user changes settings from dashboard.\n */\n updateInstanceSettings(providerType: string, settings: Record<string, any>): number {\n let updated = 0;\n for (const instance of this.instances.values()) {\n if (instance.type === providerType && typeof instance.updateSettings === 'function') {\n instance.updateSettings(settings);\n updated++;\n }\n }\n return updated;\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 * Provider Version Detection & Archiving\n *\n * Detects installed versions for all provider categories (IDE, CLI, ACP, Extension).\n * Archives version history to ~/.adhdev/version-history.json for compatibility tracking.\n *\n * Usage:\n * const archive = new VersionArchive();\n * const results = await detectAllVersions(providerLoader, archive);\n */\n\nimport * as fs from 'fs';\nimport * as path from 'path';\nimport * as os from 'os';\nimport { execSync } from 'child_process';\nimport { platform } from 'os';\nimport type { ProviderLoader } from './provider-loader.js';\n\n// ─── Types ──────────────────────────────────────\n\nexport interface ProviderVersionInfo {\n type: string;\n name: string;\n category: string;\n installed: boolean;\n version: string | null;\n path: string | null;\n binary: string | null;\n detectedAt: string; // ISO timestamp\n /**\n * Set when the detected version is NOT listed in provider.json testedVersions.\n * Means scripts may not work correctly with this version.\n */\n warning?: string;\n}\n\nexport interface VersionHistoryEntry {\n version: string;\n detectedAt: string;\n os: string;\n}\n\nexport interface VersionHistory {\n [providerType: string]: VersionHistoryEntry[];\n}\n\n// ─── Version Archive ──────────────────────────────\n\nconst ARCHIVE_PATH = path.join(os.homedir(), '.adhdev', 'version-history.json');\nconst MAX_ENTRIES_PER_PROVIDER = 20;\n\nexport class VersionArchive {\n private history: VersionHistory = {};\n\n constructor() {\n this.load();\n }\n\n private load(): void {\n try {\n if (fs.existsSync(ARCHIVE_PATH)) {\n this.history = JSON.parse(fs.readFileSync(ARCHIVE_PATH, 'utf-8'));\n }\n } catch {\n this.history = {};\n }\n }\n\n /** Record a detected version (deduplicates same version) */\n record(type: string, version: string): void {\n if (!this.history[type]) this.history[type] = [];\n\n const entries = this.history[type];\n const last = entries[entries.length - 1];\n\n // Skip if same version as last entry\n if (last && last.version === version) return;\n\n entries.push({\n version,\n detectedAt: new Date().toISOString(),\n os: platform(),\n });\n\n // Trim old entries\n if (entries.length > MAX_ENTRIES_PER_PROVIDER) {\n this.history[type] = entries.slice(-MAX_ENTRIES_PER_PROVIDER);\n }\n\n this.save();\n }\n\n /** Get version history for a provider */\n getHistory(type: string): VersionHistoryEntry[] {\n return this.history[type] || [];\n }\n\n /** Get latest known version for a provider */\n getLatest(type: string): string | null {\n const entries = this.history[type];\n return entries?.length ? entries[entries.length - 1].version : null;\n }\n\n /** Get full archive */\n getAll(): VersionHistory {\n return { ...this.history };\n }\n\n private save(): void {\n try {\n fs.mkdirSync(path.dirname(ARCHIVE_PATH), { recursive: true });\n fs.writeFileSync(ARCHIVE_PATH, JSON.stringify(this.history, null, 2));\n } catch { /* ignore write errors */ }\n }\n}\n\n// ─── Version Detection ──────────────────────────────\n\nfunction runCommand(cmd: string, timeout = 10000): string | null {\n try {\n return execSync(cmd, {\n encoding: 'utf-8',\n timeout,\n stdio: ['pipe', 'pipe', 'pipe'],\n }).trim();\n } catch {\n return null;\n }\n}\n\nfunction findBinary(name: string): string | null {\n const cmd = platform() === 'win32' ? `where ${name}` : `which ${name}`;\n const result = runCommand(cmd, 5000);\n return result ? result.split('\\n')[0] : null;\n}\n\n/** Extract version string from CLI output */\nfunction parseVersion(raw: string): string {\n // Common patterns: \"1.2.3\", \"v1.2.3\", \"tool 1.2.3\", \"tool version 1.2.3\"\n const match = raw.match(/v?(\\d+\\.\\d+(?:\\.\\d+)?(?:-[a-zA-Z0-9.]+)?)/);\n return match ? match[1] : raw.split('\\n')[0].substring(0, 100);\n}\n\nfunction getVersion(binary: string, versionCommand?: string): string | null {\n // Custom version command from provider.json\n if (versionCommand) {\n const raw = runCommand(versionCommand);\n return raw ? parseVersion(raw) : null;\n }\n\n // Default: try --version, then -V, then -v\n for (const flag of ['--version', '-V', '-v']) {\n const raw = runCommand(`\"${binary}\" ${flag}`);\n if (raw && raw.length < 500) return parseVersion(raw);\n }\n return null;\n}\n\nfunction checkPathExists(paths: string[]): string | null {\n for (const p of paths) {\n if (p.includes('*')) {\n const home = os.homedir();\n const resolved = p.replace(/\\*/g, home.split(path.sep).pop() || '');\n if (fs.existsSync(resolved)) return resolved;\n } else {\n if (fs.existsSync(p)) return p;\n }\n }\n return null;\n}\n\n/** macOS: Get app version from Info.plist */\nfunction getMacAppVersion(appPath: string): string | null {\n if (platform() !== 'darwin' || !appPath.endsWith('.app')) return null;\n const plistPath = path.join(appPath, 'Contents', 'Info.plist');\n if (!fs.existsSync(plistPath)) return null;\n const raw = runCommand(`/usr/libexec/PlistBuddy -c \"Print CFBundleShortVersionString\" \"${plistPath}\"`);\n return raw || null;\n}\n\n/**\n * Detect versions for all loaded providers\n */\nexport async function detectAllVersions(\n loader: ProviderLoader,\n archive?: VersionArchive,\n): Promise<ProviderVersionInfo[]> {\n const results: ProviderVersionInfo[] = [];\n const currentOs = platform() as string;\n\n for (const provider of loader.getAll()) {\n const info: ProviderVersionInfo = {\n type: provider.type,\n name: provider.name,\n category: provider.category,\n installed: false,\n version: null,\n path: null,\n binary: null,\n detectedAt: new Date().toISOString(),\n };\n\n const versionCommand = (provider as any).versionCommand;\n\n if (provider.category === 'ide') {\n // IDE: check app path + CLI\n const osPaths = provider.paths?.[currentOs] || [];\n const appPath = checkPathExists(osPaths);\n const cliBin = provider.cli ? findBinary(provider.cli) : null;\n\n // Also check bundled CLI inside .app for macOS\n let resolvedBin = cliBin;\n if (!resolvedBin && appPath && currentOs === 'darwin') {\n const bundled = path.join(appPath, 'Contents', 'Resources', 'app', 'bin', provider.cli || '');\n if (provider.cli && fs.existsSync(bundled)) resolvedBin = bundled;\n }\n\n info.installed = !!(appPath || resolvedBin);\n info.path = appPath || null;\n info.binary = resolvedBin || null;\n\n // Version: try CLI first, then plist\n if (resolvedBin) {\n info.version = getVersion(resolvedBin, versionCommand);\n }\n if (!info.version && appPath) {\n info.version = getMacAppVersion(appPath);\n }\n\n } else if (provider.category === 'cli' || provider.category === 'acp') {\n // CLI/ACP: check binary\n const bin = provider.binary || provider.spawn?.command || provider.cli || provider.type;\n const binPath = findBinary(bin);\n info.installed = !!binPath;\n info.binary = binPath || null;\n\n if (binPath) {\n info.version = getVersion(binPath, versionCommand);\n }\n\n } else if (provider.category === 'extension') {\n // Extension: version detection via `code --list-extensions --show-versions`\n // This is more complex and depends on the host IDE — skip for now\n // Could be detected at runtime via CDP\n info.installed = false; // Cannot reliably detect without IDE context\n info.version = null;\n }\n\n // Archive the version if detected\n if (info.version && archive) {\n archive.record(provider.type, info.version);\n }\n\n // Check testedVersions — warn if installed version is not documented\n if (info.version && info.installed) {\n const testedVersions: string[] = (provider as any).testedVersions || [];\n if (testedVersions.length > 0 && !testedVersions.includes(info.version)) {\n info.warning = `Version ${info.version} is not in testedVersions [${testedVersions.join(', ')}]. Scripts may not work correctly.`;\n }\n }\n\n results.push(info);\n }\n\n return results;\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 { ChildProcess } from 'child_process';\nimport type { DaemonCdpManager } from '../cdp/manager.js';\nimport type { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport type { DaemonCliManager } from '../commands/cli-manager.js';\nimport { generateTemplate as genScaffoldTemplate, generateFiles as genScaffoldFiles } from './scaffold-template.js';\nimport { VersionArchive, detectAllVersions } from '../providers/version-archive.js';\nimport { LOG } from '../logging/logger.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 instanceManager: ProviderInstanceManager | null;\n private cliManager: DaemonCliManager | null;\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 // Auto-implement state\n private autoImplProcess: ChildProcess | null = null;\n private autoImplSSEClients: http.ServerResponse[] = [];\n private autoImplStatus: { running: boolean; type: string | null; progress: any[] } = { running: false, type: null, progress: [] };\n\n // CLI debug SSE\n private cliSSEClients: http.ServerResponse[] = [];\n\n constructor(options: {\n providerLoader: ProviderLoader;\n cdpManagers: Map<string, DaemonCdpManager>;\n instanceManager?: ProviderInstanceManager;\n cliManager?: DaemonCliManager;\n logFn?: (msg: string) => void;\n }) {\n this.providerLoader = options.providerLoader;\n this.cdpManagers = options.cdpManagers;\n this.instanceManager = options.instanceManager || null;\n this.cliManager = options.cliManager || null;\n this.logFn = options.logFn || LOG.forComponent('DevServer').asLogFn();\n }\n\n private log(msg: string): void {\n this.logFn(`[DevServer] ${msg}`);\n }\n\n // ─── Route Table ─────────────────────────────────────\n private readonly routes: {\n method: string;\n pattern: string | RegExp;\n handler: (req: http.IncomingMessage, res: http.ServerResponse, params?: string[]) => Promise<void> | void;\n }[] = [\n // Static routes\n { method: 'GET', pattern: '/api/providers', handler: (q, s) => this.handleListProviders(q, s) },\n { method: 'GET', pattern: '/api/providers/versions', handler: (q, s) => this.handleDetectVersions(q, s) },\n { method: 'POST', pattern: '/api/providers/reload', handler: (q, s) => this.handleReload(q, s) },\n { method: 'POST', pattern: '/api/cdp/evaluate', handler: (q, s) => this.handleCdpEvaluate(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/query', handler: (q, s) => this.handleCdpDomQuery(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/inspect', handler: (q, s) => this.handleDomInspect(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/children', handler: (q, s) => this.handleDomChildren(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/analyze', handler: (q, s) => this.handleDomAnalyze(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/find-text', handler: (q, s) => this.handleFindByText(q, s) },\n { method: 'POST', pattern: '/api/cdp/dom/find-common', handler: (q, s) => this.handleFindCommon(q, s) },\n { method: 'GET', pattern: '/api/cdp/screenshot', handler: (q, s) => this.handleScreenshot(q, s) },\n { method: 'GET', pattern: '/api/cdp/targets', handler: (q, s) => this.handleCdpTargets(q, s) },\n { method: 'POST', pattern: '/api/scripts/run', handler: (q, s) => this.handleScriptsRun(q, s) },\n { method: 'GET', pattern: '/api/status', handler: (q, s) => this.handleStatus(q, s) },\n { method: 'POST', pattern: '/api/watch/start', handler: (q, s) => this.handleWatchStart(q, s) },\n { method: 'POST', pattern: '/api/watch/stop', handler: (q, s) => this.handleWatchStop(q, s) },\n { method: 'GET', pattern: '/api/watch/events', handler: (q, s) => this.handleSSE(q, s) },\n { method: 'POST', pattern: '/api/scaffold', handler: (q, s) => this.handleScaffold(q, s) },\n // CLI Debug routes\n { method: 'GET', pattern: '/api/cli/status', handler: (q, s) => this.handleCliStatus(q, s) },\n { method: 'POST', pattern: '/api/cli/launch', handler: (q, s) => this.handleCliLaunch(q, s) },\n { method: 'POST', pattern: '/api/cli/send', handler: (q, s) => this.handleCliSend(q, s) },\n { method: 'POST', pattern: '/api/cli/resolve', handler: (q, s) => this.handleCliResolve(q, s) },\n { method: 'POST', pattern: '/api/cli/raw', handler: (q, s) => this.handleCliRaw(q, s) },\n { method: 'POST', pattern: '/api/cli/stop', handler: (q, s) => this.handleCliStop(q, s) },\n { method: 'GET', pattern: '/api/cli/events', handler: (q, s) => this.handleCliSSE(q, s) },\n { method: 'GET', pattern: /^\\/api\\/cli\\/debug\\/([^/]+)$/, handler: (q, s, p) => this.handleCliDebug(p![0], q, s) },\n // Dynamic routes (provider :type param)\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/script$/, handler: (q, s, p) => this.handleRunScript(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/files$/, handler: (q, s, p) => this.handleListFiles(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/file$/, handler: (q, s, p) => this.handleReadFile(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/file$/, handler: (q, s, p) => this.handleWriteFile(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/source$/, handler: (q, s, p) => this.handleSource(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/save$/, handler: (q, s, p) => this.handleSave(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/config$/, handler: (q, s, p) => this.handleProviderConfig(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/dom-context$/, handler: (q, s, p) => this.handleDomContext(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/auto-implement$/, handler: (q, s, p) => this.handleAutoImplement(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/auto-implement\\/cancel$/,handler: (q, s, p) => this.handleAutoImplCancel(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/auto-implement\\/status$/,handler: (q, s, p) => this.handleAutoImplSSE(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/spawn-test$/, handler: (q, s, p) => this.handleSpawnTest(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/validate$/, handler: (q, s, p) => this.handleValidate(p![0], q, s) },\n { method: 'POST', pattern: /^\\/api\\/providers\\/([^/]+)\\/acp-chat$/, handler: (q, s, p) => this.handleAcpChat(p![0], q, s) },\n { method: 'GET', pattern: /^\\/api\\/providers\\/([^/]+)\\/script-hints$/, handler: (q, s, p) => this.handleScriptHints(p![0], q, s) },\n ];\n\n private matchRoute(method: string, pathname: string): { handler: (req: http.IncomingMessage, res: http.ServerResponse, params?: string[]) => Promise<void> | void; params?: string[] } | null {\n for (const route of this.routes) {\n if (route.method !== method) continue;\n if (typeof route.pattern === 'string') {\n if (pathname === route.pattern) return { handler: route.handler };\n } else {\n const m = pathname.match(route.pattern);\n if (m) return { handler: route.handler, params: m.slice(1) };\n }\n }\n return null;\n }\n\n private getEndpointList(): string[] {\n return this.routes.map(r => {\n const path = typeof r.pattern === 'string'\n ? r.pattern\n : r.pattern.source.replace(/\\\\\\//g, '/').replace(/\\(\\[.*?\\]\\+\\)/g, ':type').replace(/[\\^$]/g, '');\n return `${r.method.padEnd(5)} ${path}`;\n });\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 // ─── Route Table ───\n const route = this.matchRoute(req.method || 'GET', pathname);\n if (route) {\n await route.handler(req, res, route.params);\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: this.getEndpointList() });\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.resolve(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.resolve(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/webp',\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.getMeta(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 private async handleScriptHints(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\n // Find scripts.js in the provider dir (may be versioned)\n let scriptsPath = '';\n const directScripts = path.join(dir, 'scripts.js');\n if (fs.existsSync(directScripts)) {\n scriptsPath = directScripts;\n } else {\n // Check versioned scripts dirs\n const scriptsDir = path.join(dir, 'scripts');\n if (fs.existsSync(scriptsDir)) {\n const versions = fs.readdirSync(scriptsDir).filter(d => {\n return fs.statSync(path.join(scriptsDir, d)).isDirectory();\n }).sort().reverse();\n for (const ver of versions) {\n const p = path.join(scriptsDir, ver, 'scripts.js');\n if (fs.existsSync(p)) { scriptsPath = p; break; }\n }\n }\n }\n\n if (!scriptsPath) {\n this.json(res, 200, { hints: {} });\n return;\n }\n\n try {\n const source = fs.readFileSync(scriptsPath, 'utf-8');\n const hints: Record<string, { template: Record<string, any>; description: string }> = {};\n\n // Parse exported functions and extract param usage\n const funcRegex = /module\\.exports\\.(\\w+)\\s*=\\s*function\\s+\\w+\\s*\\(params\\)/g;\n let match;\n while ((match = funcRegex.exec(source)) !== null) {\n const name = match[1];\n // Find the function body (rough: from match to next module.exports or end)\n const startIdx = match.index;\n const nextFunc = source.indexOf('module.exports.', startIdx + 1);\n const funcBody = source.substring(startIdx, nextFunc > 0 ? nextFunc : source.length);\n\n const paramFields: Record<string, any> = {};\n\n // Pattern 1: params?.xxx or params.xxx\n const dotRegex = /params\\?\\.([a-zA-Z_]+)|params\\.([a-zA-Z_]+)/g;\n let dm;\n while ((dm = dotRegex.exec(funcBody)) !== null) {\n const field = dm[1] || dm[2];\n if (field === 'length') continue;\n if (!(field in paramFields)) {\n // Infer type from context\n if (/index|count|port|timeout/i.test(field)) paramFields[field] = 0;\n else if (/action|text|title|message|model|mode|button|name|filter/i.test(field)) paramFields[field] = '';\n else paramFields[field] = '';\n }\n }\n\n // Pattern 2: typeof params === 'string' ? params : params?.xxx\n const typeofRegex = /typeof params === 'string' \\? params : params\\?\\.([a-zA-Z_]+)/g;\n let tm;\n while ((tm = typeofRegex.exec(funcBody)) !== null) {\n const field = tm[1];\n if (!(field in paramFields)) paramFields[field] = '';\n }\n\n // Pattern 3: typeof params === 'number' ? params : params?.xxx\n const numRegex = /typeof params === 'number' \\? params : params\\?\\.([a-zA-Z_]+)/g;\n let nm;\n while ((nm = numRegex.exec(funcBody)) !== null) {\n const field = nm[1];\n if (!(field in paramFields)) paramFields[field] = 0;\n }\n\n // Determine description from function name\n const descriptions: Record<string, string> = {\n readChat: 'No params required',\n sendMessage: 'Text to send to the chat',\n listSessions: 'No params required',\n switchSession: 'Switch by index or title',\n newSession: 'No params required',\n focusEditor: 'No params required',\n openPanel: 'No params required',\n resolveAction: 'Approve/reject action buttons',\n listNotifications: 'Optional message filter',\n dismissNotification: 'Dismiss by index, message, or button',\n listModels: 'No params required',\n setModel: 'Model name to select',\n listModes: 'No params required',\n setMode: 'Mode name to select',\n };\n\n hints[name] = {\n template: Object.keys(paramFields).length > 0 ? paramFields : {},\n description: descriptions[name] || (Object.keys(paramFields).length > 0 ? 'Params: ' + Object.keys(paramFields).join(', ') : 'No params'),\n };\n }\n\n this.json(res, 200, { hints });\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n // ─── Validate provider.json ───\n private async handleValidate(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { content } = body;\n const errors: string[] = [];\n const warnings: string[] = [];\n try {\n const config = typeof content === 'string' ? JSON.parse(content) : content;\n // Required fields\n if (!config.type) errors.push('Missing required field: type');\n if (!config.name) errors.push('Missing required field: name');\n if (!config.category) errors.push('Missing required field: category');\n else if (!['ide', 'extension', 'cli', 'acp'].includes(config.category)) errors.push(`Invalid category: ${config.category}`);\n // Category-specific\n if (config.category === 'ide' || config.category === 'extension') {\n if (!config.cdpPorts || !Array.isArray(config.cdpPorts) || config.cdpPorts.length === 0)\n warnings.push('IDE/Extension providers should have cdpPorts');\n if (config.category === 'extension' && !config.extensionId)\n warnings.push('Extension providers should have extensionId');\n }\n if (config.category === 'acp' || config.category === 'cli') {\n if (!config.spawn) errors.push('ACP/CLI providers must have spawn config');\n else {\n if (!config.spawn.command) errors.push('spawn.command is required');\n }\n }\n // Settings validation\n if (config.settings) {\n for (const [key, val] of Object.entries(config.settings)) {\n const s = val as any;\n if (!s.type) errors.push(`settings.${key}: missing type`);\n else if (!['boolean', 'number', 'string', 'select'].includes(s.type))\n errors.push(`settings.${key}: invalid type '${s.type}'`);\n if (s.default === undefined) warnings.push(`settings.${key}: no default value`);\n if (s.type === 'number' && s.min !== undefined && s.max !== undefined && s.min > s.max)\n errors.push(`settings.${key}: min (${s.min}) > max (${s.max})`);\n if (s.type === 'select' && (!s.options || !Array.isArray(s.options) || s.options.length === 0))\n errors.push(`settings.${key}: select type requires options[]`);\n }\n }\n // Port conflicts\n if (config.cdpPorts && Array.isArray(config.cdpPorts)) {\n const allProviders = this.providerLoader.getAll();\n for (const port of config.cdpPorts) {\n const conflict = allProviders.find(p => p.type !== type && (p as any).cdpPorts?.includes(port));\n if (conflict) warnings.push(`CDP port ${port} conflicts with provider '${conflict.type}'`);\n }\n }\n this.json(res, 200, { valid: errors.length === 0, errors, warnings });\n } catch (e: any) {\n this.json(res, 200, { valid: false, errors: [`Invalid JSON: ${e.message}`], warnings: [] });\n }\n }\n\n // ─── ACP Chat Test ───\n private async handleAcpChat(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { message, timeout = 30000 } = body;\n if (!message) { this.json(res, 400, { error: 'message required' }); return; }\n const provider = this.providerLoader.getMeta(type);\n if (!provider) { this.json(res, 404, { error: `Provider not found: ${type}` }); return; }\n const spawn = (provider as any).spawn;\n if (!spawn) { this.json(res, 400, { error: `Provider ${type} has no spawn config` }); return; }\n\n const { spawn: spawnFn } = await import('child_process');\n const start = Date.now();\n try {\n const args = [...(spawn.args || []), message];\n const child = spawnFn(spawn.command, args, {\n shell: spawn.shell ?? false,\n timeout: timeout,\n stdio: ['pipe', 'pipe', 'pipe'],\n env: { ...process.env, ...(spawn.env || {}) },\n });\n\n let stdout = '';\n let stderr = '';\n child.stdout?.on('data', (d: Buffer) => { stdout += d.toString(); });\n child.stderr?.on('data', (d: Buffer) => { stderr += d.toString(); });\n\n await new Promise<void>((resolve) => {\n const timer = setTimeout(() => { child.kill(); resolve(); }, timeout);\n child.on('exit', () => { clearTimeout(timer); resolve(); });\n });\n\n const elapsed = Date.now() - start;\n this.json(res, 200, {\n success: true,\n message,\n response: stdout.trim(),\n stderr: stderr.trim(),\n exitCode: child.exitCode,\n elapsed,\n });\n } catch (e: any) {\n this.json(res, 200, {\n success: false,\n message,\n error: e.message,\n elapsed: Date.now() - start,\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, version } = body;\n if (!type || !name) {\n this.json(res, 400, { error: 'type and name required' });\n return;\n }\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 jsonPath = path.join(targetDir, 'provider.json');\n if (fs.existsSync(jsonPath)) {\n this.json(res, 409, { error: `Provider already exists at ${targetDir}`, path: targetDir });\n return;\n }\n\n try {\n const result = genScaffoldFiles(type, name, category, { cdpPorts, cli, processName, installPath, binary, extensionId, version });\n fs.mkdirSync(targetDir, { recursive: true });\n fs.writeFileSync(jsonPath, result['provider.json'], 'utf-8');\n const createdFiles = ['provider.json'];\n\n // Write per-function script files (new structure)\n if (result.files) {\n for (const [relPath, content] of Object.entries(result.files)) {\n const fullPath = path.join(targetDir, relPath);\n fs.mkdirSync(path.dirname(fullPath), { recursive: true });\n fs.writeFileSync(fullPath, content, 'utf-8');\n createdFiles.push(relPath);\n }\n }\n\n this.log(`Scaffolded provider: ${targetDir} (${createdFiles.length} files)`);\n this.json(res, 201, { created: true, path: targetDir, files: createdFiles, type, name, category });\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\n }\n\n // ─── Version Detection ───\n\n private async handleDetectVersions(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n try {\n const archive = new VersionArchive();\n const results = await detectAllVersions(this.providerLoader, archive);\n const installed = results.filter(r => r.installed);\n const notInstalled = results.filter(r => !r.installed);\n this.json(res, 200, {\n total: results.length,\n installed: installed.length,\n providers: results,\n history: archive.getAll(),\n });\n } catch (e: any) {\n this.json(res, 500, { error: e.message });\n }\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 private async handleFindCommon(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { include, exclude, ideType } = body;\n if (!Array.isArray(include) || include.length === 0) { this.json(res, 400, { error: 'include[] is required' }); return; }\n const cdp = this.getCdp(ideType);\n if (!cdp) { this.json(res, 503, { error: 'No CDP connection' }); return; }\n\n const script = `(() => {\n const includes = ${JSON.stringify(include)};\n const excludes = ${JSON.stringify(exclude || [])};\n\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 sig(el) {\n return el.tagName + '|' + ((el.className && typeof el.className === 'string') ? el.className.trim() : '');\n }\n\n // Step 1: For each include, find all matching leaf elements\n const includeMatches = includes.map(text => {\n const lower = text.toLowerCase();\n const found = [];\n const walker = document.createTreeWalker(document.body, NodeFilter.SHOW_TEXT, {\n acceptNode: n => n.textContent.toLowerCase().includes(lower) ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_REJECT\n });\n let node;\n while ((node = walker.nextNode()) && found.length < 5) {\n if (node.parentElement) found.push(node.parentElement);\n }\n return found;\n });\n\n if (includeMatches.some(m => m.length === 0)) {\n const missing = includes.filter((_, i) => includeMatches[i].length === 0);\n return JSON.stringify({ results: [], message: 'Text not found: ' + missing.join(', ') });\n }\n\n // Step 2: Find LCA for each combination of include elements\n // For each pair of include[0] element and include[1] element, find their LCA\n // Then within the LCA, find the direct-child subtree branch for each\n const containers = [];\n const seen = new Set();\n\n function findLCA(el1, el2) {\n const ancestors1 = new Set();\n let c = el1;\n while (c) { ancestors1.add(c); c = c.parentElement; }\n c = el2;\n while (c) { if (ancestors1.has(c)) return c; c = c.parentElement; }\n return document.body;\n }\n\n function findDirectChildContaining(parent, descendant) {\n let c = descendant;\n while (c && c.parentElement !== parent) c = c.parentElement;\n return c;\n }\n\n // Try all combinations (first 3 matches per include)\n for (const el1 of includeMatches[0].slice(0, 3)) {\n for (let ii = 1; ii < includeMatches.length; ii++) {\n for (const el2 of includeMatches[ii].slice(0, 3)) {\n if (el1 === el2) continue;\n const lca = findLCA(el1, el2);\n if (!lca || lca === document.body || lca === document.documentElement) continue;\n\n // Find which direct child of LCA contains each include element\n const child1 = findDirectChildContaining(lca, el1);\n const child2 = findDirectChildContaining(lca, el2);\n if (!child1 || !child2 || child1 === child2) continue;\n\n const lcaSel = fp(lca);\n if (seen.has(lcaSel)) continue;\n seen.add(lcaSel);\n\n // Check exclude\n if (excludes.length > 0) {\n const lcaText = (lca.textContent || '').toLowerCase();\n if (excludes.some(ex => lcaText.includes(ex.toLowerCase()))) continue;\n }\n\n // Are child1 and child2 same tag? (relaxed — ignore classes)\n const tag1 = child1.tagName;\n const tag2 = child2.tagName;\n\n // Bubble up: walk up from LCA, find the best list container\n // (the one with most repeating same-tag children)\n let container = lca;\n let bestContainer = lca;\n let bestListCount = 0;\n for (let up = 0; up < 10; up++) {\n const p = container.parentElement;\n if (!p || p === document.body || p === document.documentElement) break;\n // Check how many same-tag siblings 'container' has in parent\n const myTag = container.tagName;\n const sibCount = [...p.children].filter(c => c.tagName === myTag).length;\n if (sibCount > bestListCount) {\n bestListCount = sibCount;\n bestContainer = p;\n }\n container = p;\n }\n container = bestListCount >= 3 ? bestContainer : lca;\n\n const allChildren = [...container.children];\n const childTag = tag1 === tag2 ? tag1 : (allChildren.length > 0 ? allChildren[0].tagName : '');\n const sameTagCount = allChildren.filter(c => c.tagName === childTag).length;\n const isList = sameTagCount >= 3 && sameTagCount >= allChildren.length * 0.4;\n\n // Gather all same-tag children as list items\n const listItems = isList \n ? allChildren.filter(c => c.tagName === childTag)\n : allChildren;\n\n // Filter rendered items (skip virtual scroll placeholders)\n const rendered = listItems.filter(c => (c.innerText || '').trim().length > 0);\n const placeholderCount = listItems.length - rendered.length;\n\n const containerSel = fp(container);\n if (seen.has(containerSel)) continue;\n seen.add(containerSel);\n\n const r = container.getBoundingClientRect();\n containers.push({\n selector: containerSel,\n tag: container.tagName.toLowerCase(),\n childCount: allChildren.length,\n listItemCount: listItems.length,\n renderedCount: rendered.length,\n placeholderCount,\n isList,\n rect: { w: Math.round(r.width), h: Math.round(r.height) },\n depth: containerSel.split(' > ').length,\n items: rendered.slice(0, 30).map((el, i) => {\n const fullText = (el.innerText || el.textContent || '').trim();\n // Find snippet around first matched include text\n let text = fullText.substring(0, 200);\n const matched = [];\n for (const inc of includes) {\n const idx = fullText.toLowerCase().indexOf(inc.toLowerCase());\n if (idx >= 0) {\n matched.push(inc);\n if (matched.length === 1) {\n // Show snippet around first match\n const start = Math.max(0, idx - 30);\n const end = Math.min(fullText.length, idx + inc.length + 80);\n text = (start > 0 ? '...' : '') + fullText.substring(start, end) + (end < fullText.length ? '...' : '');\n }\n }\n }\n return {\n index: i,\n tag: el.tagName.toLowerCase(),\n cls: (el.className && typeof el.className === 'string') ? el.className.trim().split(/\\\\s+/).slice(0, 2).join(' ') : '',\n text,\n matchedIncludes: matched,\n childCount: el.children.length,\n h: Math.round(el.getBoundingClientRect().height),\n };\n }),\n });\n }\n }\n }\n\n // Sort: list containers first (more items = better), then by depth\n containers.sort((a, b) => {\n if (a.isList !== b.isList) return a.isList ? -1 : 1;\n return b.listItemCount - a.listItemCount || b.depth - a.depth;\n });\n\n return JSON.stringify({\n results: containers.slice(0, 10),\n includeCount: includes.length,\n excludeCount: excludes.length,\n });\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 handleFindByText(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { text, ideType, containerSelector } = body;\n if (!text || typeof text !== 'string') { this.json(res, 400, { error: 'text is required' }); return; }\n const cdp = this.getCdp(ideType);\n if (!cdp) { this.json(res, 503, { error: 'No CDP connection' }); return; }\n\n const containerArg = containerSelector ? JSON.stringify(containerSelector) : 'null';\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 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 parentSig(el) {\n // Signature: tag+class chain up 3 levels\n const parts = [];\n let c = el;\n for (let i = 0; i < 3 && c; i++) { parts.push(gs(c)); c = c.parentElement; }\n return parts.join(' < ');\n }\n\n const searchText = ${JSON.stringify(text)}.toLowerCase();\n const container = ${containerArg} ? document.querySelector(${containerArg}) : document.body;\n if (!container) return JSON.stringify({ error: 'Container not found' });\n\n const matches = [];\n const seen = new Set();\n\n // Find all text nodes containing the search text\n const walker = document.createTreeWalker(container, NodeFilter.SHOW_TEXT, {\n acceptNode: n => n.textContent.toLowerCase().includes(searchText) ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_REJECT\n });\n let node;\n while ((node = walker.nextNode()) && matches.length < 50) {\n // Walk up to find the most specific visible element\n let el = node.parentElement;\n if (!el) continue;\n\n // Skip hidden elements\n const r = el.getBoundingClientRect();\n if (r.width === 0 && r.height === 0) continue;\n\n const selector = fp(el);\n if (seen.has(selector)) continue;\n seen.add(selector);\n\n // Walk up parent chain — record each level's selector + sibling count\n const ancestors = [];\n let cur = el;\n let pLvl = cur.parentElement;\n for (let lvl = 0; lvl < 10 && pLvl && pLvl !== document.body; lvl++) {\n const mySig = cur.tagName + '|' + ((cur.className && typeof cur.className === 'string') ? cur.className.trim().split(/\\\\s+/).sort().join('.') : '');\n const sibs = [...pLvl.children].filter(c => {\n const sig = c.tagName + '|' + ((c.className && typeof c.className === 'string') ? c.className.trim().split(/\\\\s+/).sort().join('.') : '');\n return sig === mySig;\n });\n const childSel = gs(cur).replace(/:nth-child\\\\(\\\\d+\\\\)/, '');\n ancestors.push({\n parentSelector: fp(pLvl),\n childSelector: childSel,\n fullSelector: fp(pLvl) + ' > ' + childSel,\n siblingCount: sibs.length,\n parentTag: pLvl.tagName.toLowerCase(),\n });\n cur = pLvl;\n pLvl = pLvl.parentElement;\n }\n\n const directText = (node.textContent || '').trim().substring(0, 200);\n const allText = (node.parentElement.textContent || '').trim().substring(0, 300);\n const tag = node.parentElement.tagName.toLowerCase();\n const cls = (node.parentElement.className && typeof node.parentElement.className === 'string')\n ? node.parentElement.className.trim().split(/\\\\s+/).filter(Boolean) : [];\n\n matches.push({\n selector,\n tag,\n cls,\n directText,\n allText,\n ancestors,\n rect: { w: Math.round(r.width), h: Math.round(r.height) },\n depth: selector.split(' > ').length,\n });\n }\n\n // Sort: prefer elements with more siblings in ancestry, then fewer depth\n matches.sort((a, b) => {\n const aMax = Math.max(1, ...a.ancestors.map(x => x.siblingCount));\n const bMax = Math.max(1, ...b.ancestors.map(x => x.siblingCount));\n return (bMax - aMax) || (a.depth - b.depth);\n });\n\n return JSON.stringify({ query: ${JSON.stringify(text)}, matches, total: matches.length });\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 // ─── Phase 1: DOM Context API ───\n\n private async handleDomContext(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { ideType } = body;\n const provider = this.providerLoader.resolve(type);\n if (!provider) { this.json(res, 404, { error: `Provider not found: ${type}` }); return; }\n\n const cdp = this.getCdp(ideType || type);\n if (!cdp) { this.json(res, 503, { error: 'No CDP connection available. Target IDE must be running with CDP enabled.' }); return; }\n\n try {\n // 1. Capture screenshot\n let screenshot: string | null = null;\n try {\n const buf = await cdp.captureScreenshot();\n if (buf) screenshot = buf.toString('base64');\n } catch { /* screenshot optional */ }\n\n // 2. Collect DOM snapshot\n const domScript = `(() => {\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 rect(el) {\n 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) }; }\n catch { return null; }\n }\n\n const result = { contentEditables: [], chatContainers: [], buttons: [], sidebars: [], dropdowns: [], inputs: [] };\n\n // Content editables + textareas + inputs\n document.querySelectorAll('[contenteditable], textarea, input[type=\"text\"], input:not([type])').forEach(el => {\n if (el.offsetWidth === 0 && el.offsetHeight === 0) return;\n result.contentEditables.push({\n selector: fp(el),\n tag: el.tagName.toLowerCase(),\n contenteditable: el.getAttribute('contenteditable'),\n role: el.getAttribute('role'),\n ariaLabel: el.getAttribute('aria-label'),\n placeholder: el.getAttribute('placeholder'),\n rect: rect(el),\n visible: el.offsetParent !== null || el.offsetWidth > 0,\n });\n });\n\n // Chat containers — large divs with scroll\n document.querySelectorAll('div, section, main').forEach(el => {\n const style = getComputedStyle(el);\n const isScrollable = style.overflowY === 'auto' || style.overflowY === 'scroll';\n const r = el.getBoundingClientRect();\n if (!isScrollable || r.height < 200 || r.width < 200) return;\n const childCount = el.children.length;\n if (childCount < 2) return;\n result.chatContainers.push({\n selector: fp(el),\n childCount,\n rect: { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) },\n hasScrollable: true,\n scrollTop: Math.round(el.scrollTop),\n scrollHeight: Math.round(el.scrollHeight),\n });\n });\n\n // Buttons\n document.querySelectorAll('button, [role=\"button\"]').forEach(el => {\n if (el.offsetWidth === 0 && el.offsetHeight === 0) return;\n const text = (el.textContent || '').trim().substring(0, 80);\n if (!text && !el.getAttribute('aria-label')) return;\n result.buttons.push({\n text,\n ariaLabel: el.getAttribute('aria-label'),\n selector: fp(el),\n rect: rect(el),\n disabled: el.disabled || el.getAttribute('aria-disabled') === 'true',\n });\n });\n\n // Sidebars — panels on left/right edges\n document.querySelectorAll('[class*=\"sidebar\"], [class*=\"side-bar\"], [class*=\"panel\"], [role=\"complementary\"], [role=\"navigation\"], aside').forEach(el => {\n if (el.offsetWidth === 0 && el.offsetHeight === 0) return;\n const r = el.getBoundingClientRect();\n if (r.width < 50 || r.height < 200) return;\n result.sidebars.push({\n selector: fp(el),\n position: r.x < window.innerWidth / 3 ? 'left' : r.x > window.innerWidth * 2 / 3 ? 'right' : 'center',\n rect: { x: Math.round(r.x), y: Math.round(r.y), w: Math.round(r.width), h: Math.round(r.height) },\n childCount: el.children.length,\n });\n });\n\n // Dropdowns — select, popover, menu patterns\n document.querySelectorAll('select, [role=\"listbox\"], [role=\"menu\"], [role=\"combobox\"], [class*=\"dropdown\"], [class*=\"popover\"]').forEach(el => {\n result.dropdowns.push({\n selector: fp(el),\n tag: el.tagName.toLowerCase(),\n role: el.getAttribute('role'),\n visible: el.offsetParent !== null || el.offsetWidth > 0,\n rect: rect(el),\n });\n });\n\n return JSON.stringify(result);\n })()`;\n\n const raw = await cdp.evaluate(domScript, 15000);\n let domSnapshot: any = {};\n if (typeof raw === 'string') { try { domSnapshot = JSON.parse(raw); } catch { domSnapshot = { raw }; } }\n else domSnapshot = raw;\n\n this.json(res, 200, {\n screenshot: screenshot ? `base64:${screenshot}` : null,\n domSnapshot,\n pageTitle: await cdp.evaluate('document.title', 3000).catch(() => ''),\n pageUrl: await cdp.evaluate('window.location.href', 3000).catch(() => ''),\n providerType: type,\n timestamp: new Date().toISOString(),\n });\n } catch (e: any) {\n this.json(res, 500, { error: `DOM context collection failed: ${e.message}` });\n }\n }\n\n // ─── Phase 2: Auto-Implement Backend ───\n\n private async handleAutoImplement(type: string, req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { agent = 'claude-cli', functions, reference = 'antigravity', model } = body;\n if (!functions || !Array.isArray(functions) || functions.length === 0) {\n this.json(res, 400, { error: 'functions[] is required (e.g. [\"readChat\", \"sendMessage\"])' });\n return;\n }\n\n if (this.autoImplStatus.running) {\n this.json(res, 409, { error: 'Auto-implement already in progress', type: this.autoImplStatus.type });\n return;\n }\n\n const provider = this.providerLoader.resolve(type);\n if (!provider) { this.json(res, 404, { error: `Provider not found: ${type}` }); return; }\n\n const providerDir = this.findProviderDir(type);\n if (!providerDir) { this.json(res, 404, { error: `Provider directory not found: ${type}` }); return; }\n\n try {\n // 1. Collect DOM context\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'analyzing', message: 'DOM 구조 수집 중...' } });\n\n let domContext: any = null;\n const cdp = this.getCdp(type);\n if (cdp) {\n try {\n const domScript = `(() => {\n function fp(el) {\n if (!el || el === document.body) return 'body';\n const parts = [];\n let c = el;\n while (c && c !== document.documentElement) {\n let s = c.tagName.toLowerCase();\n if (c.id) s = '#' + c.id;\n else if (c.className && typeof c.className === 'string') {\n const cls = c.className.trim().split(/\\\\s+/).filter(x => x && !x.startsWith('_')).slice(0, 2);\n if (cls.length) s += '.' + cls.join('.');\n }\n parts.unshift(s);\n c = c.parentElement;\n }\n return parts.join(' > ');\n }\n const r = {};\n // Content editables\n r.editables = [...document.querySelectorAll('[contenteditable], textarea, input')].filter(e => e.offsetWidth > 0).slice(0, 10).map(e => ({\n selector: fp(e), tag: e.tagName.toLowerCase(), ce: e.getAttribute('contenteditable'), role: e.getAttribute('role'), ph: e.getAttribute('placeholder')\n }));\n // Scroll containers\n r.scrollContainers = [...document.querySelectorAll('div, section')].filter(e => {\n const s = getComputedStyle(e); const b = e.getBoundingClientRect();\n return (s.overflowY === 'auto' || s.overflowY === 'scroll') && b.height > 200 && e.children.length > 2;\n }).slice(0, 5).map(e => ({ selector: fp(e), children: e.children.length, h: Math.round(e.getBoundingClientRect().height) }));\n // Buttons\n r.buttons = [...document.querySelectorAll('button, [role=\"button\"]')].filter(e => e.offsetWidth > 0).slice(0, 20).map(e => ({\n text: (e.textContent||'').trim().substring(0, 60), selector: fp(e), label: e.getAttribute('aria-label')\n }));\n return JSON.stringify(r);\n })()`;\n const raw = await cdp.evaluate(domScript, 10000);\n domContext = typeof raw === 'string' ? JSON.parse(raw) : raw;\n } catch (e: any) {\n this.log(`DOM context collection failed (non-fatal): ${e.message}`);\n }\n }\n\n // 2. Load reference scripts\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'loading_reference', message: `레퍼런스 스크립트 로드 중 (${reference})...` } });\n\n let referenceScripts: Record<string, string> = {};\n const builtinDir = (this.providerLoader as any).builtinDir || path.resolve(__dirname, '../providers/_builtin');\n const refDir = path.join(builtinDir, 'ide', reference);\n if (fs.existsSync(refDir)) {\n // Find latest versioned scripts dir\n const scriptsDir = path.join(refDir, 'scripts');\n if (fs.existsSync(scriptsDir)) {\n const versions = fs.readdirSync(scriptsDir).filter((d: string) => {\n try { return fs.statSync(path.join(scriptsDir, d)).isDirectory(); } catch { return false; }\n }).sort().reverse();\n if (versions.length > 0) {\n const latestDir = path.join(scriptsDir, versions[0]);\n for (const file of fs.readdirSync(latestDir)) {\n if (file.endsWith('.js')) {\n try {\n referenceScripts[file] = fs.readFileSync(path.join(latestDir, file), 'utf-8');\n } catch { /* skip */ }\n }\n }\n }\n }\n }\n\n // 3. Build the prompt\n const prompt = this.buildAutoImplPrompt(type, provider, providerDir, functions, domContext, referenceScripts);\n\n // 4. Write prompt to temp file (avoids shell escaping issues with special chars)\n const tmpDir = path.join(os.tmpdir(), 'adhdev-autoimpl');\n if (!fs.existsSync(tmpDir)) fs.mkdirSync(tmpDir, { recursive: true });\n const promptFile = path.join(tmpDir, `prompt-${type}-${Date.now()}.md`);\n fs.writeFileSync(promptFile, prompt, 'utf-8');\n this.log(`Auto-implement prompt written to ${promptFile} (${prompt.length} chars)`);\n\n // 5. Determine agent command from provider spawn config\n const agentProvider = this.providerLoader.resolve(agent) || this.providerLoader.getMeta(agent);\n const spawn = (agentProvider as any)?.spawn;\n if (!spawn?.command) {\n try { fs.unlinkSync(promptFile); } catch { /* ignore */ }\n this.json(res, 400, { error: `Agent '${agent}' has no spawn config. Select a CLI provider with a spawn configuration.` });\n return;\n }\n\n const agentCategory = (agentProvider as any)?.category;\n\n // ─── ACP Agent: use ACP SDK (JSON-RPC protocol) ───\n if (agentCategory === 'acp') {\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'spawning', message: `ACP 에이전트 실행 중: ${spawn.command} ${(spawn.args || []).join(' ')}` } });\n this.autoImplStatus = { running: true, type, progress: [] };\n\n // Dynamic import ACP SDK\n const { ClientSideConnection, ndJsonStream, PROTOCOL_VERSION } = await import('@agentclientprotocol/sdk');\n const { Readable, Writable } = await import('stream');\n const { spawn: spawnFn } = await import('child_process');\n\n // Add model override to spawn args if specified\n const acpArgs = [...(spawn.args || [])];\n if (model) {\n acpArgs.push('--model', model);\n this.log(`Auto-implement ACP using model: ${model}`);\n }\n\n const child = spawnFn(spawn.command, acpArgs, {\n cwd: providerDir,\n stdio: ['pipe', 'pipe', 'pipe'],\n shell: spawn.shell ?? false,\n env: { ...process.env, ...(spawn.env || {}) },\n });\n this.autoImplProcess = child;\n\n // stderr → stream to SSE\n child.stderr?.on('data', (d: Buffer) => {\n const chunk = d.toString();\n this.sendAutoImplSSE({ event: 'output', data: { chunk, stream: 'stderr' } });\n });\n\n // Setup ACP connection via SDK\n const webStdin = Writable.toWeb(child.stdin!) as WritableStream<Uint8Array>;\n const webStdout = Readable.toWeb(child.stdout!) as ReadableStream<Uint8Array>;\n const stream = ndJsonStream(webStdin, webStdout);\n\n const connection = new ClientSideConnection((_agent: any) => ({\n // Auto-approve all tool calls for auto-implement\n requestPermission: async (params: any) => {\n const allowOpt = params.options?.find((o: any) => o.kind === 'allow_once') || params.options?.[0];\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `[ACP] Auto-approved: ${params.toolCall?.title || 'tool call'}\\n`, stream: 'stdout' } });\n return { outcome: { outcome: 'selected', optionId: allowOpt?.optionId || '' } };\n },\n sessionUpdate: async (params: any) => {\n const update = params?.update;\n if (!update) return;\n // Stream meaningful output only (skip thought chunks — they're too verbose)\n switch (update.sessionUpdate) {\n case 'agent_message_chunk':\n if (update.content?.text) {\n this.sendAutoImplSSE({ event: 'output', data: { chunk: update.content.text, stream: 'stdout' } });\n }\n break;\n case 'tool_call':\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `\\n🔧 [Tool] ${update.title || 'unknown'}\\n`, stream: 'stdout' } });\n break;\n case 'tool_call_update':\n if (update.status === 'completed' || update.status === 'failed') {\n const label = update.status === 'completed' ? '✅' : '❌';\n const out = update.rawOutput ? (typeof update.rawOutput === 'string' ? update.rawOutput : JSON.stringify(update.rawOutput)) : '';\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `${label} Result: ${out.slice(0, 1000)}\\n`, stream: 'stdout' } });\n }\n break;\n case 'agent_thought_chunk':\n // Skip — too verbose for auto-implement UI\n break;\n default:\n break;\n }\n },\n // Not used for auto-implement\n readTextFile: async () => { throw new Error('not supported'); },\n writeTextFile: async () => { throw new Error('not supported'); },\n createTerminal: async () => { throw new Error('not supported'); },\n terminalOutput: async () => { throw new Error('not supported'); },\n releaseTerminal: async () => { throw new Error('not supported'); },\n waitForTerminalExit: async () => { throw new Error('not supported'); },\n killTerminal: async () => { throw new Error('not supported'); },\n }), stream);\n\n child.on('exit', (code) => {\n this.autoImplProcess = null;\n this.autoImplStatus.running = false;\n const success = code === 0;\n this.sendAutoImplSSE({ event: 'complete', data: { success, exitCode: code, functions, message: success ? '✅ ACP Auto-implement 완료' : `❌ ACP 에이전트 종료 (code: ${code})` } });\n try { this.providerLoader.reload(); } catch { /* ignore */ }\n try { fs.unlinkSync(promptFile); } catch { /* ignore */ }\n this.log(`Auto-implement (ACP) ${success ? 'completed' : 'failed'}: ${type} (exit: ${code})`);\n });\n\n // ACP handshake flow (async, runs in background)\n (async () => {\n try {\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'initializing', message: 'ACP initialize...' } });\n await connection.initialize({ protocolVersion: PROTOCOL_VERSION, clientCapabilities: {} });\n\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'session', message: 'ACP session 생성 중...' } });\n const session = await connection.newSession({ cwd: providerDir, mcpServers: [] });\n const sessionId = session?.sessionId;\n if (!sessionId) throw new Error('No sessionId returned from session/new');\n\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'prompting', message: `프롬프트 전송 중 (${prompt.length} chars)...` } });\n await connection.prompt({\n sessionId,\n prompt: [{ type: 'text', text: prompt }],\n });\n\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_done', status: 'complete', message: '✅ ACP 프롬프트 처리 완료' } });\n } catch (e: any) {\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `[ACP Error] ${e.message}\\n`, stream: 'stderr' } });\n this.log(`Auto-implement ACP error: ${e.message}`);\n // Process exit will trigger the 'complete' SSE event\n if (child.exitCode === null) { child.kill('SIGTERM'); }\n }\n })();\n\n this.json(res, 202, {\n started: true, type, agent: spawn.command, functions, providerDir,\n message: 'ACP Auto-implement started. Connect to SSE for progress.',\n sseUrl: `/api/providers/${type}/auto-implement/status`,\n });\n return;\n }\n\n // ─── CLI Agent: stdin pipe approach ───\n const command: string = spawn.command;\n // Strip interactive-only flags for auto-implement (non-interactive mode)\n const interactiveFlags = ['--yolo', '--interactive', '-i'];\n const baseArgs: string[] = [...(spawn.args || [])].filter((a: string) => !interactiveFlags.includes(a));\n let args: string[];\n let useStdin = true;\n\n if (command === 'claude') {\n // Claude Code: --print mode, skip permissions for non-interactive auto-implement\n args = [...baseArgs, '--print', '--dangerously-skip-permissions', '--add-dir', providerDir];\n useStdin = true;\n } else if (command === 'gemini') {\n // Gemini CLI: -p (non-interactive mode) with stdin piped prompt\n // -p \"\" means \"non-interactive mode, read prompt from stdin\"\n // -y for yolo (auto-approve all), -s false for no sandbox\n args = [...baseArgs, '-p', '', '-y', '-s', 'false'];\n if (model) {\n args.push('-m', model);\n }\n useStdin = true;\n } else {\n // Codex CLI, etc: pipe prompt via stdin\n args = [...baseArgs];\n }\n\n // 5.5. Check agent binary exists\n const { execSync } = await import('child_process');\n try {\n execSync(`which ${command}`, { stdio: 'pipe' });\n } catch {\n try { fs.unlinkSync(promptFile); } catch { /* ignore */ }\n this.json(res, 400, { error: `Agent binary '${command}' not found on PATH. Install it first: ${(agentProvider as any)?.install || 'check provider docs'}` });\n return;\n }\n\n // 6. Spawn CLI agent via shell pipe (avoids Node.js stdin deadlock on large prompts)\n this.sendAutoImplSSE({ event: 'progress', data: { function: '_init', status: 'spawning', message: `에이전트 실행 중: ${command} ${args.join(' ')} (prompt: ${prompt.length} chars)` } });\n\n this.autoImplStatus = { running: true, type, progress: [] };\n\n const { spawn: spawnFn } = await import('child_process');\n // Shell pipe: cat promptFile | command args...\n // This avoids Node.js stdin buffer deadlock and ensures proper EOF signaling\n const escapedArgs = args.map(a => `'${a.replace(/'/g, \"'\\\\''\")}'`).join(' ');\n const shellCmd = `cat '${promptFile}' | ${command} ${escapedArgs}`;\n this.log(`Auto-implement spawn: ${shellCmd}`);\n const child = spawnFn('sh', ['-c', shellCmd], {\n cwd: providerDir,\n shell: false,\n timeout: 900000, // 15 min timeout\n stdio: ['ignore', 'pipe', 'pipe'],\n env: { ...process.env, ...(spawn.env || {}) },\n });\n this.autoImplProcess = child;\n child.on('error', (err) => {\n this.log(`Auto-implement spawn error: ${err.message}`);\n this.sendAutoImplSSE({ event: 'output', data: { chunk: `[Spawn Error] ${err.message}\\n`, stream: 'stderr' } });\n });\n\n let stdout = '';\n let stderr = '';\n child.stdout?.on('data', (d: Buffer) => {\n const chunk = d.toString();\n stdout += chunk;\n this.sendAutoImplSSE({ event: 'output', data: { chunk, stream: 'stdout' } });\n });\n child.stderr?.on('data', (d: Buffer) => {\n const chunk = d.toString();\n stderr += chunk;\n this.sendAutoImplSSE({ event: 'output', data: { chunk, stream: 'stderr' } });\n });\n\n child.on('exit', (code) => {\n this.autoImplProcess = null;\n this.autoImplStatus.running = false;\n const success = code === 0;\n this.sendAutoImplSSE({\n event: 'complete',\n data: {\n success,\n exitCode: code,\n functions,\n message: success ? '✅ Auto-implement 완료' : `❌ 에이전트 종료 (code: ${code})`,\n },\n });\n // Reload providers to pick up new scripts\n try { this.providerLoader.reload(); } catch { /* ignore */ }\n // Cleanup temp prompt file\n try { fs.unlinkSync(promptFile); } catch { /* ignore */ }\n this.log(`Auto-implement ${success ? 'completed' : 'failed'}: ${type} (exit: ${code})`);\n });\n\n this.json(res, 202, {\n started: true,\n type,\n agent: command,\n functions,\n providerDir,\n message: 'Auto-implement started. Connect to SSE for progress.',\n sseUrl: `/api/providers/${type}/auto-implement/status`,\n });\n } catch (e: any) {\n this.autoImplStatus.running = false;\n this.json(res, 500, { error: `Auto-implement failed: ${e.message}` });\n }\n }\n\n private buildAutoImplPrompt(\n type: string,\n provider: any,\n providerDir: string,\n functions: string[],\n domContext: any,\n referenceScripts: Record<string, string>,\n ): string {\n const lines: string[] = [];\n\n // ── System instructions ──\n lines.push('You are implementing browser automation scripts for an IDE provider.');\n lines.push('Be concise. Do NOT explain your reasoning. Just edit files directly.');\n lines.push('');\n\n // ── Target ──\n lines.push(`# Target: ${provider.name || type} (${type})`);\n lines.push(`Provider directory: \\`${providerDir}\\``);\n lines.push('');\n\n // ── Existing target files (inline, so no reading needed) ──\n lines.push('## Current Target Files');\n lines.push('These are the files you need to EDIT. They contain TODO stubs — replace them with working implementations.');\n lines.push('');\n\n const scriptsDir = path.join(providerDir, 'scripts');\n if (fs.existsSync(scriptsDir)) {\n const versions = fs.readdirSync(scriptsDir).filter((d: string) => {\n try { return fs.statSync(path.join(scriptsDir, d)).isDirectory(); } catch { return false; }\n }).sort().reverse();\n if (versions.length > 0) {\n const vDir = path.join(scriptsDir, versions[0]);\n lines.push(`Scripts version directory: \\`${vDir}\\``);\n lines.push('');\n for (const file of fs.readdirSync(vDir)) {\n if (file.endsWith('.js')) {\n try {\n const content = fs.readFileSync(path.join(vDir, file), 'utf-8');\n lines.push(`### \\`${file}\\``);\n lines.push('```javascript');\n lines.push(content);\n lines.push('```');\n lines.push('');\n } catch { /* skip */ }\n }\n }\n }\n }\n\n // ── DOM context ──\n if (domContext) {\n lines.push('## Live DOM Analysis (from CDP)');\n lines.push('Use these selectors in your implementations:');\n lines.push('```json');\n lines.push(JSON.stringify(domContext, null, 2));\n lines.push('```');\n lines.push('');\n }\n\n // ── Reference implementation ──\n const funcToFile: Record<string, string> = {\n readChat: 'read_chat.js', sendMessage: 'send_message.js',\n resolveAction: 'resolve_action.js', listSessions: 'list_sessions.js',\n listChats: 'list_chats.js', switchSession: 'switch_session.js',\n newSession: 'new_session.js', focusEditor: 'focus_editor.js',\n openPanel: 'open_panel.js', listModels: 'list_models.js',\n listModes: 'list_modes.js', setModel: 'set_model.js', setMode: 'set_mode.js',\n };\n\n if (Object.keys(referenceScripts).length > 0) {\n lines.push('## Reference Implementation (from Antigravity provider)');\n lines.push('These are WORKING scripts from another IDE. Adapt the PATTERNS (not selectors) for the target IDE.');\n lines.push('');\n for (const fn of functions) {\n const fileName = funcToFile[fn];\n if (fileName && referenceScripts[fileName]) {\n lines.push(`### ${fn} → \\`${fileName}\\``);\n lines.push('```javascript');\n lines.push(referenceScripts[fileName]);\n lines.push('```');\n lines.push('');\n }\n }\n if (referenceScripts['scripts.js']) {\n lines.push('### Router → `scripts.js`');\n lines.push('```javascript');\n lines.push(referenceScripts['scripts.js']);\n lines.push('```');\n lines.push('');\n }\n }\n\n // ── Task ──\n lines.push('## Task');\n lines.push(`Edit files in \\`${providerDir}\\` to implement: **${functions.join(', ')}**`);\n lines.push('');\n\n // ── Rules ──\n lines.push('## Rules');\n lines.push('1. **Scripts WITHOUT params** → IIFE: `(() => { ... })()`');\n lines.push('2. **Scripts WITH params** → arrow: `(params) => { ... }` — router calls `(${script})(${JSON.stringify(params)})`');\n lines.push('3. Use CSS selectors from the DOM analysis above');\n lines.push('4. Always wrap in try-catch, return `JSON.stringify(result)`');\n lines.push('5. Do NOT modify `scripts.js` router — only edit individual `*.js` files');\n lines.push('6. All scripts run in the browser (CDP evaluate) — use DOM APIs only');\n lines.push('');\n\n // ── Output contracts ──\n lines.push('## Required Return Format');\n lines.push('| Function | Return JSON |');\n lines.push('|---|---|');\n lines.push('| readChat | `{ id, status, title, messages: [{role, content, index, kind?, meta?}], inputContent, activeModal }` — optional `kind`: standard, thought, tool, terminal; optional `meta`: e.g. `{ label, isRunning }` for dashboard |');\n lines.push('| sendMessage | `{ sent: false, needsTypeAndSend: true, selector }` |');\n lines.push('| resolveAction | `{ resolved: true/false, clicked? }` |');\n lines.push('| listSessions | `{ sessions: [{ id, title, active, index }] }` |');\n lines.push('| switchSession | `{ switched: true/false }` |');\n lines.push('| newSession | `{ created: true/false }` |');\n lines.push('| listModels | `{ models: [{ name, id }], current }` |');\n lines.push('| setModel | `{ success: true/false }` |');\n lines.push('| listModes | `{ modes: [{ name, id }], current }` |');\n lines.push('| setMode | `{ success: true/false }` |');\n lines.push('| focusEditor | `{ focused: true/false }` |');\n lines.push('| openPanel | `{ opened: true/false }` |');\n lines.push('');\n\n lines.push('## Action');\n lines.push('1. Edit the script files to implement working code');\n lines.push('2. After editing, TEST each function using the DevConsole API (see below)');\n lines.push('3. If a test fails, fix the implementation and re-test');\n lines.push('');\n\n // ── DevConsole API for verification ──\n lines.push('## DevConsole API (for testing)');\n lines.push(`The DevConsole is running at \\`http://127.0.0.1:${DEV_SERVER_PORT}\\`. Use these HTTP APIs to test your implementations.`);\n lines.push('');\n lines.push('### Run a script against the live IDE');\n lines.push('```bash');\n lines.push(`curl -X POST http://127.0.0.1:${DEV_SERVER_PORT}/api/providers/${type}/scripts/run \\\\`);\n lines.push(` -H \"Content-Type: application/json\" \\\\`);\n lines.push(` -d '{\"script\": \"readChat\"}'`);\n lines.push('```');\n lines.push('Replace `\"readChat\"` with any function name. For functions with params:');\n lines.push('```bash');\n lines.push(`curl -X POST http://127.0.0.1:${DEV_SERVER_PORT}/api/providers/${type}/scripts/run \\\\`);\n lines.push(` -H \"Content-Type: application/json\" \\\\`);\n lines.push(` -d '{\"script\": \"sendMessage\", \"params\": {\"text\": \"hello\"}}'`);\n lines.push('```');\n lines.push('');\n lines.push('### Evaluate raw JS in the IDE (CDP)');\n lines.push('```bash');\n lines.push(`curl -X POST http://127.0.0.1:${DEV_SERVER_PORT}/api/cdp/evaluate \\\\`);\n lines.push(` -H \"Content-Type: application/json\" \\\\`);\n lines.push(` -d '{\"expression\": \"document.title\", \"ideType\": \"${type}\"}'`);\n lines.push('```');\n lines.push('');\n lines.push('### Reload provider (after editing files)');\n lines.push('```bash');\n lines.push(`curl -X POST http://127.0.0.1:${DEV_SERVER_PORT}/api/providers/reload`);\n lines.push('```');\n lines.push('**IMPORTANT**: After editing script files, you MUST call reload before running scripts.');\n lines.push('');\n lines.push('### Workflow: Edit → Reload → Test → Fix');\n lines.push('1. Edit the `.js` file');\n lines.push('2. `curl POST /api/providers/reload`');\n lines.push(`3. \\`curl POST /api/providers/${type}/scripts/run -d '{\"script\":\"readChat\"}'\\``);\n lines.push('4. Check the response — if error, fix and repeat from step 1');\n lines.push('');\n lines.push('Start NOW. Edit files, then test each one.');\n\n return lines.join('\\n');\n }\n\n private handleAutoImplSSE(type: string, 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: ${JSON.stringify({ type: 'connected', running: this.autoImplStatus.running, providerType: type })}\\n\\n`);\n\n // Replay existing progress\n for (const p of this.autoImplStatus.progress) {\n res.write(`event: ${p.event}\\ndata: ${JSON.stringify(p.data)}\\n\\n`);\n }\n\n this.autoImplSSEClients.push(res);\n req.on('close', () => {\n this.autoImplSSEClients = this.autoImplSSEClients.filter(c => c !== res);\n });\n }\n\n private handleAutoImplCancel(_type: string, _req: http.IncomingMessage, res: http.ServerResponse): void {\n if (this.autoImplProcess) {\n this.autoImplProcess.kill('SIGTERM');\n setTimeout(() => { if (this.autoImplProcess) this.autoImplProcess.kill('SIGKILL'); }, 3000);\n this.sendAutoImplSSE({ event: 'complete', data: { success: false, exitCode: -1, message: '⛔ 사용자에 의해 중단됨' } });\n this.autoImplProcess = null;\n this.autoImplStatus.running = false;\n this.json(res, 200, { cancelled: true });\n } else {\n this.autoImplStatus.running = false;\n this.json(res, 200, { cancelled: false, message: 'No running process' });\n }\n }\n\n private sendAutoImplSSE(msg: { event: string; data: any }): void {\n this.autoImplStatus.progress.push(msg);\n const payload = `event: ${msg.event}\\ndata: ${JSON.stringify(msg.data)}\\n\\n`;\n for (const client of this.autoImplSSEClients) {\n try { client.write(payload); } catch { /* ignore */ }\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 // ─── CLI Debug Handlers ──────────────────────────────\n\n /** GET /api/cli/status — list all running CLI/ACP instances with state */\n private async handleCliStatus(_req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n if (!this.instanceManager) {\n this.json(res, 503, { error: 'InstanceManager not available (daemon not fully initialized)' });\n return;\n }\n const allStates = this.instanceManager.collectAllStates();\n const cliStates = allStates.filter(s => s.category === 'cli' || s.category === 'acp');\n const result = cliStates.map(s => ({\n instanceId: s.instanceId,\n type: s.type,\n name: s.name,\n category: s.category,\n status: s.status,\n mode: s.mode,\n workspace: s.workspace,\n messageCount: s.activeChat?.messages?.length || 0,\n lastMessage: s.activeChat?.messages?.slice(-1)[0] || null,\n activeModal: s.activeChat?.activeModal || null,\n pendingEvents: s.pendingEvents || [],\n currentModel: s.currentModel,\n settings: s.settings,\n }));\n this.json(res, 200, { instances: result, count: result.length });\n }\n\n /** POST /api/cli/launch — launch a CLI agent { type, workingDir?, args? } */\n private async handleCliLaunch(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n if (!this.cliManager) {\n this.json(res, 503, { error: 'CliManager not available' });\n return;\n }\n const body = await this.readBody(req);\n const { type, workingDir, args } = body;\n if (!type) {\n this.json(res, 400, { error: 'type required (e.g. claude-cli, gemini-cli)' });\n return;\n }\n try {\n await this.cliManager.startSession(type, workingDir || process.cwd(), args || []);\n this.json(res, 200, { launched: true, type, workspace: workingDir || process.cwd() });\n } catch (e: any) {\n this.json(res, 500, { error: `Launch failed: ${e.message}` });\n }\n }\n\n /** POST /api/cli/send — send message to a running CLI { type, text } */\n private async handleCliSend(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n if (!this.instanceManager) {\n this.json(res, 503, { error: 'InstanceManager not available' });\n return;\n }\n const body = await this.readBody(req);\n const { type, text, instanceId } = body;\n if (!text) {\n this.json(res, 400, { error: 'text required' });\n return;\n }\n\n // Find the CLI instance by type or instanceId\n const allStates = this.instanceManager.collectAllStates();\n const target = allStates.find(s =>\n (s.category === 'cli' || s.category === 'acp') &&\n (instanceId ? s.instanceId === instanceId : s.type === type)\n );\n if (!target) {\n this.json(res, 404, { error: `No running instance found for: ${type || instanceId}` });\n return;\n }\n\n try {\n this.instanceManager.sendEvent(target.instanceId, 'send_message', { text });\n this.json(res, 200, { sent: true, type: target.type, instanceId: target.instanceId });\n } catch (e: any) {\n this.json(res, 500, { error: `Send failed: ${e.message}` });\n }\n }\n\n /** POST /api/cli/stop — stop a running CLI { type } */\n private async handleCliStop(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n if (!this.instanceManager) {\n this.json(res, 503, { error: 'InstanceManager not available' });\n return;\n }\n const body = await this.readBody(req);\n const { type, instanceId } = body;\n\n const allStates = this.instanceManager.collectAllStates();\n const target = allStates.find(s =>\n (s.category === 'cli' || s.category === 'acp') &&\n (instanceId ? s.instanceId === instanceId : s.type === type)\n );\n if (!target) {\n this.json(res, 404, { error: `No running instance found for: ${type || instanceId}` });\n return;\n }\n\n try {\n this.instanceManager.removeInstance(target.instanceId);\n this.json(res, 200, { stopped: true, type: target.type, instanceId: target.instanceId });\n } catch (e: any) {\n this.json(res, 500, { error: `Stop failed: ${e.message}` });\n }\n }\n\n /** GET /api/cli/events — SSE stream of CLI status events */\n private handleCliSSE(_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.cliSSEClients.push(res);\n\n // Register event listener if first client + instanceManager available\n if (this.cliSSEClients.length === 1 && this.instanceManager) {\n this.instanceManager.onEvent((event) => {\n this.sendCliSSE(event);\n });\n }\n\n // Send current state snapshot immediately\n if (this.instanceManager) {\n const allStates = this.instanceManager.collectAllStates();\n const cliStates = allStates.filter(s => s.category === 'cli' || s.category === 'acp');\n for (const s of cliStates) {\n this.sendCliSSE({ event: 'snapshot', providerType: s.type, status: s.status, instanceId: s.instanceId });\n }\n }\n\n _req.on('close', () => {\n this.cliSSEClients = this.cliSSEClients.filter(c => c !== res);\n });\n }\n\n private sendCliSSE(data: any): void {\n const msg = `data: ${JSON.stringify({ ...data, timestamp: Date.now() })}\\n\\n`;\n for (const client of this.cliSSEClients) {\n try { client.write(msg); } catch { /* ignore */ }\n }\n }\n\n /** GET /api/cli/debug/:type — full internal debug state of a CLI adapter */\n private async handleCliDebug(type: string, _req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n if (!this.instanceManager) {\n this.json(res, 503, { error: 'InstanceManager not available' });\n return;\n }\n\n // Find the matching CLI instance\n const allStates = this.instanceManager.collectAllStates();\n const target = allStates.find(s =>\n (s.category === 'cli' || s.category === 'acp') && s.type === type\n );\n if (!target) {\n this.json(res, 404, { error: `No running instance for: ${type}`, available: allStates.filter(s => s.category === 'cli' || s.category === 'acp').map(s => s.type) });\n return;\n }\n\n // Get the ProviderInstance and access adapter debug state\n const instance = this.instanceManager.getInstance(target.instanceId) as any;\n if (!instance) {\n this.json(res, 404, { error: `Instance not found: ${target.instanceId}` });\n return;\n }\n\n try {\n const adapter = instance.getAdapter?.() || instance.adapter;\n if (adapter && typeof adapter.getDebugState === 'function') {\n const debugState = adapter.getDebugState();\n this.json(res, 200, {\n instanceId: target.instanceId,\n providerState: {\n type: target.type,\n name: target.name,\n status: target.status,\n mode: 'mode' in target ? target.mode : undefined,\n },\n debug: debugState,\n });\n } else {\n // Fallback: return what we can from the state\n this.json(res, 200, {\n instanceId: target.instanceId,\n providerState: target,\n debug: null,\n message: 'No debug state available (adapter.getDebugState not found)',\n });\n }\n } catch (e: any) {\n this.json(res, 500, { error: `Debug state failed: ${e.message}` });\n }\n }\n\n /** POST /api/cli/resolve — resolve an approval modal { type, buttonIndex } */\n private async handleCliResolve(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { type, buttonIndex, instanceId } = body;\n if (buttonIndex === undefined || buttonIndex === null) {\n this.json(res, 400, { error: 'buttonIndex required (0=Yes, 1=Always, 2=Deny)' });\n return;\n }\n\n if (!this.cliManager) {\n this.json(res, 503, { error: 'CliManager not available' });\n return;\n }\n // Find adapter from cliManager.adapters map\n let adapter: any = null;\n for (const [, a] of this.cliManager.adapters) {\n if (type && (a as any).cliType === type) { adapter = a; break; }\n }\n if (!adapter) {\n this.json(res, 404, { error: `No running adapter for: ${type || instanceId}` });\n return;\n }\n try {\n if (typeof adapter.resolveModal === 'function') {\n adapter.resolveModal(buttonIndex);\n this.json(res, 200, { resolved: true, type, buttonIndex });\n } else {\n this.json(res, 400, { error: 'resolveModal not available on this adapter' });\n }\n } catch (e: any) {\n this.json(res, 500, { error: `Resolve failed: ${e.message}` });\n }\n }\n\n /** POST /api/cli/raw — send raw keystrokes to PTY { type, keys } */\n private async handleCliRaw(req: http.IncomingMessage, res: http.ServerResponse): Promise<void> {\n const body = await this.readBody(req);\n const { type, keys, instanceId } = body;\n if (!keys) {\n this.json(res, 400, { error: 'keys required (raw string to send to PTY)' });\n return;\n }\n\n if (!this.cliManager) {\n this.json(res, 503, { error: 'CliManager not available' });\n return;\n }\n let adapter: any = null;\n for (const [, a] of this.cliManager.adapters) {\n if (type && (a as any).cliType === type) { adapter = a; break; }\n }\n if (!adapter) {\n this.json(res, 404, { error: `No running adapter for: ${type || instanceId}` });\n return;\n }\n try {\n if (typeof adapter.writeRaw === 'function') {\n adapter.writeRaw(keys);\n this.json(res, 200, { sent: true, type, keysLength: keys.length });\n } else {\n this.json(res, 400, { error: 'writeRaw not available on this adapter' });\n }\n } catch (e: any) {\n this.json(res, 500, { error: `Raw send failed: ${e.message}` });\n }\n }\n}\n","/**\n * Provider scaffold template generator\n * Generates provider.json + scripts/ directory structure (Antigravity pattern).\n *\n * New pattern:\n * - Scripts WITHOUT params: self-invoking IIFE — (() => { ... })()\n * - Scripts WITH params: function expression — (params) => { ... }\n * Router invokes: `(${script})(${JSON.stringify(params)})`\n * - Each function is a separate .js file in scripts/<version>/\n * - scripts.js router loads + invokes individual files\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 version?: string;\n}\n\nexport interface ScaffoldResult {\n 'provider.json': string;\n files?: Record<string, string>;\n}\n\nexport function generateTemplate(type: string, name: string, category: string, opts: ScaffoldOptions = {}): string {\n const result = generateFiles(type, name, category, opts);\n return result['provider.json'];\n}\n\n/**\n * Generate provider.json + per-function script files.\n * Returns a map of relative paths -> file contents.\n */\nexport function generateFiles(type: string, name: string, category: string, opts: ScaffoldOptions = {}): ScaffoldResult {\n const { cdpPorts, cli, processName, installPath, binary, extensionId, version = '0.1' } = opts;\n\n // ─── CLI / ACP: provider.json only ───\n if (category === 'cli' || category === 'acp') {\n const bin = binary || type;\n const meta: Record<string, any> = {\n type,\n name,\n category,\n icon: '💻',\n binary: bin,\n spawn: {\n command: bin,\n args: [],\n shell: true,\n },\n patterns: {\n prompt: ['^[>$#] '],\n generating: ['\\\\.{3}$', 'thinking'],\n approval: ['\\\\(y\\\\/n\\\\)', 'approve', 'allow'],\n ready: ['ready'],\n },\n };\n return { 'provider.json': JSON.stringify(meta, null, 2) + '\\n' };\n }\n\n // ─── IDE / Extension: provider.json + scripts/ directory ───\n const isExtension = category === 'extension';\n const scriptDir = `scripts/${version}`;\n\n const meta: Record<string, any> = {\n type,\n name,\n category,\n displayName: name,\n icon: isExtension ? '🧩' : '💻',\n };\n if (cli) meta.cli = cli;\n if (cdpPorts) meta.cdpPorts = cdpPorts;\n else if (!isExtension) meta.cdpPorts = [9222, 9223];\n if (processName) meta.processNames = { darwin: processName };\n if (installPath) meta.paths = { darwin: [installPath] };\n if (isExtension) {\n meta.extensionId = extensionId || `publisher.${type}`;\n meta.extensionIdPattern = `${extensionId || type}`;\n } else {\n meta.inputMethod = 'cdp-type-and-send';\n meta.inputSelector = '[contenteditable=\"true\"][role=\"textbox\"]';\n meta.providerVersion = '1.0.0';\n meta.compatibility = [\n { ideVersion: `>=${version}.0`, scriptDir },\n ];\n meta.defaultScriptDir = scriptDir;\n }\n\n // ─── Individual script files ───\n const files: Record<string, string> = {};\n\n // Router (scripts.js)\n files[`${scriptDir}/scripts.js`] = `/**\n * ${name} CDP Scripts — Router\n *\n * Loads individual .js files and invokes with params.\n * Pattern:\n * - No-params scripts: loaded as-is (IIFE)\n * - With-params scripts: \\`(\\${script})(\\${JSON.stringify(params)})\\`\n */\n\n'use strict';\n\nconst fs = require('fs');\nconst path = require('path');\n\nfunction load(name) {\n try { return fs.readFileSync(path.join(__dirname, name), 'utf-8'); }\n catch { return null; }\n}\n\nfunction withParams(name, params) {\n const script = load(name);\n if (!script) return null;\n return \\`(\\${script})(\\${JSON.stringify(params)})\\`;\n}\n\n// ─── Core (no params — IIFE) ───\n\nmodule.exports.readChat = () => load('read_chat.js');\nmodule.exports.sendMessage = () => load('send_message.js');\nmodule.exports.listSessions = () => load('list_sessions.js');\nmodule.exports.newSession = () => load('new_session.js');\nmodule.exports.focusEditor = () => load('focus_editor.js');\nmodule.exports.openPanel = () => load('open_panel.js');\nmodule.exports.listModels = () => load('list_models.js');\nmodule.exports.listModes = () => load('list_modes.js');\n\n// ─── With params (function expression) ───\n\nmodule.exports.switchSession = (params) => {\n const index = typeof params === 'number' ? params : params?.index ?? 0;\n const title = typeof params === 'string' ? params : params?.title || null;\n return withParams('switch_session.js', { index, title });\n};\n\nmodule.exports.resolveAction = (params) => {\n const action = typeof params === 'string' ? params : params?.action || 'approve';\n const buttonText = params?.button || params?.buttonText\n || (action === 'approve' ? 'Accept' : action === 'reject' ? 'Reject' : action);\n return withParams('resolve_action.js', { buttonText });\n};\n\nmodule.exports.setModel = (params) => {\n const model = typeof params === 'string' ? params : params?.model;\n return withParams('set_model.js', { model });\n};\n\nmodule.exports.setMode = (params) => {\n const mode = typeof params === 'string' ? params : params?.mode;\n return withParams('set_mode.js', { mode });\n};\n`;\n\n // read_chat.js — most complex, stub with detailed TODO\n files[`${scriptDir}/read_chat.js`] = `/**\n * ${name} — read_chat\n *\n * Extract chat messages, status, and approval state from DOM.\n *\n * TODO: Identify via CDP/DevConsole:\n * 1. Chat container selector\n * 2. User message selector + class pattern\n * 3. Assistant message selector + class pattern\n * 4. Status detection (generating/idle/waiting_approval)\n * 5. Approval dialog detection (buttons, modal)\n * 6. Input field selector\n *\n * → { id, status, title, messages[], inputContent, activeModal }\n */\n(() => {\n try {\n const messages = [];\n let status = 'idle';\n let activeModal = null;\n\n // TODO: Query chat container and extract messages\n // Example:\n // document.querySelectorAll('.chat-message').forEach(el => {\n // const role = el.classList.contains('user') ? 'user' : 'assistant';\n // messages.push({ role, content: el.innerText.trim(), index: messages.length });\n // });\n\n // TODO: Detect generating state\n // TODO: Detect approval dialogs -> status = 'waiting_approval'\n\n const inputEl = document.querySelector('[contenteditable=\"true\"]');\n const inputContent = inputEl?.innerText?.trim() || '';\n\n return JSON.stringify({\n id: 'active',\n status,\n title: document.title,\n messages,\n inputContent,\n activeModal,\n });\n } catch(e) {\n return JSON.stringify({ id: '', status: 'error', messages: [], error: e.message });\n }\n})()\n`;\n\n // send_message.js\n files[`${scriptDir}/send_message.js`] = `/**\n * ${name} — send_message\n *\n * For cdp-type-and-send IDEs: returns selector for daemon to type into.\n * → { sent: false, needsTypeAndSend: true, selector }\n */\n(() => {\n try {\n const input = document.querySelector('${meta.inputSelector || '[contenteditable=\"true\"]'}');\n if (!input) return JSON.stringify({ sent: false, error: 'Input not found' });\n return JSON.stringify({\n sent: false,\n needsTypeAndSend: true,\n selector: '${meta.inputSelector || '[contenteditable=\"true\"]'}',\n });\n } catch(e) {\n return JSON.stringify({ sent: false, error: e.message });\n }\n})()\n`;\n\n // list_sessions.js\n files[`${scriptDir}/list_sessions.js`] = `/**\n * ${name} — list_sessions\n *\n * TODO: Query session/chat list from sidebar.\n * → { sessions: [{ id, title, active, index }] }\n */\n(() => {\n try {\n const sessions = [];\n // TODO: Find session list container and parse items\n return JSON.stringify({ sessions });\n } catch(e) {\n return JSON.stringify({ sessions: [], error: e.message });\n }\n})()\n`;\n\n // switch_session.js\n files[`${scriptDir}/switch_session.js`] = `/**\n * ${name} — switch_session\n *\n * params.index: number, params.title: string|null\n * TODO: Click on session in sidebar by title or index.\n * → { switched: true/false }\n */\n(params) => {\n try {\n // TODO: Find session list and click target\n return JSON.stringify({ switched: false, error: 'Not implemented' });\n } catch(e) {\n return JSON.stringify({ switched: false, error: e.message });\n }\n}\n`;\n\n // new_session.js\n files[`${scriptDir}/new_session.js`] = `/**\n * ${name} — new_session\n *\n * TODO: Click \"New Chat\" button.\n * → { created: true/false }\n */\n(() => {\n try {\n const btn = document.querySelector('[aria-label*=\"New Chat\"], [aria-label*=\"New Composer\"]');\n if (btn) { btn.click(); return JSON.stringify({ created: true }); }\n return JSON.stringify({ created: false, error: 'New Chat button not found' });\n } catch(e) {\n return JSON.stringify({ created: false, error: e.message });\n }\n})()\n`;\n\n // focus_editor.js\n files[`${scriptDir}/focus_editor.js`] = `/**\n * ${name} — focus_editor\n */\n(() => {\n try {\n const input = document.querySelector('${meta.inputSelector || '[contenteditable=\"true\"]'}');\n if (input) { input.focus(); return 'focused'; }\n return 'not_found';\n } catch(e) { return 'error'; }\n})()\n`;\n\n // open_panel.js\n files[`${scriptDir}/open_panel.js`] = `/**\n * ${name} — open_panel\n *\n * TODO: Open chat/AI panel if not visible.\n */\n(() => {\n try {\n // TODO: Check if panel visible, if not find toggle button\n return 'not_found';\n } catch(e) { return 'error'; }\n})()\n`;\n\n // resolve_action.js\n files[`${scriptDir}/resolve_action.js`] = `/**\n * ${name} — resolve_action\n *\n * params.buttonText: string — button text to find and click.\n * → { resolved: true/false, clicked? }\n */\n(params) => {\n try {\n const btns = [...document.querySelectorAll('button, [role=\"button\"]')].filter(b => b.offsetWidth > 0);\n const searchText = (params.buttonText || '').toLowerCase();\n const target = btns.find(b => (b.textContent||'').trim().toLowerCase().includes(searchText));\n if (target) {\n target.click();\n return JSON.stringify({ resolved: true, clicked: target.textContent.trim() });\n }\n return JSON.stringify({ resolved: false, available: btns.map(b => b.textContent.trim()).filter(Boolean).slice(0, 10) });\n } catch(e) { return JSON.stringify({ resolved: false, error: e.message }); }\n}\n`;\n\n // list_models.js\n files[`${scriptDir}/list_models.js`] = `/**\n * ${name} — list_models\n *\n * TODO: Open model dropdown and extract model list.\n * → { models[], current }\n */\n(() => {\n try {\n return JSON.stringify({ models: [], current: '' });\n } catch(e) { return JSON.stringify({ models: [], current: '', error: e.message }); }\n})()\n`;\n\n // list_modes.js\n files[`${scriptDir}/list_modes.js`] = `/**\n * ${name} — list_modes\n *\n * TODO: Open mode dropdown and extract mode list.\n * → { modes[], current }\n */\n(() => {\n try {\n return JSON.stringify({ modes: [], current: '' });\n } catch(e) { return JSON.stringify({ modes: [], current: '', error: e.message }); }\n})()\n`;\n\n // set_model.js\n files[`${scriptDir}/set_model.js`] = `/**\n * ${name} — set_model\n *\n * params.model: string\n * TODO: Open model dropdown and select target model.\n * → { success: true/false }\n */\nasync (params) => {\n try {\n return JSON.stringify({ success: false, error: 'Not implemented' });\n } catch(e) { return JSON.stringify({ success: false, error: e.message }); }\n}\n`;\n\n // set_mode.js\n files[`${scriptDir}/set_mode.js`] = `/**\n * ${name} — set_mode\n *\n * params.mode: string\n * TODO: Open mode dropdown and select target mode.\n * → { success: true/false }\n */\nasync (params) => {\n try {\n return JSON.stringify({ success: false, error: 'Not implemented' });\n } catch(e) { return JSON.stringify({ success: false, error: e.message }); }\n}\n`;\n\n return {\n 'provider.json': JSON.stringify(meta, null, 2) + '\\n',\n files,\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 './detection/ide-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 * Daemon Lifecycle — Shared init + shutdown for cloud/standalone\n *\n * initDaemonComponents(): Creates all core daemon components in correct order.\n * shutdownDaemonComponents(): Graceful shutdown of all components.\n *\n * Transport-specific setup (ServerConnection, P2P, HTTP/WS) remains in each daemon.\n */\n\nimport { DaemonCdpManager } from '../cdp/manager.js';\nimport { DaemonCdpInitializer, type CdpInitializerConfig } from '../cdp/initializer.js';\nimport { setupIdeInstance, type CdpSetupContext } from '../cdp/setup.js';\nimport { DaemonCommandHandler } from '../commands/handler.js';\nimport { DaemonCommandRouter, type CommandRouterDeps } from '../commands/router.js';\nimport { DaemonCliManager } from '../commands/cli-manager.js';\nimport { DaemonAgentStreamManager } from '../agent-stream/manager.js';\nimport { AgentStreamPoller } from '../agent-stream/poller.js';\nimport { ProviderLoader } from '../providers/provider-loader.js';\nimport { ProviderInstanceManager } from '../providers/provider-instance-manager.js';\nimport { detectIDEs } from '../detection/ide-detector.js';\nimport { installGlobalInterceptor, LOG } from '../logging/logger.js';\nimport { loadConfig } from '../config/config.js';\n\n// ─── Init Config ───\n\nexport interface DaemonInitConfig {\n /** ProviderLoader log function */\n providerLogFn?: (msg: string) => void;\n\n /** CLI Manager deps (transport-specific) */\n cliManagerDeps: {\n getServerConn: () => any;\n getP2p: () => any;\n onStatusChange: () => void;\n removeAgentTracking: (key: string) => void;\n };\n\n /** CDP config */\n enabledIdes?: string[];\n\n /** Router transport-specific callbacks */\n onStatusChange?: () => void;\n onPostChatCommand?: () => void;\n getCdpLogFn?: (ideType: string) => (msg: string) => void;\n\n /** Additional callback after CDP manager created (transport-specific extras) */\n onCdpManagerSetup?: (ideType: string, manager: DaemonCdpManager, managerKey: string) => void | Promise<void>;\n\n /** Poller callback (transport-specific) */\n onStreamsUpdated?: (ideType: string, streams: any[]) => void;\n\n /** Instance ticking interval (ms), default 5000 */\n tickIntervalMs?: number;\n\n /** CDP scan interval (ms), default 30000 */\n cdpScanIntervalMs?: number;\n}\n\n// ─── Result ───\n\nexport interface DaemonComponents {\n providerLoader: ProviderLoader;\n instanceManager: ProviderInstanceManager;\n cliManager: DaemonCliManager;\n commandHandler: DaemonCommandHandler;\n agentStreamManager: DaemonAgentStreamManager;\n router: DaemonCommandRouter;\n poller: AgentStreamPoller;\n cdpInitializer: DaemonCdpInitializer;\n cdpManagers: Map<string, DaemonCdpManager>;\n instanceIdMap: Map<string, string>;\n detectedIdes: { value: any[] };\n}\n\n// ─── Init ───\n\n/**\n * Initialize all daemon core components.\n * Shared by both cloud and standalone daemons.\n *\n * Order:\n * 1. Global log interceptor\n * 2. ProviderLoader\n * 3. InstanceManager + CliManager\n * 4. Detect IDEs\n * 5. CdpInitializer → connectAll + periodic scan + discovery\n * 6. CommandHandler + AgentStreamManager\n * 7. Router + Poller\n * 8. Start instance ticking\n */\nexport async function initDaemonComponents(config: DaemonInitConfig): Promise<DaemonComponents> {\n // 1. Global log interceptor\n installGlobalInterceptor();\n\n // 2. ProviderLoader\n const providerLoader = new ProviderLoader({\n logFn: config.providerLogFn,\n });\n providerLoader.loadAll();\n providerLoader.registerToDetector();\n\n // 3. Shared state\n const instanceManager = new ProviderInstanceManager();\n const cdpManagers = new Map<string, DaemonCdpManager>();\n const instanceIdMap = new Map<string, string>();\n const detectedIdesRef = { value: [] as any[] };\n\n // 4. CLI Manager\n const cliManager = new DaemonCliManager({\n ...config.cliManagerDeps,\n getInstanceManager: () => instanceManager,\n }, providerLoader);\n\n // 5. Detect IDEs\n LOG.info('Init', 'Detecting IDEs...');\n detectedIdesRef.value = await detectIDEs();\n const installed = detectedIdesRef.value.filter((i: any) => i.installed);\n LOG.info('Init', `Found ${installed.length} IDE(s): ${installed.map((i: any) => i.id).join(', ') || 'none'}`);\n\n // 6. CDP Initializer — connect + register instances\n const cdpSetupContext: CdpSetupContext = {\n providerLoader,\n instanceManager,\n cdpManagers,\n instanceIdMap,\n };\n\n const cdpInitializer = new DaemonCdpInitializer({\n providerLoader,\n cdpManagers,\n enabledIdes: config.enabledIdes || loadConfig().enabledIdes || undefined,\n onConnected: async (ideType, manager, managerKey) => {\n // Register IDE instance (shared logic)\n await setupIdeInstance(cdpSetupContext, { ideType, manager, managerKey });\n // Transport-specific extras\n await config.onCdpManagerSetup?.(ideType, manager, managerKey);\n },\n });\n await cdpInitializer.connectAll(detectedIdesRef.value);\n cdpInitializer.startPeriodicScan(config.cdpScanIntervalMs ?? 30_000);\n cdpInitializer.startDiscovery(30_000);\n\n // 7. CommandHandler\n const commandHandler = new DaemonCommandHandler({\n cdpManagers,\n ideType: 'unknown',\n adapters: cliManager.adapters,\n providerLoader,\n instanceManager,\n instanceIdMap,\n });\n\n // 8. AgentStreamManager\n const agentStreamManager = new DaemonAgentStreamManager(\n LOG.forComponent('AgentStream').asLogFn(),\n providerLoader,\n );\n commandHandler.setAgentStreamManager(agentStreamManager);\n\n // 9. Router + Poller (with internal cross-wiring)\n // Note: poller is declared first so router's onIdeConnected closure captures it\n let poller: AgentStreamPoller;\n\n const router = new DaemonCommandRouter({\n commandHandler,\n cliManager,\n cdpManagers,\n providerLoader,\n instanceManager,\n detectedIdes: detectedIdesRef,\n instanceIdMap,\n onCdpManagerCreated: async (ideType: string, manager: DaemonCdpManager) => {\n // For launch_ide: register instance + extension providers\n await setupIdeInstance(cdpSetupContext, { ideType, manager });\n await config.onCdpManagerSetup?.(ideType, manager, ideType);\n },\n onIdeConnected: () => poller?.start(),\n onStatusChange: config.onStatusChange,\n onPostChatCommand: config.onPostChatCommand,\n getCdpLogFn: config.getCdpLogFn || ((ideType: string) => LOG.forComponent(`CDP:${ideType}`).asLogFn()),\n });\n\n poller = new AgentStreamPoller({\n agentStreamManager,\n providerLoader,\n instanceManager,\n cdpManagers,\n onStreamsUpdated: config.onStreamsUpdated,\n });\n poller.start();\n\n // 10. Start instance ticking\n instanceManager.startTicking(config.tickIntervalMs ?? 5_000);\n\n return {\n providerLoader,\n instanceManager,\n cliManager,\n commandHandler,\n agentStreamManager,\n router,\n poller,\n cdpInitializer,\n cdpManagers,\n instanceIdMap,\n detectedIdes: detectedIdesRef,\n };\n}\n\n// ─── Shutdown ───\n\n/**\n * Graceful shutdown of all daemon components.\n * Shared by both cloud and standalone daemons.\n *\n * Order:\n * 1. Stop timers (poller, cdpInitializer)\n * 2. Dispose agent stream\n * 3. Shutdown CLIs\n * 4. Dispose instances\n * 5. Disconnect CDPs\n */\nexport async function shutdownDaemonComponents(components: DaemonComponents): Promise<void> {\n const {\n poller, cdpInitializer, agentStreamManager,\n cliManager, instanceManager, cdpManagers,\n } = components;\n\n // 1. Stop timers\n poller.stop();\n cdpInitializer.stop();\n\n // 2. Dispose agent stream\n try {\n const anyCdp = [...cdpManagers.values()].find(m => m.isConnected);\n if (agentStreamManager && anyCdp) {\n await agentStreamManager.dispose(anyCdp);\n }\n } catch (e: any) { LOG.warn('Shutdown', `AgentStream dispose: ${e?.message}`); }\n\n // 3. Shutdown CLIs\n try { await cliManager.shutdownAll(); } catch { /* noop */ }\n\n // 4. Dispose instances\n try { instanceManager.disposeAll(); } catch { /* noop */ }\n\n // 5. Disconnect CDPs\n for (const m of cdpManagers.values()) {\n try { m.disconnect(); } catch { /* noop */ }\n }\n cdpManagers.clear();\n}\n"],"mappings":"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","names":["path","import_fs","import_os","os","dirname","import_child_process","os","resolve","platform","os","import_child_process","fs","path","os","stripAnsi","resolve","WebSocket","reject","crypto","fs","path","os","cdp","fs","path","os","config","result","state","result","import_child_process","os","path","fs","path","os","loadConfig","saveConfig","execSync","resolve","http","port","resolve","fs","platform","loadConfig","fs","path","os","LOG_DIR","getDateStr","currentDate","writeCount","fs","execSync","spawn","os","os","path","crypto","os","path","import_child_process","fs","arch","crypto","dirName","import_child_process","resolve","chalk","instanceManager","execSync","state","fs","path","os","import_child_process","import_os","findBinary","checkPathExists","http","fs","path","os","meta","path","resolve","spawn","body","ClientSideConnection","ndJsonStream","PROTOCOL_VERSION","Readable","Writable","spawnFn","child","execSync","import_child_process","fs","resolve"]}