From 124912c71d203ba8dda3bc78941c51ec6b150cf6 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=A8=8B=E5=BA=8F=E5=91=98=E9=98=BF=E6=B1=9F=28Relakkes?= =?UTF-8?q?=29?= Date: Wed, 1 Apr 2026 01:30:48 +0800 Subject: [PATCH] feat: fix leaked source to be locally runnable - Restore full Ink TUI startup chain (cli.tsx entry point) - Create stub .md files for verify skill (Bun text loader hang fix) - Create stub types for filePersistence and SDK modules - Fix Enter key not working (modifiers-napi missing, added try-catch) - Remove overly conservative LOCAL_RECOVERY early return - Add README with setup instructions - Add .env.example template - Add bin/claude-haha entry script and preload.ts Co-Authored-By: Claude Opus 4.6 (1M context) --- .env.example | 9 + .gitignore | 4 + README.md | 361 +- bin/claude-haha | 13 + bunfig.toml | 1 + package-lock.json | 4798 +++++++++++++++++ package.json | 77 + preload.ts | 17 + src/entrypoints/sdk/coreTypes.generated.ts | 3 + src/entrypoints/sdk/runtimeTypes.ts | 2 + .../sdk/settingsTypes.generated.ts | 2 + src/entrypoints/sdk/toolTypes.ts | 2 + src/ink/components/Box.tsx | 3 +- src/ink/components/ScrollBox.tsx | 3 +- src/localRecoveryCli.ts | 291 + src/main.tsx | 20 +- src/services/policyLimits/index.ts | 4 + .../remoteManagedSettings/syncCache.ts | 4 + src/setup.ts | 10 + src/skills/bundled/index.ts | 47 +- src/skills/bundled/verify/SKILL.md | 6 + src/skills/bundled/verify/examples/cli.md | 1 + src/skills/bundled/verify/examples/server.md | 1 + .../TungstenTool/TungstenLiveMonitor.tsx | 5 + src/tools/TungstenTool/TungstenTool.ts | 43 + src/tools/WorkflowTool/constants.ts | 1 + src/types/connectorText.ts | 20 + src/utils/filePersistence/types.ts | 22 + src/utils/modifiers.ts | 14 +- src/utils/ultraplan/prompt.txt | 1 + stubs/ant-claude-for-chrome-mcp.ts | 24 + stubs/color-diff-napi.ts | 19 + tsconfig.json | 24 + 33 files changed, 5572 insertions(+), 280 deletions(-) create mode 100644 .env.example create mode 100644 .gitignore create mode 100755 bin/claude-haha create mode 100644 bunfig.toml create mode 100644 package-lock.json create mode 100644 package.json create mode 100644 preload.ts create mode 100644 src/entrypoints/sdk/coreTypes.generated.ts create mode 100644 src/entrypoints/sdk/runtimeTypes.ts create mode 100644 src/entrypoints/sdk/settingsTypes.generated.ts create mode 100644 src/entrypoints/sdk/toolTypes.ts create mode 100644 src/localRecoveryCli.ts create mode 100644 src/skills/bundled/verify/SKILL.md create mode 100644 src/skills/bundled/verify/examples/cli.md create mode 100644 src/skills/bundled/verify/examples/server.md create mode 100644 src/tools/TungstenTool/TungstenLiveMonitor.tsx create mode 100644 src/tools/TungstenTool/TungstenTool.ts create mode 100644 src/tools/WorkflowTool/constants.ts create mode 100644 src/types/connectorText.ts create mode 100644 src/utils/filePersistence/types.ts create mode 100644 src/utils/ultraplan/prompt.txt create mode 100644 stubs/ant-claude-for-chrome-mcp.ts create mode 100644 stubs/color-diff-napi.ts create mode 100644 tsconfig.json diff --git a/.env.example b/.env.example new file mode 100644 index 0000000..dd9e713 --- /dev/null +++ b/.env.example @@ -0,0 +1,9 @@ +ANTHROPIC_AUTH_TOKEN=your_token_here +ANTHROPIC_BASE_URL=https://api.minimaxi.com/anthropic +ANTHROPIC_DEFAULT_HAIKU_MODEL=MiniMax-M2.7-highspeed +ANTHROPIC_DEFAULT_OPUS_MODEL=MiniMax-M2.7-highspeed +ANTHROPIC_DEFAULT_SONNET_MODEL=MiniMax-M2.7-highspeed +ANTHROPIC_MODEL=MiniMax-M2.7-highspeed +API_TIMEOUT_MS=3000000 +CLAUDE_CODE_DISABLE_NONESSENTIAL_TRAFFIC=1 +DISABLE_TELEMETRY=1 diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..2dc4818 --- /dev/null +++ b/.gitignore @@ -0,0 +1,4 @@ +.env +.env.* +!.env.example +node_modules diff --git a/README.md b/README.md index 45db43e..8e1e7ca 100644 --- a/README.md +++ b/README.md @@ -1,257 +1,158 @@ -# Claude Code — Leaked Source (2026-03-31) +# Claude Code Haha -> **On March 31, 2026, the full source code of Anthropic's Claude Code CLI was leaked** via a `.map` file exposed in their npm registry. +基于 Claude Code 泄露源码修复的**本地可运行版本**,支持接入任意 Anthropic 兼容 API(如 MiniMax、OpenRouter 等)。 + +> 原始泄露源码无法直接运行。本仓库修复了启动链路中的多个阻塞问题,使完整的 Ink TUI 交互界面可以在本地工作。 + +## 功能 + +- 完整的 Ink TUI 交互界面(与官方 Claude Code 一致) +- `--print` 无头模式(脚本/CI 场景) +- 支持 MCP 服务器、插件、Skills +- 支持自定义 API 端点和模型 +- 降级 Recovery CLI 模式 --- -## How It Leaked +## 快速开始 -[Chaofan Shou (@Fried_rice)](https://x.com/Fried_rice) discovered the leak and posted it publicly: +### 1. 安装依赖 -> **"Claude code source code has been leaked via a map file in their npm registry!"** -> -> — [@Fried_rice, March 31, 2026](https://x.com/Fried_rice/status/2038894956459290963) +需要 [Bun](https://bun.sh) >= 1.1 和 Node.js >= 18。 -The source map file in the published npm package contained a reference to the full, unobfuscated TypeScript source, which was downloadable as a zip archive from Anthropic's R2 storage bucket. +```bash +npm install +``` + +### 2. 配置环境变量 + +复制示例文件并填入你的 API Key: + +```bash +cp .env.example .env +``` + +编辑 `.env`: + +```env +# API 认证(二选一) +ANTHROPIC_API_KEY=sk-xxx # 标准 API Key(x-api-key 头) +ANTHROPIC_AUTH_TOKEN=sk-xxx # Bearer Token(Authorization 头) + +# API 端点(可选,默认 Anthropic 官方) +ANTHROPIC_BASE_URL=https://api.minimaxi.com/anthropic + +# 模型配置 +ANTHROPIC_MODEL=MiniMax-M2.7-highspeed +ANTHROPIC_DEFAULT_SONNET_MODEL=MiniMax-M2.7-highspeed +ANTHROPIC_DEFAULT_HAIKU_MODEL=MiniMax-M2.7-highspeed +ANTHROPIC_DEFAULT_OPUS_MODEL=MiniMax-M2.7-highspeed + +# 超时(毫秒) +API_TIMEOUT_MS=3000000 + +# 禁用遥测和非必要网络请求 +DISABLE_TELEMETRY=1 +CLAUDE_CODE_DISABLE_NONESSENTIAL_TRAFFIC=1 +``` + +### 3. 启动 + +```bash +# 交互 TUI 模式(完整界面) +./bin/claude-haha + +# 无头模式(单次问答) +./bin/claude-haha -p "your prompt here" + +# 管道输入 +echo "explain this code" | ./bin/claude-haha -p + +# 查看所有选项 +./bin/claude-haha --help +``` --- -## Overview +## 环境变量说明 -Claude Code is Anthropic's official CLI tool that lets you interact with Claude directly from the terminal to perform software engineering tasks — editing files, running commands, searching codebases, managing git workflows, and more. - -This repository contains the leaked `src/` directory. - -- **Leaked on**: 2026-03-31 -- **Language**: TypeScript -- **Runtime**: Bun -- **Terminal UI**: React + [Ink](https://github.com/vadimdemedes/ink) (React for CLI) -- **Scale**: ~1,900 files, 512,000+ lines of code +| 变量 | 必填 | 说明 | +|------|------|------| +| `ANTHROPIC_API_KEY` | 二选一 | API Key,通过 `x-api-key` 头发送 | +| `ANTHROPIC_AUTH_TOKEN` | 二选一 | Auth Token,通过 `Authorization: Bearer` 头发送 | +| `ANTHROPIC_BASE_URL` | 否 | 自定义 API 端点,默认 Anthropic 官方 | +| `ANTHROPIC_MODEL` | 否 | 默认模型 | +| `ANTHROPIC_DEFAULT_SONNET_MODEL` | 否 | Sonnet 级别模型映射 | +| `ANTHROPIC_DEFAULT_HAIKU_MODEL` | 否 | Haiku 级别模型映射 | +| `ANTHROPIC_DEFAULT_OPUS_MODEL` | 否 | Opus 级别模型映射 | +| `API_TIMEOUT_MS` | 否 | API 请求超时,默认 600000 (10min) | +| `DISABLE_TELEMETRY` | 否 | 设为 `1` 禁用遥测 | +| `CLAUDE_CODE_DISABLE_NONESSENTIAL_TRAFFIC` | 否 | 设为 `1` 禁用非必要网络请求 | --- -## Directory Structure +## 降级模式 + +如果完整 TUI 出现问题,可以使用简化版 readline 交互模式: + +```bash +CLAUDE_CODE_FORCE_RECOVERY_CLI=1 ./bin/claude-haha +``` + +--- + +## 相对于原始泄露源码的修复 + +泄露的源码无法直接运行,主要修复了以下问题: + +| 问题 | 根因 | 修复 | +|------|------|------| +| TUI 不启动 | 入口脚本把无参数启动路由到了 recovery CLI | 恢复走 `cli.tsx` 完整入口 | +| 启动卡死 | `verify` skill 导入缺失的 `.md` 文件,Bun text loader 无限挂起 | 创建 stub `.md` 文件 | +| `--print` 卡死 | `filePersistence/types.ts` 缺失 | 创建类型桩文件 | +| `--print` 卡死 | `ultraplan/prompt.txt` 缺失 | 创建资源桩文件 | +| **Enter 键无响应** | `modifiers-napi` native 包缺失,`isModifierPressed()` 抛异常导致 `handleEnter` 中断,`onSubmit` 永远不执行 | 加 try-catch 容错 | +| setup 被跳过 | `preload.ts` 自动设置 `LOCAL_RECOVERY=1` 跳过全部初始化 | 移除默认设置 | + +--- + +## 项目结构 ``` +bin/claude-haha # 入口脚本 +preload.ts # Bun preload(设置 MACRO 全局变量) +.env.example # 环境变量模板 src/ -├── main.tsx # Entrypoint (Commander.js-based CLI parser) -├── commands.ts # Command registry -├── tools.ts # Tool registry -├── Tool.ts # Tool type definitions -├── QueryEngine.ts # LLM query engine (core Anthropic API caller) -├── context.ts # System/user context collection -├── cost-tracker.ts # Token cost tracking -│ -├── commands/ # Slash command implementations (~50) -├── tools/ # Agent tool implementations (~40) -├── components/ # Ink UI components (~140) -├── hooks/ # React hooks -├── services/ # External service integrations -├── screens/ # Full-screen UIs (Doctor, REPL, Resume) -├── types/ # TypeScript type definitions -├── utils/ # Utility functions -│ -├── bridge/ # IDE integration bridge (VS Code, JetBrains) -├── coordinator/ # Multi-agent coordinator -├── plugins/ # Plugin system -├── skills/ # Skill system -├── keybindings/ # Keybinding configuration -├── vim/ # Vim mode -├── voice/ # Voice input -├── remote/ # Remote sessions -├── server/ # Server mode -├── memdir/ # Memory directory (persistent memory) -├── tasks/ # Task management -├── state/ # State management -├── migrations/ # Config migrations -├── schemas/ # Config schemas (Zod) -├── entrypoints/ # Initialization logic -├── ink/ # Ink renderer wrapper -├── buddy/ # Companion sprite (Easter egg) -├── native-ts/ # Native TypeScript utils -├── outputStyles/ # Output styling -├── query/ # Query pipeline -└── upstreamproxy/ # Proxy configuration +├── entrypoints/cli.tsx # CLI 主入口 +├── main.tsx # TUI 主逻辑(Commander.js + React/Ink) +├── localRecoveryCli.ts # 降级 Recovery CLI +├── setup.ts # 启动初始化 +├── screens/REPL.tsx # 交互 REPL 界面 +├── ink/ # Ink 终端渲染引擎 +├── components/ # UI 组件 +├── tools/ # Agent 工具(Bash, Edit, Grep 等) +├── commands/ # 斜杠命令(/commit, /review 等) +├── skills/ # Skill 系统 +├── services/ # 服务层(API, MCP, OAuth 等) +├── hooks/ # React hooks +└── utils/ # 工具函数 ``` --- -## Core Architecture +## 技术栈 -### 1. Tool System (`src/tools/`) - -Every tool Claude Code can invoke is implemented as a self-contained module. Each tool defines its input schema, permission model, and execution logic. - -| Tool | Description | -|---|---| -| `BashTool` | Shell command execution | -| `FileReadTool` | File reading (images, PDFs, notebooks) | -| `FileWriteTool` | File creation / overwrite | -| `FileEditTool` | Partial file modification (string replacement) | -| `GlobTool` | File pattern matching search | -| `GrepTool` | ripgrep-based content search | -| `WebFetchTool` | Fetch URL content | -| `WebSearchTool` | Web search | -| `AgentTool` | Sub-agent spawning | -| `SkillTool` | Skill execution | -| `MCPTool` | MCP server tool invocation | -| `LSPTool` | Language Server Protocol integration | -| `NotebookEditTool` | Jupyter notebook editing | -| `TaskCreateTool` / `TaskUpdateTool` | Task creation and management | -| `SendMessageTool` | Inter-agent messaging | -| `TeamCreateTool` / `TeamDeleteTool` | Team agent management | -| `EnterPlanModeTool` / `ExitPlanModeTool` | Plan mode toggle | -| `EnterWorktreeTool` / `ExitWorktreeTool` | Git worktree isolation | -| `ToolSearchTool` | Deferred tool discovery | -| `CronCreateTool` | Scheduled trigger creation | -| `RemoteTriggerTool` | Remote trigger | -| `SleepTool` | Proactive mode wait | -| `SyntheticOutputTool` | Structured output generation | - -### 2. Command System (`src/commands/`) - -User-facing slash commands invoked with `/` prefix. - -| Command | Description | -|---|---| -| `/commit` | Create a git commit | -| `/review` | Code review | -| `/compact` | Context compression | -| `/mcp` | MCP server management | -| `/config` | Settings management | -| `/doctor` | Environment diagnostics | -| `/login` / `/logout` | Authentication | -| `/memory` | Persistent memory management | -| `/skills` | Skill management | -| `/tasks` | Task management | -| `/vim` | Vim mode toggle | -| `/diff` | View changes | -| `/cost` | Check usage cost | -| `/theme` | Change theme | -| `/context` | Context visualization | -| `/pr_comments` | View PR comments | -| `/resume` | Restore previous session | -| `/share` | Share session | -| `/desktop` | Desktop app handoff | -| `/mobile` | Mobile app handoff | - -### 3. Service Layer (`src/services/`) - -| Service | Description | -|---|---| -| `api/` | Anthropic API client, file API, bootstrap | -| `mcp/` | Model Context Protocol server connection and management | -| `oauth/` | OAuth 2.0 authentication flow | -| `lsp/` | Language Server Protocol manager | -| `analytics/` | GrowthBook-based feature flags and analytics | -| `plugins/` | Plugin loader | -| `compact/` | Conversation context compression | -| `policyLimits/` | Organization policy limits | -| `remoteManagedSettings/` | Remote managed settings | -| `extractMemories/` | Automatic memory extraction | -| `tokenEstimation.ts` | Token count estimation | -| `teamMemorySync/` | Team memory synchronization | - -### 4. Bridge System (`src/bridge/`) - -A bidirectional communication layer connecting IDE extensions (VS Code, JetBrains) with the Claude Code CLI. - -- `bridgeMain.ts` — Bridge main loop -- `bridgeMessaging.ts` — Message protocol -- `bridgePermissionCallbacks.ts` — Permission callbacks -- `replBridge.ts` — REPL session bridge -- `jwtUtils.ts` — JWT-based authentication -- `sessionRunner.ts` — Session execution management - -### 5. Permission System (`src/hooks/toolPermission/`) - -Checks permissions on every tool invocation. Either prompts the user for approval/denial or automatically resolves based on the configured permission mode (`default`, `plan`, `bypassPermissions`, `auto`, etc.). - -### 6. Feature Flags - -Dead code elimination via Bun's `bun:bundle` feature flags: - -```typescript -import { feature } from 'bun:bundle' - -// Inactive code is completely stripped at build time -const voiceCommand = feature('VOICE_MODE') - ? require('./commands/voice/index.js').default - : null -``` - -Notable flags: `PROACTIVE`, `KAIROS`, `BRIDGE_MODE`, `DAEMON`, `VOICE_MODE`, `AGENT_TRIGGERS`, `MONITOR_TOOL` - ---- - -## Key Files in Detail - -### `QueryEngine.ts` (~46K lines) - -The core engine for LLM API calls. Handles streaming responses, tool-call loops, thinking mode, retry logic, and token counting. - -### `Tool.ts` (~29K lines) - -Defines base types and interfaces for all tools — input schemas, permission models, and progress state types. - -### `commands.ts` (~25K lines) - -Manages registration and execution of all slash commands. Uses conditional imports to load different command sets per environment. - -### `main.tsx` - -Commander.js-based CLI parser + React/Ink renderer initialization. At startup, parallelizes MDM settings, keychain prefetch, and GrowthBook initialization for faster boot. - ---- - -## Tech Stack - -| Category | Technology | -|---|---| -| Runtime | [Bun](https://bun.sh) | -| Language | TypeScript (strict) | -| Terminal UI | [React](https://react.dev) + [Ink](https://github.com/vadimdemedes/ink) | -| CLI Parsing | [Commander.js](https://github.com/tj/commander.js) (extra-typings) | -| Schema Validation | [Zod v4](https://zod.dev) | -| Code Search | [ripgrep](https://github.com/BurntSushi/ripgrep) (via GrepTool) | -| Protocols | [MCP SDK](https://modelcontextprotocol.io), LSP | -| API | [Anthropic SDK](https://docs.anthropic.com) | -| Telemetry | OpenTelemetry + gRPC | -| Feature Flags | GrowthBook | -| Auth | OAuth 2.0, JWT, macOS Keychain | - ---- - -## Notable Design Patterns - -### Parallel Prefetch - -Startup time is optimized by prefetching MDM settings, keychain reads, and API preconnect in parallel — before heavy module evaluation begins. - -```typescript -// main.tsx — fired as side-effects before other imports -startMdmRawRead() -startKeychainPrefetch() -``` - -### Lazy Loading - -Heavy modules (OpenTelemetry ~400KB, gRPC ~700KB) are deferred via dynamic `import()` until actually needed. - -### Agent Swarms - -Sub-agents are spawned via `AgentTool`, with `coordinator/` handling multi-agent orchestration. `TeamCreateTool` enables team-level parallel work. - -### Skill System - -Reusable workflows defined in `skills/` and executed through `SkillTool`. Users can add custom skills. - -### Plugin Architecture - -Built-in and third-party plugins are loaded through the `plugins/` subsystem. +| 类别 | 技术 | +|------|------| +| 运行时 | [Bun](https://bun.sh) | +| 语言 | TypeScript | +| 终端 UI | React + [Ink](https://github.com/vadimdemedes/ink) | +| CLI 解析 | Commander.js | +| API | Anthropic SDK | +| 协议 | MCP, LSP | --- ## Disclaimer -This repository archives source code that was leaked from Anthropic's npm registry on **2026-03-31**. All original source code is the property of [Anthropic](https://www.anthropic.com). +本仓库基于 2026-03-31 从 Anthropic npm registry 泄露的 Claude Code 源码。所有原始源码版权归 [Anthropic](https://www.anthropic.com) 所有。仅供学习和研究用途。 diff --git a/bin/claude-haha b/bin/claude-haha new file mode 100755 index 0000000..2e254c4 --- /dev/null +++ b/bin/claude-haha @@ -0,0 +1,13 @@ +#!/usr/bin/env bash +set -euo pipefail + +ROOT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")/.." && pwd)" +cd "$ROOT_DIR" + +# Force recovery CLI (simple readline REPL, no Ink TUI) +if [[ "${CLAUDE_CODE_FORCE_RECOVERY_CLI:-0}" == "1" ]]; then + exec bun --env-file=.env ./src/localRecoveryCli.ts "$@" +fi + +# Default: full CLI with Ink TUI +exec bun --env-file=.env ./src/entrypoints/cli.tsx "$@" diff --git a/bunfig.toml b/bunfig.toml new file mode 100644 index 0000000..7d029e7 --- /dev/null +++ b/bunfig.toml @@ -0,0 +1 @@ +preload = ["./preload.ts"] diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..0db4033 --- /dev/null +++ b/package-lock.json @@ -0,0 +1,4798 @@ +{ + "name": "claude-code-local", + "version": "0.0.0-local", + "lockfileVersion": 3, + "requires": true, + "packages": { + "": { + "name": "claude-code-local", + "version": "0.0.0-local", + "dependencies": { + "@anthropic-ai/sandbox-runtime": "^0.0.44", + "@anthropic-ai/sdk": "^0.80.0", + "@aws-sdk/client-bedrock-runtime": "^3.1020.0", + "@commander-js/extra-typings": "^14.0.0", + "@growthbook/growthbook": "^1.6.5", + "@modelcontextprotocol/sdk": "^1.29.0", + "@opentelemetry/api-logs": "^0.214.0", + "@opentelemetry/core": "^2.6.1", + "@opentelemetry/resources": "^2.6.1", + "@opentelemetry/sdk-logs": "^0.214.0", + "@opentelemetry/sdk-metrics": "^2.6.1", + "@opentelemetry/sdk-trace-base": "^2.6.1", + "@opentelemetry/semantic-conventions": "^1.40.0", + "ajv": "^8.18.0", + "asciichart": "^1.5.25", + "auto-bind": "^5.0.1", + "axios": "^1.14.0", + "bidi-js": "^1.0.3", + "chalk": "^5.6.2", + "chokidar": "^5.0.0", + "cli-boxes": "^4.0.1", + "code-excerpt": "^4.0.0", + "diff": "^8.0.4", + "emoji-regex": "^10.6.0", + "env-paths": "^4.0.0", + "execa": "^9.6.1", + "figures": "^6.1.0", + "fuse.js": "^7.1.0", + "get-east-asian-width": "^1.5.0", + "google-auth-library": "^10.6.2", + "highlight.js": "^11.11.1", + "https-proxy-agent": "^8.0.0", + "ignore": "^7.0.5", + "indent-string": "^5.0.0", + "ink": "^6.8.0", + "jsonc-parser": "^3.3.1", + "lodash-es": "^4.17.23", + "lru-cache": "^11.2.7", + "marked": "^17.0.5", + "p-map": "^7.0.4", + "picomatch": "^4.0.4", + "proper-lockfile": "^4.1.2", + "qrcode": "^1.5.4", + "react": "^19.2.4", + "react-reconciler": "^0.33.0", + "semver": "^7.7.4", + "shell-quote": "^1.8.3", + "signal-exit": "^4.1.0", + "stack-utils": "^2.0.6", + "strip-ansi": "^7.2.0", + "supports-hyperlinks": "^4.4.0", + "tree-kill": "^1.2.2", + "type-fest": "^5.5.0", + "undici": "^7.24.6", + "usehooks-ts": "^3.1.1", + "vscode-jsonrpc": "^8.2.1", + "vscode-languageserver-types": "^3.17.5", + "wrap-ansi": "^10.0.0", + "ws": "^8.20.0", + "xss": "^1.0.15", + "yaml": "^2.8.3", + "zod": "^4.3.6" + }, + "bin": { + "claude-haha": "bin/claude-haha" + } + }, + "node_modules/@alcalzone/ansi-tokenize": { + "version": "0.2.5", + "resolved": "https://registry.npmmirror.com/@alcalzone/ansi-tokenize/-/ansi-tokenize-0.2.5.tgz", + "integrity": "sha512-3NX/MpTdroi0aKz134A6RC2Gb2iXVECN4QaAXnvCIxxIm3C3AVB1mkUe8NaaiyvOpDfsrqWhYtj+Q6a62RrTsw==", + "license": "MIT", + "dependencies": { + "ansi-styles": "^6.2.1", + "is-fullwidth-code-point": "^5.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/@anthropic-ai/sandbox-runtime": { + "version": "0.0.44", + "resolved": "https://registry.npmmirror.com/@anthropic-ai/sandbox-runtime/-/sandbox-runtime-0.0.44.tgz", + "integrity": "sha512-mmyjq0mzsHnQZyiU+FGYyaiJcPckuQpP78VB8iqFi2IOu8rcb9i5SmaOKyJENJNfY8l/1grzLMQgWq4Apvmozw==", + "license": "Apache-2.0", + "dependencies": { + "@pondwader/socks5-server": "^1.0.10", + "@types/lodash-es": "^4.17.12", + "commander": "^12.1.0", + "lodash-es": "^4.17.23", + "shell-quote": "^1.8.3", + "zod": "^3.24.1" + }, + "bin": { + "srt": "dist/cli.js" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@anthropic-ai/sandbox-runtime/node_modules/commander": { + "version": "12.1.0", + "resolved": "https://registry.npmmirror.com/commander/-/commander-12.1.0.tgz", + "integrity": "sha512-Vw8qHK3bZM9y/P10u3Vib8o/DdkvA2OtPtZvD871QKjy74Wj1WSKFILMPRPSdUSx5RFK1arlJzEtA4PkFgnbuA==", + "license": "MIT", + "engines": { + "node": ">=18" + } + }, + "node_modules/@anthropic-ai/sandbox-runtime/node_modules/zod": { + "version": "3.25.76", + "resolved": "https://registry.npmmirror.com/zod/-/zod-3.25.76.tgz", + "integrity": "sha512-gzUt/qt81nXsFGKIFcC3YnfEAx5NkunCfnDlvuBSSFS02bcXu4Lmea0AFIUwbLWxWPx3d9p8S5QoaujKcNQxcQ==", + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/colinhacks" + } + }, + "node_modules/@anthropic-ai/sdk": { + "version": "0.80.0", + "resolved": "https://registry.npmmirror.com/@anthropic-ai/sdk/-/sdk-0.80.0.tgz", + "integrity": "sha512-WeXLn7zNVk3yjeshn+xZHvld6AoFUOR3Sep6pSoHho5YbSi6HwcirqgPA5ccFuW8QTVJAAU7N8uQQC6Wa9TG+g==", + "license": "MIT", + "dependencies": { + "json-schema-to-ts": "^3.1.1" + }, + "bin": { + "anthropic-ai-sdk": "bin/cli" + }, + "peerDependencies": { + "zod": "^3.25.0 || ^4.0.0" + }, + "peerDependenciesMeta": { + "zod": { + "optional": true + } + } + }, + "node_modules/@aws-crypto/crc32": { + "version": "5.2.0", + "resolved": "https://registry.npmmirror.com/@aws-crypto/crc32/-/crc32-5.2.0.tgz", + "integrity": "sha512-nLbCWqQNgUiwwtFsen1AdzAtvuLRsQS8rYgMuxCrdKf9kOssamGLuPwyTY9wyYblNr9+1XM8v6zoDTPPSIeANg==", + "license": "Apache-2.0", + "dependencies": { + "@aws-crypto/util": "^5.2.0", + "@aws-sdk/types": "^3.222.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=16.0.0" + } + }, + "node_modules/@aws-crypto/sha256-browser": { + "version": "5.2.0", + "resolved": "https://registry.npmmirror.com/@aws-crypto/sha256-browser/-/sha256-browser-5.2.0.tgz", + "integrity": "sha512-AXfN/lGotSQwu6HNcEsIASo7kWXZ5HYWvfOmSNKDsEqC4OashTp8alTmaz+F7TC2L083SFv5RdB+qU3Vs1kZqw==", + "license": "Apache-2.0", + "dependencies": { + "@aws-crypto/sha256-js": "^5.2.0", + "@aws-crypto/supports-web-crypto": "^5.2.0", + "@aws-crypto/util": "^5.2.0", + "@aws-sdk/types": "^3.222.0", + "@aws-sdk/util-locate-window": "^3.0.0", + "@smithy/util-utf8": "^2.0.0", + "tslib": "^2.6.2" + } + }, + "node_modules/@aws-crypto/sha256-browser/node_modules/@smithy/is-array-buffer": { + "version": "2.2.0", + "resolved": "https://registry.npmmirror.com/@smithy/is-array-buffer/-/is-array-buffer-2.2.0.tgz", + "integrity": "sha512-GGP3O9QFD24uGeAXYUjwSTXARoqpZykHadOmA8G5vfJPK0/DC67qa//0qvqrJzL1xc8WQWX7/yc7fwudjPHPhA==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@aws-crypto/sha256-browser/node_modules/@smithy/util-buffer-from": { + "version": "2.2.0", + "resolved": "https://registry.npmmirror.com/@smithy/util-buffer-from/-/util-buffer-from-2.2.0.tgz", + "integrity": "sha512-IJdWBbTcMQ6DA0gdNhh/BwrLkDR+ADW5Kr1aZmd4k3DIF6ezMV4R2NIAmT08wQJ3yUK82thHWmC/TnK/wpMMIA==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/is-array-buffer": "^2.2.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@aws-crypto/sha256-browser/node_modules/@smithy/util-utf8": { + "version": "2.3.0", + "resolved": "https://registry.npmmirror.com/@smithy/util-utf8/-/util-utf8-2.3.0.tgz", + "integrity": "sha512-R8Rdn8Hy72KKcebgLiv8jQcQkXoLMOGGv5uI1/k0l+snqkOzQ1R0ChUBCxWMlBsFMekWjq0wRudIweFs7sKT5A==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/util-buffer-from": "^2.2.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@aws-crypto/sha256-js": { + "version": "5.2.0", + "resolved": "https://registry.npmmirror.com/@aws-crypto/sha256-js/-/sha256-js-5.2.0.tgz", + "integrity": "sha512-FFQQyu7edu4ufvIZ+OadFpHHOt+eSTBaYaki44c+akjg7qZg9oOQeLlk77F6tSYqjDAFClrHJk9tMf0HdVyOvA==", + "license": "Apache-2.0", + "dependencies": { + "@aws-crypto/util": "^5.2.0", + "@aws-sdk/types": "^3.222.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=16.0.0" + } + }, + "node_modules/@aws-crypto/supports-web-crypto": { + "version": "5.2.0", + "resolved": "https://registry.npmmirror.com/@aws-crypto/supports-web-crypto/-/supports-web-crypto-5.2.0.tgz", + "integrity": "sha512-iAvUotm021kM33eCdNfwIN//F77/IADDSs58i+MDaOqFrVjZo9bAal0NK7HurRuWLLpF1iLX7gbWrjHjeo+YFg==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + } + }, + "node_modules/@aws-crypto/util": { + "version": "5.2.0", + "resolved": "https://registry.npmmirror.com/@aws-crypto/util/-/util-5.2.0.tgz", + "integrity": "sha512-4RkU9EsI6ZpBve5fseQlGNUWKMa1RLPQ1dnjnQoe07ldfIzcsGb5hC5W0Dm7u423KWzawlrpbjXBrXCEv9zazQ==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.222.0", + "@smithy/util-utf8": "^2.0.0", + "tslib": "^2.6.2" + } + }, + "node_modules/@aws-crypto/util/node_modules/@smithy/is-array-buffer": { + "version": "2.2.0", + "resolved": "https://registry.npmmirror.com/@smithy/is-array-buffer/-/is-array-buffer-2.2.0.tgz", + "integrity": "sha512-GGP3O9QFD24uGeAXYUjwSTXARoqpZykHadOmA8G5vfJPK0/DC67qa//0qvqrJzL1xc8WQWX7/yc7fwudjPHPhA==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@aws-crypto/util/node_modules/@smithy/util-buffer-from": { + "version": "2.2.0", + "resolved": "https://registry.npmmirror.com/@smithy/util-buffer-from/-/util-buffer-from-2.2.0.tgz", + "integrity": "sha512-IJdWBbTcMQ6DA0gdNhh/BwrLkDR+ADW5Kr1aZmd4k3DIF6ezMV4R2NIAmT08wQJ3yUK82thHWmC/TnK/wpMMIA==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/is-array-buffer": "^2.2.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@aws-crypto/util/node_modules/@smithy/util-utf8": { + "version": "2.3.0", + "resolved": "https://registry.npmmirror.com/@smithy/util-utf8/-/util-utf8-2.3.0.tgz", + "integrity": "sha512-R8Rdn8Hy72KKcebgLiv8jQcQkXoLMOGGv5uI1/k0l+snqkOzQ1R0ChUBCxWMlBsFMekWjq0wRudIweFs7sKT5A==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/util-buffer-from": "^2.2.0", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/@aws-sdk/client-bedrock-runtime": { + "version": "3.1020.0", + "resolved": "https://registry.npmmirror.com/@aws-sdk/client-bedrock-runtime/-/client-bedrock-runtime-3.1020.0.tgz", + "integrity": "sha512-nqDCbaB05gRc3FuIEN74Mo04+k8RNI0YT2YBAU/9nioqgDyoqzMx8Ia2QWaw9UhUyIHMBjcFEfKIPfCZx7caCw==", + "license": "Apache-2.0", + "dependencies": { + "@aws-crypto/sha256-browser": "5.2.0", + "@aws-crypto/sha256-js": "5.2.0", + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/credential-provider-node": "^3.972.28", + "@aws-sdk/eventstream-handler-node": "^3.972.12", + "@aws-sdk/middleware-eventstream": "^3.972.8", + "@aws-sdk/middleware-host-header": "^3.972.8", + "@aws-sdk/middleware-logger": "^3.972.8", + "@aws-sdk/middleware-recursion-detection": "^3.972.9", + "@aws-sdk/middleware-user-agent": "^3.972.27", + "@aws-sdk/middleware-websocket": "^3.972.14", + "@aws-sdk/region-config-resolver": "^3.972.10", + "@aws-sdk/token-providers": "3.1020.0", + "@aws-sdk/types": "^3.973.6", + "@aws-sdk/util-endpoints": "^3.996.5", + "@aws-sdk/util-user-agent-browser": "^3.972.8", + "@aws-sdk/util-user-agent-node": "^3.973.13", + "@smithy/config-resolver": "^4.4.13", + "@smithy/core": "^3.23.13", + "@smithy/eventstream-serde-browser": "^4.2.12", + "@smithy/eventstream-serde-config-resolver": "^4.3.12", + "@smithy/eventstream-serde-node": "^4.2.12", + "@smithy/fetch-http-handler": "^5.3.15", + "@smithy/hash-node": "^4.2.12", + "@smithy/invalid-dependency": "^4.2.12", + "@smithy/middleware-content-length": "^4.2.12", + "@smithy/middleware-endpoint": "^4.4.28", + "@smithy/middleware-retry": "^4.4.45", + "@smithy/middleware-serde": "^4.2.16", + "@smithy/middleware-stack": "^4.2.12", + "@smithy/node-config-provider": "^4.3.12", + "@smithy/node-http-handler": "^4.5.1", + "@smithy/protocol-http": "^5.3.12", + "@smithy/smithy-client": "^4.12.8", + "@smithy/types": "^4.13.1", + "@smithy/url-parser": "^4.2.12", + "@smithy/util-base64": "^4.3.2", + "@smithy/util-body-length-browser": "^4.2.2", + "@smithy/util-body-length-node": "^4.2.3", + "@smithy/util-defaults-mode-browser": "^4.3.44", + "@smithy/util-defaults-mode-node": "^4.2.48", + "@smithy/util-endpoints": "^3.3.3", + "@smithy/util-middleware": "^4.2.12", + "@smithy/util-retry": "^4.2.12", + "@smithy/util-stream": "^4.5.21", + "@smithy/util-utf8": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/core": { + "version": "3.973.26", + "resolved": "https://registry.npmmirror.com/@aws-sdk/core/-/core-3.973.26.tgz", + "integrity": "sha512-A/E6n2W42ruU+sfWk+mMUOyVXbsSgGrY3MJ9/0Az5qUdG67y8I6HYzzoAa+e/lzxxl1uCYmEL6BTMi9ZiZnplQ==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@aws-sdk/xml-builder": "^3.972.16", + "@smithy/core": "^3.23.13", + "@smithy/node-config-provider": "^4.3.12", + "@smithy/property-provider": "^4.2.12", + "@smithy/protocol-http": "^5.3.12", + "@smithy/signature-v4": "^5.3.12", + "@smithy/smithy-client": "^4.12.8", + "@smithy/types": "^4.13.1", + "@smithy/util-base64": "^4.3.2", + "@smithy/util-middleware": "^4.2.12", + "@smithy/util-utf8": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/credential-provider-env": { + "version": "3.972.24", + "resolved": "https://registry.npmmirror.com/@aws-sdk/credential-provider-env/-/credential-provider-env-3.972.24.tgz", + "integrity": "sha512-FWg8uFmT6vQM7VuzELzwVo5bzExGaKHdubn0StjgrcU5FvuLExUe+k06kn/40uKv59rYzhez8eFNM4yYE/Yb/w==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/types": "^3.973.6", + "@smithy/property-provider": "^4.2.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/credential-provider-http": { + "version": "3.972.26", + "resolved": "https://registry.npmmirror.com/@aws-sdk/credential-provider-http/-/credential-provider-http-3.972.26.tgz", + "integrity": "sha512-CY4ppZ+qHYqcXqBVi//sdHST1QK3KzOEiLtpLsc9W2k2vfZPKExGaQIsOwcyvjpjUEolotitmd3mUNY56IwDEA==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/types": "^3.973.6", + "@smithy/fetch-http-handler": "^5.3.15", + "@smithy/node-http-handler": "^4.5.1", + "@smithy/property-provider": "^4.2.12", + "@smithy/protocol-http": "^5.3.12", + "@smithy/smithy-client": "^4.12.8", + "@smithy/types": "^4.13.1", + "@smithy/util-stream": "^4.5.21", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/credential-provider-ini": { + "version": "3.972.27", + "resolved": "https://registry.npmmirror.com/@aws-sdk/credential-provider-ini/-/credential-provider-ini-3.972.27.tgz", + "integrity": "sha512-Um26EsNSUfVUX0wUXnUA1W3wzKhVy6nviEElsh5lLZUYj9bk6DXOPnpte0gt+WHubcVfVsRk40bbm4KaroTEag==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/credential-provider-env": "^3.972.24", + "@aws-sdk/credential-provider-http": "^3.972.26", + "@aws-sdk/credential-provider-login": "^3.972.27", + "@aws-sdk/credential-provider-process": "^3.972.24", + "@aws-sdk/credential-provider-sso": "^3.972.27", + "@aws-sdk/credential-provider-web-identity": "^3.972.27", + "@aws-sdk/nested-clients": "^3.996.17", + "@aws-sdk/types": "^3.973.6", + "@smithy/credential-provider-imds": "^4.2.12", + "@smithy/property-provider": "^4.2.12", + "@smithy/shared-ini-file-loader": "^4.4.7", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/credential-provider-login": { + "version": "3.972.27", + "resolved": "https://registry.npmmirror.com/@aws-sdk/credential-provider-login/-/credential-provider-login-3.972.27.tgz", + "integrity": "sha512-t3ehEtHomGZwg5Gixw4fYbYtG9JBnjfAjSDabxhPEu/KLLUp0BB37/APX7MSKXQhX6ZH7pseuACFJ19NrAkNdg==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/nested-clients": "^3.996.17", + "@aws-sdk/types": "^3.973.6", + "@smithy/property-provider": "^4.2.12", + "@smithy/protocol-http": "^5.3.12", + "@smithy/shared-ini-file-loader": "^4.4.7", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/credential-provider-node": { + "version": "3.972.28", + "resolved": "https://registry.npmmirror.com/@aws-sdk/credential-provider-node/-/credential-provider-node-3.972.28.tgz", + "integrity": "sha512-rren+P6k5rShG5PX61iVi40kKdueyuMLBRTctQbyR5LooO9Ygr5L6R7ilG7RF1957NSH3KC3TU206fZuKwjSpQ==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/credential-provider-env": "^3.972.24", + "@aws-sdk/credential-provider-http": "^3.972.26", + "@aws-sdk/credential-provider-ini": "^3.972.27", + "@aws-sdk/credential-provider-process": "^3.972.24", + "@aws-sdk/credential-provider-sso": "^3.972.27", + "@aws-sdk/credential-provider-web-identity": "^3.972.27", + "@aws-sdk/types": "^3.973.6", + "@smithy/credential-provider-imds": "^4.2.12", + "@smithy/property-provider": "^4.2.12", + "@smithy/shared-ini-file-loader": "^4.4.7", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/credential-provider-process": { + "version": "3.972.24", + "resolved": "https://registry.npmmirror.com/@aws-sdk/credential-provider-process/-/credential-provider-process-3.972.24.tgz", + "integrity": "sha512-Q2k/XLrFXhEztPHqj4SLCNID3hEPdlhh1CDLBpNnM+1L8fq7P+yON9/9M1IGN/dA5W45v44ylERfXtDAlmMNmw==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/types": "^3.973.6", + "@smithy/property-provider": "^4.2.12", + "@smithy/shared-ini-file-loader": "^4.4.7", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/credential-provider-sso": { + "version": "3.972.27", + "resolved": "https://registry.npmmirror.com/@aws-sdk/credential-provider-sso/-/credential-provider-sso-3.972.27.tgz", + "integrity": "sha512-CWXeGjlbBuHcm9appZUgXKP2zHDyTti0/+gXpSFJ2J3CnSwf1KWjicjN0qG2ozkMH6blrrzMrimeIOEYNl238Q==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/nested-clients": "^3.996.17", + "@aws-sdk/token-providers": "3.1020.0", + "@aws-sdk/types": "^3.973.6", + "@smithy/property-provider": "^4.2.12", + "@smithy/shared-ini-file-loader": "^4.4.7", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/credential-provider-web-identity": { + "version": "3.972.27", + "resolved": "https://registry.npmmirror.com/@aws-sdk/credential-provider-web-identity/-/credential-provider-web-identity-3.972.27.tgz", + "integrity": "sha512-CUY4hQIFswdQNEsRGEzGBUKGMK5KpqmNDdu2ROMgI+45PLFS8H0y3Tm7kvM16uvvw3n1pVxk85tnRVUTgtaa1w==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/nested-clients": "^3.996.17", + "@aws-sdk/types": "^3.973.6", + "@smithy/property-provider": "^4.2.12", + "@smithy/shared-ini-file-loader": "^4.4.7", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/eventstream-handler-node": { + "version": "3.972.12", + "resolved": "https://registry.npmmirror.com/@aws-sdk/eventstream-handler-node/-/eventstream-handler-node-3.972.12.tgz", + "integrity": "sha512-ruyc/MNR6e+cUrGCth7fLQ12RXBZDy/bV06tgqB9Z5n/0SN/C0m6bsQEV8FF9zPI6VSAOaRd0rNgmpYVnGawrQ==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@smithy/eventstream-codec": "^4.2.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/middleware-eventstream": { + "version": "3.972.8", + "resolved": "https://registry.npmmirror.com/@aws-sdk/middleware-eventstream/-/middleware-eventstream-3.972.8.tgz", + "integrity": "sha512-r+oP+tbCxgqXVC3pu3MUVePgSY0ILMjA+aEwOosS77m3/DRbtvHrHwqvMcw+cjANMeGzJ+i0ar+n77KXpRA8RQ==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@smithy/protocol-http": "^5.3.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/middleware-host-header": { + "version": "3.972.8", + "resolved": "https://registry.npmmirror.com/@aws-sdk/middleware-host-header/-/middleware-host-header-3.972.8.tgz", + "integrity": "sha512-wAr2REfKsqoKQ+OkNqvOShnBoh+nkPurDKW7uAeVSu6kUECnWlSJiPvnoqxGlfousEY/v9LfS9sNc46hjSYDIQ==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@smithy/protocol-http": "^5.3.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/middleware-logger": { + "version": "3.972.8", + "resolved": "https://registry.npmmirror.com/@aws-sdk/middleware-logger/-/middleware-logger-3.972.8.tgz", + "integrity": "sha512-CWl5UCM57WUFaFi5kB7IBY1UmOeLvNZAZ2/OZ5l20ldiJ3TiIz1pC65gYj8X0BCPWkeR1E32mpsCk1L1I4n+lA==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/middleware-recursion-detection": { + "version": "3.972.9", + "resolved": "https://registry.npmmirror.com/@aws-sdk/middleware-recursion-detection/-/middleware-recursion-detection-3.972.9.tgz", + "integrity": "sha512-/Wt5+CT8dpTFQxEJ9iGy/UGrXr7p2wlIOEHvIr/YcHYByzoLjrqkYqXdJjd9UIgWjv7eqV2HnFJen93UTuwfTQ==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@aws/lambda-invoke-store": "^0.2.2", + "@smithy/protocol-http": "^5.3.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/middleware-user-agent": { + "version": "3.972.27", + "resolved": "https://registry.npmmirror.com/@aws-sdk/middleware-user-agent/-/middleware-user-agent-3.972.27.tgz", + "integrity": "sha512-TIRLO5UR2+FVUGmhYoAwVkKhcVzywEDX/5LzR9tjy1h8FQAXOtFg2IqgmwvxU7y933rkTn9rl6AdgcAUgQ1/Kg==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/types": "^3.973.6", + "@aws-sdk/util-endpoints": "^3.996.5", + "@smithy/core": "^3.23.13", + "@smithy/protocol-http": "^5.3.12", + "@smithy/types": "^4.13.1", + "@smithy/util-retry": "^4.2.12", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/middleware-websocket": { + "version": "3.972.14", + "resolved": "https://registry.npmmirror.com/@aws-sdk/middleware-websocket/-/middleware-websocket-3.972.14.tgz", + "integrity": "sha512-qnfDlIHjm6DrTYNvWOUbnZdVKgtoKbO/Qzj+C0Wp5Y7VUrsvBRQtGKxD+hc+mRTS4N0kBJ6iZ3+zxm4N1OSyjg==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@aws-sdk/util-format-url": "^3.972.8", + "@smithy/eventstream-codec": "^4.2.12", + "@smithy/eventstream-serde-browser": "^4.2.12", + "@smithy/fetch-http-handler": "^5.3.15", + "@smithy/protocol-http": "^5.3.12", + "@smithy/signature-v4": "^5.3.12", + "@smithy/types": "^4.13.1", + "@smithy/util-base64": "^4.3.2", + "@smithy/util-hex-encoding": "^4.2.2", + "@smithy/util-utf8": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">= 14.0.0" + } + }, + "node_modules/@aws-sdk/nested-clients": { + "version": "3.996.17", + "resolved": "https://registry.npmmirror.com/@aws-sdk/nested-clients/-/nested-clients-3.996.17.tgz", + "integrity": "sha512-7B0HIX0tEFmOSJuWzdHZj1WhMXSryM+h66h96ZkqSncoY7J6wq61KOu4Kr57b/YnJP3J/EeQYVFulgR281h+7A==", + "license": "Apache-2.0", + "dependencies": { + "@aws-crypto/sha256-browser": "5.2.0", + "@aws-crypto/sha256-js": "5.2.0", + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/middleware-host-header": "^3.972.8", + "@aws-sdk/middleware-logger": "^3.972.8", + "@aws-sdk/middleware-recursion-detection": "^3.972.9", + "@aws-sdk/middleware-user-agent": "^3.972.27", + "@aws-sdk/region-config-resolver": "^3.972.10", + "@aws-sdk/types": "^3.973.6", + "@aws-sdk/util-endpoints": "^3.996.5", + "@aws-sdk/util-user-agent-browser": "^3.972.8", + "@aws-sdk/util-user-agent-node": "^3.973.13", + "@smithy/config-resolver": "^4.4.13", + "@smithy/core": "^3.23.13", + "@smithy/fetch-http-handler": "^5.3.15", + "@smithy/hash-node": "^4.2.12", + "@smithy/invalid-dependency": "^4.2.12", + "@smithy/middleware-content-length": "^4.2.12", + "@smithy/middleware-endpoint": "^4.4.28", + "@smithy/middleware-retry": "^4.4.45", + "@smithy/middleware-serde": "^4.2.16", + "@smithy/middleware-stack": "^4.2.12", + "@smithy/node-config-provider": "^4.3.12", + "@smithy/node-http-handler": "^4.5.1", + "@smithy/protocol-http": "^5.3.12", + "@smithy/smithy-client": "^4.12.8", + "@smithy/types": "^4.13.1", + "@smithy/url-parser": "^4.2.12", + "@smithy/util-base64": "^4.3.2", + "@smithy/util-body-length-browser": "^4.2.2", + "@smithy/util-body-length-node": "^4.2.3", + "@smithy/util-defaults-mode-browser": "^4.3.44", + "@smithy/util-defaults-mode-node": "^4.2.48", + "@smithy/util-endpoints": "^3.3.3", + "@smithy/util-middleware": "^4.2.12", + "@smithy/util-retry": "^4.2.12", + "@smithy/util-utf8": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/region-config-resolver": { + "version": "3.972.10", + "resolved": "https://registry.npmmirror.com/@aws-sdk/region-config-resolver/-/region-config-resolver-3.972.10.tgz", + "integrity": "sha512-1dq9ToC6e070QvnVhhbAs3bb5r6cQ10gTVc6cyRV5uvQe7P138TV2uG2i6+Yok4bAkVAcx5AqkTEBUvWEtBlsQ==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@smithy/config-resolver": "^4.4.13", + "@smithy/node-config-provider": "^4.3.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/token-providers": { + "version": "3.1020.0", + "resolved": "https://registry.npmmirror.com/@aws-sdk/token-providers/-/token-providers-3.1020.0.tgz", + "integrity": "sha512-T61KA/VKl0zVUubdxigr1ut7SEpwE1/4CIKb14JDLyTAOne2yWKtQE1dDCSHl0UqrZNwW/bTt+EBHfQbslZJdw==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/core": "^3.973.26", + "@aws-sdk/nested-clients": "^3.996.17", + "@aws-sdk/types": "^3.973.6", + "@smithy/property-provider": "^4.2.12", + "@smithy/shared-ini-file-loader": "^4.4.7", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/types": { + "version": "3.973.6", + "resolved": "https://registry.npmmirror.com/@aws-sdk/types/-/types-3.973.6.tgz", + "integrity": "sha512-Atfcy4E++beKtwJHiDln2Nby8W/mam64opFPTiHEqgsthqeydFS1pY+OUlN1ouNOmf8ArPU/6cDS65anOP3KQw==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/util-endpoints": { + "version": "3.996.5", + "resolved": "https://registry.npmmirror.com/@aws-sdk/util-endpoints/-/util-endpoints-3.996.5.tgz", + "integrity": "sha512-Uh93L5sXFNbyR5sEPMzUU8tJ++Ku97EY4udmC01nB8Zu+xfBPwpIwJ6F7snqQeq8h2pf+8SGN5/NoytfKgYPIw==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@smithy/types": "^4.13.1", + "@smithy/url-parser": "^4.2.12", + "@smithy/util-endpoints": "^3.3.3", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/util-format-url": { + "version": "3.972.8", + "resolved": "https://registry.npmmirror.com/@aws-sdk/util-format-url/-/util-format-url-3.972.8.tgz", + "integrity": "sha512-J6DS9oocrgxM8xlUTTmQOuwRF6rnAGEujAN9SAzllcrQmwn5iJ58ogxy3SEhD0Q7JZvlA5jvIXBkpQRqEqlE9A==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@smithy/querystring-builder": "^4.2.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/util-locate-window": { + "version": "3.965.5", + "resolved": "https://registry.npmmirror.com/@aws-sdk/util-locate-window/-/util-locate-window-3.965.5.tgz", + "integrity": "sha512-WhlJNNINQB+9qtLtZJcpQdgZw3SCDCpXdUJP7cToGwHbCWCnRckGlc6Bx/OhWwIYFNAn+FIydY8SZ0QmVu3xTQ==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws-sdk/util-user-agent-browser": { + "version": "3.972.8", + "resolved": "https://registry.npmmirror.com/@aws-sdk/util-user-agent-browser/-/util-user-agent-browser-3.972.8.tgz", + "integrity": "sha512-B3KGXJviV2u6Cdw2SDY2aDhoJkVfY/Q/Trwk2CMSkikE1Oi6gRzxhvhIfiRpHfmIsAhV4EA54TVEX8K6CbHbkA==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/types": "^3.973.6", + "@smithy/types": "^4.13.1", + "bowser": "^2.11.0", + "tslib": "^2.6.2" + } + }, + "node_modules/@aws-sdk/util-user-agent-node": { + "version": "3.973.13", + "resolved": "https://registry.npmmirror.com/@aws-sdk/util-user-agent-node/-/util-user-agent-node-3.973.13.tgz", + "integrity": "sha512-s1dCJ0J9WU9UPkT3FFqhKTSquYTkqWXGRaapHFyWwwJH86ZussewhNST5R5TwXVL1VSHq4aJVl9fWK+svaRVCQ==", + "license": "Apache-2.0", + "dependencies": { + "@aws-sdk/middleware-user-agent": "^3.972.27", + "@aws-sdk/types": "^3.973.6", + "@smithy/node-config-provider": "^4.3.12", + "@smithy/types": "^4.13.1", + "@smithy/util-config-provider": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + }, + "peerDependencies": { + "aws-crt": ">=1.0.0" + }, + "peerDependenciesMeta": { + "aws-crt": { + "optional": true + } + } + }, + "node_modules/@aws-sdk/xml-builder": { + "version": "3.972.16", + "resolved": "https://registry.npmmirror.com/@aws-sdk/xml-builder/-/xml-builder-3.972.16.tgz", + "integrity": "sha512-iu2pyvaqmeatIJLURLqx9D+4jKAdTH20ntzB6BFwjyN7V960r4jK32mx0Zf7YbtOYAbmbtQfDNuL60ONinyw7A==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "fast-xml-parser": "5.5.8", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=20.0.0" + } + }, + "node_modules/@aws/lambda-invoke-store": { + "version": "0.2.4", + "resolved": "https://registry.npmmirror.com/@aws/lambda-invoke-store/-/lambda-invoke-store-0.2.4.tgz", + "integrity": "sha512-iY8yvjE0y651BixKNPgmv1WrQc+GZ142sb0z4gYnChDDY2YqI4P/jsSopBWrKfAt7LOJAkOXt7rC/hms+WclQQ==", + "license": "Apache-2.0", + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@babel/runtime": { + "version": "7.29.2", + "resolved": "https://registry.npmmirror.com/@babel/runtime/-/runtime-7.29.2.tgz", + "integrity": "sha512-JiDShH45zKHWyGe4ZNVRrCjBz8Nh9TMmZG1kh4QTK8hCBTWBi8Da+i7s1fJw7/lYpM4ccepSNfqzZ/QvABBi5g==", + "license": "MIT", + "engines": { + "node": ">=6.9.0" + } + }, + "node_modules/@commander-js/extra-typings": { + "version": "14.0.0", + "resolved": "https://registry.npmmirror.com/@commander-js/extra-typings/-/extra-typings-14.0.0.tgz", + "integrity": "sha512-hIn0ncNaJRLkZrxBIp5AsW/eXEHNKYQBh0aPdoUqNgD+Io3NIykQqpKFyKcuasZhicGaEZJX/JBSIkZ4e5x8Dg==", + "license": "MIT", + "peerDependencies": { + "commander": "~14.0.0" + } + }, + "node_modules/@growthbook/growthbook": { + "version": "1.6.5", + "resolved": "https://registry.npmmirror.com/@growthbook/growthbook/-/growthbook-1.6.5.tgz", + "integrity": "sha512-mUaMsgeUTpRIUOTn33EUXHRK6j7pxBjwqH4WpQyq+pukjd1AIzWlEa6w7i6bInJUcweGgP2beXZmaP6b6UPn7A==", + "license": "MIT", + "dependencies": { + "dom-mutator": "^0.6.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/@hono/node-server": { + "version": "1.19.12", + "resolved": "https://registry.npmmirror.com/@hono/node-server/-/node-server-1.19.12.tgz", + "integrity": "sha512-txsUW4SQ1iilgE0l9/e9VQWmELXifEFvmdA1j6WFh/aFPj99hIntrSsq/if0UWyGVkmrRPKA1wCeP+UCr1B9Uw==", + "license": "MIT", + "engines": { + "node": ">=18.14.1" + }, + "peerDependencies": { + "hono": "^4" + } + }, + "node_modules/@modelcontextprotocol/sdk": { + "version": "1.29.0", + "resolved": "https://registry.npmmirror.com/@modelcontextprotocol/sdk/-/sdk-1.29.0.tgz", + "integrity": "sha512-zo37mZA9hJWpULgkRpowewez1y6ML5GsXJPY8FI0tBBCd77HEvza4jDqRKOXgHNn867PVGCyTdzqpz0izu5ZjQ==", + "license": "MIT", + "dependencies": { + "@hono/node-server": "^1.19.9", + "ajv": "^8.17.1", + "ajv-formats": "^3.0.1", + "content-type": "^1.0.5", + "cors": "^2.8.5", + "cross-spawn": "^7.0.5", + "eventsource": "^3.0.2", + "eventsource-parser": "^3.0.0", + "express": "^5.2.1", + "express-rate-limit": "^8.2.1", + "hono": "^4.11.4", + "jose": "^6.1.3", + "json-schema-typed": "^8.0.2", + "pkce-challenge": "^5.0.0", + "raw-body": "^3.0.0", + "zod": "^3.25 || ^4.0", + "zod-to-json-schema": "^3.25.1" + }, + "engines": { + "node": ">=18" + }, + "peerDependencies": { + "@cfworker/json-schema": "^4.1.1", + "zod": "^3.25 || ^4.0" + }, + "peerDependenciesMeta": { + "@cfworker/json-schema": { + "optional": true + }, + "zod": { + "optional": false + } + } + }, + "node_modules/@opentelemetry/api": { + "version": "1.9.1", + "resolved": "https://registry.npmmirror.com/@opentelemetry/api/-/api-1.9.1.tgz", + "integrity": "sha512-gLyJlPHPZYdAk1JENA9LeHejZe1Ti77/pTeFm/nMXmQH/HFZlcS/O2XJB+L8fkbrNSqhdtlvjBVjxwUYanNH5Q==", + "license": "Apache-2.0", + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/@opentelemetry/api-logs": { + "version": "0.214.0", + "resolved": "https://registry.npmmirror.com/@opentelemetry/api-logs/-/api-logs-0.214.0.tgz", + "integrity": "sha512-40lSJeqYO8Uz2Yj7u94/SJWE/wONa7rmMKjI1ZcIjgf3MHNHv1OZUCrCETGuaRF62d5pQD1wKIW+L4lmSMTzZA==", + "license": "Apache-2.0", + "dependencies": { + "@opentelemetry/api": "^1.3.0" + }, + "engines": { + "node": ">=8.0.0" + } + }, + "node_modules/@opentelemetry/core": { + "version": "2.6.1", + "resolved": "https://registry.npmmirror.com/@opentelemetry/core/-/core-2.6.1.tgz", + "integrity": "sha512-8xHSGWpJP9wBxgBpnqGL0R3PbdWQndL1Qp50qrg71+B28zK5OQmUgcDKLJgzyAAV38t4tOyLMGDD60LneR5W8g==", + "license": "Apache-2.0", + "dependencies": { + "@opentelemetry/semantic-conventions": "^1.29.0" + }, + "engines": { + "node": "^18.19.0 || >=20.6.0" + }, + "peerDependencies": { + "@opentelemetry/api": ">=1.0.0 <1.10.0" + } + }, + "node_modules/@opentelemetry/resources": { + "version": "2.6.1", + "resolved": "https://registry.npmmirror.com/@opentelemetry/resources/-/resources-2.6.1.tgz", + "integrity": "sha512-lID/vxSuKWXM55XhAKNoYXu9Cutoq5hFdkbTdI/zDKQktXzcWBVhNsOkiZFTMU9UtEWuGRNe0HUgmsFldIdxVA==", + "license": "Apache-2.0", + "dependencies": { + "@opentelemetry/core": "2.6.1", + "@opentelemetry/semantic-conventions": "^1.29.0" + }, + "engines": { + "node": "^18.19.0 || >=20.6.0" + }, + "peerDependencies": { + "@opentelemetry/api": ">=1.3.0 <1.10.0" + } + }, + "node_modules/@opentelemetry/sdk-logs": { + "version": "0.214.0", + "resolved": "https://registry.npmmirror.com/@opentelemetry/sdk-logs/-/sdk-logs-0.214.0.tgz", + "integrity": "sha512-zf6acnScjhsaBUU22zXZ/sLWim1dfhUAbGXdMmHmNG3LfBnQ3DKsOCITb2IZwoUsNNMTogqFKBnlIPPftUgGwA==", + "license": "Apache-2.0", + "dependencies": { + "@opentelemetry/api-logs": "0.214.0", + "@opentelemetry/core": "2.6.1", + "@opentelemetry/resources": "2.6.1", + "@opentelemetry/semantic-conventions": "^1.29.0" + }, + "engines": { + "node": "^18.19.0 || >=20.6.0" + }, + "peerDependencies": { + "@opentelemetry/api": ">=1.4.0 <1.10.0" + } + }, + "node_modules/@opentelemetry/sdk-metrics": { + "version": "2.6.1", + "resolved": "https://registry.npmmirror.com/@opentelemetry/sdk-metrics/-/sdk-metrics-2.6.1.tgz", + "integrity": "sha512-9t9hJHX15meBy2NmTJxL+NJfXmnausR2xUDvE19XQce0Qi/GBtDGamU8nS1RMbdgDmhgpm3VaOu2+fiS/SfTpQ==", + "license": "Apache-2.0", + "dependencies": { + "@opentelemetry/core": "2.6.1", + "@opentelemetry/resources": "2.6.1" + }, + "engines": { + "node": "^18.19.0 || >=20.6.0" + }, + "peerDependencies": { + "@opentelemetry/api": ">=1.9.0 <1.10.0" + } + }, + "node_modules/@opentelemetry/sdk-trace-base": { + "version": "2.6.1", + "resolved": "https://registry.npmmirror.com/@opentelemetry/sdk-trace-base/-/sdk-trace-base-2.6.1.tgz", + "integrity": "sha512-r86ut4T1e8vNwB35CqCcKd45yzqH6/6Wzvpk2/cZB8PsPLlZFTvrh8yfOS3CYZYcUmAx4hHTZJ8AO8Dj8nrdhw==", + "license": "Apache-2.0", + "dependencies": { + "@opentelemetry/core": "2.6.1", + "@opentelemetry/resources": "2.6.1", + "@opentelemetry/semantic-conventions": "^1.29.0" + }, + "engines": { + "node": "^18.19.0 || >=20.6.0" + }, + "peerDependencies": { + "@opentelemetry/api": ">=1.3.0 <1.10.0" + } + }, + "node_modules/@opentelemetry/semantic-conventions": { + "version": "1.40.0", + "resolved": "https://registry.npmmirror.com/@opentelemetry/semantic-conventions/-/semantic-conventions-1.40.0.tgz", + "integrity": "sha512-cifvXDhcqMwwTlTK04GBNeIe7yyo28Mfby85QXFe1Yk8nmi36Ab/5UQwptOx84SsoGNRg+EVSjwzfSZMy6pmlw==", + "license": "Apache-2.0", + "engines": { + "node": ">=14" + } + }, + "node_modules/@pondwader/socks5-server": { + "version": "1.0.10", + "resolved": "https://registry.npmmirror.com/@pondwader/socks5-server/-/socks5-server-1.0.10.tgz", + "integrity": "sha512-bQY06wzzR8D2+vVCUoBsr5QS2U6UgPUQRmErNwtsuI6vLcyRKkafjkr3KxbtGFf9aBBIV2mcvlsKD1UYaIV+sg==", + "license": "MIT" + }, + "node_modules/@sec-ant/readable-stream": { + "version": "0.4.1", + "resolved": "https://registry.npmmirror.com/@sec-ant/readable-stream/-/readable-stream-0.4.1.tgz", + "integrity": "sha512-831qok9r2t8AlxLko40y2ebgSDhenenCatLVeW/uBtnHPyhHOvG0C7TvfgecV+wHzIm5KUICgzmVpWS+IMEAeg==", + "license": "MIT" + }, + "node_modules/@sindresorhus/merge-streams": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/@sindresorhus/merge-streams/-/merge-streams-4.0.0.tgz", + "integrity": "sha512-tlqY9xq5ukxTUZBmoOp+m61cqwQD5pHJtFY3Mn8CA8ps6yghLH/Hw8UPdqg4OLmFW3IFlcXnQNmo/dh8HzXYIQ==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/@smithy/config-resolver": { + "version": "4.4.13", + "resolved": "https://registry.npmmirror.com/@smithy/config-resolver/-/config-resolver-4.4.13.tgz", + "integrity": "sha512-iIzMC5NmOUP6WL6o8iPBjFhUhBZ9pPjpUpQYWMUFQqKyXXzOftbfK8zcQCz/jFV1Psmf05BK5ypx4K2r4Tnwdg==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/node-config-provider": "^4.3.12", + "@smithy/types": "^4.13.1", + "@smithy/util-config-provider": "^4.2.2", + "@smithy/util-endpoints": "^3.3.3", + "@smithy/util-middleware": "^4.2.12", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/core": { + "version": "3.23.13", + "resolved": "https://registry.npmmirror.com/@smithy/core/-/core-3.23.13.tgz", + "integrity": "sha512-J+2TT9D6oGsUVXVEMvz8h2EmdVnkBiy2auCie4aSJMvKlzUtO5hqjEzXhoCUkIMo7gAYjbQcN0g/MMSXEhDs1Q==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/protocol-http": "^5.3.12", + "@smithy/types": "^4.13.1", + "@smithy/url-parser": "^4.2.12", + "@smithy/util-base64": "^4.3.2", + "@smithy/util-body-length-browser": "^4.2.2", + "@smithy/util-middleware": "^4.2.12", + "@smithy/util-stream": "^4.5.21", + "@smithy/util-utf8": "^4.2.2", + "@smithy/uuid": "^1.1.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/credential-provider-imds": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/credential-provider-imds/-/credential-provider-imds-4.2.12.tgz", + "integrity": "sha512-cr2lR792vNZcYMriSIj+Um3x9KWrjcu98kn234xA6reOAFMmbRpQMOv8KPgEmLLtx3eldU6c5wALKFqNOhugmg==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/node-config-provider": "^4.3.12", + "@smithy/property-provider": "^4.2.12", + "@smithy/types": "^4.13.1", + "@smithy/url-parser": "^4.2.12", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/eventstream-codec": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/eventstream-codec/-/eventstream-codec-4.2.12.tgz", + "integrity": "sha512-FE3bZdEl62ojmy8x4FHqxq2+BuOHlcxiH5vaZ6aqHJr3AIZzwF5jfx8dEiU/X0a8RboyNDjmXjlbr8AdEyLgiA==", + "license": "Apache-2.0", + "dependencies": { + "@aws-crypto/crc32": "5.2.0", + "@smithy/types": "^4.13.1", + "@smithy/util-hex-encoding": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/eventstream-serde-browser": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/eventstream-serde-browser/-/eventstream-serde-browser-4.2.12.tgz", + "integrity": "sha512-XUSuMxlTxV5pp4VpqZf6Sa3vT/Q75FVkLSpSSE3KkWBvAQWeuWt1msTv8fJfgA4/jcJhrbrbMzN1AC/hvPmm5A==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/eventstream-serde-universal": "^4.2.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/eventstream-serde-config-resolver": { + "version": "4.3.12", + "resolved": "https://registry.npmmirror.com/@smithy/eventstream-serde-config-resolver/-/eventstream-serde-config-resolver-4.3.12.tgz", + "integrity": "sha512-7epsAZ3QvfHkngz6RXQYseyZYHlmWXSTPOfPmXkiS+zA6TBNo1awUaMFL9vxyXlGdoELmCZyZe1nQE+imbmV+Q==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/eventstream-serde-node": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/eventstream-serde-node/-/eventstream-serde-node-4.2.12.tgz", + "integrity": "sha512-D1pFuExo31854eAvg89KMn9Oab/wEeJR6Buy32B49A9Ogdtx5fwZPqBHUlDzaCDpycTFk2+fSQgX689Qsk7UGA==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/eventstream-serde-universal": "^4.2.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/eventstream-serde-universal": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/eventstream-serde-universal/-/eventstream-serde-universal-4.2.12.tgz", + "integrity": "sha512-+yNuTiyBACxOJUTvbsNsSOfH9G9oKbaJE1lNL3YHpGcuucl6rPZMi3nrpehpVOVR2E07YqFFmtwpImtpzlouHQ==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/eventstream-codec": "^4.2.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/fetch-http-handler": { + "version": "5.3.15", + "resolved": "https://registry.npmmirror.com/@smithy/fetch-http-handler/-/fetch-http-handler-5.3.15.tgz", + "integrity": "sha512-T4jFU5N/yiIfrtrsb9uOQn7RdELdM/7HbyLNr6uO/mpkj1ctiVs7CihVr51w4LyQlXWDpXFn4BElf1WmQvZu/A==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/protocol-http": "^5.3.12", + "@smithy/querystring-builder": "^4.2.12", + "@smithy/types": "^4.13.1", + "@smithy/util-base64": "^4.3.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/hash-node": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/hash-node/-/hash-node-4.2.12.tgz", + "integrity": "sha512-QhBYbGrbxTkZ43QoTPrK72DoYviDeg6YKDrHTMJbbC+A0sml3kSjzFtXP7BtbyJnXojLfTQldGdUR0RGD8dA3w==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "@smithy/util-buffer-from": "^4.2.2", + "@smithy/util-utf8": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/invalid-dependency": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/invalid-dependency/-/invalid-dependency-4.2.12.tgz", + "integrity": "sha512-/4F1zb7Z8LOu1PalTdESFHR0RbPwHd3FcaG1sI3UEIriQTWakysgJr65lc1jj6QY5ye7aFsisajotH6UhWfm/g==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/is-array-buffer": { + "version": "4.2.2", + "resolved": "https://registry.npmmirror.com/@smithy/is-array-buffer/-/is-array-buffer-4.2.2.tgz", + "integrity": "sha512-n6rQ4N8Jj4YTQO3YFrlgZuwKodf4zUFs7EJIWH86pSCWBaAtAGBFfCM7Wx6D2bBJ2xqFNxGBSrUWswT3M0VJow==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/middleware-content-length": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/middleware-content-length/-/middleware-content-length-4.2.12.tgz", + "integrity": "sha512-YE58Yz+cvFInWI/wOTrB+DbvUVz/pLn5mC5MvOV4fdRUc6qGwygyngcucRQjAhiCEbmfLOXX0gntSIcgMvAjmA==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/protocol-http": "^5.3.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/middleware-endpoint": { + "version": "4.4.28", + "resolved": "https://registry.npmmirror.com/@smithy/middleware-endpoint/-/middleware-endpoint-4.4.28.tgz", + "integrity": "sha512-p1gfYpi91CHcs5cBq982UlGlDrxoYUX6XdHSo91cQ2KFuz6QloHosO7Jc60pJiVmkWrKOV8kFYlGFFbQ2WUKKQ==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/core": "^3.23.13", + "@smithy/middleware-serde": "^4.2.16", + "@smithy/node-config-provider": "^4.3.12", + "@smithy/shared-ini-file-loader": "^4.4.7", + "@smithy/types": "^4.13.1", + "@smithy/url-parser": "^4.2.12", + "@smithy/util-middleware": "^4.2.12", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/middleware-retry": { + "version": "4.4.46", + "resolved": "https://registry.npmmirror.com/@smithy/middleware-retry/-/middleware-retry-4.4.46.tgz", + "integrity": "sha512-SpvWNNOPOrKQGUqZbEPO+es+FRXMWvIyzUKUOYdDgdlA6BdZj/R58p4umoQ76c2oJC44PiM7mKizyyex1IJzow==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/node-config-provider": "^4.3.12", + "@smithy/protocol-http": "^5.3.12", + "@smithy/service-error-classification": "^4.2.12", + "@smithy/smithy-client": "^4.12.8", + "@smithy/types": "^4.13.1", + "@smithy/util-middleware": "^4.2.12", + "@smithy/util-retry": "^4.2.13", + "@smithy/uuid": "^1.1.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/middleware-serde": { + "version": "4.2.16", + "resolved": "https://registry.npmmirror.com/@smithy/middleware-serde/-/middleware-serde-4.2.16.tgz", + "integrity": "sha512-beqfV+RZ9RSv+sQqor3xroUUYgRFCGRw6niGstPG8zO9LgTl0B0MCucxjmrH/2WwksQN7UUgI7KNANoZv+KALA==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/core": "^3.23.13", + "@smithy/protocol-http": "^5.3.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/middleware-stack": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/middleware-stack/-/middleware-stack-4.2.12.tgz", + "integrity": "sha512-kruC5gRHwsCOuyCd4ouQxYjgRAym2uDlCvQ5acuMtRrcdfg7mFBg6blaxcJ09STpt3ziEkis6bhg1uwrWU7txw==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/node-config-provider": { + "version": "4.3.12", + "resolved": "https://registry.npmmirror.com/@smithy/node-config-provider/-/node-config-provider-4.3.12.tgz", + "integrity": "sha512-tr2oKX2xMcO+rBOjobSwVAkV05SIfUKz8iI53rzxEmgW3GOOPOv0UioSDk+J8OpRQnpnhsO3Af6IEBabQBVmiw==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/property-provider": "^4.2.12", + "@smithy/shared-ini-file-loader": "^4.4.7", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/node-http-handler": { + "version": "4.5.1", + "resolved": "https://registry.npmmirror.com/@smithy/node-http-handler/-/node-http-handler-4.5.1.tgz", + "integrity": "sha512-ejjxdAXjkPIs9lyYyVutOGNOraqUE9v/NjGMKwwFrfOM354wfSD8lmlj8hVwUzQmlLLF4+udhfCX9Exnbmvfzw==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/protocol-http": "^5.3.12", + "@smithy/querystring-builder": "^4.2.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/property-provider": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/property-provider/-/property-provider-4.2.12.tgz", + "integrity": "sha512-jqve46eYU1v7pZ5BM+fmkbq3DerkSluPr5EhvOcHxygxzD05ByDRppRwRPPpFrsFo5yDtCYLKu+kreHKVrvc7A==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/protocol-http": { + "version": "5.3.12", + "resolved": "https://registry.npmmirror.com/@smithy/protocol-http/-/protocol-http-5.3.12.tgz", + "integrity": "sha512-fit0GZK9I1xoRlR4jXmbLhoN0OdEpa96ul8M65XdmXnxXkuMxM0Y8HDT0Fh0Xb4I85MBvBClOzgSrV1X2s1Hxw==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/querystring-builder": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/querystring-builder/-/querystring-builder-4.2.12.tgz", + "integrity": "sha512-6wTZjGABQufekycfDGMEB84BgtdOE/rCVTov+EDXQ8NHKTUNIp/j27IliwP7tjIU9LR+sSzyGBOXjeEtVgzCHg==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "@smithy/util-uri-escape": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/querystring-parser": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/querystring-parser/-/querystring-parser-4.2.12.tgz", + "integrity": "sha512-P2OdvrgiAKpkPNKlKUtWbNZKB1XjPxM086NeVhK+W+wI46pIKdWBe5QyXvhUm3MEcyS/rkLvY8rZzyUdmyDZBw==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/service-error-classification": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/service-error-classification/-/service-error-classification-4.2.12.tgz", + "integrity": "sha512-LlP29oSQN0Tw0b6D0Xo6BIikBswuIiGYbRACy5ujw/JgWSzTdYj46U83ssf6Ux0GyNJVivs2uReU8pt7Eu9okQ==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/shared-ini-file-loader": { + "version": "4.4.7", + "resolved": "https://registry.npmmirror.com/@smithy/shared-ini-file-loader/-/shared-ini-file-loader-4.4.7.tgz", + "integrity": "sha512-HrOKWsUb+otTeo1HxVWeEb99t5ER1XrBi/xka2Wv6NVmTbuCUC1dvlrksdvxFtODLBjsC+PHK+fuy2x/7Ynyiw==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/signature-v4": { + "version": "5.3.12", + "resolved": "https://registry.npmmirror.com/@smithy/signature-v4/-/signature-v4-5.3.12.tgz", + "integrity": "sha512-B/FBwO3MVOL00DaRSXfXfa/TRXRheagt/q5A2NM13u7q+sHS59EOVGQNfG7DkmVtdQm5m3vOosoKAXSqn/OEgw==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/is-array-buffer": "^4.2.2", + "@smithy/protocol-http": "^5.3.12", + "@smithy/types": "^4.13.1", + "@smithy/util-hex-encoding": "^4.2.2", + "@smithy/util-middleware": "^4.2.12", + "@smithy/util-uri-escape": "^4.2.2", + "@smithy/util-utf8": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/smithy-client": { + "version": "4.12.8", + "resolved": "https://registry.npmmirror.com/@smithy/smithy-client/-/smithy-client-4.12.8.tgz", + "integrity": "sha512-aJaAX7vHe5i66smoSSID7t4rKY08PbD8EBU7DOloixvhOozfYWdcSYE4l6/tjkZ0vBZhGjheWzB2mh31sLgCMA==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/core": "^3.23.13", + "@smithy/middleware-endpoint": "^4.4.28", + "@smithy/middleware-stack": "^4.2.12", + "@smithy/protocol-http": "^5.3.12", + "@smithy/types": "^4.13.1", + "@smithy/util-stream": "^4.5.21", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/types": { + "version": "4.13.1", + "resolved": "https://registry.npmmirror.com/@smithy/types/-/types-4.13.1.tgz", + "integrity": "sha512-787F3yzE2UiJIQ+wYW1CVg2odHjmaWLGksnKQHUrK/lYZSEcy1msuLVvxaR/sI2/aDe9U+TBuLsXnr3vod1g0g==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/url-parser": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/url-parser/-/url-parser-4.2.12.tgz", + "integrity": "sha512-wOPKPEpso+doCZGIlr+e1lVI6+9VAKfL4kZWFgzVgGWY2hZxshNKod4l2LXS3PRC9otH/JRSjtEHqQ/7eLciRA==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/querystring-parser": "^4.2.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-base64": { + "version": "4.3.2", + "resolved": "https://registry.npmmirror.com/@smithy/util-base64/-/util-base64-4.3.2.tgz", + "integrity": "sha512-XRH6b0H/5A3SgblmMa5ErXQ2XKhfbQB+Fm/oyLZ2O2kCUrwgg55bU0RekmzAhuwOjA9qdN5VU2BprOvGGUkOOQ==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/util-buffer-from": "^4.2.2", + "@smithy/util-utf8": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-body-length-browser": { + "version": "4.2.2", + "resolved": "https://registry.npmmirror.com/@smithy/util-body-length-browser/-/util-body-length-browser-4.2.2.tgz", + "integrity": "sha512-JKCrLNOup3OOgmzeaKQwi4ZCTWlYR5H4Gm1r2uTMVBXoemo1UEghk5vtMi1xSu2ymgKVGW631e2fp9/R610ZjQ==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-body-length-node": { + "version": "4.2.3", + "resolved": "https://registry.npmmirror.com/@smithy/util-body-length-node/-/util-body-length-node-4.2.3.tgz", + "integrity": "sha512-ZkJGvqBzMHVHE7r/hcuCxlTY8pQr1kMtdsVPs7ex4mMU+EAbcXppfo5NmyxMYi2XU49eqaz56j2gsk4dHHPG/g==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-buffer-from": { + "version": "4.2.2", + "resolved": "https://registry.npmmirror.com/@smithy/util-buffer-from/-/util-buffer-from-4.2.2.tgz", + "integrity": "sha512-FDXD7cvUoFWwN6vtQfEta540Y/YBe5JneK3SoZg9bThSoOAC/eGeYEua6RkBgKjGa/sz6Y+DuBZj3+YEY21y4Q==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/is-array-buffer": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-config-provider": { + "version": "4.2.2", + "resolved": "https://registry.npmmirror.com/@smithy/util-config-provider/-/util-config-provider-4.2.2.tgz", + "integrity": "sha512-dWU03V3XUprJwaUIFVv4iOnS1FC9HnMHDfUrlNDSh4315v0cWyaIErP8KiqGVbf5z+JupoVpNM7ZB3jFiTejvQ==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-defaults-mode-browser": { + "version": "4.3.44", + "resolved": "https://registry.npmmirror.com/@smithy/util-defaults-mode-browser/-/util-defaults-mode-browser-4.3.44.tgz", + "integrity": "sha512-eZg6XzaCbVr2S5cAErU5eGBDaOVTuTo1I65i4tQcHENRcZ8rMWhQy1DaIYUSLyZjsfXvmCqZrstSMYyGFocvHA==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/property-provider": "^4.2.12", + "@smithy/smithy-client": "^4.12.8", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-defaults-mode-node": { + "version": "4.2.48", + "resolved": "https://registry.npmmirror.com/@smithy/util-defaults-mode-node/-/util-defaults-mode-node-4.2.48.tgz", + "integrity": "sha512-FqOKTlqSaoV3nzO55pMs5NBnZX8EhoI0DGmn9kbYeXWppgHD6dchyuj2HLqp4INJDJbSrj6OFYJkAh/WhSzZPg==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/config-resolver": "^4.4.13", + "@smithy/credential-provider-imds": "^4.2.12", + "@smithy/node-config-provider": "^4.3.12", + "@smithy/property-provider": "^4.2.12", + "@smithy/smithy-client": "^4.12.8", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-endpoints": { + "version": "3.3.3", + "resolved": "https://registry.npmmirror.com/@smithy/util-endpoints/-/util-endpoints-3.3.3.tgz", + "integrity": "sha512-VACQVe50j0HZPjpwWcjyT51KUQ4AnsvEaQ2lKHOSL4mNLD0G9BjEniQ+yCt1qqfKfiAHRAts26ud7hBjamrwig==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/node-config-provider": "^4.3.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-hex-encoding": { + "version": "4.2.2", + "resolved": "https://registry.npmmirror.com/@smithy/util-hex-encoding/-/util-hex-encoding-4.2.2.tgz", + "integrity": "sha512-Qcz3W5vuHK4sLQdyT93k/rfrUwdJ8/HZ+nMUOyGdpeGA1Wxt65zYwi3oEl9kOM+RswvYq90fzkNDahPS8K0OIg==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-middleware": { + "version": "4.2.12", + "resolved": "https://registry.npmmirror.com/@smithy/util-middleware/-/util-middleware-4.2.12.tgz", + "integrity": "sha512-Er805uFUOvgc0l8nv0e0su0VFISoxhJ/AwOn3gL2NWNY2LUEldP5WtVcRYSQBcjg0y9NfG8JYrCJaYDpupBHJQ==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-retry": { + "version": "4.2.13", + "resolved": "https://registry.npmmirror.com/@smithy/util-retry/-/util-retry-4.2.13.tgz", + "integrity": "sha512-qQQsIvL0MGIbUjeSrg0/VlQ3jGNKyM3/2iU3FPNgy01z+Sp4OvcaxbgIoFOTvB61ZoohtutuOvOcgmhbD0katQ==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/service-error-classification": "^4.2.12", + "@smithy/types": "^4.13.1", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-stream": { + "version": "4.5.21", + "resolved": "https://registry.npmmirror.com/@smithy/util-stream/-/util-stream-4.5.21.tgz", + "integrity": "sha512-KzSg+7KKywLnkoKejRtIBXDmwBfjGvg1U1i/etkC7XSWUyFCoLno1IohV2c74IzQqdhX5y3uE44r/8/wuK+A7Q==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/fetch-http-handler": "^5.3.15", + "@smithy/node-http-handler": "^4.5.1", + "@smithy/types": "^4.13.1", + "@smithy/util-base64": "^4.3.2", + "@smithy/util-buffer-from": "^4.2.2", + "@smithy/util-hex-encoding": "^4.2.2", + "@smithy/util-utf8": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-uri-escape": { + "version": "4.2.2", + "resolved": "https://registry.npmmirror.com/@smithy/util-uri-escape/-/util-uri-escape-4.2.2.tgz", + "integrity": "sha512-2kAStBlvq+lTXHyAZYfJRb/DfS3rsinLiwb+69SstC9Vb0s9vNWkRwpnj918Pfi85mzi42sOqdV72OLxWAISnw==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/util-utf8": { + "version": "4.2.2", + "resolved": "https://registry.npmmirror.com/@smithy/util-utf8/-/util-utf8-4.2.2.tgz", + "integrity": "sha512-75MeYpjdWRe8M5E3AW0O4Cx3UadweS+cwdXjwYGBW5h/gxxnbeZ877sLPX/ZJA9GVTlL/qG0dXP29JWFCD1Ayw==", + "license": "Apache-2.0", + "dependencies": { + "@smithy/util-buffer-from": "^4.2.2", + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@smithy/uuid": { + "version": "1.1.2", + "resolved": "https://registry.npmmirror.com/@smithy/uuid/-/uuid-1.1.2.tgz", + "integrity": "sha512-O/IEdcCUKkubz60tFbGA7ceITTAJsty+lBjNoorP4Z6XRqaFb/OjQjZODophEcuq68nKm6/0r+6/lLQ+XVpk8g==", + "license": "Apache-2.0", + "dependencies": { + "tslib": "^2.6.2" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/@types/lodash": { + "version": "4.17.24", + "resolved": "https://registry.npmmirror.com/@types/lodash/-/lodash-4.17.24.tgz", + "integrity": "sha512-gIW7lQLZbue7lRSWEFql49QJJWThrTFFeIMJdp3eH4tKoxm1OvEPg02rm4wCCSHS0cL3/Fizimb35b7k8atwsQ==", + "license": "MIT" + }, + "node_modules/@types/lodash-es": { + "version": "4.17.12", + "resolved": "https://registry.npmmirror.com/@types/lodash-es/-/lodash-es-4.17.12.tgz", + "integrity": "sha512-0NgftHUcV4v34VhXm8QBSftKVXtbkBG3ViCjs6+eJ5a6y6Mi/jiFGPc1sC7QK+9BFhWrURE3EOggmWaSxL9OzQ==", + "license": "MIT", + "dependencies": { + "@types/lodash": "*" + } + }, + "node_modules/accepts": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/accepts/-/accepts-2.0.0.tgz", + "integrity": "sha512-5cvg6CtKwfgdmVqY1WIiXKc3Q1bkRqGLi+2W/6ao+6Y7gu/RCwRuAhGEzh5B4KlszSuTLgZYuqFqo5bImjNKng==", + "license": "MIT", + "dependencies": { + "mime-types": "^3.0.0", + "negotiator": "^1.0.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/agent-base": { + "version": "8.0.0", + "resolved": "https://registry.npmmirror.com/agent-base/-/agent-base-8.0.0.tgz", + "integrity": "sha512-QT8i0hCz6C/KQ+KTAbSNwCHDGdmUJl2tp2ZpNlGSWCfhUNVbYG2WLE3MdZGBAgXPV4GAvjGMxo+C1hroyxmZEg==", + "license": "MIT", + "engines": { + "node": ">= 14" + } + }, + "node_modules/ajv": { + "version": "8.18.0", + "resolved": "https://registry.npmmirror.com/ajv/-/ajv-8.18.0.tgz", + "integrity": "sha512-PlXPeEWMXMZ7sPYOHqmDyCJzcfNrUr3fGNKtezX14ykXOEIvyK81d+qydx89KY5O71FKMPaQ2vBfBFI5NHR63A==", + "license": "MIT", + "dependencies": { + "fast-deep-equal": "^3.1.3", + "fast-uri": "^3.0.1", + "json-schema-traverse": "^1.0.0", + "require-from-string": "^2.0.2" + }, + "funding": { + "type": "github", + "url": "https://github.com/sponsors/epoberezkin" + } + }, + "node_modules/ajv-formats": { + "version": "3.0.1", + "resolved": "https://registry.npmmirror.com/ajv-formats/-/ajv-formats-3.0.1.tgz", + "integrity": "sha512-8iUql50EUR+uUcdRQ3HDqa6EVyo3docL8g5WJ3FNcWmu62IbkGUue/pEyLBW8VGKKucTPgqeks4fIU1DA4yowQ==", + "license": "MIT", + "dependencies": { + "ajv": "^8.0.0" + }, + "peerDependencies": { + "ajv": "^8.0.0" + }, + "peerDependenciesMeta": { + "ajv": { + "optional": true + } + } + }, + "node_modules/ansi-escapes": { + "version": "7.3.0", + "resolved": "https://registry.npmmirror.com/ansi-escapes/-/ansi-escapes-7.3.0.tgz", + "integrity": "sha512-BvU8nYgGQBxcmMuEeUEmNTvrMVjJNSH7RgW24vXexN4Ven6qCvy4TntnvlnwnMLTVlcRQQdbRY8NKnaIoeWDNg==", + "license": "MIT", + "dependencies": { + "environment": "^1.0.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ansi-regex": { + "version": "6.2.2", + "resolved": "https://registry.npmmirror.com/ansi-regex/-/ansi-regex-6.2.2.tgz", + "integrity": "sha512-Bq3SmSpyFHaWjPk8If9yc6svM8c56dB5BAtW4Qbw5jHTwwXXcTLoRMkpDJp6VL0XzlWaCHTXrkFURMYmD0sLqg==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-regex?sponsor=1" + } + }, + "node_modules/ansi-styles": { + "version": "6.2.3", + "resolved": "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-6.2.3.tgz", + "integrity": "sha512-4Dj6M28JB+oAH8kFkTLUo+a2jwOFkuqb3yucU0CANcRRUbxS0cP0nZYCGjcc3BNXwRIsUVmDGgzawme7zvJHvg==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/asciichart": { + "version": "1.5.25", + "resolved": "https://registry.npmmirror.com/asciichart/-/asciichart-1.5.25.tgz", + "integrity": "sha512-PNxzXIPPOtWq8T7bgzBtk9cI2lgS4SJZthUHEiQ1aoIc3lNzGfUvIvo9LiAnq26TACo9t1/4qP6KTGAUbzX9Xg==", + "license": "MIT" + }, + "node_modules/asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmmirror.com/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==", + "license": "MIT" + }, + "node_modules/auto-bind": { + "version": "5.0.1", + "resolved": "https://registry.npmmirror.com/auto-bind/-/auto-bind-5.0.1.tgz", + "integrity": "sha512-ooviqdwwgfIfNmDwo94wlshcdzfO64XV0Cg6oDsDYBJfITDz1EngD2z7DkbvCWn+XIMsIqW27sEVF6qcpJrRcg==", + "license": "MIT", + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/axios": { + "version": "1.14.0", + "resolved": "https://registry.npmmirror.com/axios/-/axios-1.14.0.tgz", + "integrity": "sha512-3Y8yrqLSwjuzpXuZ0oIYZ/XGgLwUIBU3uLvbcpb0pidD9ctpShJd43KSlEEkVQg6DS0G9NKyzOvBfUtDKEyHvQ==", + "license": "MIT", + "dependencies": { + "follow-redirects": "^1.15.11", + "form-data": "^4.0.5", + "proxy-from-env": "^2.1.0" + } + }, + "node_modules/base64-js": { + "version": "1.5.1", + "resolved": "https://registry.npmmirror.com/base64-js/-/base64-js-1.5.1.tgz", + "integrity": "sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "MIT" + }, + "node_modules/bidi-js": { + "version": "1.0.3", + "resolved": "https://registry.npmmirror.com/bidi-js/-/bidi-js-1.0.3.tgz", + "integrity": "sha512-RKshQI1R3YQ+n9YJz2QQ147P66ELpa1FQEg20Dk8oW9t2KgLbpDLLp9aGZ7y8WHSshDknG0bknqGw5/tyCs5tw==", + "license": "MIT", + "dependencies": { + "require-from-string": "^2.0.2" + } + }, + "node_modules/bignumber.js": { + "version": "9.3.1", + "resolved": "https://registry.npmmirror.com/bignumber.js/-/bignumber.js-9.3.1.tgz", + "integrity": "sha512-Ko0uX15oIUS7wJ3Rb30Fs6SkVbLmPBAKdlm7q9+ak9bbIeFf0MwuBsQV6z7+X768/cHsfg+WlysDWJcmthjsjQ==", + "license": "MIT", + "engines": { + "node": "*" + } + }, + "node_modules/body-parser": { + "version": "2.2.2", + "resolved": "https://registry.npmmirror.com/body-parser/-/body-parser-2.2.2.tgz", + "integrity": "sha512-oP5VkATKlNwcgvxi0vM0p/D3n2C3EReYVX+DNYs5TjZFn/oQt2j+4sVJtSMr18pdRr8wjTcBl6LoV+FUwzPmNA==", + "license": "MIT", + "dependencies": { + "bytes": "^3.1.2", + "content-type": "^1.0.5", + "debug": "^4.4.3", + "http-errors": "^2.0.0", + "iconv-lite": "^0.7.0", + "on-finished": "^2.4.1", + "qs": "^6.14.1", + "raw-body": "^3.0.1", + "type-is": "^2.0.1" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/bowser": { + "version": "2.14.1", + "resolved": "https://registry.npmmirror.com/bowser/-/bowser-2.14.1.tgz", + "integrity": "sha512-tzPjzCxygAKWFOJP011oxFHs57HzIhOEracIgAePE4pqB3LikALKnSzUyU4MGs9/iCEUuHlAJTjTc5M+u7YEGg==", + "license": "MIT" + }, + "node_modules/buffer-equal-constant-time": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", + "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==", + "license": "BSD-3-Clause" + }, + "node_modules/bytes": { + "version": "3.1.2", + "resolved": "https://registry.npmmirror.com/bytes/-/bytes-3.1.2.tgz", + "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/call-bind-apply-helpers": { + "version": "1.0.2", + "resolved": "https://registry.npmmirror.com/call-bind-apply-helpers/-/call-bind-apply-helpers-1.0.2.tgz", + "integrity": "sha512-Sp1ablJ0ivDkSzjcaJdxEunN5/XvksFJ2sMBFfq6x0ryhQV/2b/KwFe21cMpmHtPOSij8K99/wSfoEuTObmuMQ==", + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/call-bound": { + "version": "1.0.4", + "resolved": "https://registry.npmmirror.com/call-bound/-/call-bound-1.0.4.tgz", + "integrity": "sha512-+ys997U96po4Kx/ABpBCqhA9EuxJaQWDQg7295H4hBphv3IZg0boBKuwYpt4YXp6MZ5AmZQnU/tyMTlRpaSejg==", + "license": "MIT", + "dependencies": { + "call-bind-apply-helpers": "^1.0.2", + "get-intrinsic": "^1.3.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmmirror.com/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==", + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/chalk": { + "version": "5.6.2", + "resolved": "https://registry.npmmirror.com/chalk/-/chalk-5.6.2.tgz", + "integrity": "sha512-7NzBL0rN6fMUW+f7A6Io4h40qQlG+xGmtMxfbnH/K7TAtt8JQWVQK+6g0UXKMeVJoyV5EkkNsErQ8pVD3bLHbA==", + "license": "MIT", + "engines": { + "node": "^12.17.0 || ^14.13 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/chalk/chalk?sponsor=1" + } + }, + "node_modules/chokidar": { + "version": "5.0.0", + "resolved": "https://registry.npmmirror.com/chokidar/-/chokidar-5.0.0.tgz", + "integrity": "sha512-TQMmc3w+5AxjpL8iIiwebF73dRDF4fBIieAqGn9RGCWaEVwQ6Fb2cGe31Yns0RRIzii5goJ1Y7xbMwo1TxMplw==", + "license": "MIT", + "dependencies": { + "readdirp": "^5.0.0" + }, + "engines": { + "node": ">= 20.19.0" + }, + "funding": { + "url": "https://paulmillr.com/funding/" + } + }, + "node_modules/cli-boxes": { + "version": "4.0.1", + "resolved": "https://registry.npmmirror.com/cli-boxes/-/cli-boxes-4.0.1.tgz", + "integrity": "sha512-5IOn+jcCEHEraYolBPs/sT4BxYCe2nHg374OPiItB1O96KZFseS2gthU4twyYzeDcFew4DaUM/xwc5BQf08JJw==", + "license": "MIT", + "engines": { + "node": ">=18.20 <19 || >=20.10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/cli-cursor": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/cli-cursor/-/cli-cursor-4.0.0.tgz", + "integrity": "sha512-VGtlMu3x/4DOtIUwEkRezxUZ2lBacNJCHash0N0WeZDBS+7Ux1dm3XWAgWYxLJFMMdOeXMHXorshEFhbMSGelg==", + "license": "MIT", + "dependencies": { + "restore-cursor": "^4.0.0" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/cli-truncate": { + "version": "5.2.0", + "resolved": "https://registry.npmmirror.com/cli-truncate/-/cli-truncate-5.2.0.tgz", + "integrity": "sha512-xRwvIOMGrfOAnM1JYtqQImuaNtDEv9v6oIYAs4LIHwTiKee8uwvIi363igssOC0O5U04i4AlENs79LQLu9tEMw==", + "license": "MIT", + "dependencies": { + "slice-ansi": "^8.0.0", + "string-width": "^8.2.0" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/cliui": { + "version": "6.0.0", + "resolved": "https://registry.npmmirror.com/cliui/-/cliui-6.0.0.tgz", + "integrity": "sha512-t6wbgtoCXvAzst7QgXxJYqPt0usEfbgQdftEPbLL/cvv6HPE5VgvqCuAIDR0NgU52ds6rFwqrgakNLrHEjCbrQ==", + "license": "ISC", + "dependencies": { + "string-width": "^4.2.0", + "strip-ansi": "^6.0.0", + "wrap-ansi": "^6.2.0" + } + }, + "node_modules/cliui/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmmirror.com/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/ansi-styles": { + "version": "4.3.0", + "resolved": "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz", + "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==", + "license": "MIT", + "dependencies": { + "color-convert": "^2.0.1" + }, + "engines": { + "node": ">=8" + }, + "funding": { + "url": "https://github.com/chalk/ansi-styles?sponsor=1" + } + }, + "node_modules/cliui/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmmirror.com/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "license": "MIT" + }, + "node_modules/cliui/node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmmirror.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmmirror.com/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmmirror.com/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/cliui/node_modules/wrap-ansi": { + "version": "6.2.0", + "resolved": "https://registry.npmmirror.com/wrap-ansi/-/wrap-ansi-6.2.0.tgz", + "integrity": "sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==", + "license": "MIT", + "dependencies": { + "ansi-styles": "^4.0.0", + "string-width": "^4.1.0", + "strip-ansi": "^6.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/code-excerpt": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/code-excerpt/-/code-excerpt-4.0.0.tgz", + "integrity": "sha512-xxodCmBen3iy2i0WtAK8FlFNrRzjUqjRsMfho58xT/wvZU1YTM3fCnRjcy1gJPMepaRlgm/0e6w8SpWHpn3/cA==", + "license": "MIT", + "dependencies": { + "convert-to-spaces": "^2.0.1" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + } + }, + "node_modules/color-convert": { + "version": "2.0.1", + "resolved": "https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz", + "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==", + "license": "MIT", + "dependencies": { + "color-name": "~1.1.4" + }, + "engines": { + "node": ">=7.0.0" + } + }, + "node_modules/color-name": { + "version": "1.1.4", + "resolved": "https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz", + "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==", + "license": "MIT" + }, + "node_modules/combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmmirror.com/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "license": "MIT", + "dependencies": { + "delayed-stream": "~1.0.0" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/commander": { + "version": "14.0.3", + "resolved": "https://registry.npmmirror.com/commander/-/commander-14.0.3.tgz", + "integrity": "sha512-H+y0Jo/T1RZ9qPP4Eh1pkcQcLRglraJaSLoyOtHxu6AapkjWVCy2Sit1QQ4x3Dng8qDlSsZEet7g5Pq06MvTgw==", + "license": "MIT", + "peer": true, + "engines": { + "node": ">=20" + } + }, + "node_modules/content-disposition": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/content-disposition/-/content-disposition-1.0.1.tgz", + "integrity": "sha512-oIXISMynqSqm241k6kcQ5UwttDILMK4BiurCfGEREw6+X9jkkpEe5T9FZaApyLGGOnFuyMWZpdolTXMtvEJ08Q==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/content-type": { + "version": "1.0.5", + "resolved": "https://registry.npmmirror.com/content-type/-/content-type-1.0.5.tgz", + "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/convert-to-spaces": { + "version": "2.0.1", + "resolved": "https://registry.npmmirror.com/convert-to-spaces/-/convert-to-spaces-2.0.1.tgz", + "integrity": "sha512-rcQ1bsQO9799wq24uE5AM2tAILy4gXGIK/njFWcVQkGNZ96edlpY+A7bjwvzjYvLDyzmG1MmMLZhpcsb+klNMQ==", + "license": "MIT", + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + } + }, + "node_modules/cookie": { + "version": "0.7.2", + "resolved": "https://registry.npmmirror.com/cookie/-/cookie-0.7.2.tgz", + "integrity": "sha512-yki5XnKuf750l50uGTllt6kKILY4nQ1eNIQatoXEByZ5dWgnKqbnqmTrBE5B4N7lrMJKQ2ytWMiTO2o0v6Ew/w==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/cookie-signature": { + "version": "1.2.2", + "resolved": "https://registry.npmmirror.com/cookie-signature/-/cookie-signature-1.2.2.tgz", + "integrity": "sha512-D76uU73ulSXrD1UXF4KE2TMxVVwhsnCgfAyTg9k8P6KGZjlXKrOLe4dJQKI3Bxi5wjesZoFXJWElNWBjPZMbhg==", + "license": "MIT", + "engines": { + "node": ">=6.6.0" + } + }, + "node_modules/cors": { + "version": "2.8.6", + "resolved": "https://registry.npmmirror.com/cors/-/cors-2.8.6.tgz", + "integrity": "sha512-tJtZBBHA6vjIAaF6EnIaq6laBBP9aq/Y3ouVJjEfoHbRBcHBAHYcMh/w8LDrk2PvIMMq8gmopa5D4V8RmbrxGw==", + "license": "MIT", + "dependencies": { + "object-assign": "^4", + "vary": "^1" + }, + "engines": { + "node": ">= 0.10" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/cross-spawn": { + "version": "7.0.6", + "resolved": "https://registry.npmmirror.com/cross-spawn/-/cross-spawn-7.0.6.tgz", + "integrity": "sha512-uV2QOWP2nWzsy2aMp8aRibhi9dlzF5Hgh5SHaB9OiTGEyDTiJJyx0uy51QXdyWbtAHNua4XJzUKca3OzKUd3vA==", + "license": "MIT", + "dependencies": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/cssfilter": { + "version": "0.0.10", + "resolved": "https://registry.npmmirror.com/cssfilter/-/cssfilter-0.0.10.tgz", + "integrity": "sha512-FAaLDaplstoRsDR8XGYH51znUN0UY7nMc6Z9/fvE8EXGwvJE9hu7W2vHwx1+bd6gCYnln9nLbzxFTrcO9YQDZw==", + "license": "MIT" + }, + "node_modules/data-uri-to-buffer": { + "version": "4.0.1", + "resolved": "https://registry.npmmirror.com/data-uri-to-buffer/-/data-uri-to-buffer-4.0.1.tgz", + "integrity": "sha512-0R9ikRb668HB7QDxT1vkpuUBtqc53YyAwMwGeUFKRojY/NWKvdZ+9UYtRfGmhqNbRkTSVpMbmyhXipFFv2cb/A==", + "license": "MIT", + "engines": { + "node": ">= 12" + } + }, + "node_modules/debug": { + "version": "4.4.3", + "resolved": "https://registry.npmmirror.com/debug/-/debug-4.4.3.tgz", + "integrity": "sha512-RGwwWnwQvkVfavKVt22FGLw+xYSdzARwm0ru6DhTVA3umU5hZc28V3kO4stgYryrTlLpuvgI9GiijltAjNbcqA==", + "license": "MIT", + "dependencies": { + "ms": "^2.1.3" + }, + "engines": { + "node": ">=6.0" + }, + "peerDependenciesMeta": { + "supports-color": { + "optional": true + } + } + }, + "node_modules/decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmmirror.com/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha512-z2S+W9X73hAUUki+N+9Za2lBlun89zigOyGrsax+KUQ6wKW4ZoWpEYBkGhQjwAjjDCkWxhY0VKEhk8wzY7F5cA==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==", + "license": "MIT", + "engines": { + "node": ">=0.4.0" + } + }, + "node_modules/depd": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/depd/-/depd-2.0.0.tgz", + "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/diff": { + "version": "8.0.4", + "resolved": "https://registry.npmmirror.com/diff/-/diff-8.0.4.tgz", + "integrity": "sha512-DPi0FmjiSU5EvQV0++GFDOJ9ASQUVFh5kD+OzOnYdi7n3Wpm9hWWGfB/O2blfHcMVTL5WkQXSnRiK9makhrcnw==", + "license": "BSD-3-Clause", + "engines": { + "node": ">=0.3.1" + } + }, + "node_modules/dijkstrajs": { + "version": "1.0.3", + "resolved": "https://registry.npmmirror.com/dijkstrajs/-/dijkstrajs-1.0.3.tgz", + "integrity": "sha512-qiSlmBq9+BCdCA/L46dw8Uy93mloxsPSbwnm5yrKn2vMPiy8KyAskTF6zuV/j5BMsmOGZDPs7KjU+mjb670kfA==", + "license": "MIT" + }, + "node_modules/dom-mutator": { + "version": "0.6.0", + "resolved": "https://registry.npmmirror.com/dom-mutator/-/dom-mutator-0.6.0.tgz", + "integrity": "sha512-iCt9o0aYfXMUkz/43ZOAUFQYotjGB+GNbYJiJdz4TgXkyToXbbRy5S6FbTp72lRBtfpUMwEc1KmpFEU4CZeoNg==", + "license": "MIT", + "engines": { + "node": ">=10" + } + }, + "node_modules/dunder-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/dunder-proto/-/dunder-proto-1.0.1.tgz", + "integrity": "sha512-KIN/nDJBQRcXw0MLVhZE9iQHmG68qAVIBg9CqmUYjmQIhgij9U5MFvrqkUL5FbtyyzZuOeOt0zdeRe4UY7ct+A==", + "license": "MIT", + "dependencies": { + "call-bind-apply-helpers": "^1.0.1", + "es-errors": "^1.3.0", + "gopd": "^1.2.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/ecdsa-sig-formatter": { + "version": "1.0.11", + "resolved": "https://registry.npmmirror.com/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", + "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", + "license": "Apache-2.0", + "dependencies": { + "safe-buffer": "^5.0.1" + } + }, + "node_modules/ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmmirror.com/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==", + "license": "MIT" + }, + "node_modules/emoji-regex": { + "version": "10.6.0", + "resolved": "https://registry.npmmirror.com/emoji-regex/-/emoji-regex-10.6.0.tgz", + "integrity": "sha512-toUI84YS5YmxW219erniWD0CIVOo46xGKColeNQRgOzDorgBi1v4D71/OFzgD9GO2UGKIv1C3Sp8DAn0+j5w7A==", + "license": "MIT" + }, + "node_modules/encodeurl": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/encodeurl/-/encodeurl-2.0.0.tgz", + "integrity": "sha512-Q0n9HRi4m6JuGIV1eFlmvJB7ZEVxu93IrMyiMsGC0lrMJMWzRgx6WGquyfQgZVb31vhGgXnfmPNNXmxnOkRBrg==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/env-paths": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/env-paths/-/env-paths-4.0.0.tgz", + "integrity": "sha512-pxP8eL2SwwaTRi/KHYwLYXinDs7gL3jxFcBYmEdYfZmZXbaVDvdppd0XBU8qVz03rDfKZMXg1omHCbsJjZrMsw==", + "license": "MIT", + "dependencies": { + "is-safe-filename": "^0.1.0" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/environment": { + "version": "1.1.0", + "resolved": "https://registry.npmmirror.com/environment/-/environment-1.1.0.tgz", + "integrity": "sha512-xUtoPkMggbz0MPyPiIWr1Kp4aeWJjDZ6SMvURhimjdZgsRuDplF5/s9hcgGhyXMhs+6vpnuoiZ2kFiu3FMnS8Q==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/es-define-property": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/es-define-property/-/es-define-property-1.0.1.tgz", + "integrity": "sha512-e3nRfgfUZ4rNGL232gUgX06QNyyez04KdjFrF+LTRoOXmrOgFKDg4BCdsjW8EnT69eqdYGmRpJwiPVYNrCaW3g==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmmirror.com/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-object-atoms": { + "version": "1.1.1", + "resolved": "https://registry.npmmirror.com/es-object-atoms/-/es-object-atoms-1.1.1.tgz", + "integrity": "sha512-FGgH2h8zKNim9ljj7dankFPcICIK9Cp5bm+c2gQSYePhpaG5+esrLODihIorn+Pe6FGJzWhXQotPv73jTaldXA==", + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-set-tostringtag": { + "version": "2.1.0", + "resolved": "https://registry.npmmirror.com/es-set-tostringtag/-/es-set-tostringtag-2.1.0.tgz", + "integrity": "sha512-j6vWzfrGVfyXxge+O0x5sh6cvxAog0a/4Rdd2K36zCMV5eJ+/+tOAngRO8cODMNWbVRdVlmGZQL2YS3yR8bIUA==", + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.6", + "has-tostringtag": "^1.0.2", + "hasown": "^2.0.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-toolkit": { + "version": "1.45.1", + "resolved": "https://registry.npmmirror.com/es-toolkit/-/es-toolkit-1.45.1.tgz", + "integrity": "sha512-/jhoOj/Fx+A+IIyDNOvO3TItGmlMKhtX8ISAHKE90c4b/k1tqaqEZ+uUqfpU8DMnW5cgNJv606zS55jGvza0Xw==", + "license": "MIT", + "workspaces": [ + "docs", + "benchmarks" + ] + }, + "node_modules/escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmmirror.com/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==", + "license": "MIT" + }, + "node_modules/escape-string-regexp": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", + "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/etag": { + "version": "1.8.1", + "resolved": "https://registry.npmmirror.com/etag/-/etag-1.8.1.tgz", + "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/eventsource": { + "version": "3.0.7", + "resolved": "https://registry.npmmirror.com/eventsource/-/eventsource-3.0.7.tgz", + "integrity": "sha512-CRT1WTyuQoD771GW56XEZFQ/ZoSfWid1alKGDYMmkt2yl8UXrVR4pspqWNEcqKvVIzg6PAltWjxcSSPrboA4iA==", + "license": "MIT", + "dependencies": { + "eventsource-parser": "^3.0.1" + }, + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/eventsource-parser": { + "version": "3.0.6", + "resolved": "https://registry.npmmirror.com/eventsource-parser/-/eventsource-parser-3.0.6.tgz", + "integrity": "sha512-Vo1ab+QXPzZ4tCa8SwIHJFaSzy4R6SHf7BY79rFBDf0idraZWAkYrDjDj8uWaSm3S2TK+hJ7/t1CEmZ7jXw+pg==", + "license": "MIT", + "engines": { + "node": ">=18.0.0" + } + }, + "node_modules/execa": { + "version": "9.6.1", + "resolved": "https://registry.npmmirror.com/execa/-/execa-9.6.1.tgz", + "integrity": "sha512-9Be3ZoN4LmYR90tUoVu2te2BsbzHfhJyfEiAVfz7N5/zv+jduIfLrV2xdQXOHbaD6KgpGdO9PRPM1Y4Q9QkPkA==", + "license": "MIT", + "dependencies": { + "@sindresorhus/merge-streams": "^4.0.0", + "cross-spawn": "^7.0.6", + "figures": "^6.1.0", + "get-stream": "^9.0.0", + "human-signals": "^8.0.1", + "is-plain-obj": "^4.1.0", + "is-stream": "^4.0.1", + "npm-run-path": "^6.0.0", + "pretty-ms": "^9.2.0", + "signal-exit": "^4.1.0", + "strip-final-newline": "^4.0.0", + "yoctocolors": "^2.1.1" + }, + "engines": { + "node": "^18.19.0 || >=20.5.0" + }, + "funding": { + "url": "https://github.com/sindresorhus/execa?sponsor=1" + } + }, + "node_modules/express": { + "version": "5.2.1", + "resolved": "https://registry.npmmirror.com/express/-/express-5.2.1.tgz", + "integrity": "sha512-hIS4idWWai69NezIdRt2xFVofaF4j+6INOpJlVOLDO8zXGpUVEVzIYk12UUi2JzjEzWL3IOAxcTubgz9Po0yXw==", + "license": "MIT", + "dependencies": { + "accepts": "^2.0.0", + "body-parser": "^2.2.1", + "content-disposition": "^1.0.0", + "content-type": "^1.0.5", + "cookie": "^0.7.1", + "cookie-signature": "^1.2.1", + "debug": "^4.4.0", + "depd": "^2.0.0", + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "etag": "^1.8.1", + "finalhandler": "^2.1.0", + "fresh": "^2.0.0", + "http-errors": "^2.0.0", + "merge-descriptors": "^2.0.0", + "mime-types": "^3.0.0", + "on-finished": "^2.4.1", + "once": "^1.4.0", + "parseurl": "^1.3.3", + "proxy-addr": "^2.0.7", + "qs": "^6.14.0", + "range-parser": "^1.2.1", + "router": "^2.2.0", + "send": "^1.1.0", + "serve-static": "^2.2.0", + "statuses": "^2.0.1", + "type-is": "^2.0.1", + "vary": "^1.1.2" + }, + "engines": { + "node": ">= 18" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/express-rate-limit": { + "version": "8.3.2", + "resolved": "https://registry.npmmirror.com/express-rate-limit/-/express-rate-limit-8.3.2.tgz", + "integrity": "sha512-77VmFeJkO0/rvimEDuUC5H30oqUC4EyOhyGccfqoLebB0oiEYfM7nwPrsDsBL1gsTpwfzX8SFy2MT3TDyRq+bg==", + "license": "MIT", + "dependencies": { + "ip-address": "10.1.0" + }, + "engines": { + "node": ">= 16" + }, + "funding": { + "url": "https://github.com/sponsors/express-rate-limit" + }, + "peerDependencies": { + "express": ">= 4.11" + } + }, + "node_modules/extend": { + "version": "3.0.2", + "resolved": "https://registry.npmmirror.com/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==", + "license": "MIT" + }, + "node_modules/fast-deep-equal": { + "version": "3.1.3", + "resolved": "https://registry.npmmirror.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz", + "integrity": "sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==", + "license": "MIT" + }, + "node_modules/fast-uri": { + "version": "3.1.0", + "resolved": "https://registry.npmmirror.com/fast-uri/-/fast-uri-3.1.0.tgz", + "integrity": "sha512-iPeeDKJSWf4IEOasVVrknXpaBV0IApz/gp7S2bb7Z4Lljbl2MGJRqInZiUrQwV16cpzw/D3S5j5Julj/gT52AA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/fastify" + }, + { + "type": "opencollective", + "url": "https://opencollective.com/fastify" + } + ], + "license": "BSD-3-Clause" + }, + "node_modules/fast-xml-builder": { + "version": "1.1.4", + "resolved": "https://registry.npmmirror.com/fast-xml-builder/-/fast-xml-builder-1.1.4.tgz", + "integrity": "sha512-f2jhpN4Eccy0/Uz9csxh3Nu6q4ErKxf0XIsasomfOihuSUa3/xw6w8dnOtCDgEItQFJG8KyXPzQXzcODDrrbOg==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/NaturalIntelligence" + } + ], + "license": "MIT", + "dependencies": { + "path-expression-matcher": "^1.1.3" + } + }, + "node_modules/fast-xml-parser": { + "version": "5.5.8", + "resolved": "https://registry.npmmirror.com/fast-xml-parser/-/fast-xml-parser-5.5.8.tgz", + "integrity": "sha512-Z7Fh2nVQSb2d+poDViM063ix2ZGt9jmY1nWhPfHBOK2Hgnb/OW3P4Et3P/81SEej0J7QbWtJqxO05h8QYfK7LQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/NaturalIntelligence" + } + ], + "license": "MIT", + "dependencies": { + "fast-xml-builder": "^1.1.4", + "path-expression-matcher": "^1.2.0", + "strnum": "^2.2.0" + }, + "bin": { + "fxparser": "src/cli/cli.js" + } + }, + "node_modules/fetch-blob": { + "version": "3.2.0", + "resolved": "https://registry.npmmirror.com/fetch-blob/-/fetch-blob-3.2.0.tgz", + "integrity": "sha512-7yAQpD2UMJzLi1Dqv7qFYnPbaPx7ZfFK6PiIxQ4PfkGPyNyl2Ugx+a/umUonmKqjhM4DnfbMvdX6otXq83soQQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/jimmywarting" + }, + { + "type": "paypal", + "url": "https://paypal.me/jimmywarting" + } + ], + "license": "MIT", + "dependencies": { + "node-domexception": "^1.0.0", + "web-streams-polyfill": "^3.0.3" + }, + "engines": { + "node": "^12.20 || >= 14.13" + } + }, + "node_modules/figures": { + "version": "6.1.0", + "resolved": "https://registry.npmmirror.com/figures/-/figures-6.1.0.tgz", + "integrity": "sha512-d+l3qxjSesT4V7v2fh+QnmFnUWv9lSpjarhShNTgBOfA0ttejbQUAlHLitbjkoRiDulW0OPoQPYIGhIC8ohejg==", + "license": "MIT", + "dependencies": { + "is-unicode-supported": "^2.0.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/finalhandler": { + "version": "2.1.1", + "resolved": "https://registry.npmmirror.com/finalhandler/-/finalhandler-2.1.1.tgz", + "integrity": "sha512-S8KoZgRZN+a5rNwqTxlZZePjT/4cnm0ROV70LedRHZ0p8u9fRID0hJUZQpkKLzro8LfmC8sx23bY6tVNxv8pQA==", + "license": "MIT", + "dependencies": { + "debug": "^4.4.0", + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "on-finished": "^2.4.1", + "parseurl": "^1.3.3", + "statuses": "^2.0.1" + }, + "engines": { + "node": ">= 18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmmirror.com/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "license": "MIT", + "dependencies": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/follow-redirects": { + "version": "1.15.11", + "resolved": "https://registry.npmmirror.com/follow-redirects/-/follow-redirects-1.15.11.tgz", + "integrity": "sha512-deG2P0JfjrTxl50XGCDyfI97ZGVCxIpfKYmfyrQ54n5FO/0gfIES8C/Psl6kWVDolizcaaxZJnTS0QSMxvnsBQ==", + "funding": [ + { + "type": "individual", + "url": "https://github.com/sponsors/RubenVerborgh" + } + ], + "license": "MIT", + "engines": { + "node": ">=4.0" + }, + "peerDependenciesMeta": { + "debug": { + "optional": true + } + } + }, + "node_modules/form-data": { + "version": "4.0.5", + "resolved": "https://registry.npmmirror.com/form-data/-/form-data-4.0.5.tgz", + "integrity": "sha512-8RipRLol37bNs2bhoV67fiTEvdTrbMUYcFTiy3+wuuOnUog2QBHCZWXDRijWQfAkhBj2Uf5UnVaiWwA5vdd82w==", + "license": "MIT", + "dependencies": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.8", + "es-set-tostringtag": "^2.1.0", + "hasown": "^2.0.2", + "mime-types": "^2.1.12" + }, + "engines": { + "node": ">= 6" + } + }, + "node_modules/form-data/node_modules/mime-db": { + "version": "1.52.0", + "resolved": "https://registry.npmmirror.com/mime-db/-/mime-db-1.52.0.tgz", + "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/form-data/node_modules/mime-types": { + "version": "2.1.35", + "resolved": "https://registry.npmmirror.com/mime-types/-/mime-types-2.1.35.tgz", + "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", + "license": "MIT", + "dependencies": { + "mime-db": "1.52.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/formdata-polyfill": { + "version": "4.0.10", + "resolved": "https://registry.npmmirror.com/formdata-polyfill/-/formdata-polyfill-4.0.10.tgz", + "integrity": "sha512-buewHzMvYL29jdeQTVILecSaZKnt/RJWjoZCF5OW60Z67/GmSLBkOFM7qh1PI3zFNtJbaZL5eQu1vLfazOwj4g==", + "license": "MIT", + "dependencies": { + "fetch-blob": "^3.1.2" + }, + "engines": { + "node": ">=12.20.0" + } + }, + "node_modules/forwarded": { + "version": "0.2.0", + "resolved": "https://registry.npmmirror.com/forwarded/-/forwarded-0.2.0.tgz", + "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/fresh": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/fresh/-/fresh-2.0.0.tgz", + "integrity": "sha512-Rx/WycZ60HOaqLKAi6cHRKKI7zxWbJ31MhntmtwMoaTeF7XFH9hhBp8vITaMidfljRQ6eYWCKkaTK+ykVJHP2A==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/function-bind": { + "version": "1.1.2", + "resolved": "https://registry.npmmirror.com/function-bind/-/function-bind-1.1.2.tgz", + "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/fuse.js": { + "version": "7.1.0", + "resolved": "https://registry.npmmirror.com/fuse.js/-/fuse.js-7.1.0.tgz", + "integrity": "sha512-trLf4SzuuUxfusZADLINj+dE8clK1frKdmqiJNb1Es75fmI5oY6X2mxLVUciLLjxqw/xr72Dhy+lER6dGd02FQ==", + "license": "Apache-2.0", + "engines": { + "node": ">=10" + } + }, + "node_modules/gaxios": { + "version": "7.1.4", + "resolved": "https://registry.npmmirror.com/gaxios/-/gaxios-7.1.4.tgz", + "integrity": "sha512-bTIgTsM2bWn3XklZISBTQX7ZSddGW+IO3bMdGaemHZ3tbqExMENHLx6kKZ/KlejgrMtj8q7wBItt51yegqalrA==", + "license": "Apache-2.0", + "dependencies": { + "extend": "^3.0.2", + "https-proxy-agent": "^7.0.1", + "node-fetch": "^3.3.2" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/gaxios/node_modules/agent-base": { + "version": "7.1.4", + "resolved": "https://registry.npmmirror.com/agent-base/-/agent-base-7.1.4.tgz", + "integrity": "sha512-MnA+YT8fwfJPgBx3m60MNqakm30XOkyIoH1y6huTQvC0PwZG7ki8NacLBcrPbNoo8vEZy7Jpuk7+jMO+CUovTQ==", + "license": "MIT", + "engines": { + "node": ">= 14" + } + }, + "node_modules/gaxios/node_modules/https-proxy-agent": { + "version": "7.0.6", + "resolved": "https://registry.npmmirror.com/https-proxy-agent/-/https-proxy-agent-7.0.6.tgz", + "integrity": "sha512-vK9P5/iUfdl95AI+JVyUuIcVtd4ofvtrOr3HNtM2yxC9bnMbEdp3x01OhQNnjb8IJYi38VlTE3mBXwcfvywuSw==", + "license": "MIT", + "dependencies": { + "agent-base": "^7.1.2", + "debug": "4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/gcp-metadata": { + "version": "8.1.2", + "resolved": "https://registry.npmmirror.com/gcp-metadata/-/gcp-metadata-8.1.2.tgz", + "integrity": "sha512-zV/5HKTfCeKWnxG0Dmrw51hEWFGfcF2xiXqcA3+J90WDuP0SvoiSO5ORvcBsifmx/FoIjgQN3oNOGaQ5PhLFkg==", + "license": "Apache-2.0", + "dependencies": { + "gaxios": "^7.0.0", + "google-logging-utils": "^1.0.0", + "json-bigint": "^1.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmmirror.com/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==", + "license": "ISC", + "engines": { + "node": "6.* || 8.* || >= 10.*" + } + }, + "node_modules/get-east-asian-width": { + "version": "1.5.0", + "resolved": "https://registry.npmmirror.com/get-east-asian-width/-/get-east-asian-width-1.5.0.tgz", + "integrity": "sha512-CQ+bEO+Tva/qlmw24dCejulK5pMzVnUOFOijVogd3KQs07HnRIgp8TGipvCCRT06xeYEbpbgwaCxglFyiuIcmA==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/get-intrinsic": { + "version": "1.3.0", + "resolved": "https://registry.npmmirror.com/get-intrinsic/-/get-intrinsic-1.3.0.tgz", + "integrity": "sha512-9fSjSaos/fRIVIp+xSJlE6lfwhES7LNtKaCBIamHsjr2na1BiABJPo0mOjjz8GJDURarmCPGqaiVg5mfjb98CQ==", + "license": "MIT", + "dependencies": { + "call-bind-apply-helpers": "^1.0.2", + "es-define-property": "^1.0.1", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.1.1", + "function-bind": "^1.1.2", + "get-proto": "^1.0.1", + "gopd": "^1.2.0", + "has-symbols": "^1.1.0", + "hasown": "^2.0.2", + "math-intrinsics": "^1.1.0" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/get-proto": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/get-proto/-/get-proto-1.0.1.tgz", + "integrity": "sha512-sTSfBjoXBp89JvIKIefqw7U2CCebsc74kiY6awiGogKtoSGbgjYE/G/+l9sF3MWFPNc9IcoOC4ODfKHfxFmp0g==", + "license": "MIT", + "dependencies": { + "dunder-proto": "^1.0.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/get-stream": { + "version": "9.0.1", + "resolved": "https://registry.npmmirror.com/get-stream/-/get-stream-9.0.1.tgz", + "integrity": "sha512-kVCxPF3vQM/N0B1PmoqVUqgHP+EeVjmZSQn+1oCRPxd2P21P2F19lIgbR3HBosbB1PUhOAoctJnfEn2GbN2eZA==", + "license": "MIT", + "dependencies": { + "@sec-ant/readable-stream": "^0.4.1", + "is-stream": "^4.0.1" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/google-auth-library": { + "version": "10.6.2", + "resolved": "https://registry.npmmirror.com/google-auth-library/-/google-auth-library-10.6.2.tgz", + "integrity": "sha512-e27Z6EThmVNNvtYASwQxose/G57rkRuaRbQyxM2bvYLLX/GqWZ5chWq2EBoUchJbCc57eC9ArzO5wMsEmWftCw==", + "license": "Apache-2.0", + "dependencies": { + "base64-js": "^1.3.0", + "ecdsa-sig-formatter": "^1.0.11", + "gaxios": "^7.1.4", + "gcp-metadata": "8.1.2", + "google-logging-utils": "1.1.3", + "jws": "^4.0.0" + }, + "engines": { + "node": ">=18" + } + }, + "node_modules/google-logging-utils": { + "version": "1.1.3", + "resolved": "https://registry.npmmirror.com/google-logging-utils/-/google-logging-utils-1.1.3.tgz", + "integrity": "sha512-eAmLkjDjAFCVXg7A1unxHsLf961m6y17QFqXqAXGj/gVkKFrEICfStRfwUlGNfeCEjNRa32JEWOUTlYXPyyKvA==", + "license": "Apache-2.0", + "engines": { + "node": ">=14" + } + }, + "node_modules/gopd": { + "version": "1.2.0", + "resolved": "https://registry.npmmirror.com/gopd/-/gopd-1.2.0.tgz", + "integrity": "sha512-ZUKRh6/kUFoAiTAtTYPZJ3hw9wNxx+BIBOijnlG9PnrJsCcSjs1wyyD6vJpaYtgnzDrKYRSqf3OO6Rfa93xsRg==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/graceful-fs": { + "version": "4.2.11", + "resolved": "https://registry.npmmirror.com/graceful-fs/-/graceful-fs-4.2.11.tgz", + "integrity": "sha512-RbJ5/jmFcNNCcDV5o9eTnBLJ/HszWV0P73bc+Ff4nS/rJj+YaS6IGyiOL0VoBYX+l1Wrl3k63h/KrH+nhJ0XvQ==", + "license": "ISC" + }, + "node_modules/has-flag": { + "version": "5.0.1", + "resolved": "https://registry.npmmirror.com/has-flag/-/has-flag-5.0.1.tgz", + "integrity": "sha512-CsNUt5x9LUdx6hnk/E2SZLsDyvfqANZSUq4+D3D8RzDJ2M+HDTIkF60ibS1vHaK55vzgiZw1bEPFG9yH7l33wA==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/has-symbols": { + "version": "1.1.0", + "resolved": "https://registry.npmmirror.com/has-symbols/-/has-symbols-1.1.0.tgz", + "integrity": "sha512-1cDNdwJ2Jaohmb3sg4OmKaMBwuC48sYni5HUw2DvsC8LjGTLK9h+eb1X6RyuOHe4hT0ULCW68iomhjUoKUqlPQ==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/has-tostringtag": { + "version": "1.0.2", + "resolved": "https://registry.npmmirror.com/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", + "license": "MIT", + "dependencies": { + "has-symbols": "^1.0.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/hasown": { + "version": "2.0.2", + "resolved": "https://registry.npmmirror.com/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", + "license": "MIT", + "dependencies": { + "function-bind": "^1.1.2" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/highlight.js": { + "version": "11.11.1", + "resolved": "https://registry.npmmirror.com/highlight.js/-/highlight.js-11.11.1.tgz", + "integrity": "sha512-Xwwo44whKBVCYoliBQwaPvtd/2tYFkRQtXDWj1nackaV2JPXx3L0+Jvd8/qCJ2p+ML0/XVkJ2q+Mr+UVdpJK5w==", + "license": "BSD-3-Clause", + "engines": { + "node": ">=12.0.0" + } + }, + "node_modules/hono": { + "version": "4.12.9", + "resolved": "https://registry.npmmirror.com/hono/-/hono-4.12.9.tgz", + "integrity": "sha512-wy3T8Zm2bsEvxKZM5w21VdHDDcwVS1yUFFY6i8UobSsKfFceT7TOwhbhfKsDyx7tYQlmRM5FLpIuYvNFyjctiA==", + "license": "MIT", + "engines": { + "node": ">=16.9.0" + } + }, + "node_modules/http-errors": { + "version": "2.0.1", + "resolved": "https://registry.npmmirror.com/http-errors/-/http-errors-2.0.1.tgz", + "integrity": "sha512-4FbRdAX+bSdmo4AUFuS0WNiPz8NgFt+r8ThgNWmlrjQjt1Q7ZR9+zTlce2859x4KSXrwIsaeTqDoKQmtP8pLmQ==", + "license": "MIT", + "dependencies": { + "depd": "~2.0.0", + "inherits": "~2.0.4", + "setprototypeof": "~1.2.0", + "statuses": "~2.0.2", + "toidentifier": "~1.0.1" + }, + "engines": { + "node": ">= 0.8" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/https-proxy-agent": { + "version": "8.0.0", + "resolved": "https://registry.npmmirror.com/https-proxy-agent/-/https-proxy-agent-8.0.0.tgz", + "integrity": "sha512-YYeW+iCnAS3xhvj2dvVoWgsbca3RfQy/IlaNHHOtDmU0jMqPI9euIq3Y9BJETdxk16h9NHHCKqp/KB9nIMStCQ==", + "license": "MIT", + "dependencies": { + "agent-base": "8.0.0", + "debug": "^4.3.4" + }, + "engines": { + "node": ">= 14" + } + }, + "node_modules/human-signals": { + "version": "8.0.1", + "resolved": "https://registry.npmmirror.com/human-signals/-/human-signals-8.0.1.tgz", + "integrity": "sha512-eKCa6bwnJhvxj14kZk5NCPc6Hb6BdsU9DZcOnmQKSnO1VKrfV0zCvtttPZUsBvjmNDn8rpcJfpwSYnHBjc95MQ==", + "license": "Apache-2.0", + "engines": { + "node": ">=18.18.0" + } + }, + "node_modules/iconv-lite": { + "version": "0.7.2", + "resolved": "https://registry.npmmirror.com/iconv-lite/-/iconv-lite-0.7.2.tgz", + "integrity": "sha512-im9DjEDQ55s9fL4EYzOAv0yMqmMBSZp6G0VvFyTMPKWxiSBHUj9NW/qqLmXUwXrrM7AvqSlTCfvqRb0cM8yYqw==", + "license": "MIT", + "dependencies": { + "safer-buffer": ">= 2.1.2 < 3.0.0" + }, + "engines": { + "node": ">=0.10.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/ignore": { + "version": "7.0.5", + "resolved": "https://registry.npmmirror.com/ignore/-/ignore-7.0.5.tgz", + "integrity": "sha512-Hs59xBNfUIunMFgWAbGX5cq6893IbWg4KnrjbYwX3tx0ztorVgTDA6B2sxf8ejHJ4wz8BqGUMYlnzNBer5NvGg==", + "license": "MIT", + "engines": { + "node": ">= 4" + } + }, + "node_modules/indent-string": { + "version": "5.0.0", + "resolved": "https://registry.npmmirror.com/indent-string/-/indent-string-5.0.0.tgz", + "integrity": "sha512-m6FAo/spmsW2Ab2fU35JTYwtOKa2yAwXSwgjSv1TJzh4Mh7mC3lzAOVLBprb72XsTrgkEIsl7YrFNAiDiRhIGg==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmmirror.com/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==", + "license": "ISC" + }, + "node_modules/ink": { + "version": "6.8.0", + "resolved": "https://registry.npmmirror.com/ink/-/ink-6.8.0.tgz", + "integrity": "sha512-sbl1RdLOgkO9isK42WCZlJCFN9hb++sX9dsklOvfd1YQ3bQ2AiFu12Q6tFlr0HvEUvzraJntQCCpfEoUe9DSzA==", + "license": "MIT", + "dependencies": { + "@alcalzone/ansi-tokenize": "^0.2.4", + "ansi-escapes": "^7.3.0", + "ansi-styles": "^6.2.1", + "auto-bind": "^5.0.1", + "chalk": "^5.6.0", + "cli-boxes": "^3.0.0", + "cli-cursor": "^4.0.0", + "cli-truncate": "^5.1.1", + "code-excerpt": "^4.0.0", + "es-toolkit": "^1.39.10", + "indent-string": "^5.0.0", + "is-in-ci": "^2.0.0", + "patch-console": "^2.0.0", + "react-reconciler": "^0.33.0", + "scheduler": "^0.27.0", + "signal-exit": "^3.0.7", + "slice-ansi": "^8.0.0", + "stack-utils": "^2.0.6", + "string-width": "^8.1.1", + "terminal-size": "^4.0.1", + "type-fest": "^5.4.1", + "widest-line": "^6.0.0", + "wrap-ansi": "^9.0.0", + "ws": "^8.18.0", + "yoga-layout": "~3.2.1" + }, + "engines": { + "node": ">=20" + }, + "peerDependencies": { + "@types/react": ">=19.0.0", + "react": ">=19.0.0", + "react-devtools-core": ">=6.1.2" + }, + "peerDependenciesMeta": { + "@types/react": { + "optional": true + }, + "react-devtools-core": { + "optional": true + } + } + }, + "node_modules/ink/node_modules/cli-boxes": { + "version": "3.0.0", + "resolved": "https://registry.npmmirror.com/cli-boxes/-/cli-boxes-3.0.0.tgz", + "integrity": "sha512-/lzGpEWL/8PfI0BmBOPRwp0c/wFNX1RdUML3jK/RcSBA9T8mZDdQpqYBKtCFTOfQbwPqWEOpjqW+Fnayc0969g==", + "license": "MIT", + "engines": { + "node": ">=10" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ink/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmmirror.com/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "license": "ISC" + }, + "node_modules/ink/node_modules/wrap-ansi": { + "version": "9.0.2", + "resolved": "https://registry.npmmirror.com/wrap-ansi/-/wrap-ansi-9.0.2.tgz", + "integrity": "sha512-42AtmgqjV+X1VpdOfyTGOYRi0/zsoLqtXQckTmqTeybT+BDIbM/Guxo7x3pE2vtpr1ok6xRqM9OpBe+Jyoqyww==", + "license": "MIT", + "dependencies": { + "ansi-styles": "^6.2.1", + "string-width": "^7.0.0", + "strip-ansi": "^7.1.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/ink/node_modules/wrap-ansi/node_modules/string-width": { + "version": "7.2.0", + "resolved": "https://registry.npmmirror.com/string-width/-/string-width-7.2.0.tgz", + "integrity": "sha512-tsaTIkKW9b4N+AEj+SVA+WhJzV7/zMhcSu78mLKWSk7cXMOSHsBKFWUs0fWwq8QyK3MgJBQRX6Gbi4kYbdvGkQ==", + "license": "MIT", + "dependencies": { + "emoji-regex": "^10.3.0", + "get-east-asian-width": "^1.0.0", + "strip-ansi": "^7.1.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/ip-address": { + "version": "10.1.0", + "resolved": "https://registry.npmmirror.com/ip-address/-/ip-address-10.1.0.tgz", + "integrity": "sha512-XXADHxXmvT9+CRxhXg56LJovE+bmWnEWB78LB83VZTprKTmaC5QfruXocxzTZ2Kl0DNwKuBdlIhjL8LeY8Sf8Q==", + "license": "MIT", + "engines": { + "node": ">= 12" + } + }, + "node_modules/ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmmirror.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", + "license": "MIT", + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/is-fullwidth-code-point": { + "version": "5.1.0", + "resolved": "https://registry.npmmirror.com/is-fullwidth-code-point/-/is-fullwidth-code-point-5.1.0.tgz", + "integrity": "sha512-5XHYaSyiqADb4RnZ1Bdad6cPp8Toise4TzEjcOYDHZkTCbKgiUl7WTUCpNWHuxmDt91wnsZBc9xinNzopv3JMQ==", + "license": "MIT", + "dependencies": { + "get-east-asian-width": "^1.3.1" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-in-ci": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/is-in-ci/-/is-in-ci-2.0.0.tgz", + "integrity": "sha512-cFeerHriAnhrQSbpAxL37W1wcJKUUX07HyLWZCW1URJT/ra3GyUTzBgUnh24TMVfNTV2Hij2HLxkPHFZfOZy5w==", + "license": "MIT", + "bin": { + "is-in-ci": "cli.js" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-plain-obj": { + "version": "4.1.0", + "resolved": "https://registry.npmmirror.com/is-plain-obj/-/is-plain-obj-4.1.0.tgz", + "integrity": "sha512-+Pgi+vMuUNkJyExiMBt5IlFoMyKnr5zhJ4Uspz58WOhBF5QoIZkFyNHIbBAtHwzVAgk5RtndVNsDRN61/mmDqg==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-promise": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/is-promise/-/is-promise-4.0.0.tgz", + "integrity": "sha512-hvpoI6korhJMnej285dSg6nu1+e6uxs7zG3BYAm5byqDsgJNWwxzM6z6iZiAgQR4TJ30JmBTOwqZUw3WlyH3AQ==", + "license": "MIT" + }, + "node_modules/is-safe-filename": { + "version": "0.1.1", + "resolved": "https://registry.npmmirror.com/is-safe-filename/-/is-safe-filename-0.1.1.tgz", + "integrity": "sha512-4SrR7AdnY11LHfDKTZY1u6Ga3RuxZdl3YKWWShO5iyuG5h8QS4GD2tOb04peBJ5I7pXbR+CGBNEhTcwK+FzN3g==", + "license": "MIT", + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-stream": { + "version": "4.0.1", + "resolved": "https://registry.npmmirror.com/is-stream/-/is-stream-4.0.1.tgz", + "integrity": "sha512-Dnz92NInDqYckGEUJv689RbRiTSEHCQ7wOVeALbkOz999YpqT46yMRIGtSNl2iCL1waAZSx40+h59NV/EwzV/A==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/is-unicode-supported": { + "version": "2.1.0", + "resolved": "https://registry.npmmirror.com/is-unicode-supported/-/is-unicode-supported-2.1.0.tgz", + "integrity": "sha512-mE00Gnza5EEB3Ds0HfMyllZzbBrmLOX3vfWoj9A9PEnTfratQ/BcaJOuMhnkhjXvb2+FkY3VuHqtAGpTPmglFQ==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha512-RHxMLp9lnKHGHRng9QFhRCMbYAcVpn69smSGcq3f36xjgVVWThj4qqLbTLlq7Ssj8B+fIQ1EuCEGI2lKsyQeIw==", + "license": "ISC" + }, + "node_modules/jose": { + "version": "6.2.2", + "resolved": "https://registry.npmmirror.com/jose/-/jose-6.2.2.tgz", + "integrity": "sha512-d7kPDd34KO/YnzaDOlikGpOurfF0ByC2sEV4cANCtdqLlTfBlw2p14O/5d/zv40gJPbIQxfES3nSx1/oYNyuZQ==", + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/panva" + } + }, + "node_modules/json-bigint": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/json-bigint/-/json-bigint-1.0.0.tgz", + "integrity": "sha512-SiPv/8VpZuWbvLSMtTDU8hEfrZWg/mH/nV/b4o0CYbSxu1UIQPLdwKOCIyLQX+VIPO5vrLX3i8qtqFyhdPSUSQ==", + "license": "MIT", + "dependencies": { + "bignumber.js": "^9.0.0" + } + }, + "node_modules/json-schema-to-ts": { + "version": "3.1.1", + "resolved": "https://registry.npmmirror.com/json-schema-to-ts/-/json-schema-to-ts-3.1.1.tgz", + "integrity": "sha512-+DWg8jCJG2TEnpy7kOm/7/AxaYoaRbjVB4LFZLySZlWn8exGs3A4OLJR966cVvU26N7X9TWxl+Jsw7dzAqKT6g==", + "license": "MIT", + "dependencies": { + "@babel/runtime": "^7.18.3", + "ts-algebra": "^2.0.0" + }, + "engines": { + "node": ">=16" + } + }, + "node_modules/json-schema-traverse": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/json-schema-traverse/-/json-schema-traverse-1.0.0.tgz", + "integrity": "sha512-NM8/P9n3XjXhIZn1lLhkFaACTOURQXjWhV4BA/RnOv8xvgqtqpAX9IO4mRQxSx1Rlo4tqzeqb0sOlruaOy3dug==", + "license": "MIT" + }, + "node_modules/json-schema-typed": { + "version": "8.0.2", + "resolved": "https://registry.npmmirror.com/json-schema-typed/-/json-schema-typed-8.0.2.tgz", + "integrity": "sha512-fQhoXdcvc3V28x7C7BMs4P5+kNlgUURe2jmUT1T//oBRMDrqy1QPelJimwZGo7Hg9VPV3EQV5Bnq4hbFy2vetA==", + "license": "BSD-2-Clause" + }, + "node_modules/jsonc-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmmirror.com/jsonc-parser/-/jsonc-parser-3.3.1.tgz", + "integrity": "sha512-HUgH65KyejrUFPvHFPbqOY0rsFip3Bo5wb4ngvdi1EpCYWUQDC5V+Y7mZws+DLkr4M//zQJoanu1SP+87Dv1oQ==", + "license": "MIT" + }, + "node_modules/jwa": { + "version": "2.0.1", + "resolved": "https://registry.npmmirror.com/jwa/-/jwa-2.0.1.tgz", + "integrity": "sha512-hRF04fqJIP8Abbkq5NKGN0Bbr3JxlQ+qhZufXVr0DvujKy93ZCbXZMHDL4EOtodSbCWxOqR8MS1tXA5hwqCXDg==", + "license": "MIT", + "dependencies": { + "buffer-equal-constant-time": "^1.0.1", + "ecdsa-sig-formatter": "1.0.11", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/jws": { + "version": "4.0.1", + "resolved": "https://registry.npmmirror.com/jws/-/jws-4.0.1.tgz", + "integrity": "sha512-EKI/M/yqPncGUUh44xz0PxSidXFr/+r0pA70+gIYhjv+et7yxM+s29Y+VGDkovRofQem0fs7Uvf4+YmAdyRduA==", + "license": "MIT", + "dependencies": { + "jwa": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "node_modules/locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmmirror.com/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "license": "MIT", + "dependencies": { + "p-locate": "^4.1.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/lodash-es": { + "version": "4.17.23", + "resolved": "https://registry.npmmirror.com/lodash-es/-/lodash-es-4.17.23.tgz", + "integrity": "sha512-kVI48u3PZr38HdYz98UmfPnXl2DXrpdctLrFLCd3kOx1xUkOmpFPx7gCWWM5MPkL/fD8zb+Ph0QzjGFs4+hHWg==", + "license": "MIT" + }, + "node_modules/lodash.debounce": { + "version": "4.0.8", + "resolved": "https://registry.npmmirror.com/lodash.debounce/-/lodash.debounce-4.0.8.tgz", + "integrity": "sha512-FT1yDzDYEoYWhnSGnpE/4Kj1fLZkDFyqRb7fNt6FdYOSxlUWAtp42Eh6Wb0rGIv/m9Bgo7x4GhQbm5Ys4SG5ow==", + "license": "MIT" + }, + "node_modules/lru-cache": { + "version": "11.2.7", + "resolved": "https://registry.npmmirror.com/lru-cache/-/lru-cache-11.2.7.tgz", + "integrity": "sha512-aY/R+aEsRelme17KGQa/1ZSIpLpNYYrhcrepKTZgE+W3WM16YMCaPwOHLHsmopZHELU0Ojin1lPVxKR0MihncA==", + "license": "BlueOak-1.0.0", + "engines": { + "node": "20 || >=22" + } + }, + "node_modules/marked": { + "version": "17.0.5", + "resolved": "https://registry.npmmirror.com/marked/-/marked-17.0.5.tgz", + "integrity": "sha512-6hLvc0/JEbRjRgzI6wnT2P1XuM1/RrrDEX0kPt0N7jGm1133g6X7DlxFasUIx+72aKAr904GTxhSLDrd5DIlZg==", + "license": "MIT", + "bin": { + "marked": "bin/marked.js" + }, + "engines": { + "node": ">= 20" + } + }, + "node_modules/math-intrinsics": { + "version": "1.1.0", + "resolved": "https://registry.npmmirror.com/math-intrinsics/-/math-intrinsics-1.1.0.tgz", + "integrity": "sha512-/IXtbwEk5HTPyEwyKX6hGkYXxM9nbj64B+ilVJnC/R6B0pH5G4V3b0pVbL7DBj4tkhBAppbQUlf6F6Xl9LHu1g==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/media-typer": { + "version": "1.1.0", + "resolved": "https://registry.npmmirror.com/media-typer/-/media-typer-1.1.0.tgz", + "integrity": "sha512-aisnrDP4GNe06UcKFnV5bfMNPBUw4jsLGaWwWfnH3v02GnBuXX2MCVn5RbrWo0j3pczUilYblq7fQ7Nw2t5XKw==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/merge-descriptors": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/merge-descriptors/-/merge-descriptors-2.0.0.tgz", + "integrity": "sha512-Snk314V5ayFLhp3fkUREub6WtjBfPdCPY1Ln8/8munuLuiYhsABgBVWsozAG+MWMbVEvcdcpbi9R7ww22l9Q3g==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/mime-db": { + "version": "1.54.0", + "resolved": "https://registry.npmmirror.com/mime-db/-/mime-db-1.54.0.tgz", + "integrity": "sha512-aU5EJuIN2WDemCcAp2vFBfp/m4EAhWJnUNSSw0ixs7/kXbd6Pg64EmwJkNdFhB8aWt1sH2CTXrLxo/iAGV3oPQ==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/mime-types": { + "version": "3.0.2", + "resolved": "https://registry.npmmirror.com/mime-types/-/mime-types-3.0.2.tgz", + "integrity": "sha512-Lbgzdk0h4juoQ9fCKXW4by0UJqj+nOOrI9MJ1sSj4nI8aI2eo1qmvQEie4VD1glsS250n15LsWsYtCugiStS5A==", + "license": "MIT", + "dependencies": { + "mime-db": "^1.54.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmmirror.com/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==", + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/ms": { + "version": "2.1.3", + "resolved": "https://registry.npmmirror.com/ms/-/ms-2.1.3.tgz", + "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==", + "license": "MIT" + }, + "node_modules/negotiator": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/negotiator/-/negotiator-1.0.0.tgz", + "integrity": "sha512-8Ofs/AUQh8MaEcrlq5xOX0CQ9ypTF5dl78mjlMNfOK08fzpgTHQRQPBxcPlEtIw0yRpws+Zo/3r+5WRby7u3Gg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/node-domexception": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/node-domexception/-/node-domexception-1.0.0.tgz", + "integrity": "sha512-/jKZoMpw0F8GRwl4/eLROPA3cfcXtLApP0QzLmUT/HuPCZWyB7IY9ZrMeKw2O/nFIqPQB3PVM9aYm0F312AXDQ==", + "deprecated": "Use your platform's native DOMException instead", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/jimmywarting" + }, + { + "type": "github", + "url": "https://paypal.me/jimmywarting" + } + ], + "license": "MIT", + "engines": { + "node": ">=10.5.0" + } + }, + "node_modules/node-fetch": { + "version": "3.3.2", + "resolved": "https://registry.npmmirror.com/node-fetch/-/node-fetch-3.3.2.tgz", + "integrity": "sha512-dRB78srN/l6gqWulah9SrxeYnxeddIG30+GOqK/9OlLVyLg3HPnr6SqOWTWOXKRwC2eGYCkZ59NNuSgvSrpgOA==", + "license": "MIT", + "dependencies": { + "data-uri-to-buffer": "^4.0.0", + "fetch-blob": "^3.1.4", + "formdata-polyfill": "^4.0.10" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/node-fetch" + } + }, + "node_modules/npm-run-path": { + "version": "6.0.0", + "resolved": "https://registry.npmmirror.com/npm-run-path/-/npm-run-path-6.0.0.tgz", + "integrity": "sha512-9qny7Z9DsQU8Ou39ERsPU4OZQlSTP47ShQzuKZ6PRXpYLtIFgl/DEBYEXKlvcEa+9tHVcK8CF81Y2V72qaZhWA==", + "license": "MIT", + "dependencies": { + "path-key": "^4.0.0", + "unicorn-magic": "^0.3.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/npm-run-path/node_modules/path-key": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/path-key/-/path-key-4.0.0.tgz", + "integrity": "sha512-haREypq7xkM7ErfgIyA0z+Bj4AGKlMSdlQE2jvJo6huWD1EdkKYV+G/T4nq0YEF2vgTT8kqMFKo1uHn950r4SQ==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmmirror.com/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/object-inspect": { + "version": "1.13.4", + "resolved": "https://registry.npmmirror.com/object-inspect/-/object-inspect-1.13.4.tgz", + "integrity": "sha512-W67iLl4J2EXEGTbfeHCffrjDfitvLANg0UlX3wFUUSTx92KXRFegMHUVgSqE+wvhAbi4WqjGg9czysTV2Epbew==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/on-finished": { + "version": "2.4.1", + "resolved": "https://registry.npmmirror.com/on-finished/-/on-finished-2.4.1.tgz", + "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", + "license": "MIT", + "dependencies": { + "ee-first": "1.1.1" + }, + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/once": { + "version": "1.4.0", + "resolved": "https://registry.npmmirror.com/once/-/once-1.4.0.tgz", + "integrity": "sha512-lNaJgI+2Q5URQBkccEKHTQOPaXdUxnZZElQTZY0MFUAuaEqe1E+Nyvgdz/aIyNi6Z9MzO5dv1H8n58/GELp3+w==", + "license": "ISC", + "dependencies": { + "wrappy": "1" + } + }, + "node_modules/onetime": { + "version": "5.1.2", + "resolved": "https://registry.npmmirror.com/onetime/-/onetime-5.1.2.tgz", + "integrity": "sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==", + "license": "MIT", + "dependencies": { + "mimic-fn": "^2.1.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-limit": { + "version": "2.3.0", + "resolved": "https://registry.npmmirror.com/p-limit/-/p-limit-2.3.0.tgz", + "integrity": "sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w==", + "license": "MIT", + "dependencies": { + "p-try": "^2.0.0" + }, + "engines": { + "node": ">=6" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmmirror.com/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "license": "MIT", + "dependencies": { + "p-limit": "^2.2.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/p-map": { + "version": "7.0.4", + "resolved": "https://registry.npmmirror.com/p-map/-/p-map-7.0.4.tgz", + "integrity": "sha512-tkAQEw8ysMzmkhgw8k+1U/iPhWNhykKnSk4Rd5zLoPJCuJaGRPo6YposrZgaxHKzDHdDWWZvE/Sk7hsL2X/CpQ==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmmirror.com/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==", + "license": "MIT", + "engines": { + "node": ">=6" + } + }, + "node_modules/parse-ms": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/parse-ms/-/parse-ms-4.0.0.tgz", + "integrity": "sha512-TXfryirbmq34y8QBwgqCVLi+8oA3oWx2eAnSn62ITyEhEYaWRlVZ2DvMM9eZbMs/RfxPu/PK/aBLyGj4IrqMHw==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmmirror.com/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/patch-console": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/patch-console/-/patch-console-2.0.0.tgz", + "integrity": "sha512-0YNdUceMdaQwoKce1gatDScmMo5pu/tfABfnzEqeG0gtTmd7mh/WcwgUjtAeOU7N8nFFlbQBnFK2gXW5fGvmMA==", + "license": "MIT", + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + } + }, + "node_modules/path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/path-expression-matcher": { + "version": "1.2.0", + "resolved": "https://registry.npmmirror.com/path-expression-matcher/-/path-expression-matcher-1.2.0.tgz", + "integrity": "sha512-DwmPWeFn+tq7TiyJ2CxezCAirXjFxvaiD03npak3cRjlP9+OjTmSy1EpIrEbh+l6JgUundniloMLDQ/6VTdhLQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/NaturalIntelligence" + } + ], + "license": "MIT", + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmmirror.com/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/path-to-regexp": { + "version": "8.4.1", + "resolved": "https://registry.npmmirror.com/path-to-regexp/-/path-to-regexp-8.4.1.tgz", + "integrity": "sha512-fvU78fIjZ+SBM9YwCknCvKOUKkLVqtWDVctl0s7xIqfmfb38t2TT4ZU2gHm+Z8xGwgW+QWEU3oQSAzIbo89Ggw==", + "license": "MIT", + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/picomatch": { + "version": "4.0.4", + "resolved": "https://registry.npmmirror.com/picomatch/-/picomatch-4.0.4.tgz", + "integrity": "sha512-QP88BAKvMam/3NxH6vj2o21R6MjxZUAd6nlwAS/pnGvN9IVLocLHxGYIzFhg6fUQ+5th6P4dv4eW9jX3DSIj7A==", + "license": "MIT", + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/sponsors/jonschlinkert" + } + }, + "node_modules/pkce-challenge": { + "version": "5.0.1", + "resolved": "https://registry.npmmirror.com/pkce-challenge/-/pkce-challenge-5.0.1.tgz", + "integrity": "sha512-wQ0b/W4Fr01qtpHlqSqspcj3EhBvimsdh0KlHhH8HRZnMsEa0ea2fTULOXOS9ccQr3om+GcGRk4e+isrZWV8qQ==", + "license": "MIT", + "engines": { + "node": ">=16.20.0" + } + }, + "node_modules/pngjs": { + "version": "5.0.0", + "resolved": "https://registry.npmmirror.com/pngjs/-/pngjs-5.0.0.tgz", + "integrity": "sha512-40QW5YalBNfQo5yRYmiw7Yz6TKKVr3h6970B2YE+3fQpsWcrbj1PzJgxeJ19DRQjhMbKPIuMY8rFaXc8moolVw==", + "license": "MIT", + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/pretty-ms": { + "version": "9.3.0", + "resolved": "https://registry.npmmirror.com/pretty-ms/-/pretty-ms-9.3.0.tgz", + "integrity": "sha512-gjVS5hOP+M3wMm5nmNOucbIrqudzs9v/57bWRHQWLYklXqoXKrVfYW2W9+glfGsqtPgpiz5WwyEEB+ksXIx3gQ==", + "license": "MIT", + "dependencies": { + "parse-ms": "^4.0.0" + }, + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/proper-lockfile": { + "version": "4.1.2", + "resolved": "https://registry.npmmirror.com/proper-lockfile/-/proper-lockfile-4.1.2.tgz", + "integrity": "sha512-TjNPblN4BwAWMXU8s9AEz4JmQxnD1NNL7bNOY/AKUzyamc379FWASUhc/K1pL2noVb+XmZKLL68cjzLsiOAMaA==", + "license": "MIT", + "dependencies": { + "graceful-fs": "^4.2.4", + "retry": "^0.12.0", + "signal-exit": "^3.0.2" + } + }, + "node_modules/proper-lockfile/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmmirror.com/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "license": "ISC" + }, + "node_modules/proxy-addr": { + "version": "2.0.7", + "resolved": "https://registry.npmmirror.com/proxy-addr/-/proxy-addr-2.0.7.tgz", + "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", + "license": "MIT", + "dependencies": { + "forwarded": "0.2.0", + "ipaddr.js": "1.9.1" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/proxy-from-env": { + "version": "2.1.0", + "resolved": "https://registry.npmmirror.com/proxy-from-env/-/proxy-from-env-2.1.0.tgz", + "integrity": "sha512-cJ+oHTW1VAEa8cJslgmUZrc+sjRKgAKl3Zyse6+PV38hZe/V6Z14TbCuXcan9F9ghlz4QrFr2c92TNF82UkYHA==", + "license": "MIT", + "engines": { + "node": ">=10" + } + }, + "node_modules/qrcode": { + "version": "1.5.4", + "resolved": "https://registry.npmmirror.com/qrcode/-/qrcode-1.5.4.tgz", + "integrity": "sha512-1ca71Zgiu6ORjHqFBDpnSMTR2ReToX4l1Au1VFLyVeBTFavzQnv5JxMFr3ukHVKpSrSA2MCk0lNJSykjUfz7Zg==", + "license": "MIT", + "dependencies": { + "dijkstrajs": "^1.0.1", + "pngjs": "^5.0.0", + "yargs": "^15.3.1" + }, + "bin": { + "qrcode": "bin/qrcode" + }, + "engines": { + "node": ">=10.13.0" + } + }, + "node_modules/qs": { + "version": "6.15.0", + "resolved": "https://registry.npmmirror.com/qs/-/qs-6.15.0.tgz", + "integrity": "sha512-mAZTtNCeetKMH+pSjrb76NAM8V9a05I9aBZOHztWy/UqcJdQYNsf59vrRKWnojAT9Y+GbIvoTBC++CPHqpDBhQ==", + "license": "BSD-3-Clause", + "dependencies": { + "side-channel": "^1.1.0" + }, + "engines": { + "node": ">=0.6" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmmirror.com/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", + "license": "MIT", + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/raw-body": { + "version": "3.0.2", + "resolved": "https://registry.npmmirror.com/raw-body/-/raw-body-3.0.2.tgz", + "integrity": "sha512-K5zQjDllxWkf7Z5xJdV0/B0WTNqx6vxG70zJE4N0kBs4LovmEYWJzQGxC9bS9RAKu3bgM40lrd5zoLJ12MQ5BA==", + "license": "MIT", + "dependencies": { + "bytes": "~3.1.2", + "http-errors": "~2.0.1", + "iconv-lite": "~0.7.0", + "unpipe": "~1.0.0" + }, + "engines": { + "node": ">= 0.10" + } + }, + "node_modules/react": { + "version": "19.2.4", + "resolved": "https://registry.npmmirror.com/react/-/react-19.2.4.tgz", + "integrity": "sha512-9nfp2hYpCwOjAN+8TZFGhtWEwgvWHXqESH8qT89AT/lWklpLON22Lc8pEtnpsZz7VmawabSU0gCjnj8aC0euHQ==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/react-reconciler": { + "version": "0.33.0", + "resolved": "https://registry.npmmirror.com/react-reconciler/-/react-reconciler-0.33.0.tgz", + "integrity": "sha512-KetWRytFv1epdpJc3J4G75I4WrplZE5jOL7Yq0p34+OVOKF4Se7WrdIdVC45XsSSmUTlht2FM/fM1FZb1mfQeA==", + "license": "MIT", + "dependencies": { + "scheduler": "^0.27.0" + }, + "engines": { + "node": ">=0.10.0" + }, + "peerDependencies": { + "react": "^19.2.0" + } + }, + "node_modules/readdirp": { + "version": "5.0.0", + "resolved": "https://registry.npmmirror.com/readdirp/-/readdirp-5.0.0.tgz", + "integrity": "sha512-9u/XQ1pvrQtYyMpZe7DXKv2p5CNvyVwzUB6uhLAnQwHMSgKMBR62lc7AHljaeteeHXn11XTAaLLUVZYVZyuRBQ==", + "license": "MIT", + "engines": { + "node": ">= 20.19.0" + }, + "funding": { + "type": "individual", + "url": "https://paulmillr.com/funding/" + } + }, + "node_modules/require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmmirror.com/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/require-from-string": { + "version": "2.0.2", + "resolved": "https://registry.npmmirror.com/require-from-string/-/require-from-string-2.0.2.tgz", + "integrity": "sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==", + "license": "MIT", + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/require-main-filename": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/require-main-filename/-/require-main-filename-2.0.0.tgz", + "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==", + "license": "ISC" + }, + "node_modules/restore-cursor": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/restore-cursor/-/restore-cursor-4.0.0.tgz", + "integrity": "sha512-I9fPXU9geO9bHOt9pHHOhOkYerIMsmVaWB0rA2AI9ERh/+x/i7MV5HKBNrg+ljO5eoPVgCcnFuRjJ9uH6I/3eg==", + "license": "MIT", + "dependencies": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + }, + "engines": { + "node": "^12.20.0 || ^14.13.1 || >=16.0.0" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/restore-cursor/node_modules/signal-exit": { + "version": "3.0.7", + "resolved": "https://registry.npmmirror.com/signal-exit/-/signal-exit-3.0.7.tgz", + "integrity": "sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==", + "license": "ISC" + }, + "node_modules/retry": { + "version": "0.12.0", + "resolved": "https://registry.npmmirror.com/retry/-/retry-0.12.0.tgz", + "integrity": "sha512-9LkiTwjUh6rT555DtE9rTX+BKByPfrMzEAtnlEtdEwr3Nkffwiihqe2bWADg+OQRjt9gl6ICdmB/ZFDCGAtSow==", + "license": "MIT", + "engines": { + "node": ">= 4" + } + }, + "node_modules/router": { + "version": "2.2.0", + "resolved": "https://registry.npmmirror.com/router/-/router-2.2.0.tgz", + "integrity": "sha512-nLTrUKm2UyiL7rlhapu/Zl45FwNgkZGaCpZbIHajDYgwlJCOzLSk+cIPAnsEqV955GjILJnKbdQC1nVPz+gAYQ==", + "license": "MIT", + "dependencies": { + "debug": "^4.4.0", + "depd": "^2.0.0", + "is-promise": "^4.0.0", + "parseurl": "^1.3.3", + "path-to-regexp": "^8.0.0" + }, + "engines": { + "node": ">= 18" + } + }, + "node_modules/safe-buffer": { + "version": "5.2.1", + "resolved": "https://registry.npmmirror.com/safe-buffer/-/safe-buffer-5.2.1.tgz", + "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/feross" + }, + { + "type": "patreon", + "url": "https://www.patreon.com/feross" + }, + { + "type": "consulting", + "url": "https://feross.org/support" + } + ], + "license": "MIT" + }, + "node_modules/safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmmirror.com/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", + "license": "MIT" + }, + "node_modules/scheduler": { + "version": "0.27.0", + "resolved": "https://registry.npmmirror.com/scheduler/-/scheduler-0.27.0.tgz", + "integrity": "sha512-eNv+WrVbKu1f3vbYJT/xtiF5syA5HPIMtf9IgY/nKg0sWqzAUEvqY/xm7OcZc/qafLx/iO9FgOmeSAp4v5ti/Q==", + "license": "MIT" + }, + "node_modules/semver": { + "version": "7.7.4", + "resolved": "https://registry.npmmirror.com/semver/-/semver-7.7.4.tgz", + "integrity": "sha512-vFKC2IEtQnVhpT78h1Yp8wzwrf8CM+MzKMHGJZfBtzhZNycRFnXsHk6E5TxIkkMsgNS7mdX3AGB7x2QM2di4lA==", + "license": "ISC", + "bin": { + "semver": "bin/semver.js" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/send": { + "version": "1.2.1", + "resolved": "https://registry.npmmirror.com/send/-/send-1.2.1.tgz", + "integrity": "sha512-1gnZf7DFcoIcajTjTwjwuDjzuz4PPcY2StKPlsGAQ1+YH20IRVrBaXSWmdjowTJ6u8Rc01PoYOGHXfP1mYcZNQ==", + "license": "MIT", + "dependencies": { + "debug": "^4.4.3", + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "etag": "^1.8.1", + "fresh": "^2.0.0", + "http-errors": "^2.0.1", + "mime-types": "^3.0.2", + "ms": "^2.1.3", + "on-finished": "^2.4.1", + "range-parser": "^1.2.1", + "statuses": "^2.0.2" + }, + "engines": { + "node": ">= 18" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/serve-static": { + "version": "2.2.1", + "resolved": "https://registry.npmmirror.com/serve-static/-/serve-static-2.2.1.tgz", + "integrity": "sha512-xRXBn0pPqQTVQiC8wyQrKs2MOlX24zQ0POGaj0kultvoOCstBQM5yvOhAVSUwOMjQtTvsPWoNCHfPGwaaQJhTw==", + "license": "MIT", + "dependencies": { + "encodeurl": "^2.0.0", + "escape-html": "^1.0.3", + "parseurl": "^1.3.3", + "send": "^1.2.0" + }, + "engines": { + "node": ">= 18" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/express" + } + }, + "node_modules/set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==", + "license": "ISC" + }, + "node_modules/setprototypeof": { + "version": "1.2.0", + "resolved": "https://registry.npmmirror.com/setprototypeof/-/setprototypeof-1.2.0.tgz", + "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==", + "license": "ISC" + }, + "node_modules/shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "license": "MIT", + "dependencies": { + "shebang-regex": "^3.0.0" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmmirror.com/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/shell-quote": { + "version": "1.8.3", + "resolved": "https://registry.npmmirror.com/shell-quote/-/shell-quote-1.8.3.tgz", + "integrity": "sha512-ObmnIF4hXNg1BqhnHmgbDETF8dLPCggZWBjkQfhZpbszZnYur5DUljTcCHii5LC3J5E0yeO/1LIMyH+UvHQgyw==", + "license": "MIT", + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/side-channel": { + "version": "1.1.0", + "resolved": "https://registry.npmmirror.com/side-channel/-/side-channel-1.1.0.tgz", + "integrity": "sha512-ZX99e6tRweoUXqR+VBrslhda51Nh5MTQwou5tnUDgbtyM0dBgmhEDtWGP/xbKn6hqfPRHujUNwz5fy/wbbhnpw==", + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "object-inspect": "^1.13.3", + "side-channel-list": "^1.0.0", + "side-channel-map": "^1.0.1", + "side-channel-weakmap": "^1.0.2" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/side-channel-list": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/side-channel-list/-/side-channel-list-1.0.0.tgz", + "integrity": "sha512-FCLHtRD/gnpCiCHEiJLOwdmFP+wzCmDEkc9y7NsYxeF4u7Btsn1ZuwgwJGxImImHicJArLP4R0yX4c2KCrMrTA==", + "license": "MIT", + "dependencies": { + "es-errors": "^1.3.0", + "object-inspect": "^1.13.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/side-channel-map": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/side-channel-map/-/side-channel-map-1.0.1.tgz", + "integrity": "sha512-VCjCNfgMsby3tTdo02nbjtM/ewra6jPHmpThenkTYh8pG9ucZ/1P8So4u4FGBek/BjpOVsDCMoLA/iuBKIFXRA==", + "license": "MIT", + "dependencies": { + "call-bound": "^1.0.2", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.5", + "object-inspect": "^1.13.3" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/side-channel-weakmap": { + "version": "1.0.2", + "resolved": "https://registry.npmmirror.com/side-channel-weakmap/-/side-channel-weakmap-1.0.2.tgz", + "integrity": "sha512-WPS/HvHQTYnHisLo9McqBHOJk2FkHO/tlpvldyrnem4aeQp4hai3gythswg6p01oSoTl58rcpiFAjF2br2Ak2A==", + "license": "MIT", + "dependencies": { + "call-bound": "^1.0.2", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.5", + "object-inspect": "^1.13.3", + "side-channel-map": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/signal-exit": { + "version": "4.1.0", + "resolved": "https://registry.npmmirror.com/signal-exit/-/signal-exit-4.1.0.tgz", + "integrity": "sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==", + "license": "ISC", + "engines": { + "node": ">=14" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" + } + }, + "node_modules/slice-ansi": { + "version": "8.0.0", + "resolved": "https://registry.npmmirror.com/slice-ansi/-/slice-ansi-8.0.0.tgz", + "integrity": "sha512-stxByr12oeeOyY2BlviTNQlYV5xOj47GirPr4yA1hE9JCtxfQN0+tVbkxwCtYDQWhEKWFHsEK48ORg5jrouCAg==", + "license": "MIT", + "dependencies": { + "ansi-styles": "^6.2.3", + "is-fullwidth-code-point": "^5.1.0" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/chalk/slice-ansi?sponsor=1" + } + }, + "node_modules/stack-utils": { + "version": "2.0.6", + "resolved": "https://registry.npmmirror.com/stack-utils/-/stack-utils-2.0.6.tgz", + "integrity": "sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==", + "license": "MIT", + "dependencies": { + "escape-string-regexp": "^2.0.0" + }, + "engines": { + "node": ">=10" + } + }, + "node_modules/statuses": { + "version": "2.0.2", + "resolved": "https://registry.npmmirror.com/statuses/-/statuses-2.0.2.tgz", + "integrity": "sha512-DvEy55V3DB7uknRo+4iOGT5fP1slR8wQohVdknigZPMpMstaKJQWhwiYBACJE3Ul2pTnATihhBYnRhZQHGBiRw==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/string-width": { + "version": "8.2.0", + "resolved": "https://registry.npmmirror.com/string-width/-/string-width-8.2.0.tgz", + "integrity": "sha512-6hJPQ8N0V0P3SNmP6h2J99RLuzrWz2gvT7VnK5tKvrNqJoyS9W4/Fb8mo31UiPvy00z7DQXkP2hnKBVav76thw==", + "license": "MIT", + "dependencies": { + "get-east-asian-width": "^1.5.0", + "strip-ansi": "^7.1.2" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/strip-ansi": { + "version": "7.2.0", + "resolved": "https://registry.npmmirror.com/strip-ansi/-/strip-ansi-7.2.0.tgz", + "integrity": "sha512-yDPMNjp4WyfYBkHnjIRLfca1i6KMyGCtsVgoKe/z1+6vukgaENdgGBZt+ZmKPc4gavvEZ5OgHfHdrazhgNyG7w==", + "license": "MIT", + "dependencies": { + "ansi-regex": "^6.2.2" + }, + "engines": { + "node": ">=12" + }, + "funding": { + "url": "https://github.com/chalk/strip-ansi?sponsor=1" + } + }, + "node_modules/strip-final-newline": { + "version": "4.0.0", + "resolved": "https://registry.npmmirror.com/strip-final-newline/-/strip-final-newline-4.0.0.tgz", + "integrity": "sha512-aulFJcD6YK8V1G7iRB5tigAP4TsHBZZrOV8pjV++zdUwmeV8uzbY7yn6h9MswN62adStNZFuCIx4haBnRuMDaw==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/strnum": { + "version": "2.2.2", + "resolved": "https://registry.npmmirror.com/strnum/-/strnum-2.2.2.tgz", + "integrity": "sha512-DnR90I+jtXNSTXWdwrEy9FakW7UX+qUZg28gj5fk2vxxl7uS/3bpI4fjFYVmdK9etptYBPNkpahuQnEwhwECqA==", + "funding": [ + { + "type": "github", + "url": "https://github.com/sponsors/NaturalIntelligence" + } + ], + "license": "MIT" + }, + "node_modules/supports-color": { + "version": "10.2.2", + "resolved": "https://registry.npmmirror.com/supports-color/-/supports-color-10.2.2.tgz", + "integrity": "sha512-SS+jx45GF1QjgEXQx4NJZV9ImqmO2NPz5FNsIHrsDjh2YsHnawpan7SNQ1o8NuhrbHZy9AZhIoCUiCeaW/C80g==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/chalk/supports-color?sponsor=1" + } + }, + "node_modules/supports-hyperlinks": { + "version": "4.4.0", + "resolved": "https://registry.npmmirror.com/supports-hyperlinks/-/supports-hyperlinks-4.4.0.tgz", + "integrity": "sha512-UKbpT93hN5Nr9go5UY7bopIB9YQlMz9nm/ct4IXt/irb5YRkn9WaqrOBJGZ5Pwvsd5FQzSVeYlGdXoCAPQZrPg==", + "license": "MIT", + "dependencies": { + "has-flag": "^5.0.1", + "supports-color": "^10.2.2" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/chalk/supports-hyperlinks?sponsor=1" + } + }, + "node_modules/tagged-tag": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/tagged-tag/-/tagged-tag-1.0.0.tgz", + "integrity": "sha512-yEFYrVhod+hdNyx7g5Bnkkb0G6si8HJurOoOEgC8B/O0uXLHlaey/65KRv6cuWBNhBgHKAROVpc7QyYqE5gFng==", + "license": "MIT", + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/terminal-size": { + "version": "4.0.1", + "resolved": "https://registry.npmmirror.com/terminal-size/-/terminal-size-4.0.1.tgz", + "integrity": "sha512-avMLDQpUI9I5XFrklECw1ZEUPJhqzcwSWsyyI8blhRLT+8N1jLJWLWWYQpB2q2xthq8xDvjZPISVh53T/+CLYQ==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/toidentifier": { + "version": "1.0.1", + "resolved": "https://registry.npmmirror.com/toidentifier/-/toidentifier-1.0.1.tgz", + "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", + "license": "MIT", + "engines": { + "node": ">=0.6" + } + }, + "node_modules/tree-kill": { + "version": "1.2.2", + "resolved": "https://registry.npmmirror.com/tree-kill/-/tree-kill-1.2.2.tgz", + "integrity": "sha512-L0Orpi8qGpRG//Nd+H90vFB+3iHnue1zSSGmNOOCh1GLJ7rUKVwV2HvijphGQS2UmhUZewS9VgvxYIdgr+fG1A==", + "license": "MIT", + "bin": { + "tree-kill": "cli.js" + } + }, + "node_modules/ts-algebra": { + "version": "2.0.0", + "resolved": "https://registry.npmmirror.com/ts-algebra/-/ts-algebra-2.0.0.tgz", + "integrity": "sha512-FPAhNPFMrkwz76P7cdjdmiShwMynZYN6SgOujD1urY4oNm80Ou9oMdmbR45LotcKOXoy7wSmHkRFE6Mxbrhefw==", + "license": "MIT" + }, + "node_modules/tslib": { + "version": "2.8.1", + "resolved": "https://registry.npmmirror.com/tslib/-/tslib-2.8.1.tgz", + "integrity": "sha512-oJFu94HQb+KVduSUQL7wnpmqnfmLsOA/nAh6b6EH0wCEoK0/mPeXU6c3wKDV83MkOuHPRHtSXKKU99IBazS/2w==", + "license": "0BSD" + }, + "node_modules/type-fest": { + "version": "5.5.0", + "resolved": "https://registry.npmmirror.com/type-fest/-/type-fest-5.5.0.tgz", + "integrity": "sha512-PlBfpQwiUvGViBNX84Yxwjsdhd1TUlXr6zjX7eoirtCPIr08NAmxwa+fcYBTeRQxHo9YC9wwF3m9i700sHma8g==", + "license": "(MIT OR CC0-1.0)", + "dependencies": { + "tagged-tag": "^1.0.0" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/type-is": { + "version": "2.0.1", + "resolved": "https://registry.npmmirror.com/type-is/-/type-is-2.0.1.tgz", + "integrity": "sha512-OZs6gsjF4vMp32qrCbiVSkrFmXtG/AZhY3t0iAMrMBiAZyV9oALtXO8hsrHbMXF9x6L3grlFuwW2oAz7cav+Gw==", + "license": "MIT", + "dependencies": { + "content-type": "^1.0.5", + "media-typer": "^1.1.0", + "mime-types": "^3.0.0" + }, + "engines": { + "node": ">= 0.6" + } + }, + "node_modules/undici": { + "version": "7.24.6", + "resolved": "https://registry.npmmirror.com/undici/-/undici-7.24.6.tgz", + "integrity": "sha512-Xi4agocCbRzt0yYMZGMA6ApD7gvtUFaxm4ZmeacWI4cZxaF6C+8I8QfofC20NAePiB/IcvZmzkJ7XPa471AEtA==", + "license": "MIT", + "engines": { + "node": ">=20.18.1" + } + }, + "node_modules/unicorn-magic": { + "version": "0.3.0", + "resolved": "https://registry.npmmirror.com/unicorn-magic/-/unicorn-magic-0.3.0.tgz", + "integrity": "sha512-+QBBXBCvifc56fsbuxZQ6Sic3wqqc3WWaqxs58gvJrcOuN83HGTCwz3oS5phzU9LthRNE9VrJCFCLUgHeeFnfA==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmmirror.com/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/usehooks-ts": { + "version": "3.1.1", + "resolved": "https://registry.npmmirror.com/usehooks-ts/-/usehooks-ts-3.1.1.tgz", + "integrity": "sha512-I4diPp9Cq6ieSUH2wu+fDAVQO43xwtulo+fKEidHUwZPnYImbtkTjzIJYcDcJqxgmX31GVqNFURodvcgHcW0pA==", + "license": "MIT", + "dependencies": { + "lodash.debounce": "^4.0.8" + }, + "engines": { + "node": ">=16.15.0" + }, + "peerDependencies": { + "react": "^16.8.0 || ^17 || ^18 || ^19 || ^19.0.0-rc" + } + }, + "node_modules/vary": { + "version": "1.1.2", + "resolved": "https://registry.npmmirror.com/vary/-/vary-1.1.2.tgz", + "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", + "license": "MIT", + "engines": { + "node": ">= 0.8" + } + }, + "node_modules/vscode-jsonrpc": { + "version": "8.2.1", + "resolved": "https://registry.npmmirror.com/vscode-jsonrpc/-/vscode-jsonrpc-8.2.1.tgz", + "integrity": "sha512-kdjOSJ2lLIn7r1rtrMbbNCHjyMPfRnowdKjBQ+mGq6NAW5QY2bEZC/khaC5OR8svbbjvLEaIXkOq45e2X9BIbQ==", + "license": "MIT", + "engines": { + "node": ">=14.0.0" + } + }, + "node_modules/vscode-languageserver-types": { + "version": "3.17.5", + "resolved": "https://registry.npmmirror.com/vscode-languageserver-types/-/vscode-languageserver-types-3.17.5.tgz", + "integrity": "sha512-Ld1VelNuX9pdF39h2Hgaeb5hEZM2Z3jUrrMgWQAu82jMtZp7p3vJT3BzToKtZI7NgQssZje5o0zryOrhQvzQAg==", + "license": "MIT" + }, + "node_modules/web-streams-polyfill": { + "version": "3.3.3", + "resolved": "https://registry.npmmirror.com/web-streams-polyfill/-/web-streams-polyfill-3.3.3.tgz", + "integrity": "sha512-d2JWLCivmZYTSIoge9MsgFCZrt571BikcWGYkjC1khllbTeDlGqZ2D8vD8E/lJa8WGWbb7Plm8/XJYV7IJHZZw==", + "license": "MIT", + "engines": { + "node": ">= 8" + } + }, + "node_modules/which": { + "version": "2.0.2", + "resolved": "https://registry.npmmirror.com/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "license": "ISC", + "dependencies": { + "isexe": "^2.0.0" + }, + "bin": { + "node-which": "bin/node-which" + }, + "engines": { + "node": ">= 8" + } + }, + "node_modules/which-module": { + "version": "2.0.1", + "resolved": "https://registry.npmmirror.com/which-module/-/which-module-2.0.1.tgz", + "integrity": "sha512-iBdZ57RDvnOR9AGBhML2vFZf7h8vmBjhoaZqODJBFWHVtKkDmKuHai3cx5PgVMrX5YDNp27AofYbAwctSS+vhQ==", + "license": "ISC" + }, + "node_modules/widest-line": { + "version": "6.0.0", + "resolved": "https://registry.npmmirror.com/widest-line/-/widest-line-6.0.0.tgz", + "integrity": "sha512-U89AsyEeAsyoF0zVJBkG9zBgekjgjK7yk9sje3F4IQpXBJ10TF6ByLlIfjMhcmHMJgHZI4KHt4rdNfktzxIAMA==", + "license": "MIT", + "dependencies": { + "string-width": "^8.1.0" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/wrap-ansi": { + "version": "10.0.0", + "resolved": "https://registry.npmmirror.com/wrap-ansi/-/wrap-ansi-10.0.0.tgz", + "integrity": "sha512-SGcvg80f0wUy2/fXES19feHMz8E0JoXv2uNgHOu4Dgi2OrCy1lqwFYEJz1BLbDI0exjPMe/ZdzZ/YpGECBG/aQ==", + "license": "MIT", + "dependencies": { + "ansi-styles": "^6.2.3", + "string-width": "^8.2.0", + "strip-ansi": "^7.1.2" + }, + "engines": { + "node": ">=20" + }, + "funding": { + "url": "https://github.com/chalk/wrap-ansi?sponsor=1" + } + }, + "node_modules/wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmmirror.com/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==", + "license": "ISC" + }, + "node_modules/ws": { + "version": "8.20.0", + "resolved": "https://registry.npmmirror.com/ws/-/ws-8.20.0.tgz", + "integrity": "sha512-sAt8BhgNbzCtgGbt2OxmpuryO63ZoDk/sqaB/znQm94T4fCEsy/yV+7CdC1kJhOU9lboAEU7R3kquuycDoibVA==", + "license": "MIT", + "engines": { + "node": ">=10.0.0" + }, + "peerDependencies": { + "bufferutil": "^4.0.1", + "utf-8-validate": ">=5.0.2" + }, + "peerDependenciesMeta": { + "bufferutil": { + "optional": true + }, + "utf-8-validate": { + "optional": true + } + } + }, + "node_modules/xss": { + "version": "1.0.15", + "resolved": "https://registry.npmmirror.com/xss/-/xss-1.0.15.tgz", + "integrity": "sha512-FVdlVVC67WOIPvfOwhoMETV72f6GbW7aOabBC3WxN/oUdoEMDyLz4OgRv5/gck2ZeNqEQu+Tb0kloovXOfpYVg==", + "license": "MIT", + "dependencies": { + "commander": "^2.20.3", + "cssfilter": "0.0.10" + }, + "bin": { + "xss": "bin/xss" + }, + "engines": { + "node": ">= 0.10.0" + } + }, + "node_modules/xss/node_modules/commander": { + "version": "2.20.3", + "resolved": "https://registry.npmmirror.com/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==", + "license": "MIT" + }, + "node_modules/y18n": { + "version": "4.0.3", + "resolved": "https://registry.npmmirror.com/y18n/-/y18n-4.0.3.tgz", + "integrity": "sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==", + "license": "ISC" + }, + "node_modules/yaml": { + "version": "2.8.3", + "resolved": "https://registry.npmmirror.com/yaml/-/yaml-2.8.3.tgz", + "integrity": "sha512-AvbaCLOO2Otw/lW5bmh9d/WEdcDFdQp2Z2ZUH3pX9U2ihyUY0nvLv7J6TrWowklRGPYbB/IuIMfYgxaCPg5Bpg==", + "license": "ISC", + "bin": { + "yaml": "bin.mjs" + }, + "engines": { + "node": ">= 14.6" + }, + "funding": { + "url": "https://github.com/sponsors/eemeli" + } + }, + "node_modules/yargs": { + "version": "15.4.1", + "resolved": "https://registry.npmmirror.com/yargs/-/yargs-15.4.1.tgz", + "integrity": "sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==", + "license": "MIT", + "dependencies": { + "cliui": "^6.0.0", + "decamelize": "^1.2.0", + "find-up": "^4.1.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^4.2.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^18.1.2" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs-parser": { + "version": "18.1.3", + "resolved": "https://registry.npmmirror.com/yargs-parser/-/yargs-parser-18.1.3.tgz", + "integrity": "sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==", + "license": "ISC", + "dependencies": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + }, + "engines": { + "node": ">=6" + } + }, + "node_modules/yargs/node_modules/ansi-regex": { + "version": "5.0.1", + "resolved": "https://registry.npmmirror.com/ansi-regex/-/ansi-regex-5.0.1.tgz", + "integrity": "sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs/node_modules/emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmmirror.com/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==", + "license": "MIT" + }, + "node_modules/yargs/node_modules/is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmmirror.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==", + "license": "MIT", + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs/node_modules/string-width": { + "version": "4.2.3", + "resolved": "https://registry.npmmirror.com/string-width/-/string-width-4.2.3.tgz", + "integrity": "sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==", + "license": "MIT", + "dependencies": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/yargs/node_modules/strip-ansi": { + "version": "6.0.1", + "resolved": "https://registry.npmmirror.com/strip-ansi/-/strip-ansi-6.0.1.tgz", + "integrity": "sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A==", + "license": "MIT", + "dependencies": { + "ansi-regex": "^5.0.1" + }, + "engines": { + "node": ">=8" + } + }, + "node_modules/yoctocolors": { + "version": "2.1.2", + "resolved": "https://registry.npmmirror.com/yoctocolors/-/yoctocolors-2.1.2.tgz", + "integrity": "sha512-CzhO+pFNo8ajLM2d2IW/R93ipy99LWjtwblvC1RsoSUMZgyLbYFr221TnSNT7GjGdYui6P459mw9JH/g/zW2ug==", + "license": "MIT", + "engines": { + "node": ">=18" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" + } + }, + "node_modules/yoga-layout": { + "version": "3.2.1", + "resolved": "https://registry.npmmirror.com/yoga-layout/-/yoga-layout-3.2.1.tgz", + "integrity": "sha512-0LPOt3AxKqMdFBZA3HBAt/t/8vIKq7VaQYbuA8WxCgung+p9TVyKRYdpvCb80HcdTN2NkbIKbhNwKUfm3tQywQ==", + "license": "MIT" + }, + "node_modules/zod": { + "version": "4.3.6", + "resolved": "https://registry.npmmirror.com/zod/-/zod-4.3.6.tgz", + "integrity": "sha512-rftlrkhHZOcjDwkGlnUtZZkvaPHCsDATp4pGpuOOMDaTdDDXF91wuVDJoWoPsKX/3YPQ5fHuF3STjcYyKr+Qhg==", + "license": "MIT", + "funding": { + "url": "https://github.com/sponsors/colinhacks" + } + }, + "node_modules/zod-to-json-schema": { + "version": "3.25.2", + "resolved": "https://registry.npmmirror.com/zod-to-json-schema/-/zod-to-json-schema-3.25.2.tgz", + "integrity": "sha512-O/PgfnpT1xKSDeQYSCfRI5Gy3hPf91mKVDuYLUHZJMiDFptvP41MSnWofm8dnCm0256ZNfZIM7DSzuSMAFnjHA==", + "license": "ISC", + "peerDependencies": { + "zod": "^3.25.28 || ^4" + } + } + } +} diff --git a/package.json b/package.json new file mode 100644 index 0000000..b048d49 --- /dev/null +++ b/package.json @@ -0,0 +1,77 @@ +{ + "name": "claude-code-local", + "version": "999.0.0-local", + "private": true, + "type": "module", + "bin": { + "claude-haha": "./bin/claude-haha" + }, + "scripts": { + "claude-haha": "bun run ./bin/claude-haha", + "start": "bun run ./bin/claude-haha" + }, + "dependencies": { + "@anthropic-ai/sandbox-runtime": "^0.0.44", + "@anthropic-ai/sdk": "^0.80.0", + "@aws-sdk/client-bedrock-runtime": "^3.1020.0", + "@commander-js/extra-typings": "^14.0.0", + "@growthbook/growthbook": "^1.6.5", + "@modelcontextprotocol/sdk": "^1.29.0", + "@opentelemetry/api-logs": "^0.214.0", + "@opentelemetry/core": "^2.6.1", + "@opentelemetry/resources": "^2.6.1", + "@opentelemetry/sdk-logs": "^0.214.0", + "@opentelemetry/sdk-metrics": "^2.6.1", + "@opentelemetry/sdk-trace-base": "^2.6.1", + "@opentelemetry/semantic-conventions": "^1.40.0", + "ajv": "^8.18.0", + "asciichart": "^1.5.25", + "auto-bind": "^5.0.1", + "axios": "^1.14.0", + "bidi-js": "^1.0.3", + "chalk": "^5.6.2", + "chokidar": "^5.0.0", + "cli-boxes": "^4.0.1", + "code-excerpt": "^4.0.0", + "diff": "^8.0.4", + "emoji-regex": "^10.6.0", + "env-paths": "^4.0.0", + "execa": "^9.6.1", + "figures": "^6.1.0", + "fuse.js": "^7.1.0", + "get-east-asian-width": "^1.5.0", + "google-auth-library": "^10.6.2", + "highlight.js": "^11.11.1", + "https-proxy-agent": "^8.0.0", + "ignore": "^7.0.5", + "indent-string": "^5.0.0", + "ink": "^6.8.0", + "jsonc-parser": "^3.3.1", + "lodash-es": "^4.17.23", + "lru-cache": "^11.2.7", + "marked": "^17.0.5", + "p-map": "^7.0.4", + "picomatch": "^4.0.4", + "proper-lockfile": "^4.1.2", + "qrcode": "^1.5.4", + "react": "^19.2.4", + "react-reconciler": "^0.33.0", + "semver": "^7.7.4", + "shell-quote": "^1.8.3", + "signal-exit": "^4.1.0", + "stack-utils": "^2.0.6", + "strip-ansi": "^7.2.0", + "supports-hyperlinks": "^4.4.0", + "tree-kill": "^1.2.2", + "type-fest": "^5.5.0", + "undici": "^7.24.6", + "usehooks-ts": "^3.1.1", + "vscode-jsonrpc": "^8.2.1", + "vscode-languageserver-types": "^3.17.5", + "wrap-ansi": "^10.0.0", + "ws": "^8.20.0", + "xss": "^1.0.15", + "yaml": "^2.8.3", + "zod": "^4.3.6" + } +} diff --git a/preload.ts b/preload.ts new file mode 100644 index 0000000..956c724 --- /dev/null +++ b/preload.ts @@ -0,0 +1,17 @@ +const version = process.env.CLAUDE_CODE_LOCAL_VERSION ?? '999.0.0-local'; +const packageUrl = process.env.CLAUDE_CODE_LOCAL_PACKAGE_URL ?? 'claude-code-local'; +const buildTime = process.env.CLAUDE_CODE_LOCAL_BUILD_TIME ?? new Date().toISOString(); + +process.env.CLAUDE_CODE_LOCAL_SKIP_REMOTE_PREFETCH ??= '1'; + +Object.assign(globalThis, { + MACRO: { + VERSION: version, + PACKAGE_URL: packageUrl, + NATIVE_PACKAGE_URL: packageUrl, + BUILD_TIME: buildTime, + FEEDBACK_CHANNEL: 'local', + VERSION_CHANGELOG: '', + ISSUES_EXPLAINER: '', + }, +}); diff --git a/src/entrypoints/sdk/coreTypes.generated.ts b/src/entrypoints/sdk/coreTypes.generated.ts new file mode 100644 index 0000000..51d022e --- /dev/null +++ b/src/entrypoints/sdk/coreTypes.generated.ts @@ -0,0 +1,3 @@ +// Local recovery stub for missing generated SDK types. +// The leaked source tree does not include this codegen artifact. +export {} diff --git a/src/entrypoints/sdk/runtimeTypes.ts b/src/entrypoints/sdk/runtimeTypes.ts new file mode 100644 index 0000000..c08c2e3 --- /dev/null +++ b/src/entrypoints/sdk/runtimeTypes.ts @@ -0,0 +1,2 @@ +// Local recovery stub for missing SDK runtime type exports. +export {} diff --git a/src/entrypoints/sdk/settingsTypes.generated.ts b/src/entrypoints/sdk/settingsTypes.generated.ts new file mode 100644 index 0000000..1682cd1 --- /dev/null +++ b/src/entrypoints/sdk/settingsTypes.generated.ts @@ -0,0 +1,2 @@ +// Local recovery stub for missing generated SDK settings types. +export {} diff --git a/src/entrypoints/sdk/toolTypes.ts b/src/entrypoints/sdk/toolTypes.ts new file mode 100644 index 0000000..c29faea --- /dev/null +++ b/src/entrypoints/sdk/toolTypes.ts @@ -0,0 +1,2 @@ +// Local recovery stub for missing SDK tool type exports. +export {} diff --git a/src/ink/components/Box.tsx b/src/ink/components/Box.tsx index 67f2500..1c1fdec 100644 --- a/src/ink/components/Box.tsx +++ b/src/ink/components/Box.tsx @@ -1,5 +1,4 @@ import { c as _c } from "react/compiler-runtime"; -import '../global.d.ts'; import React, { type PropsWithChildren, type Ref } from 'react'; import type { Except } from 'type-fest'; import type { DOMElement } from '../dom.js'; @@ -211,4 +210,4 @@ function Box(t0) { return t4; } export default Box; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropsWithChildren","Ref","Except","DOMElement","ClickEvent","FocusEvent","KeyboardEvent","Styles","warn","Props","ref","tabIndex","autoFocus","onClick","event","onFocus","onFocusCapture","onBlur","onBlurCapture","onKeyDown","onKeyDownCapture","onMouseEnter","onMouseLeave","Box","t0","$","_c","children","flexDirection","flexGrow","flexShrink","flexWrap","style","t1","t2","t3","t4","t5","t6","t7","t8","t9","t10","t11","t12","t13","t14","t15","t16","t17","t18","undefined","ifNotInteger","margin","marginX","marginY","marginTop","marginBottom","marginLeft","marginRight","padding","paddingX","paddingY","paddingTop","paddingBottom","paddingLeft","paddingRight","gap","columnGap","rowGap","overflowX","overflow","overflowY"],"sources":["Box.tsx"],"sourcesContent":["import '../global.d.ts'\nimport React, { type PropsWithChildren, type Ref } from 'react'\nimport type { Except } from 'type-fest'\nimport type { DOMElement } from '../dom.js'\nimport type { ClickEvent } from '../events/click-event.js'\nimport type { FocusEvent } from '../events/focus-event.js'\nimport type { KeyboardEvent } from '../events/keyboard-event.js'\nimport type { Styles } from '../styles.js'\nimport * as warn from '../warn.js'\n\nexport type Props = Except<Styles, 'textWrap'> & {\n  ref?: Ref<DOMElement>\n  /**\n   * Tab order index. Nodes with `tabIndex >= 0` participate in\n   * Tab/Shift+Tab cycling; `-1` means programmatically focusable only.\n   */\n  tabIndex?: number\n  /**\n   * Focus this element when it mounts. Like the HTML `autofocus`\n   * attribute — the FocusManager calls `focus(node)` during the\n   * reconciler's `commitMount` phase.\n   */\n  autoFocus?: boolean\n  /**\n   * Fired on left-button click (press + release without drag). Only works\n   * inside `<AlternateScreen>` where mouse tracking is enabled — no-op\n   * otherwise. The event bubbles from the deepest hit Box up through\n   * ancestors; call `event.stopImmediatePropagation()` to stop bubbling.\n   */\n  onClick?: (event: ClickEvent) => void\n  onFocus?: (event: FocusEvent) => void\n  onFocusCapture?: (event: FocusEvent) => void\n  onBlur?: (event: FocusEvent) => void\n  onBlurCapture?: (event: FocusEvent) => void\n  onKeyDown?: (event: KeyboardEvent) => void\n  onKeyDownCapture?: (event: KeyboardEvent) => void\n  /**\n   * Fired when the mouse moves into this Box's rendered rect. Like DOM\n   * `mouseenter`, does NOT bubble — moving between children does not\n   * re-fire on the parent. Only works inside `<AlternateScreen>` where\n   * mode-1003 mouse tracking is enabled.\n   */\n  onMouseEnter?: () => void\n  /** Fired when the mouse moves out of this Box's rendered rect. */\n  onMouseLeave?: () => void\n}\n\n/**\n * `<Box>` is an essential Ink component to build your layout. It's like `<div style=\"display: flex\">` in the browser.\n */\nfunction Box({\n  children,\n  flexWrap = 'nowrap',\n  flexDirection = 'row',\n  flexGrow = 0,\n  flexShrink = 1,\n  ref,\n  tabIndex,\n  autoFocus,\n  onClick,\n  onFocus,\n  onFocusCapture,\n  onBlur,\n  onBlurCapture,\n  onMouseEnter,\n  onMouseLeave,\n  onKeyDown,\n  onKeyDownCapture,\n  ...style\n}: PropsWithChildren<Props>): React.ReactNode {\n  // Warn if spacing values are not integers to prevent fractional layout dimensions\n  warn.ifNotInteger(style.margin, 'margin')\n  warn.ifNotInteger(style.marginX, 'marginX')\n  warn.ifNotInteger(style.marginY, 'marginY')\n  warn.ifNotInteger(style.marginTop, 'marginTop')\n  warn.ifNotInteger(style.marginBottom, 'marginBottom')\n  warn.ifNotInteger(style.marginLeft, 'marginLeft')\n  warn.ifNotInteger(style.marginRight, 'marginRight')\n  warn.ifNotInteger(style.padding, 'padding')\n  warn.ifNotInteger(style.paddingX, 'paddingX')\n  warn.ifNotInteger(style.paddingY, 'paddingY')\n  warn.ifNotInteger(style.paddingTop, 'paddingTop')\n  warn.ifNotInteger(style.paddingBottom, 'paddingBottom')\n  warn.ifNotInteger(style.paddingLeft, 'paddingLeft')\n  warn.ifNotInteger(style.paddingRight, 'paddingRight')\n  warn.ifNotInteger(style.gap, 'gap')\n  warn.ifNotInteger(style.columnGap, 'columnGap')\n  warn.ifNotInteger(style.rowGap, 'rowGap')\n\n  return (\n    <ink-box\n      ref={ref}\n      tabIndex={tabIndex}\n      autoFocus={autoFocus}\n      onClick={onClick}\n      onFocus={onFocus}\n      onFocusCapture={onFocusCapture}\n      onBlur={onBlur}\n      onBlurCapture={onBlurCapture}\n      onMouseEnter={onMouseEnter}\n      onMouseLeave={onMouseLeave}\n      onKeyDown={onKeyDown}\n      onKeyDownCapture={onKeyDownCapture}\n      style={{\n        flexWrap,\n        flexDirection,\n        flexGrow,\n        flexShrink,\n        ...style,\n        overflowX: style.overflowX ?? style.overflow ?? 'visible',\n        overflowY: style.overflowY ?? style.overflow ?? 'visible',\n      }}\n    >\n      {children}\n    </ink-box>\n  )\n}\n\nexport default Box\n"],"mappings":"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","ignoreList":[]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropsWithChildren","Ref","Except","DOMElement","ClickEvent","FocusEvent","KeyboardEvent","Styles","warn","Props","ref","tabIndex","autoFocus","onClick","event","onFocus","onFocusCapture","onBlur","onBlurCapture","onKeyDown","onKeyDownCapture","onMouseEnter","onMouseLeave","Box","t0","$","_c","children","flexDirection","flexGrow","flexShrink","flexWrap","style","t1","t2","t3","t4","t5","t6","t7","t8","t9","t10","t11","t12","t13","t14","t15","t16","t17","t18","undefined","ifNotInteger","margin","marginX","marginY","marginTop","marginBottom","marginLeft","marginRight","padding","paddingX","paddingY","paddingTop","paddingBottom","paddingLeft","paddingRight","gap","columnGap","rowGap","overflowX","overflow","overflowY"],"sources":["Box.tsx"],"sourcesContent":["import '../global.d.ts'\nimport React, { type PropsWithChildren, type Ref } from 'react'\nimport type { Except } from 'type-fest'\nimport type { DOMElement } from '../dom.js'\nimport type { ClickEvent } from '../events/click-event.js'\nimport type { FocusEvent } from '../events/focus-event.js'\nimport type { KeyboardEvent } from '../events/keyboard-event.js'\nimport type { Styles } from '../styles.js'\nimport * as warn from '../warn.js'\n\nexport type Props = Except<Styles, 'textWrap'> & {\n  ref?: Ref<DOMElement>\n  /**\n   * Tab order index. Nodes with `tabIndex >= 0` participate in\n   * Tab/Shift+Tab cycling; `-1` means programmatically focusable only.\n   */\n  tabIndex?: number\n  /**\n   * Focus this element when it mounts. Like the HTML `autofocus`\n   * attribute — the FocusManager calls `focus(node)` during the\n   * reconciler's `commitMount` phase.\n   */\n  autoFocus?: boolean\n  /**\n   * Fired on left-button click (press + release without drag). Only works\n   * inside `<AlternateScreen>` where mouse tracking is enabled — no-op\n   * otherwise. The event bubbles from the deepest hit Box up through\n   * ancestors; call `event.stopImmediatePropagation()` to stop bubbling.\n   */\n  onClick?: (event: ClickEvent) => void\n  onFocus?: (event: FocusEvent) => void\n  onFocusCapture?: (event: FocusEvent) => void\n  onBlur?: (event: FocusEvent) => void\n  onBlurCapture?: (event: FocusEvent) => void\n  onKeyDown?: (event: KeyboardEvent) => void\n  onKeyDownCapture?: (event: KeyboardEvent) => void\n  /**\n   * Fired when the mouse moves into this Box's rendered rect. Like DOM\n   * `mouseenter`, does NOT bubble — moving between children does not\n   * re-fire on the parent. Only works inside `<AlternateScreen>` where\n   * mode-1003 mouse tracking is enabled.\n   */\n  onMouseEnter?: () => void\n  /** Fired when the mouse moves out of this Box's rendered rect. */\n  onMouseLeave?: () => void\n}\n\n/**\n * `<Box>` is an essential Ink component to build your layout. It's like `<div style=\"display: flex\">` in the browser.\n */\nfunction Box({\n  children,\n  flexWrap = 'nowrap',\n  flexDirection = 'row',\n  flexGrow = 0,\n  flexShrink = 1,\n  ref,\n  tabIndex,\n  autoFocus,\n  onClick,\n  onFocus,\n  onFocusCapture,\n  onBlur,\n  onBlurCapture,\n  onMouseEnter,\n  onMouseLeave,\n  onKeyDown,\n  onKeyDownCapture,\n  ...style\n}: PropsWithChildren<Props>): React.ReactNode {\n  // Warn if spacing values are not integers to prevent fractional layout dimensions\n  warn.ifNotInteger(style.margin, 'margin')\n  warn.ifNotInteger(style.marginX, 'marginX')\n  warn.ifNotInteger(style.marginY, 'marginY')\n  warn.ifNotInteger(style.marginTop, 'marginTop')\n  warn.ifNotInteger(style.marginBottom, 'marginBottom')\n  warn.ifNotInteger(style.marginLeft, 'marginLeft')\n  warn.ifNotInteger(style.marginRight, 'marginRight')\n  warn.ifNotInteger(style.padding, 'padding')\n  warn.ifNotInteger(style.paddingX, 'paddingX')\n  warn.ifNotInteger(style.paddingY, 'paddingY')\n  warn.ifNotInteger(style.paddingTop, 'paddingTop')\n  warn.ifNotInteger(style.paddingBottom, 'paddingBottom')\n  warn.ifNotInteger(style.paddingLeft, 'paddingLeft')\n  warn.ifNotInteger(style.paddingRight, 'paddingRight')\n  warn.ifNotInteger(style.gap, 'gap')\n  warn.ifNotInteger(style.columnGap, 'columnGap')\n  warn.ifNotInteger(style.rowGap, 'rowGap')\n\n  return (\n    <ink-box\n      ref={ref}\n      tabIndex={tabIndex}\n      autoFocus={autoFocus}\n      onClick={onClick}\n      onFocus={onFocus}\n      onFocusCapture={onFocusCapture}\n      onBlur={onBlur}\n      onBlurCapture={onBlurCapture}\n      onMouseEnter={onMouseEnter}\n      onMouseLeave={onMouseLeave}\n      onKeyDown={onKeyDown}\n      onKeyDownCapture={onKeyDownCapture}\n      style={{\n        flexWrap,\n        flexDirection,\n        flexGrow,\n        flexShrink,\n        ...style,\n        overflowX: style.overflowX ?? style.overflow ?? 'visible',\n        overflowY: style.overflowY ?? style.overflow ?? 'visible',\n      }}\n    >\n      {children}\n    </ink-box>\n  )\n}\n\nexport default Box\n"],"mappings":"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","ignoreList":[]} diff --git a/src/ink/components/ScrollBox.tsx b/src/ink/components/ScrollBox.tsx index 03e4a31..ed10111 100644 --- a/src/ink/components/ScrollBox.tsx +++ b/src/ink/components/ScrollBox.tsx @@ -5,7 +5,6 @@ import type { DOMElement } from '../dom.js'; import { markDirty, scheduleRenderFrom } from '../dom.js'; import { markCommitStart } from '../reconciler.js'; import type { Styles } from '../styles.js'; -import '../global.d.ts'; import Box from './Box.js'; export type ScrollBoxHandle = { scrollTo: (y: number) => void; @@ -234,4 +233,4 @@ function ScrollBox({ ; } export default ScrollBox; -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropsWithChildren","Ref","useImperativeHandle","useRef","useState","Except","markScrollActivity","DOMElement","markDirty","scheduleRenderFrom","markCommitStart","Styles","Box","ScrollBoxHandle","scrollTo","y","scrollBy","dy","scrollToElement","el","offset","scrollToBottom","getScrollTop","getPendingDelta","getScrollHeight","getFreshScrollHeight","getViewportHeight","getViewportTop","isSticky","subscribe","listener","setClampBounds","min","max","ScrollBoxProps","ref","stickyScroll","ScrollBox","children","style","ReactNode","domRef","forceRender","listenersRef","Set","renderQueuedRef","notify","l","current","scrollMutated","queueMicrotask","pendingScrollDelta","undefined","scrollAnchor","scrollTop","Math","floor","box","n","scrollHeight","content","childNodes","yogaNode","getComputedHeight","scrollViewportHeight","scrollViewportTop","Boolean","attributes","add","delete","scrollClampMin","scrollClampMax","flexWrap","flexDirection","flexGrow","flexShrink","overflowX","overflowY"],"sources":["ScrollBox.tsx"],"sourcesContent":["import React, {\n  type PropsWithChildren,\n  type Ref,\n  useImperativeHandle,\n  useRef,\n  useState,\n} from 'react'\nimport type { Except } from 'type-fest'\nimport { markScrollActivity } from '../../bootstrap/state.js'\nimport type { DOMElement } from '../dom.js'\nimport { markDirty, scheduleRenderFrom } from '../dom.js'\nimport { markCommitStart } from '../reconciler.js'\nimport type { Styles } from '../styles.js'\nimport '../global.d.ts'\nimport Box from './Box.js'\n\nexport type ScrollBoxHandle = {\n  scrollTo: (y: number) => void\n  scrollBy: (dy: number) => void\n  /**\n   * Scroll so `el`'s top is at the viewport top (plus `offset`). Unlike\n   * scrollTo which bakes a number that's stale by the time the throttled\n   * render fires, this defers the position read to render time —\n   * render-node-to-output reads `el.yogaNode.getComputedTop()` in the\n   * SAME Yoga pass that computes scrollHeight. Deterministic. One-shot.\n   */\n  scrollToElement: (el: DOMElement, offset?: number) => void\n  scrollToBottom: () => void\n  getScrollTop: () => number\n  getPendingDelta: () => number\n  getScrollHeight: () => number\n  /**\n   * Like getScrollHeight, but reads Yoga directly instead of the cached\n   * value written by render-node-to-output (throttled, up to 16ms stale).\n   * Use when you need a fresh value in useLayoutEffect after a React commit\n   * that grew content. Slightly more expensive (native Yoga call).\n   */\n  getFreshScrollHeight: () => number\n  getViewportHeight: () => number\n  /**\n   * Absolute screen-buffer row of the first visible content line (inside\n   * padding). Used for drag-to-scroll edge detection.\n   */\n  getViewportTop: () => number\n  /**\n   * True when scroll is pinned to the bottom. Set by scrollToBottom, the\n   * initial stickyScroll attribute, and by the renderer when positional\n   * follow fires (scrollTop at prevMax, content grows). Cleared by\n   * scrollTo/scrollBy. Stable signal for \"at bottom\" that doesn't depend on\n   * layout values (unlike scrollTop+viewportH >= scrollHeight).\n   */\n  isSticky: () => boolean\n  /**\n   * Subscribe to imperative scroll changes (scrollTo/scrollBy/scrollToBottom).\n   * Does NOT fire for stickyScroll updates done by the Ink renderer — those\n   * happen during Ink's render phase after React has committed. Callers that\n   * care about the sticky case should treat \"at bottom\" as a fallback.\n   */\n  subscribe: (listener: () => void) => () => void\n  /**\n   * Set the render-time scrollTop clamp to the currently-mounted children's\n   * coverage span. Called by useVirtualScroll after computing its range;\n   * render-node-to-output clamps scrollTop to [min, max] so burst scrollTo\n   * calls that race past React's async re-render show the edge of mounted\n   * content instead of blank spacer. Pass undefined to disable (sticky,\n   * cold start).\n   */\n  setClampBounds: (min: number | undefined, max: number | undefined) => void\n}\n\nexport type ScrollBoxProps = Except<\n  Styles,\n  'textWrap' | 'overflow' | 'overflowX' | 'overflowY'\n> & {\n  ref?: Ref<ScrollBoxHandle>\n  /**\n   * When true, automatically pins scroll position to the bottom when content\n   * grows. Unset manually via scrollTo/scrollBy to break the stickiness.\n   */\n  stickyScroll?: boolean\n}\n\n/**\n * A Box with `overflow: scroll` and an imperative scroll API.\n *\n * Children are laid out at their full Yoga-computed height inside a\n * constrained container. At render time, only children intersecting the\n * visible window (scrollTop..scrollTop+height) are rendered (viewport\n * culling). Content is translated by -scrollTop and clipped to the box bounds.\n *\n * Works best inside a fullscreen (constrained-height root) Ink tree.\n */\nfunction ScrollBox({\n  children,\n  ref,\n  stickyScroll,\n  ...style\n}: PropsWithChildren<ScrollBoxProps>): React.ReactNode {\n  const domRef = useRef<DOMElement>(null)\n  // scrollTo/scrollBy bypass React: they mutate scrollTop on the DOM node,\n  // mark it dirty, and call the root's throttled scheduleRender directly.\n  // The Ink renderer reads scrollTop from the node — no React state needed,\n  // no reconciler overhead per wheel event. The microtask defer coalesces\n  // multiple scrollBy calls in one input batch (discreteUpdates) into one\n  // render — otherwise scheduleRender's leading edge fires on the FIRST\n  // event before subsequent events mutate scrollTop. scrollToBottom still\n  // forces a React render: sticky is attribute-observed, no DOM-only path.\n  const [, forceRender] = useState(0)\n  const listenersRef = useRef(new Set<() => void>())\n  const renderQueuedRef = useRef(false)\n\n  const notify = () => {\n    for (const l of listenersRef.current) l()\n  }\n\n  function scrollMutated(el: DOMElement): void {\n    // Signal background intervals (IDE poll, LSP poll, GCS fetch, orphan\n    // check) to skip their next tick — they compete for the event loop and\n    // contributed to 1402ms max frame gaps during scroll drain.\n    markScrollActivity()\n    markDirty(el)\n    markCommitStart()\n    notify()\n    if (renderQueuedRef.current) return\n    renderQueuedRef.current = true\n    queueMicrotask(() => {\n      renderQueuedRef.current = false\n      scheduleRenderFrom(el)\n    })\n  }\n\n  useImperativeHandle(\n    ref,\n    (): ScrollBoxHandle => ({\n      scrollTo(y: number) {\n        const el = domRef.current\n        if (!el) return\n        // Explicit false overrides the DOM attribute so manual scroll\n        // breaks stickiness. Render code checks ?? precedence.\n        el.stickyScroll = false\n        el.pendingScrollDelta = undefined\n        el.scrollAnchor = undefined\n        el.scrollTop = Math.max(0, Math.floor(y))\n        scrollMutated(el)\n      },\n      scrollToElement(el: DOMElement, offset = 0) {\n        const box = domRef.current\n        if (!box) return\n        box.stickyScroll = false\n        box.pendingScrollDelta = undefined\n        box.scrollAnchor = { el, offset }\n        scrollMutated(box)\n      },\n      scrollBy(dy: number) {\n        const el = domRef.current\n        if (!el) return\n        el.stickyScroll = false\n        // Wheel input cancels any in-flight anchor seek — user override.\n        el.scrollAnchor = undefined\n        // Accumulate in pendingScrollDelta; renderer drains it at a capped\n        // rate so fast flicks show intermediate frames. Pure accumulator:\n        // scroll-up followed by scroll-down naturally cancels.\n        el.pendingScrollDelta = (el.pendingScrollDelta ?? 0) + Math.floor(dy)\n        scrollMutated(el)\n      },\n      scrollToBottom() {\n        const el = domRef.current\n        if (!el) return\n        el.pendingScrollDelta = undefined\n        el.stickyScroll = true\n        markDirty(el)\n        notify()\n        forceRender(n => n + 1)\n      },\n      getScrollTop() {\n        return domRef.current?.scrollTop ?? 0\n      },\n      getPendingDelta() {\n        // Accumulated-but-not-yet-drained delta. useVirtualScroll needs\n        // this to mount the union [committed, committed+pending] range —\n        // otherwise intermediate drain frames find no children (blank).\n        return domRef.current?.pendingScrollDelta ?? 0\n      },\n      getScrollHeight() {\n        return domRef.current?.scrollHeight ?? 0\n      },\n      getFreshScrollHeight() {\n        const content = domRef.current?.childNodes[0] as DOMElement | undefined\n        return (\n          content?.yogaNode?.getComputedHeight() ??\n          domRef.current?.scrollHeight ??\n          0\n        )\n      },\n      getViewportHeight() {\n        return domRef.current?.scrollViewportHeight ?? 0\n      },\n      getViewportTop() {\n        return domRef.current?.scrollViewportTop ?? 0\n      },\n      isSticky() {\n        const el = domRef.current\n        if (!el) return false\n        return el.stickyScroll ?? Boolean(el.attributes['stickyScroll'])\n      },\n      subscribe(listener: () => void) {\n        listenersRef.current.add(listener)\n        return () => listenersRef.current.delete(listener)\n      },\n      setClampBounds(min, max) {\n        const el = domRef.current\n        if (!el) return\n        el.scrollClampMin = min\n        el.scrollClampMax = max\n      },\n    }),\n    // notify/scrollMutated are inline (no useCallback) but only close over\n    // refs + imports — stable. Empty deps avoids rebuilding the handle on\n    // every render (which re-registers the ref = churn).\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [],\n  )\n\n  // Structure: outer viewport (overflow:scroll, constrained height) >\n  // inner content (flexGrow:1, flexShrink:0 — fills at least the viewport\n  // but grows beyond it for tall content). flexGrow:1 lets children use\n  // spacers to pin elements to the bottom of the scroll area. Yoga's\n  // Overflow.Scroll prevents the viewport from growing to fit the content.\n  // The renderer computes scrollHeight from the content box and culls\n  // content's children based on scrollTop.\n  //\n  // stickyScroll is passed as a DOM attribute (via ink-box directly) so it's\n  // available on the first render — ref callbacks fire after the initial\n  // commit, which is too late for the first frame.\n  return (\n    <ink-box\n      ref={el => {\n        domRef.current = el\n        if (el) el.scrollTop ??= 0\n      }}\n      style={{\n        flexWrap: 'nowrap',\n        flexDirection: style.flexDirection ?? 'row',\n        flexGrow: style.flexGrow ?? 0,\n        flexShrink: style.flexShrink ?? 1,\n        ...style,\n        overflowX: 'scroll',\n        overflowY: 'scroll',\n      }}\n      {...(stickyScroll ? { stickyScroll: true } : {})}\n    >\n      <Box flexDirection=\"column\" flexGrow={1} flexShrink={0} width=\"100%\">\n        {children}\n      </Box>\n    </ink-box>\n  )\n}\n\nexport default ScrollBox\n"],"mappings":"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","ignoreList":[]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","PropsWithChildren","Ref","useImperativeHandle","useRef","useState","Except","markScrollActivity","DOMElement","markDirty","scheduleRenderFrom","markCommitStart","Styles","Box","ScrollBoxHandle","scrollTo","y","scrollBy","dy","scrollToElement","el","offset","scrollToBottom","getScrollTop","getPendingDelta","getScrollHeight","getFreshScrollHeight","getViewportHeight","getViewportTop","isSticky","subscribe","listener","setClampBounds","min","max","ScrollBoxProps","ref","stickyScroll","ScrollBox","children","style","ReactNode","domRef","forceRender","listenersRef","Set","renderQueuedRef","notify","l","current","scrollMutated","queueMicrotask","pendingScrollDelta","undefined","scrollAnchor","scrollTop","Math","floor","box","n","scrollHeight","content","childNodes","yogaNode","getComputedHeight","scrollViewportHeight","scrollViewportTop","Boolean","attributes","add","delete","scrollClampMin","scrollClampMax","flexWrap","flexDirection","flexGrow","flexShrink","overflowX","overflowY"],"sources":["ScrollBox.tsx"],"sourcesContent":["import React, {\n  type PropsWithChildren,\n  type Ref,\n  useImperativeHandle,\n  useRef,\n  useState,\n} from 'react'\nimport type { Except } from 'type-fest'\nimport { markScrollActivity } from '../../bootstrap/state.js'\nimport type { DOMElement } from '../dom.js'\nimport { markDirty, scheduleRenderFrom } from '../dom.js'\nimport { markCommitStart } from '../reconciler.js'\nimport type { Styles } from '../styles.js'\nimport '../global.d.ts'\nimport Box from './Box.js'\n\nexport type ScrollBoxHandle = {\n  scrollTo: (y: number) => void\n  scrollBy: (dy: number) => void\n  /**\n   * Scroll so `el`'s top is at the viewport top (plus `offset`). Unlike\n   * scrollTo which bakes a number that's stale by the time the throttled\n   * render fires, this defers the position read to render time —\n   * render-node-to-output reads `el.yogaNode.getComputedTop()` in the\n   * SAME Yoga pass that computes scrollHeight. Deterministic. One-shot.\n   */\n  scrollToElement: (el: DOMElement, offset?: number) => void\n  scrollToBottom: () => void\n  getScrollTop: () => number\n  getPendingDelta: () => number\n  getScrollHeight: () => number\n  /**\n   * Like getScrollHeight, but reads Yoga directly instead of the cached\n   * value written by render-node-to-output (throttled, up to 16ms stale).\n   * Use when you need a fresh value in useLayoutEffect after a React commit\n   * that grew content. Slightly more expensive (native Yoga call).\n   */\n  getFreshScrollHeight: () => number\n  getViewportHeight: () => number\n  /**\n   * Absolute screen-buffer row of the first visible content line (inside\n   * padding). Used for drag-to-scroll edge detection.\n   */\n  getViewportTop: () => number\n  /**\n   * True when scroll is pinned to the bottom. Set by scrollToBottom, the\n   * initial stickyScroll attribute, and by the renderer when positional\n   * follow fires (scrollTop at prevMax, content grows). Cleared by\n   * scrollTo/scrollBy. Stable signal for \"at bottom\" that doesn't depend on\n   * layout values (unlike scrollTop+viewportH >= scrollHeight).\n   */\n  isSticky: () => boolean\n  /**\n   * Subscribe to imperative scroll changes (scrollTo/scrollBy/scrollToBottom).\n   * Does NOT fire for stickyScroll updates done by the Ink renderer — those\n   * happen during Ink's render phase after React has committed. Callers that\n   * care about the sticky case should treat \"at bottom\" as a fallback.\n   */\n  subscribe: (listener: () => void) => () => void\n  /**\n   * Set the render-time scrollTop clamp to the currently-mounted children's\n   * coverage span. Called by useVirtualScroll after computing its range;\n   * render-node-to-output clamps scrollTop to [min, max] so burst scrollTo\n   * calls that race past React's async re-render show the edge of mounted\n   * content instead of blank spacer. Pass undefined to disable (sticky,\n   * cold start).\n   */\n  setClampBounds: (min: number | undefined, max: number | undefined) => void\n}\n\nexport type ScrollBoxProps = Except<\n  Styles,\n  'textWrap' | 'overflow' | 'overflowX' | 'overflowY'\n> & {\n  ref?: Ref<ScrollBoxHandle>\n  /**\n   * When true, automatically pins scroll position to the bottom when content\n   * grows. Unset manually via scrollTo/scrollBy to break the stickiness.\n   */\n  stickyScroll?: boolean\n}\n\n/**\n * A Box with `overflow: scroll` and an imperative scroll API.\n *\n * Children are laid out at their full Yoga-computed height inside a\n * constrained container. At render time, only children intersecting the\n * visible window (scrollTop..scrollTop+height) are rendered (viewport\n * culling). Content is translated by -scrollTop and clipped to the box bounds.\n *\n * Works best inside a fullscreen (constrained-height root) Ink tree.\n */\nfunction ScrollBox({\n  children,\n  ref,\n  stickyScroll,\n  ...style\n}: PropsWithChildren<ScrollBoxProps>): React.ReactNode {\n  const domRef = useRef<DOMElement>(null)\n  // scrollTo/scrollBy bypass React: they mutate scrollTop on the DOM node,\n  // mark it dirty, and call the root's throttled scheduleRender directly.\n  // The Ink renderer reads scrollTop from the node — no React state needed,\n  // no reconciler overhead per wheel event. The microtask defer coalesces\n  // multiple scrollBy calls in one input batch (discreteUpdates) into one\n  // render — otherwise scheduleRender's leading edge fires on the FIRST\n  // event before subsequent events mutate scrollTop. scrollToBottom still\n  // forces a React render: sticky is attribute-observed, no DOM-only path.\n  const [, forceRender] = useState(0)\n  const listenersRef = useRef(new Set<() => void>())\n  const renderQueuedRef = useRef(false)\n\n  const notify = () => {\n    for (const l of listenersRef.current) l()\n  }\n\n  function scrollMutated(el: DOMElement): void {\n    // Signal background intervals (IDE poll, LSP poll, GCS fetch, orphan\n    // check) to skip their next tick — they compete for the event loop and\n    // contributed to 1402ms max frame gaps during scroll drain.\n    markScrollActivity()\n    markDirty(el)\n    markCommitStart()\n    notify()\n    if (renderQueuedRef.current) return\n    renderQueuedRef.current = true\n    queueMicrotask(() => {\n      renderQueuedRef.current = false\n      scheduleRenderFrom(el)\n    })\n  }\n\n  useImperativeHandle(\n    ref,\n    (): ScrollBoxHandle => ({\n      scrollTo(y: number) {\n        const el = domRef.current\n        if (!el) return\n        // Explicit false overrides the DOM attribute so manual scroll\n        // breaks stickiness. Render code checks ?? precedence.\n        el.stickyScroll = false\n        el.pendingScrollDelta = undefined\n        el.scrollAnchor = undefined\n        el.scrollTop = Math.max(0, Math.floor(y))\n        scrollMutated(el)\n      },\n      scrollToElement(el: DOMElement, offset = 0) {\n        const box = domRef.current\n        if (!box) return\n        box.stickyScroll = false\n        box.pendingScrollDelta = undefined\n        box.scrollAnchor = { el, offset }\n        scrollMutated(box)\n      },\n      scrollBy(dy: number) {\n        const el = domRef.current\n        if (!el) return\n        el.stickyScroll = false\n        // Wheel input cancels any in-flight anchor seek — user override.\n        el.scrollAnchor = undefined\n        // Accumulate in pendingScrollDelta; renderer drains it at a capped\n        // rate so fast flicks show intermediate frames. Pure accumulator:\n        // scroll-up followed by scroll-down naturally cancels.\n        el.pendingScrollDelta = (el.pendingScrollDelta ?? 0) + Math.floor(dy)\n        scrollMutated(el)\n      },\n      scrollToBottom() {\n        const el = domRef.current\n        if (!el) return\n        el.pendingScrollDelta = undefined\n        el.stickyScroll = true\n        markDirty(el)\n        notify()\n        forceRender(n => n + 1)\n      },\n      getScrollTop() {\n        return domRef.current?.scrollTop ?? 0\n      },\n      getPendingDelta() {\n        // Accumulated-but-not-yet-drained delta. useVirtualScroll needs\n        // this to mount the union [committed, committed+pending] range —\n        // otherwise intermediate drain frames find no children (blank).\n        return domRef.current?.pendingScrollDelta ?? 0\n      },\n      getScrollHeight() {\n        return domRef.current?.scrollHeight ?? 0\n      },\n      getFreshScrollHeight() {\n        const content = domRef.current?.childNodes[0] as DOMElement | undefined\n        return (\n          content?.yogaNode?.getComputedHeight() ??\n          domRef.current?.scrollHeight ??\n          0\n        )\n      },\n      getViewportHeight() {\n        return domRef.current?.scrollViewportHeight ?? 0\n      },\n      getViewportTop() {\n        return domRef.current?.scrollViewportTop ?? 0\n      },\n      isSticky() {\n        const el = domRef.current\n        if (!el) return false\n        return el.stickyScroll ?? Boolean(el.attributes['stickyScroll'])\n      },\n      subscribe(listener: () => void) {\n        listenersRef.current.add(listener)\n        return () => listenersRef.current.delete(listener)\n      },\n      setClampBounds(min, max) {\n        const el = domRef.current\n        if (!el) return\n        el.scrollClampMin = min\n        el.scrollClampMax = max\n      },\n    }),\n    // notify/scrollMutated are inline (no useCallback) but only close over\n    // refs + imports — stable. Empty deps avoids rebuilding the handle on\n    // every render (which re-registers the ref = churn).\n    // eslint-disable-next-line react-hooks/exhaustive-deps\n    [],\n  )\n\n  // Structure: outer viewport (overflow:scroll, constrained height) >\n  // inner content (flexGrow:1, flexShrink:0 — fills at least the viewport\n  // but grows beyond it for tall content). flexGrow:1 lets children use\n  // spacers to pin elements to the bottom of the scroll area. Yoga's\n  // Overflow.Scroll prevents the viewport from growing to fit the content.\n  // The renderer computes scrollHeight from the content box and culls\n  // content's children based on scrollTop.\n  //\n  // stickyScroll is passed as a DOM attribute (via ink-box directly) so it's\n  // available on the first render — ref callbacks fire after the initial\n  // commit, which is too late for the first frame.\n  return (\n    <ink-box\n      ref={el => {\n        domRef.current = el\n        if (el) el.scrollTop ??= 0\n      }}\n      style={{\n        flexWrap: 'nowrap',\n        flexDirection: style.flexDirection ?? 'row',\n        flexGrow: style.flexGrow ?? 0,\n        flexShrink: style.flexShrink ?? 1,\n        ...style,\n        overflowX: 'scroll',\n        overflowY: 'scroll',\n      }}\n      {...(stickyScroll ? { stickyScroll: true } : {})}\n    >\n      <Box flexDirection=\"column\" flexGrow={1} flexShrink={0} width=\"100%\">\n        {children}\n      </Box>\n    </ink-box>\n  )\n}\n\nexport default ScrollBox\n"],"mappings":"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","ignoreList":[]} diff --git a/src/localRecoveryCli.ts b/src/localRecoveryCli.ts new file mode 100644 index 0000000..69b94ba --- /dev/null +++ b/src/localRecoveryCli.ts @@ -0,0 +1,291 @@ +import Anthropic from '@anthropic-ai/sdk' +import { readFileSync } from 'fs' +import { createInterface } from 'readline' + +type OutputFormat = 'text' | 'json' + +function printHelp(): void { + process.stdout.write( + [ + 'Usage: claude-haha [options] [prompt]', + '', + 'Local recovery mode for this leaked source tree.', + '', + 'Options:', + ' -h, --help Show help', + ' -v, --version Show version', + ' (no args) Start local interactive mode', + ' -p, --print Send a single prompt and print the result', + ' --model Override model', + ' --system-prompt Override system prompt', + ' --system-prompt-file Read system prompt from file', + ' --append-system-prompt Append to the system prompt', + ' --output-format text (default) or json', + '', + 'Environment:', + ' ANTHROPIC_API_KEY or ANTHROPIC_AUTH_TOKEN', + ' ANTHROPIC_BASE_URL', + ' ANTHROPIC_MODEL', + ' API_TIMEOUT_MS', + '', + ].join('\n'), + ) +} + +function printVersion(): void { + process.stdout.write('999.0.0-local (Claude Code local recovery)\n') +} + +function parseArgs(argv: string[]) { + let print = false + let model = process.env.ANTHROPIC_MODEL + let systemPrompt: string | undefined + let appendSystemPrompt: string | undefined + let outputFormat: OutputFormat = 'text' + const positional: string[] = [] + + for (let i = 0; i < argv.length; i++) { + const arg = argv[i] + if (!arg) continue + + if (arg === '-h' || arg === '--help') { + return { command: 'help' as const } + } + if (arg === '-v' || arg === '--version' || arg === '-V') { + return { command: 'version' as const } + } + if (arg === '-p' || arg === '--print') { + print = true + continue + } + if (arg === '--bare') { + continue + } + if (arg === '--dangerously-skip-permissions') { + continue + } + if (arg === '--model') { + model = argv[++i] + continue + } + if (arg === '--system-prompt') { + systemPrompt = argv[++i] + continue + } + if (arg === '--system-prompt-file') { + const file = argv[++i] + systemPrompt = readFileSync(file!, 'utf8') + continue + } + if (arg === '--append-system-prompt') { + appendSystemPrompt = argv[++i] + continue + } + if (arg === '--output-format') { + const value = argv[++i] + if (value === 'json' || value === 'text') { + outputFormat = value + } + continue + } + if (arg.startsWith('-')) { + continue + } + positional.push(arg) + } + + return { + command: 'run' as const, + print, + model, + systemPrompt, + appendSystemPrompt, + outputFormat, + prompt: positional.join(' ').trim(), + } +} + +async function readPromptFromStdin(): Promise { + if (process.stdin.isTTY) return '' + const chunks: Buffer[] = [] + for await (const chunk of process.stdin) { + chunks.push(Buffer.isBuffer(chunk) ? chunk : Buffer.from(String(chunk))) + } + return Buffer.concat(chunks).toString('utf8').trim() +} + +function getSystemPrompt( + systemPrompt: string | undefined, + appendSystemPrompt: string | undefined, +): string | undefined { + if (systemPrompt && appendSystemPrompt) { + return `${systemPrompt}\n\n${appendSystemPrompt}` + } + return systemPrompt ?? appendSystemPrompt +} + +async function run(): Promise { + const parsed = parseArgs(process.argv.slice(2)) + + if (parsed.command === 'help') { + printHelp() + return + } + if (parsed.command === 'version') { + printVersion() + return + } + + if (!parsed.print) { + await runInteractive(parsed) + return + } + + const prompt = parsed.prompt || (await readPromptFromStdin()) + if (!prompt) { + process.stderr.write('Error: prompt is required\n') + process.exitCode = 1 + return + } + + const apiKey = process.env.ANTHROPIC_API_KEY + const authToken = process.env.ANTHROPIC_AUTH_TOKEN + if (!apiKey && !authToken) { + process.stderr.write( + 'Error: set ANTHROPIC_API_KEY or ANTHROPIC_AUTH_TOKEN\n', + ) + process.exitCode = 1 + return + } + + const model = + parsed.model || + process.env.ANTHROPIC_DEFAULT_SONNET_MODEL || + process.env.ANTHROPIC_MODEL + + if (!model) { + process.stderr.write('Error: model is required\n') + process.exitCode = 1 + return + } + + const client = new Anthropic({ + apiKey: apiKey ?? undefined, + authToken: authToken ?? undefined, + baseURL: process.env.ANTHROPIC_BASE_URL || undefined, + timeout: parseInt(process.env.API_TIMEOUT_MS || String(600_000), 10), + maxRetries: 0, + }) + + const response = await client.messages.create({ + model, + max_tokens: 4096, + system: getSystemPrompt(parsed.systemPrompt, parsed.appendSystemPrompt), + messages: [{ role: 'user', content: prompt }], + }) + + if (parsed.outputFormat === 'json') { + process.stdout.write(`${JSON.stringify(response, null, 2)}\n`) + return + } + + const text = response.content + .filter(block => block.type === 'text') + .map(block => block.text) + .join('\n') + + process.stdout.write(`${text}\n`) +} + +async function runInteractive(parsed: { + model?: string + systemPrompt?: string + appendSystemPrompt?: string +}): Promise { + const apiKey = process.env.ANTHROPIC_API_KEY + const authToken = process.env.ANTHROPIC_AUTH_TOKEN + if (!apiKey && !authToken) { + process.stderr.write( + 'Error: set ANTHROPIC_API_KEY or ANTHROPIC_AUTH_TOKEN\n', + ) + process.exitCode = 1 + return + } + + const model = + parsed.model || + process.env.ANTHROPIC_DEFAULT_SONNET_MODEL || + process.env.ANTHROPIC_MODEL + + if (!model) { + process.stderr.write('Error: model is required\n') + process.exitCode = 1 + return + } + + const client = new Anthropic({ + apiKey: apiKey ?? undefined, + authToken: authToken ?? undefined, + baseURL: process.env.ANTHROPIC_BASE_URL || undefined, + timeout: parseInt(process.env.API_TIMEOUT_MS || String(600_000), 10), + maxRetries: 0, + }) + + const system = getSystemPrompt(parsed.systemPrompt, parsed.appendSystemPrompt) + const messages: Array<{ role: 'user' | 'assistant'; content: string }> = [] + const rl = createInterface({ + input: process.stdin, + output: process.stdout, + prompt: 'you> ', + }) + + process.stdout.write( + `Claude Haha local interactive mode\nmodel: ${model}\ncommands: /exit, /clear\n\n`, + ) + rl.prompt() + + for await (const line of rl) { + const input = line.trim() + if (!input) { + rl.prompt() + continue + } + if (input === '/exit' || input === '/quit') { + rl.close() + break + } + if (input === '/clear') { + messages.length = 0 + process.stdout.write('history cleared\n') + rl.prompt() + continue + } + + messages.push({ role: 'user', content: input }) + try { + const response = await client.messages.create({ + model, + max_tokens: 4096, + system, + messages, + }) + const text = response.content + .filter(block => block.type === 'text') + .map(block => block.text) + .join('\n') + process.stdout.write(`claude> ${text}\n\n`) + messages.push({ role: 'assistant', content: text }) + } catch (error) { + const message = + error instanceof Error ? error.message : String(error) + process.stderr.write(`error: ${message}\n`) + } + rl.prompt() + } +} + +void run().catch(error => { + const message = error instanceof Error ? error.stack || error.message : String(error) + process.stderr.write(`${message}\n`) + process.exitCode = 1 +}) diff --git a/src/main.tsx b/src/main.tsx index ea51d90..3668c32 100644 --- a/src/main.tsx +++ b/src/main.tsx @@ -165,7 +165,7 @@ import { setCwd } from 'src/utils/Shell.js'; import { type ProcessedResume, processResumedConversation } from 'src/utils/sessionRestore.js'; import { parseSettingSourcesFlag } from 'src/utils/settings/constants.js'; import { plural } from 'src/utils/stringUtils.js'; -import { type ChannelEntry, getInitialMainLoopModel, getIsNonInteractiveSession, getSdkBetas, getSessionId, getUserMsgOptIn, setAllowedChannels, setAllowedSettingSources, setChromeFlagOverride, setClientType, setCwdState, setDirectConnectServerUrl, setFlagSettingsPath, setInitialMainLoopModel, setInlinePlugins, setIsInteractive, setKairosActive, setOriginalCwd, setQuestionPreviewFormat, setSdkBetas, setSessionBypassPermissionsMode, setSessionPersistenceDisabled, setSessionSource, setUserMsgOptIn, switchSession } from './bootstrap/state.js'; +import { type ChannelEntry, getInitialMainLoopModel, getIsNonInteractiveSession, getSdkBetas, getSessionId, getUserMsgOptIn, setAllowedChannels, setAllowedSettingSources, setChromeFlagOverride, setClientType, setCwdState, setDirectConnectServerUrl, setFlagSettingsPath, setInitialMainLoopModel, setInlinePlugins, setIsInteractive, setKairosActive, setOriginalCwd, setProjectRoot, setQuestionPreviewFormat, setSdkBetas, setSessionBypassPermissionsMode, setSessionPersistenceDisabled, setSessionSource, setUserMsgOptIn, switchSession } from './bootstrap/state.js'; /* eslint-disable @typescript-eslint/no-require-imports */ const autoModeStateModule = feature('TRANSCRIPT_CLASSIFIER') ? require('./utils/permissions/autoModeState.js') as typeof import('./utils/permissions/autoModeState.js') : null; @@ -973,7 +973,7 @@ async function run(): Promise { // If not provided but flag is present, value will be true // The actual filtering is handled in debug.ts by parsing process.argv return true; - }).addOption(new Option('-d2e, --debug-to-stderr', 'Enable debug mode (to stderr)').argParser(Boolean).hideHelp()).option('--debug-file ', 'Write debug logs to a specific file path (implicitly enables debug mode)', () => true).option('--verbose', 'Override verbose mode setting from config', () => true).option('-p, --print', 'Print response and exit (useful for pipes). Note: The workspace trust dialog is skipped when Claude is run with the -p mode. Only use this flag in directories you trust.', () => true).option('--bare', 'Minimal mode: skip hooks, LSP, plugin sync, attribution, auto-memory, background prefetches, keychain reads, and CLAUDE.md auto-discovery. Sets CLAUDE_CODE_SIMPLE=1. Anthropic auth is strictly ANTHROPIC_API_KEY or apiKeyHelper via --settings (OAuth and keychain are never read). 3P providers (Bedrock/Vertex/Foundry) use their own credentials. Skills still resolve via /skill-name. Explicitly provide context via: --system-prompt[-file], --append-system-prompt[-file], --add-dir (CLAUDE.md dirs), --mcp-config, --settings, --agents, --plugin-dir.', () => true).addOption(new Option('--init', 'Run Setup hooks with init trigger, then continue').hideHelp()).addOption(new Option('--init-only', 'Run Setup and SessionStart:startup hooks, then exit').hideHelp()).addOption(new Option('--maintenance', 'Run Setup hooks with maintenance trigger, then continue').hideHelp()).addOption(new Option('--output-format ', 'Output format (only works with --print): "text" (default), "json" (single result), or "stream-json" (realtime streaming)').choices(['text', 'json', 'stream-json'])).addOption(new Option('--json-schema ', 'JSON Schema for structured output validation. ' + 'Example: {"type":"object","properties":{"name":{"type":"string"}},"required":["name"]}').argParser(String)).option('--include-hook-events', 'Include all hook lifecycle events in the output stream (only works with --output-format=stream-json)', () => true).option('--include-partial-messages', 'Include partial message chunks as they arrive (only works with --print and --output-format=stream-json)', () => true).addOption(new Option('--input-format ', 'Input format (only works with --print): "text" (default), or "stream-json" (realtime streaming input)').choices(['text', 'stream-json'])).option('--mcp-debug', '[DEPRECATED. Use --debug instead] Enable MCP debug mode (shows MCP server errors)', () => true).option('--dangerously-skip-permissions', 'Bypass all permission checks. Recommended only for sandboxes with no internet access.', () => true).option('--allow-dangerously-skip-permissions', 'Enable bypassing all permission checks as an option, without it being enabled by default. Recommended only for sandboxes with no internet access.', () => true).addOption(new Option('--thinking ', 'Thinking mode: enabled (equivalent to adaptive), disabled').choices(['enabled', 'adaptive', 'disabled']).hideHelp()).addOption(new Option('--max-thinking-tokens ', '[DEPRECATED. Use --thinking instead for newer models] Maximum number of thinking tokens (only works with --print)').argParser(Number).hideHelp()).addOption(new Option('--max-turns ', 'Maximum number of agentic turns in non-interactive mode. This will early exit the conversation after the specified number of turns. (only works with --print)').argParser(Number).hideHelp()).addOption(new Option('--max-budget-usd ', 'Maximum dollar amount to spend on API calls (only works with --print)').argParser(value => { + }).addOption(new Option('--debug-to-stderr', 'Enable debug mode (to stderr)').argParser(Boolean).hideHelp()).option('--debug-file ', 'Write debug logs to a specific file path (implicitly enables debug mode)', () => true).option('--verbose', 'Override verbose mode setting from config', () => true).option('-p, --print', 'Print response and exit (useful for pipes). Note: The workspace trust dialog is skipped when Claude is run with the -p mode. Only use this flag in directories you trust.', () => true).option('--bare', 'Minimal mode: skip hooks, LSP, plugin sync, attribution, auto-memory, background prefetches, keychain reads, and CLAUDE.md auto-discovery. Sets CLAUDE_CODE_SIMPLE=1. Anthropic auth is strictly ANTHROPIC_API_KEY or apiKeyHelper via --settings (OAuth and keychain are never read). 3P providers (Bedrock/Vertex/Foundry) use their own credentials. Skills still resolve via /skill-name. Explicitly provide context via: --system-prompt[-file], --append-system-prompt[-file], --add-dir (CLAUDE.md dirs), --mcp-config, --settings, --agents, --plugin-dir.', () => true).addOption(new Option('--init', 'Run Setup hooks with init trigger, then continue').hideHelp()).addOption(new Option('--init-only', 'Run Setup and SessionStart:startup hooks, then exit').hideHelp()).addOption(new Option('--maintenance', 'Run Setup hooks with maintenance trigger, then continue').hideHelp()).addOption(new Option('--output-format ', 'Output format (only works with --print): "text" (default), "json" (single result), or "stream-json" (realtime streaming)').choices(['text', 'json', 'stream-json'])).addOption(new Option('--json-schema ', 'JSON Schema for structured output validation. ' + 'Example: {"type":"object","properties":{"name":{"type":"string"}},"required":["name"]}').argParser(String)).option('--include-hook-events', 'Include all hook lifecycle events in the output stream (only works with --output-format=stream-json)', () => true).option('--include-partial-messages', 'Include partial message chunks as they arrive (only works with --print and --output-format=stream-json)', () => true).addOption(new Option('--input-format ', 'Input format (only works with --print): "text" (default), or "stream-json" (realtime streaming input)').choices(['text', 'stream-json'])).option('--mcp-debug', '[DEPRECATED. Use --debug instead] Enable MCP debug mode (shows MCP server errors)', () => true).option('--dangerously-skip-permissions', 'Bypass all permission checks. Recommended only for sandboxes with no internet access.', () => true).option('--allow-dangerously-skip-permissions', 'Enable bypassing all permission checks as an option, without it being enabled by default. Recommended only for sandboxes with no internet access.', () => true).addOption(new Option('--thinking ', 'Thinking mode: enabled (equivalent to adaptive), disabled').choices(['enabled', 'adaptive', 'disabled']).hideHelp()).addOption(new Option('--max-thinking-tokens ', '[DEPRECATED. Use --thinking instead for newer models] Maximum number of thinking tokens (only works with --print)').argParser(Number).hideHelp()).addOption(new Option('--max-turns ', 'Maximum number of agentic turns in non-interactive mode. This will early exit the conversation after the specified number of turns. (only works with --print)').argParser(Number).hideHelp()).addOption(new Option('--max-budget-usd ', 'Maximum dollar amount to spend on API calls (only works with --print)').argParser(value => { const amount = Number(value); if (isNaN(amount) || amount <= 0) { throw new Error('--max-budget-usd must be a positive number greater than 0'); @@ -1904,9 +1904,6 @@ async function run(): Promise { profileCheckpoint('action_before_setup'); logForDebugging('[STARTUP] Running setup()...'); const setupStart = Date.now(); - const { - setup - } = await import('./setup.js'); const messagingSocketPath = feature('UDS_INBOX') ? (options as { messagingSocketPath?: string; }).messagingSocketPath : undefined; @@ -1924,7 +1921,16 @@ async function run(): Promise { initBuiltinPlugins(); initBundledSkills(); } - const setupPromise = setup(preSetupCwd, permissionMode, allowDangerouslySkipPermissions, worktreeEnabled, worktreeName, tmuxEnabled, sessionId ? validateUuid(sessionId) : undefined, worktreePRNumber, messagingSocketPath); + const setupPromise = process.env.CLAUDE_CODE_LOCAL_RECOVERY === '1' ? (async () => { + setOriginalCwd(preSetupCwd); + setProjectRoot(preSetupCwd); + logForDebugging('[STARTUP] setup() skipped in local recovery mode'); + })() : (async () => { + const { + setup + } = await import('./setup.js'); + await setup(preSetupCwd, permissionMode, allowDangerouslySkipPermissions, worktreeEnabled, worktreeName, tmuxEnabled, sessionId ? validateUuid(sessionId) : undefined, worktreePRNumber, messagingSocketPath); + })(); const commandsPromise = worktreeEnabled ? null : getCommands(preSetupCwd); const agentDefsPromise = worktreeEnabled ? null : getAgentDefinitionsWithOverrides(preSetupCwd); // Suppress transient unhandledRejection if these reject during the @@ -4681,4 +4687,4 @@ function extractTeammateOptions(options: unknown): TeammateOptions { agentType: typeof opts.agentType === 'string' ? opts.agentType : undefined }; } -//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["profileCheckpoint","profileReport","startMdmRawRead","ensureKeychainPrefetchCompleted","startKeychainPrefetch","feature","Command","CommanderCommand","InvalidArgumentError","Option","chalk","readFileSync","mapValues","pickBy","uniqBy","React","getOauthConfig","getRemoteSessionUrl","getSystemContext","getUserContext","init","initializeTelemetryAfterTrust","addToHistory","Root","launchRepl","hasGrowthBookEnvOverride","initializeGrowthBook","refreshGrowthBookAfterAuthChange","fetchBootstrapData","DownloadResult","downloadSessionFiles","FilesApiConfig","parseFileSpecs","prefetchPassesEligibility","prefetchOfficialMcpUrls","McpSdkServerConfig","McpServerConfig","ScopedMcpServerConfig","isPolicyAllowed","loadPolicyLimits","refreshPolicyLimits","waitForPolicyLimitsToLoad","loadRemoteManagedSettings","refreshRemoteManagedSettings","ToolInputJSONSchema","createSyntheticOutputTool","isSyntheticOutputToolEnabled","getTools","canUserConfigureAdvisor","getInitialAdvisorSetting","isAdvisorEnabled","isValidAdvisorModel","modelSupportsAdvisor","isAgentSwarmsEnabled","count","uniq","installAsciicastRecorder","getSubscriptionType","isClaudeAISubscriber","prefetchAwsCredentialsAndBedRockInfoIfSafe","prefetchGcpCredentialsIfSafe","validateForceLoginOrg","checkHasTrustDialogAccepted","getGlobalConfig","getRemoteControlAtStartup","isAutoUpdaterDisabled","saveGlobalConfig","seedEarlyInput","stopCapturingEarlyInput","getInitialEffortSetting","parseEffortValue","getInitialFastModeSetting","isFastModeEnabled","prefetchFastModeStatus","resolveFastModeStatusFromCache","applyConfigEnvironmentVariables","createSystemMessage","createUserMessage","getPlatform","getBaseRenderOptions","getSessionIngressAuthToken","settingsChangeDetector","skillChangeDetector","jsonParse","writeFileSync_DEPRECATED","computeInitialTeamContext","initializeWarningHandler","isWorktreeModeEnabled","getTeammateUtils","require","getTeammatePromptAddendum","getTeammateModeSnapshot","coordinatorModeModule","assistantModule","kairosGate","relative","resolve","isAnalyticsDisabled","getFeatureValue_CACHED_MAY_BE_STALE","AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS","logEvent","initializeAnalyticsGates","getOriginalCwd","setAdditionalDirectoriesForClaudeMd","setIsRemoteMode","setMainLoopModelOverride","setMainThreadAgentType","setTeleportedSessionInfo","filterCommandsForRemoteMode","getCommands","StatsStore","launchAssistantInstallWizard","launchAssistantSessionChooser","launchInvalidSettingsDialog","launchResumeChooser","launchSnapshotUpdateDialog","launchTeleportRepoMismatchDialog","launchTeleportResumeWrapper","SHOW_CURSOR","exitWithError","exitWithMessage","getRenderContext","renderAndRun","showSetupScreens","initBuiltinPlugins","checkQuotaStatus","getMcpToolsCommandsAndResources","prefetchAllMcpResources","VALID_INSTALLABLE_SCOPES","VALID_UPDATE_SCOPES","initBundledSkills","AgentColorName","getActiveAgentsFromList","getAgentDefinitionsWithOverrides","isBuiltInAgent","isCustomAgent","parseAgentsFromJson","LogOption","Message","MessageType","assertMinVersion","CLAUDE_IN_CHROME_SKILL_HINT","CLAUDE_IN_CHROME_SKILL_HINT_WITH_WEBBROWSER","setupClaudeInChrome","shouldAutoEnableClaudeInChrome","shouldEnableClaudeInChrome","getContextWindowForModel","loadConversationForResume","buildDeepLinkBanner","hasNodeOption","isBareMode","isEnvTruthy","isInProtectedNamespace","refreshExampleCommands","FpsMetrics","getWorktreePaths","findGitRoot","getBranch","getIsGit","getWorktreeCount","getGhAuthStatus","safeParseJSON","logError","getModelDeprecationWarning","getDefaultMainLoopModel","getUserSpecifiedModelSetting","normalizeModelStringForAPI","parseUserSpecifiedModel","ensureModelStringsInitialized","PERMISSION_MODES","checkAndDisableBypassPermissions","getAutoModeEnabledStateIfCached","initializeToolPermissionContext","initialPermissionModeFromCLI","isDefaultPermissionModeAuto","parseToolListFromCLI","removeDangerousPermissions","stripDangerousPermissionsForAutoMode","verifyAutoModeGateAccess","cleanupOrphanedPluginVersionsInBackground","initializeVersionedPlugins","getManagedPluginNames","getGlobExclusionsForPluginCache","getPluginSeedDirs","countFilesRoundedRg","processSessionStartHooks","processSetupHooks","cacheSessionTitle","getSessionIdFromLog","loadTranscriptFromFile","saveAgentSetting","saveMode","searchSessionsByCustomTitle","sessionIdExists","ensureMdmSettingsLoaded","getInitialSettings","getManagedSettingsKeysForLogging","getSettingsForSource","getSettingsWithErrors","resetSettingsCache","ValidationError","DEFAULT_TASKS_MODE_TASK_LIST_ID","TASK_STATUSES","logPluginLoadErrors","logPluginsEnabledForSession","logSkillsLoaded","generateTempFilePath","validateUuid","registerMcpAddCommand","registerMcpXaaIdpCommand","logPermissionContextForAnts","fetchClaudeAIMcpConfigsIfEligible","clearServerCache","areMcpConfigsAllowedWithEnterpriseMcpConfig","dedupClaudeAiMcpServers","doesEnterpriseMcpConfigExist","filterMcpServersByPolicy","getClaudeCodeMcpConfigs","getMcpServerSignature","parseMcpConfig","parseMcpConfigFromFilePath","excludeCommandsByServer","excludeResourcesByServer","isXaaEnabled","getRelevantTips","logContextMetrics","CLAUDE_IN_CHROME_MCP_SERVER_NAME","isClaudeInChromeMCPServer","registerCleanup","eagerParseCliFlag","createEmptyAttributionState","countConcurrentSessions","registerSession","updateSessionName","getCwd","logForDebugging","setHasFormattedOutput","errorMessage","getErrnoCode","isENOENT","TeleportOperationError","toError","getFsImplementation","safeResolvePath","gracefulShutdown","gracefulShutdownSync","setAllHookEventsEnabled","refreshModelCapabilities","peekForStdinData","writeToStderr","setCwd","ProcessedResume","processResumedConversation","parseSettingSourcesFlag","plural","ChannelEntry","getInitialMainLoopModel","getIsNonInteractiveSession","getSdkBetas","getSessionId","getUserMsgOptIn","setAllowedChannels","setAllowedSettingSources","setChromeFlagOverride","setClientType","setCwdState","setDirectConnectServerUrl","setFlagSettingsPath","setInitialMainLoopModel","setInlinePlugins","setIsInteractive","setKairosActive","setOriginalCwd","setQuestionPreviewFormat","setSdkBetas","setSessionBypassPermissionsMode","setSessionPersistenceDisabled","setSessionSource","setUserMsgOptIn","switchSession","autoModeStateModule","migrateAutoUpdatesToSettings","migrateBypassPermissionsAcceptedToSettings","migrateEnableAllProjectMcpServersToSettings","migrateFennecToOpus","migrateLegacyOpusToCurrent","migrateOpusToOpus1m","migrateReplBridgeEnabledToRemoteControlAtStartup","migrateSonnet1mToSonnet45","migrateSonnet45ToSonnet46","resetAutoModeOptInForDefaultOffer","resetProToOpusDefault","createRemoteSessionConfig","createDirectConnectSession","DirectConnectError","initializeLspServerManager","shouldEnablePromptSuggestion","AppState","getDefaultAppState","IDLE_SPECULATION_STATE","onChangeAppState","createStore","asSessionId","filterAllowedSdkBetas","isInBundledMode","isRunningWithBun","logForDiagnosticsNoPII","filterExistingPaths","getKnownPathsForRepo","clearPluginCache","loadAllPluginsCacheOnly","migrateChangelogFromConfig","SandboxManager","fetchSession","prepareApiRequest","checkOutTeleportedSessionBranch","processMessagesForTeleportResume","teleportToRemoteWithErrorHandling","validateGitState","validateSessionRepository","shouldEnableThinkingByDefault","ThinkingConfig","initUser","resetUserCache","getTmuxInstallInstructions","isTmuxAvailable","parsePRReference","logManagedSettings","policySettings","allKeys","keyCount","length","keys","join","isBeingDebugged","isBun","hasInspectArg","process","execArgv","some","arg","test","hasInspectEnv","env","NODE_OPTIONS","inspector","global","hasInspectorUrl","url","exit","logSessionTelemetry","model","then","enabled","errors","managedNames","catch","err","getCertEnvVarTelemetry","Record","result","NODE_EXTRA_CA_CERTS","has_node_extra_ca_certs","CLAUDE_CODE_CLIENT_CERT","has_client_cert","has_use_system_ca","has_use_openssl_ca","logStartupTelemetry","Promise","isGit","worktreeCount","ghAuthStatus","all","is_git","worktree_count","gh_auth_status","sandbox_enabled","isSandboxingEnabled","are_unsandboxed_commands_allowed","areUnsandboxedCommandsAllowed","is_auto_bash_allowed_if_sandbox_enabled","isAutoAllowBashIfSandboxedEnabled","auto_updater_disabled","prefers_reduced_motion","prefersReducedMotion","CURRENT_MIGRATION_VERSION","runMigrations","migrationVersion","prev","prefetchSystemContextIfSafe","isNonInteractiveSession","hasTrust","startDeferredPrefetches","CLAUDE_CODE_EXIT_AFTER_FIRST_RENDER","CLAUDE_CODE_USE_BEDROCK","CLAUDE_CODE_SKIP_BEDROCK_AUTH","CLAUDE_CODE_USE_VERTEX","CLAUDE_CODE_SKIP_VERTEX_AUTH","AbortSignal","timeout","initialize","m","startEventLoopStallDetector","loadSettingsFromFlag","settingsFile","trimmedSettings","trim","looksLikeJson","startsWith","endsWith","settingsPath","parsedJson","stderr","write","red","contentHash","resolvedPath","resolvedSettingsPath","e","error","Error","loadSettingSourcesFromFlag","settingSourcesArg","sources","eagerLoadSettings","undefined","initializeEntrypoint","isNonInteractive","CLAUDE_CODE_ENTRYPOINT","cliArgs","argv","slice","mcpIndex","indexOf","CLAUDE_CODE_ACTION","PendingConnect","authToken","dangerouslySkipPermissions","_pendingConnect","PendingAssistantChat","sessionId","discover","_pendingAssistantChat","PendingSSH","host","cwd","permissionMode","local","extraCliArgs","_pendingSSH","main","NoDefaultCurrentDirectoryInExePath","on","resetCursor","includes","rawCliArgs","ccIdx","findIndex","a","ccUrl","parseConnectUrl","parsed","stripped","filter","_","i","dspIdx","splice","serverUrl","handleUriIdx","enableConfigs","uri","handleDeepLinkUri","exitCode","platform","__CFBundleIdentifier","handleUrlSchemeLaunch","urlSchemeResult","rawArgs","nextArg","localIdx","pmIdx","pmEqIdx","split","extractFlag","flag","opts","hasValue","as","push","val","eqI","consumed","rest","hasPrintFlag","hasInitOnlyFlag","hasSdkUrl","stdout","isTTY","isInteractive","clientType","GITHUB_ACTIONS","hasSessionIngressToken","CLAUDE_CODE_SESSION_ACCESS_TOKEN","CLAUDE_CODE_WEBSOCKET_AUTH_FILE_DESCRIPTOR","previewFormat","CLAUDE_CODE_QUESTION_PREVIEW_FORMAT","CLAUDE_CODE_ENVIRONMENT_KIND","run","getInputPrompt","prompt","inputFormat","AsyncIterable","stdin","setEncoding","data","onData","chunk","timedOut","off","Boolean","createSortedHelpConfig","sortSubcommands","sortOptions","getOptionSortKey","opt","long","replace","short","Object","assign","const","compareOptions","b","localeCompare","program","configureHelp","enablePositionalOptions","hook","thisCommand","CLAUDE_CODE_DISABLE_TERMINAL_TITLE","title","initSinks","pluginDir","getOptionValue","Array","isArray","every","p","uploadUserSettingsInBackground","name","description","argument","String","helpOption","option","_value","addOption","argParser","hideHelp","choices","Number","value","amount","isNaN","tokens","isInteger","default","v","n","isFinite","rawValue","toLowerCase","allowed","action","options","bare","CLAUDE_CODE_SIMPLE","console","warn","yellow","kairosEnabled","assistantTeamContext","Awaited","ReturnType","NonNullable","assistant","markAssistantForced","isAssistantMode","agentId","isAssistantForced","isKairosEnabled","brief","initializeAssistantTeam","debug","debugToStderr","allowDangerouslySkipPermissions","tools","baseTools","allowedTools","disallowedTools","mcpConfig","permissionModeCli","addDir","fallbackModel","betas","ide","includeHookEvents","includePartialMessages","prefill","fileDownloadPromise","agentsJson","agents","agentCli","agent","CLAUDE_CODE_AGENT","outputFormat","verbose","print","initOnly","maintenance","disableSlashCommands","tasksOption","tasks","taskListId","CLAUDE_CODE_TASK_LIST_ID","worktreeOption","worktree","worktreeName","worktreeEnabled","worktreePRNumber","prNum","tmuxEnabled","tmux","storedTeammateOpts","TeammateOptions","teammateOpts","extractTeammateOptions","hasAnyTeammateOpt","agentName","teamName","hasAllRequiredTeammateOpts","setDynamicTeamContext","color","agentColor","planModeRequired","parentSessionId","teammateMode","setCliTeammateModeOverride","sdkUrl","effectiveIncludePartialMessages","CLAUDE_CODE_INCLUDE_PARTIAL_MESSAGES","CLAUDE_CODE_REMOTE","teleport","remoteOption","remote","remoteControlOption","remoteControl","rc","remoteControlName","continue","resume","forkSession","validatedSessionId","fileSpecs","file","sessionToken","fileSessionId","CLAUDE_CODE_REMOTE_SESSION_ID","files","config","baseUrl","ANTHROPIC_BASE_URL","BASE_API_URL","oauthToken","systemPrompt","systemPromptFile","filePath","code","appendSystemPrompt","appendSystemPromptFile","addendum","TEAMMATE_SYSTEM_PROMPT_ADDENDUM","mode","notification","permissionModeNotification","enableAutoMode","setAutoModeFlagCli","dynamicMcpConfig","processedConfigs","map","allConfigs","allErrors","configItem","configs","configObject","expandVars","scope","mcpServers","configPath","formattedErrors","path","message","level","nonSdkConfigNames","entries","type","reservedNameError","isComputerUseMCPServer","COMPUTER_USE_MCP_SERVER_NAME","scopedConfigs","blocked","chromeOpts","chrome","enableClaudeInChrome","autoEnableClaudeInChrome","chromeMcpConfig","chromeMcpTools","chromeSystemPrompt","hint","Bun","strictMcpConfig","getChicagoEnabled","setupComputerUseMCP","cuTools","devChannels","parseChannelEntries","raw","bad","c","at","kind","marketplace","channelOpts","channels","dangerouslyLoadDevelopmentChannels","rawChannels","rawDev","channelEntries","joinPluginIds","ids","flatMap","sort","channels_count","dev_count","plugins","dev_plugins","BRIEF_TOOL_NAME","LEGACY_BRIEF_TOOL_NAME","isBriefEntitled","initResult","allowedToolsCli","disallowedToolsCli","baseToolsCli","addDirs","toolPermissionContext","warnings","dangerousPermissions","overlyBroadBashPermissions","permission","ruleDisplay","sourceDisplay","forEach","warning","claudeaiConfigPromise","mcpConfigStart","Date","now","mcpConfigResolvedMs","mcpConfigPromise","servers","replayUserMessages","sessionPersistence","effectivePrompt","inputPrompt","maybeActivateProactive","CLAUDE_CODE_COORDINATOR_MODE","applyCoordinatorToolFilter","jsonSchema","syntheticOutputResult","tool","schema_property_count","properties","has_required_fields","required","setupStart","setup","messagingSocketPath","preSetupCwd","setupPromise","commandsPromise","agentDefsPromise","effectiveReplayUserMessages","sessionNameArg","explicitModel","ANTHROPIC_MODEL","cachedGrowthBookFeatures","userSpecifiedModel","userSpecifiedFallbackModel","currentCwd","commandsStart","commands","agentDefinitionsResult","cliAgents","activeAgents","parsedAgents","allAgents","agentDefinitions","agentSetting","mainThreadAgentDefinition","find","agentType","source","agentSystemPrompt","getSystemPrompt","initialPrompt","effectiveModel","initialMainLoopModel","resolvedInitialModel","advisorModel","advisorOption","advisor","normalizedAdvisorModel","customAgent","customPrompt","memory","agent_type","customInstructions","maybeActivateBrief","defaultView","proactive","CLAUDE_CODE_PROACTIVE","isCoordinatorMode","briefVisibility","isBriefEnabled","proactivePrompt","assistantAddendum","getAssistantSystemPromptAddendum","root","getFpsMetrics","stats","ctx","createRoot","renderOptions","event","durationMs","Math","round","uptime","setupScreensStart","onboardingShown","getBridgeDisabledReason","disabledReason","pendingSnapshotUpdate","agentDef","choice","snapshotTimestamp","buildMergePrompt","mergePrompt","clearTrustedDeviceToken","enrollTrustedDevice","orgValidation","valid","nonMcpErrors","mcpErrorMetadata","settingsErrors","onExit","bgRefreshThrottleMs","lastPrefetched","startupPrefetchedAt","skipStartupPrefetches","lastPrefetchedInfo","current","existingMcpConfigs","allMcpConfigs","sdkMcpConfigs","regularMcpConfigs","typedConfig","localMcpPromise","clients","claudeaiMcpPromise","mcpPromise","claudeai","hooksPromise","hookMessages","mcpClients","mcpTools","mcpCommands","thinkingEnabled","thinkingConfig","thinking","maxThinkingTokens","MAX_THINKING_TOKENS","parseInt","budgetTokens","version","MACRO","VERSION","is_native_binary","logTenguInit","hasInitialPrompt","hasStdin","numAllowedTools","numDisallowedTools","mcpClientCount","skipWebFetchPreflight","githubActionInputs","GITHUB_ACTION_INPUTS","dangerouslySkipPermissionsPassed","modeIsBypass","allowDangerouslySkipPermissionsPassed","systemPromptFlag","appendSystemPromptFlag","assistantActivationPath","getAssistantActivationPath","registered","num_sessions","setupTrigger","forceSyncExecution","sessionStartHooksPromise","commandsHeadless","command","disableNonInteractive","supportsNonInteractive","defaultState","headlessInitialState","mcp","effortValue","effort","fastMode","headlessStore","getState","updateContext","setState","nextCtx","connectMcpBatch","label","client","CLAUDE_AI_MCP_TIMEOUT_MS","claudeaiConnect","claudeaiConfigs","claudeaiSigs","Set","values","sig","add","suppressed","has","size","onclose","resources","t","mcpInfo","serverName","nonPluginConfigs","dedupedClaudeAi","claudeaiTimer","setTimeout","claudeaiTimedOut","race","r","clearTimeout","startBackgroundHousekeeping","startSdkMemoryMonitor","runHeadless","permissionPromptToolName","permissionPromptTool","maxTurns","maxBudgetUsd","taskBudget","total","resumeSessionAt","rewindFiles","enableAuthStatus","workload","cli_flag","env_var","settings_file","subscriptionType","deprecationWarning","initialNotifications","key","text","priority","displayList","displays","effectiveToolPermissionContext","isPlanModeRequired","initialIsBriefOnly","fullRemoteControl","ccrMirrorEnabled","isCcrMirrorEnabled","initialState","settings","agentNameRegistry","Map","mainLoopModel","mainLoopModelForSession","isBriefOnly","expandedView","showSpinnerTree","showExpandedTodos","showTeammateMessagePreview","selectedIPAgentIndex","coordinatorTaskIndex","viewSelectionMode","footerSelection","pluginReconnectKey","disabled","installationStatus","marketplaces","needsRefresh","statusLineText","remoteSessionUrl","remoteConnectionStatus","remoteBackgroundTaskCount","replBridgeEnabled","replBridgeExplicit","replBridgeOutboundOnly","replBridgeConnected","replBridgeSessionActive","replBridgeReconnecting","replBridgeConnectUrl","replBridgeSessionUrl","replBridgeEnvironmentId","replBridgeSessionId","replBridgeError","replBridgeInitialName","showRemoteCallout","notifications","queue","elicitation","todos","remoteAgentTaskSuggestions","fileHistory","snapshots","trackedFiles","snapshotSequence","attribution","promptSuggestionEnabled","sessionHooks","inbox","messages","promptSuggestion","promptId","shownAt","acceptedAt","generationRequestId","speculation","speculationSessionTimeSavedMs","skillImprovement","suggestion","workerSandboxPermissions","selectedIndex","pendingWorkerRequest","pendingSandboxRequest","authVersion","initialMessage","content","activeOverlays","teamContext","initialTools","numStartups","setImmediate","sessionUploaderPromise","uploaderReady","mod","createSessionTurnUploader","sessionConfig","autoConnectIdeFlag","onTurnComplete","uploader","resumeContext","modeApi","resumeSucceeded","resumeStart","performance","clearSessionCaches","success","loaded","includeAttribution","transcriptPath","fullPath","restoredAgentDef","resume_duration_ms","initialMessages","initialFileHistorySnapshots","fileHistorySnapshots","initialContentReplacements","contentReplacements","initialAgentName","initialAgentColor","directConnectConfig","session","workDir","connectInfoMessage","createSSHSession","createLocalSSHSession","SSHSessionError","sshSession","hadProgress","localVersion","onProgress","msg","remoteCwd","sshInfoMessage","discoverAssistantSessions","targetSessionId","sessions","installedDir","beforeExit","id","picked","checkAndRefreshOAuthTokenIfNeeded","getClaudeAIOAuthTokens","apiCreds","getAccessToken","accessToken","remoteSessionConfig","orgUUID","infoMessage","assistantInitialState","remoteCommands","fromPr","processedResume","maybeSessionId","searchTerm","matchedLog","filterByPr","trimmedValue","matches","exact","isRemoteTuiEnabled","has_initial_prompt","currentBranch","createdSession","AbortController","signal","session_id","getTokensForRemote","getAccessTokenForRemote","remoteInfoMessage","initialUserMessage","remoteInitialState","teleportResult","branchError","branch","log","sessionData","repoValidation","status","sessionRepo","knownPaths","existingPaths","selectedPath","targetRepo","initialPaths","chdir","bold","teleportWithProgress","formattedMessage","parseCcshareId","loadCcshare","ccshareId","logOption","entrypoint","sessionIdOverride","results","failedCount","resumeData","initialSearchQuery","pendingHookMessages","deepLinkBanner","deepLinkOrigin","has_prefill","has_repo","deepLinkRepo","prefillLength","repo","lastFetch","deepLinkLastFetch","implies","isPrintMode","isCcUrl","parseAsync","mcpServeHandler","mcpRemoveHandler","mcpListHandler","mcpGetHandler","json","clientSecret","mcpAddJsonHandler","mcpAddFromDesktopHandler","mcpResetChoicesHandler","port","unix","workspace","idleTimeout","maxSessions","randomBytes","startServer","SessionManager","DangerousBackend","printBanner","createServerLogger","writeServerLock","removeServerLock","probeRunningServer","existing","pid","httpUrl","toString","idleTimeoutMs","backend","sessionManager","logger","server","actualPort","startedAt","shuttingDown","shutdown","stop","destroyAll","once","connectConfig","runConnectHeadless","interactive","auth","email","sso","useConsole","authLogin","authStatus","authLogout","coworkOption","pluginCmd","alias","manifestPath","cowork","pluginValidateHandler","available","pluginListHandler","marketplaceCmd","sparse","marketplaceAddHandler","marketplaceListHandler","marketplaceRemoveHandler","marketplaceUpdateHandler","plugin","pluginInstallHandler","keepData","pluginUninstallHandler","pluginEnableHandler","pluginDisableHandler","pluginUpdateHandler","setupTokenHandler","agentsHandler","autoModeCmd","autoModeDefaultsHandler","autoModeConfigHandler","autoModeCritiqueHandler","hidden","bridgeMain","doctorHandler","update","up","target","list","dryRun","safe","rollback","force","installHandler","validateLogId","logId","logHandler","number","errorHandler","usage","addHelpText","outputFile","exportHandler","taskCmd","subject","taskCreateHandler","pending","taskListHandler","taskGetHandler","owner","clearOwner","taskUpdateHandler","taskDirHandler","shell","output","completionHandler","inProtectedNamespace","thinkingType","is_simple","is_coordinator","autoUpdatesChannel","gitRoot","rp","relativeProjectPath","proactiveModule","isProactiveActive","activateProactive","briefFlag","briefEnv","CLAUDE_CODE_BRIEF","entitled","gated","terminal"],"sources":["main.tsx"],"sourcesContent":["// These side-effects must run before all other imports:\n// 1. profileCheckpoint marks entry before heavy module evaluation begins\n// 2. startMdmRawRead fires MDM subprocesses (plutil/reg query) so they run in\n//    parallel with the remaining ~135ms of imports below\n// 3. startKeychainPrefetch fires both macOS keychain reads (OAuth + legacy API\n//    key) in parallel — isRemoteManagedSettingsEligible() otherwise reads them\n//    sequentially via sync spawn inside applySafeConfigEnvironmentVariables()\n//    (~65ms on every macOS startup)\nimport { profileCheckpoint, profileReport } from './utils/startupProfiler.js'\n\n// eslint-disable-next-line custom-rules/no-top-level-side-effects\nprofileCheckpoint('main_tsx_entry')\n\nimport { startMdmRawRead } from './utils/settings/mdm/rawRead.js'\n\n// eslint-disable-next-line custom-rules/no-top-level-side-effects\nstartMdmRawRead()\n\nimport {\n  ensureKeychainPrefetchCompleted,\n  startKeychainPrefetch,\n} from './utils/secureStorage/keychainPrefetch.js'\n\n// eslint-disable-next-line custom-rules/no-top-level-side-effects\nstartKeychainPrefetch()\n\nimport { feature } from 'bun:bundle'\nimport {\n  Command as CommanderCommand,\n  InvalidArgumentError,\n  Option,\n} from '@commander-js/extra-typings'\nimport chalk from 'chalk'\nimport { readFileSync } from 'fs'\nimport mapValues from 'lodash-es/mapValues.js'\nimport pickBy from 'lodash-es/pickBy.js'\nimport uniqBy from 'lodash-es/uniqBy.js'\nimport React from 'react'\nimport { getOauthConfig } from './constants/oauth.js'\nimport { getRemoteSessionUrl } from './constants/product.js'\nimport { getSystemContext, getUserContext } from './context.js'\nimport { init, initializeTelemetryAfterTrust } from './entrypoints/init.js'\nimport { addToHistory } from './history.js'\nimport type { Root } from './ink.js'\nimport { launchRepl } from './replLauncher.js'\nimport {\n  hasGrowthBookEnvOverride,\n  initializeGrowthBook,\n  refreshGrowthBookAfterAuthChange,\n} from './services/analytics/growthbook.js'\nimport { fetchBootstrapData } from './services/api/bootstrap.js'\nimport {\n  type DownloadResult,\n  downloadSessionFiles,\n  type FilesApiConfig,\n  parseFileSpecs,\n} from './services/api/filesApi.js'\nimport { prefetchPassesEligibility } from './services/api/referral.js'\nimport { prefetchOfficialMcpUrls } from './services/mcp/officialRegistry.js'\nimport type {\n  McpSdkServerConfig,\n  McpServerConfig,\n  ScopedMcpServerConfig,\n} from './services/mcp/types.js'\nimport {\n  isPolicyAllowed,\n  loadPolicyLimits,\n  refreshPolicyLimits,\n  waitForPolicyLimitsToLoad,\n} from './services/policyLimits/index.js'\nimport {\n  loadRemoteManagedSettings,\n  refreshRemoteManagedSettings,\n} from './services/remoteManagedSettings/index.js'\nimport type { ToolInputJSONSchema } from './Tool.js'\nimport {\n  createSyntheticOutputTool,\n  isSyntheticOutputToolEnabled,\n} from './tools/SyntheticOutputTool/SyntheticOutputTool.js'\nimport { getTools } from './tools.js'\nimport {\n  canUserConfigureAdvisor,\n  getInitialAdvisorSetting,\n  isAdvisorEnabled,\n  isValidAdvisorModel,\n  modelSupportsAdvisor,\n} from './utils/advisor.js'\nimport { isAgentSwarmsEnabled } from './utils/agentSwarmsEnabled.js'\nimport { count, uniq } from './utils/array.js'\nimport { installAsciicastRecorder } from './utils/asciicast.js'\nimport {\n  getSubscriptionType,\n  isClaudeAISubscriber,\n  prefetchAwsCredentialsAndBedRockInfoIfSafe,\n  prefetchGcpCredentialsIfSafe,\n  validateForceLoginOrg,\n} from './utils/auth.js'\nimport {\n  checkHasTrustDialogAccepted,\n  getGlobalConfig,\n  getRemoteControlAtStartup,\n  isAutoUpdaterDisabled,\n  saveGlobalConfig,\n} from './utils/config.js'\nimport { seedEarlyInput, stopCapturingEarlyInput } from './utils/earlyInput.js'\nimport { getInitialEffortSetting, parseEffortValue } from './utils/effort.js'\nimport {\n  getInitialFastModeSetting,\n  isFastModeEnabled,\n  prefetchFastModeStatus,\n  resolveFastModeStatusFromCache,\n} from './utils/fastMode.js'\nimport { applyConfigEnvironmentVariables } from './utils/managedEnv.js'\nimport { createSystemMessage, createUserMessage } from './utils/messages.js'\nimport { getPlatform } from './utils/platform.js'\nimport { getBaseRenderOptions } from './utils/renderOptions.js'\nimport { getSessionIngressAuthToken } from './utils/sessionIngressAuth.js'\nimport { settingsChangeDetector } from './utils/settings/changeDetector.js'\nimport { skillChangeDetector } from './utils/skills/skillChangeDetector.js'\nimport { jsonParse, writeFileSync_DEPRECATED } from './utils/slowOperations.js'\nimport { computeInitialTeamContext } from './utils/swarm/reconnection.js'\nimport { initializeWarningHandler } from './utils/warningHandler.js'\nimport { isWorktreeModeEnabled } from './utils/worktreeModeEnabled.js'\n\n// Lazy require to avoid circular dependency: teammate.ts -> AppState.tsx -> ... -> main.tsx\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst getTeammateUtils = () =>\n  require('./utils/teammate.js') as typeof import('./utils/teammate.js')\nconst getTeammatePromptAddendum = () =>\n  require('./utils/swarm/teammatePromptAddendum.js') as typeof import('./utils/swarm/teammatePromptAddendum.js')\nconst getTeammateModeSnapshot = () =>\n  require('./utils/swarm/backends/teammateModeSnapshot.js') as typeof import('./utils/swarm/backends/teammateModeSnapshot.js')\n/* eslint-enable @typescript-eslint/no-require-imports */\n// Dead code elimination: conditional import for COORDINATOR_MODE\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst coordinatorModeModule = feature('COORDINATOR_MODE')\n  ? (require('./coordinator/coordinatorMode.js') as typeof import('./coordinator/coordinatorMode.js'))\n  : null\n/* eslint-enable @typescript-eslint/no-require-imports */\n// Dead code elimination: conditional import for KAIROS (assistant mode)\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst assistantModule = feature('KAIROS')\n  ? (require('./assistant/index.js') as typeof import('./assistant/index.js'))\n  : null\nconst kairosGate = feature('KAIROS')\n  ? (require('./assistant/gate.js') as typeof import('./assistant/gate.js'))\n  : null\n\nimport { relative, resolve } from 'path'\nimport { isAnalyticsDisabled } from 'src/services/analytics/config.js'\nimport { getFeatureValue_CACHED_MAY_BE_STALE } from 'src/services/analytics/growthbook.js'\nimport {\n  type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  logEvent,\n} from 'src/services/analytics/index.js'\nimport { initializeAnalyticsGates } from 'src/services/analytics/sink.js'\nimport {\n  getOriginalCwd,\n  setAdditionalDirectoriesForClaudeMd,\n  setIsRemoteMode,\n  setMainLoopModelOverride,\n  setMainThreadAgentType,\n  setTeleportedSessionInfo,\n} from './bootstrap/state.js'\nimport { filterCommandsForRemoteMode, getCommands } from './commands.js'\nimport type { StatsStore } from './context/stats.js'\nimport {\n  launchAssistantInstallWizard,\n  launchAssistantSessionChooser,\n  launchInvalidSettingsDialog,\n  launchResumeChooser,\n  launchSnapshotUpdateDialog,\n  launchTeleportRepoMismatchDialog,\n  launchTeleportResumeWrapper,\n} from './dialogLaunchers.js'\nimport { SHOW_CURSOR } from './ink/termio/dec.js'\nimport {\n  exitWithError,\n  exitWithMessage,\n  getRenderContext,\n  renderAndRun,\n  showSetupScreens,\n} from './interactiveHelpers.js'\nimport { initBuiltinPlugins } from './plugins/bundled/index.js'\n/* eslint-enable @typescript-eslint/no-require-imports */\nimport { checkQuotaStatus } from './services/claudeAiLimits.js'\nimport {\n  getMcpToolsCommandsAndResources,\n  prefetchAllMcpResources,\n} from './services/mcp/client.js'\nimport {\n  VALID_INSTALLABLE_SCOPES,\n  VALID_UPDATE_SCOPES,\n} from './services/plugins/pluginCliCommands.js'\nimport { initBundledSkills } from './skills/bundled/index.js'\nimport type { AgentColorName } from './tools/AgentTool/agentColorManager.js'\nimport {\n  getActiveAgentsFromList,\n  getAgentDefinitionsWithOverrides,\n  isBuiltInAgent,\n  isCustomAgent,\n  parseAgentsFromJson,\n} from './tools/AgentTool/loadAgentsDir.js'\nimport type { LogOption } from './types/logs.js'\nimport type { Message as MessageType } from './types/message.js'\nimport { assertMinVersion } from './utils/autoUpdater.js'\nimport {\n  CLAUDE_IN_CHROME_SKILL_HINT,\n  CLAUDE_IN_CHROME_SKILL_HINT_WITH_WEBBROWSER,\n} from './utils/claudeInChrome/prompt.js'\nimport {\n  setupClaudeInChrome,\n  shouldAutoEnableClaudeInChrome,\n  shouldEnableClaudeInChrome,\n} from './utils/claudeInChrome/setup.js'\nimport { getContextWindowForModel } from './utils/context.js'\nimport { loadConversationForResume } from './utils/conversationRecovery.js'\nimport { buildDeepLinkBanner } from './utils/deepLink/banner.js'\nimport {\n  hasNodeOption,\n  isBareMode,\n  isEnvTruthy,\n  isInProtectedNamespace,\n} from './utils/envUtils.js'\nimport { refreshExampleCommands } from './utils/exampleCommands.js'\nimport type { FpsMetrics } from './utils/fpsTracker.js'\nimport { getWorktreePaths } from './utils/getWorktreePaths.js'\nimport {\n  findGitRoot,\n  getBranch,\n  getIsGit,\n  getWorktreeCount,\n} from './utils/git.js'\nimport { getGhAuthStatus } from './utils/github/ghAuthStatus.js'\nimport { safeParseJSON } from './utils/json.js'\nimport { logError } from './utils/log.js'\nimport { getModelDeprecationWarning } from './utils/model/deprecation.js'\nimport {\n  getDefaultMainLoopModel,\n  getUserSpecifiedModelSetting,\n  normalizeModelStringForAPI,\n  parseUserSpecifiedModel,\n} from './utils/model/model.js'\nimport { ensureModelStringsInitialized } from './utils/model/modelStrings.js'\nimport { PERMISSION_MODES } from './utils/permissions/PermissionMode.js'\nimport {\n  checkAndDisableBypassPermissions,\n  getAutoModeEnabledStateIfCached,\n  initializeToolPermissionContext,\n  initialPermissionModeFromCLI,\n  isDefaultPermissionModeAuto,\n  parseToolListFromCLI,\n  removeDangerousPermissions,\n  stripDangerousPermissionsForAutoMode,\n  verifyAutoModeGateAccess,\n} from './utils/permissions/permissionSetup.js'\nimport { cleanupOrphanedPluginVersionsInBackground } from './utils/plugins/cacheUtils.js'\nimport { initializeVersionedPlugins } from './utils/plugins/installedPluginsManager.js'\nimport { getManagedPluginNames } from './utils/plugins/managedPlugins.js'\nimport { getGlobExclusionsForPluginCache } from './utils/plugins/orphanedPluginFilter.js'\nimport { getPluginSeedDirs } from './utils/plugins/pluginDirectories.js'\nimport { countFilesRoundedRg } from './utils/ripgrep.js'\nimport {\n  processSessionStartHooks,\n  processSetupHooks,\n} from './utils/sessionStart.js'\nimport {\n  cacheSessionTitle,\n  getSessionIdFromLog,\n  loadTranscriptFromFile,\n  saveAgentSetting,\n  saveMode,\n  searchSessionsByCustomTitle,\n  sessionIdExists,\n} from './utils/sessionStorage.js'\nimport { ensureMdmSettingsLoaded } from './utils/settings/mdm/settings.js'\nimport {\n  getInitialSettings,\n  getManagedSettingsKeysForLogging,\n  getSettingsForSource,\n  getSettingsWithErrors,\n} from './utils/settings/settings.js'\nimport { resetSettingsCache } from './utils/settings/settingsCache.js'\nimport type { ValidationError } from './utils/settings/validation.js'\nimport {\n  DEFAULT_TASKS_MODE_TASK_LIST_ID,\n  TASK_STATUSES,\n} from './utils/tasks.js'\nimport {\n  logPluginLoadErrors,\n  logPluginsEnabledForSession,\n} from './utils/telemetry/pluginTelemetry.js'\nimport { logSkillsLoaded } from './utils/telemetry/skillLoadedEvent.js'\nimport { generateTempFilePath } from './utils/tempfile.js'\nimport { validateUuid } from './utils/uuid.js'\n// Plugin startup checks are now handled non-blockingly in REPL.tsx\n\nimport { registerMcpAddCommand } from 'src/commands/mcp/addCommand.js'\nimport { registerMcpXaaIdpCommand } from 'src/commands/mcp/xaaIdpCommand.js'\nimport { logPermissionContextForAnts } from 'src/services/internalLogging.js'\nimport { fetchClaudeAIMcpConfigsIfEligible } from 'src/services/mcp/claudeai.js'\nimport { clearServerCache } from 'src/services/mcp/client.js'\nimport {\n  areMcpConfigsAllowedWithEnterpriseMcpConfig,\n  dedupClaudeAiMcpServers,\n  doesEnterpriseMcpConfigExist,\n  filterMcpServersByPolicy,\n  getClaudeCodeMcpConfigs,\n  getMcpServerSignature,\n  parseMcpConfig,\n  parseMcpConfigFromFilePath,\n} from 'src/services/mcp/config.js'\nimport {\n  excludeCommandsByServer,\n  excludeResourcesByServer,\n} from 'src/services/mcp/utils.js'\nimport { isXaaEnabled } from 'src/services/mcp/xaaIdpLogin.js'\nimport { getRelevantTips } from 'src/services/tips/tipRegistry.js'\nimport { logContextMetrics } from 'src/utils/api.js'\nimport {\n  CLAUDE_IN_CHROME_MCP_SERVER_NAME,\n  isClaudeInChromeMCPServer,\n} from 'src/utils/claudeInChrome/common.js'\nimport { registerCleanup } from 'src/utils/cleanupRegistry.js'\nimport { eagerParseCliFlag } from 'src/utils/cliArgs.js'\nimport { createEmptyAttributionState } from 'src/utils/commitAttribution.js'\nimport {\n  countConcurrentSessions,\n  registerSession,\n  updateSessionName,\n} from 'src/utils/concurrentSessions.js'\nimport { getCwd } from 'src/utils/cwd.js'\nimport { logForDebugging, setHasFormattedOutput } from 'src/utils/debug.js'\nimport {\n  errorMessage,\n  getErrnoCode,\n  isENOENT,\n  TeleportOperationError,\n  toError,\n} from 'src/utils/errors.js'\nimport { getFsImplementation, safeResolvePath } from 'src/utils/fsOperations.js'\nimport {\n  gracefulShutdown,\n  gracefulShutdownSync,\n} from 'src/utils/gracefulShutdown.js'\nimport { setAllHookEventsEnabled } from 'src/utils/hooks/hookEvents.js'\nimport { refreshModelCapabilities } from 'src/utils/model/modelCapabilities.js'\nimport { peekForStdinData, writeToStderr } from 'src/utils/process.js'\nimport { setCwd } from 'src/utils/Shell.js'\nimport {\n  type ProcessedResume,\n  processResumedConversation,\n} from 'src/utils/sessionRestore.js'\nimport { parseSettingSourcesFlag } from 'src/utils/settings/constants.js'\nimport { plural } from 'src/utils/stringUtils.js'\nimport {\n  type ChannelEntry,\n  getInitialMainLoopModel,\n  getIsNonInteractiveSession,\n  getSdkBetas,\n  getSessionId,\n  getUserMsgOptIn,\n  setAllowedChannels,\n  setAllowedSettingSources,\n  setChromeFlagOverride,\n  setClientType,\n  setCwdState,\n  setDirectConnectServerUrl,\n  setFlagSettingsPath,\n  setInitialMainLoopModel,\n  setInlinePlugins,\n  setIsInteractive,\n  setKairosActive,\n  setOriginalCwd,\n  setQuestionPreviewFormat,\n  setSdkBetas,\n  setSessionBypassPermissionsMode,\n  setSessionPersistenceDisabled,\n  setSessionSource,\n  setUserMsgOptIn,\n  switchSession,\n} from './bootstrap/state.js'\n\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst autoModeStateModule = feature('TRANSCRIPT_CLASSIFIER')\n  ? (require('./utils/permissions/autoModeState.js') as typeof import('./utils/permissions/autoModeState.js'))\n  : null\n\n// TeleportRepoMismatchDialog, TeleportResumeWrapper dynamically imported at call sites\nimport { migrateAutoUpdatesToSettings } from './migrations/migrateAutoUpdatesToSettings.js'\nimport { migrateBypassPermissionsAcceptedToSettings } from './migrations/migrateBypassPermissionsAcceptedToSettings.js'\nimport { migrateEnableAllProjectMcpServersToSettings } from './migrations/migrateEnableAllProjectMcpServersToSettings.js'\nimport { migrateFennecToOpus } from './migrations/migrateFennecToOpus.js'\nimport { migrateLegacyOpusToCurrent } from './migrations/migrateLegacyOpusToCurrent.js'\nimport { migrateOpusToOpus1m } from './migrations/migrateOpusToOpus1m.js'\nimport { migrateReplBridgeEnabledToRemoteControlAtStartup } from './migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.js'\nimport { migrateSonnet1mToSonnet45 } from './migrations/migrateSonnet1mToSonnet45.js'\nimport { migrateSonnet45ToSonnet46 } from './migrations/migrateSonnet45ToSonnet46.js'\nimport { resetAutoModeOptInForDefaultOffer } from './migrations/resetAutoModeOptInForDefaultOffer.js'\nimport { resetProToOpusDefault } from './migrations/resetProToOpusDefault.js'\nimport { createRemoteSessionConfig } from './remote/RemoteSessionManager.js'\n/* eslint-enable @typescript-eslint/no-require-imports */\n// teleportWithProgress dynamically imported at call site\nimport {\n  createDirectConnectSession,\n  DirectConnectError,\n} from './server/createDirectConnectSession.js'\nimport { initializeLspServerManager } from './services/lsp/manager.js'\nimport { shouldEnablePromptSuggestion } from './services/PromptSuggestion/promptSuggestion.js'\nimport {\n  type AppState,\n  getDefaultAppState,\n  IDLE_SPECULATION_STATE,\n} from './state/AppStateStore.js'\nimport { onChangeAppState } from './state/onChangeAppState.js'\nimport { createStore } from './state/store.js'\nimport { asSessionId } from './types/ids.js'\nimport { filterAllowedSdkBetas } from './utils/betas.js'\nimport { isInBundledMode, isRunningWithBun } from './utils/bundledMode.js'\nimport { logForDiagnosticsNoPII } from './utils/diagLogs.js'\nimport {\n  filterExistingPaths,\n  getKnownPathsForRepo,\n} from './utils/githubRepoPathMapping.js'\nimport {\n  clearPluginCache,\n  loadAllPluginsCacheOnly,\n} from './utils/plugins/pluginLoader.js'\nimport { migrateChangelogFromConfig } from './utils/releaseNotes.js'\nimport { SandboxManager } from './utils/sandbox/sandbox-adapter.js'\nimport { fetchSession, prepareApiRequest } from './utils/teleport/api.js'\nimport {\n  checkOutTeleportedSessionBranch,\n  processMessagesForTeleportResume,\n  teleportToRemoteWithErrorHandling,\n  validateGitState,\n  validateSessionRepository,\n} from './utils/teleport.js'\nimport {\n  shouldEnableThinkingByDefault,\n  type ThinkingConfig,\n} from './utils/thinking.js'\nimport { initUser, resetUserCache } from './utils/user.js'\nimport {\n  getTmuxInstallInstructions,\n  isTmuxAvailable,\n  parsePRReference,\n} from './utils/worktree.js'\n\n// eslint-disable-next-line custom-rules/no-top-level-side-effects\nprofileCheckpoint('main_tsx_imports_loaded')\n\n/**\n * Log managed settings keys to Statsig for analytics.\n * This is called after init() completes to ensure settings are loaded\n * and environment variables are applied before model resolution.\n */\nfunction logManagedSettings(): void {\n  try {\n    const policySettings = getSettingsForSource('policySettings')\n    if (policySettings) {\n      const allKeys = getManagedSettingsKeysForLogging(policySettings)\n      logEvent('tengu_managed_settings_loaded', {\n        keyCount: allKeys.length,\n        keys: allKeys.join(\n          ',',\n        ) as unknown as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      })\n    }\n  } catch {\n    // Silently ignore errors - this is just for analytics\n  }\n}\n\n// Check if running in debug/inspection mode\nfunction isBeingDebugged() {\n  const isBun = isRunningWithBun()\n\n  // Check for inspect flags in process arguments (including all variants)\n  const hasInspectArg = process.execArgv.some(arg => {\n    if (isBun) {\n      // Note: Bun has an issue with single-file executables where application arguments\n      // from process.argv leak into process.execArgv (similar to https://github.com/oven-sh/bun/issues/11673)\n      // This breaks use of --debug mode if we omit this branch\n      // We're fine to skip that check, because Bun doesn't support Node.js legacy --debug or --debug-brk flags\n      return /--inspect(-brk)?/.test(arg)\n    } else {\n      // In Node.js, check for both --inspect and legacy --debug flags\n      return /--inspect(-brk)?|--debug(-brk)?/.test(arg)\n    }\n  })\n\n  // Check if NODE_OPTIONS contains inspect flags\n  const hasInspectEnv =\n    process.env.NODE_OPTIONS &&\n    /--inspect(-brk)?|--debug(-brk)?/.test(process.env.NODE_OPTIONS)\n\n  // Check if inspector is available and active (indicates debugging)\n  try {\n    // Dynamic import would be better but is async - use global object instead\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const inspector = (global as any).require('inspector')\n    const hasInspectorUrl = !!inspector.url()\n    return hasInspectorUrl || hasInspectArg || hasInspectEnv\n  } catch {\n    // Ignore error and fall back to argument detection\n    return hasInspectArg || hasInspectEnv\n  }\n}\n\n// Exit if we detect node debugging or inspection\nif (\"external\" !== 'ant' && isBeingDebugged()) {\n  // Use process.exit directly here since we're in the top-level code before imports\n  // and gracefulShutdown is not yet available\n  // eslint-disable-next-line custom-rules/no-top-level-side-effects\n  process.exit(1)\n}\n\n/**\n * Per-session skill/plugin telemetry. Called from both the interactive path\n * and the headless -p path (before runHeadless) — both go through\n * main.tsx but branch before the interactive startup path, so it needs two\n * call sites here rather than one here + one in QueryEngine.\n */\nfunction logSessionTelemetry(): void {\n  const model = parseUserSpecifiedModel(\n    getInitialMainLoopModel() ?? getDefaultMainLoopModel(),\n  )\n  void logSkillsLoaded(getCwd(), getContextWindowForModel(model, getSdkBetas()))\n  void loadAllPluginsCacheOnly()\n    .then(({ enabled, errors }) => {\n      const managedNames = getManagedPluginNames()\n      logPluginsEnabledForSession(enabled, managedNames, getPluginSeedDirs())\n      logPluginLoadErrors(errors, managedNames)\n    })\n    .catch(err => logError(err))\n}\n\nfunction getCertEnvVarTelemetry(): Record<string, boolean> {\n  const result: Record<string, boolean> = {}\n  if (process.env.NODE_EXTRA_CA_CERTS) {\n    result.has_node_extra_ca_certs = true\n  }\n  if (process.env.CLAUDE_CODE_CLIENT_CERT) {\n    result.has_client_cert = true\n  }\n  if (hasNodeOption('--use-system-ca')) {\n    result.has_use_system_ca = true\n  }\n  if (hasNodeOption('--use-openssl-ca')) {\n    result.has_use_openssl_ca = true\n  }\n  return result\n}\n\nasync function logStartupTelemetry(): Promise<void> {\n  if (isAnalyticsDisabled()) return\n  const [isGit, worktreeCount, ghAuthStatus] = await Promise.all([\n    getIsGit(),\n    getWorktreeCount(),\n    getGhAuthStatus(),\n  ])\n\n  logEvent('tengu_startup_telemetry', {\n    is_git: isGit,\n    worktree_count: worktreeCount,\n    gh_auth_status:\n      ghAuthStatus as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n    sandbox_enabled: SandboxManager.isSandboxingEnabled(),\n    are_unsandboxed_commands_allowed:\n      SandboxManager.areUnsandboxedCommandsAllowed(),\n    is_auto_bash_allowed_if_sandbox_enabled:\n      SandboxManager.isAutoAllowBashIfSandboxedEnabled(),\n    auto_updater_disabled: isAutoUpdaterDisabled(),\n    prefers_reduced_motion: getInitialSettings().prefersReducedMotion ?? false,\n    ...getCertEnvVarTelemetry(),\n  })\n}\n\n// @[MODEL LAUNCH]: Consider any migrations you may need for model strings. See migrateSonnet1mToSonnet45.ts for an example.\n// Bump this when adding a new sync migration so existing users re-run the set.\nconst CURRENT_MIGRATION_VERSION = 11\nfunction runMigrations(): void {\n  if (getGlobalConfig().migrationVersion !== CURRENT_MIGRATION_VERSION) {\n    migrateAutoUpdatesToSettings()\n    migrateBypassPermissionsAcceptedToSettings()\n    migrateEnableAllProjectMcpServersToSettings()\n    resetProToOpusDefault()\n    migrateSonnet1mToSonnet45()\n    migrateLegacyOpusToCurrent()\n    migrateSonnet45ToSonnet46()\n    migrateOpusToOpus1m()\n    migrateReplBridgeEnabledToRemoteControlAtStartup()\n    if (feature('TRANSCRIPT_CLASSIFIER')) {\n      resetAutoModeOptInForDefaultOffer()\n    }\n    if (\"external\" === 'ant') {\n      migrateFennecToOpus()\n    }\n    saveGlobalConfig(prev =>\n      prev.migrationVersion === CURRENT_MIGRATION_VERSION\n        ? prev\n        : { ...prev, migrationVersion: CURRENT_MIGRATION_VERSION },\n    )\n  }\n  // Async migration - fire and forget since it's non-blocking\n  migrateChangelogFromConfig().catch(() => {\n    // Silently ignore migration errors - will retry on next startup\n  })\n}\n\n/**\n * Prefetch system context (including git status) only when it's safe to do so.\n * Git commands can execute arbitrary code via hooks and config (e.g., core.fsmonitor,\n * diff.external), so we must only run them after trust is established or in\n * non-interactive mode where trust is implicit.\n */\nfunction prefetchSystemContextIfSafe(): void {\n  const isNonInteractiveSession = getIsNonInteractiveSession()\n\n  // In non-interactive mode (--print), trust dialog is skipped and\n  // execution is considered trusted (as documented in help text)\n  if (isNonInteractiveSession) {\n    logForDiagnosticsNoPII('info', 'prefetch_system_context_non_interactive')\n    void getSystemContext()\n    return\n  }\n\n  // In interactive mode, only prefetch if trust has already been established\n  const hasTrust = checkHasTrustDialogAccepted()\n  if (hasTrust) {\n    logForDiagnosticsNoPII('info', 'prefetch_system_context_has_trust')\n    void getSystemContext()\n  } else {\n    logForDiagnosticsNoPII('info', 'prefetch_system_context_skipped_no_trust')\n  }\n  // Otherwise, don't prefetch - wait for trust to be established first\n}\n\n/**\n * Start background prefetches and housekeeping that are NOT needed before first render.\n * These are deferred from setup() to reduce event loop contention and child process\n * spawning during the critical startup path.\n * Call this after the REPL has been rendered.\n */\nexport function startDeferredPrefetches(): void {\n  // This function runs after first render, so it doesn't block the initial paint.\n  // However, the spawned processes and async work still contend for CPU and event\n  // loop time, which skews startup benchmarks (CPU profiles, time-to-first-render\n  // measurements). Skip all of it when we're only measuring startup performance.\n  if (\n    isEnvTruthy(process.env.CLAUDE_CODE_EXIT_AFTER_FIRST_RENDER) ||\n    // --bare: skip ALL prefetches. These are cache-warms for the REPL's\n    // first-turn responsiveness (initUser, getUserContext, tips, countFiles,\n    // modelCapabilities, change detectors). Scripted -p calls don't have a\n    // \"user is typing\" window to hide this work in — it's pure overhead on\n    // the critical path.\n    isBareMode()\n  ) {\n    return\n  }\n\n  // Process-spawning prefetches (consumed at first API call, user is still typing)\n  void initUser()\n  void getUserContext()\n  prefetchSystemContextIfSafe()\n  void getRelevantTips()\n  if (\n    isEnvTruthy(process.env.CLAUDE_CODE_USE_BEDROCK) &&\n    !isEnvTruthy(process.env.CLAUDE_CODE_SKIP_BEDROCK_AUTH)\n  ) {\n    void prefetchAwsCredentialsAndBedRockInfoIfSafe()\n  }\n  if (\n    isEnvTruthy(process.env.CLAUDE_CODE_USE_VERTEX) &&\n    !isEnvTruthy(process.env.CLAUDE_CODE_SKIP_VERTEX_AUTH)\n  ) {\n    void prefetchGcpCredentialsIfSafe()\n  }\n  void countFilesRoundedRg(getCwd(), AbortSignal.timeout(3000), [])\n\n  // Analytics and feature flag initialization\n  void initializeAnalyticsGates()\n  void prefetchOfficialMcpUrls()\n\n  void refreshModelCapabilities()\n\n  // File change detectors deferred from init() to unblock first render\n  void settingsChangeDetector.initialize()\n  if (!isBareMode()) {\n    void skillChangeDetector.initialize()\n  }\n\n  // Event loop stall detector — logs when the main thread is blocked >500ms\n  if (\"external\" === 'ant') {\n    void import('./utils/eventLoopStallDetector.js').then(m =>\n      m.startEventLoopStallDetector(),\n    )\n  }\n}\n\nfunction loadSettingsFromFlag(settingsFile: string): void {\n  try {\n    const trimmedSettings = settingsFile.trim()\n    const looksLikeJson =\n      trimmedSettings.startsWith('{') && trimmedSettings.endsWith('}')\n\n    let settingsPath: string\n\n    if (looksLikeJson) {\n      // It's a JSON string - validate and create temp file\n      const parsedJson = safeParseJSON(trimmedSettings)\n      if (!parsedJson) {\n        process.stderr.write(\n          chalk.red('Error: Invalid JSON provided to --settings\\n'),\n        )\n        process.exit(1)\n      }\n\n      // Create a temporary file and write the JSON to it.\n      // Use a content-hash-based path instead of random UUID to avoid\n      // busting the Anthropic API prompt cache. The settings path ends up\n      // in the Bash tool's sandbox denyWithinAllow list, which is part of\n      // the tool description sent to the API. A random UUID per subprocess\n      // changes the tool description on every query() call, invalidating\n      // the cache prefix and causing a 12x input token cost penalty.\n      // The content hash ensures identical settings produce the same path\n      // across process boundaries (each SDK query() spawns a new process).\n      settingsPath = generateTempFilePath('claude-settings', '.json', {\n        contentHash: trimmedSettings,\n      })\n      writeFileSync_DEPRECATED(settingsPath, trimmedSettings, 'utf8')\n    } else {\n      // It's a file path - resolve and validate by attempting to read\n      const { resolvedPath: resolvedSettingsPath } = safeResolvePath(\n        getFsImplementation(),\n        settingsFile,\n      )\n      try {\n        readFileSync(resolvedSettingsPath, 'utf8')\n      } catch (e) {\n        if (isENOENT(e)) {\n          process.stderr.write(\n            chalk.red(\n              `Error: Settings file not found: ${resolvedSettingsPath}\\n`,\n            ),\n          )\n          process.exit(1)\n        }\n        throw e\n      }\n      settingsPath = resolvedSettingsPath\n    }\n\n    setFlagSettingsPath(settingsPath)\n    resetSettingsCache()\n  } catch (error) {\n    if (error instanceof Error) {\n      logError(error)\n    }\n    process.stderr.write(\n      chalk.red(`Error processing settings: ${errorMessage(error)}\\n`),\n    )\n    process.exit(1)\n  }\n}\n\nfunction loadSettingSourcesFromFlag(settingSourcesArg: string): void {\n  try {\n    const sources = parseSettingSourcesFlag(settingSourcesArg)\n    setAllowedSettingSources(sources)\n    resetSettingsCache()\n  } catch (error) {\n    if (error instanceof Error) {\n      logError(error)\n    }\n    process.stderr.write(\n      chalk.red(`Error processing --setting-sources: ${errorMessage(error)}\\n`),\n    )\n    process.exit(1)\n  }\n}\n\n/**\n * Parse and load settings flags early, before init()\n * This ensures settings are filtered from the start of initialization\n */\nfunction eagerLoadSettings(): void {\n  profileCheckpoint('eagerLoadSettings_start')\n  // Parse --settings flag early to ensure settings are loaded before init()\n  const settingsFile = eagerParseCliFlag('--settings')\n  if (settingsFile) {\n    loadSettingsFromFlag(settingsFile)\n  }\n\n  // Parse --setting-sources flag early to control which sources are loaded\n  const settingSourcesArg = eagerParseCliFlag('--setting-sources')\n  if (settingSourcesArg !== undefined) {\n    loadSettingSourcesFromFlag(settingSourcesArg)\n  }\n  profileCheckpoint('eagerLoadSettings_end')\n}\n\nfunction initializeEntrypoint(isNonInteractive: boolean): void {\n  // Skip if already set (e.g., by SDK or other entrypoints)\n  if (process.env.CLAUDE_CODE_ENTRYPOINT) {\n    return\n  }\n\n  const cliArgs = process.argv.slice(2)\n\n  // Check for MCP serve command (handle flags before mcp serve, e.g., --debug mcp serve)\n  const mcpIndex = cliArgs.indexOf('mcp')\n  if (mcpIndex !== -1 && cliArgs[mcpIndex + 1] === 'serve') {\n    process.env.CLAUDE_CODE_ENTRYPOINT = 'mcp'\n    return\n  }\n\n  if (isEnvTruthy(process.env.CLAUDE_CODE_ACTION)) {\n    process.env.CLAUDE_CODE_ENTRYPOINT = 'claude-code-github-action'\n    return\n  }\n\n  // Note: 'local-agent' entrypoint is set by the local agent mode launcher\n  // via CLAUDE_CODE_ENTRYPOINT env var (handled by early return above)\n\n  // Set based on interactive status\n  process.env.CLAUDE_CODE_ENTRYPOINT = isNonInteractive ? 'sdk-cli' : 'cli'\n}\n\n// Set by early argv processing when `claude open <url>` is detected (interactive mode only)\ntype PendingConnect = {\n  url: string | undefined\n  authToken: string | undefined\n  dangerouslySkipPermissions: boolean\n}\nconst _pendingConnect: PendingConnect | undefined = feature('DIRECT_CONNECT')\n  ? { url: undefined, authToken: undefined, dangerouslySkipPermissions: false }\n  : undefined\n\n// Set by early argv processing when `claude assistant [sessionId]` is detected\ntype PendingAssistantChat = { sessionId?: string; discover: boolean }\nconst _pendingAssistantChat: PendingAssistantChat | undefined = feature(\n  'KAIROS',\n)\n  ? { sessionId: undefined, discover: false }\n  : undefined\n\n// `claude ssh <host> [dir]` — parsed from argv early (same pattern as\n// DIRECT_CONNECT above) so the main command path can pick it up and hand\n// the REPL an SSH-backed session instead of a local one.\ntype PendingSSH = {\n  host: string | undefined\n  cwd: string | undefined\n  permissionMode: string | undefined\n  dangerouslySkipPermissions: boolean\n  /** --local: spawn the child CLI directly, skip ssh/probe/deploy. e2e test mode. */\n  local: boolean\n  /** Extra CLI args to forward to the remote CLI on initial spawn (--resume, -c). */\n  extraCliArgs: string[]\n}\nconst _pendingSSH: PendingSSH | undefined = feature('SSH_REMOTE')\n  ? {\n      host: undefined,\n      cwd: undefined,\n      permissionMode: undefined,\n      dangerouslySkipPermissions: false,\n      local: false,\n      extraCliArgs: [],\n    }\n  : undefined\n\nexport async function main() {\n  profileCheckpoint('main_function_start')\n\n  // SECURITY: Prevent Windows from executing commands from current directory\n  // This must be set before ANY command execution to prevent PATH hijacking attacks\n  // See: https://docs.microsoft.com/en-us/windows/win32/api/processenv/nf-processenv-searchpathw\n  process.env.NoDefaultCurrentDirectoryInExePath = '1'\n\n  // Initialize warning handler early to catch warnings\n  initializeWarningHandler()\n\n  process.on('exit', () => {\n    resetCursor()\n  })\n  process.on('SIGINT', () => {\n    // In print mode, print.ts registers its own SIGINT handler that aborts\n    // the in-flight query and calls gracefulShutdown; skip here to avoid\n    // preempting it with a synchronous process.exit().\n    if (process.argv.includes('-p') || process.argv.includes('--print')) {\n      return\n    }\n    process.exit(0)\n  })\n  profileCheckpoint('main_warning_handler_initialized')\n\n  // Check for cc:// or cc+unix:// URL in argv — rewrite so the main command\n  // handles it, giving the full interactive TUI instead of a stripped-down subcommand.\n  // For headless (-p), we rewrite to the internal `open` subcommand.\n  if (feature('DIRECT_CONNECT')) {\n    const rawCliArgs = process.argv.slice(2)\n    const ccIdx = rawCliArgs.findIndex(\n      a => a.startsWith('cc://') || a.startsWith('cc+unix://'),\n    )\n    if (ccIdx !== -1 && _pendingConnect) {\n      const ccUrl = rawCliArgs[ccIdx]!\n      const { parseConnectUrl } = await import('./server/parseConnectUrl.js')\n      const parsed = parseConnectUrl(ccUrl)\n      _pendingConnect.dangerouslySkipPermissions = rawCliArgs.includes(\n        '--dangerously-skip-permissions',\n      )\n\n      if (rawCliArgs.includes('-p') || rawCliArgs.includes('--print')) {\n        // Headless: rewrite to internal `open` subcommand\n        const stripped = rawCliArgs.filter((_, i) => i !== ccIdx)\n        const dspIdx = stripped.indexOf('--dangerously-skip-permissions')\n        if (dspIdx !== -1) {\n          stripped.splice(dspIdx, 1)\n        }\n        process.argv = [\n          process.argv[0]!,\n          process.argv[1]!,\n          'open',\n          ccUrl,\n          ...stripped,\n        ]\n      } else {\n        // Interactive: strip cc:// URL and flags, run main command\n        _pendingConnect.url = parsed.serverUrl\n        _pendingConnect.authToken = parsed.authToken\n        const stripped = rawCliArgs.filter((_, i) => i !== ccIdx)\n        const dspIdx = stripped.indexOf('--dangerously-skip-permissions')\n        if (dspIdx !== -1) {\n          stripped.splice(dspIdx, 1)\n        }\n        process.argv = [process.argv[0]!, process.argv[1]!, ...stripped]\n      }\n    }\n  }\n\n  // Handle deep link URIs early — this is invoked by the OS protocol handler\n  // and should bail out before full init since it only needs to parse the URI\n  // and open a terminal.\n  if (feature('LODESTONE')) {\n    const handleUriIdx = process.argv.indexOf('--handle-uri')\n    if (handleUriIdx !== -1 && process.argv[handleUriIdx + 1]) {\n      const { enableConfigs } = await import('./utils/config.js')\n      enableConfigs()\n      const uri = process.argv[handleUriIdx + 1]!\n      const { handleDeepLinkUri } = await import(\n        './utils/deepLink/protocolHandler.js'\n      )\n      const exitCode = await handleDeepLinkUri(uri)\n      process.exit(exitCode)\n    }\n\n    // macOS URL handler: when LaunchServices launches our .app bundle, the\n    // URL arrives via Apple Event (not argv). LaunchServices overwrites\n    // __CFBundleIdentifier to the launching bundle's ID, which is a precise\n    // positive signal — cheaper than importing and guessing with heuristics.\n    if (\n      process.platform === 'darwin' &&\n      process.env.__CFBundleIdentifier ===\n        'com.anthropic.claude-code-url-handler'\n    ) {\n      const { enableConfigs } = await import('./utils/config.js')\n      enableConfigs()\n      const { handleUrlSchemeLaunch } = await import(\n        './utils/deepLink/protocolHandler.js'\n      )\n      const urlSchemeResult = await handleUrlSchemeLaunch()\n      process.exit(urlSchemeResult ?? 1)\n    }\n  }\n\n  // `claude assistant [sessionId]` — stash and strip so the main\n  // command handles it, giving the full interactive TUI. Position-0 only\n  // (matching the ssh pattern below) — indexOf would false-positive on\n  // `claude -p \"explain assistant\"`. Root-flag-before-subcommand\n  // (e.g. `--debug assistant`) falls through to the stub, which\n  // prints usage.\n  if (feature('KAIROS') && _pendingAssistantChat) {\n    const rawArgs = process.argv.slice(2)\n    if (rawArgs[0] === 'assistant') {\n      const nextArg = rawArgs[1]\n      if (nextArg && !nextArg.startsWith('-')) {\n        _pendingAssistantChat.sessionId = nextArg\n        rawArgs.splice(0, 2) // drop 'assistant' and sessionId\n        process.argv = [process.argv[0]!, process.argv[1]!, ...rawArgs]\n      } else if (!nextArg) {\n        _pendingAssistantChat.discover = true\n        rawArgs.splice(0, 1) // drop 'assistant'\n        process.argv = [process.argv[0]!, process.argv[1]!, ...rawArgs]\n      }\n      // else: `claude assistant --help` → fall through to stub\n    }\n  }\n\n  // `claude ssh <host> [dir]` — strip from argv so the main command handler\n  // runs (full interactive TUI), stash the host/dir for the REPL branch at\n  // ~line 3720 to pick up. Headless (-p) mode not supported in v1: SSH\n  // sessions need the local REPL to drive them (interrupt, permissions).\n  if (feature('SSH_REMOTE') && _pendingSSH) {\n    const rawCliArgs = process.argv.slice(2)\n    // SSH-specific flags can appear before the host positional (e.g.\n    // `ssh --permission-mode auto host /tmp` — standard POSIX flags-before-\n    // positionals). Pull them all out BEFORE checking whether a host was\n    // given, so `claude ssh --permission-mode auto host` and `claude ssh host\n    // --permission-mode auto` are equivalent. The host check below only needs\n    // to guard against `-h`/`--help` (which commander should handle).\n    if (rawCliArgs[0] === 'ssh') {\n      const localIdx = rawCliArgs.indexOf('--local')\n      if (localIdx !== -1) {\n        _pendingSSH.local = true\n        rawCliArgs.splice(localIdx, 1)\n      }\n      const dspIdx = rawCliArgs.indexOf('--dangerously-skip-permissions')\n      if (dspIdx !== -1) {\n        _pendingSSH.dangerouslySkipPermissions = true\n        rawCliArgs.splice(dspIdx, 1)\n      }\n      const pmIdx = rawCliArgs.indexOf('--permission-mode')\n      if (\n        pmIdx !== -1 &&\n        rawCliArgs[pmIdx + 1] &&\n        !rawCliArgs[pmIdx + 1]!.startsWith('-')\n      ) {\n        _pendingSSH.permissionMode = rawCliArgs[pmIdx + 1]\n        rawCliArgs.splice(pmIdx, 2)\n      }\n      const pmEqIdx = rawCliArgs.findIndex(a =>\n        a.startsWith('--permission-mode='),\n      )\n      if (pmEqIdx !== -1) {\n        _pendingSSH.permissionMode = rawCliArgs[pmEqIdx]!.split('=')[1]\n        rawCliArgs.splice(pmEqIdx, 1)\n      }\n      // Forward session-resume + model flags to the remote CLI's initial spawn.\n      // --continue/-c and --resume <uuid> operate on the REMOTE session history\n      // (which persists under the remote's ~/.claude/projects/<cwd>/).\n      // --model controls which model the remote uses.\n      const extractFlag = (\n        flag: string,\n        opts: { hasValue?: boolean; as?: string } = {},\n      ) => {\n        const i = rawCliArgs.indexOf(flag)\n        if (i !== -1) {\n          _pendingSSH.extraCliArgs.push(opts.as ?? flag)\n          const val = rawCliArgs[i + 1]\n          if (opts.hasValue && val && !val.startsWith('-')) {\n            _pendingSSH.extraCliArgs.push(val)\n            rawCliArgs.splice(i, 2)\n          } else {\n            rawCliArgs.splice(i, 1)\n          }\n        }\n        const eqI = rawCliArgs.findIndex(a => a.startsWith(`${flag}=`))\n        if (eqI !== -1) {\n          _pendingSSH.extraCliArgs.push(\n            opts.as ?? flag,\n            rawCliArgs[eqI]!.slice(flag.length + 1),\n          )\n          rawCliArgs.splice(eqI, 1)\n        }\n      }\n      extractFlag('-c', { as: '--continue' })\n      extractFlag('--continue')\n      extractFlag('--resume', { hasValue: true })\n      extractFlag('--model', { hasValue: true })\n    }\n    // After pre-extraction, any remaining dash-arg at [1] is either -h/--help\n    // (commander handles) or an unknown-to-ssh flag (fall through to commander\n    // so it surfaces a proper error). Only a non-dash arg is the host.\n    if (\n      rawCliArgs[0] === 'ssh' &&\n      rawCliArgs[1] &&\n      !rawCliArgs[1].startsWith('-')\n    ) {\n      _pendingSSH.host = rawCliArgs[1]\n      // Optional positional cwd.\n      let consumed = 2\n      if (rawCliArgs[2] && !rawCliArgs[2].startsWith('-')) {\n        _pendingSSH.cwd = rawCliArgs[2]\n        consumed = 3\n      }\n      const rest = rawCliArgs.slice(consumed)\n\n      // Headless (-p) mode is not supported with SSH in v1 — reject early\n      // so the flag doesn't silently cause local execution.\n      if (rest.includes('-p') || rest.includes('--print')) {\n        process.stderr.write(\n          'Error: headless (-p/--print) mode is not supported with claude ssh\\n',\n        )\n        gracefulShutdownSync(1)\n        return\n      }\n\n      // Rewrite argv so the main command sees remaining flags but not `ssh`.\n      process.argv = [process.argv[0]!, process.argv[1]!, ...rest]\n    }\n  }\n\n  // Check for -p/--print and --init-only flags early to set isInteractiveSession before init()\n  // This is needed because telemetry initialization calls auth functions that need this flag\n  const cliArgs = process.argv.slice(2)\n  const hasPrintFlag = cliArgs.includes('-p') || cliArgs.includes('--print')\n  const hasInitOnlyFlag = cliArgs.includes('--init-only')\n  const hasSdkUrl = cliArgs.some(arg => arg.startsWith('--sdk-url'))\n  const isNonInteractive =\n    hasPrintFlag || hasInitOnlyFlag || hasSdkUrl || !process.stdout.isTTY\n\n  // Stop capturing early input for non-interactive modes\n  if (isNonInteractive) {\n    stopCapturingEarlyInput()\n  }\n\n  // Set simplified tracking fields\n  const isInteractive = !isNonInteractive\n  setIsInteractive(isInteractive)\n\n  // Initialize entrypoint based on mode - needs to be set before any event is logged\n  initializeEntrypoint(isNonInteractive)\n\n  // Determine client type\n  const clientType = (() => {\n    if (isEnvTruthy(process.env.GITHUB_ACTIONS)) return 'github-action'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'sdk-ts') return 'sdk-typescript'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'sdk-py') return 'sdk-python'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'sdk-cli') return 'sdk-cli'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'claude-vscode')\n      return 'claude-vscode'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'local-agent')\n      return 'local-agent'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'claude-desktop')\n      return 'claude-desktop'\n\n    // Check if session-ingress token is provided (indicates remote session)\n    const hasSessionIngressToken =\n      process.env.CLAUDE_CODE_SESSION_ACCESS_TOKEN ||\n      process.env.CLAUDE_CODE_WEBSOCKET_AUTH_FILE_DESCRIPTOR\n    if (\n      process.env.CLAUDE_CODE_ENTRYPOINT === 'remote' ||\n      hasSessionIngressToken\n    ) {\n      return 'remote'\n    }\n\n    return 'cli'\n  })()\n  setClientType(clientType)\n\n  const previewFormat = process.env.CLAUDE_CODE_QUESTION_PREVIEW_FORMAT\n  if (previewFormat === 'markdown' || previewFormat === 'html') {\n    setQuestionPreviewFormat(previewFormat)\n  } else if (\n    !clientType.startsWith('sdk-') &&\n    // Desktop and CCR pass previewFormat via toolConfig; when the feature is\n    // gated off they pass undefined — don't override that with markdown.\n    clientType !== 'claude-desktop' &&\n    clientType !== 'local-agent' &&\n    clientType !== 'remote'\n  ) {\n    setQuestionPreviewFormat('markdown')\n  }\n\n  // Tag sessions created via `claude remote-control` so the backend can identify them\n  if (process.env.CLAUDE_CODE_ENVIRONMENT_KIND === 'bridge') {\n    setSessionSource('remote-control')\n  }\n\n  profileCheckpoint('main_client_type_determined')\n\n  // Parse and load settings flags early, before init()\n  eagerLoadSettings()\n\n  profileCheckpoint('main_before_run')\n\n  await run()\n  profileCheckpoint('main_after_run')\n}\n\nasync function getInputPrompt(\n  prompt: string,\n  inputFormat: 'text' | 'stream-json',\n): Promise<string | AsyncIterable<string>> {\n  if (\n    !process.stdin.isTTY &&\n    // Input hijacking breaks MCP.\n    !process.argv.includes('mcp')\n  ) {\n    if (inputFormat === 'stream-json') {\n      return process.stdin\n    }\n    process.stdin.setEncoding('utf8')\n    let data = ''\n    const onData = (chunk: string) => {\n      data += chunk\n    }\n    process.stdin.on('data', onData)\n    // If no data arrives in 3s, stop waiting and warn. Stdin is likely an\n    // inherited pipe from a parent that isn't writing (subprocess spawned\n    // without explicit stdin handling). 3s covers slow producers like curl,\n    // jq on large files, python with import overhead. The warning makes\n    // silent data loss visible for the rare producer that's slower still.\n    const timedOut = await peekForStdinData(process.stdin, 3000)\n    process.stdin.off('data', onData)\n    if (timedOut) {\n      process.stderr.write(\n        'Warning: no stdin data received in 3s, proceeding without it. ' +\n          'If piping from a slow command, redirect stdin explicitly: < /dev/null to skip, or wait longer.\\n',\n      )\n    }\n    return [prompt, data].filter(Boolean).join('\\n')\n  }\n  return prompt\n}\n\nasync function run(): Promise<CommanderCommand> {\n  profileCheckpoint('run_function_start')\n\n  // Create help config that sorts options by long option name.\n  // Commander supports compareOptions at runtime but @commander-js/extra-typings\n  // doesn't include it in the type definitions, so we use Object.assign to add it.\n  function createSortedHelpConfig(): {\n    sortSubcommands: true\n    sortOptions: true\n  } {\n    const getOptionSortKey = (opt: Option): string =>\n      opt.long?.replace(/^--/, '') ?? opt.short?.replace(/^-/, '') ?? ''\n    return Object.assign(\n      { sortSubcommands: true, sortOptions: true } as const,\n      {\n        compareOptions: (a: Option, b: Option) =>\n          getOptionSortKey(a).localeCompare(getOptionSortKey(b)),\n      },\n    )\n  }\n  const program = new CommanderCommand()\n    .configureHelp(createSortedHelpConfig())\n    .enablePositionalOptions()\n  profileCheckpoint('run_commander_initialized')\n\n  // Use preAction hook to run initialization only when executing a command,\n  // not when displaying help. This avoids the need for env variable signaling.\n  program.hook('preAction', async thisCommand => {\n    profileCheckpoint('preAction_start')\n    // Await async subprocess loads started at module evaluation (lines 12-20).\n    // Nearly free — subprocesses complete during the ~135ms of imports above.\n    // Must resolve before init() which triggers the first settings read\n    // (applySafeConfigEnvironmentVariables → getSettingsForSource('policySettings')\n    // → isRemoteManagedSettingsEligible → sync keychain reads otherwise ~65ms).\n    await Promise.all([\n      ensureMdmSettingsLoaded(),\n      ensureKeychainPrefetchCompleted(),\n    ])\n    profileCheckpoint('preAction_after_mdm')\n    await init()\n    profileCheckpoint('preAction_after_init')\n\n    // process.title on Windows sets the console title directly; on POSIX,\n    // terminal shell integration may mirror the process name to the tab.\n    // After init() so settings.json env can also gate this (gh-4765).\n    if (!isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_TERMINAL_TITLE)) {\n      process.title = 'claude'\n    }\n\n    // Attach logging sinks so subcommand handlers can use logEvent/logError.\n    // Before PR #11106 logEvent dispatched directly; after, events queue until\n    // a sink attaches. setup() attaches sinks for the default command, but\n    // subcommands (doctor, mcp, plugin, auth) never call setup() and would\n    // silently drop events on process.exit(). Both inits are idempotent.\n    const { initSinks } = await import('./utils/sinks.js')\n    initSinks()\n    profileCheckpoint('preAction_after_sinks')\n\n    // gh-33508: --plugin-dir is a top-level program option. The default\n    // action reads it from its own options destructure, but subcommands\n    // (plugin list, plugin install, mcp *) have their own actions and\n    // never see it. Wire it up here so getInlinePlugins() works everywhere.\n    // thisCommand.opts() is typed {} here because this hook is attached\n    // before .option('--plugin-dir', ...) in the chain — extra-typings\n    // builds the type as options are added. Narrow with a runtime guard;\n    // the collect accumulator + [] default guarantee string[] in practice.\n    const pluginDir = thisCommand.getOptionValue('pluginDir')\n    if (\n      Array.isArray(pluginDir) &&\n      pluginDir.length > 0 &&\n      pluginDir.every(p => typeof p === 'string')\n    ) {\n      setInlinePlugins(pluginDir)\n      clearPluginCache('preAction: --plugin-dir inline plugins')\n    }\n\n    runMigrations()\n    profileCheckpoint('preAction_after_migrations')\n\n    // Load remote managed settings for enterprise customers (non-blocking)\n    // Fails open - if fetch fails, continues without remote settings\n    // Settings are applied via hot-reload when they arrive\n    // Must happen after init() to ensure config reading is allowed\n    void loadRemoteManagedSettings()\n    void loadPolicyLimits()\n\n    profileCheckpoint('preAction_after_remote_settings')\n\n    // Load settings sync (non-blocking, fail-open)\n    // CLI: uploads local settings to remote (CCR download is handled by print.ts)\n    if (feature('UPLOAD_USER_SETTINGS')) {\n      void import('./services/settingsSync/index.js').then(m =>\n        m.uploadUserSettingsInBackground(),\n      )\n    }\n\n    profileCheckpoint('preAction_after_settings_sync')\n  })\n\n  program\n    .name('claude')\n    .description(\n      `Claude Code - starts an interactive session by default, use -p/--print for non-interactive output`,\n    )\n    .argument('[prompt]', 'Your prompt', String)\n    // Subcommands inherit helpOption via commander's copyInheritedSettings —\n    // setting it once here covers mcp, plugin, auth, and all other subcommands.\n    .helpOption('-h, --help', 'Display help for command')\n    .option(\n      '-d, --debug [filter]',\n      'Enable debug mode with optional category filtering (e.g., \"api,hooks\" or \"!1p,!file\")',\n      (_value: string | true) => {\n        // If value is provided, it will be the filter string\n        // If not provided but flag is present, value will be true\n        // The actual filtering is handled in debug.ts by parsing process.argv\n        return true\n      },\n    )\n    .addOption(\n      new Option('-d2e, --debug-to-stderr', 'Enable debug mode (to stderr)')\n        .argParser(Boolean)\n        .hideHelp(),\n    )\n    .option(\n      '--debug-file <path>',\n      'Write debug logs to a specific file path (implicitly enables debug mode)',\n      () => true,\n    )\n    .option(\n      '--verbose',\n      'Override verbose mode setting from config',\n      () => true,\n    )\n    .option(\n      '-p, --print',\n      'Print response and exit (useful for pipes). Note: The workspace trust dialog is skipped when Claude is run with the -p mode. Only use this flag in directories you trust.',\n      () => true,\n    )\n    .option(\n      '--bare',\n      'Minimal mode: skip hooks, LSP, plugin sync, attribution, auto-memory, background prefetches, keychain reads, and CLAUDE.md auto-discovery. Sets CLAUDE_CODE_SIMPLE=1. Anthropic auth is strictly ANTHROPIC_API_KEY or apiKeyHelper via --settings (OAuth and keychain are never read). 3P providers (Bedrock/Vertex/Foundry) use their own credentials. Skills still resolve via /skill-name. Explicitly provide context via: --system-prompt[-file], --append-system-prompt[-file], --add-dir (CLAUDE.md dirs), --mcp-config, --settings, --agents, --plugin-dir.',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--init',\n        'Run Setup hooks with init trigger, then continue',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--init-only',\n        'Run Setup and SessionStart:startup hooks, then exit',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--maintenance',\n        'Run Setup hooks with maintenance trigger, then continue',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--output-format <format>',\n        'Output format (only works with --print): \"text\" (default), \"json\" (single result), or \"stream-json\" (realtime streaming)',\n      ).choices(['text', 'json', 'stream-json']),\n    )\n    .addOption(\n      new Option(\n        '--json-schema <schema>',\n        'JSON Schema for structured output validation. ' +\n          'Example: {\"type\":\"object\",\"properties\":{\"name\":{\"type\":\"string\"}},\"required\":[\"name\"]}',\n      ).argParser(String),\n    )\n    .option(\n      '--include-hook-events',\n      'Include all hook lifecycle events in the output stream (only works with --output-format=stream-json)',\n      () => true,\n    )\n    .option(\n      '--include-partial-messages',\n      'Include partial message chunks as they arrive (only works with --print and --output-format=stream-json)',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--input-format <format>',\n        'Input format (only works with --print): \"text\" (default), or \"stream-json\" (realtime streaming input)',\n      ).choices(['text', 'stream-json']),\n    )\n    .option(\n      '--mcp-debug',\n      '[DEPRECATED. Use --debug instead] Enable MCP debug mode (shows MCP server errors)',\n      () => true,\n    )\n    .option(\n      '--dangerously-skip-permissions',\n      'Bypass all permission checks. Recommended only for sandboxes with no internet access.',\n      () => true,\n    )\n    .option(\n      '--allow-dangerously-skip-permissions',\n      'Enable bypassing all permission checks as an option, without it being enabled by default. Recommended only for sandboxes with no internet access.',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--thinking <mode>',\n        'Thinking mode: enabled (equivalent to adaptive), disabled',\n      )\n        .choices(['enabled', 'adaptive', 'disabled'])\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--max-thinking-tokens <tokens>',\n        '[DEPRECATED. Use --thinking instead for newer models] Maximum number of thinking tokens (only works with --print)',\n      )\n        .argParser(Number)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--max-turns <turns>',\n        'Maximum number of agentic turns in non-interactive mode. This will early exit the conversation after the specified number of turns. (only works with --print)',\n      )\n        .argParser(Number)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--max-budget-usd <amount>',\n        'Maximum dollar amount to spend on API calls (only works with --print)',\n      ).argParser(value => {\n        const amount = Number(value)\n        if (isNaN(amount) || amount <= 0) {\n          throw new Error(\n            '--max-budget-usd must be a positive number greater than 0',\n          )\n        }\n        return amount\n      }),\n    )\n    .addOption(\n      new Option(\n        '--task-budget <tokens>',\n        'API-side task budget in tokens (output_config.task_budget)',\n      )\n        .argParser(value => {\n          const tokens = Number(value)\n          if (isNaN(tokens) || tokens <= 0 || !Number.isInteger(tokens)) {\n            throw new Error('--task-budget must be a positive integer')\n          }\n          return tokens\n        })\n        .hideHelp(),\n    )\n    .option(\n      '--replay-user-messages',\n      'Re-emit user messages from stdin back on stdout for acknowledgment (only works with --input-format=stream-json and --output-format=stream-json)',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--enable-auth-status',\n        'Enable auth status messages in SDK mode',\n      )\n        .default(false)\n        .hideHelp(),\n    )\n    .option(\n      '--allowedTools, --allowed-tools <tools...>',\n      'Comma or space-separated list of tool names to allow (e.g. \"Bash(git:*) Edit\")',\n    )\n    .option(\n      '--tools <tools...>',\n      'Specify the list of available tools from the built-in set. Use \"\" to disable all tools, \"default\" to use all tools, or specify tool names (e.g. \"Bash,Edit,Read\").',\n    )\n    .option(\n      '--disallowedTools, --disallowed-tools <tools...>',\n      'Comma or space-separated list of tool names to deny (e.g. \"Bash(git:*) Edit\")',\n    )\n    .option(\n      '--mcp-config <configs...>',\n      'Load MCP servers from JSON files or strings (space-separated)',\n    )\n    .addOption(\n      new Option(\n        '--permission-prompt-tool <tool>',\n        'MCP tool to use for permission prompts (only works with --print)',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--system-prompt <prompt>',\n        'System prompt to use for the session',\n      ).argParser(String),\n    )\n    .addOption(\n      new Option(\n        '--system-prompt-file <file>',\n        'Read system prompt from a file',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--append-system-prompt <prompt>',\n        'Append a system prompt to the default system prompt',\n      ).argParser(String),\n    )\n    .addOption(\n      new Option(\n        '--append-system-prompt-file <file>',\n        'Read system prompt from a file and append to the default system prompt',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--permission-mode <mode>',\n        'Permission mode to use for the session',\n      )\n        .argParser(String)\n        .choices(PERMISSION_MODES),\n    )\n    .option(\n      '-c, --continue',\n      'Continue the most recent conversation in the current directory',\n      () => true,\n    )\n    .option(\n      '-r, --resume [value]',\n      'Resume a conversation by session ID, or open interactive picker with optional search term',\n      value => value || true,\n    )\n    .option(\n      '--fork-session',\n      'When resuming, create a new session ID instead of reusing the original (use with --resume or --continue)',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--prefill <text>',\n        'Pre-fill the prompt input with text without submitting it',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--deep-link-origin',\n        'Signal that this session was launched from a deep link',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--deep-link-repo <slug>',\n        'Repo slug the deep link ?repo= parameter resolved to the current cwd',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--deep-link-last-fetch <ms>',\n        'FETCH_HEAD mtime in epoch ms, precomputed by the deep link trampoline',\n      )\n        .argParser(v => {\n          const n = Number(v)\n          return Number.isFinite(n) ? n : undefined\n        })\n        .hideHelp(),\n    )\n    .option(\n      '--from-pr [value]',\n      'Resume a session linked to a PR by PR number/URL, or open interactive picker with optional search term',\n      value => value || true,\n    )\n    .option(\n      '--no-session-persistence',\n      'Disable session persistence - sessions will not be saved to disk and cannot be resumed (only works with --print)',\n    )\n    .addOption(\n      new Option(\n        '--resume-session-at <message id>',\n        'When resuming, only messages up to and including the assistant message with <message.id> (use with --resume in print mode)',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--rewind-files <user-message-id>',\n        'Restore files to state at the specified user message and exit (requires --resume)',\n      ).hideHelp(),\n    )\n    // @[MODEL LAUNCH]: Update the example model ID in the --model help text.\n    .option(\n      '--model <model>',\n      `Model for the current session. Provide an alias for the latest model (e.g. 'sonnet' or 'opus') or a model's full name (e.g. 'claude-sonnet-4-6').`,\n    )\n    .addOption(\n      new Option(\n        '--effort <level>',\n        `Effort level for the current session (low, medium, high, max)`,\n      ).argParser((rawValue: string) => {\n        const value = rawValue.toLowerCase()\n        const allowed = ['low', 'medium', 'high', 'max']\n        if (!allowed.includes(value)) {\n          throw new InvalidArgumentError(\n            `It must be one of: ${allowed.join(', ')}`,\n          )\n        }\n        return value\n      }),\n    )\n    .option(\n      '--agent <agent>',\n      `Agent for the current session. Overrides the 'agent' setting.`,\n    )\n    .option(\n      '--betas <betas...>',\n      'Beta headers to include in API requests (API key users only)',\n    )\n    .option(\n      '--fallback-model <model>',\n      'Enable automatic fallback to specified model when default model is overloaded (only works with --print)',\n    )\n    .addOption(\n      new Option(\n        '--workload <tag>',\n        'Workload tag for billing-header attribution (cc_workload). Process-scoped; set by SDK daemon callers that spawn subprocesses for cron work. (only works with --print)',\n      ).hideHelp(),\n    )\n    .option(\n      '--settings <file-or-json>',\n      'Path to a settings JSON file or a JSON string to load additional settings from',\n    )\n    .option(\n      '--add-dir <directories...>',\n      'Additional directories to allow tool access to',\n    )\n    .option(\n      '--ide',\n      'Automatically connect to IDE on startup if exactly one valid IDE is available',\n      () => true,\n    )\n    .option(\n      '--strict-mcp-config',\n      'Only use MCP servers from --mcp-config, ignoring all other MCP configurations',\n      () => true,\n    )\n    .option(\n      '--session-id <uuid>',\n      'Use a specific session ID for the conversation (must be a valid UUID)',\n    )\n    .option(\n      '-n, --name <name>',\n      'Set a display name for this session (shown in /resume and terminal title)',\n    )\n    .option(\n      '--agents <json>',\n      'JSON object defining custom agents (e.g. \\'{\"reviewer\": {\"description\": \"Reviews code\", \"prompt\": \"You are a code reviewer\"}}\\')',\n    )\n    .option(\n      '--setting-sources <sources>',\n      'Comma-separated list of setting sources to load (user, project, local).',\n    )\n    // gh-33508: <paths...> (variadic) consumed everything until the next\n    // --flag. `claude --plugin-dir /path mcp add --transport http` swallowed\n    // `mcp` and `add` as paths, then choked on --transport as an unknown\n    // top-level option. Single-value + collect accumulator means each\n    // --plugin-dir takes exactly one arg; repeat the flag for multiple dirs.\n    .option(\n      '--plugin-dir <path>',\n      'Load plugins from a directory for this session only (repeatable: --plugin-dir A --plugin-dir B)',\n      (val: string, prev: string[]) => [...prev, val],\n      [] as string[],\n    )\n    .option('--disable-slash-commands', 'Disable all skills', () => true)\n    .option('--chrome', 'Enable Claude in Chrome integration')\n    .option('--no-chrome', 'Disable Claude in Chrome integration')\n    .option(\n      '--file <specs...>',\n      'File resources to download at startup. Format: file_id:relative_path (e.g., --file file_abc:doc.txt file_def:img.png)',\n    )\n    .action(async (prompt, options) => {\n      profileCheckpoint('action_handler_start')\n\n      // --bare = one-switch minimal mode. Sets SIMPLE so all the existing\n      // gates fire (CLAUDE.md, skills, hooks inside executeHooks, agent\n      // dir-walk). Must be set before setup() / any of the gated work runs.\n      if ((options as { bare?: boolean }).bare) {\n        process.env.CLAUDE_CODE_SIMPLE = '1'\n      }\n\n      // Ignore \"code\" as a prompt - treat it the same as no prompt\n      if (prompt === 'code') {\n        logEvent('tengu_code_prompt_ignored', {})\n        // biome-ignore lint/suspicious/noConsole:: intentional console output\n        console.warn(\n          chalk.yellow('Tip: You can launch Claude Code with just `claude`'),\n        )\n        prompt = undefined\n      }\n\n      // Log event for any single-word prompt\n      if (\n        prompt &&\n        typeof prompt === 'string' &&\n        !/\\s/.test(prompt) &&\n        prompt.length > 0\n      ) {\n        logEvent('tengu_single_word_prompt', { length: prompt.length })\n      }\n\n      // Assistant mode: when .claude/settings.json has assistant: true AND\n      // the tengu_kairos GrowthBook gate is on, force brief on. Permission\n      // mode is left to the user — settings defaultMode or --permission-mode\n      // apply as normal. REPL-typed messages already default to 'next'\n      // priority (messageQueueManager.enqueue) so they drain mid-turn between\n      // tool calls. SendUserMessage (BriefTool) is enabled via the brief env\n      // var. SleepTool stays disabled (its isEnabled() gates on proactive).\n      // kairosEnabled is computed once here and reused at the\n      // getAssistantSystemPromptAddendum() call site further down.\n      //\n      // Trust gate: .claude/settings.json is attacker-controllable in an\n      // untrusted clone. We run ~1000 lines before showSetupScreens() shows\n      // the trust dialog, and by then we've already appended\n      // .claude/agents/assistant.md to the system prompt. Refuse to activate\n      // until the directory has been explicitly trusted.\n      let kairosEnabled = false\n      let assistantTeamContext:\n        | Awaited<\n            ReturnType<\n              NonNullable<typeof assistantModule>['initializeAssistantTeam']\n            >\n          >\n        | undefined\n      if (\n        feature('KAIROS') &&\n        (options as { assistant?: boolean }).assistant &&\n        assistantModule\n      ) {\n        // --assistant (Agent SDK daemon mode): force the latch before\n        // isAssistantMode() runs below. The daemon has already checked\n        // entitlement — don't make the child re-check tengu_kairos.\n        assistantModule.markAssistantForced()\n      }\n      if (\n        feature('KAIROS') &&\n        assistantModule?.isAssistantMode() &&\n        // Spawned teammates share the leader's cwd + settings.json, so\n        // isAssistantMode() is true for them too. --agent-id being set\n        // means we ARE a spawned teammate (extractTeammateOptions runs\n        // ~170 lines later so check the raw commander option) — don't\n        // re-init the team or override teammateMode/proactive/brief.\n        !(options as { agentId?: unknown }).agentId &&\n        kairosGate\n      ) {\n        if (!checkHasTrustDialogAccepted()) {\n          // biome-ignore lint/suspicious/noConsole:: intentional console output\n          console.warn(\n            chalk.yellow(\n              'Assistant mode disabled: directory is not trusted. Accept the trust dialog and restart.',\n            ),\n          )\n        } else {\n          // Blocking gate check — returns cached `true` instantly; if disk\n          // cache is false/missing, lazily inits GrowthBook and fetches fresh\n          // (max ~5s). --assistant skips the gate entirely (daemon is\n          // pre-entitled).\n          kairosEnabled =\n            assistantModule.isAssistantForced() ||\n            (await kairosGate.isKairosEnabled())\n          if (kairosEnabled) {\n            const opts = options as { brief?: boolean }\n            opts.brief = true\n            setKairosActive(true)\n            // Pre-seed an in-process team so Agent(name: \"foo\") spawns\n            // teammates without TeamCreate. Must run BEFORE setup() captures\n            // the teammateMode snapshot (initializeAssistantTeam calls\n            // setCliTeammateModeOverride internally).\n            assistantTeamContext =\n              await assistantModule.initializeAssistantTeam()\n          }\n        }\n      }\n\n      const {\n        debug = false,\n        debugToStderr = false,\n        dangerouslySkipPermissions,\n        allowDangerouslySkipPermissions = false,\n        tools: baseTools = [],\n        allowedTools = [],\n        disallowedTools = [],\n        mcpConfig = [],\n        permissionMode: permissionModeCli,\n        addDir = [],\n        fallbackModel,\n        betas = [],\n        ide = false,\n        sessionId,\n        includeHookEvents,\n        includePartialMessages,\n      } = options\n\n      if (options.prefill) {\n        seedEarlyInput(options.prefill)\n      }\n\n      // Promise for file downloads - started early, awaited before REPL renders\n      let fileDownloadPromise: Promise<DownloadResult[]> | undefined\n\n      const agentsJson = options.agents\n      const agentCli = options.agent\n      if (feature('BG_SESSIONS') && agentCli) {\n        process.env.CLAUDE_CODE_AGENT = agentCli\n      }\n\n      // NOTE: LSP manager initialization is intentionally deferred until after\n      // the trust dialog is accepted. This prevents plugin LSP servers from\n      // executing code in untrusted directories before user consent.\n\n      // Extract these separately so they can be modified if needed\n      let outputFormat = options.outputFormat\n      let inputFormat = options.inputFormat\n      let verbose = options.verbose ?? getGlobalConfig().verbose\n      let print = options.print\n      const init = options.init ?? false\n      const initOnly = options.initOnly ?? false\n      const maintenance = options.maintenance ?? false\n\n      // Extract disable slash commands flag\n      const disableSlashCommands = options.disableSlashCommands || false\n\n      // Extract tasks mode options (ant-only)\n      const tasksOption =\n        \"external\" === 'ant' &&\n        (options as { tasks?: boolean | string }).tasks\n      const taskListId = tasksOption\n        ? typeof tasksOption === 'string'\n          ? tasksOption\n          : DEFAULT_TASKS_MODE_TASK_LIST_ID\n        : undefined\n      if (\"external\" === 'ant' && taskListId) {\n        process.env.CLAUDE_CODE_TASK_LIST_ID = taskListId\n      }\n\n      // Extract worktree option\n      // worktree can be true (flag without value) or a string (custom name or PR reference)\n      const worktreeOption = isWorktreeModeEnabled()\n        ? (options as { worktree?: boolean | string }).worktree\n        : undefined\n      let worktreeName =\n        typeof worktreeOption === 'string' ? worktreeOption : undefined\n      const worktreeEnabled = worktreeOption !== undefined\n\n      // Check if worktree name is a PR reference (#N or GitHub PR URL)\n      let worktreePRNumber: number | undefined\n      if (worktreeName) {\n        const prNum = parsePRReference(worktreeName)\n        if (prNum !== null) {\n          worktreePRNumber = prNum\n          worktreeName = undefined // slug will be generated in setup()\n        }\n      }\n\n      // Extract tmux option (requires --worktree)\n      const tmuxEnabled =\n        isWorktreeModeEnabled() && (options as { tmux?: boolean }).tmux === true\n\n      // Validate tmux option\n      if (tmuxEnabled) {\n        if (!worktreeEnabled) {\n          process.stderr.write(chalk.red('Error: --tmux requires --worktree\\n'))\n          process.exit(1)\n        }\n        if (getPlatform() === 'windows') {\n          process.stderr.write(\n            chalk.red('Error: --tmux is not supported on Windows\\n'),\n          )\n          process.exit(1)\n        }\n        if (!(await isTmuxAvailable())) {\n          process.stderr.write(\n            chalk.red(\n              `Error: tmux is not installed.\\n${getTmuxInstallInstructions()}\\n`,\n            ),\n          )\n          process.exit(1)\n        }\n      }\n\n      // Extract teammate options (for tmux-spawned agents)\n      // Declared outside the if block so it's accessible later for system prompt addendum\n      let storedTeammateOpts: TeammateOptions | undefined\n      if (isAgentSwarmsEnabled()) {\n        // Extract agent identity options (for tmux-spawned agents)\n        // These replace the CLAUDE_CODE_* environment variables\n        const teammateOpts = extractTeammateOptions(options)\n        storedTeammateOpts = teammateOpts\n\n        // If any teammate identity option is provided, all three required ones must be present\n        const hasAnyTeammateOpt =\n          teammateOpts.agentId ||\n          teammateOpts.agentName ||\n          teammateOpts.teamName\n        const hasAllRequiredTeammateOpts =\n          teammateOpts.agentId &&\n          teammateOpts.agentName &&\n          teammateOpts.teamName\n\n        if (hasAnyTeammateOpt && !hasAllRequiredTeammateOpts) {\n          process.stderr.write(\n            chalk.red(\n              'Error: --agent-id, --agent-name, and --team-name must all be provided together\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        // If teammate identity is provided via CLI, set up dynamicTeamContext\n        if (\n          teammateOpts.agentId &&\n          teammateOpts.agentName &&\n          teammateOpts.teamName\n        ) {\n          getTeammateUtils().setDynamicTeamContext?.({\n            agentId: teammateOpts.agentId,\n            agentName: teammateOpts.agentName,\n            teamName: teammateOpts.teamName,\n            color: teammateOpts.agentColor,\n            planModeRequired: teammateOpts.planModeRequired ?? false,\n            parentSessionId: teammateOpts.parentSessionId,\n          })\n        }\n\n        // Set teammate mode CLI override if provided\n        // This must be done before setup() captures the snapshot\n        if (teammateOpts.teammateMode) {\n          getTeammateModeSnapshot().setCliTeammateModeOverride?.(\n            teammateOpts.teammateMode,\n          )\n        }\n      }\n\n      // Extract remote sdk options\n      const sdkUrl = (options as { sdkUrl?: string }).sdkUrl ?? undefined\n\n      // Allow env var to enable partial messages (used by sandbox gateway for baku)\n      const effectiveIncludePartialMessages =\n        includePartialMessages ||\n        isEnvTruthy(process.env.CLAUDE_CODE_INCLUDE_PARTIAL_MESSAGES)\n\n      // Enable all hook event types when explicitly requested via SDK option\n      // or when running in CLAUDE_CODE_REMOTE mode (CCR needs them).\n      // Without this, only SessionStart and Setup events are emitted.\n      if (includeHookEvents || isEnvTruthy(process.env.CLAUDE_CODE_REMOTE)) {\n        setAllHookEventsEnabled(true)\n      }\n\n      // Auto-set input/output formats, verbose mode, and print mode when SDK URL is provided\n      if (sdkUrl) {\n        // If SDK URL is provided, automatically use stream-json formats unless explicitly set\n        if (!inputFormat) {\n          inputFormat = 'stream-json'\n        }\n        if (!outputFormat) {\n          outputFormat = 'stream-json'\n        }\n        // Auto-enable verbose mode unless explicitly disabled or already set\n        if (options.verbose === undefined) {\n          verbose = true\n        }\n        // Auto-enable print mode unless explicitly disabled\n        if (!options.print) {\n          print = true\n        }\n      }\n\n      // Extract teleport option\n      const teleport =\n        (options as { teleport?: string | true }).teleport ?? null\n\n      // Extract remote option (can be true if no description provided, or a string)\n      const remoteOption = (options as { remote?: string | true }).remote\n      const remote = remoteOption === true ? '' : (remoteOption ?? null)\n\n      // Extract --remote-control / --rc flag (enable bridge in interactive session)\n      const remoteControlOption =\n        (options as { remoteControl?: string | true }).remoteControl ??\n        (options as { rc?: string | true }).rc\n      // Actual bridge check is deferred to after showSetupScreens() so that\n      // trust is established and GrowthBook has auth headers.\n      let remoteControl = false\n      const remoteControlName =\n        typeof remoteControlOption === 'string' &&\n        remoteControlOption.length > 0\n          ? remoteControlOption\n          : undefined\n\n      // Validate session ID if provided\n      if (sessionId) {\n        // Check for conflicting flags\n        // --session-id can be used with --continue or --resume when --fork-session is also provided\n        // (to specify a custom ID for the forked session)\n        if ((options.continue || options.resume) && !options.forkSession) {\n          process.stderr.write(\n            chalk.red(\n              'Error: --session-id can only be used with --continue or --resume if --fork-session is also specified.\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        // When --sdk-url is provided (bridge/remote mode), the session ID is a\n        // server-assigned tagged ID (e.g. \"session_local_01...\") rather than a\n        // UUID. Skip UUID validation and local existence checks in that case.\n        if (!sdkUrl) {\n          const validatedSessionId = validateUuid(sessionId)\n          if (!validatedSessionId) {\n            process.stderr.write(\n              chalk.red('Error: Invalid session ID. Must be a valid UUID.\\n'),\n            )\n            process.exit(1)\n          }\n\n          // Check if session ID already exists\n          if (sessionIdExists(validatedSessionId)) {\n            process.stderr.write(\n              chalk.red(\n                `Error: Session ID ${validatedSessionId} is already in use.\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n        }\n      }\n\n      // Download file resources if specified via --file flag\n      const fileSpecs = (options as { file?: string[] }).file\n      if (fileSpecs && fileSpecs.length > 0) {\n        // Get session ingress token (provided by EnvManager via CLAUDE_CODE_SESSION_ACCESS_TOKEN)\n        const sessionToken = getSessionIngressAuthToken()\n        if (!sessionToken) {\n          process.stderr.write(\n            chalk.red(\n              'Error: Session token required for file downloads. CLAUDE_CODE_SESSION_ACCESS_TOKEN must be set.\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        // Resolve session ID: prefer remote session ID, fall back to internal session ID\n        const fileSessionId =\n          process.env.CLAUDE_CODE_REMOTE_SESSION_ID || getSessionId()\n\n        const files = parseFileSpecs(fileSpecs)\n        if (files.length > 0) {\n          // Use ANTHROPIC_BASE_URL if set (by EnvManager), otherwise use OAuth config\n          // This ensures consistency with session ingress API in all environments\n          const config: FilesApiConfig = {\n            baseUrl:\n              process.env.ANTHROPIC_BASE_URL || getOauthConfig().BASE_API_URL,\n            oauthToken: sessionToken,\n            sessionId: fileSessionId,\n          }\n\n          // Start download without blocking startup - await before REPL renders\n          fileDownloadPromise = downloadSessionFiles(files, config)\n        }\n      }\n\n      // Get isNonInteractiveSession from state (was set before init())\n      const isNonInteractiveSession = getIsNonInteractiveSession()\n\n      // Validate that fallback model is different from main model\n      if (fallbackModel && options.model && fallbackModel === options.model) {\n        process.stderr.write(\n          chalk.red(\n            'Error: Fallback model cannot be the same as the main model. Please specify a different model for --fallback-model.\\n',\n          ),\n        )\n        process.exit(1)\n      }\n\n      // Handle system prompt options\n      let systemPrompt = options.systemPrompt\n      if (options.systemPromptFile) {\n        if (options.systemPrompt) {\n          process.stderr.write(\n            chalk.red(\n              'Error: Cannot use both --system-prompt and --system-prompt-file. Please use only one.\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        try {\n          const filePath = resolve(options.systemPromptFile)\n          systemPrompt = readFileSync(filePath, 'utf8')\n        } catch (error) {\n          const code = getErrnoCode(error)\n          if (code === 'ENOENT') {\n            process.stderr.write(\n              chalk.red(\n                `Error: System prompt file not found: ${resolve(options.systemPromptFile)}\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n          process.stderr.write(\n            chalk.red(\n              `Error reading system prompt file: ${errorMessage(error)}\\n`,\n            ),\n          )\n          process.exit(1)\n        }\n      }\n\n      // Handle append system prompt options\n      let appendSystemPrompt = options.appendSystemPrompt\n      if (options.appendSystemPromptFile) {\n        if (options.appendSystemPrompt) {\n          process.stderr.write(\n            chalk.red(\n              'Error: Cannot use both --append-system-prompt and --append-system-prompt-file. Please use only one.\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        try {\n          const filePath = resolve(options.appendSystemPromptFile)\n          appendSystemPrompt = readFileSync(filePath, 'utf8')\n        } catch (error) {\n          const code = getErrnoCode(error)\n          if (code === 'ENOENT') {\n            process.stderr.write(\n              chalk.red(\n                `Error: Append system prompt file not found: ${resolve(options.appendSystemPromptFile)}\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n          process.stderr.write(\n            chalk.red(\n              `Error reading append system prompt file: ${errorMessage(error)}\\n`,\n            ),\n          )\n          process.exit(1)\n        }\n      }\n\n      // Add teammate-specific system prompt addendum for tmux teammates\n      if (\n        isAgentSwarmsEnabled() &&\n        storedTeammateOpts?.agentId &&\n        storedTeammateOpts?.agentName &&\n        storedTeammateOpts?.teamName\n      ) {\n        const addendum =\n          getTeammatePromptAddendum().TEAMMATE_SYSTEM_PROMPT_ADDENDUM\n        appendSystemPrompt = appendSystemPrompt\n          ? `${appendSystemPrompt}\\n\\n${addendum}`\n          : addendum\n      }\n\n      const { mode: permissionMode, notification: permissionModeNotification } =\n        initialPermissionModeFromCLI({\n          permissionModeCli,\n          dangerouslySkipPermissions,\n        })\n\n      // Store session bypass permissions mode for trust dialog check\n      setSessionBypassPermissionsMode(permissionMode === 'bypassPermissions')\n      if (feature('TRANSCRIPT_CLASSIFIER')) {\n        // autoModeFlagCli is the \"did the user intend auto this session\" signal.\n        // Set when: --enable-auto-mode, --permission-mode auto, resolved mode\n        // is auto, OR settings defaultMode is auto but the gate denied it\n        // (permissionMode resolved to default with no explicit CLI override).\n        // Used by verifyAutoModeGateAccess to decide whether to notify on\n        // auto-unavailable, and by tengu_auto_mode_config opt-in carousel.\n        if (\n          (options as { enableAutoMode?: boolean }).enableAutoMode ||\n          permissionModeCli === 'auto' ||\n          permissionMode === 'auto' ||\n          (!permissionModeCli && isDefaultPermissionModeAuto())\n        ) {\n          autoModeStateModule?.setAutoModeFlagCli(true)\n        }\n      }\n\n      // Parse the MCP config files/strings if provided\n      let dynamicMcpConfig: Record<string, ScopedMcpServerConfig> = {}\n\n      if (mcpConfig && mcpConfig.length > 0) {\n        // Process mcpConfig array\n        const processedConfigs = mcpConfig\n          .map(config => config.trim())\n          .filter(config => config.length > 0)\n\n        let allConfigs: Record<string, McpServerConfig> = {}\n        const allErrors: ValidationError[] = []\n\n        for (const configItem of processedConfigs) {\n          let configs: Record<string, McpServerConfig> | null = null\n          let errors: ValidationError[] = []\n\n          // First try to parse as JSON string\n          const parsedJson = safeParseJSON(configItem)\n          if (parsedJson) {\n            const result = parseMcpConfig({\n              configObject: parsedJson,\n              filePath: 'command line',\n              expandVars: true,\n              scope: 'dynamic',\n            })\n            if (result.config) {\n              configs = result.config.mcpServers\n            } else {\n              errors = result.errors\n            }\n          } else {\n            // Try as file path\n            const configPath = resolve(configItem)\n            const result = parseMcpConfigFromFilePath({\n              filePath: configPath,\n              expandVars: true,\n              scope: 'dynamic',\n            })\n            if (result.config) {\n              configs = result.config.mcpServers\n            } else {\n              errors = result.errors\n            }\n          }\n\n          if (errors.length > 0) {\n            allErrors.push(...errors)\n          } else if (configs) {\n            // Merge configs, later ones override earlier ones\n            allConfigs = { ...allConfigs, ...configs }\n          }\n        }\n\n        if (allErrors.length > 0) {\n          const formattedErrors = allErrors\n            .map(err => `${err.path ? err.path + ': ' : ''}${err.message}`)\n            .join('\\n')\n          logForDebugging(\n            `--mcp-config validation failed (${allErrors.length} errors): ${formattedErrors}`,\n            { level: 'error' },\n          )\n          process.stderr.write(\n            `Error: Invalid MCP configuration:\\n${formattedErrors}\\n`,\n          )\n          process.exit(1)\n        }\n\n        if (Object.keys(allConfigs).length > 0) {\n          // SDK hosts (Nest/Desktop) own their server naming and may reuse\n          // built-in names — skip reserved-name checks for type:'sdk'.\n          const nonSdkConfigNames = Object.entries(allConfigs)\n            .filter(([, config]) => config.type !== 'sdk')\n            .map(([name]) => name)\n\n          let reservedNameError: string | null = null\n          if (nonSdkConfigNames.some(isClaudeInChromeMCPServer)) {\n            reservedNameError = `Invalid MCP configuration: \"${CLAUDE_IN_CHROME_MCP_SERVER_NAME}\" is a reserved MCP name.`\n          } else if (feature('CHICAGO_MCP')) {\n            const { isComputerUseMCPServer, COMPUTER_USE_MCP_SERVER_NAME } =\n              await import('src/utils/computerUse/common.js')\n            if (nonSdkConfigNames.some(isComputerUseMCPServer)) {\n              reservedNameError = `Invalid MCP configuration: \"${COMPUTER_USE_MCP_SERVER_NAME}\" is a reserved MCP name.`\n            }\n          }\n          if (reservedNameError) {\n            // stderr+exit(1) — a throw here becomes a silent unhandled\n            // rejection in stream-json mode (void main() in cli.tsx).\n            process.stderr.write(`Error: ${reservedNameError}\\n`)\n            process.exit(1)\n          }\n\n          // Add dynamic scope to all configs. type:'sdk' entries pass through\n          // unchanged — they're extracted into sdkMcpConfigs downstream and\n          // passed to print.ts. The Python SDK relies on this path (it doesn't\n          // send sdkMcpServers in the initialize message). Dropping them here\n          // broke Coworker (inc-5122). The policy filter below already exempts\n          // type:'sdk', and the entries are inert without an SDK transport on\n          // stdin, so there's no bypass risk from letting them through.\n          const scopedConfigs = mapValues(allConfigs, config => ({\n            ...config,\n            scope: 'dynamic' as const,\n          }))\n\n          // Enforce managed policy (allowedMcpServers / deniedMcpServers) on\n          // --mcp-config servers. Without this, the CLI flag bypasses the\n          // enterprise allowlist that user/project/local configs go through in\n          // getClaudeCodeMcpConfigs — callers spread dynamicMcpConfig back on\n          // top of filtered results. Filter here at the source so all\n          // downstream consumers see the policy-filtered set.\n          const { allowed, blocked } = filterMcpServersByPolicy(scopedConfigs)\n          if (blocked.length > 0) {\n            process.stderr.write(\n              `Warning: MCP ${plural(blocked.length, 'server')} blocked by enterprise policy: ${blocked.join(', ')}\\n`,\n            )\n          }\n          dynamicMcpConfig = { ...dynamicMcpConfig, ...allowed }\n        }\n      }\n\n      // Extract Claude in Chrome option and enforce claude.ai subscriber check (unless user is ant)\n      const chromeOpts = options as { chrome?: boolean }\n      // Store the explicit CLI flag so teammates can inherit it\n      setChromeFlagOverride(chromeOpts.chrome)\n      const enableClaudeInChrome =\n        shouldEnableClaudeInChrome(chromeOpts.chrome) &&\n        (\"external\" === 'ant' || isClaudeAISubscriber())\n      const autoEnableClaudeInChrome =\n        !enableClaudeInChrome && shouldAutoEnableClaudeInChrome()\n\n      if (enableClaudeInChrome) {\n        const platform = getPlatform()\n        try {\n          logEvent('tengu_claude_in_chrome_setup', {\n            platform:\n              platform as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n\n          const {\n            mcpConfig: chromeMcpConfig,\n            allowedTools: chromeMcpTools,\n            systemPrompt: chromeSystemPrompt,\n          } = setupClaudeInChrome()\n          dynamicMcpConfig = { ...dynamicMcpConfig, ...chromeMcpConfig }\n          allowedTools.push(...chromeMcpTools)\n          if (chromeSystemPrompt) {\n            appendSystemPrompt = appendSystemPrompt\n              ? `${chromeSystemPrompt}\\n\\n${appendSystemPrompt}`\n              : chromeSystemPrompt\n          }\n        } catch (error) {\n          logEvent('tengu_claude_in_chrome_setup_failed', {\n            platform:\n              platform as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n          logForDebugging(`[Claude in Chrome] Error: ${error}`)\n          logError(error)\n          // biome-ignore lint/suspicious/noConsole:: intentional console output\n          console.error(`Error: Failed to run with Claude in Chrome.`)\n          process.exit(1)\n        }\n      } else if (autoEnableClaudeInChrome) {\n        try {\n          const { mcpConfig: chromeMcpConfig } = setupClaudeInChrome()\n          dynamicMcpConfig = { ...dynamicMcpConfig, ...chromeMcpConfig }\n\n          const hint =\n            feature('WEB_BROWSER_TOOL') &&\n            typeof Bun !== 'undefined' &&\n            'WebView' in Bun\n              ? CLAUDE_IN_CHROME_SKILL_HINT_WITH_WEBBROWSER\n              : CLAUDE_IN_CHROME_SKILL_HINT\n          appendSystemPrompt = appendSystemPrompt\n            ? `${appendSystemPrompt}\\n\\n${hint}`\n            : hint\n        } catch (error) {\n          // Silently skip any errors for the auto-enable\n          logForDebugging(`[Claude in Chrome] Error (auto-enable): ${error}`)\n        }\n      }\n\n      // Extract strict MCP config flag\n      const strictMcpConfig = options.strictMcpConfig || false\n\n      // Check if enterprise MCP configuration exists. When it does, only allow dynamic MCP\n      // configs that contain special server types (sdk)\n      if (doesEnterpriseMcpConfigExist()) {\n        if (strictMcpConfig) {\n          process.stderr.write(\n            chalk.red(\n              'You cannot use --strict-mcp-config when an enterprise MCP config is present',\n            ),\n          )\n          process.exit(1)\n        }\n\n        // For --mcp-config, allow if all servers are internal types (sdk)\n        if (\n          dynamicMcpConfig &&\n          !areMcpConfigsAllowedWithEnterpriseMcpConfig(dynamicMcpConfig)\n        ) {\n          process.stderr.write(\n            chalk.red(\n              'You cannot dynamically configure MCP servers when an enterprise MCP config is present',\n            ),\n          )\n          process.exit(1)\n        }\n      }\n\n      // chicago MCP: guarded Computer Use (app allowlist + frontmost gate +\n      // SCContentFilter screenshots). Ant-only, GrowthBook-gated — failures\n      // are silent (this is dogfooding). Platform + interactive checks inline\n      // so non-macOS / print-mode ants skip the heavy @ant/computer-use-mcp\n      // import entirely. gates.js is light (type-only package import).\n      //\n      // Placed AFTER the enterprise-MCP-config check: that check rejects any\n      // dynamicMcpConfig entry with `type !== 'sdk'`, and our config is\n      // `type: 'stdio'`. An enterprise-config ant with the GB gate on would\n      // otherwise process.exit(1). Chrome has the same latent issue but has\n      // shipped without incident; chicago places itself correctly.\n      if (\n        feature('CHICAGO_MCP') &&\n        getPlatform() === 'macos' &&\n        !getIsNonInteractiveSession()\n      ) {\n        try {\n          const { getChicagoEnabled } = await import(\n            'src/utils/computerUse/gates.js'\n          )\n          if (getChicagoEnabled()) {\n            const { setupComputerUseMCP } = await import(\n              'src/utils/computerUse/setup.js'\n            )\n            const { mcpConfig, allowedTools: cuTools } = setupComputerUseMCP()\n            dynamicMcpConfig = { ...dynamicMcpConfig, ...mcpConfig }\n            allowedTools.push(...cuTools)\n          }\n        } catch (error) {\n          logForDebugging(\n            `[Computer Use MCP] Setup failed: ${errorMessage(error)}`,\n          )\n        }\n      }\n\n      // Store additional directories for CLAUDE.md loading (controlled by env var)\n      setAdditionalDirectoriesForClaudeMd(addDir)\n\n      // Channel server allowlist from --channels flag — servers whose\n      // inbound push notifications should register this session. The option\n      // is added inside a feature() block so TS doesn't know about it\n      // on the options type — same pattern as --assistant at main.tsx:1824.\n      // devChannels is deferred: showSetupScreens shows a confirmation dialog\n      // and only appends to allowedChannels on accept.\n      let devChannels: ChannelEntry[] | undefined\n      if (feature('KAIROS') || feature('KAIROS_CHANNELS')) {\n        // Parse plugin:name@marketplace / server:Y tags into typed entries.\n        // Tag decides trust model downstream: plugin-kind hits marketplace\n        // verification + GrowthBook allowlist, server-kind always fails\n        // allowlist (schema is plugin-only) unless dev flag is set.\n        // Untagged or marketplace-less plugin entries are hard errors —\n        // silently not-matching in the gate would look like channels are\n        // \"on\" but nothing ever fires.\n        const parseChannelEntries = (\n          raw: string[],\n          flag: string,\n        ): ChannelEntry[] => {\n          const entries: ChannelEntry[] = []\n          const bad: string[] = []\n          for (const c of raw) {\n            if (c.startsWith('plugin:')) {\n              const rest = c.slice(7)\n              const at = rest.indexOf('@')\n              if (at <= 0 || at === rest.length - 1) {\n                bad.push(c)\n              } else {\n                entries.push({\n                  kind: 'plugin',\n                  name: rest.slice(0, at),\n                  marketplace: rest.slice(at + 1),\n                })\n              }\n            } else if (c.startsWith('server:') && c.length > 7) {\n              entries.push({ kind: 'server', name: c.slice(7) })\n            } else {\n              bad.push(c)\n            }\n          }\n          if (bad.length > 0) {\n            process.stderr.write(\n              chalk.red(\n                `${flag} entries must be tagged: ${bad.join(', ')}\\n` +\n                  `  plugin:<name>@<marketplace>  — plugin-provided channel (allowlist enforced)\\n` +\n                  `  server:<name>                — manually configured MCP server\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n          return entries\n        }\n\n        const channelOpts = options as {\n          channels?: string[]\n          dangerouslyLoadDevelopmentChannels?: string[]\n        }\n        const rawChannels = channelOpts.channels\n        const rawDev = channelOpts.dangerouslyLoadDevelopmentChannels\n        // Always parse + set. ChannelsNotice reads getAllowedChannels() and\n        // renders the appropriate branch (disabled/noAuth/policyBlocked/\n        // listening) in the startup screen. gateChannelServer() enforces.\n        // --channels works in both interactive and print/SDK modes; dev-channels\n        // stays interactive-only (requires a confirmation dialog).\n        let channelEntries: ChannelEntry[] = []\n        if (rawChannels && rawChannels.length > 0) {\n          channelEntries = parseChannelEntries(rawChannels, '--channels')\n          setAllowedChannels(channelEntries)\n        }\n        if (!isNonInteractiveSession) {\n          if (rawDev && rawDev.length > 0) {\n            devChannels = parseChannelEntries(\n              rawDev,\n              '--dangerously-load-development-channels',\n            )\n          }\n        }\n        // Flag-usage telemetry. Plugin identifiers are logged (same tier as\n        // tengu_plugin_installed — public-registry-style names); server-kind\n        // names are not (MCP-server-name tier, opt-in-only elsewhere).\n        // Per-server gate outcomes land in tengu_mcp_channel_gate once\n        // servers connect. Dev entries go through a confirmation dialog after\n        // this — dev_plugins captures what was typed, not what was accepted.\n        if (channelEntries.length > 0 || (devChannels?.length ?? 0) > 0) {\n          const joinPluginIds = (entries: ChannelEntry[]) => {\n            const ids = entries.flatMap(e =>\n              e.kind === 'plugin' ? [`${e.name}@${e.marketplace}`] : [],\n            )\n            return ids.length > 0\n              ? (ids\n                  .sort()\n                  .join(\n                    ',',\n                  ) as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS)\n              : undefined\n          }\n          logEvent('tengu_mcp_channel_flags', {\n            channels_count: channelEntries.length,\n            dev_count: devChannels?.length ?? 0,\n            plugins: joinPluginIds(channelEntries),\n            dev_plugins: joinPluginIds(devChannels ?? []),\n          })\n        }\n      }\n\n      // SDK opt-in for SendUserMessage via --tools. All sessions require\n      // explicit opt-in; listing it in --tools signals intent. Runs BEFORE\n      // initializeToolPermissionContext so getToolsForDefaultPreset() sees\n      // the tool as enabled when computing the base-tools disallow filter.\n      // Conditional require avoids leaking the tool-name string into\n      // external builds.\n      if (\n        (feature('KAIROS') || feature('KAIROS_BRIEF')) &&\n        baseTools.length > 0\n      ) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const { BRIEF_TOOL_NAME, LEGACY_BRIEF_TOOL_NAME } =\n          require('./tools/BriefTool/prompt.js') as typeof import('./tools/BriefTool/prompt.js')\n        const { isBriefEntitled } =\n          require('./tools/BriefTool/BriefTool.js') as typeof import('./tools/BriefTool/BriefTool.js')\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        const parsed = parseToolListFromCLI(baseTools)\n        if (\n          (parsed.includes(BRIEF_TOOL_NAME) ||\n            parsed.includes(LEGACY_BRIEF_TOOL_NAME)) &&\n          isBriefEntitled()\n        ) {\n          setUserMsgOptIn(true)\n        }\n      }\n\n      // This await replaces blocking existsSync/statSync calls that were already in\n      // the startup path. Wall-clock time is unchanged; we just yield to the event\n      // loop during the fs I/O instead of blocking it. See #19661.\n      const initResult = await initializeToolPermissionContext({\n        allowedToolsCli: allowedTools,\n        disallowedToolsCli: disallowedTools,\n        baseToolsCli: baseTools,\n        permissionMode,\n        allowDangerouslySkipPermissions,\n        addDirs: addDir,\n      })\n      let toolPermissionContext = initResult.toolPermissionContext\n      const { warnings, dangerousPermissions, overlyBroadBashPermissions } =\n        initResult\n\n      // Handle overly broad shell allow rules for ant users (Bash(*), PowerShell(*))\n      if (\n        \"external\" === 'ant' &&\n        overlyBroadBashPermissions.length > 0\n      ) {\n        for (const permission of overlyBroadBashPermissions) {\n          logForDebugging(\n            `Ignoring overly broad shell permission ${permission.ruleDisplay} from ${permission.sourceDisplay}`,\n          )\n        }\n        toolPermissionContext = removeDangerousPermissions(\n          toolPermissionContext,\n          overlyBroadBashPermissions,\n        )\n      }\n\n      if (feature('TRANSCRIPT_CLASSIFIER') && dangerousPermissions.length > 0) {\n        toolPermissionContext = stripDangerousPermissionsForAutoMode(\n          toolPermissionContext,\n        )\n      }\n\n      // Print any warnings from initialization\n      warnings.forEach(warning => {\n        // biome-ignore lint/suspicious/noConsole:: intentional console output\n        console.error(warning)\n      })\n\n      void assertMinVersion()\n\n      // claude.ai config fetch: -p mode only (interactive uses useManageMCPConnections\n      // two-phase loading). Kicked off here to overlap with setup(); awaited\n      // before runHeadless so single-turn -p sees connectors. Skipped under\n      // enterprise/strict MCP to preserve policy boundaries.\n      const claudeaiConfigPromise: Promise<\n        Record<string, ScopedMcpServerConfig>\n      > =\n        isNonInteractiveSession &&\n        !strictMcpConfig &&\n        !doesEnterpriseMcpConfigExist() &&\n        // --bare / SIMPLE: skip claude.ai proxy servers (datadog, Gmail,\n        // Slack, BigQuery, PubMed — 6-14s each to connect). Scripted calls\n        // that need MCP pass --mcp-config explicitly.\n        !isBareMode()\n          ? fetchClaudeAIMcpConfigsIfEligible().then(configs => {\n              const { allowed, blocked } = filterMcpServersByPolicy(configs)\n              if (blocked.length > 0) {\n                process.stderr.write(\n                  `Warning: claude.ai MCP ${plural(blocked.length, 'server')} blocked by enterprise policy: ${blocked.join(', ')}\\n`,\n                )\n              }\n              return allowed\n            })\n          : Promise.resolve({})\n\n      // Kick off MCP config loading early (safe - just reads files, no execution).\n      // Both interactive and -p use getClaudeCodeMcpConfigs (local file reads only).\n      // The local promise is awaited later (before prefetchAllMcpResources) to\n      // overlap config I/O with setup(), commands loading, and trust dialog.\n      logForDebugging('[STARTUP] Loading MCP configs...')\n      const mcpConfigStart = Date.now()\n      let mcpConfigResolvedMs: number | undefined\n      // --bare skips auto-discovered MCP (.mcp.json, user settings, plugins) —\n      // only explicit --mcp-config works. dynamicMcpConfig is spread onto\n      // allMcpConfigs downstream so it survives this skip.\n      const mcpConfigPromise = (\n        strictMcpConfig || isBareMode()\n          ? Promise.resolve({\n              servers: {} as Record<string, ScopedMcpServerConfig>,\n            })\n          : getClaudeCodeMcpConfigs(dynamicMcpConfig)\n      ).then(result => {\n        mcpConfigResolvedMs = Date.now() - mcpConfigStart\n        return result\n      })\n\n      // NOTE: We do NOT call prefetchAllMcpResources here - that's deferred until after trust dialog\n\n      if (\n        inputFormat &&\n        inputFormat !== 'text' &&\n        inputFormat !== 'stream-json'\n      ) {\n        // biome-ignore lint/suspicious/noConsole:: intentional console output\n        console.error(`Error: Invalid input format \"${inputFormat}\".`)\n        process.exit(1)\n      }\n      if (inputFormat === 'stream-json' && outputFormat !== 'stream-json') {\n        // biome-ignore lint/suspicious/noConsole:: intentional console output\n        console.error(\n          `Error: --input-format=stream-json requires output-format=stream-json.`,\n        )\n        process.exit(1)\n      }\n\n      // Validate sdkUrl is only used with appropriate formats (formats are auto-set above)\n      if (sdkUrl) {\n        if (inputFormat !== 'stream-json' || outputFormat !== 'stream-json') {\n          // biome-ignore lint/suspicious/noConsole:: intentional console output\n          console.error(\n            `Error: --sdk-url requires both --input-format=stream-json and --output-format=stream-json.`,\n          )\n          process.exit(1)\n        }\n      }\n\n      // Validate replayUserMessages is only used with stream-json formats\n      if (options.replayUserMessages) {\n        if (inputFormat !== 'stream-json' || outputFormat !== 'stream-json') {\n          // biome-ignore lint/suspicious/noConsole:: intentional console output\n          console.error(\n            `Error: --replay-user-messages requires both --input-format=stream-json and --output-format=stream-json.`,\n          )\n          process.exit(1)\n        }\n      }\n\n      // Validate includePartialMessages is only used with print mode and stream-json output\n      if (effectiveIncludePartialMessages) {\n        if (!isNonInteractiveSession || outputFormat !== 'stream-json') {\n          writeToStderr(\n            `Error: --include-partial-messages requires --print and --output-format=stream-json.`,\n          )\n          process.exit(1)\n        }\n      }\n\n      // Validate --no-session-persistence is only used with print mode\n      if (options.sessionPersistence === false && !isNonInteractiveSession) {\n        writeToStderr(\n          `Error: --no-session-persistence can only be used with --print mode.`,\n        )\n        process.exit(1)\n      }\n\n      const effectivePrompt = prompt || ''\n      let inputPrompt = await getInputPrompt(\n        effectivePrompt,\n        (inputFormat ?? 'text') as 'text' | 'stream-json',\n      )\n      profileCheckpoint('action_after_input_prompt')\n\n      // Activate proactive mode BEFORE getTools() so SleepTool.isEnabled()\n      // (which returns isProactiveActive()) passes and Sleep is included.\n      // The later REPL-path maybeActivateProactive() calls are idempotent.\n      maybeActivateProactive(options)\n\n      let tools = getTools(toolPermissionContext)\n\n      // Apply coordinator mode tool filtering for headless path\n      // (mirrors useMergedTools.ts filtering for REPL/interactive path)\n      if (\n        feature('COORDINATOR_MODE') &&\n        isEnvTruthy(process.env.CLAUDE_CODE_COORDINATOR_MODE)\n      ) {\n        const { applyCoordinatorToolFilter } = await import(\n          './utils/toolPool.js'\n        )\n        tools = applyCoordinatorToolFilter(tools)\n      }\n\n      profileCheckpoint('action_tools_loaded')\n\n      let jsonSchema: ToolInputJSONSchema | undefined\n      if (\n        isSyntheticOutputToolEnabled({ isNonInteractiveSession }) &&\n        options.jsonSchema\n      ) {\n        jsonSchema = jsonParse(options.jsonSchema) as ToolInputJSONSchema\n      }\n\n      if (jsonSchema) {\n        const syntheticOutputResult = createSyntheticOutputTool(jsonSchema)\n        if ('tool' in syntheticOutputResult) {\n          // Add SyntheticOutputTool to the tools array AFTER getTools() filtering.\n          // This tool is excluded from normal filtering (see tools.ts) because it's\n          // an implementation detail for structured output, not a user-controlled tool.\n          tools = [...tools, syntheticOutputResult.tool]\n\n          logEvent('tengu_structured_output_enabled', {\n            schema_property_count: Object.keys(\n              (jsonSchema.properties as Record<string, unknown>) || {},\n            )\n              .length as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n            has_required_fields: Boolean(\n              jsonSchema.required,\n            ) as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n        } else {\n          logEvent('tengu_structured_output_failure', {\n            error:\n              'Invalid JSON schema' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n        }\n      }\n\n      // IMPORTANT: setup() must be called before any other code that depends on the cwd or worktree setup\n      profileCheckpoint('action_before_setup')\n      logForDebugging('[STARTUP] Running setup()...')\n      const setupStart = Date.now()\n      const { setup } = await import('./setup.js')\n      const messagingSocketPath = feature('UDS_INBOX')\n        ? (options as { messagingSocketPath?: string }).messagingSocketPath\n        : undefined\n      // Parallelize setup() with commands+agents loading. setup()'s ~28ms is\n      // mostly startUdsMessaging (socket bind, ~20ms) — not disk-bound, so it\n      // doesn't contend with getCommands' file reads. Gated on !worktreeEnabled\n      // since --worktree makes setup() process.chdir() (setup.ts:203), and\n      // commands/agents need the post-chdir cwd.\n      const preSetupCwd = getCwd()\n      // Register bundled skills/plugins before kicking getCommands() — they're\n      // pure in-memory array pushes (<1ms, zero I/O) that getBundledSkills()\n      // reads synchronously. Previously ran inside setup() after ~20ms of\n      // await points, so the parallel getCommands() memoized an empty list.\n      if (process.env.CLAUDE_CODE_ENTRYPOINT !== 'local-agent') {\n        initBuiltinPlugins()\n        initBundledSkills()\n      }\n      const setupPromise = setup(\n        preSetupCwd,\n        permissionMode,\n        allowDangerouslySkipPermissions,\n        worktreeEnabled,\n        worktreeName,\n        tmuxEnabled,\n        sessionId ? validateUuid(sessionId) : undefined,\n        worktreePRNumber,\n        messagingSocketPath,\n      )\n      const commandsPromise = worktreeEnabled ? null : getCommands(preSetupCwd)\n      const agentDefsPromise = worktreeEnabled\n        ? null\n        : getAgentDefinitionsWithOverrides(preSetupCwd)\n      // Suppress transient unhandledRejection if these reject during the\n      // ~28ms setupPromise await before Promise.all joins them below.\n      commandsPromise?.catch(() => {})\n      agentDefsPromise?.catch(() => {})\n      await setupPromise\n      logForDebugging(\n        `[STARTUP] setup() completed in ${Date.now() - setupStart}ms`,\n      )\n      profileCheckpoint('action_after_setup')\n\n      // Replay user messages into stream-json only when the socket was\n      // explicitly requested. The auto-generated socket is passive — it\n      // lets tools inject if they want to, but turning it on by default\n      // shouldn't reshape stream-json for SDK consumers who never touch it.\n      // Callers who inject and also want those injections visible in the\n      // stream pass --messaging-socket-path explicitly (or --replay-user-messages).\n      let effectiveReplayUserMessages = !!options.replayUserMessages\n      if (feature('UDS_INBOX')) {\n        if (!effectiveReplayUserMessages && outputFormat === 'stream-json') {\n          effectiveReplayUserMessages = !!(\n            options as { messagingSocketPath?: string }\n          ).messagingSocketPath\n        }\n      }\n\n      if (getIsNonInteractiveSession()) {\n        // Apply full merged settings env now (including project-scoped\n        // .claude/settings.json PATH/GIT_DIR/GIT_WORK_TREE) so gitExe() and\n        // the git spawn below see it. Trust is implicit in -p mode; the\n        // docstring at managedEnv.ts:96-97 says this applies \"potentially\n        // dangerous environment variables such as LD_PRELOAD, PATH\" from all\n        // sources. The later call in the isNonInteractiveSession block below\n        // is idempotent (Object.assign, configureGlobalAgents ejects prior\n        // interceptor) and picks up any plugin-contributed env after plugin\n        // init. Project settings are already loaded here:\n        // applySafeConfigEnvironmentVariables in init() called\n        // getSettings_DEPRECATED at managedEnv.ts:86 which merges all enabled\n        // sources including projectSettings/localSettings.\n        applyConfigEnvironmentVariables()\n\n        // Spawn git status/log/branch now so the subprocess execution overlaps\n        // with the getCommands await below and startDeferredPrefetches. After\n        // setup() so cwd is final (setup.ts:254 may process.chdir(worktreePath)\n        // for --worktree) and after the applyConfigEnvironmentVariables above\n        // so PATH/GIT_DIR/GIT_WORK_TREE from all sources (trusted + project)\n        // are applied. getSystemContext is memoized; the\n        // prefetchSystemContextIfSafe call in startDeferredPrefetches becomes\n        // a cache hit. The microtask from await getIsGit() drains at the\n        // getCommands Promise.all await below. Trust is implicit in -p mode\n        // (same gate as prefetchSystemContextIfSafe).\n        void getSystemContext()\n        // Kick getUserContext now too — its first await (fs.readFile in\n        // getMemoryFiles) yields naturally, so the CLAUDE.md directory walk\n        // runs during the ~280ms overlap window before the context\n        // Promise.all join in print.ts. The void getUserContext() in\n        // startDeferredPrefetches becomes a memoize cache-hit.\n        void getUserContext()\n        // Kick ensureModelStringsInitialized now — for Bedrock this triggers\n        // a 100-200ms profile fetch that was awaited serially at\n        // print.ts:739. updateBedrockModelStrings is sequential()-wrapped so\n        // the await joins the in-flight fetch. Non-Bedrock is a sync\n        // early-return (zero-cost).\n        void ensureModelStringsInitialized()\n      }\n\n      // Apply --name: cache-only so no orphan file is created before the\n      // session ID is finalized by --continue/--resume. materializeSessionFile\n      // persists it on the first user message; REPL's useTerminalTitle reads it\n      // via getCurrentSessionTitle.\n      const sessionNameArg = options.name?.trim()\n      if (sessionNameArg) {\n        cacheSessionTitle(sessionNameArg)\n      }\n\n      // Ant model aliases (capybara-fast etc.) resolve via the\n      // tengu_ant_model_override GrowthBook flag. _CACHED_MAY_BE_STALE reads\n      // disk synchronously; disk is populated by a fire-and-forget write. On a\n      // cold cache, parseUserSpecifiedModel returns the unresolved alias, the\n      // API 404s, and -p exits before the async write lands — crashloop on\n      // fresh pods. Awaiting init here populates the in-memory payload map that\n      // _CACHED_MAY_BE_STALE now checks first. Gated so the warm path stays\n      // non-blocking:\n      //  - explicit model via --model or ANTHROPIC_MODEL (both feed alias resolution)\n      //  - no env override (which short-circuits _CACHED_MAY_BE_STALE before disk)\n      //  - flag absent from disk (== null also catches pre-#22279 poisoned null)\n      const explicitModel = options.model || process.env.ANTHROPIC_MODEL\n      if (\n        \"external\" === 'ant' &&\n        explicitModel &&\n        explicitModel !== 'default' &&\n        !hasGrowthBookEnvOverride('tengu_ant_model_override') &&\n        getGlobalConfig().cachedGrowthBookFeatures?.[\n          'tengu_ant_model_override'\n        ] == null\n      ) {\n        await initializeGrowthBook()\n      }\n\n      // Special case the default model with the null keyword\n      // NOTE: Model resolution happens after setup() to ensure trust is established before AWS auth\n      const userSpecifiedModel =\n        options.model === 'default' ? getDefaultMainLoopModel() : options.model\n      const userSpecifiedFallbackModel =\n        fallbackModel === 'default' ? getDefaultMainLoopModel() : fallbackModel\n\n      // Reuse preSetupCwd unless setup() chdir'd (worktreeEnabled). Saves a\n      // getCwd() syscall in the common path.\n      const currentCwd = worktreeEnabled ? getCwd() : preSetupCwd\n      logForDebugging('[STARTUP] Loading commands and agents...')\n      const commandsStart = Date.now()\n      // Join the promises kicked before setup() (or start fresh if\n      // worktreeEnabled gated the early kick). Both memoized by cwd.\n      const [commands, agentDefinitionsResult] = await Promise.all([\n        commandsPromise ?? getCommands(currentCwd),\n        agentDefsPromise ?? getAgentDefinitionsWithOverrides(currentCwd),\n      ])\n      logForDebugging(\n        `[STARTUP] Commands and agents loaded in ${Date.now() - commandsStart}ms`,\n      )\n      profileCheckpoint('action_commands_loaded')\n\n      // Parse CLI agents if provided via --agents flag\n      let cliAgents: typeof agentDefinitionsResult.activeAgents = []\n      if (agentsJson) {\n        try {\n          const parsedAgents = safeParseJSON(agentsJson)\n          if (parsedAgents) {\n            cliAgents = parseAgentsFromJson(parsedAgents, 'flagSettings')\n          }\n        } catch (error) {\n          logError(error)\n        }\n      }\n\n      // Merge CLI agents with existing ones\n      const allAgents = [...agentDefinitionsResult.allAgents, ...cliAgents]\n      const agentDefinitions = {\n        ...agentDefinitionsResult,\n        allAgents,\n        activeAgents: getActiveAgentsFromList(allAgents),\n      }\n\n      // Look up main thread agent from CLI flag or settings\n      const agentSetting = agentCli ?? getInitialSettings().agent\n      let mainThreadAgentDefinition:\n        | (typeof agentDefinitions.activeAgents)[number]\n        | undefined\n      if (agentSetting) {\n        mainThreadAgentDefinition = agentDefinitions.activeAgents.find(\n          agent => agent.agentType === agentSetting,\n        )\n        if (!mainThreadAgentDefinition) {\n          logForDebugging(\n            `Warning: agent \"${agentSetting}\" not found. ` +\n              `Available agents: ${agentDefinitions.activeAgents.map(a => a.agentType).join(', ')}. ` +\n              `Using default behavior.`,\n          )\n        }\n      }\n\n      // Store the main thread agent type in bootstrap state so hooks can access it\n      setMainThreadAgentType(mainThreadAgentDefinition?.agentType)\n\n      // Log agent flag usage — only log agent name for built-in agents to avoid leaking custom agent names\n      if (mainThreadAgentDefinition) {\n        logEvent('tengu_agent_flag', {\n          agentType: isBuiltInAgent(mainThreadAgentDefinition)\n            ? (mainThreadAgentDefinition.agentType as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS)\n            : ('custom' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS),\n          ...(agentCli && {\n            source:\n              'cli' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          }),\n        })\n      }\n\n      // Persist agent setting to session transcript for resume view display and restoration\n      if (mainThreadAgentDefinition?.agentType) {\n        saveAgentSetting(mainThreadAgentDefinition.agentType)\n      }\n\n      // Apply the agent's system prompt for non-interactive sessions\n      // (interactive mode uses buildEffectiveSystemPrompt instead)\n      if (\n        isNonInteractiveSession &&\n        mainThreadAgentDefinition &&\n        !systemPrompt &&\n        !isBuiltInAgent(mainThreadAgentDefinition)\n      ) {\n        const agentSystemPrompt = mainThreadAgentDefinition.getSystemPrompt()\n        if (agentSystemPrompt) {\n          systemPrompt = agentSystemPrompt\n        }\n      }\n\n      // initialPrompt goes first so its slash command (if any) is processed;\n      // user-provided text becomes trailing context.\n      // Only concatenate when inputPrompt is a string. When it's an\n      // AsyncIterable (SDK stream-json mode), template interpolation would\n      // call .toString() producing \"[object Object]\". The AsyncIterable case\n      // is handled in print.ts via structuredIO.prependUserMessage().\n      if (mainThreadAgentDefinition?.initialPrompt) {\n        if (typeof inputPrompt === 'string') {\n          inputPrompt = inputPrompt\n            ? `${mainThreadAgentDefinition.initialPrompt}\\n\\n${inputPrompt}`\n            : mainThreadAgentDefinition.initialPrompt\n        } else if (!inputPrompt) {\n          inputPrompt = mainThreadAgentDefinition.initialPrompt\n        }\n      }\n\n      // Compute effective model early so hooks can run in parallel with MCP\n      // If user didn't specify a model but agent has one, use the agent's model\n      let effectiveModel = userSpecifiedModel\n      if (\n        !effectiveModel &&\n        mainThreadAgentDefinition?.model &&\n        mainThreadAgentDefinition.model !== 'inherit'\n      ) {\n        effectiveModel = parseUserSpecifiedModel(\n          mainThreadAgentDefinition.model,\n        )\n      }\n\n      setMainLoopModelOverride(effectiveModel)\n\n      // Compute resolved model for hooks (use user-specified model at launch)\n      setInitialMainLoopModel(getUserSpecifiedModelSetting() || null)\n      const initialMainLoopModel = getInitialMainLoopModel()\n      const resolvedInitialModel = parseUserSpecifiedModel(\n        initialMainLoopModel ?? getDefaultMainLoopModel(),\n      )\n\n      let advisorModel: string | undefined\n      if (isAdvisorEnabled()) {\n        const advisorOption = canUserConfigureAdvisor()\n          ? (options as { advisor?: string }).advisor\n          : undefined\n        if (advisorOption) {\n          logForDebugging(`[AdvisorTool] --advisor ${advisorOption}`)\n          if (!modelSupportsAdvisor(resolvedInitialModel)) {\n            process.stderr.write(\n              chalk.red(\n                `Error: The model \"${resolvedInitialModel}\" does not support the advisor tool.\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n          const normalizedAdvisorModel = normalizeModelStringForAPI(\n            parseUserSpecifiedModel(advisorOption),\n          )\n          if (!isValidAdvisorModel(normalizedAdvisorModel)) {\n            process.stderr.write(\n              chalk.red(\n                `Error: The model \"${advisorOption}\" cannot be used as an advisor.\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n        }\n        advisorModel = canUserConfigureAdvisor()\n          ? (advisorOption ?? getInitialAdvisorSetting())\n          : advisorOption\n        if (advisorModel) {\n          logForDebugging(`[AdvisorTool] Advisor model: ${advisorModel}`)\n        }\n      }\n\n      // For tmux teammates with --agent-type, append the custom agent's prompt\n      if (\n        isAgentSwarmsEnabled() &&\n        storedTeammateOpts?.agentId &&\n        storedTeammateOpts?.agentName &&\n        storedTeammateOpts?.teamName &&\n        storedTeammateOpts?.agentType\n      ) {\n        // Look up the custom agent definition\n        const customAgent = agentDefinitions.activeAgents.find(\n          a => a.agentType === storedTeammateOpts.agentType,\n        )\n        if (customAgent) {\n          // Get the prompt - need to handle both built-in and custom agents\n          let customPrompt: string | undefined\n          if (customAgent.source === 'built-in') {\n            // Built-in agents have getSystemPrompt that takes toolUseContext\n            // We can't access full toolUseContext here, so skip for now\n            logForDebugging(\n              `[teammate] Built-in agent ${storedTeammateOpts.agentType} - skipping custom prompt (not supported)`,\n            )\n          } else {\n            // Custom agents have getSystemPrompt that takes no args\n            customPrompt = customAgent.getSystemPrompt()\n          }\n\n          // Log agent memory loaded event for tmux teammates\n          if (customAgent.memory) {\n            logEvent('tengu_agent_memory_loaded', {\n              ...(\"external\" === 'ant' && {\n                agent_type:\n                  customAgent.agentType as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n              }),\n              scope:\n                customAgent.memory as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n              source:\n                'teammate' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n            })\n          }\n\n          if (customPrompt) {\n            const customInstructions = `\\n# Custom Agent Instructions\\n${customPrompt}`\n            appendSystemPrompt = appendSystemPrompt\n              ? `${appendSystemPrompt}\\n\\n${customInstructions}`\n              : customInstructions\n          }\n        } else {\n          logForDebugging(\n            `[teammate] Custom agent ${storedTeammateOpts.agentType} not found in available agents`,\n          )\n        }\n      }\n\n      maybeActivateBrief(options)\n      // defaultView: 'chat' is a persisted opt-in — check entitlement and set\n      // userMsgOptIn so the tool + prompt section activate. Interactive-only:\n      // defaultView is a display preference; SDK sessions have no display, and\n      // the assistant installer writes defaultView:'chat' to settings.local.json\n      // which would otherwise leak into --print sessions in the same directory.\n      // Runs right after maybeActivateBrief() so all startup opt-in paths fire\n      // BEFORE any isBriefEnabled() read below (proactive prompt's\n      // briefVisibility). A persisted 'chat' after a GB kill-switch falls\n      // through (entitlement fails).\n      if (\n        (feature('KAIROS') || feature('KAIROS_BRIEF')) &&\n        !getIsNonInteractiveSession() &&\n        !getUserMsgOptIn() &&\n        getInitialSettings().defaultView === 'chat'\n      ) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const { isBriefEntitled } =\n          require('./tools/BriefTool/BriefTool.js') as typeof import('./tools/BriefTool/BriefTool.js')\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        if (isBriefEntitled()) {\n          setUserMsgOptIn(true)\n        }\n      }\n      // Coordinator mode has its own system prompt and filters out Sleep, so\n      // the generic proactive prompt would tell it to call a tool it can't\n      // access and conflict with delegation instructions.\n      if (\n        (feature('PROACTIVE') || feature('KAIROS')) &&\n        ((options as { proactive?: boolean }).proactive ||\n          isEnvTruthy(process.env.CLAUDE_CODE_PROACTIVE)) &&\n        !coordinatorModeModule?.isCoordinatorMode()\n      ) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const briefVisibility =\n          feature('KAIROS') || feature('KAIROS_BRIEF')\n            ? (\n                require('./tools/BriefTool/BriefTool.js') as typeof import('./tools/BriefTool/BriefTool.js')\n              ).isBriefEnabled()\n              ? 'Call SendUserMessage at checkpoints to mark where things stand.'\n              : 'The user will see any text you output.'\n            : 'The user will see any text you output.'\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        const proactivePrompt = `\\n# Proactive Mode\\n\\nYou are in proactive mode. Take initiative — explore, act, and make progress without waiting for instructions.\\n\\nStart by briefly greeting the user.\\n\\nYou will receive periodic <tick> prompts. These are check-ins. Do whatever seems most useful, or call Sleep if there's nothing to do. ${briefVisibility}`\n        appendSystemPrompt = appendSystemPrompt\n          ? `${appendSystemPrompt}\\n\\n${proactivePrompt}`\n          : proactivePrompt\n      }\n\n      if (feature('KAIROS') && kairosEnabled && assistantModule) {\n        const assistantAddendum =\n          assistantModule.getAssistantSystemPromptAddendum()\n        appendSystemPrompt = appendSystemPrompt\n          ? `${appendSystemPrompt}\\n\\n${assistantAddendum}`\n          : assistantAddendum\n      }\n\n      // Ink root is only needed for interactive sessions — patchConsole in the\n      // Ink constructor would swallow console output in headless mode.\n      let root!: Root\n      let getFpsMetrics!: () => FpsMetrics | undefined\n      let stats!: StatsStore\n\n      // Show setup screens after commands are loaded\n      if (!isNonInteractiveSession) {\n        const ctx = getRenderContext(false)\n        getFpsMetrics = ctx.getFpsMetrics\n        stats = ctx.stats\n        // Install asciicast recorder before Ink mounts (ant-only, opt-in via CLAUDE_CODE_TERMINAL_RECORDING=1)\n        if (\"external\" === 'ant') {\n          installAsciicastRecorder()\n        }\n\n        const { createRoot } = await import('./ink.js')\n        root = await createRoot(ctx.renderOptions)\n\n        // Log startup time now, before any blocking dialog renders. Logging\n        // from REPL's first render (the old location) included however long\n        // the user sat on trust/OAuth/onboarding/resume-picker — p99 was ~70s\n        // dominated by dialog-wait time, not code-path startup.\n        logEvent('tengu_timer', {\n          event:\n            'startup' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          durationMs: Math.round(process.uptime() * 1000),\n        })\n\n        logForDebugging('[STARTUP] Running showSetupScreens()...')\n        const setupScreensStart = Date.now()\n        const onboardingShown = await showSetupScreens(\n          root,\n          permissionMode,\n          allowDangerouslySkipPermissions,\n          commands,\n          enableClaudeInChrome,\n          devChannels,\n        )\n        logForDebugging(\n          `[STARTUP] showSetupScreens() completed in ${Date.now() - setupScreensStart}ms`,\n        )\n\n        // Now that trust is established and GrowthBook has auth headers,\n        // resolve the --remote-control / --rc entitlement gate.\n        if (feature('BRIDGE_MODE') && remoteControlOption !== undefined) {\n          const { getBridgeDisabledReason } = await import(\n            './bridge/bridgeEnabled.js'\n          )\n          const disabledReason = await getBridgeDisabledReason()\n          remoteControl = disabledReason === null\n          if (disabledReason) {\n            process.stderr.write(\n              chalk.yellow(`${disabledReason}\\n--rc flag ignored.\\n`),\n            )\n          }\n        }\n\n        // Check for pending agent memory snapshot updates (only for --agent mode, ant-only)\n        if (\n          feature('AGENT_MEMORY_SNAPSHOT') &&\n          mainThreadAgentDefinition &&\n          isCustomAgent(mainThreadAgentDefinition) &&\n          mainThreadAgentDefinition.memory &&\n          mainThreadAgentDefinition.pendingSnapshotUpdate\n        ) {\n          const agentDef = mainThreadAgentDefinition\n          const choice = await launchSnapshotUpdateDialog(root, {\n            agentType: agentDef.agentType,\n            scope: agentDef.memory!,\n            snapshotTimestamp:\n              agentDef.pendingSnapshotUpdate!.snapshotTimestamp,\n          })\n          if (choice === 'merge') {\n            const { buildMergePrompt } = await import(\n              './components/agents/SnapshotUpdateDialog.js'\n            )\n            const mergePrompt = buildMergePrompt(\n              agentDef.agentType,\n              agentDef.memory!,\n            )\n            inputPrompt = inputPrompt\n              ? `${mergePrompt}\\n\\n${inputPrompt}`\n              : mergePrompt\n          }\n          agentDef.pendingSnapshotUpdate = undefined\n        }\n\n        // Skip executing /login if we just completed onboarding for it\n        if (onboardingShown && prompt?.trim().toLowerCase() === '/login') {\n          prompt = ''\n        }\n\n        if (onboardingShown) {\n          // Refresh auth-dependent services now that the user has logged in during onboarding.\n          // Keep in sync with the post-login logic in src/commands/login.tsx\n          void refreshRemoteManagedSettings()\n          void refreshPolicyLimits()\n          // Clear user data cache BEFORE GrowthBook refresh so it picks up fresh credentials\n          resetUserCache()\n          // Refresh GrowthBook after login to get updated feature flags (e.g., for claude.ai MCPs)\n          refreshGrowthBookAfterAuthChange()\n          // Clear any stale trusted device token then enroll for Remote Control.\n          // Both self-gate on tengu_sessions_elevated_auth_enforcement internally\n          // — enrollTrustedDevice() via checkGate_CACHED_OR_BLOCKING (awaits\n          // the GrowthBook reinit above), clearTrustedDeviceToken() via the\n          // sync cached check (acceptable since clear is idempotent).\n          void import('./bridge/trustedDevice.js').then(m => {\n            m.clearTrustedDeviceToken()\n            return m.enrollTrustedDevice()\n          })\n        }\n\n        // Validate that the active token's org matches forceLoginOrgUUID (if set\n        // in managed settings). Runs after onboarding so managed settings and\n        // login state are fully loaded.\n        const orgValidation = await validateForceLoginOrg()\n        if (!orgValidation.valid) {\n          await exitWithError(root, orgValidation.message)\n        }\n      }\n\n      // If gracefulShutdown was initiated (e.g., user rejected trust dialog),\n      // process.exitCode will be set. Skip all subsequent operations that could\n      // trigger code execution before the process exits (e.g. we don't want apiKeyHelper\n      // to run if trust was not established).\n      if (process.exitCode !== undefined) {\n        logForDebugging(\n          'Graceful shutdown initiated, skipping further initialization',\n        )\n        return\n      }\n\n      // Initialize LSP manager AFTER trust is established (or in non-interactive mode\n      // where trust is implicit). This prevents plugin LSP servers from executing\n      // code in untrusted directories before user consent.\n      // Must be after inline plugins are set (if any) so --plugin-dir LSP servers are included.\n      initializeLspServerManager()\n\n      // Show settings validation errors after trust is established\n      // MCP config errors don't block settings from loading, so exclude them\n      if (!isNonInteractiveSession) {\n        const { errors } = getSettingsWithErrors()\n        const nonMcpErrors = errors.filter(e => !e.mcpErrorMetadata)\n        if (nonMcpErrors.length > 0) {\n          await launchInvalidSettingsDialog(root, {\n            settingsErrors: nonMcpErrors,\n            onExit: () => gracefulShutdownSync(1),\n          })\n        }\n      }\n\n      // Check quota status, fast mode, passes eligibility, and bootstrap data\n      // after trust is established. These make API calls which could trigger\n      // apiKeyHelper execution.\n      // --bare / SIMPLE: skip — these are cache-warms for the REPL's\n      // first-turn responsiveness (quota, passes, fastMode, bootstrap data). Fast\n      // mode doesn't apply to the Agent SDK anyway (see getFastModeUnavailableReason).\n      const bgRefreshThrottleMs = getFeatureValue_CACHED_MAY_BE_STALE(\n        'tengu_cicada_nap_ms',\n        0,\n      )\n      const lastPrefetched = getGlobalConfig().startupPrefetchedAt ?? 0\n      const skipStartupPrefetches =\n        isBareMode() ||\n        (bgRefreshThrottleMs > 0 &&\n          Date.now() - lastPrefetched < bgRefreshThrottleMs)\n\n      if (!skipStartupPrefetches) {\n        const lastPrefetchedInfo =\n          lastPrefetched > 0\n            ? ` last ran ${Math.round((Date.now() - lastPrefetched) / 1000)}s ago`\n            : ''\n        logForDebugging(\n          `Starting background startup prefetches${lastPrefetchedInfo}`,\n        )\n\n        checkQuotaStatus().catch(error => logError(error))\n\n        // Fetch bootstrap data from the server and update all cache values.\n        void fetchBootstrapData()\n\n        // TODO: Consolidate other prefetches into a single bootstrap request.\n        void prefetchPassesEligibility()\n        if (\n          !getFeatureValue_CACHED_MAY_BE_STALE('tengu_miraculo_the_bard', false)\n        ) {\n          void prefetchFastModeStatus()\n        } else {\n          // Kill switch skips the network call, not org-policy enforcement.\n          // Resolve from cache so orgStatus doesn't stay 'pending' (which\n          // getFastModeUnavailableReason treats as permissive).\n          resolveFastModeStatusFromCache()\n        }\n        if (bgRefreshThrottleMs > 0) {\n          saveGlobalConfig(current => ({\n            ...current,\n            startupPrefetchedAt: Date.now(),\n          }))\n        }\n      } else {\n        logForDebugging(\n          `Skipping startup prefetches, last ran ${Math.round((Date.now() - lastPrefetched) / 1000)}s ago`,\n        )\n        // Resolve fast mode org status from cache (no network)\n        resolveFastModeStatusFromCache()\n      }\n\n      if (!isNonInteractiveSession) {\n        void refreshExampleCommands() // Pre-fetch example commands (runs git log, no API call)\n      }\n\n      // Resolve MCP configs (started early, overlaps with setup/trust dialog work)\n      const { servers: existingMcpConfigs } = await mcpConfigPromise\n      logForDebugging(\n        `[STARTUP] MCP configs resolved in ${mcpConfigResolvedMs}ms (awaited at +${Date.now() - mcpConfigStart}ms)`,\n      )\n      // CLI flag (--mcp-config) should override file-based configs, matching settings precedence\n      const allMcpConfigs = { ...existingMcpConfigs, ...dynamicMcpConfig }\n\n      // Separate SDK configs from regular MCP configs\n      const sdkMcpConfigs: Record<string, McpSdkServerConfig> = {}\n      const regularMcpConfigs: Record<string, ScopedMcpServerConfig> = {}\n\n      for (const [name, config] of Object.entries(allMcpConfigs)) {\n        const typedConfig = config as ScopedMcpServerConfig | McpSdkServerConfig\n        if (typedConfig.type === 'sdk') {\n          sdkMcpConfigs[name] = typedConfig as McpSdkServerConfig\n        } else {\n          regularMcpConfigs[name] = typedConfig as ScopedMcpServerConfig\n        }\n      }\n\n      profileCheckpoint('action_mcp_configs_loaded')\n\n      // Prefetch MCP resources after trust dialog (this is where execution happens).\n      // Interactive mode only: print mode defers connects until headlessStore exists\n      // and pushes per-server (below), so ToolSearch's pending-client handling works\n      // and one slow server doesn't block the batch.\n      const localMcpPromise = isNonInteractiveSession\n        ? Promise.resolve({ clients: [], tools: [], commands: [] })\n        : prefetchAllMcpResources(regularMcpConfigs)\n      const claudeaiMcpPromise = isNonInteractiveSession\n        ? Promise.resolve({ clients: [], tools: [], commands: [] })\n        : claudeaiConfigPromise.then(configs =>\n            Object.keys(configs).length > 0\n              ? prefetchAllMcpResources(configs)\n              : { clients: [], tools: [], commands: [] },\n          )\n      // Merge with dedup by name: each prefetchAllMcpResources call independently\n      // adds helper tools (ListMcpResourcesTool, ReadMcpResourceTool) via\n      // local dedup flags, so merging two calls can yield duplicates. print.ts\n      // already uniqBy's the final tool pool, but dedup here keeps appState clean.\n      const mcpPromise = Promise.all([\n        localMcpPromise,\n        claudeaiMcpPromise,\n      ]).then(([local, claudeai]) => ({\n        clients: [...local.clients, ...claudeai.clients],\n        tools: uniqBy([...local.tools, ...claudeai.tools], 'name'),\n        commands: uniqBy([...local.commands, ...claudeai.commands], 'name'),\n      }))\n\n      // Start hooks early so they run in parallel with MCP connections.\n      // Skip for initOnly/init/maintenance (handled separately), non-interactive\n      // (handled via setupTrigger), and resume/continue (conversationRecovery.ts\n      // fires 'resume' instead — without this guard, hooks fire TWICE on /resume\n      // and the second systemMessage clobbers the first. gh-30825)\n      const hooksPromise =\n        initOnly ||\n        init ||\n        maintenance ||\n        isNonInteractiveSession ||\n        options.continue ||\n        options.resume\n          ? null\n          : processSessionStartHooks('startup', {\n              agentType: mainThreadAgentDefinition?.agentType,\n              model: resolvedInitialModel,\n            })\n\n      // MCP never blocks REPL render OR turn 1 TTFT. useManageMCPConnections\n      // populates appState.mcp async as servers connect (connectToServer is\n      // memoized — the prefetch calls above and the hook converge on the same\n      // connections). getToolUseContext reads store.getState() fresh via\n      // computeTools(), so turn 1 sees whatever's connected by query time.\n      // Slow servers populate for turn 2+. Matches interactive-no-prompt\n      // behavior. Print mode: per-server push into headlessStore (below).\n      const hookMessages: Awaited<NonNullable<typeof hooksPromise>> = []\n      // Suppress transient unhandledRejection — the prefetch warms the\n      // memoized connectToServer cache but nobody awaits it in interactive.\n      mcpPromise.catch(() => {})\n\n      const mcpClients: Awaited<typeof mcpPromise>['clients'] = []\n      const mcpTools: Awaited<typeof mcpPromise>['tools'] = []\n      const mcpCommands: Awaited<typeof mcpPromise>['commands'] = []\n\n      let thinkingEnabled = shouldEnableThinkingByDefault()\n      let thinkingConfig: ThinkingConfig =\n        thinkingEnabled !== false ? { type: 'adaptive' } : { type: 'disabled' }\n\n      if (options.thinking === 'adaptive' || options.thinking === 'enabled') {\n        thinkingEnabled = true\n        thinkingConfig = { type: 'adaptive' }\n      } else if (options.thinking === 'disabled') {\n        thinkingEnabled = false\n        thinkingConfig = { type: 'disabled' }\n      } else {\n        const maxThinkingTokens = process.env.MAX_THINKING_TOKENS\n          ? parseInt(process.env.MAX_THINKING_TOKENS, 10)\n          : options.maxThinkingTokens\n        if (maxThinkingTokens !== undefined) {\n          if (maxThinkingTokens > 0) {\n            thinkingEnabled = true\n            thinkingConfig = {\n              type: 'enabled',\n              budgetTokens: maxThinkingTokens,\n            }\n          } else if (maxThinkingTokens === 0) {\n            thinkingEnabled = false\n            thinkingConfig = { type: 'disabled' }\n          }\n        }\n      }\n\n      logForDiagnosticsNoPII('info', 'started', {\n        version: MACRO.VERSION,\n        is_native_binary: isInBundledMode(),\n      })\n\n      registerCleanup(async () => {\n        logForDiagnosticsNoPII('info', 'exited')\n      })\n\n      void logTenguInit({\n        hasInitialPrompt: Boolean(prompt),\n        hasStdin: Boolean(inputPrompt),\n        verbose,\n        debug,\n        debugToStderr,\n        print: print ?? false,\n        outputFormat: outputFormat ?? 'text',\n        inputFormat: inputFormat ?? 'text',\n        numAllowedTools: allowedTools.length,\n        numDisallowedTools: disallowedTools.length,\n        mcpClientCount: Object.keys(allMcpConfigs).length,\n        worktreeEnabled,\n        skipWebFetchPreflight: getInitialSettings().skipWebFetchPreflight,\n        githubActionInputs: process.env.GITHUB_ACTION_INPUTS,\n        dangerouslySkipPermissionsPassed: dangerouslySkipPermissions ?? false,\n        permissionMode,\n        modeIsBypass: permissionMode === 'bypassPermissions',\n        allowDangerouslySkipPermissionsPassed: allowDangerouslySkipPermissions,\n        systemPromptFlag: systemPrompt\n          ? options.systemPromptFile\n            ? 'file'\n            : 'flag'\n          : undefined,\n        appendSystemPromptFlag: appendSystemPrompt\n          ? options.appendSystemPromptFile\n            ? 'file'\n            : 'flag'\n          : undefined,\n        thinkingConfig,\n        assistantActivationPath:\n          feature('KAIROS') && kairosEnabled\n            ? assistantModule?.getAssistantActivationPath()\n            : undefined,\n      })\n\n      // Log context metrics once at initialization\n      void logContextMetrics(regularMcpConfigs, toolPermissionContext)\n\n      void logPermissionContextForAnts(null, 'initialization')\n\n      logManagedSettings()\n\n      // Register PID file for concurrent-session detection (~/.claude/sessions/)\n      // and fire multi-clauding telemetry. Lives here (not init.ts) so only the\n      // REPL path registers — not subcommands like `claude doctor`. Chained:\n      // count must run after register's write completes or it misses our own file.\n      void registerSession().then(registered => {\n        if (!registered) return\n        if (sessionNameArg) {\n          void updateSessionName(sessionNameArg)\n        }\n        void countConcurrentSessions().then(count => {\n          if (count >= 2) {\n            logEvent('tengu_concurrent_sessions', { num_sessions: count })\n          }\n        })\n      })\n\n      // Initialize versioned plugins system (triggers V1→V2 migration if\n      // needed). Then run orphan GC, THEN warm the Grep/Glob exclusion cache.\n      // Sequencing matters: the warmup scans disk for .orphaned_at markers,\n      // so it must see the GC's Pass 1 (remove markers from reinstalled\n      // versions) and Pass 2 (stamp unmarked orphans) already applied. The\n      // warm also lands before autoupdate (fires on first submit in REPL)\n      // can orphan this session's active version underneath us.\n      // --bare / SIMPLE: skip plugin version sync + orphan cleanup. These\n      // are install/upgrade bookkeeping that scripted calls don't need —\n      // the next interactive session will reconcile. The await here was\n      // blocking -p on a marketplace round-trip.\n      if (isBareMode()) {\n        // skip — no-op\n      } else if (isNonInteractiveSession) {\n        // In headless mode, await to ensure plugin sync completes before CLI exits\n        await initializeVersionedPlugins()\n        profileCheckpoint('action_after_plugins_init')\n        void cleanupOrphanedPluginVersionsInBackground().then(() =>\n          getGlobExclusionsForPluginCache(),\n        )\n      } else {\n        // In interactive mode, fire-and-forget — this is purely bookkeeping\n        // that doesn't affect runtime behavior of the current session\n        void initializeVersionedPlugins().then(async () => {\n          profileCheckpoint('action_after_plugins_init')\n          await cleanupOrphanedPluginVersionsInBackground()\n          void getGlobExclusionsForPluginCache()\n        })\n      }\n\n      const setupTrigger =\n        initOnly || init ? 'init' : maintenance ? 'maintenance' : null\n      if (initOnly) {\n        applyConfigEnvironmentVariables()\n        await processSetupHooks('init', { forceSyncExecution: true })\n        await processSessionStartHooks('startup', { forceSyncExecution: true })\n        gracefulShutdownSync(0)\n        return\n      }\n\n      // --print mode\n      if (isNonInteractiveSession) {\n        if (outputFormat === 'stream-json' || outputFormat === 'json') {\n          setHasFormattedOutput(true)\n        }\n\n        // Apply full environment variables in print mode since trust dialog is bypassed\n        // This includes potentially dangerous environment variables from untrusted sources\n        // but print mode is considered trusted (as documented in help text)\n        applyConfigEnvironmentVariables()\n\n        // Initialize telemetry after env vars are applied so OTEL endpoint env vars and\n        // otelHeadersHelper (which requires trust to execute) are available.\n        initializeTelemetryAfterTrust()\n\n        // Kick SessionStart hooks now so the subprocess spawn overlaps with\n        // MCP connect + plugin init + print.ts import below. loadInitialMessages\n        // joins this at print.ts:4397. Guarded same as loadInitialMessages —\n        // continue/resume/teleport paths don't fire startup hooks (or fire them\n        // conditionally inside the resume branch, where this promise is\n        // undefined and the ?? fallback runs). Also skip when setupTrigger is\n        // set — those paths run setup hooks first (print.ts:544), and session\n        // start hooks must wait until setup completes.\n        const sessionStartHooksPromise =\n          options.continue || options.resume || teleport || setupTrigger\n            ? undefined\n            : processSessionStartHooks('startup')\n        // Suppress transient unhandledRejection if this rejects before\n        // loadInitialMessages awaits it. Downstream await still observes the\n        // rejection — this just prevents the spurious global handler fire.\n        sessionStartHooksPromise?.catch(() => {})\n\n        profileCheckpoint('before_validateForceLoginOrg')\n        // Validate org restriction for non-interactive sessions\n        const orgValidation = await validateForceLoginOrg()\n        if (!orgValidation.valid) {\n          process.stderr.write(orgValidation.message + '\\n')\n          process.exit(1)\n        }\n\n        // Headless mode supports all prompt commands and some local commands\n        // If disableSlashCommands is true, return empty array\n        const commandsHeadless = disableSlashCommands\n          ? []\n          : commands.filter(\n              command =>\n                (command.type === 'prompt' && !command.disableNonInteractive) ||\n                (command.type === 'local' && command.supportsNonInteractive),\n            )\n\n        const defaultState = getDefaultAppState()\n        const headlessInitialState: AppState = {\n          ...defaultState,\n          mcp: {\n            ...defaultState.mcp,\n            clients: mcpClients,\n            commands: mcpCommands,\n            tools: mcpTools,\n          },\n          toolPermissionContext,\n          effortValue:\n            parseEffortValue(options.effort) ?? getInitialEffortSetting(),\n          ...(isFastModeEnabled() && {\n            fastMode: getInitialFastModeSetting(effectiveModel ?? null),\n          }),\n          ...(isAdvisorEnabled() && advisorModel && { advisorModel }),\n          // kairosEnabled gates the async fire-and-forget path in\n          // executeForkedSlashCommand (processSlashCommand.tsx:132) and\n          // AgentTool's shouldRunAsync. The REPL initialState sets this at\n          // ~3459; headless was defaulting to false, so the daemon child's\n          // scheduled tasks and Agent-tool calls ran synchronously — N\n          // overdue cron tasks on spawn = N serial subagent turns blocking\n          // user input. Computed at :1620, well before this branch.\n          ...(feature('KAIROS') ? { kairosEnabled } : {}),\n        }\n\n        // Init app state\n        const headlessStore = createStore(\n          headlessInitialState,\n          onChangeAppState,\n        )\n\n        // Check if bypassPermissions should be disabled based on Statsig gate\n        // This runs in parallel to the code below, to avoid blocking the main loop.\n        if (\n          toolPermissionContext.mode === 'bypassPermissions' ||\n          allowDangerouslySkipPermissions\n        ) {\n          void checkAndDisableBypassPermissions(toolPermissionContext)\n        }\n\n        // Async check of auto mode gate — corrects state and disables auto if needed.\n        // Gated on TRANSCRIPT_CLASSIFIER (not USER_TYPE) so GrowthBook kill switch runs for external builds too.\n        if (feature('TRANSCRIPT_CLASSIFIER')) {\n          void verifyAutoModeGateAccess(\n            toolPermissionContext,\n            headlessStore.getState().fastMode,\n          ).then(({ updateContext }) => {\n            headlessStore.setState(prev => {\n              const nextCtx = updateContext(prev.toolPermissionContext)\n              if (nextCtx === prev.toolPermissionContext) return prev\n              return { ...prev, toolPermissionContext: nextCtx }\n            })\n          })\n        }\n\n        // Set global state for session persistence\n        if (options.sessionPersistence === false) {\n          setSessionPersistenceDisabled(true)\n        }\n\n        // Store SDK betas in global state for context window calculation\n        // Only store allowed betas (filters by allowlist and subscriber status)\n        setSdkBetas(filterAllowedSdkBetas(betas))\n\n        // Print-mode MCP: per-server incremental push into headlessStore.\n        // Mirrors useManageMCPConnections — push pending first (so ToolSearch's\n        // pending-check at ToolSearchTool.ts:334 sees them), then replace with\n        // connected/failed as each server settles.\n        const connectMcpBatch = (\n          configs: Record<string, ScopedMcpServerConfig>,\n          label: string,\n        ): Promise<void> => {\n          if (Object.keys(configs).length === 0) return Promise.resolve()\n          headlessStore.setState(prev => ({\n            ...prev,\n            mcp: {\n              ...prev.mcp,\n              clients: [\n                ...prev.mcp.clients,\n                ...Object.entries(configs).map(([name, config]) => ({\n                  name,\n                  type: 'pending' as const,\n                  config,\n                })),\n              ],\n            },\n          }))\n          return getMcpToolsCommandsAndResources(\n            ({ client, tools, commands }) => {\n              headlessStore.setState(prev => ({\n                ...prev,\n                mcp: {\n                  ...prev.mcp,\n                  clients: prev.mcp.clients.some(c => c.name === client.name)\n                    ? prev.mcp.clients.map(c =>\n                        c.name === client.name ? client : c,\n                      )\n                    : [...prev.mcp.clients, client],\n                  tools: uniqBy([...prev.mcp.tools, ...tools], 'name'),\n                  commands: uniqBy([...prev.mcp.commands, ...commands], 'name'),\n                },\n              }))\n            },\n            configs,\n          ).catch(err =>\n            logForDebugging(`[MCP] ${label} connect error: ${err}`),\n          )\n        }\n        // Await all MCP configs — print mode is often single-turn, so\n        // \"late-connecting servers visible next turn\" doesn't help. SDK init\n        // message and turn-1 tool list both need configured MCP tools present.\n        // Zero-server case is free via the early return in connectMcpBatch.\n        // Connectors parallelize inside getMcpToolsCommandsAndResources\n        // (processBatched with Promise.all). claude.ai is awaited too — its\n        // fetch was kicked off early (line ~2558) so only residual time blocks\n        // here. --bare skips claude.ai entirely for perf-sensitive scripts.\n        profileCheckpoint('before_connectMcp')\n        await connectMcpBatch(regularMcpConfigs, 'regular')\n        profileCheckpoint('after_connectMcp')\n        // Dedup: suppress plugin MCP servers that duplicate a claude.ai\n        // connector (connector wins), then connect claude.ai servers.\n        // Bounded wait — #23725 made this blocking so single-turn -p sees\n        // connectors, but with 40+ slow connectors tengu_startup_perf p99\n        // climbed to 76s. If fetch+connect doesn't finish in time, proceed;\n        // the promise keeps running and updates headlessStore in the\n        // background so turn 2+ still sees connectors.\n        const CLAUDE_AI_MCP_TIMEOUT_MS = 5_000\n        const claudeaiConnect = claudeaiConfigPromise.then(claudeaiConfigs => {\n          if (Object.keys(claudeaiConfigs).length > 0) {\n            const claudeaiSigs = new Set<string>()\n            for (const config of Object.values(claudeaiConfigs)) {\n              const sig = getMcpServerSignature(config)\n              if (sig) claudeaiSigs.add(sig)\n            }\n            const suppressed = new Set<string>()\n            for (const [name, config] of Object.entries(regularMcpConfigs)) {\n              if (!name.startsWith('plugin:')) continue\n              const sig = getMcpServerSignature(config)\n              if (sig && claudeaiSigs.has(sig)) suppressed.add(name)\n            }\n            if (suppressed.size > 0) {\n              logForDebugging(\n                `[MCP] Lazy dedup: suppressing ${suppressed.size} plugin server(s) that duplicate claude.ai connectors: ${[...suppressed].join(', ')}`,\n              )\n              // Disconnect before filtering from state. Only connected\n              // servers need cleanup — clearServerCache on a never-connected\n              // server triggers a real connect just to kill it (memoize\n              // cache-miss path, see useManageMCPConnections.ts:870).\n              for (const c of headlessStore.getState().mcp.clients) {\n                if (!suppressed.has(c.name) || c.type !== 'connected') continue\n                c.client.onclose = undefined\n                void clearServerCache(c.name, c.config).catch(() => {})\n              }\n              headlessStore.setState(prev => {\n                let { clients, tools, commands, resources } = prev.mcp\n                clients = clients.filter(c => !suppressed.has(c.name))\n                tools = tools.filter(\n                  t => !t.mcpInfo || !suppressed.has(t.mcpInfo.serverName),\n                )\n                for (const name of suppressed) {\n                  commands = excludeCommandsByServer(commands, name)\n                  resources = excludeResourcesByServer(resources, name)\n                }\n                return {\n                  ...prev,\n                  mcp: { ...prev.mcp, clients, tools, commands, resources },\n                }\n              })\n            }\n          }\n          // Suppress claude.ai connectors that duplicate an enabled\n          // manual server (URL-signature match). Plugin dedup above only\n          // handles `plugin:*` keys; this catches manual `.mcp.json` entries.\n          // plugin:* must be excluded here — step 1 already suppressed\n          // those (claude.ai wins); leaving them in suppresses the\n          // connector too, and neither survives (gh-39974).\n          const nonPluginConfigs = pickBy(\n            regularMcpConfigs,\n            (_, n) => !n.startsWith('plugin:'),\n          )\n          const { servers: dedupedClaudeAi } = dedupClaudeAiMcpServers(\n            claudeaiConfigs,\n            nonPluginConfigs,\n          )\n          return connectMcpBatch(dedupedClaudeAi, 'claudeai')\n        })\n        let claudeaiTimer: ReturnType<typeof setTimeout> | undefined\n        const claudeaiTimedOut = await Promise.race([\n          claudeaiConnect.then(() => false),\n          new Promise<boolean>(resolve => {\n            claudeaiTimer = setTimeout(\n              r => r(true),\n              CLAUDE_AI_MCP_TIMEOUT_MS,\n              resolve,\n            )\n          }),\n        ])\n        if (claudeaiTimer) clearTimeout(claudeaiTimer)\n        if (claudeaiTimedOut) {\n          logForDebugging(\n            `[MCP] claude.ai connectors not ready after ${CLAUDE_AI_MCP_TIMEOUT_MS}ms — proceeding; background connection continues`,\n          )\n        }\n        profileCheckpoint('after_connectMcp_claudeai')\n\n        // In headless mode, start deferred prefetches immediately (no user typing delay)\n        // --bare / SIMPLE: startDeferredPrefetches early-returns internally.\n        // backgroundHousekeeping (initExtractMemories, pruneShellSnapshots,\n        // cleanupOldMessageFiles) and sdkHeapDumpMonitor are all bookkeeping\n        // that scripted calls don't need — the next interactive session reconciles.\n        if (!isBareMode()) {\n          startDeferredPrefetches()\n          void import('./utils/backgroundHousekeeping.js').then(m =>\n            m.startBackgroundHousekeeping(),\n          )\n          if (\"external\" === 'ant') {\n            void import('./utils/sdkHeapDumpMonitor.js').then(m =>\n              m.startSdkMemoryMonitor(),\n            )\n          }\n        }\n\n        logSessionTelemetry()\n        profileCheckpoint('before_print_import')\n        const { runHeadless } = await import('src/cli/print.js')\n        profileCheckpoint('after_print_import')\n        void runHeadless(\n          inputPrompt,\n          () => headlessStore.getState(),\n          headlessStore.setState,\n          commandsHeadless,\n          tools,\n          sdkMcpConfigs,\n          agentDefinitions.activeAgents,\n          {\n            continue: options.continue,\n            resume: options.resume,\n            verbose: verbose,\n            outputFormat: outputFormat,\n            jsonSchema,\n            permissionPromptToolName: options.permissionPromptTool,\n            allowedTools,\n            thinkingConfig,\n            maxTurns: options.maxTurns,\n            maxBudgetUsd: options.maxBudgetUsd,\n            taskBudget: options.taskBudget\n              ? { total: options.taskBudget }\n              : undefined,\n            systemPrompt,\n            appendSystemPrompt,\n            userSpecifiedModel: effectiveModel,\n            fallbackModel: userSpecifiedFallbackModel,\n            teleport,\n            sdkUrl,\n            replayUserMessages: effectiveReplayUserMessages,\n            includePartialMessages: effectiveIncludePartialMessages,\n            forkSession: options.forkSession || false,\n            resumeSessionAt: options.resumeSessionAt || undefined,\n            rewindFiles: options.rewindFiles,\n            enableAuthStatus: options.enableAuthStatus,\n            agent: agentCli,\n            workload: options.workload,\n            setupTrigger: setupTrigger ?? undefined,\n            sessionStartHooksPromise,\n          },\n        )\n        return\n      }\n\n      // Log model config at startup\n      logEvent('tengu_startup_manual_model_config', {\n        cli_flag:\n          options.model as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        env_var: process.env\n          .ANTHROPIC_MODEL as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        settings_file: (getInitialSettings() || {})\n          .model as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        subscriptionType:\n          getSubscriptionType() as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        agent:\n          agentSetting as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      })\n\n      // Get deprecation warning for the initial model (resolvedInitialModel computed earlier for hooks parallelization)\n      const deprecationWarning =\n        getModelDeprecationWarning(resolvedInitialModel)\n\n      // Build initial notification queue\n      const initialNotifications: Array<{\n        key: string\n        text: string\n        color?: 'warning'\n        priority: 'high'\n      }> = []\n      if (permissionModeNotification) {\n        initialNotifications.push({\n          key: 'permission-mode-notification',\n          text: permissionModeNotification,\n          priority: 'high',\n        })\n      }\n      if (deprecationWarning) {\n        initialNotifications.push({\n          key: 'model-deprecation-warning',\n          text: deprecationWarning,\n          color: 'warning',\n          priority: 'high',\n        })\n      }\n      if (overlyBroadBashPermissions.length > 0) {\n        const displayList = uniq(\n          overlyBroadBashPermissions.map(p => p.ruleDisplay),\n        )\n        const displays = displayList.join(', ')\n        const sources = uniq(\n          overlyBroadBashPermissions.map(p => p.sourceDisplay),\n        ).join(', ')\n        const n = displayList.length\n        initialNotifications.push({\n          key: 'overly-broad-bash-notification',\n          text: `${displays} allow ${plural(n, 'rule')} from ${sources} ${plural(n, 'was', 'were')} ignored \\u2014 not available for Ants, please use auto-mode instead`,\n          color: 'warning',\n          priority: 'high',\n        })\n      }\n\n      const effectiveToolPermissionContext = {\n        ...toolPermissionContext,\n        mode:\n          isAgentSwarmsEnabled() && getTeammateUtils().isPlanModeRequired()\n            ? ('plan' as const)\n            : toolPermissionContext.mode,\n      }\n      // All startup opt-in paths (--tools, --brief, defaultView) have fired\n      // above; initialIsBriefOnly just reads the resulting state.\n      const initialIsBriefOnly =\n        feature('KAIROS') || feature('KAIROS_BRIEF') ? getUserMsgOptIn() : false\n      const fullRemoteControl =\n        remoteControl || getRemoteControlAtStartup() || kairosEnabled\n      let ccrMirrorEnabled = false\n      if (feature('CCR_MIRROR') && !fullRemoteControl) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const { isCcrMirrorEnabled } =\n          require('./bridge/bridgeEnabled.js') as typeof import('./bridge/bridgeEnabled.js')\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        ccrMirrorEnabled = isCcrMirrorEnabled()\n      }\n\n      const initialState: AppState = {\n        settings: getInitialSettings(),\n        tasks: {},\n        agentNameRegistry: new Map(),\n        verbose: verbose ?? getGlobalConfig().verbose ?? false,\n        mainLoopModel: initialMainLoopModel,\n        mainLoopModelForSession: null,\n        isBriefOnly: initialIsBriefOnly,\n        expandedView: getGlobalConfig().showSpinnerTree\n          ? 'teammates'\n          : getGlobalConfig().showExpandedTodos\n            ? 'tasks'\n            : 'none',\n        showTeammateMessagePreview: isAgentSwarmsEnabled() ? false : undefined,\n        selectedIPAgentIndex: -1,\n        coordinatorTaskIndex: -1,\n        viewSelectionMode: 'none',\n        footerSelection: null,\n        toolPermissionContext: effectiveToolPermissionContext,\n        agent: mainThreadAgentDefinition?.agentType,\n        agentDefinitions,\n        mcp: {\n          clients: [],\n          tools: [],\n          commands: [],\n          resources: {},\n          pluginReconnectKey: 0,\n        },\n        plugins: {\n          enabled: [],\n          disabled: [],\n          commands: [],\n          errors: [],\n          installationStatus: {\n            marketplaces: [],\n            plugins: [],\n          },\n          needsRefresh: false,\n        },\n        statusLineText: undefined,\n        kairosEnabled,\n        remoteSessionUrl: undefined,\n        remoteConnectionStatus: 'connecting',\n        remoteBackgroundTaskCount: 0,\n        replBridgeEnabled: fullRemoteControl || ccrMirrorEnabled,\n        replBridgeExplicit: remoteControl,\n        replBridgeOutboundOnly: ccrMirrorEnabled,\n        replBridgeConnected: false,\n        replBridgeSessionActive: false,\n        replBridgeReconnecting: false,\n        replBridgeConnectUrl: undefined,\n        replBridgeSessionUrl: undefined,\n        replBridgeEnvironmentId: undefined,\n        replBridgeSessionId: undefined,\n        replBridgeError: undefined,\n        replBridgeInitialName: remoteControlName,\n        showRemoteCallout: false,\n        notifications: {\n          current: null,\n          queue: initialNotifications,\n        },\n        elicitation: {\n          queue: [],\n        },\n        todos: {},\n        remoteAgentTaskSuggestions: [],\n        fileHistory: {\n          snapshots: [],\n          trackedFiles: new Set(),\n          snapshotSequence: 0,\n        },\n        attribution: createEmptyAttributionState(),\n        thinkingEnabled,\n        promptSuggestionEnabled: shouldEnablePromptSuggestion(),\n        sessionHooks: new Map(),\n        inbox: {\n          messages: [],\n        },\n        promptSuggestion: {\n          text: null,\n          promptId: null,\n          shownAt: 0,\n          acceptedAt: 0,\n          generationRequestId: null,\n        },\n        speculation: IDLE_SPECULATION_STATE,\n        speculationSessionTimeSavedMs: 0,\n        skillImprovement: {\n          suggestion: null,\n        },\n        workerSandboxPermissions: {\n          queue: [],\n          selectedIndex: 0,\n        },\n        pendingWorkerRequest: null,\n        pendingSandboxRequest: null,\n        authVersion: 0,\n        initialMessage: inputPrompt\n          ? { message: createUserMessage({ content: String(inputPrompt) }) }\n          : null,\n        effortValue:\n          parseEffortValue(options.effort) ?? getInitialEffortSetting(),\n        activeOverlays: new Set<string>(),\n        fastMode: getInitialFastModeSetting(resolvedInitialModel),\n        ...(isAdvisorEnabled() && advisorModel && { advisorModel }),\n        // Compute teamContext synchronously to avoid useEffect setState during render.\n        // KAIROS: assistantTeamContext takes precedence — set earlier in the\n        // KAIROS block so Agent(name: \"foo\") can spawn in-process teammates\n        // without TeamCreate. computeInitialTeamContext() is for tmux-spawned\n        // teammates reading their own identity, not the assistant-mode leader.\n        teamContext: feature('KAIROS')\n          ? (assistantTeamContext ?? computeInitialTeamContext?.())\n          : computeInitialTeamContext?.(),\n      }\n\n      // Add CLI initial prompt to history\n      if (inputPrompt) {\n        addToHistory(String(inputPrompt))\n      }\n\n      const initialTools = mcpTools\n\n      // Increment numStartups synchronously — first-render readers like\n      // shouldShowEffortCallout (via useState initializer) need the updated\n      // value before setImmediate fires. Defer only telemetry.\n      saveGlobalConfig(current => ({\n        ...current,\n        numStartups: (current.numStartups ?? 0) + 1,\n      }))\n      setImmediate(() => {\n        void logStartupTelemetry()\n        logSessionTelemetry()\n      })\n\n      // Set up per-turn session environment data uploader (ant-only build).\n      // Default-enabled for all ant users when working in an Anthropic-owned\n      // repo. Captures git/filesystem state (NOT transcripts) at each turn so\n      // environments can be recreated at any user message index. Gating:\n      //   - Build-time: this import is stubbed in external builds.\n      //   - Runtime: uploader checks github.com/anthropics/* remote + gcloud auth.\n      //   - Safety: CLAUDE_CODE_DISABLE_SESSION_DATA_UPLOAD=1 bypasses (tests set this).\n      // Import is dynamic + async to avoid adding startup latency.\n      const sessionUploaderPromise =\n        \"external\" === 'ant'\n          ? import('./utils/sessionDataUploader.js')\n          : null\n\n      // Defer session uploader resolution to the onTurnComplete callback to avoid\n      // adding a new top-level await in main.tsx (performance-critical path).\n      // The per-turn auth logic in sessionDataUploader.ts handles unauthenticated\n      // state gracefully (re-checks each turn, so auth recovery mid-session works).\n      const uploaderReady = sessionUploaderPromise\n        ? sessionUploaderPromise\n            .then(mod => mod.createSessionTurnUploader())\n            .catch(() => null)\n        : null\n\n      const sessionConfig = {\n        debug: debug || debugToStderr,\n        commands: [...commands, ...mcpCommands],\n        initialTools,\n        mcpClients,\n        autoConnectIdeFlag: ide,\n        mainThreadAgentDefinition,\n        disableSlashCommands,\n        dynamicMcpConfig,\n        strictMcpConfig,\n        systemPrompt,\n        appendSystemPrompt,\n        taskListId,\n        thinkingConfig,\n        ...(uploaderReady && {\n          onTurnComplete: (messages: MessageType[]) => {\n            void uploaderReady.then(uploader => uploader?.(messages))\n          },\n        }),\n      }\n\n      // Shared context for processResumedConversation calls\n      const resumeContext = {\n        modeApi: coordinatorModeModule,\n        mainThreadAgentDefinition,\n        agentDefinitions,\n        currentCwd,\n        cliAgents,\n        initialState,\n      }\n\n      if (options.continue) {\n        // Continue the most recent conversation directly\n        let resumeSucceeded = false\n        try {\n          const resumeStart = performance.now()\n\n          // Clear stale caches before resuming to ensure fresh file/skill discovery\n          const { clearSessionCaches } = await import(\n            './commands/clear/caches.js'\n          )\n          clearSessionCaches()\n\n          const result = await loadConversationForResume(\n            undefined /* sessionId */,\n            undefined /* sourceFile */,\n          )\n          if (!result) {\n            logEvent('tengu_continue', {\n              success: false,\n            })\n            return await exitWithError(\n              root,\n              'No conversation found to continue',\n            )\n          }\n\n          const loaded = await processResumedConversation(\n            result,\n            {\n              forkSession: !!options.forkSession,\n              includeAttribution: true,\n              transcriptPath: result.fullPath,\n            },\n            resumeContext,\n          )\n\n          if (loaded.restoredAgentDef) {\n            mainThreadAgentDefinition = loaded.restoredAgentDef\n          }\n\n          maybeActivateProactive(options)\n          maybeActivateBrief(options)\n\n          logEvent('tengu_continue', {\n            success: true,\n            resume_duration_ms: Math.round(performance.now() - resumeStart),\n          })\n          resumeSucceeded = true\n\n          await launchRepl(\n            root,\n            { getFpsMetrics, stats, initialState: loaded.initialState },\n            {\n              ...sessionConfig,\n              mainThreadAgentDefinition:\n                loaded.restoredAgentDef ?? mainThreadAgentDefinition,\n              initialMessages: loaded.messages,\n              initialFileHistorySnapshots: loaded.fileHistorySnapshots,\n              initialContentReplacements: loaded.contentReplacements,\n              initialAgentName: loaded.agentName,\n              initialAgentColor: loaded.agentColor,\n            },\n            renderAndRun,\n          )\n        } catch (error) {\n          if (!resumeSucceeded) {\n            logEvent('tengu_continue', {\n              success: false,\n            })\n          }\n          logError(error)\n          process.exit(1)\n        }\n      } else if (feature('DIRECT_CONNECT') && _pendingConnect?.url) {\n        // `claude connect <url>` — full interactive TUI connected to a remote server\n        let directConnectConfig\n        try {\n          const session = await createDirectConnectSession({\n            serverUrl: _pendingConnect.url,\n            authToken: _pendingConnect.authToken,\n            cwd: getOriginalCwd(),\n            dangerouslySkipPermissions:\n              _pendingConnect.dangerouslySkipPermissions,\n          })\n          if (session.workDir) {\n            setOriginalCwd(session.workDir)\n            setCwdState(session.workDir)\n          }\n          setDirectConnectServerUrl(_pendingConnect.url)\n          directConnectConfig = session.config\n        } catch (err) {\n          return await exitWithError(\n            root,\n            err instanceof DirectConnectError ? err.message : String(err),\n            () => gracefulShutdown(1),\n          )\n        }\n\n        const connectInfoMessage = createSystemMessage(\n          `Connected to server at ${_pendingConnect.url}\\nSession: ${directConnectConfig.sessionId}`,\n          'info',\n        )\n\n        await launchRepl(\n          root,\n          { getFpsMetrics, stats, initialState },\n          {\n            debug: debug || debugToStderr,\n            commands,\n            initialTools: [],\n            initialMessages: [connectInfoMessage],\n            mcpClients: [],\n            autoConnectIdeFlag: ide,\n            mainThreadAgentDefinition,\n            disableSlashCommands,\n            directConnectConfig,\n            thinkingConfig,\n          },\n          renderAndRun,\n        )\n        return\n      } else if (feature('SSH_REMOTE') && _pendingSSH?.host) {\n        // `claude ssh <host> [dir]` — probe remote, deploy binary if needed,\n        // spawn ssh with unix-socket -R forward to a local auth proxy, hand\n        // the REPL an SSHSession. Tools run remotely, UI renders locally.\n        // `--local` skips probe/deploy/ssh and spawns the current binary\n        // directly with the same env — e2e test of the proxy/auth plumbing.\n        const { createSSHSession, createLocalSSHSession, SSHSessionError } =\n          await import('./ssh/createSSHSession.js')\n        let sshSession\n        try {\n          if (_pendingSSH.local) {\n            process.stderr.write('Starting local ssh-proxy test session...\\n')\n            sshSession = createLocalSSHSession({\n              cwd: _pendingSSH.cwd,\n              permissionMode: _pendingSSH.permissionMode,\n              dangerouslySkipPermissions:\n                _pendingSSH.dangerouslySkipPermissions,\n            })\n          } else {\n            process.stderr.write(`Connecting to ${_pendingSSH.host}…\\n`)\n            // In-place progress: \\r + EL0 (erase to end of line). Final \\n on\n            // success so the next message lands on a fresh line. No-op when\n            // stderr isn't a TTY (piped/redirected) — \\r would just emit noise.\n            const isTTY = process.stderr.isTTY\n            let hadProgress = false\n            sshSession = await createSSHSession(\n              {\n                host: _pendingSSH.host,\n                cwd: _pendingSSH.cwd,\n                localVersion: MACRO.VERSION,\n                permissionMode: _pendingSSH.permissionMode,\n                dangerouslySkipPermissions:\n                  _pendingSSH.dangerouslySkipPermissions,\n                extraCliArgs: _pendingSSH.extraCliArgs,\n              },\n              isTTY\n                ? {\n                    onProgress: msg => {\n                      hadProgress = true\n                      process.stderr.write(`\\r  ${msg}\\x1b[K`)\n                    },\n                  }\n                : {},\n            )\n            if (hadProgress) process.stderr.write('\\n')\n          }\n          setOriginalCwd(sshSession.remoteCwd)\n          setCwdState(sshSession.remoteCwd)\n          setDirectConnectServerUrl(\n            _pendingSSH.local ? 'local' : _pendingSSH.host,\n          )\n        } catch (err) {\n          return await exitWithError(\n            root,\n            err instanceof SSHSessionError ? err.message : String(err),\n            () => gracefulShutdown(1),\n          )\n        }\n\n        const sshInfoMessage = createSystemMessage(\n          _pendingSSH.local\n            ? `Local ssh-proxy test session\\ncwd: ${sshSession.remoteCwd}\\nAuth: unix socket → local proxy`\n            : `SSH session to ${_pendingSSH.host}\\nRemote cwd: ${sshSession.remoteCwd}\\nAuth: unix socket -R → local proxy`,\n          'info',\n        )\n\n        await launchRepl(\n          root,\n          { getFpsMetrics, stats, initialState },\n          {\n            debug: debug || debugToStderr,\n            commands,\n            initialTools: [],\n            initialMessages: [sshInfoMessage],\n            mcpClients: [],\n            autoConnectIdeFlag: ide,\n            mainThreadAgentDefinition,\n            disableSlashCommands,\n            sshSession,\n            thinkingConfig,\n          },\n          renderAndRun,\n        )\n        return\n      } else if (\n        feature('KAIROS') &&\n        _pendingAssistantChat &&\n        (_pendingAssistantChat.sessionId || _pendingAssistantChat.discover)\n      ) {\n        // `claude assistant [sessionId]` — REPL as a pure viewer client\n        // of a remote assistant session. The agentic loop runs remotely; this\n        // process streams live events and POSTs messages. History is lazy-\n        // loaded by useAssistantHistory on scroll-up (no blocking fetch here).\n        const { discoverAssistantSessions } = await import(\n          './assistant/sessionDiscovery.js'\n        )\n\n        let targetSessionId = _pendingAssistantChat.sessionId\n\n        // Discovery flow — list bridge environments, filter sessions\n        if (!targetSessionId) {\n          let sessions\n          try {\n            sessions = await discoverAssistantSessions()\n          } catch (e) {\n            return await exitWithError(\n              root,\n              `Failed to discover sessions: ${e instanceof Error ? e.message : e}`,\n              () => gracefulShutdown(1),\n            )\n          }\n          if (sessions.length === 0) {\n            let installedDir: string | null\n            try {\n              installedDir = await launchAssistantInstallWizard(root)\n            } catch (e) {\n              return await exitWithError(\n                root,\n                `Assistant installation failed: ${e instanceof Error ? e.message : e}`,\n                () => gracefulShutdown(1),\n              )\n            }\n            if (installedDir === null) {\n              await gracefulShutdown(0)\n              process.exit(0)\n            }\n            // The daemon needs a few seconds to spin up its worker and\n            // establish a bridge session before discovery will find it.\n            return await exitWithMessage(\n              root,\n              `Assistant installed in ${installedDir}. The daemon is starting up — run \\`claude assistant\\` again in a few seconds to connect.`,\n              { exitCode: 0, beforeExit: () => gracefulShutdown(0) },\n            )\n          }\n          if (sessions.length === 1) {\n            targetSessionId = sessions[0]!.id\n          } else {\n            const picked = await launchAssistantSessionChooser(root, {\n              sessions,\n            })\n            if (!picked) {\n              await gracefulShutdown(0)\n              process.exit(0)\n            }\n            targetSessionId = picked\n          }\n        }\n\n        // Auth — call prepareApiRequest() once for orgUUID, but use a\n        // getAccessToken closure for the token so reconnects get fresh tokens.\n        const { checkAndRefreshOAuthTokenIfNeeded, getClaudeAIOAuthTokens } =\n          await import('./utils/auth.js')\n        await checkAndRefreshOAuthTokenIfNeeded()\n        let apiCreds\n        try {\n          apiCreds = await prepareApiRequest()\n        } catch (e) {\n          return await exitWithError(\n            root,\n            `Error: ${e instanceof Error ? e.message : 'Failed to authenticate'}`,\n            () => gracefulShutdown(1),\n          )\n        }\n        const getAccessToken = (): string =>\n          getClaudeAIOAuthTokens()?.accessToken ?? apiCreds.accessToken\n\n        // Brief mode activation: setKairosActive(true) satisfies BOTH opt-in\n        // and entitlement for isBriefEnabled() (BriefTool.ts:124-132).\n        setKairosActive(true)\n        setUserMsgOptIn(true)\n        setIsRemoteMode(true)\n\n        const remoteSessionConfig = createRemoteSessionConfig(\n          targetSessionId,\n          getAccessToken,\n          apiCreds.orgUUID,\n          /* hasInitialPrompt */ false,\n          /* viewerOnly */ true,\n        )\n\n        const infoMessage = createSystemMessage(\n          `Attached to assistant session ${targetSessionId.slice(0, 8)}…`,\n          'info',\n        )\n\n        const assistantInitialState: AppState = {\n          ...initialState,\n          isBriefOnly: true,\n          kairosEnabled: false,\n          replBridgeEnabled: false,\n        }\n\n        const remoteCommands = filterCommandsForRemoteMode(commands)\n        await launchRepl(\n          root,\n          { getFpsMetrics, stats, initialState: assistantInitialState },\n          {\n            debug: debug || debugToStderr,\n            commands: remoteCommands,\n            initialTools: [],\n            initialMessages: [infoMessage],\n            mcpClients: [],\n            autoConnectIdeFlag: ide,\n            mainThreadAgentDefinition,\n            disableSlashCommands,\n            remoteSessionConfig,\n            thinkingConfig,\n          },\n          renderAndRun,\n        )\n        return\n      } else if (\n        options.resume ||\n        options.fromPr ||\n        teleport ||\n        remote !== null\n      ) {\n        // Handle resume flow - from file (ant-only), session ID, or interactive selector\n\n        // Clear stale caches before resuming to ensure fresh file/skill discovery\n        const { clearSessionCaches } = await import(\n          './commands/clear/caches.js'\n        )\n        clearSessionCaches()\n\n        let messages: MessageType[] | null = null\n        let processedResume: ProcessedResume | undefined = undefined\n\n        let maybeSessionId = validateUuid(options.resume)\n        let searchTerm: string | undefined = undefined\n        // Store full LogOption when found by custom title (for cross-worktree resume)\n        let matchedLog: LogOption | null = null\n        // PR filter for --from-pr flag\n        let filterByPr: boolean | number | string | undefined = undefined\n\n        // Handle --from-pr flag\n        if (options.fromPr) {\n          if (options.fromPr === true) {\n            // Show all sessions with linked PRs\n            filterByPr = true\n          } else if (typeof options.fromPr === 'string') {\n            // Could be a PR number or URL\n            filterByPr = options.fromPr\n          }\n        }\n\n        // If resume value is not a UUID, try exact match by custom title first\n        if (\n          options.resume &&\n          typeof options.resume === 'string' &&\n          !maybeSessionId\n        ) {\n          const trimmedValue = options.resume.trim()\n          if (trimmedValue) {\n            const matches = await searchSessionsByCustomTitle(trimmedValue, {\n              exact: true,\n            })\n\n            if (matches.length === 1) {\n              // Exact match found - store full LogOption for cross-worktree resume\n              matchedLog = matches[0]!\n              maybeSessionId = getSessionIdFromLog(matchedLog) ?? null\n            } else {\n              // No match or multiple matches - use as search term for picker\n              searchTerm = trimmedValue\n            }\n          }\n        }\n\n        // --remote and --teleport both create/resume Claude Code Web (CCR) sessions.\n        // Remote Control (--rc) is a separate feature gated in initReplBridge.ts.\n        if (remote !== null || teleport) {\n          await waitForPolicyLimitsToLoad()\n          if (!isPolicyAllowed('allow_remote_sessions')) {\n            return await exitWithError(\n              root,\n              \"Error: Remote sessions are disabled by your organization's policy.\",\n              () => gracefulShutdown(1),\n            )\n          }\n        }\n\n        if (remote !== null) {\n          // Create remote session (optionally with initial prompt)\n          const hasInitialPrompt = remote.length > 0\n\n          // Check if TUI mode is enabled - description is only optional in TUI mode\n          const isRemoteTuiEnabled = getFeatureValue_CACHED_MAY_BE_STALE(\n            'tengu_remote_backend',\n            false,\n          )\n          if (!isRemoteTuiEnabled && !hasInitialPrompt) {\n            return await exitWithError(\n              root,\n              'Error: --remote requires a description.\\nUsage: claude --remote \"your task description\"',\n              () => gracefulShutdown(1),\n            )\n          }\n\n          logEvent('tengu_remote_create_session', {\n            has_initial_prompt: String(\n              hasInitialPrompt,\n            ) as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n\n          // Pass current branch so CCR clones the repo at the right revision\n          const currentBranch = await getBranch()\n          const createdSession = await teleportToRemoteWithErrorHandling(\n            root,\n            hasInitialPrompt ? remote : null,\n            new AbortController().signal,\n            currentBranch || undefined,\n          )\n          if (!createdSession) {\n            logEvent('tengu_remote_create_session_error', {\n              error:\n                'unable_to_create_session' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n            })\n            return await exitWithError(\n              root,\n              'Error: Unable to create remote session',\n              () => gracefulShutdown(1),\n            )\n          }\n          logEvent('tengu_remote_create_session_success', {\n            session_id:\n              createdSession.id as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n\n          // Check if new remote TUI mode is enabled via feature gate\n          if (!isRemoteTuiEnabled) {\n            // Original behavior: print session info and exit\n            process.stdout.write(\n              `Created remote session: ${createdSession.title}\\n`,\n            )\n            process.stdout.write(\n              `View: ${getRemoteSessionUrl(createdSession.id)}?m=0\\n`,\n            )\n            process.stdout.write(\n              `Resume with: claude --teleport ${createdSession.id}\\n`,\n            )\n            await gracefulShutdown(0)\n            process.exit(0)\n          }\n\n          // New behavior: start local TUI with CCR engine\n          // Mark that we're in remote mode for command visibility\n          setIsRemoteMode(true)\n          switchSession(asSessionId(createdSession.id))\n\n          // Get OAuth credentials for remote session\n          let apiCreds: { accessToken: string; orgUUID: string }\n          try {\n            apiCreds = await prepareApiRequest()\n          } catch (error) {\n            logError(toError(error))\n            return await exitWithError(\n              root,\n              `Error: ${errorMessage(error) || 'Failed to authenticate'}`,\n              () => gracefulShutdown(1),\n            )\n          }\n\n          // Create remote session config for the REPL\n          const { getClaudeAIOAuthTokens: getTokensForRemote } = await import(\n            './utils/auth.js'\n          )\n          const getAccessTokenForRemote = (): string =>\n            getTokensForRemote()?.accessToken ?? apiCreds.accessToken\n          const remoteSessionConfig = createRemoteSessionConfig(\n            createdSession.id,\n            getAccessTokenForRemote,\n            apiCreds.orgUUID,\n            hasInitialPrompt,\n          )\n\n          // Add remote session info as initial system message\n          const remoteSessionUrl = `${getRemoteSessionUrl(createdSession.id)}?m=0`\n          const remoteInfoMessage = createSystemMessage(\n            `/remote-control is active. Code in CLI or at ${remoteSessionUrl}`,\n            'info',\n          )\n\n          // Create initial user message from the prompt if provided (CCR echoes it back but we ignore that)\n          const initialUserMessage = hasInitialPrompt\n            ? createUserMessage({ content: remote })\n            : null\n\n          // Set remote session URL in app state for footer indicator\n          const remoteInitialState = {\n            ...initialState,\n            remoteSessionUrl,\n          }\n\n          // Pre-filter commands to only include remote-safe ones.\n          // CCR's init response may further refine the list (via handleRemoteInit in REPL).\n          const remoteCommands = filterCommandsForRemoteMode(commands)\n          await launchRepl(\n            root,\n            { getFpsMetrics, stats, initialState: remoteInitialState },\n            {\n              debug: debug || debugToStderr,\n              commands: remoteCommands,\n              initialTools: [],\n              initialMessages: initialUserMessage\n                ? [remoteInfoMessage, initialUserMessage]\n                : [remoteInfoMessage],\n              mcpClients: [],\n              autoConnectIdeFlag: ide,\n              mainThreadAgentDefinition,\n              disableSlashCommands,\n              remoteSessionConfig,\n              thinkingConfig,\n            },\n            renderAndRun,\n          )\n          return\n        } else if (teleport) {\n          if (teleport === true || teleport === '') {\n            // Interactive mode: show task selector and handle resume\n            logEvent('tengu_teleport_interactive_mode', {})\n            logForDebugging(\n              'selectAndResumeTeleportTask: Starting teleport flow...',\n            )\n            const teleportResult = await launchTeleportResumeWrapper(root)\n            if (!teleportResult) {\n              // User cancelled or error occurred\n              await gracefulShutdown(0)\n              process.exit(0)\n            }\n            const { branchError } = await checkOutTeleportedSessionBranch(\n              teleportResult.branch,\n            )\n            messages = processMessagesForTeleportResume(\n              teleportResult.log,\n              branchError,\n            )\n          } else if (typeof teleport === 'string') {\n            logEvent('tengu_teleport_resume_session', {\n              mode: 'direct' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n            })\n            try {\n              // First, fetch session and validate repository before checking git state\n              const sessionData = await fetchSession(teleport)\n              const repoValidation =\n                await validateSessionRepository(sessionData)\n\n              // Handle repo mismatch or not in repo cases\n              if (\n                repoValidation.status === 'mismatch' ||\n                repoValidation.status === 'not_in_repo'\n              ) {\n                const sessionRepo = repoValidation.sessionRepo\n                if (sessionRepo) {\n                  // Check for known paths\n                  const knownPaths = getKnownPathsForRepo(sessionRepo)\n                  const existingPaths = await filterExistingPaths(knownPaths)\n\n                  if (existingPaths.length > 0) {\n                    // Show directory switch dialog\n                    const selectedPath = await launchTeleportRepoMismatchDialog(\n                      root,\n                      {\n                        targetRepo: sessionRepo,\n                        initialPaths: existingPaths,\n                      },\n                    )\n\n                    if (selectedPath) {\n                      // Change to the selected directory\n                      process.chdir(selectedPath)\n                      setCwd(selectedPath)\n                      setOriginalCwd(selectedPath)\n                    } else {\n                      // User cancelled\n                      await gracefulShutdown(0)\n                    }\n                  } else {\n                    // No known paths - show original error\n                    throw new TeleportOperationError(\n                      `You must run claude --teleport ${teleport} from a checkout of ${sessionRepo}.`,\n                      chalk.red(\n                        `You must run claude --teleport ${teleport} from a checkout of ${chalk.bold(sessionRepo)}.\\n`,\n                      ),\n                    )\n                  }\n                }\n              } else if (repoValidation.status === 'error') {\n                throw new TeleportOperationError(\n                  repoValidation.errorMessage || 'Failed to validate session',\n                  chalk.red(\n                    `Error: ${repoValidation.errorMessage || 'Failed to validate session'}\\n`,\n                  ),\n                )\n              }\n\n              await validateGitState()\n\n              // Use progress UI for teleport\n              const { teleportWithProgress } = await import(\n                './components/TeleportProgress.js'\n              )\n              const result = await teleportWithProgress(root, teleport)\n              // Track teleported session for reliability logging\n              setTeleportedSessionInfo({ sessionId: teleport })\n              messages = result.messages\n            } catch (error) {\n              if (error instanceof TeleportOperationError) {\n                process.stderr.write(error.formattedMessage + '\\n')\n              } else {\n                logError(error)\n                process.stderr.write(\n                  chalk.red(`Error: ${errorMessage(error)}\\n`),\n                )\n              }\n              await gracefulShutdown(1)\n            }\n          }\n        }\n        if (\"external\" === 'ant') {\n          if (\n            options.resume &&\n            typeof options.resume === 'string' &&\n            !maybeSessionId\n          ) {\n            // Check for ccshare URL (e.g. https://go/ccshare/boris-20260311-211036)\n            const { parseCcshareId, loadCcshare } = await import(\n              './utils/ccshareResume.js'\n            )\n            const ccshareId = parseCcshareId(options.resume)\n            if (ccshareId) {\n              try {\n                const resumeStart = performance.now()\n                const logOption = await loadCcshare(ccshareId)\n                const result = await loadConversationForResume(\n                  logOption,\n                  undefined,\n                )\n                if (result) {\n                  processedResume = await processResumedConversation(\n                    result,\n                    {\n                      forkSession: true,\n                      transcriptPath: result.fullPath,\n                    },\n                    resumeContext,\n                  )\n                  if (processedResume.restoredAgentDef) {\n                    mainThreadAgentDefinition = processedResume.restoredAgentDef\n                  }\n                  logEvent('tengu_session_resumed', {\n                    entrypoint:\n                      'ccshare' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                    success: true,\n                    resume_duration_ms: Math.round(\n                      performance.now() - resumeStart,\n                    ),\n                  })\n                } else {\n                  logEvent('tengu_session_resumed', {\n                    entrypoint:\n                      'ccshare' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                    success: false,\n                  })\n                }\n              } catch (error) {\n                logEvent('tengu_session_resumed', {\n                  entrypoint:\n                    'ccshare' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                  success: false,\n                })\n                logError(error)\n                await exitWithError(\n                  root,\n                  `Unable to resume from ccshare: ${errorMessage(error)}`,\n                  () => gracefulShutdown(1),\n                )\n              }\n            } else {\n              const resolvedPath = resolve(options.resume)\n              try {\n                const resumeStart = performance.now()\n                let logOption\n                try {\n                  // Attempt to load as a transcript file; ENOENT falls through to session-ID handling\n                  logOption = await loadTranscriptFromFile(resolvedPath)\n                } catch (error) {\n                  if (!isENOENT(error)) throw error\n                  // ENOENT: not a file path — fall through to session-ID handling\n                }\n                if (logOption) {\n                  const result = await loadConversationForResume(\n                    logOption,\n                    undefined /* sourceFile */,\n                  )\n                  if (result) {\n                    processedResume = await processResumedConversation(\n                      result,\n                      {\n                        forkSession: !!options.forkSession,\n                        transcriptPath: result.fullPath,\n                      },\n                      resumeContext,\n                    )\n                    if (processedResume.restoredAgentDef) {\n                      mainThreadAgentDefinition =\n                        processedResume.restoredAgentDef\n                    }\n                    logEvent('tengu_session_resumed', {\n                      entrypoint:\n                        'file' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                      success: true,\n                      resume_duration_ms: Math.round(\n                        performance.now() - resumeStart,\n                      ),\n                    })\n                  } else {\n                    logEvent('tengu_session_resumed', {\n                      entrypoint:\n                        'file' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                      success: false,\n                    })\n                  }\n                }\n              } catch (error) {\n                logEvent('tengu_session_resumed', {\n                  entrypoint:\n                    'file' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                  success: false,\n                })\n                logError(error)\n                await exitWithError(\n                  root,\n                  `Unable to load transcript from file: ${options.resume}`,\n                  () => gracefulShutdown(1),\n                )\n              }\n            }\n          }\n        }\n\n        // If not loaded as a file, try as session ID\n        if (maybeSessionId) {\n          // Resume specific session by ID\n          const sessionId = maybeSessionId\n          try {\n            const resumeStart = performance.now()\n            // Use matchedLog if available (for cross-worktree resume by custom title)\n            // Otherwise fall back to sessionId string (for direct UUID resume)\n            const result = await loadConversationForResume(\n              matchedLog ?? sessionId,\n              undefined,\n            )\n\n            if (!result) {\n              logEvent('tengu_session_resumed', {\n                entrypoint:\n                  'cli_flag' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                success: false,\n              })\n              return await exitWithError(\n                root,\n                `No conversation found with session ID: ${sessionId}`,\n              )\n            }\n\n            const fullPath = matchedLog?.fullPath ?? result.fullPath\n            processedResume = await processResumedConversation(\n              result,\n              {\n                forkSession: !!options.forkSession,\n                sessionIdOverride: sessionId,\n                transcriptPath: fullPath,\n              },\n              resumeContext,\n            )\n\n            if (processedResume.restoredAgentDef) {\n              mainThreadAgentDefinition = processedResume.restoredAgentDef\n            }\n            logEvent('tengu_session_resumed', {\n              entrypoint:\n                'cli_flag' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n              success: true,\n              resume_duration_ms: Math.round(performance.now() - resumeStart),\n            })\n          } catch (error) {\n            logEvent('tengu_session_resumed', {\n              entrypoint:\n                'cli_flag' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n              success: false,\n            })\n            logError(error)\n            await exitWithError(root, `Failed to resume session ${sessionId}`)\n          }\n        }\n\n        // Await file downloads before rendering REPL (files must be available)\n        if (fileDownloadPromise) {\n          try {\n            const results = await fileDownloadPromise\n            const failedCount = count(results, r => !r.success)\n            if (failedCount > 0) {\n              process.stderr.write(\n                chalk.yellow(\n                  `Warning: ${failedCount}/${results.length} file(s) failed to download.\\n`,\n                ),\n              )\n            }\n          } catch (error) {\n            return await exitWithError(\n              root,\n              `Error downloading files: ${errorMessage(error)}`,\n            )\n          }\n        }\n\n        // If we have a processed resume or teleport messages, render the REPL\n        const resumeData =\n          processedResume ??\n          (Array.isArray(messages)\n            ? {\n                messages,\n                fileHistorySnapshots: undefined,\n                agentName: undefined,\n                agentColor: undefined as AgentColorName | undefined,\n                restoredAgentDef: mainThreadAgentDefinition,\n                initialState,\n                contentReplacements: undefined,\n              }\n            : undefined)\n        if (resumeData) {\n          maybeActivateProactive(options)\n          maybeActivateBrief(options)\n\n          await launchRepl(\n            root,\n            { getFpsMetrics, stats, initialState: resumeData.initialState },\n            {\n              ...sessionConfig,\n              mainThreadAgentDefinition:\n                resumeData.restoredAgentDef ?? mainThreadAgentDefinition,\n              initialMessages: resumeData.messages,\n              initialFileHistorySnapshots: resumeData.fileHistorySnapshots,\n              initialContentReplacements: resumeData.contentReplacements,\n              initialAgentName: resumeData.agentName,\n              initialAgentColor: resumeData.agentColor,\n            },\n            renderAndRun,\n          )\n        } else {\n          // Show interactive selector (includes same-repo worktrees)\n          // Note: ResumeConversation loads logs internally to ensure proper GC after selection\n          await launchResumeChooser(\n            root,\n            { getFpsMetrics, stats, initialState },\n            getWorktreePaths(getOriginalCwd()),\n            {\n              ...sessionConfig,\n              initialSearchQuery: searchTerm,\n              forkSession: options.forkSession,\n              filterByPr,\n            },\n          )\n        }\n      } else {\n        // Pass unresolved hooks promise to REPL so it can render immediately\n        // instead of blocking ~500ms waiting for SessionStart hooks to finish.\n        // REPL will inject hook messages when they resolve and await them before\n        // the first API call so the model always sees hook context.\n        const pendingHookMessages =\n          hooksPromise && hookMessages.length === 0 ? hooksPromise : undefined\n\n        profileCheckpoint('action_after_hooks')\n        maybeActivateProactive(options)\n        maybeActivateBrief(options)\n        // Persist the current mode for fresh sessions so future resumes know what mode was used\n        if (feature('COORDINATOR_MODE')) {\n          saveMode(\n            coordinatorModeModule?.isCoordinatorMode()\n              ? 'coordinator'\n              : 'normal',\n          )\n        }\n\n        // If launched via a deep link, show a provenance banner so the user\n        // knows the session originated externally. Linux xdg-open and\n        // browsers with \"always allow\" set dispatch the link with no OS-level\n        // confirmation, so this is the only signal the user gets that the\n        // prompt — and the working directory / CLAUDE.md it implies — came\n        // from an external source rather than something they typed.\n        let deepLinkBanner: ReturnType<typeof createSystemMessage> | null = null\n        if (feature('LODESTONE')) {\n          if (options.deepLinkOrigin) {\n            logEvent('tengu_deep_link_opened', {\n              has_prefill: Boolean(options.prefill),\n              has_repo: Boolean(options.deepLinkRepo),\n            })\n            deepLinkBanner = createSystemMessage(\n              buildDeepLinkBanner({\n                cwd: getCwd(),\n                prefillLength: options.prefill?.length,\n                repo: options.deepLinkRepo,\n                lastFetch:\n                  options.deepLinkLastFetch !== undefined\n                    ? new Date(options.deepLinkLastFetch)\n                    : undefined,\n              }),\n              'warning',\n            )\n          } else if (options.prefill) {\n            deepLinkBanner = createSystemMessage(\n              'Launched with a pre-filled prompt — review it before pressing Enter.',\n              'warning',\n            )\n          }\n        }\n        const initialMessages = deepLinkBanner\n          ? [deepLinkBanner, ...hookMessages]\n          : hookMessages.length > 0\n            ? hookMessages\n            : undefined\n\n        await launchRepl(\n          root,\n          { getFpsMetrics, stats, initialState },\n          {\n            ...sessionConfig,\n            initialMessages,\n            pendingHookMessages,\n          },\n          renderAndRun,\n        )\n      }\n    })\n    .version(\n      `${MACRO.VERSION} (Claude Code)`,\n      '-v, --version',\n      'Output the version number',\n    )\n\n  // Worktree flags\n  program.option(\n    '-w, --worktree [name]',\n    'Create a new git worktree for this session (optionally specify a name)',\n  )\n  program.option(\n    '--tmux',\n    'Create a tmux session for the worktree (requires --worktree). Uses iTerm2 native panes when available; use --tmux=classic for traditional tmux.',\n  )\n\n  if (canUserConfigureAdvisor()) {\n    program.addOption(\n      new Option(\n        '--advisor <model>',\n        'Enable the server-side advisor tool with the specified model (alias or full ID).',\n      ).hideHelp(),\n    )\n  }\n\n  if (\"external\" === 'ant') {\n    program.addOption(\n      new Option(\n        '--delegate-permissions',\n        '[ANT-ONLY] Alias for --permission-mode auto.',\n      ).implies({ permissionMode: 'auto' }),\n    )\n    program.addOption(\n      new Option(\n        '--dangerously-skip-permissions-with-classifiers',\n        '[ANT-ONLY] Deprecated alias for --permission-mode auto.',\n      )\n        .hideHelp()\n        .implies({ permissionMode: 'auto' }),\n    )\n    program.addOption(\n      new Option(\n        '--afk',\n        '[ANT-ONLY] Deprecated alias for --permission-mode auto.',\n      )\n        .hideHelp()\n        .implies({ permissionMode: 'auto' }),\n    )\n    program.addOption(\n      new Option(\n        '--tasks [id]',\n        '[ANT-ONLY] Tasks mode: watch for tasks and auto-process them. Optional id is used as both the task list ID and agent ID (defaults to \"tasklist\").',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    program.option(\n      '--agent-teams',\n      '[ANT-ONLY] Force Claude to use multi-agent mode for solving problems',\n      () => true,\n    )\n  }\n\n  if (feature('TRANSCRIPT_CLASSIFIER')) {\n    program.addOption(\n      new Option('--enable-auto-mode', 'Opt in to auto mode').hideHelp(),\n    )\n  }\n\n  if (feature('PROACTIVE') || feature('KAIROS')) {\n    program.addOption(\n      new Option('--proactive', 'Start in proactive autonomous mode'),\n    )\n  }\n\n  if (feature('UDS_INBOX')) {\n    program.addOption(\n      new Option(\n        '--messaging-socket-path <path>',\n        'Unix domain socket path for the UDS messaging server (defaults to a tmp path)',\n      ),\n    )\n  }\n\n  if (feature('KAIROS') || feature('KAIROS_BRIEF')) {\n    program.addOption(\n      new Option(\n        '--brief',\n        'Enable SendUserMessage tool for agent-to-user communication',\n      ),\n    )\n  }\n  if (feature('KAIROS')) {\n    program.addOption(\n      new Option(\n        '--assistant',\n        'Force assistant mode (Agent SDK daemon use)',\n      ).hideHelp(),\n    )\n  }\n  if (feature('KAIROS') || feature('KAIROS_CHANNELS')) {\n    program.addOption(\n      new Option(\n        '--channels <servers...>',\n        'MCP servers whose channel notifications (inbound push) should register this session. Space-separated server names.',\n      ).hideHelp(),\n    )\n    program.addOption(\n      new Option(\n        '--dangerously-load-development-channels <servers...>',\n        'Load channel servers not on the approved allowlist. For local channel development only. Shows a confirmation dialog at startup.',\n      ).hideHelp(),\n    )\n  }\n\n  // Teammate identity options (set by leader when spawning tmux teammates)\n  // These replace the CLAUDE_CODE_* environment variables\n  program.addOption(\n    new Option('--agent-id <id>', 'Teammate agent ID').hideHelp(),\n  )\n  program.addOption(\n    new Option('--agent-name <name>', 'Teammate display name').hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--team-name <name>',\n      'Team name for swarm coordination',\n    ).hideHelp(),\n  )\n  program.addOption(\n    new Option('--agent-color <color>', 'Teammate UI color').hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--plan-mode-required',\n      'Require plan mode before implementation',\n    ).hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--parent-session-id <id>',\n      'Parent session ID for analytics correlation',\n    ).hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--teammate-mode <mode>',\n      'How to spawn teammates: \"tmux\", \"in-process\", or \"auto\"',\n    )\n      .choices(['auto', 'tmux', 'in-process'])\n      .hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--agent-type <type>',\n      'Custom agent type for this teammate',\n    ).hideHelp(),\n  )\n\n  // Enable SDK URL for all builds but hide from help\n  program.addOption(\n    new Option(\n      '--sdk-url <url>',\n      'Use remote WebSocket endpoint for SDK I/O streaming (only with -p and stream-json format)',\n    ).hideHelp(),\n  )\n\n  // Enable teleport/remote flags for all builds but keep them undocumented until GA\n  program.addOption(\n    new Option(\n      '--teleport [session]',\n      'Resume a teleport session, optionally specify session ID',\n    ).hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--remote [description]',\n      'Create a remote session with the given description',\n    ).hideHelp(),\n  )\n  if (feature('BRIDGE_MODE')) {\n    program.addOption(\n      new Option(\n        '--remote-control [name]',\n        'Start an interactive session with Remote Control enabled (optionally named)',\n      )\n        .argParser(value => value || true)\n        .hideHelp(),\n    )\n    program.addOption(\n      new Option('--rc [name]', 'Alias for --remote-control')\n        .argParser(value => value || true)\n        .hideHelp(),\n    )\n  }\n\n  if (feature('HARD_FAIL')) {\n    program.addOption(\n      new Option(\n        '--hard-fail',\n        'Crash on logError calls instead of silently logging',\n      ).hideHelp(),\n    )\n  }\n\n  profileCheckpoint('run_main_options_built')\n\n  // -p/--print mode: skip subcommand registration. The 52 subcommands\n  // (mcp, auth, plugin, skill, task, config, doctor, update, etc.) are\n  // never dispatched in print mode — commander routes the prompt to the\n  // default action. The subcommand registration path was measured at ~65ms\n  // on baseline — mostly the isBridgeEnabled() call (25ms settings Zod parse\n  // + 40ms sync keychain subprocess), both hidden by the try/catch that\n  // always returns false before enableConfigs(). cc:// URLs are rewritten to\n  // `open` at main() line ~851 BEFORE this runs, so argv check is safe here.\n  const isPrintMode =\n    process.argv.includes('-p') || process.argv.includes('--print')\n  const isCcUrl = process.argv.some(\n    a => a.startsWith('cc://') || a.startsWith('cc+unix://'),\n  )\n  if (isPrintMode && !isCcUrl) {\n    profileCheckpoint('run_before_parse')\n    await program.parseAsync(process.argv)\n    profileCheckpoint('run_after_parse')\n    return program\n  }\n\n  // claude mcp\n\n  const mcp = program\n    .command('mcp')\n    .description('Configure and manage MCP servers')\n    .configureHelp(createSortedHelpConfig())\n    .enablePositionalOptions()\n\n  mcp\n    .command('serve')\n    .description(`Start the Claude Code MCP server`)\n    .option('-d, --debug', 'Enable debug mode', () => true)\n    .option(\n      '--verbose',\n      'Override verbose mode setting from config',\n      () => true,\n    )\n    .action(\n      async ({ debug, verbose }: { debug?: boolean; verbose?: boolean }) => {\n        const { mcpServeHandler } = await import('./cli/handlers/mcp.js')\n        await mcpServeHandler({ debug, verbose })\n      },\n    )\n\n  // Register the mcp add subcommand (extracted for testability)\n  registerMcpAddCommand(mcp)\n\n  if (isXaaEnabled()) {\n    registerMcpXaaIdpCommand(mcp)\n  }\n\n  mcp\n    .command('remove <name>')\n    .description('Remove an MCP server')\n    .option(\n      '-s, --scope <scope>',\n      'Configuration scope (local, user, or project) - if not specified, removes from whichever scope it exists in',\n    )\n    .action(async (name: string, options: { scope?: string }) => {\n      const { mcpRemoveHandler } = await import('./cli/handlers/mcp.js')\n      await mcpRemoveHandler(name, options)\n    })\n\n  mcp\n    .command('list')\n    .description(\n      'List configured MCP servers. Note: The workspace trust dialog is skipped and stdio servers from .mcp.json are spawned for health checks. Only use this command in directories you trust.',\n    )\n    .action(async () => {\n      const { mcpListHandler } = await import('./cli/handlers/mcp.js')\n      await mcpListHandler()\n    })\n\n  mcp\n    .command('get <name>')\n    .description(\n      'Get details about an MCP server. Note: The workspace trust dialog is skipped and stdio servers from .mcp.json are spawned for health checks. Only use this command in directories you trust.',\n    )\n    .action(async (name: string) => {\n      const { mcpGetHandler } = await import('./cli/handlers/mcp.js')\n      await mcpGetHandler(name)\n    })\n\n  mcp\n    .command('add-json <name> <json>')\n    .description('Add an MCP server (stdio or SSE) with a JSON string')\n    .option(\n      '-s, --scope <scope>',\n      'Configuration scope (local, user, or project)',\n      'local',\n    )\n    .option(\n      '--client-secret',\n      'Prompt for OAuth client secret (or set MCP_CLIENT_SECRET env var)',\n    )\n    .action(\n      async (\n        name: string,\n        json: string,\n        options: { scope?: string; clientSecret?: true },\n      ) => {\n        const { mcpAddJsonHandler } = await import('./cli/handlers/mcp.js')\n        await mcpAddJsonHandler(name, json, options)\n      },\n    )\n\n  mcp\n    .command('add-from-claude-desktop')\n    .description('Import MCP servers from Claude Desktop (Mac and WSL only)')\n    .option(\n      '-s, --scope <scope>',\n      'Configuration scope (local, user, or project)',\n      'local',\n    )\n    .action(async (options: { scope?: string }) => {\n      const { mcpAddFromDesktopHandler } = await import('./cli/handlers/mcp.js')\n      await mcpAddFromDesktopHandler(options)\n    })\n\n  mcp\n    .command('reset-project-choices')\n    .description(\n      'Reset all approved and rejected project-scoped (.mcp.json) servers within this project',\n    )\n    .action(async () => {\n      const { mcpResetChoicesHandler } = await import('./cli/handlers/mcp.js')\n      await mcpResetChoicesHandler()\n    })\n\n  // claude server\n  if (feature('DIRECT_CONNECT')) {\n    program\n      .command('server')\n      .description('Start a Claude Code session server')\n      .option('--port <number>', 'HTTP port', '0')\n      .option('--host <string>', 'Bind address', '0.0.0.0')\n      .option('--auth-token <token>', 'Bearer token for auth')\n      .option('--unix <path>', 'Listen on a unix domain socket')\n      .option(\n        '--workspace <dir>',\n        'Default working directory for sessions that do not specify cwd',\n      )\n      .option(\n        '--idle-timeout <ms>',\n        'Idle timeout for detached sessions in ms (0 = never expire)',\n        '600000',\n      )\n      .option(\n        '--max-sessions <n>',\n        'Maximum concurrent sessions (0 = unlimited)',\n        '32',\n      )\n      .action(\n        async (opts: {\n          port: string\n          host: string\n          authToken?: string\n          unix?: string\n          workspace?: string\n          idleTimeout: string\n          maxSessions: string\n        }) => {\n          const { randomBytes } = await import('crypto')\n          const { startServer } = await import('./server/server.js')\n          const { SessionManager } = await import('./server/sessionManager.js')\n          const { DangerousBackend } = await import(\n            './server/backends/dangerousBackend.js'\n          )\n          const { printBanner } = await import('./server/serverBanner.js')\n          const { createServerLogger } = await import('./server/serverLog.js')\n          const { writeServerLock, removeServerLock, probeRunningServer } =\n            await import('./server/lockfile.js')\n\n          const existing = await probeRunningServer()\n          if (existing) {\n            process.stderr.write(\n              `A claude server is already running (pid ${existing.pid}) at ${existing.httpUrl}\\n`,\n            )\n            process.exit(1)\n          }\n\n          const authToken =\n            opts.authToken ??\n            `sk-ant-cc-${randomBytes(16).toString('base64url')}`\n\n          const config = {\n            port: parseInt(opts.port, 10),\n            host: opts.host,\n            authToken,\n            unix: opts.unix,\n            workspace: opts.workspace,\n            idleTimeoutMs: parseInt(opts.idleTimeout, 10),\n            maxSessions: parseInt(opts.maxSessions, 10),\n          }\n\n          const backend = new DangerousBackend()\n          const sessionManager = new SessionManager(backend, {\n            idleTimeoutMs: config.idleTimeoutMs,\n            maxSessions: config.maxSessions,\n          })\n          const logger = createServerLogger()\n\n          const server = startServer(config, sessionManager, logger)\n          const actualPort = server.port ?? config.port\n          printBanner(config, authToken, actualPort)\n\n          await writeServerLock({\n            pid: process.pid,\n            port: actualPort,\n            host: config.host,\n            httpUrl: config.unix\n              ? `unix:${config.unix}`\n              : `http://${config.host}:${actualPort}`,\n            startedAt: Date.now(),\n          })\n\n          let shuttingDown = false\n          const shutdown = async () => {\n            if (shuttingDown) return\n            shuttingDown = true\n            // Stop accepting new connections before tearing down sessions.\n            server.stop(true)\n            await sessionManager.destroyAll()\n            await removeServerLock()\n            process.exit(0)\n          }\n          process.once('SIGINT', () => void shutdown())\n          process.once('SIGTERM', () => void shutdown())\n        },\n      )\n  }\n\n  // `claude ssh <host> [dir]` — registered here only so --help shows it.\n  // The actual interactive flow is handled by early argv rewriting in main()\n  // (parallels the DIRECT_CONNECT/cc:// pattern above). If commander reaches\n  // this action it means the argv rewrite didn't fire (e.g. user ran\n  // `claude ssh` with no host) — just print usage.\n  if (feature('SSH_REMOTE')) {\n    program\n      .command('ssh <host> [dir]')\n      .description(\n        'Run Claude Code on a remote host over SSH. Deploys the binary and ' +\n          'tunnels API auth back through your local machine — no remote setup needed.',\n      )\n      .option(\n        '--permission-mode <mode>',\n        'Permission mode for the remote session',\n      )\n      .option(\n        '--dangerously-skip-permissions',\n        'Skip all permission prompts on the remote (dangerous)',\n      )\n      .option(\n        '--local',\n        'e2e test mode — spawn the child CLI locally (skip ssh/deploy). ' +\n          'Exercises the auth proxy and unix-socket plumbing without a remote host.',\n      )\n      .action(async () => {\n        // Argv rewriting in main() should have consumed `ssh <host>` before\n        // commander runs. Reaching here means host was missing or the\n        // rewrite predicate didn't match.\n        process.stderr.write(\n          'Usage: claude ssh <user@host | ssh-config-alias> [dir]\\n\\n' +\n            \"Runs Claude Code on a remote Linux host. You don't need to install\\n\" +\n            'anything on the remote or run `claude auth login` there — the binary is\\n' +\n            'deployed over SSH and API auth tunnels back through your local machine.\\n',\n        )\n        process.exit(1)\n      })\n  }\n\n  // claude connect — subcommand only handles -p (headless) mode.\n  // Interactive mode (without -p) is handled by early argv rewriting in main()\n  // which redirects to the main command with full TUI support.\n  if (feature('DIRECT_CONNECT')) {\n    program\n      .command('open <cc-url>')\n      .description(\n        'Connect to a Claude Code server (internal — use cc:// URLs)',\n      )\n      .option('-p, --print [prompt]', 'Print mode (headless)')\n      .option(\n        '--output-format <format>',\n        'Output format: text, json, stream-json',\n        'text',\n      )\n      .action(\n        async (\n          ccUrl: string,\n          opts: {\n            print?: string | boolean\n            outputFormat: string\n          },\n        ) => {\n          const { parseConnectUrl } = await import(\n            './server/parseConnectUrl.js'\n          )\n          const { serverUrl, authToken } = parseConnectUrl(ccUrl)\n\n          let connectConfig\n          try {\n            const session = await createDirectConnectSession({\n              serverUrl,\n              authToken,\n              cwd: getOriginalCwd(),\n              dangerouslySkipPermissions:\n                _pendingConnect?.dangerouslySkipPermissions,\n            })\n            if (session.workDir) {\n              setOriginalCwd(session.workDir)\n              setCwdState(session.workDir)\n            }\n            setDirectConnectServerUrl(serverUrl)\n            connectConfig = session.config\n          } catch (err) {\n            // biome-ignore lint/suspicious/noConsole: intentional error output\n            console.error(\n              err instanceof DirectConnectError ? err.message : String(err),\n            )\n            process.exit(1)\n          }\n\n          const { runConnectHeadless } = await import(\n            './server/connectHeadless.js'\n          )\n\n          const prompt = typeof opts.print === 'string' ? opts.print : ''\n          const interactive = opts.print === true\n          await runConnectHeadless(\n            connectConfig,\n            prompt,\n            opts.outputFormat,\n            interactive,\n          )\n        },\n      )\n  }\n\n  // claude auth\n\n  const auth = program\n    .command('auth')\n    .description('Manage authentication')\n    .configureHelp(createSortedHelpConfig())\n\n  auth\n    .command('login')\n    .description('Sign in to your Anthropic account')\n    .option('--email <email>', 'Pre-populate email address on the login page')\n    .option('--sso', 'Force SSO login flow')\n    .option(\n      '--console',\n      'Use Anthropic Console (API usage billing) instead of Claude subscription',\n    )\n    .option('--claudeai', 'Use Claude subscription (default)')\n    .action(\n      async ({\n        email,\n        sso,\n        console: useConsole,\n        claudeai,\n      }: {\n        email?: string\n        sso?: boolean\n        console?: boolean\n        claudeai?: boolean\n      }) => {\n        const { authLogin } = await import('./cli/handlers/auth.js')\n        await authLogin({ email, sso, console: useConsole, claudeai })\n      },\n    )\n\n  auth\n    .command('status')\n    .description('Show authentication status')\n    .option('--json', 'Output as JSON (default)')\n    .option('--text', 'Output as human-readable text')\n    .action(async (opts: { json?: boolean; text?: boolean }) => {\n      const { authStatus } = await import('./cli/handlers/auth.js')\n      await authStatus(opts)\n    })\n\n  auth\n    .command('logout')\n    .description('Log out from your Anthropic account')\n    .action(async () => {\n      const { authLogout } = await import('./cli/handlers/auth.js')\n      await authLogout()\n    })\n\n  /**\n   * Helper function to handle marketplace command errors consistently.\n   * Logs the error and exits the process with status 1.\n   * @param error The error that occurred\n   * @param action Description of the action that failed\n   */\n  // Hidden flag on all plugin/marketplace subcommands to target cowork_plugins.\n  const coworkOption = () =>\n    new Option('--cowork', 'Use cowork_plugins directory').hideHelp()\n\n  // Plugin validate command\n  const pluginCmd = program\n    .command('plugin')\n    .alias('plugins')\n    .description('Manage Claude Code plugins')\n    .configureHelp(createSortedHelpConfig())\n\n  pluginCmd\n    .command('validate <path>')\n    .description('Validate a plugin or marketplace manifest')\n    .addOption(coworkOption())\n    .action(async (manifestPath: string, options: { cowork?: boolean }) => {\n      const { pluginValidateHandler } = await import(\n        './cli/handlers/plugins.js'\n      )\n      await pluginValidateHandler(manifestPath, options)\n    })\n\n  // Plugin list command\n  pluginCmd\n    .command('list')\n    .description('List installed plugins')\n    .option('--json', 'Output as JSON')\n    .option(\n      '--available',\n      'Include available plugins from marketplaces (requires --json)',\n    )\n    .addOption(coworkOption())\n    .action(\n      async (options: {\n        json?: boolean\n        available?: boolean\n        cowork?: boolean\n      }) => {\n        const { pluginListHandler } = await import('./cli/handlers/plugins.js')\n        await pluginListHandler(options)\n      },\n    )\n\n  // Marketplace subcommands\n  const marketplaceCmd = pluginCmd\n    .command('marketplace')\n    .description('Manage Claude Code marketplaces')\n    .configureHelp(createSortedHelpConfig())\n\n  marketplaceCmd\n    .command('add <source>')\n    .description('Add a marketplace from a URL, path, or GitHub repo')\n    .addOption(coworkOption())\n    .option(\n      '--sparse <paths...>',\n      'Limit checkout to specific directories via git sparse-checkout (for monorepos). Example: --sparse .claude-plugin plugins',\n    )\n    .option(\n      '--scope <scope>',\n      'Where to declare the marketplace: user (default), project, or local',\n    )\n    .action(\n      async (\n        source: string,\n        options: { cowork?: boolean; sparse?: string[]; scope?: string },\n      ) => {\n        const { marketplaceAddHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await marketplaceAddHandler(source, options)\n      },\n    )\n\n  marketplaceCmd\n    .command('list')\n    .description('List all configured marketplaces')\n    .option('--json', 'Output as JSON')\n    .addOption(coworkOption())\n    .action(async (options: { json?: boolean; cowork?: boolean }) => {\n      const { marketplaceListHandler } = await import(\n        './cli/handlers/plugins.js'\n      )\n      await marketplaceListHandler(options)\n    })\n\n  marketplaceCmd\n    .command('remove <name>')\n    .alias('rm')\n    .description('Remove a configured marketplace')\n    .addOption(coworkOption())\n    .action(async (name: string, options: { cowork?: boolean }) => {\n      const { marketplaceRemoveHandler } = await import(\n        './cli/handlers/plugins.js'\n      )\n      await marketplaceRemoveHandler(name, options)\n    })\n\n  marketplaceCmd\n    .command('update [name]')\n    .description(\n      'Update marketplace(s) from their source - updates all if no name specified',\n    )\n    .addOption(coworkOption())\n    .action(async (name: string | undefined, options: { cowork?: boolean }) => {\n      const { marketplaceUpdateHandler } = await import(\n        './cli/handlers/plugins.js'\n      )\n      await marketplaceUpdateHandler(name, options)\n    })\n\n  // Plugin install command\n  pluginCmd\n    .command('install <plugin>')\n    .alias('i')\n    .description(\n      'Install a plugin from available marketplaces (use plugin@marketplace for specific marketplace)',\n    )\n    .option(\n      '-s, --scope <scope>',\n      'Installation scope: user, project, or local',\n      'user',\n    )\n    .addOption(coworkOption())\n    .action(\n      async (plugin: string, options: { scope?: string; cowork?: boolean }) => {\n        const { pluginInstallHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginInstallHandler(plugin, options)\n      },\n    )\n\n  // Plugin uninstall command\n  pluginCmd\n    .command('uninstall <plugin>')\n    .alias('remove')\n    .alias('rm')\n    .description('Uninstall an installed plugin')\n    .option(\n      '-s, --scope <scope>',\n      'Uninstall from scope: user, project, or local',\n      'user',\n    )\n    .option(\n      '--keep-data',\n      \"Preserve the plugin's persistent data directory (~/.claude/plugins/data/{id}/)\",\n    )\n    .addOption(coworkOption())\n    .action(\n      async (\n        plugin: string,\n        options: { scope?: string; cowork?: boolean; keepData?: boolean },\n      ) => {\n        const { pluginUninstallHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginUninstallHandler(plugin, options)\n      },\n    )\n\n  // Plugin enable command\n  pluginCmd\n    .command('enable <plugin>')\n    .description('Enable a disabled plugin')\n    .option(\n      '-s, --scope <scope>',\n      `Installation scope: ${VALID_INSTALLABLE_SCOPES.join(', ')} (default: auto-detect)`,\n    )\n    .addOption(coworkOption())\n    .action(\n      async (plugin: string, options: { scope?: string; cowork?: boolean }) => {\n        const { pluginEnableHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginEnableHandler(plugin, options)\n      },\n    )\n\n  // Plugin disable command\n  pluginCmd\n    .command('disable [plugin]')\n    .description('Disable an enabled plugin')\n    .option('-a, --all', 'Disable all enabled plugins')\n    .option(\n      '-s, --scope <scope>',\n      `Installation scope: ${VALID_INSTALLABLE_SCOPES.join(', ')} (default: auto-detect)`,\n    )\n    .addOption(coworkOption())\n    .action(\n      async (\n        plugin: string | undefined,\n        options: { scope?: string; cowork?: boolean; all?: boolean },\n      ) => {\n        const { pluginDisableHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginDisableHandler(plugin, options)\n      },\n    )\n\n  // Plugin update command\n  pluginCmd\n    .command('update <plugin>')\n    .description(\n      'Update a plugin to the latest version (restart required to apply)',\n    )\n    .option(\n      '-s, --scope <scope>',\n      `Installation scope: ${VALID_UPDATE_SCOPES.join(', ')} (default: user)`,\n    )\n    .addOption(coworkOption())\n    .action(\n      async (plugin: string, options: { scope?: string; cowork?: boolean }) => {\n        const { pluginUpdateHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginUpdateHandler(plugin, options)\n      },\n    )\n  // END ANT-ONLY\n\n  // Setup token command\n  program\n    .command('setup-token')\n    .description(\n      'Set up a long-lived authentication token (requires Claude subscription)',\n    )\n    .action(async () => {\n      const [{ setupTokenHandler }, { createRoot }] = await Promise.all([\n        import('./cli/handlers/util.js'),\n        import('./ink.js'),\n      ])\n      const root = await createRoot(getBaseRenderOptions(false))\n      await setupTokenHandler(root)\n    })\n\n  // Agents command - list configured agents\n  program\n    .command('agents')\n    .description('List configured agents')\n    .option(\n      '--setting-sources <sources>',\n      'Comma-separated list of setting sources to load (user, project, local).',\n    )\n    .action(async () => {\n      const { agentsHandler } = await import('./cli/handlers/agents.js')\n      await agentsHandler()\n      process.exit(0)\n    })\n\n  if (feature('TRANSCRIPT_CLASSIFIER')) {\n    // Skip when tengu_auto_mode_config.enabled === 'disabled' (circuit breaker).\n    // Reads from disk cache — GrowthBook isn't initialized at registration time.\n    if (getAutoModeEnabledStateIfCached() !== 'disabled') {\n      const autoModeCmd = program\n        .command('auto-mode')\n        .description('Inspect auto mode classifier configuration')\n\n      autoModeCmd\n        .command('defaults')\n        .description(\n          'Print the default auto mode environment, allow, and deny rules as JSON',\n        )\n        .action(async () => {\n          const { autoModeDefaultsHandler } = await import(\n            './cli/handlers/autoMode.js'\n          )\n          autoModeDefaultsHandler()\n          process.exit(0)\n        })\n\n      autoModeCmd\n        .command('config')\n        .description(\n          'Print the effective auto mode config as JSON: your settings where set, defaults otherwise',\n        )\n        .action(async () => {\n          const { autoModeConfigHandler } = await import(\n            './cli/handlers/autoMode.js'\n          )\n          autoModeConfigHandler()\n          process.exit(0)\n        })\n\n      autoModeCmd\n        .command('critique')\n        .description('Get AI feedback on your custom auto mode rules')\n        .option('--model <model>', 'Override which model is used')\n        .action(async options => {\n          const { autoModeCritiqueHandler } = await import(\n            './cli/handlers/autoMode.js'\n          )\n          await autoModeCritiqueHandler(options)\n          process.exit()\n        })\n    }\n  }\n\n  // Remote Control command — connect local environment to claude.ai/code.\n  // The actual command is intercepted by the fast-path in cli.tsx before\n  // Commander.js runs, so this registration exists only for help output.\n  // Always hidden: isBridgeEnabled() at this point (before enableConfigs)\n  // would throw inside isClaudeAISubscriber → getGlobalConfig and return\n  // false via the try/catch — but not before paying ~65ms of side effects\n  // (25ms settings Zod parse + 40ms sync `security` keychain subprocess).\n  // The dynamic visibility never worked; the command was always hidden.\n  if (feature('BRIDGE_MODE')) {\n    program\n      .command('remote-control', { hidden: true })\n      .alias('rc')\n      .description(\n        'Connect your local environment for remote-control sessions via claude.ai/code',\n      )\n      .action(async () => {\n        // Unreachable — cli.tsx fast-path handles this command before main.tsx loads.\n        // If somehow reached, delegate to bridgeMain.\n        const { bridgeMain } = await import('./bridge/bridgeMain.js')\n        await bridgeMain(process.argv.slice(3))\n      })\n  }\n\n  if (feature('KAIROS')) {\n    program\n      .command('assistant [sessionId]')\n      .description(\n        'Attach the REPL as a client to a running bridge session. Discovers sessions via API if no sessionId given.',\n      )\n      .action(() => {\n        // Argv rewriting above should have consumed `assistant [id]`\n        // before commander runs. Reaching here means a root flag came first\n        // (e.g. `--debug assistant`) and the position-0 predicate\n        // didn't match. Print usage like the ssh stub does.\n        process.stderr.write(\n          'Usage: claude assistant [sessionId]\\n\\n' +\n            'Attach the REPL as a viewer client to a running bridge session.\\n' +\n            'Omit sessionId to discover and pick from available sessions.\\n',\n        )\n        process.exit(1)\n      })\n  }\n\n  // Doctor command - check installation health\n  program\n    .command('doctor')\n    .description(\n      'Check the health of your Claude Code auto-updater. Note: The workspace trust dialog is skipped and stdio servers from .mcp.json are spawned for health checks. Only use this command in directories you trust.',\n    )\n    .action(async () => {\n      const [{ doctorHandler }, { createRoot }] = await Promise.all([\n        import('./cli/handlers/util.js'),\n        import('./ink.js'),\n      ])\n      const root = await createRoot(getBaseRenderOptions(false))\n      await doctorHandler(root)\n    })\n\n  // claude update\n  //\n  // For SemVer-compliant versioning with build metadata (X.X.X+SHA):\n  // - We perform exact string comparison (including SHA) to detect any change\n  // - This ensures users always get the latest build, even when only the SHA changes\n  // - UI shows both versions including build metadata for clarity\n  program\n    .command('update')\n    .alias('upgrade')\n    .description('Check for updates and install if available')\n    .action(async () => {\n      const { update } = await import('src/cli/update.js')\n      await update()\n    })\n\n  // claude up — run the project's CLAUDE.md \"# claude up\" setup instructions.\n  if (\"external\" === 'ant') {\n    program\n      .command('up')\n      .description(\n        '[ANT-ONLY] Initialize or upgrade the local dev environment using the \"# claude up\" section of the nearest CLAUDE.md',\n      )\n      .action(async () => {\n        const { up } = await import('src/cli/up.js')\n        await up()\n      })\n  }\n\n  // claude rollback (ant-only)\n  // Rolls back to previous releases\n  if (\"external\" === 'ant') {\n    program\n      .command('rollback [target]')\n      .description(\n        '[ANT-ONLY] Roll back to a previous release\\n\\nExamples:\\n  claude rollback                                    Go 1 version back from current\\n  claude rollback 3                                  Go 3 versions back from current\\n  claude rollback 2.0.73-dev.20251217.t190658        Roll back to a specific version',\n      )\n      .option('-l, --list', 'List recent published versions with ages')\n      .option('--dry-run', 'Show what would be installed without installing')\n      .option(\n        '--safe',\n        'Roll back to the server-pinned safe version (set by oncall during incidents)',\n      )\n      .action(\n        async (\n          target?: string,\n          options?: { list?: boolean; dryRun?: boolean; safe?: boolean },\n        ) => {\n          const { rollback } = await import('src/cli/rollback.js')\n          await rollback(target, options)\n        },\n      )\n  }\n\n  // claude install\n  program\n    .command('install [target]')\n    .description(\n      'Install Claude Code native build. Use [target] to specify version (stable, latest, or specific version)',\n    )\n    .option('--force', 'Force installation even if already installed')\n    .action(\n      async (target: string | undefined, options: { force?: boolean }) => {\n        const { installHandler } = await import('./cli/handlers/util.js')\n        await installHandler(target, options)\n      },\n    )\n\n  // ant-only commands\n  if (\"external\" === 'ant') {\n    const validateLogId = (value: string) => {\n      const maybeSessionId = validateUuid(value)\n      if (maybeSessionId) return maybeSessionId\n      return Number(value)\n    }\n    // claude log\n    program\n      .command('log')\n      .description('[ANT-ONLY] Manage conversation logs.')\n      .argument(\n        '[number|sessionId]',\n        'A number (0, 1, 2, etc.) to display a specific log, or the sesssion ID (uuid) of a log',\n        validateLogId,\n      )\n      .action(async (logId: string | number | undefined) => {\n        const { logHandler } = await import('./cli/handlers/ant.js')\n        await logHandler(logId)\n      })\n\n    // claude error\n    program\n      .command('error')\n      .description(\n        '[ANT-ONLY] View error logs. Optionally provide a number (0, -1, -2, etc.) to display a specific log.',\n      )\n      .argument(\n        '[number]',\n        'A number (0, 1, 2, etc.) to display a specific log',\n        parseInt,\n      )\n      .action(async (number: number | undefined) => {\n        const { errorHandler } = await import('./cli/handlers/ant.js')\n        await errorHandler(number)\n      })\n\n    // claude export\n    program\n      .command('export')\n      .description('[ANT-ONLY] Export a conversation to a text file.')\n      .usage('<source> <outputFile>')\n      .argument(\n        '<source>',\n        'Session ID, log index (0, 1, 2...), or path to a .json/.jsonl log file',\n      )\n      .argument('<outputFile>', 'Output file path for the exported text')\n      .addHelpText(\n        'after',\n        `\nExamples:\n  $ claude export 0 conversation.txt                Export conversation at log index 0\n  $ claude export <uuid> conversation.txt           Export conversation by session ID\n  $ claude export input.json output.txt             Render JSON log file to text\n  $ claude export <uuid>.jsonl output.txt           Render JSONL session file to text`,\n      )\n      .action(async (source: string, outputFile: string) => {\n        const { exportHandler } = await import('./cli/handlers/ant.js')\n        await exportHandler(source, outputFile)\n      })\n\n    if (\"external\" === 'ant') {\n      const taskCmd = program\n        .command('task')\n        .description('[ANT-ONLY] Manage task list tasks')\n\n      taskCmd\n        .command('create <subject>')\n        .description('Create a new task')\n        .option('-d, --description <text>', 'Task description')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .action(\n          async (\n            subject: string,\n            opts: { description?: string; list?: string },\n          ) => {\n            const { taskCreateHandler } = await import('./cli/handlers/ant.js')\n            await taskCreateHandler(subject, opts)\n          },\n        )\n\n      taskCmd\n        .command('list')\n        .description('List all tasks')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .option('--pending', 'Show only pending tasks')\n        .option('--json', 'Output as JSON')\n        .action(\n          async (opts: {\n            list?: string\n            pending?: boolean\n            json?: boolean\n          }) => {\n            const { taskListHandler } = await import('./cli/handlers/ant.js')\n            await taskListHandler(opts)\n          },\n        )\n\n      taskCmd\n        .command('get <id>')\n        .description('Get details of a task')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .action(async (id: string, opts: { list?: string }) => {\n          const { taskGetHandler } = await import('./cli/handlers/ant.js')\n          await taskGetHandler(id, opts)\n        })\n\n      taskCmd\n        .command('update <id>')\n        .description('Update a task')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .option(\n          '-s, --status <status>',\n          `Set status (${TASK_STATUSES.join(', ')})`,\n        )\n        .option('--subject <text>', 'Update subject')\n        .option('-d, --description <text>', 'Update description')\n        .option('--owner <agentId>', 'Set owner')\n        .option('--clear-owner', 'Clear owner')\n        .action(\n          async (\n            id: string,\n            opts: {\n              list?: string\n              status?: string\n              subject?: string\n              description?: string\n              owner?: string\n              clearOwner?: boolean\n            },\n          ) => {\n            const { taskUpdateHandler } = await import('./cli/handlers/ant.js')\n            await taskUpdateHandler(id, opts)\n          },\n        )\n\n      taskCmd\n        .command('dir')\n        .description('Show the tasks directory path')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .action(async (opts: { list?: string }) => {\n          const { taskDirHandler } = await import('./cli/handlers/ant.js')\n          await taskDirHandler(opts)\n        })\n    }\n\n    // claude completion <shell>\n    program\n      .command('completion <shell>', { hidden: true })\n      .description('Generate shell completion script (bash, zsh, or fish)')\n      .option(\n        '--output <file>',\n        'Write completion script directly to a file instead of stdout',\n      )\n      .action(async (shell: string, opts: { output?: string }) => {\n        const { completionHandler } = await import('./cli/handlers/ant.js')\n        await completionHandler(shell, opts, program)\n      })\n  }\n\n  profileCheckpoint('run_before_parse')\n  await program.parseAsync(process.argv)\n  profileCheckpoint('run_after_parse')\n\n  // Record final checkpoint for total_time calculation\n  profileCheckpoint('main_after_run')\n\n  // Log startup perf to Statsig (sampled) and output detailed report if enabled\n  profileReport()\n\n  return program\n}\n\nasync function logTenguInit({\n  hasInitialPrompt,\n  hasStdin,\n  verbose,\n  debug,\n  debugToStderr,\n  print,\n  outputFormat,\n  inputFormat,\n  numAllowedTools,\n  numDisallowedTools,\n  mcpClientCount,\n  worktreeEnabled,\n  skipWebFetchPreflight,\n  githubActionInputs,\n  dangerouslySkipPermissionsPassed,\n  permissionMode,\n  modeIsBypass,\n  allowDangerouslySkipPermissionsPassed,\n  systemPromptFlag,\n  appendSystemPromptFlag,\n  thinkingConfig,\n  assistantActivationPath,\n}: {\n  hasInitialPrompt: boolean\n  hasStdin: boolean\n  verbose: boolean\n  debug: boolean\n  debugToStderr: boolean\n  print: boolean\n  outputFormat: string\n  inputFormat: string\n  numAllowedTools: number\n  numDisallowedTools: number\n  mcpClientCount: number\n  worktreeEnabled: boolean\n  skipWebFetchPreflight: boolean | undefined\n  githubActionInputs: string | undefined\n  dangerouslySkipPermissionsPassed: boolean\n  permissionMode: string\n  modeIsBypass: boolean\n  allowDangerouslySkipPermissionsPassed: boolean\n  systemPromptFlag: 'file' | 'flag' | undefined\n  appendSystemPromptFlag: 'file' | 'flag' | undefined\n  thinkingConfig: ThinkingConfig\n  assistantActivationPath: string | undefined\n}): Promise<void> {\n  try {\n    logEvent('tengu_init', {\n      entrypoint:\n        'claude' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      hasInitialPrompt,\n      hasStdin,\n      verbose,\n      debug,\n      debugToStderr,\n      print,\n      outputFormat:\n        outputFormat as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      inputFormat:\n        inputFormat as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      numAllowedTools,\n      numDisallowedTools,\n      mcpClientCount,\n      worktree: worktreeEnabled,\n      skipWebFetchPreflight,\n      ...(githubActionInputs && {\n        githubActionInputs:\n          githubActionInputs as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      }),\n      dangerouslySkipPermissionsPassed,\n      permissionMode:\n        permissionMode as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      modeIsBypass,\n      inProtectedNamespace: isInProtectedNamespace(),\n      allowDangerouslySkipPermissionsPassed,\n      thinkingType:\n        thinkingConfig.type as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      ...(systemPromptFlag && {\n        systemPromptFlag:\n          systemPromptFlag as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      }),\n      ...(appendSystemPromptFlag && {\n        appendSystemPromptFlag:\n          appendSystemPromptFlag as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      }),\n      is_simple: isBareMode() || undefined,\n      is_coordinator:\n        feature('COORDINATOR_MODE') &&\n        coordinatorModeModule?.isCoordinatorMode()\n          ? true\n          : undefined,\n      ...(assistantActivationPath && {\n        assistantActivationPath:\n          assistantActivationPath as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      }),\n      autoUpdatesChannel: (getInitialSettings().autoUpdatesChannel ??\n        'latest') as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      ...(\"external\" === 'ant'\n        ? (() => {\n            const cwd = getCwd()\n            const gitRoot = findGitRoot(cwd)\n            const rp = gitRoot ? relative(gitRoot, cwd) || '.' : undefined\n            return rp\n              ? {\n                  relativeProjectPath:\n                    rp as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                }\n              : {}\n          })()\n        : {}),\n    })\n  } catch (error) {\n    logError(error)\n  }\n}\n\nfunction maybeActivateProactive(options: unknown): void {\n  if (\n    (feature('PROACTIVE') || feature('KAIROS')) &&\n    ((options as { proactive?: boolean }).proactive ||\n      isEnvTruthy(process.env.CLAUDE_CODE_PROACTIVE))\n  ) {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    const proactiveModule = require('./proactive/index.js')\n    if (!proactiveModule.isProactiveActive()) {\n      proactiveModule.activateProactive('command')\n    }\n  }\n}\n\nfunction maybeActivateBrief(options: unknown): void {\n  if (!(feature('KAIROS') || feature('KAIROS_BRIEF'))) return\n  const briefFlag = (options as { brief?: boolean }).brief\n  const briefEnv = isEnvTruthy(process.env.CLAUDE_CODE_BRIEF)\n  if (!briefFlag && !briefEnv) return\n  // --brief / CLAUDE_CODE_BRIEF are explicit opt-ins: check entitlement,\n  // then set userMsgOptIn to activate the tool + prompt section. The env\n  // var also grants entitlement (isBriefEntitled() reads it), so setting\n  // CLAUDE_CODE_BRIEF=1 alone force-enables for dev/testing — no GB gate\n  // needed. initialIsBriefOnly reads getUserMsgOptIn() directly.\n  // Conditional require: static import would leak the tool name string\n  // into external builds via BriefTool.ts → prompt.ts.\n  /* eslint-disable @typescript-eslint/no-require-imports */\n  const { isBriefEntitled } =\n    require('./tools/BriefTool/BriefTool.js') as typeof import('./tools/BriefTool/BriefTool.js')\n  /* eslint-enable @typescript-eslint/no-require-imports */\n  const entitled = isBriefEntitled()\n  if (entitled) {\n    setUserMsgOptIn(true)\n  }\n  // Fire unconditionally once intent is seen: enabled=false captures the\n  // \"user tried but was gated\" failure mode in Datadog.\n  logEvent('tengu_brief_mode_enabled', {\n    enabled: entitled,\n    gated: !entitled,\n    source: (briefEnv\n      ? 'env'\n      : 'flag') as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  })\n}\n\nfunction resetCursor() {\n  const terminal = process.stderr.isTTY\n    ? process.stderr\n    : process.stdout.isTTY\n      ? process.stdout\n      : undefined\n  terminal?.write(SHOW_CURSOR)\n}\n\ntype TeammateOptions = {\n  agentId?: string\n  agentName?: string\n  teamName?: string\n  agentColor?: string\n  planModeRequired?: boolean\n  parentSessionId?: string\n  teammateMode?: 'auto' | 'tmux' | 'in-process'\n  agentType?: string\n}\n\nfunction extractTeammateOptions(options: unknown): TeammateOptions {\n  if (typeof options !== 'object' || options === null) {\n    return {}\n  }\n  const opts = options as Record<string, unknown>\n  const teammateMode = opts.teammateMode\n  return {\n    agentId: typeof opts.agentId === 'string' ? opts.agentId : undefined,\n    agentName: typeof opts.agentName === 'string' ? opts.agentName : undefined,\n    teamName: typeof opts.teamName === 'string' ? opts.teamName : undefined,\n    agentColor:\n      typeof opts.agentColor === 'string' ? opts.agentColor : undefined,\n    planModeRequired:\n      typeof opts.planModeRequired === 'boolean'\n        ? opts.planModeRequired\n        : undefined,\n    parentSessionId:\n      typeof opts.parentSessionId === 'string'\n        ? opts.parentSessionId\n        : undefined,\n    teammateMode:\n      teammateMode === 'auto' ||\n      teammateMode === 'tmux' ||\n      teammateMode === 'in-process'\n        ? teammateMode\n        : undefined,\n    agentType: typeof opts.agentType === 'string' ? opts.agentType : undefined,\n  }\n}\n"],"mappings":"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","ignoreList":[]} \ No newline at end of file +//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["profileCheckpoint","profileReport","startMdmRawRead","ensureKeychainPrefetchCompleted","startKeychainPrefetch","feature","Command","CommanderCommand","InvalidArgumentError","Option","chalk","readFileSync","mapValues","pickBy","uniqBy","React","getOauthConfig","getRemoteSessionUrl","getSystemContext","getUserContext","init","initializeTelemetryAfterTrust","addToHistory","Root","launchRepl","hasGrowthBookEnvOverride","initializeGrowthBook","refreshGrowthBookAfterAuthChange","fetchBootstrapData","DownloadResult","downloadSessionFiles","FilesApiConfig","parseFileSpecs","prefetchPassesEligibility","prefetchOfficialMcpUrls","McpSdkServerConfig","McpServerConfig","ScopedMcpServerConfig","isPolicyAllowed","loadPolicyLimits","refreshPolicyLimits","waitForPolicyLimitsToLoad","loadRemoteManagedSettings","refreshRemoteManagedSettings","ToolInputJSONSchema","createSyntheticOutputTool","isSyntheticOutputToolEnabled","getTools","canUserConfigureAdvisor","getInitialAdvisorSetting","isAdvisorEnabled","isValidAdvisorModel","modelSupportsAdvisor","isAgentSwarmsEnabled","count","uniq","installAsciicastRecorder","getSubscriptionType","isClaudeAISubscriber","prefetchAwsCredentialsAndBedRockInfoIfSafe","prefetchGcpCredentialsIfSafe","validateForceLoginOrg","checkHasTrustDialogAccepted","getGlobalConfig","getRemoteControlAtStartup","isAutoUpdaterDisabled","saveGlobalConfig","seedEarlyInput","stopCapturingEarlyInput","getInitialEffortSetting","parseEffortValue","getInitialFastModeSetting","isFastModeEnabled","prefetchFastModeStatus","resolveFastModeStatusFromCache","applyConfigEnvironmentVariables","createSystemMessage","createUserMessage","getPlatform","getBaseRenderOptions","getSessionIngressAuthToken","settingsChangeDetector","skillChangeDetector","jsonParse","writeFileSync_DEPRECATED","computeInitialTeamContext","initializeWarningHandler","isWorktreeModeEnabled","getTeammateUtils","require","getTeammatePromptAddendum","getTeammateModeSnapshot","coordinatorModeModule","assistantModule","kairosGate","relative","resolve","isAnalyticsDisabled","getFeatureValue_CACHED_MAY_BE_STALE","AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS","logEvent","initializeAnalyticsGates","getOriginalCwd","setAdditionalDirectoriesForClaudeMd","setIsRemoteMode","setMainLoopModelOverride","setMainThreadAgentType","setTeleportedSessionInfo","filterCommandsForRemoteMode","getCommands","StatsStore","launchAssistantInstallWizard","launchAssistantSessionChooser","launchInvalidSettingsDialog","launchResumeChooser","launchSnapshotUpdateDialog","launchTeleportRepoMismatchDialog","launchTeleportResumeWrapper","SHOW_CURSOR","exitWithError","exitWithMessage","getRenderContext","renderAndRun","showSetupScreens","initBuiltinPlugins","checkQuotaStatus","getMcpToolsCommandsAndResources","prefetchAllMcpResources","VALID_INSTALLABLE_SCOPES","VALID_UPDATE_SCOPES","initBundledSkills","AgentColorName","getActiveAgentsFromList","getAgentDefinitionsWithOverrides","isBuiltInAgent","isCustomAgent","parseAgentsFromJson","LogOption","Message","MessageType","assertMinVersion","CLAUDE_IN_CHROME_SKILL_HINT","CLAUDE_IN_CHROME_SKILL_HINT_WITH_WEBBROWSER","setupClaudeInChrome","shouldAutoEnableClaudeInChrome","shouldEnableClaudeInChrome","getContextWindowForModel","loadConversationForResume","buildDeepLinkBanner","hasNodeOption","isBareMode","isEnvTruthy","isInProtectedNamespace","refreshExampleCommands","FpsMetrics","getWorktreePaths","findGitRoot","getBranch","getIsGit","getWorktreeCount","getGhAuthStatus","safeParseJSON","logError","getModelDeprecationWarning","getDefaultMainLoopModel","getUserSpecifiedModelSetting","normalizeModelStringForAPI","parseUserSpecifiedModel","ensureModelStringsInitialized","PERMISSION_MODES","checkAndDisableBypassPermissions","getAutoModeEnabledStateIfCached","initializeToolPermissionContext","initialPermissionModeFromCLI","isDefaultPermissionModeAuto","parseToolListFromCLI","removeDangerousPermissions","stripDangerousPermissionsForAutoMode","verifyAutoModeGateAccess","cleanupOrphanedPluginVersionsInBackground","initializeVersionedPlugins","getManagedPluginNames","getGlobExclusionsForPluginCache","getPluginSeedDirs","countFilesRoundedRg","processSessionStartHooks","processSetupHooks","cacheSessionTitle","getSessionIdFromLog","loadTranscriptFromFile","saveAgentSetting","saveMode","searchSessionsByCustomTitle","sessionIdExists","ensureMdmSettingsLoaded","getInitialSettings","getManagedSettingsKeysForLogging","getSettingsForSource","getSettingsWithErrors","resetSettingsCache","ValidationError","DEFAULT_TASKS_MODE_TASK_LIST_ID","TASK_STATUSES","logPluginLoadErrors","logPluginsEnabledForSession","logSkillsLoaded","generateTempFilePath","validateUuid","registerMcpAddCommand","registerMcpXaaIdpCommand","logPermissionContextForAnts","fetchClaudeAIMcpConfigsIfEligible","clearServerCache","areMcpConfigsAllowedWithEnterpriseMcpConfig","dedupClaudeAiMcpServers","doesEnterpriseMcpConfigExist","filterMcpServersByPolicy","getClaudeCodeMcpConfigs","getMcpServerSignature","parseMcpConfig","parseMcpConfigFromFilePath","excludeCommandsByServer","excludeResourcesByServer","isXaaEnabled","getRelevantTips","logContextMetrics","CLAUDE_IN_CHROME_MCP_SERVER_NAME","isClaudeInChromeMCPServer","registerCleanup","eagerParseCliFlag","createEmptyAttributionState","countConcurrentSessions","registerSession","updateSessionName","getCwd","logForDebugging","setHasFormattedOutput","errorMessage","getErrnoCode","isENOENT","TeleportOperationError","toError","getFsImplementation","safeResolvePath","gracefulShutdown","gracefulShutdownSync","setAllHookEventsEnabled","refreshModelCapabilities","peekForStdinData","writeToStderr","setCwd","ProcessedResume","processResumedConversation","parseSettingSourcesFlag","plural","ChannelEntry","getInitialMainLoopModel","getIsNonInteractiveSession","getSdkBetas","getSessionId","getUserMsgOptIn","setAllowedChannels","setAllowedSettingSources","setChromeFlagOverride","setClientType","setCwdState","setDirectConnectServerUrl","setFlagSettingsPath","setInitialMainLoopModel","setInlinePlugins","setIsInteractive","setKairosActive","setOriginalCwd","setQuestionPreviewFormat","setSdkBetas","setSessionBypassPermissionsMode","setSessionPersistenceDisabled","setSessionSource","setUserMsgOptIn","switchSession","autoModeStateModule","migrateAutoUpdatesToSettings","migrateBypassPermissionsAcceptedToSettings","migrateEnableAllProjectMcpServersToSettings","migrateFennecToOpus","migrateLegacyOpusToCurrent","migrateOpusToOpus1m","migrateReplBridgeEnabledToRemoteControlAtStartup","migrateSonnet1mToSonnet45","migrateSonnet45ToSonnet46","resetAutoModeOptInForDefaultOffer","resetProToOpusDefault","createRemoteSessionConfig","createDirectConnectSession","DirectConnectError","initializeLspServerManager","shouldEnablePromptSuggestion","AppState","getDefaultAppState","IDLE_SPECULATION_STATE","onChangeAppState","createStore","asSessionId","filterAllowedSdkBetas","isInBundledMode","isRunningWithBun","logForDiagnosticsNoPII","filterExistingPaths","getKnownPathsForRepo","clearPluginCache","loadAllPluginsCacheOnly","migrateChangelogFromConfig","SandboxManager","fetchSession","prepareApiRequest","checkOutTeleportedSessionBranch","processMessagesForTeleportResume","teleportToRemoteWithErrorHandling","validateGitState","validateSessionRepository","shouldEnableThinkingByDefault","ThinkingConfig","initUser","resetUserCache","getTmuxInstallInstructions","isTmuxAvailable","parsePRReference","logManagedSettings","policySettings","allKeys","keyCount","length","keys","join","isBeingDebugged","isBun","hasInspectArg","process","execArgv","some","arg","test","hasInspectEnv","env","NODE_OPTIONS","inspector","global","hasInspectorUrl","url","exit","logSessionTelemetry","model","then","enabled","errors","managedNames","catch","err","getCertEnvVarTelemetry","Record","result","NODE_EXTRA_CA_CERTS","has_node_extra_ca_certs","CLAUDE_CODE_CLIENT_CERT","has_client_cert","has_use_system_ca","has_use_openssl_ca","logStartupTelemetry","Promise","isGit","worktreeCount","ghAuthStatus","all","is_git","worktree_count","gh_auth_status","sandbox_enabled","isSandboxingEnabled","are_unsandboxed_commands_allowed","areUnsandboxedCommandsAllowed","is_auto_bash_allowed_if_sandbox_enabled","isAutoAllowBashIfSandboxedEnabled","auto_updater_disabled","prefers_reduced_motion","prefersReducedMotion","CURRENT_MIGRATION_VERSION","runMigrations","migrationVersion","prev","prefetchSystemContextIfSafe","isNonInteractiveSession","hasTrust","startDeferredPrefetches","CLAUDE_CODE_EXIT_AFTER_FIRST_RENDER","CLAUDE_CODE_USE_BEDROCK","CLAUDE_CODE_SKIP_BEDROCK_AUTH","CLAUDE_CODE_USE_VERTEX","CLAUDE_CODE_SKIP_VERTEX_AUTH","AbortSignal","timeout","initialize","m","startEventLoopStallDetector","loadSettingsFromFlag","settingsFile","trimmedSettings","trim","looksLikeJson","startsWith","endsWith","settingsPath","parsedJson","stderr","write","red","contentHash","resolvedPath","resolvedSettingsPath","e","error","Error","loadSettingSourcesFromFlag","settingSourcesArg","sources","eagerLoadSettings","undefined","initializeEntrypoint","isNonInteractive","CLAUDE_CODE_ENTRYPOINT","cliArgs","argv","slice","mcpIndex","indexOf","CLAUDE_CODE_ACTION","PendingConnect","authToken","dangerouslySkipPermissions","_pendingConnect","PendingAssistantChat","sessionId","discover","_pendingAssistantChat","PendingSSH","host","cwd","permissionMode","local","extraCliArgs","_pendingSSH","main","NoDefaultCurrentDirectoryInExePath","on","resetCursor","includes","rawCliArgs","ccIdx","findIndex","a","ccUrl","parseConnectUrl","parsed","stripped","filter","_","i","dspIdx","splice","serverUrl","handleUriIdx","enableConfigs","uri","handleDeepLinkUri","exitCode","platform","__CFBundleIdentifier","handleUrlSchemeLaunch","urlSchemeResult","rawArgs","nextArg","localIdx","pmIdx","pmEqIdx","split","extractFlag","flag","opts","hasValue","as","push","val","eqI","consumed","rest","hasPrintFlag","hasInitOnlyFlag","hasSdkUrl","stdout","isTTY","isInteractive","clientType","GITHUB_ACTIONS","hasSessionIngressToken","CLAUDE_CODE_SESSION_ACCESS_TOKEN","CLAUDE_CODE_WEBSOCKET_AUTH_FILE_DESCRIPTOR","previewFormat","CLAUDE_CODE_QUESTION_PREVIEW_FORMAT","CLAUDE_CODE_ENVIRONMENT_KIND","run","getInputPrompt","prompt","inputFormat","AsyncIterable","stdin","setEncoding","data","onData","chunk","timedOut","off","Boolean","createSortedHelpConfig","sortSubcommands","sortOptions","getOptionSortKey","opt","long","replace","short","Object","assign","const","compareOptions","b","localeCompare","program","configureHelp","enablePositionalOptions","hook","thisCommand","CLAUDE_CODE_DISABLE_TERMINAL_TITLE","title","initSinks","pluginDir","getOptionValue","Array","isArray","every","p","uploadUserSettingsInBackground","name","description","argument","String","helpOption","option","_value","addOption","argParser","hideHelp","choices","Number","value","amount","isNaN","tokens","isInteger","default","v","n","isFinite","rawValue","toLowerCase","allowed","action","options","bare","CLAUDE_CODE_SIMPLE","console","warn","yellow","kairosEnabled","assistantTeamContext","Awaited","ReturnType","NonNullable","assistant","markAssistantForced","isAssistantMode","agentId","isAssistantForced","isKairosEnabled","brief","initializeAssistantTeam","debug","debugToStderr","allowDangerouslySkipPermissions","tools","baseTools","allowedTools","disallowedTools","mcpConfig","permissionModeCli","addDir","fallbackModel","betas","ide","includeHookEvents","includePartialMessages","prefill","fileDownloadPromise","agentsJson","agents","agentCli","agent","CLAUDE_CODE_AGENT","outputFormat","verbose","print","initOnly","maintenance","disableSlashCommands","tasksOption","tasks","taskListId","CLAUDE_CODE_TASK_LIST_ID","worktreeOption","worktree","worktreeName","worktreeEnabled","worktreePRNumber","prNum","tmuxEnabled","tmux","storedTeammateOpts","TeammateOptions","teammateOpts","extractTeammateOptions","hasAnyTeammateOpt","agentName","teamName","hasAllRequiredTeammateOpts","setDynamicTeamContext","color","agentColor","planModeRequired","parentSessionId","teammateMode","setCliTeammateModeOverride","sdkUrl","effectiveIncludePartialMessages","CLAUDE_CODE_INCLUDE_PARTIAL_MESSAGES","CLAUDE_CODE_REMOTE","teleport","remoteOption","remote","remoteControlOption","remoteControl","rc","remoteControlName","continue","resume","forkSession","validatedSessionId","fileSpecs","file","sessionToken","fileSessionId","CLAUDE_CODE_REMOTE_SESSION_ID","files","config","baseUrl","ANTHROPIC_BASE_URL","BASE_API_URL","oauthToken","systemPrompt","systemPromptFile","filePath","code","appendSystemPrompt","appendSystemPromptFile","addendum","TEAMMATE_SYSTEM_PROMPT_ADDENDUM","mode","notification","permissionModeNotification","enableAutoMode","setAutoModeFlagCli","dynamicMcpConfig","processedConfigs","map","allConfigs","allErrors","configItem","configs","configObject","expandVars","scope","mcpServers","configPath","formattedErrors","path","message","level","nonSdkConfigNames","entries","type","reservedNameError","isComputerUseMCPServer","COMPUTER_USE_MCP_SERVER_NAME","scopedConfigs","blocked","chromeOpts","chrome","enableClaudeInChrome","autoEnableClaudeInChrome","chromeMcpConfig","chromeMcpTools","chromeSystemPrompt","hint","Bun","strictMcpConfig","getChicagoEnabled","setupComputerUseMCP","cuTools","devChannels","parseChannelEntries","raw","bad","c","at","kind","marketplace","channelOpts","channels","dangerouslyLoadDevelopmentChannels","rawChannels","rawDev","channelEntries","joinPluginIds","ids","flatMap","sort","channels_count","dev_count","plugins","dev_plugins","BRIEF_TOOL_NAME","LEGACY_BRIEF_TOOL_NAME","isBriefEntitled","initResult","allowedToolsCli","disallowedToolsCli","baseToolsCli","addDirs","toolPermissionContext","warnings","dangerousPermissions","overlyBroadBashPermissions","permission","ruleDisplay","sourceDisplay","forEach","warning","claudeaiConfigPromise","mcpConfigStart","Date","now","mcpConfigResolvedMs","mcpConfigPromise","servers","replayUserMessages","sessionPersistence","effectivePrompt","inputPrompt","maybeActivateProactive","CLAUDE_CODE_COORDINATOR_MODE","applyCoordinatorToolFilter","jsonSchema","syntheticOutputResult","tool","schema_property_count","properties","has_required_fields","required","setupStart","setup","messagingSocketPath","preSetupCwd","setupPromise","commandsPromise","agentDefsPromise","effectiveReplayUserMessages","sessionNameArg","explicitModel","ANTHROPIC_MODEL","cachedGrowthBookFeatures","userSpecifiedModel","userSpecifiedFallbackModel","currentCwd","commandsStart","commands","agentDefinitionsResult","cliAgents","activeAgents","parsedAgents","allAgents","agentDefinitions","agentSetting","mainThreadAgentDefinition","find","agentType","source","agentSystemPrompt","getSystemPrompt","initialPrompt","effectiveModel","initialMainLoopModel","resolvedInitialModel","advisorModel","advisorOption","advisor","normalizedAdvisorModel","customAgent","customPrompt","memory","agent_type","customInstructions","maybeActivateBrief","defaultView","proactive","CLAUDE_CODE_PROACTIVE","isCoordinatorMode","briefVisibility","isBriefEnabled","proactivePrompt","assistantAddendum","getAssistantSystemPromptAddendum","root","getFpsMetrics","stats","ctx","createRoot","renderOptions","event","durationMs","Math","round","uptime","setupScreensStart","onboardingShown","getBridgeDisabledReason","disabledReason","pendingSnapshotUpdate","agentDef","choice","snapshotTimestamp","buildMergePrompt","mergePrompt","clearTrustedDeviceToken","enrollTrustedDevice","orgValidation","valid","nonMcpErrors","mcpErrorMetadata","settingsErrors","onExit","bgRefreshThrottleMs","lastPrefetched","startupPrefetchedAt","skipStartupPrefetches","lastPrefetchedInfo","current","existingMcpConfigs","allMcpConfigs","sdkMcpConfigs","regularMcpConfigs","typedConfig","localMcpPromise","clients","claudeaiMcpPromise","mcpPromise","claudeai","hooksPromise","hookMessages","mcpClients","mcpTools","mcpCommands","thinkingEnabled","thinkingConfig","thinking","maxThinkingTokens","MAX_THINKING_TOKENS","parseInt","budgetTokens","version","MACRO","VERSION","is_native_binary","logTenguInit","hasInitialPrompt","hasStdin","numAllowedTools","numDisallowedTools","mcpClientCount","skipWebFetchPreflight","githubActionInputs","GITHUB_ACTION_INPUTS","dangerouslySkipPermissionsPassed","modeIsBypass","allowDangerouslySkipPermissionsPassed","systemPromptFlag","appendSystemPromptFlag","assistantActivationPath","getAssistantActivationPath","registered","num_sessions","setupTrigger","forceSyncExecution","sessionStartHooksPromise","commandsHeadless","command","disableNonInteractive","supportsNonInteractive","defaultState","headlessInitialState","mcp","effortValue","effort","fastMode","headlessStore","getState","updateContext","setState","nextCtx","connectMcpBatch","label","client","CLAUDE_AI_MCP_TIMEOUT_MS","claudeaiConnect","claudeaiConfigs","claudeaiSigs","Set","values","sig","add","suppressed","has","size","onclose","resources","t","mcpInfo","serverName","nonPluginConfigs","dedupedClaudeAi","claudeaiTimer","setTimeout","claudeaiTimedOut","race","r","clearTimeout","startBackgroundHousekeeping","startSdkMemoryMonitor","runHeadless","permissionPromptToolName","permissionPromptTool","maxTurns","maxBudgetUsd","taskBudget","total","resumeSessionAt","rewindFiles","enableAuthStatus","workload","cli_flag","env_var","settings_file","subscriptionType","deprecationWarning","initialNotifications","key","text","priority","displayList","displays","effectiveToolPermissionContext","isPlanModeRequired","initialIsBriefOnly","fullRemoteControl","ccrMirrorEnabled","isCcrMirrorEnabled","initialState","settings","agentNameRegistry","Map","mainLoopModel","mainLoopModelForSession","isBriefOnly","expandedView","showSpinnerTree","showExpandedTodos","showTeammateMessagePreview","selectedIPAgentIndex","coordinatorTaskIndex","viewSelectionMode","footerSelection","pluginReconnectKey","disabled","installationStatus","marketplaces","needsRefresh","statusLineText","remoteSessionUrl","remoteConnectionStatus","remoteBackgroundTaskCount","replBridgeEnabled","replBridgeExplicit","replBridgeOutboundOnly","replBridgeConnected","replBridgeSessionActive","replBridgeReconnecting","replBridgeConnectUrl","replBridgeSessionUrl","replBridgeEnvironmentId","replBridgeSessionId","replBridgeError","replBridgeInitialName","showRemoteCallout","notifications","queue","elicitation","todos","remoteAgentTaskSuggestions","fileHistory","snapshots","trackedFiles","snapshotSequence","attribution","promptSuggestionEnabled","sessionHooks","inbox","messages","promptSuggestion","promptId","shownAt","acceptedAt","generationRequestId","speculation","speculationSessionTimeSavedMs","skillImprovement","suggestion","workerSandboxPermissions","selectedIndex","pendingWorkerRequest","pendingSandboxRequest","authVersion","initialMessage","content","activeOverlays","teamContext","initialTools","numStartups","setImmediate","sessionUploaderPromise","uploaderReady","mod","createSessionTurnUploader","sessionConfig","autoConnectIdeFlag","onTurnComplete","uploader","resumeContext","modeApi","resumeSucceeded","resumeStart","performance","clearSessionCaches","success","loaded","includeAttribution","transcriptPath","fullPath","restoredAgentDef","resume_duration_ms","initialMessages","initialFileHistorySnapshots","fileHistorySnapshots","initialContentReplacements","contentReplacements","initialAgentName","initialAgentColor","directConnectConfig","session","workDir","connectInfoMessage","createSSHSession","createLocalSSHSession","SSHSessionError","sshSession","hadProgress","localVersion","onProgress","msg","remoteCwd","sshInfoMessage","discoverAssistantSessions","targetSessionId","sessions","installedDir","beforeExit","id","picked","checkAndRefreshOAuthTokenIfNeeded","getClaudeAIOAuthTokens","apiCreds","getAccessToken","accessToken","remoteSessionConfig","orgUUID","infoMessage","assistantInitialState","remoteCommands","fromPr","processedResume","maybeSessionId","searchTerm","matchedLog","filterByPr","trimmedValue","matches","exact","isRemoteTuiEnabled","has_initial_prompt","currentBranch","createdSession","AbortController","signal","session_id","getTokensForRemote","getAccessTokenForRemote","remoteInfoMessage","initialUserMessage","remoteInitialState","teleportResult","branchError","branch","log","sessionData","repoValidation","status","sessionRepo","knownPaths","existingPaths","selectedPath","targetRepo","initialPaths","chdir","bold","teleportWithProgress","formattedMessage","parseCcshareId","loadCcshare","ccshareId","logOption","entrypoint","sessionIdOverride","results","failedCount","resumeData","initialSearchQuery","pendingHookMessages","deepLinkBanner","deepLinkOrigin","has_prefill","has_repo","deepLinkRepo","prefillLength","repo","lastFetch","deepLinkLastFetch","implies","isPrintMode","isCcUrl","parseAsync","mcpServeHandler","mcpRemoveHandler","mcpListHandler","mcpGetHandler","json","clientSecret","mcpAddJsonHandler","mcpAddFromDesktopHandler","mcpResetChoicesHandler","port","unix","workspace","idleTimeout","maxSessions","randomBytes","startServer","SessionManager","DangerousBackend","printBanner","createServerLogger","writeServerLock","removeServerLock","probeRunningServer","existing","pid","httpUrl","toString","idleTimeoutMs","backend","sessionManager","logger","server","actualPort","startedAt","shuttingDown","shutdown","stop","destroyAll","once","connectConfig","runConnectHeadless","interactive","auth","email","sso","useConsole","authLogin","authStatus","authLogout","coworkOption","pluginCmd","alias","manifestPath","cowork","pluginValidateHandler","available","pluginListHandler","marketplaceCmd","sparse","marketplaceAddHandler","marketplaceListHandler","marketplaceRemoveHandler","marketplaceUpdateHandler","plugin","pluginInstallHandler","keepData","pluginUninstallHandler","pluginEnableHandler","pluginDisableHandler","pluginUpdateHandler","setupTokenHandler","agentsHandler","autoModeCmd","autoModeDefaultsHandler","autoModeConfigHandler","autoModeCritiqueHandler","hidden","bridgeMain","doctorHandler","update","up","target","list","dryRun","safe","rollback","force","installHandler","validateLogId","logId","logHandler","number","errorHandler","usage","addHelpText","outputFile","exportHandler","taskCmd","subject","taskCreateHandler","pending","taskListHandler","taskGetHandler","owner","clearOwner","taskUpdateHandler","taskDirHandler","shell","output","completionHandler","inProtectedNamespace","thinkingType","is_simple","is_coordinator","autoUpdatesChannel","gitRoot","rp","relativeProjectPath","proactiveModule","isProactiveActive","activateProactive","briefFlag","briefEnv","CLAUDE_CODE_BRIEF","entitled","gated","terminal"],"sources":["main.tsx"],"sourcesContent":["// These side-effects must run before all other imports:\n// 1. profileCheckpoint marks entry before heavy module evaluation begins\n// 2. startMdmRawRead fires MDM subprocesses (plutil/reg query) so they run in\n//    parallel with the remaining ~135ms of imports below\n// 3. startKeychainPrefetch fires both macOS keychain reads (OAuth + legacy API\n//    key) in parallel — isRemoteManagedSettingsEligible() otherwise reads them\n//    sequentially via sync spawn inside applySafeConfigEnvironmentVariables()\n//    (~65ms on every macOS startup)\nimport { profileCheckpoint, profileReport } from './utils/startupProfiler.js'\n\n// eslint-disable-next-line custom-rules/no-top-level-side-effects\nprofileCheckpoint('main_tsx_entry')\n\nimport { startMdmRawRead } from './utils/settings/mdm/rawRead.js'\n\n// eslint-disable-next-line custom-rules/no-top-level-side-effects\nstartMdmRawRead()\n\nimport {\n  ensureKeychainPrefetchCompleted,\n  startKeychainPrefetch,\n} from './utils/secureStorage/keychainPrefetch.js'\n\n// eslint-disable-next-line custom-rules/no-top-level-side-effects\nstartKeychainPrefetch()\n\nimport { feature } from 'bun:bundle'\nimport {\n  Command as CommanderCommand,\n  InvalidArgumentError,\n  Option,\n} from '@commander-js/extra-typings'\nimport chalk from 'chalk'\nimport { readFileSync } from 'fs'\nimport mapValues from 'lodash-es/mapValues.js'\nimport pickBy from 'lodash-es/pickBy.js'\nimport uniqBy from 'lodash-es/uniqBy.js'\nimport React from 'react'\nimport { getOauthConfig } from './constants/oauth.js'\nimport { getRemoteSessionUrl } from './constants/product.js'\nimport { getSystemContext, getUserContext } from './context.js'\nimport { init, initializeTelemetryAfterTrust } from './entrypoints/init.js'\nimport { addToHistory } from './history.js'\nimport type { Root } from './ink.js'\nimport { launchRepl } from './replLauncher.js'\nimport {\n  hasGrowthBookEnvOverride,\n  initializeGrowthBook,\n  refreshGrowthBookAfterAuthChange,\n} from './services/analytics/growthbook.js'\nimport { fetchBootstrapData } from './services/api/bootstrap.js'\nimport {\n  type DownloadResult,\n  downloadSessionFiles,\n  type FilesApiConfig,\n  parseFileSpecs,\n} from './services/api/filesApi.js'\nimport { prefetchPassesEligibility } from './services/api/referral.js'\nimport { prefetchOfficialMcpUrls } from './services/mcp/officialRegistry.js'\nimport type {\n  McpSdkServerConfig,\n  McpServerConfig,\n  ScopedMcpServerConfig,\n} from './services/mcp/types.js'\nimport {\n  isPolicyAllowed,\n  loadPolicyLimits,\n  refreshPolicyLimits,\n  waitForPolicyLimitsToLoad,\n} from './services/policyLimits/index.js'\nimport {\n  loadRemoteManagedSettings,\n  refreshRemoteManagedSettings,\n} from './services/remoteManagedSettings/index.js'\nimport type { ToolInputJSONSchema } from './Tool.js'\nimport {\n  createSyntheticOutputTool,\n  isSyntheticOutputToolEnabled,\n} from './tools/SyntheticOutputTool/SyntheticOutputTool.js'\nimport { getTools } from './tools.js'\nimport {\n  canUserConfigureAdvisor,\n  getInitialAdvisorSetting,\n  isAdvisorEnabled,\n  isValidAdvisorModel,\n  modelSupportsAdvisor,\n} from './utils/advisor.js'\nimport { isAgentSwarmsEnabled } from './utils/agentSwarmsEnabled.js'\nimport { count, uniq } from './utils/array.js'\nimport { installAsciicastRecorder } from './utils/asciicast.js'\nimport {\n  getSubscriptionType,\n  isClaudeAISubscriber,\n  prefetchAwsCredentialsAndBedRockInfoIfSafe,\n  prefetchGcpCredentialsIfSafe,\n  validateForceLoginOrg,\n} from './utils/auth.js'\nimport {\n  checkHasTrustDialogAccepted,\n  getGlobalConfig,\n  getRemoteControlAtStartup,\n  isAutoUpdaterDisabled,\n  saveGlobalConfig,\n} from './utils/config.js'\nimport { seedEarlyInput, stopCapturingEarlyInput } from './utils/earlyInput.js'\nimport { getInitialEffortSetting, parseEffortValue } from './utils/effort.js'\nimport {\n  getInitialFastModeSetting,\n  isFastModeEnabled,\n  prefetchFastModeStatus,\n  resolveFastModeStatusFromCache,\n} from './utils/fastMode.js'\nimport { applyConfigEnvironmentVariables } from './utils/managedEnv.js'\nimport { createSystemMessage, createUserMessage } from './utils/messages.js'\nimport { getPlatform } from './utils/platform.js'\nimport { getBaseRenderOptions } from './utils/renderOptions.js'\nimport { getSessionIngressAuthToken } from './utils/sessionIngressAuth.js'\nimport { settingsChangeDetector } from './utils/settings/changeDetector.js'\nimport { skillChangeDetector } from './utils/skills/skillChangeDetector.js'\nimport { jsonParse, writeFileSync_DEPRECATED } from './utils/slowOperations.js'\nimport { computeInitialTeamContext } from './utils/swarm/reconnection.js'\nimport { initializeWarningHandler } from './utils/warningHandler.js'\nimport { isWorktreeModeEnabled } from './utils/worktreeModeEnabled.js'\n\n// Lazy require to avoid circular dependency: teammate.ts -> AppState.tsx -> ... -> main.tsx\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst getTeammateUtils = () =>\n  require('./utils/teammate.js') as typeof import('./utils/teammate.js')\nconst getTeammatePromptAddendum = () =>\n  require('./utils/swarm/teammatePromptAddendum.js') as typeof import('./utils/swarm/teammatePromptAddendum.js')\nconst getTeammateModeSnapshot = () =>\n  require('./utils/swarm/backends/teammateModeSnapshot.js') as typeof import('./utils/swarm/backends/teammateModeSnapshot.js')\n/* eslint-enable @typescript-eslint/no-require-imports */\n// Dead code elimination: conditional import for COORDINATOR_MODE\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst coordinatorModeModule = feature('COORDINATOR_MODE')\n  ? (require('./coordinator/coordinatorMode.js') as typeof import('./coordinator/coordinatorMode.js'))\n  : null\n/* eslint-enable @typescript-eslint/no-require-imports */\n// Dead code elimination: conditional import for KAIROS (assistant mode)\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst assistantModule = feature('KAIROS')\n  ? (require('./assistant/index.js') as typeof import('./assistant/index.js'))\n  : null\nconst kairosGate = feature('KAIROS')\n  ? (require('./assistant/gate.js') as typeof import('./assistant/gate.js'))\n  : null\n\nimport { relative, resolve } from 'path'\nimport { isAnalyticsDisabled } from 'src/services/analytics/config.js'\nimport { getFeatureValue_CACHED_MAY_BE_STALE } from 'src/services/analytics/growthbook.js'\nimport {\n  type AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  logEvent,\n} from 'src/services/analytics/index.js'\nimport { initializeAnalyticsGates } from 'src/services/analytics/sink.js'\nimport {\n  getOriginalCwd,\n  setAdditionalDirectoriesForClaudeMd,\n  setIsRemoteMode,\n  setMainLoopModelOverride,\n  setMainThreadAgentType,\n  setTeleportedSessionInfo,\n} from './bootstrap/state.js'\nimport { filterCommandsForRemoteMode, getCommands } from './commands.js'\nimport type { StatsStore } from './context/stats.js'\nimport {\n  launchAssistantInstallWizard,\n  launchAssistantSessionChooser,\n  launchInvalidSettingsDialog,\n  launchResumeChooser,\n  launchSnapshotUpdateDialog,\n  launchTeleportRepoMismatchDialog,\n  launchTeleportResumeWrapper,\n} from './dialogLaunchers.js'\nimport { SHOW_CURSOR } from './ink/termio/dec.js'\nimport {\n  exitWithError,\n  exitWithMessage,\n  getRenderContext,\n  renderAndRun,\n  showSetupScreens,\n} from './interactiveHelpers.js'\nimport { initBuiltinPlugins } from './plugins/bundled/index.js'\n/* eslint-enable @typescript-eslint/no-require-imports */\nimport { checkQuotaStatus } from './services/claudeAiLimits.js'\nimport {\n  getMcpToolsCommandsAndResources,\n  prefetchAllMcpResources,\n} from './services/mcp/client.js'\nimport {\n  VALID_INSTALLABLE_SCOPES,\n  VALID_UPDATE_SCOPES,\n} from './services/plugins/pluginCliCommands.js'\nimport { initBundledSkills } from './skills/bundled/index.js'\nimport type { AgentColorName } from './tools/AgentTool/agentColorManager.js'\nimport {\n  getActiveAgentsFromList,\n  getAgentDefinitionsWithOverrides,\n  isBuiltInAgent,\n  isCustomAgent,\n  parseAgentsFromJson,\n} from './tools/AgentTool/loadAgentsDir.js'\nimport type { LogOption } from './types/logs.js'\nimport type { Message as MessageType } from './types/message.js'\nimport { assertMinVersion } from './utils/autoUpdater.js'\nimport {\n  CLAUDE_IN_CHROME_SKILL_HINT,\n  CLAUDE_IN_CHROME_SKILL_HINT_WITH_WEBBROWSER,\n} from './utils/claudeInChrome/prompt.js'\nimport {\n  setupClaudeInChrome,\n  shouldAutoEnableClaudeInChrome,\n  shouldEnableClaudeInChrome,\n} from './utils/claudeInChrome/setup.js'\nimport { getContextWindowForModel } from './utils/context.js'\nimport { loadConversationForResume } from './utils/conversationRecovery.js'\nimport { buildDeepLinkBanner } from './utils/deepLink/banner.js'\nimport {\n  hasNodeOption,\n  isBareMode,\n  isEnvTruthy,\n  isInProtectedNamespace,\n} from './utils/envUtils.js'\nimport { refreshExampleCommands } from './utils/exampleCommands.js'\nimport type { FpsMetrics } from './utils/fpsTracker.js'\nimport { getWorktreePaths } from './utils/getWorktreePaths.js'\nimport {\n  findGitRoot,\n  getBranch,\n  getIsGit,\n  getWorktreeCount,\n} from './utils/git.js'\nimport { getGhAuthStatus } from './utils/github/ghAuthStatus.js'\nimport { safeParseJSON } from './utils/json.js'\nimport { logError } from './utils/log.js'\nimport { getModelDeprecationWarning } from './utils/model/deprecation.js'\nimport {\n  getDefaultMainLoopModel,\n  getUserSpecifiedModelSetting,\n  normalizeModelStringForAPI,\n  parseUserSpecifiedModel,\n} from './utils/model/model.js'\nimport { ensureModelStringsInitialized } from './utils/model/modelStrings.js'\nimport { PERMISSION_MODES } from './utils/permissions/PermissionMode.js'\nimport {\n  checkAndDisableBypassPermissions,\n  getAutoModeEnabledStateIfCached,\n  initializeToolPermissionContext,\n  initialPermissionModeFromCLI,\n  isDefaultPermissionModeAuto,\n  parseToolListFromCLI,\n  removeDangerousPermissions,\n  stripDangerousPermissionsForAutoMode,\n  verifyAutoModeGateAccess,\n} from './utils/permissions/permissionSetup.js'\nimport { cleanupOrphanedPluginVersionsInBackground } from './utils/plugins/cacheUtils.js'\nimport { initializeVersionedPlugins } from './utils/plugins/installedPluginsManager.js'\nimport { getManagedPluginNames } from './utils/plugins/managedPlugins.js'\nimport { getGlobExclusionsForPluginCache } from './utils/plugins/orphanedPluginFilter.js'\nimport { getPluginSeedDirs } from './utils/plugins/pluginDirectories.js'\nimport { countFilesRoundedRg } from './utils/ripgrep.js'\nimport {\n  processSessionStartHooks,\n  processSetupHooks,\n} from './utils/sessionStart.js'\nimport {\n  cacheSessionTitle,\n  getSessionIdFromLog,\n  loadTranscriptFromFile,\n  saveAgentSetting,\n  saveMode,\n  searchSessionsByCustomTitle,\n  sessionIdExists,\n} from './utils/sessionStorage.js'\nimport { ensureMdmSettingsLoaded } from './utils/settings/mdm/settings.js'\nimport {\n  getInitialSettings,\n  getManagedSettingsKeysForLogging,\n  getSettingsForSource,\n  getSettingsWithErrors,\n} from './utils/settings/settings.js'\nimport { resetSettingsCache } from './utils/settings/settingsCache.js'\nimport type { ValidationError } from './utils/settings/validation.js'\nimport {\n  DEFAULT_TASKS_MODE_TASK_LIST_ID,\n  TASK_STATUSES,\n} from './utils/tasks.js'\nimport {\n  logPluginLoadErrors,\n  logPluginsEnabledForSession,\n} from './utils/telemetry/pluginTelemetry.js'\nimport { logSkillsLoaded } from './utils/telemetry/skillLoadedEvent.js'\nimport { generateTempFilePath } from './utils/tempfile.js'\nimport { validateUuid } from './utils/uuid.js'\n// Plugin startup checks are now handled non-blockingly in REPL.tsx\n\nimport { registerMcpAddCommand } from 'src/commands/mcp/addCommand.js'\nimport { registerMcpXaaIdpCommand } from 'src/commands/mcp/xaaIdpCommand.js'\nimport { logPermissionContextForAnts } from 'src/services/internalLogging.js'\nimport { fetchClaudeAIMcpConfigsIfEligible } from 'src/services/mcp/claudeai.js'\nimport { clearServerCache } from 'src/services/mcp/client.js'\nimport {\n  areMcpConfigsAllowedWithEnterpriseMcpConfig,\n  dedupClaudeAiMcpServers,\n  doesEnterpriseMcpConfigExist,\n  filterMcpServersByPolicy,\n  getClaudeCodeMcpConfigs,\n  getMcpServerSignature,\n  parseMcpConfig,\n  parseMcpConfigFromFilePath,\n} from 'src/services/mcp/config.js'\nimport {\n  excludeCommandsByServer,\n  excludeResourcesByServer,\n} from 'src/services/mcp/utils.js'\nimport { isXaaEnabled } from 'src/services/mcp/xaaIdpLogin.js'\nimport { getRelevantTips } from 'src/services/tips/tipRegistry.js'\nimport { logContextMetrics } from 'src/utils/api.js'\nimport {\n  CLAUDE_IN_CHROME_MCP_SERVER_NAME,\n  isClaudeInChromeMCPServer,\n} from 'src/utils/claudeInChrome/common.js'\nimport { registerCleanup } from 'src/utils/cleanupRegistry.js'\nimport { eagerParseCliFlag } from 'src/utils/cliArgs.js'\nimport { createEmptyAttributionState } from 'src/utils/commitAttribution.js'\nimport {\n  countConcurrentSessions,\n  registerSession,\n  updateSessionName,\n} from 'src/utils/concurrentSessions.js'\nimport { getCwd } from 'src/utils/cwd.js'\nimport { logForDebugging, setHasFormattedOutput } from 'src/utils/debug.js'\nimport {\n  errorMessage,\n  getErrnoCode,\n  isENOENT,\n  TeleportOperationError,\n  toError,\n} from 'src/utils/errors.js'\nimport { getFsImplementation, safeResolvePath } from 'src/utils/fsOperations.js'\nimport {\n  gracefulShutdown,\n  gracefulShutdownSync,\n} from 'src/utils/gracefulShutdown.js'\nimport { setAllHookEventsEnabled } from 'src/utils/hooks/hookEvents.js'\nimport { refreshModelCapabilities } from 'src/utils/model/modelCapabilities.js'\nimport { peekForStdinData, writeToStderr } from 'src/utils/process.js'\nimport { setCwd } from 'src/utils/Shell.js'\nimport {\n  type ProcessedResume,\n  processResumedConversation,\n} from 'src/utils/sessionRestore.js'\nimport { parseSettingSourcesFlag } from 'src/utils/settings/constants.js'\nimport { plural } from 'src/utils/stringUtils.js'\nimport {\n  type ChannelEntry,\n  getInitialMainLoopModel,\n  getIsNonInteractiveSession,\n  getSdkBetas,\n  getSessionId,\n  getUserMsgOptIn,\n  setAllowedChannels,\n  setAllowedSettingSources,\n  setChromeFlagOverride,\n  setClientType,\n  setCwdState,\n  setDirectConnectServerUrl,\n  setFlagSettingsPath,\n  setInitialMainLoopModel,\n  setInlinePlugins,\n  setIsInteractive,\n  setKairosActive,\n  setOriginalCwd,\n  setQuestionPreviewFormat,\n  setSdkBetas,\n  setSessionBypassPermissionsMode,\n  setSessionPersistenceDisabled,\n  setSessionSource,\n  setUserMsgOptIn,\n  switchSession,\n} from './bootstrap/state.js'\n\n/* eslint-disable @typescript-eslint/no-require-imports */\nconst autoModeStateModule = feature('TRANSCRIPT_CLASSIFIER')\n  ? (require('./utils/permissions/autoModeState.js') as typeof import('./utils/permissions/autoModeState.js'))\n  : null\n\n// TeleportRepoMismatchDialog, TeleportResumeWrapper dynamically imported at call sites\nimport { migrateAutoUpdatesToSettings } from './migrations/migrateAutoUpdatesToSettings.js'\nimport { migrateBypassPermissionsAcceptedToSettings } from './migrations/migrateBypassPermissionsAcceptedToSettings.js'\nimport { migrateEnableAllProjectMcpServersToSettings } from './migrations/migrateEnableAllProjectMcpServersToSettings.js'\nimport { migrateFennecToOpus } from './migrations/migrateFennecToOpus.js'\nimport { migrateLegacyOpusToCurrent } from './migrations/migrateLegacyOpusToCurrent.js'\nimport { migrateOpusToOpus1m } from './migrations/migrateOpusToOpus1m.js'\nimport { migrateReplBridgeEnabledToRemoteControlAtStartup } from './migrations/migrateReplBridgeEnabledToRemoteControlAtStartup.js'\nimport { migrateSonnet1mToSonnet45 } from './migrations/migrateSonnet1mToSonnet45.js'\nimport { migrateSonnet45ToSonnet46 } from './migrations/migrateSonnet45ToSonnet46.js'\nimport { resetAutoModeOptInForDefaultOffer } from './migrations/resetAutoModeOptInForDefaultOffer.js'\nimport { resetProToOpusDefault } from './migrations/resetProToOpusDefault.js'\nimport { createRemoteSessionConfig } from './remote/RemoteSessionManager.js'\n/* eslint-enable @typescript-eslint/no-require-imports */\n// teleportWithProgress dynamically imported at call site\nimport {\n  createDirectConnectSession,\n  DirectConnectError,\n} from './server/createDirectConnectSession.js'\nimport { initializeLspServerManager } from './services/lsp/manager.js'\nimport { shouldEnablePromptSuggestion } from './services/PromptSuggestion/promptSuggestion.js'\nimport {\n  type AppState,\n  getDefaultAppState,\n  IDLE_SPECULATION_STATE,\n} from './state/AppStateStore.js'\nimport { onChangeAppState } from './state/onChangeAppState.js'\nimport { createStore } from './state/store.js'\nimport { asSessionId } from './types/ids.js'\nimport { filterAllowedSdkBetas } from './utils/betas.js'\nimport { isInBundledMode, isRunningWithBun } from './utils/bundledMode.js'\nimport { logForDiagnosticsNoPII } from './utils/diagLogs.js'\nimport {\n  filterExistingPaths,\n  getKnownPathsForRepo,\n} from './utils/githubRepoPathMapping.js'\nimport {\n  clearPluginCache,\n  loadAllPluginsCacheOnly,\n} from './utils/plugins/pluginLoader.js'\nimport { migrateChangelogFromConfig } from './utils/releaseNotes.js'\nimport { SandboxManager } from './utils/sandbox/sandbox-adapter.js'\nimport { fetchSession, prepareApiRequest } from './utils/teleport/api.js'\nimport {\n  checkOutTeleportedSessionBranch,\n  processMessagesForTeleportResume,\n  teleportToRemoteWithErrorHandling,\n  validateGitState,\n  validateSessionRepository,\n} from './utils/teleport.js'\nimport {\n  shouldEnableThinkingByDefault,\n  type ThinkingConfig,\n} from './utils/thinking.js'\nimport { initUser, resetUserCache } from './utils/user.js'\nimport {\n  getTmuxInstallInstructions,\n  isTmuxAvailable,\n  parsePRReference,\n} from './utils/worktree.js'\n\n// eslint-disable-next-line custom-rules/no-top-level-side-effects\nprofileCheckpoint('main_tsx_imports_loaded')\n\n/**\n * Log managed settings keys to Statsig for analytics.\n * This is called after init() completes to ensure settings are loaded\n * and environment variables are applied before model resolution.\n */\nfunction logManagedSettings(): void {\n  try {\n    const policySettings = getSettingsForSource('policySettings')\n    if (policySettings) {\n      const allKeys = getManagedSettingsKeysForLogging(policySettings)\n      logEvent('tengu_managed_settings_loaded', {\n        keyCount: allKeys.length,\n        keys: allKeys.join(\n          ',',\n        ) as unknown as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      })\n    }\n  } catch {\n    // Silently ignore errors - this is just for analytics\n  }\n}\n\n// Check if running in debug/inspection mode\nfunction isBeingDebugged() {\n  const isBun = isRunningWithBun()\n\n  // Check for inspect flags in process arguments (including all variants)\n  const hasInspectArg = process.execArgv.some(arg => {\n    if (isBun) {\n      // Note: Bun has an issue with single-file executables where application arguments\n      // from process.argv leak into process.execArgv (similar to https://github.com/oven-sh/bun/issues/11673)\n      // This breaks use of --debug mode if we omit this branch\n      // We're fine to skip that check, because Bun doesn't support Node.js legacy --debug or --debug-brk flags\n      return /--inspect(-brk)?/.test(arg)\n    } else {\n      // In Node.js, check for both --inspect and legacy --debug flags\n      return /--inspect(-brk)?|--debug(-brk)?/.test(arg)\n    }\n  })\n\n  // Check if NODE_OPTIONS contains inspect flags\n  const hasInspectEnv =\n    process.env.NODE_OPTIONS &&\n    /--inspect(-brk)?|--debug(-brk)?/.test(process.env.NODE_OPTIONS)\n\n  // Check if inspector is available and active (indicates debugging)\n  try {\n    // Dynamic import would be better but is async - use global object instead\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const inspector = (global as any).require('inspector')\n    const hasInspectorUrl = !!inspector.url()\n    return hasInspectorUrl || hasInspectArg || hasInspectEnv\n  } catch {\n    // Ignore error and fall back to argument detection\n    return hasInspectArg || hasInspectEnv\n  }\n}\n\n// Exit if we detect node debugging or inspection\nif (\"external\" !== 'ant' && isBeingDebugged()) {\n  // Use process.exit directly here since we're in the top-level code before imports\n  // and gracefulShutdown is not yet available\n  // eslint-disable-next-line custom-rules/no-top-level-side-effects\n  process.exit(1)\n}\n\n/**\n * Per-session skill/plugin telemetry. Called from both the interactive path\n * and the headless -p path (before runHeadless) — both go through\n * main.tsx but branch before the interactive startup path, so it needs two\n * call sites here rather than one here + one in QueryEngine.\n */\nfunction logSessionTelemetry(): void {\n  const model = parseUserSpecifiedModel(\n    getInitialMainLoopModel() ?? getDefaultMainLoopModel(),\n  )\n  void logSkillsLoaded(getCwd(), getContextWindowForModel(model, getSdkBetas()))\n  void loadAllPluginsCacheOnly()\n    .then(({ enabled, errors }) => {\n      const managedNames = getManagedPluginNames()\n      logPluginsEnabledForSession(enabled, managedNames, getPluginSeedDirs())\n      logPluginLoadErrors(errors, managedNames)\n    })\n    .catch(err => logError(err))\n}\n\nfunction getCertEnvVarTelemetry(): Record<string, boolean> {\n  const result: Record<string, boolean> = {}\n  if (process.env.NODE_EXTRA_CA_CERTS) {\n    result.has_node_extra_ca_certs = true\n  }\n  if (process.env.CLAUDE_CODE_CLIENT_CERT) {\n    result.has_client_cert = true\n  }\n  if (hasNodeOption('--use-system-ca')) {\n    result.has_use_system_ca = true\n  }\n  if (hasNodeOption('--use-openssl-ca')) {\n    result.has_use_openssl_ca = true\n  }\n  return result\n}\n\nasync function logStartupTelemetry(): Promise<void> {\n  if (isAnalyticsDisabled()) return\n  const [isGit, worktreeCount, ghAuthStatus] = await Promise.all([\n    getIsGit(),\n    getWorktreeCount(),\n    getGhAuthStatus(),\n  ])\n\n  logEvent('tengu_startup_telemetry', {\n    is_git: isGit,\n    worktree_count: worktreeCount,\n    gh_auth_status:\n      ghAuthStatus as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n    sandbox_enabled: SandboxManager.isSandboxingEnabled(),\n    are_unsandboxed_commands_allowed:\n      SandboxManager.areUnsandboxedCommandsAllowed(),\n    is_auto_bash_allowed_if_sandbox_enabled:\n      SandboxManager.isAutoAllowBashIfSandboxedEnabled(),\n    auto_updater_disabled: isAutoUpdaterDisabled(),\n    prefers_reduced_motion: getInitialSettings().prefersReducedMotion ?? false,\n    ...getCertEnvVarTelemetry(),\n  })\n}\n\n// @[MODEL LAUNCH]: Consider any migrations you may need for model strings. See migrateSonnet1mToSonnet45.ts for an example.\n// Bump this when adding a new sync migration so existing users re-run the set.\nconst CURRENT_MIGRATION_VERSION = 11\nfunction runMigrations(): void {\n  if (getGlobalConfig().migrationVersion !== CURRENT_MIGRATION_VERSION) {\n    migrateAutoUpdatesToSettings()\n    migrateBypassPermissionsAcceptedToSettings()\n    migrateEnableAllProjectMcpServersToSettings()\n    resetProToOpusDefault()\n    migrateSonnet1mToSonnet45()\n    migrateLegacyOpusToCurrent()\n    migrateSonnet45ToSonnet46()\n    migrateOpusToOpus1m()\n    migrateReplBridgeEnabledToRemoteControlAtStartup()\n    if (feature('TRANSCRIPT_CLASSIFIER')) {\n      resetAutoModeOptInForDefaultOffer()\n    }\n    if (\"external\" === 'ant') {\n      migrateFennecToOpus()\n    }\n    saveGlobalConfig(prev =>\n      prev.migrationVersion === CURRENT_MIGRATION_VERSION\n        ? prev\n        : { ...prev, migrationVersion: CURRENT_MIGRATION_VERSION },\n    )\n  }\n  // Async migration - fire and forget since it's non-blocking\n  migrateChangelogFromConfig().catch(() => {\n    // Silently ignore migration errors - will retry on next startup\n  })\n}\n\n/**\n * Prefetch system context (including git status) only when it's safe to do so.\n * Git commands can execute arbitrary code via hooks and config (e.g., core.fsmonitor,\n * diff.external), so we must only run them after trust is established or in\n * non-interactive mode where trust is implicit.\n */\nfunction prefetchSystemContextIfSafe(): void {\n  const isNonInteractiveSession = getIsNonInteractiveSession()\n\n  // In non-interactive mode (--print), trust dialog is skipped and\n  // execution is considered trusted (as documented in help text)\n  if (isNonInteractiveSession) {\n    logForDiagnosticsNoPII('info', 'prefetch_system_context_non_interactive')\n    void getSystemContext()\n    return\n  }\n\n  // In interactive mode, only prefetch if trust has already been established\n  const hasTrust = checkHasTrustDialogAccepted()\n  if (hasTrust) {\n    logForDiagnosticsNoPII('info', 'prefetch_system_context_has_trust')\n    void getSystemContext()\n  } else {\n    logForDiagnosticsNoPII('info', 'prefetch_system_context_skipped_no_trust')\n  }\n  // Otherwise, don't prefetch - wait for trust to be established first\n}\n\n/**\n * Start background prefetches and housekeeping that are NOT needed before first render.\n * These are deferred from setup() to reduce event loop contention and child process\n * spawning during the critical startup path.\n * Call this after the REPL has been rendered.\n */\nexport function startDeferredPrefetches(): void {\n  // This function runs after first render, so it doesn't block the initial paint.\n  // However, the spawned processes and async work still contend for CPU and event\n  // loop time, which skews startup benchmarks (CPU profiles, time-to-first-render\n  // measurements). Skip all of it when we're only measuring startup performance.\n  if (\n    isEnvTruthy(process.env.CLAUDE_CODE_EXIT_AFTER_FIRST_RENDER) ||\n    // --bare: skip ALL prefetches. These are cache-warms for the REPL's\n    // first-turn responsiveness (initUser, getUserContext, tips, countFiles,\n    // modelCapabilities, change detectors). Scripted -p calls don't have a\n    // \"user is typing\" window to hide this work in — it's pure overhead on\n    // the critical path.\n    isBareMode()\n  ) {\n    return\n  }\n\n  // Process-spawning prefetches (consumed at first API call, user is still typing)\n  void initUser()\n  void getUserContext()\n  prefetchSystemContextIfSafe()\n  void getRelevantTips()\n  if (\n    isEnvTruthy(process.env.CLAUDE_CODE_USE_BEDROCK) &&\n    !isEnvTruthy(process.env.CLAUDE_CODE_SKIP_BEDROCK_AUTH)\n  ) {\n    void prefetchAwsCredentialsAndBedRockInfoIfSafe()\n  }\n  if (\n    isEnvTruthy(process.env.CLAUDE_CODE_USE_VERTEX) &&\n    !isEnvTruthy(process.env.CLAUDE_CODE_SKIP_VERTEX_AUTH)\n  ) {\n    void prefetchGcpCredentialsIfSafe()\n  }\n  void countFilesRoundedRg(getCwd(), AbortSignal.timeout(3000), [])\n\n  // Analytics and feature flag initialization\n  void initializeAnalyticsGates()\n  void prefetchOfficialMcpUrls()\n\n  void refreshModelCapabilities()\n\n  // File change detectors deferred from init() to unblock first render\n  void settingsChangeDetector.initialize()\n  if (!isBareMode()) {\n    void skillChangeDetector.initialize()\n  }\n\n  // Event loop stall detector — logs when the main thread is blocked >500ms\n  if (\"external\" === 'ant') {\n    void import('./utils/eventLoopStallDetector.js').then(m =>\n      m.startEventLoopStallDetector(),\n    )\n  }\n}\n\nfunction loadSettingsFromFlag(settingsFile: string): void {\n  try {\n    const trimmedSettings = settingsFile.trim()\n    const looksLikeJson =\n      trimmedSettings.startsWith('{') && trimmedSettings.endsWith('}')\n\n    let settingsPath: string\n\n    if (looksLikeJson) {\n      // It's a JSON string - validate and create temp file\n      const parsedJson = safeParseJSON(trimmedSettings)\n      if (!parsedJson) {\n        process.stderr.write(\n          chalk.red('Error: Invalid JSON provided to --settings\\n'),\n        )\n        process.exit(1)\n      }\n\n      // Create a temporary file and write the JSON to it.\n      // Use a content-hash-based path instead of random UUID to avoid\n      // busting the Anthropic API prompt cache. The settings path ends up\n      // in the Bash tool's sandbox denyWithinAllow list, which is part of\n      // the tool description sent to the API. A random UUID per subprocess\n      // changes the tool description on every query() call, invalidating\n      // the cache prefix and causing a 12x input token cost penalty.\n      // The content hash ensures identical settings produce the same path\n      // across process boundaries (each SDK query() spawns a new process).\n      settingsPath = generateTempFilePath('claude-settings', '.json', {\n        contentHash: trimmedSettings,\n      })\n      writeFileSync_DEPRECATED(settingsPath, trimmedSettings, 'utf8')\n    } else {\n      // It's a file path - resolve and validate by attempting to read\n      const { resolvedPath: resolvedSettingsPath } = safeResolvePath(\n        getFsImplementation(),\n        settingsFile,\n      )\n      try {\n        readFileSync(resolvedSettingsPath, 'utf8')\n      } catch (e) {\n        if (isENOENT(e)) {\n          process.stderr.write(\n            chalk.red(\n              `Error: Settings file not found: ${resolvedSettingsPath}\\n`,\n            ),\n          )\n          process.exit(1)\n        }\n        throw e\n      }\n      settingsPath = resolvedSettingsPath\n    }\n\n    setFlagSettingsPath(settingsPath)\n    resetSettingsCache()\n  } catch (error) {\n    if (error instanceof Error) {\n      logError(error)\n    }\n    process.stderr.write(\n      chalk.red(`Error processing settings: ${errorMessage(error)}\\n`),\n    )\n    process.exit(1)\n  }\n}\n\nfunction loadSettingSourcesFromFlag(settingSourcesArg: string): void {\n  try {\n    const sources = parseSettingSourcesFlag(settingSourcesArg)\n    setAllowedSettingSources(sources)\n    resetSettingsCache()\n  } catch (error) {\n    if (error instanceof Error) {\n      logError(error)\n    }\n    process.stderr.write(\n      chalk.red(`Error processing --setting-sources: ${errorMessage(error)}\\n`),\n    )\n    process.exit(1)\n  }\n}\n\n/**\n * Parse and load settings flags early, before init()\n * This ensures settings are filtered from the start of initialization\n */\nfunction eagerLoadSettings(): void {\n  profileCheckpoint('eagerLoadSettings_start')\n  // Parse --settings flag early to ensure settings are loaded before init()\n  const settingsFile = eagerParseCliFlag('--settings')\n  if (settingsFile) {\n    loadSettingsFromFlag(settingsFile)\n  }\n\n  // Parse --setting-sources flag early to control which sources are loaded\n  const settingSourcesArg = eagerParseCliFlag('--setting-sources')\n  if (settingSourcesArg !== undefined) {\n    loadSettingSourcesFromFlag(settingSourcesArg)\n  }\n  profileCheckpoint('eagerLoadSettings_end')\n}\n\nfunction initializeEntrypoint(isNonInteractive: boolean): void {\n  // Skip if already set (e.g., by SDK or other entrypoints)\n  if (process.env.CLAUDE_CODE_ENTRYPOINT) {\n    return\n  }\n\n  const cliArgs = process.argv.slice(2)\n\n  // Check for MCP serve command (handle flags before mcp serve, e.g., --debug mcp serve)\n  const mcpIndex = cliArgs.indexOf('mcp')\n  if (mcpIndex !== -1 && cliArgs[mcpIndex + 1] === 'serve') {\n    process.env.CLAUDE_CODE_ENTRYPOINT = 'mcp'\n    return\n  }\n\n  if (isEnvTruthy(process.env.CLAUDE_CODE_ACTION)) {\n    process.env.CLAUDE_CODE_ENTRYPOINT = 'claude-code-github-action'\n    return\n  }\n\n  // Note: 'local-agent' entrypoint is set by the local agent mode launcher\n  // via CLAUDE_CODE_ENTRYPOINT env var (handled by early return above)\n\n  // Set based on interactive status\n  process.env.CLAUDE_CODE_ENTRYPOINT = isNonInteractive ? 'sdk-cli' : 'cli'\n}\n\n// Set by early argv processing when `claude open <url>` is detected (interactive mode only)\ntype PendingConnect = {\n  url: string | undefined\n  authToken: string | undefined\n  dangerouslySkipPermissions: boolean\n}\nconst _pendingConnect: PendingConnect | undefined = feature('DIRECT_CONNECT')\n  ? { url: undefined, authToken: undefined, dangerouslySkipPermissions: false }\n  : undefined\n\n// Set by early argv processing when `claude assistant [sessionId]` is detected\ntype PendingAssistantChat = { sessionId?: string; discover: boolean }\nconst _pendingAssistantChat: PendingAssistantChat | undefined = feature(\n  'KAIROS',\n)\n  ? { sessionId: undefined, discover: false }\n  : undefined\n\n// `claude ssh <host> [dir]` — parsed from argv early (same pattern as\n// DIRECT_CONNECT above) so the main command path can pick it up and hand\n// the REPL an SSH-backed session instead of a local one.\ntype PendingSSH = {\n  host: string | undefined\n  cwd: string | undefined\n  permissionMode: string | undefined\n  dangerouslySkipPermissions: boolean\n  /** --local: spawn the child CLI directly, skip ssh/probe/deploy. e2e test mode. */\n  local: boolean\n  /** Extra CLI args to forward to the remote CLI on initial spawn (--resume, -c). */\n  extraCliArgs: string[]\n}\nconst _pendingSSH: PendingSSH | undefined = feature('SSH_REMOTE')\n  ? {\n      host: undefined,\n      cwd: undefined,\n      permissionMode: undefined,\n      dangerouslySkipPermissions: false,\n      local: false,\n      extraCliArgs: [],\n    }\n  : undefined\n\nexport async function main() {\n  profileCheckpoint('main_function_start')\n\n  // SECURITY: Prevent Windows from executing commands from current directory\n  // This must be set before ANY command execution to prevent PATH hijacking attacks\n  // See: https://docs.microsoft.com/en-us/windows/win32/api/processenv/nf-processenv-searchpathw\n  process.env.NoDefaultCurrentDirectoryInExePath = '1'\n\n  // Initialize warning handler early to catch warnings\n  initializeWarningHandler()\n\n  process.on('exit', () => {\n    resetCursor()\n  })\n  process.on('SIGINT', () => {\n    // In print mode, print.ts registers its own SIGINT handler that aborts\n    // the in-flight query and calls gracefulShutdown; skip here to avoid\n    // preempting it with a synchronous process.exit().\n    if (process.argv.includes('-p') || process.argv.includes('--print')) {\n      return\n    }\n    process.exit(0)\n  })\n  profileCheckpoint('main_warning_handler_initialized')\n\n  // Check for cc:// or cc+unix:// URL in argv — rewrite so the main command\n  // handles it, giving the full interactive TUI instead of a stripped-down subcommand.\n  // For headless (-p), we rewrite to the internal `open` subcommand.\n  if (feature('DIRECT_CONNECT')) {\n    const rawCliArgs = process.argv.slice(2)\n    const ccIdx = rawCliArgs.findIndex(\n      a => a.startsWith('cc://') || a.startsWith('cc+unix://'),\n    )\n    if (ccIdx !== -1 && _pendingConnect) {\n      const ccUrl = rawCliArgs[ccIdx]!\n      const { parseConnectUrl } = await import('./server/parseConnectUrl.js')\n      const parsed = parseConnectUrl(ccUrl)\n      _pendingConnect.dangerouslySkipPermissions = rawCliArgs.includes(\n        '--dangerously-skip-permissions',\n      )\n\n      if (rawCliArgs.includes('-p') || rawCliArgs.includes('--print')) {\n        // Headless: rewrite to internal `open` subcommand\n        const stripped = rawCliArgs.filter((_, i) => i !== ccIdx)\n        const dspIdx = stripped.indexOf('--dangerously-skip-permissions')\n        if (dspIdx !== -1) {\n          stripped.splice(dspIdx, 1)\n        }\n        process.argv = [\n          process.argv[0]!,\n          process.argv[1]!,\n          'open',\n          ccUrl,\n          ...stripped,\n        ]\n      } else {\n        // Interactive: strip cc:// URL and flags, run main command\n        _pendingConnect.url = parsed.serverUrl\n        _pendingConnect.authToken = parsed.authToken\n        const stripped = rawCliArgs.filter((_, i) => i !== ccIdx)\n        const dspIdx = stripped.indexOf('--dangerously-skip-permissions')\n        if (dspIdx !== -1) {\n          stripped.splice(dspIdx, 1)\n        }\n        process.argv = [process.argv[0]!, process.argv[1]!, ...stripped]\n      }\n    }\n  }\n\n  // Handle deep link URIs early — this is invoked by the OS protocol handler\n  // and should bail out before full init since it only needs to parse the URI\n  // and open a terminal.\n  if (feature('LODESTONE')) {\n    const handleUriIdx = process.argv.indexOf('--handle-uri')\n    if (handleUriIdx !== -1 && process.argv[handleUriIdx + 1]) {\n      const { enableConfigs } = await import('./utils/config.js')\n      enableConfigs()\n      const uri = process.argv[handleUriIdx + 1]!\n      const { handleDeepLinkUri } = await import(\n        './utils/deepLink/protocolHandler.js'\n      )\n      const exitCode = await handleDeepLinkUri(uri)\n      process.exit(exitCode)\n    }\n\n    // macOS URL handler: when LaunchServices launches our .app bundle, the\n    // URL arrives via Apple Event (not argv). LaunchServices overwrites\n    // __CFBundleIdentifier to the launching bundle's ID, which is a precise\n    // positive signal — cheaper than importing and guessing with heuristics.\n    if (\n      process.platform === 'darwin' &&\n      process.env.__CFBundleIdentifier ===\n        'com.anthropic.claude-code-url-handler'\n    ) {\n      const { enableConfigs } = await import('./utils/config.js')\n      enableConfigs()\n      const { handleUrlSchemeLaunch } = await import(\n        './utils/deepLink/protocolHandler.js'\n      )\n      const urlSchemeResult = await handleUrlSchemeLaunch()\n      process.exit(urlSchemeResult ?? 1)\n    }\n  }\n\n  // `claude assistant [sessionId]` — stash and strip so the main\n  // command handles it, giving the full interactive TUI. Position-0 only\n  // (matching the ssh pattern below) — indexOf would false-positive on\n  // `claude -p \"explain assistant\"`. Root-flag-before-subcommand\n  // (e.g. `--debug assistant`) falls through to the stub, which\n  // prints usage.\n  if (feature('KAIROS') && _pendingAssistantChat) {\n    const rawArgs = process.argv.slice(2)\n    if (rawArgs[0] === 'assistant') {\n      const nextArg = rawArgs[1]\n      if (nextArg && !nextArg.startsWith('-')) {\n        _pendingAssistantChat.sessionId = nextArg\n        rawArgs.splice(0, 2) // drop 'assistant' and sessionId\n        process.argv = [process.argv[0]!, process.argv[1]!, ...rawArgs]\n      } else if (!nextArg) {\n        _pendingAssistantChat.discover = true\n        rawArgs.splice(0, 1) // drop 'assistant'\n        process.argv = [process.argv[0]!, process.argv[1]!, ...rawArgs]\n      }\n      // else: `claude assistant --help` → fall through to stub\n    }\n  }\n\n  // `claude ssh <host> [dir]` — strip from argv so the main command handler\n  // runs (full interactive TUI), stash the host/dir for the REPL branch at\n  // ~line 3720 to pick up. Headless (-p) mode not supported in v1: SSH\n  // sessions need the local REPL to drive them (interrupt, permissions).\n  if (feature('SSH_REMOTE') && _pendingSSH) {\n    const rawCliArgs = process.argv.slice(2)\n    // SSH-specific flags can appear before the host positional (e.g.\n    // `ssh --permission-mode auto host /tmp` — standard POSIX flags-before-\n    // positionals). Pull them all out BEFORE checking whether a host was\n    // given, so `claude ssh --permission-mode auto host` and `claude ssh host\n    // --permission-mode auto` are equivalent. The host check below only needs\n    // to guard against `-h`/`--help` (which commander should handle).\n    if (rawCliArgs[0] === 'ssh') {\n      const localIdx = rawCliArgs.indexOf('--local')\n      if (localIdx !== -1) {\n        _pendingSSH.local = true\n        rawCliArgs.splice(localIdx, 1)\n      }\n      const dspIdx = rawCliArgs.indexOf('--dangerously-skip-permissions')\n      if (dspIdx !== -1) {\n        _pendingSSH.dangerouslySkipPermissions = true\n        rawCliArgs.splice(dspIdx, 1)\n      }\n      const pmIdx = rawCliArgs.indexOf('--permission-mode')\n      if (\n        pmIdx !== -1 &&\n        rawCliArgs[pmIdx + 1] &&\n        !rawCliArgs[pmIdx + 1]!.startsWith('-')\n      ) {\n        _pendingSSH.permissionMode = rawCliArgs[pmIdx + 1]\n        rawCliArgs.splice(pmIdx, 2)\n      }\n      const pmEqIdx = rawCliArgs.findIndex(a =>\n        a.startsWith('--permission-mode='),\n      )\n      if (pmEqIdx !== -1) {\n        _pendingSSH.permissionMode = rawCliArgs[pmEqIdx]!.split('=')[1]\n        rawCliArgs.splice(pmEqIdx, 1)\n      }\n      // Forward session-resume + model flags to the remote CLI's initial spawn.\n      // --continue/-c and --resume <uuid> operate on the REMOTE session history\n      // (which persists under the remote's ~/.claude/projects/<cwd>/).\n      // --model controls which model the remote uses.\n      const extractFlag = (\n        flag: string,\n        opts: { hasValue?: boolean; as?: string } = {},\n      ) => {\n        const i = rawCliArgs.indexOf(flag)\n        if (i !== -1) {\n          _pendingSSH.extraCliArgs.push(opts.as ?? flag)\n          const val = rawCliArgs[i + 1]\n          if (opts.hasValue && val && !val.startsWith('-')) {\n            _pendingSSH.extraCliArgs.push(val)\n            rawCliArgs.splice(i, 2)\n          } else {\n            rawCliArgs.splice(i, 1)\n          }\n        }\n        const eqI = rawCliArgs.findIndex(a => a.startsWith(`${flag}=`))\n        if (eqI !== -1) {\n          _pendingSSH.extraCliArgs.push(\n            opts.as ?? flag,\n            rawCliArgs[eqI]!.slice(flag.length + 1),\n          )\n          rawCliArgs.splice(eqI, 1)\n        }\n      }\n      extractFlag('-c', { as: '--continue' })\n      extractFlag('--continue')\n      extractFlag('--resume', { hasValue: true })\n      extractFlag('--model', { hasValue: true })\n    }\n    // After pre-extraction, any remaining dash-arg at [1] is either -h/--help\n    // (commander handles) or an unknown-to-ssh flag (fall through to commander\n    // so it surfaces a proper error). Only a non-dash arg is the host.\n    if (\n      rawCliArgs[0] === 'ssh' &&\n      rawCliArgs[1] &&\n      !rawCliArgs[1].startsWith('-')\n    ) {\n      _pendingSSH.host = rawCliArgs[1]\n      // Optional positional cwd.\n      let consumed = 2\n      if (rawCliArgs[2] && !rawCliArgs[2].startsWith('-')) {\n        _pendingSSH.cwd = rawCliArgs[2]\n        consumed = 3\n      }\n      const rest = rawCliArgs.slice(consumed)\n\n      // Headless (-p) mode is not supported with SSH in v1 — reject early\n      // so the flag doesn't silently cause local execution.\n      if (rest.includes('-p') || rest.includes('--print')) {\n        process.stderr.write(\n          'Error: headless (-p/--print) mode is not supported with claude ssh\\n',\n        )\n        gracefulShutdownSync(1)\n        return\n      }\n\n      // Rewrite argv so the main command sees remaining flags but not `ssh`.\n      process.argv = [process.argv[0]!, process.argv[1]!, ...rest]\n    }\n  }\n\n  // Check for -p/--print and --init-only flags early to set isInteractiveSession before init()\n  // This is needed because telemetry initialization calls auth functions that need this flag\n  const cliArgs = process.argv.slice(2)\n  const hasPrintFlag = cliArgs.includes('-p') || cliArgs.includes('--print')\n  const hasInitOnlyFlag = cliArgs.includes('--init-only')\n  const hasSdkUrl = cliArgs.some(arg => arg.startsWith('--sdk-url'))\n  const isNonInteractive =\n    hasPrintFlag || hasInitOnlyFlag || hasSdkUrl || !process.stdout.isTTY\n\n  // Stop capturing early input for non-interactive modes\n  if (isNonInteractive) {\n    stopCapturingEarlyInput()\n  }\n\n  // Set simplified tracking fields\n  const isInteractive = !isNonInteractive\n  setIsInteractive(isInteractive)\n\n  // Initialize entrypoint based on mode - needs to be set before any event is logged\n  initializeEntrypoint(isNonInteractive)\n\n  // Determine client type\n  const clientType = (() => {\n    if (isEnvTruthy(process.env.GITHUB_ACTIONS)) return 'github-action'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'sdk-ts') return 'sdk-typescript'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'sdk-py') return 'sdk-python'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'sdk-cli') return 'sdk-cli'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'claude-vscode')\n      return 'claude-vscode'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'local-agent')\n      return 'local-agent'\n    if (process.env.CLAUDE_CODE_ENTRYPOINT === 'claude-desktop')\n      return 'claude-desktop'\n\n    // Check if session-ingress token is provided (indicates remote session)\n    const hasSessionIngressToken =\n      process.env.CLAUDE_CODE_SESSION_ACCESS_TOKEN ||\n      process.env.CLAUDE_CODE_WEBSOCKET_AUTH_FILE_DESCRIPTOR\n    if (\n      process.env.CLAUDE_CODE_ENTRYPOINT === 'remote' ||\n      hasSessionIngressToken\n    ) {\n      return 'remote'\n    }\n\n    return 'cli'\n  })()\n  setClientType(clientType)\n\n  const previewFormat = process.env.CLAUDE_CODE_QUESTION_PREVIEW_FORMAT\n  if (previewFormat === 'markdown' || previewFormat === 'html') {\n    setQuestionPreviewFormat(previewFormat)\n  } else if (\n    !clientType.startsWith('sdk-') &&\n    // Desktop and CCR pass previewFormat via toolConfig; when the feature is\n    // gated off they pass undefined — don't override that with markdown.\n    clientType !== 'claude-desktop' &&\n    clientType !== 'local-agent' &&\n    clientType !== 'remote'\n  ) {\n    setQuestionPreviewFormat('markdown')\n  }\n\n  // Tag sessions created via `claude remote-control` so the backend can identify them\n  if (process.env.CLAUDE_CODE_ENVIRONMENT_KIND === 'bridge') {\n    setSessionSource('remote-control')\n  }\n\n  profileCheckpoint('main_client_type_determined')\n\n  // Parse and load settings flags early, before init()\n  eagerLoadSettings()\n\n  profileCheckpoint('main_before_run')\n\n  await run()\n  profileCheckpoint('main_after_run')\n}\n\nasync function getInputPrompt(\n  prompt: string,\n  inputFormat: 'text' | 'stream-json',\n): Promise<string | AsyncIterable<string>> {\n  if (\n    !process.stdin.isTTY &&\n    // Input hijacking breaks MCP.\n    !process.argv.includes('mcp')\n  ) {\n    if (inputFormat === 'stream-json') {\n      return process.stdin\n    }\n    process.stdin.setEncoding('utf8')\n    let data = ''\n    const onData = (chunk: string) => {\n      data += chunk\n    }\n    process.stdin.on('data', onData)\n    // If no data arrives in 3s, stop waiting and warn. Stdin is likely an\n    // inherited pipe from a parent that isn't writing (subprocess spawned\n    // without explicit stdin handling). 3s covers slow producers like curl,\n    // jq on large files, python with import overhead. The warning makes\n    // silent data loss visible for the rare producer that's slower still.\n    const timedOut = await peekForStdinData(process.stdin, 3000)\n    process.stdin.off('data', onData)\n    if (timedOut) {\n      process.stderr.write(\n        'Warning: no stdin data received in 3s, proceeding without it. ' +\n          'If piping from a slow command, redirect stdin explicitly: < /dev/null to skip, or wait longer.\\n',\n      )\n    }\n    return [prompt, data].filter(Boolean).join('\\n')\n  }\n  return prompt\n}\n\nasync function run(): Promise<CommanderCommand> {\n  profileCheckpoint('run_function_start')\n\n  // Create help config that sorts options by long option name.\n  // Commander supports compareOptions at runtime but @commander-js/extra-typings\n  // doesn't include it in the type definitions, so we use Object.assign to add it.\n  function createSortedHelpConfig(): {\n    sortSubcommands: true\n    sortOptions: true\n  } {\n    const getOptionSortKey = (opt: Option): string =>\n      opt.long?.replace(/^--/, '') ?? opt.short?.replace(/^-/, '') ?? ''\n    return Object.assign(\n      { sortSubcommands: true, sortOptions: true } as const,\n      {\n        compareOptions: (a: Option, b: Option) =>\n          getOptionSortKey(a).localeCompare(getOptionSortKey(b)),\n      },\n    )\n  }\n  const program = new CommanderCommand()\n    .configureHelp(createSortedHelpConfig())\n    .enablePositionalOptions()\n  profileCheckpoint('run_commander_initialized')\n\n  // Use preAction hook to run initialization only when executing a command,\n  // not when displaying help. This avoids the need for env variable signaling.\n  program.hook('preAction', async thisCommand => {\n    profileCheckpoint('preAction_start')\n    // Await async subprocess loads started at module evaluation (lines 12-20).\n    // Nearly free — subprocesses complete during the ~135ms of imports above.\n    // Must resolve before init() which triggers the first settings read\n    // (applySafeConfigEnvironmentVariables → getSettingsForSource('policySettings')\n    // → isRemoteManagedSettingsEligible → sync keychain reads otherwise ~65ms).\n    await Promise.all([\n      ensureMdmSettingsLoaded(),\n      ensureKeychainPrefetchCompleted(),\n    ])\n    profileCheckpoint('preAction_after_mdm')\n    await init()\n    profileCheckpoint('preAction_after_init')\n\n    // process.title on Windows sets the console title directly; on POSIX,\n    // terminal shell integration may mirror the process name to the tab.\n    // After init() so settings.json env can also gate this (gh-4765).\n    if (!isEnvTruthy(process.env.CLAUDE_CODE_DISABLE_TERMINAL_TITLE)) {\n      process.title = 'claude'\n    }\n\n    // Attach logging sinks so subcommand handlers can use logEvent/logError.\n    // Before PR #11106 logEvent dispatched directly; after, events queue until\n    // a sink attaches. setup() attaches sinks for the default command, but\n    // subcommands (doctor, mcp, plugin, auth) never call setup() and would\n    // silently drop events on process.exit(). Both inits are idempotent.\n    const { initSinks } = await import('./utils/sinks.js')\n    initSinks()\n    profileCheckpoint('preAction_after_sinks')\n\n    // gh-33508: --plugin-dir is a top-level program option. The default\n    // action reads it from its own options destructure, but subcommands\n    // (plugin list, plugin install, mcp *) have their own actions and\n    // never see it. Wire it up here so getInlinePlugins() works everywhere.\n    // thisCommand.opts() is typed {} here because this hook is attached\n    // before .option('--plugin-dir', ...) in the chain — extra-typings\n    // builds the type as options are added. Narrow with a runtime guard;\n    // the collect accumulator + [] default guarantee string[] in practice.\n    const pluginDir = thisCommand.getOptionValue('pluginDir')\n    if (\n      Array.isArray(pluginDir) &&\n      pluginDir.length > 0 &&\n      pluginDir.every(p => typeof p === 'string')\n    ) {\n      setInlinePlugins(pluginDir)\n      clearPluginCache('preAction: --plugin-dir inline plugins')\n    }\n\n    runMigrations()\n    profileCheckpoint('preAction_after_migrations')\n\n    // Load remote managed settings for enterprise customers (non-blocking)\n    // Fails open - if fetch fails, continues without remote settings\n    // Settings are applied via hot-reload when they arrive\n    // Must happen after init() to ensure config reading is allowed\n    void loadRemoteManagedSettings()\n    void loadPolicyLimits()\n\n    profileCheckpoint('preAction_after_remote_settings')\n\n    // Load settings sync (non-blocking, fail-open)\n    // CLI: uploads local settings to remote (CCR download is handled by print.ts)\n    if (feature('UPLOAD_USER_SETTINGS')) {\n      void import('./services/settingsSync/index.js').then(m =>\n        m.uploadUserSettingsInBackground(),\n      )\n    }\n\n    profileCheckpoint('preAction_after_settings_sync')\n  })\n\n  program\n    .name('claude')\n    .description(\n      `Claude Code - starts an interactive session by default, use -p/--print for non-interactive output`,\n    )\n    .argument('[prompt]', 'Your prompt', String)\n    // Subcommands inherit helpOption via commander's copyInheritedSettings —\n    // setting it once here covers mcp, plugin, auth, and all other subcommands.\n    .helpOption('-h, --help', 'Display help for command')\n    .option(\n      '-d, --debug [filter]',\n      'Enable debug mode with optional category filtering (e.g., \"api,hooks\" or \"!1p,!file\")',\n      (_value: string | true) => {\n        // If value is provided, it will be the filter string\n        // If not provided but flag is present, value will be true\n        // The actual filtering is handled in debug.ts by parsing process.argv\n        return true\n      },\n    )\n    .addOption(\n      new Option('-d2e, --debug-to-stderr', 'Enable debug mode (to stderr)')\n        .argParser(Boolean)\n        .hideHelp(),\n    )\n    .option(\n      '--debug-file <path>',\n      'Write debug logs to a specific file path (implicitly enables debug mode)',\n      () => true,\n    )\n    .option(\n      '--verbose',\n      'Override verbose mode setting from config',\n      () => true,\n    )\n    .option(\n      '-p, --print',\n      'Print response and exit (useful for pipes). Note: The workspace trust dialog is skipped when Claude is run with the -p mode. Only use this flag in directories you trust.',\n      () => true,\n    )\n    .option(\n      '--bare',\n      'Minimal mode: skip hooks, LSP, plugin sync, attribution, auto-memory, background prefetches, keychain reads, and CLAUDE.md auto-discovery. Sets CLAUDE_CODE_SIMPLE=1. Anthropic auth is strictly ANTHROPIC_API_KEY or apiKeyHelper via --settings (OAuth and keychain are never read). 3P providers (Bedrock/Vertex/Foundry) use their own credentials. Skills still resolve via /skill-name. Explicitly provide context via: --system-prompt[-file], --append-system-prompt[-file], --add-dir (CLAUDE.md dirs), --mcp-config, --settings, --agents, --plugin-dir.',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--init',\n        'Run Setup hooks with init trigger, then continue',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--init-only',\n        'Run Setup and SessionStart:startup hooks, then exit',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--maintenance',\n        'Run Setup hooks with maintenance trigger, then continue',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--output-format <format>',\n        'Output format (only works with --print): \"text\" (default), \"json\" (single result), or \"stream-json\" (realtime streaming)',\n      ).choices(['text', 'json', 'stream-json']),\n    )\n    .addOption(\n      new Option(\n        '--json-schema <schema>',\n        'JSON Schema for structured output validation. ' +\n          'Example: {\"type\":\"object\",\"properties\":{\"name\":{\"type\":\"string\"}},\"required\":[\"name\"]}',\n      ).argParser(String),\n    )\n    .option(\n      '--include-hook-events',\n      'Include all hook lifecycle events in the output stream (only works with --output-format=stream-json)',\n      () => true,\n    )\n    .option(\n      '--include-partial-messages',\n      'Include partial message chunks as they arrive (only works with --print and --output-format=stream-json)',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--input-format <format>',\n        'Input format (only works with --print): \"text\" (default), or \"stream-json\" (realtime streaming input)',\n      ).choices(['text', 'stream-json']),\n    )\n    .option(\n      '--mcp-debug',\n      '[DEPRECATED. Use --debug instead] Enable MCP debug mode (shows MCP server errors)',\n      () => true,\n    )\n    .option(\n      '--dangerously-skip-permissions',\n      'Bypass all permission checks. Recommended only for sandboxes with no internet access.',\n      () => true,\n    )\n    .option(\n      '--allow-dangerously-skip-permissions',\n      'Enable bypassing all permission checks as an option, without it being enabled by default. Recommended only for sandboxes with no internet access.',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--thinking <mode>',\n        'Thinking mode: enabled (equivalent to adaptive), disabled',\n      )\n        .choices(['enabled', 'adaptive', 'disabled'])\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--max-thinking-tokens <tokens>',\n        '[DEPRECATED. Use --thinking instead for newer models] Maximum number of thinking tokens (only works with --print)',\n      )\n        .argParser(Number)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--max-turns <turns>',\n        'Maximum number of agentic turns in non-interactive mode. This will early exit the conversation after the specified number of turns. (only works with --print)',\n      )\n        .argParser(Number)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--max-budget-usd <amount>',\n        'Maximum dollar amount to spend on API calls (only works with --print)',\n      ).argParser(value => {\n        const amount = Number(value)\n        if (isNaN(amount) || amount <= 0) {\n          throw new Error(\n            '--max-budget-usd must be a positive number greater than 0',\n          )\n        }\n        return amount\n      }),\n    )\n    .addOption(\n      new Option(\n        '--task-budget <tokens>',\n        'API-side task budget in tokens (output_config.task_budget)',\n      )\n        .argParser(value => {\n          const tokens = Number(value)\n          if (isNaN(tokens) || tokens <= 0 || !Number.isInteger(tokens)) {\n            throw new Error('--task-budget must be a positive integer')\n          }\n          return tokens\n        })\n        .hideHelp(),\n    )\n    .option(\n      '--replay-user-messages',\n      'Re-emit user messages from stdin back on stdout for acknowledgment (only works with --input-format=stream-json and --output-format=stream-json)',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--enable-auth-status',\n        'Enable auth status messages in SDK mode',\n      )\n        .default(false)\n        .hideHelp(),\n    )\n    .option(\n      '--allowedTools, --allowed-tools <tools...>',\n      'Comma or space-separated list of tool names to allow (e.g. \"Bash(git:*) Edit\")',\n    )\n    .option(\n      '--tools <tools...>',\n      'Specify the list of available tools from the built-in set. Use \"\" to disable all tools, \"default\" to use all tools, or specify tool names (e.g. \"Bash,Edit,Read\").',\n    )\n    .option(\n      '--disallowedTools, --disallowed-tools <tools...>',\n      'Comma or space-separated list of tool names to deny (e.g. \"Bash(git:*) Edit\")',\n    )\n    .option(\n      '--mcp-config <configs...>',\n      'Load MCP servers from JSON files or strings (space-separated)',\n    )\n    .addOption(\n      new Option(\n        '--permission-prompt-tool <tool>',\n        'MCP tool to use for permission prompts (only works with --print)',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--system-prompt <prompt>',\n        'System prompt to use for the session',\n      ).argParser(String),\n    )\n    .addOption(\n      new Option(\n        '--system-prompt-file <file>',\n        'Read system prompt from a file',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--append-system-prompt <prompt>',\n        'Append a system prompt to the default system prompt',\n      ).argParser(String),\n    )\n    .addOption(\n      new Option(\n        '--append-system-prompt-file <file>',\n        'Read system prompt from a file and append to the default system prompt',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--permission-mode <mode>',\n        'Permission mode to use for the session',\n      )\n        .argParser(String)\n        .choices(PERMISSION_MODES),\n    )\n    .option(\n      '-c, --continue',\n      'Continue the most recent conversation in the current directory',\n      () => true,\n    )\n    .option(\n      '-r, --resume [value]',\n      'Resume a conversation by session ID, or open interactive picker with optional search term',\n      value => value || true,\n    )\n    .option(\n      '--fork-session',\n      'When resuming, create a new session ID instead of reusing the original (use with --resume or --continue)',\n      () => true,\n    )\n    .addOption(\n      new Option(\n        '--prefill <text>',\n        'Pre-fill the prompt input with text without submitting it',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--deep-link-origin',\n        'Signal that this session was launched from a deep link',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--deep-link-repo <slug>',\n        'Repo slug the deep link ?repo= parameter resolved to the current cwd',\n      ).hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--deep-link-last-fetch <ms>',\n        'FETCH_HEAD mtime in epoch ms, precomputed by the deep link trampoline',\n      )\n        .argParser(v => {\n          const n = Number(v)\n          return Number.isFinite(n) ? n : undefined\n        })\n        .hideHelp(),\n    )\n    .option(\n      '--from-pr [value]',\n      'Resume a session linked to a PR by PR number/URL, or open interactive picker with optional search term',\n      value => value || true,\n    )\n    .option(\n      '--no-session-persistence',\n      'Disable session persistence - sessions will not be saved to disk and cannot be resumed (only works with --print)',\n    )\n    .addOption(\n      new Option(\n        '--resume-session-at <message id>',\n        'When resuming, only messages up to and including the assistant message with <message.id> (use with --resume in print mode)',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    .addOption(\n      new Option(\n        '--rewind-files <user-message-id>',\n        'Restore files to state at the specified user message and exit (requires --resume)',\n      ).hideHelp(),\n    )\n    // @[MODEL LAUNCH]: Update the example model ID in the --model help text.\n    .option(\n      '--model <model>',\n      `Model for the current session. Provide an alias for the latest model (e.g. 'sonnet' or 'opus') or a model's full name (e.g. 'claude-sonnet-4-6').`,\n    )\n    .addOption(\n      new Option(\n        '--effort <level>',\n        `Effort level for the current session (low, medium, high, max)`,\n      ).argParser((rawValue: string) => {\n        const value = rawValue.toLowerCase()\n        const allowed = ['low', 'medium', 'high', 'max']\n        if (!allowed.includes(value)) {\n          throw new InvalidArgumentError(\n            `It must be one of: ${allowed.join(', ')}`,\n          )\n        }\n        return value\n      }),\n    )\n    .option(\n      '--agent <agent>',\n      `Agent for the current session. Overrides the 'agent' setting.`,\n    )\n    .option(\n      '--betas <betas...>',\n      'Beta headers to include in API requests (API key users only)',\n    )\n    .option(\n      '--fallback-model <model>',\n      'Enable automatic fallback to specified model when default model is overloaded (only works with --print)',\n    )\n    .addOption(\n      new Option(\n        '--workload <tag>',\n        'Workload tag for billing-header attribution (cc_workload). Process-scoped; set by SDK daemon callers that spawn subprocesses for cron work. (only works with --print)',\n      ).hideHelp(),\n    )\n    .option(\n      '--settings <file-or-json>',\n      'Path to a settings JSON file or a JSON string to load additional settings from',\n    )\n    .option(\n      '--add-dir <directories...>',\n      'Additional directories to allow tool access to',\n    )\n    .option(\n      '--ide',\n      'Automatically connect to IDE on startup if exactly one valid IDE is available',\n      () => true,\n    )\n    .option(\n      '--strict-mcp-config',\n      'Only use MCP servers from --mcp-config, ignoring all other MCP configurations',\n      () => true,\n    )\n    .option(\n      '--session-id <uuid>',\n      'Use a specific session ID for the conversation (must be a valid UUID)',\n    )\n    .option(\n      '-n, --name <name>',\n      'Set a display name for this session (shown in /resume and terminal title)',\n    )\n    .option(\n      '--agents <json>',\n      'JSON object defining custom agents (e.g. \\'{\"reviewer\": {\"description\": \"Reviews code\", \"prompt\": \"You are a code reviewer\"}}\\')',\n    )\n    .option(\n      '--setting-sources <sources>',\n      'Comma-separated list of setting sources to load (user, project, local).',\n    )\n    // gh-33508: <paths...> (variadic) consumed everything until the next\n    // --flag. `claude --plugin-dir /path mcp add --transport http` swallowed\n    // `mcp` and `add` as paths, then choked on --transport as an unknown\n    // top-level option. Single-value + collect accumulator means each\n    // --plugin-dir takes exactly one arg; repeat the flag for multiple dirs.\n    .option(\n      '--plugin-dir <path>',\n      'Load plugins from a directory for this session only (repeatable: --plugin-dir A --plugin-dir B)',\n      (val: string, prev: string[]) => [...prev, val],\n      [] as string[],\n    )\n    .option('--disable-slash-commands', 'Disable all skills', () => true)\n    .option('--chrome', 'Enable Claude in Chrome integration')\n    .option('--no-chrome', 'Disable Claude in Chrome integration')\n    .option(\n      '--file <specs...>',\n      'File resources to download at startup. Format: file_id:relative_path (e.g., --file file_abc:doc.txt file_def:img.png)',\n    )\n    .action(async (prompt, options) => {\n      profileCheckpoint('action_handler_start')\n\n      // --bare = one-switch minimal mode. Sets SIMPLE so all the existing\n      // gates fire (CLAUDE.md, skills, hooks inside executeHooks, agent\n      // dir-walk). Must be set before setup() / any of the gated work runs.\n      if ((options as { bare?: boolean }).bare) {\n        process.env.CLAUDE_CODE_SIMPLE = '1'\n      }\n\n      // Ignore \"code\" as a prompt - treat it the same as no prompt\n      if (prompt === 'code') {\n        logEvent('tengu_code_prompt_ignored', {})\n        // biome-ignore lint/suspicious/noConsole:: intentional console output\n        console.warn(\n          chalk.yellow('Tip: You can launch Claude Code with just `claude`'),\n        )\n        prompt = undefined\n      }\n\n      // Log event for any single-word prompt\n      if (\n        prompt &&\n        typeof prompt === 'string' &&\n        !/\\s/.test(prompt) &&\n        prompt.length > 0\n      ) {\n        logEvent('tengu_single_word_prompt', { length: prompt.length })\n      }\n\n      // Assistant mode: when .claude/settings.json has assistant: true AND\n      // the tengu_kairos GrowthBook gate is on, force brief on. Permission\n      // mode is left to the user — settings defaultMode or --permission-mode\n      // apply as normal. REPL-typed messages already default to 'next'\n      // priority (messageQueueManager.enqueue) so they drain mid-turn between\n      // tool calls. SendUserMessage (BriefTool) is enabled via the brief env\n      // var. SleepTool stays disabled (its isEnabled() gates on proactive).\n      // kairosEnabled is computed once here and reused at the\n      // getAssistantSystemPromptAddendum() call site further down.\n      //\n      // Trust gate: .claude/settings.json is attacker-controllable in an\n      // untrusted clone. We run ~1000 lines before showSetupScreens() shows\n      // the trust dialog, and by then we've already appended\n      // .claude/agents/assistant.md to the system prompt. Refuse to activate\n      // until the directory has been explicitly trusted.\n      let kairosEnabled = false\n      let assistantTeamContext:\n        | Awaited<\n            ReturnType<\n              NonNullable<typeof assistantModule>['initializeAssistantTeam']\n            >\n          >\n        | undefined\n      if (\n        feature('KAIROS') &&\n        (options as { assistant?: boolean }).assistant &&\n        assistantModule\n      ) {\n        // --assistant (Agent SDK daemon mode): force the latch before\n        // isAssistantMode() runs below. The daemon has already checked\n        // entitlement — don't make the child re-check tengu_kairos.\n        assistantModule.markAssistantForced()\n      }\n      if (\n        feature('KAIROS') &&\n        assistantModule?.isAssistantMode() &&\n        // Spawned teammates share the leader's cwd + settings.json, so\n        // isAssistantMode() is true for them too. --agent-id being set\n        // means we ARE a spawned teammate (extractTeammateOptions runs\n        // ~170 lines later so check the raw commander option) — don't\n        // re-init the team or override teammateMode/proactive/brief.\n        !(options as { agentId?: unknown }).agentId &&\n        kairosGate\n      ) {\n        if (!checkHasTrustDialogAccepted()) {\n          // biome-ignore lint/suspicious/noConsole:: intentional console output\n          console.warn(\n            chalk.yellow(\n              'Assistant mode disabled: directory is not trusted. Accept the trust dialog and restart.',\n            ),\n          )\n        } else {\n          // Blocking gate check — returns cached `true` instantly; if disk\n          // cache is false/missing, lazily inits GrowthBook and fetches fresh\n          // (max ~5s). --assistant skips the gate entirely (daemon is\n          // pre-entitled).\n          kairosEnabled =\n            assistantModule.isAssistantForced() ||\n            (await kairosGate.isKairosEnabled())\n          if (kairosEnabled) {\n            const opts = options as { brief?: boolean }\n            opts.brief = true\n            setKairosActive(true)\n            // Pre-seed an in-process team so Agent(name: \"foo\") spawns\n            // teammates without TeamCreate. Must run BEFORE setup() captures\n            // the teammateMode snapshot (initializeAssistantTeam calls\n            // setCliTeammateModeOverride internally).\n            assistantTeamContext =\n              await assistantModule.initializeAssistantTeam()\n          }\n        }\n      }\n\n      const {\n        debug = false,\n        debugToStderr = false,\n        dangerouslySkipPermissions,\n        allowDangerouslySkipPermissions = false,\n        tools: baseTools = [],\n        allowedTools = [],\n        disallowedTools = [],\n        mcpConfig = [],\n        permissionMode: permissionModeCli,\n        addDir = [],\n        fallbackModel,\n        betas = [],\n        ide = false,\n        sessionId,\n        includeHookEvents,\n        includePartialMessages,\n      } = options\n\n      if (options.prefill) {\n        seedEarlyInput(options.prefill)\n      }\n\n      // Promise for file downloads - started early, awaited before REPL renders\n      let fileDownloadPromise: Promise<DownloadResult[]> | undefined\n\n      const agentsJson = options.agents\n      const agentCli = options.agent\n      if (feature('BG_SESSIONS') && agentCli) {\n        process.env.CLAUDE_CODE_AGENT = agentCli\n      }\n\n      // NOTE: LSP manager initialization is intentionally deferred until after\n      // the trust dialog is accepted. This prevents plugin LSP servers from\n      // executing code in untrusted directories before user consent.\n\n      // Extract these separately so they can be modified if needed\n      let outputFormat = options.outputFormat\n      let inputFormat = options.inputFormat\n      let verbose = options.verbose ?? getGlobalConfig().verbose\n      let print = options.print\n      const init = options.init ?? false\n      const initOnly = options.initOnly ?? false\n      const maintenance = options.maintenance ?? false\n\n      // Extract disable slash commands flag\n      const disableSlashCommands = options.disableSlashCommands || false\n\n      // Extract tasks mode options (ant-only)\n      const tasksOption =\n        \"external\" === 'ant' &&\n        (options as { tasks?: boolean | string }).tasks\n      const taskListId = tasksOption\n        ? typeof tasksOption === 'string'\n          ? tasksOption\n          : DEFAULT_TASKS_MODE_TASK_LIST_ID\n        : undefined\n      if (\"external\" === 'ant' && taskListId) {\n        process.env.CLAUDE_CODE_TASK_LIST_ID = taskListId\n      }\n\n      // Extract worktree option\n      // worktree can be true (flag without value) or a string (custom name or PR reference)\n      const worktreeOption = isWorktreeModeEnabled()\n        ? (options as { worktree?: boolean | string }).worktree\n        : undefined\n      let worktreeName =\n        typeof worktreeOption === 'string' ? worktreeOption : undefined\n      const worktreeEnabled = worktreeOption !== undefined\n\n      // Check if worktree name is a PR reference (#N or GitHub PR URL)\n      let worktreePRNumber: number | undefined\n      if (worktreeName) {\n        const prNum = parsePRReference(worktreeName)\n        if (prNum !== null) {\n          worktreePRNumber = prNum\n          worktreeName = undefined // slug will be generated in setup()\n        }\n      }\n\n      // Extract tmux option (requires --worktree)\n      const tmuxEnabled =\n        isWorktreeModeEnabled() && (options as { tmux?: boolean }).tmux === true\n\n      // Validate tmux option\n      if (tmuxEnabled) {\n        if (!worktreeEnabled) {\n          process.stderr.write(chalk.red('Error: --tmux requires --worktree\\n'))\n          process.exit(1)\n        }\n        if (getPlatform() === 'windows') {\n          process.stderr.write(\n            chalk.red('Error: --tmux is not supported on Windows\\n'),\n          )\n          process.exit(1)\n        }\n        if (!(await isTmuxAvailable())) {\n          process.stderr.write(\n            chalk.red(\n              `Error: tmux is not installed.\\n${getTmuxInstallInstructions()}\\n`,\n            ),\n          )\n          process.exit(1)\n        }\n      }\n\n      // Extract teammate options (for tmux-spawned agents)\n      // Declared outside the if block so it's accessible later for system prompt addendum\n      let storedTeammateOpts: TeammateOptions | undefined\n      if (isAgentSwarmsEnabled()) {\n        // Extract agent identity options (for tmux-spawned agents)\n        // These replace the CLAUDE_CODE_* environment variables\n        const teammateOpts = extractTeammateOptions(options)\n        storedTeammateOpts = teammateOpts\n\n        // If any teammate identity option is provided, all three required ones must be present\n        const hasAnyTeammateOpt =\n          teammateOpts.agentId ||\n          teammateOpts.agentName ||\n          teammateOpts.teamName\n        const hasAllRequiredTeammateOpts =\n          teammateOpts.agentId &&\n          teammateOpts.agentName &&\n          teammateOpts.teamName\n\n        if (hasAnyTeammateOpt && !hasAllRequiredTeammateOpts) {\n          process.stderr.write(\n            chalk.red(\n              'Error: --agent-id, --agent-name, and --team-name must all be provided together\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        // If teammate identity is provided via CLI, set up dynamicTeamContext\n        if (\n          teammateOpts.agentId &&\n          teammateOpts.agentName &&\n          teammateOpts.teamName\n        ) {\n          getTeammateUtils().setDynamicTeamContext?.({\n            agentId: teammateOpts.agentId,\n            agentName: teammateOpts.agentName,\n            teamName: teammateOpts.teamName,\n            color: teammateOpts.agentColor,\n            planModeRequired: teammateOpts.planModeRequired ?? false,\n            parentSessionId: teammateOpts.parentSessionId,\n          })\n        }\n\n        // Set teammate mode CLI override if provided\n        // This must be done before setup() captures the snapshot\n        if (teammateOpts.teammateMode) {\n          getTeammateModeSnapshot().setCliTeammateModeOverride?.(\n            teammateOpts.teammateMode,\n          )\n        }\n      }\n\n      // Extract remote sdk options\n      const sdkUrl = (options as { sdkUrl?: string }).sdkUrl ?? undefined\n\n      // Allow env var to enable partial messages (used by sandbox gateway for baku)\n      const effectiveIncludePartialMessages =\n        includePartialMessages ||\n        isEnvTruthy(process.env.CLAUDE_CODE_INCLUDE_PARTIAL_MESSAGES)\n\n      // Enable all hook event types when explicitly requested via SDK option\n      // or when running in CLAUDE_CODE_REMOTE mode (CCR needs them).\n      // Without this, only SessionStart and Setup events are emitted.\n      if (includeHookEvents || isEnvTruthy(process.env.CLAUDE_CODE_REMOTE)) {\n        setAllHookEventsEnabled(true)\n      }\n\n      // Auto-set input/output formats, verbose mode, and print mode when SDK URL is provided\n      if (sdkUrl) {\n        // If SDK URL is provided, automatically use stream-json formats unless explicitly set\n        if (!inputFormat) {\n          inputFormat = 'stream-json'\n        }\n        if (!outputFormat) {\n          outputFormat = 'stream-json'\n        }\n        // Auto-enable verbose mode unless explicitly disabled or already set\n        if (options.verbose === undefined) {\n          verbose = true\n        }\n        // Auto-enable print mode unless explicitly disabled\n        if (!options.print) {\n          print = true\n        }\n      }\n\n      // Extract teleport option\n      const teleport =\n        (options as { teleport?: string | true }).teleport ?? null\n\n      // Extract remote option (can be true if no description provided, or a string)\n      const remoteOption = (options as { remote?: string | true }).remote\n      const remote = remoteOption === true ? '' : (remoteOption ?? null)\n\n      // Extract --remote-control / --rc flag (enable bridge in interactive session)\n      const remoteControlOption =\n        (options as { remoteControl?: string | true }).remoteControl ??\n        (options as { rc?: string | true }).rc\n      // Actual bridge check is deferred to after showSetupScreens() so that\n      // trust is established and GrowthBook has auth headers.\n      let remoteControl = false\n      const remoteControlName =\n        typeof remoteControlOption === 'string' &&\n        remoteControlOption.length > 0\n          ? remoteControlOption\n          : undefined\n\n      // Validate session ID if provided\n      if (sessionId) {\n        // Check for conflicting flags\n        // --session-id can be used with --continue or --resume when --fork-session is also provided\n        // (to specify a custom ID for the forked session)\n        if ((options.continue || options.resume) && !options.forkSession) {\n          process.stderr.write(\n            chalk.red(\n              'Error: --session-id can only be used with --continue or --resume if --fork-session is also specified.\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        // When --sdk-url is provided (bridge/remote mode), the session ID is a\n        // server-assigned tagged ID (e.g. \"session_local_01...\") rather than a\n        // UUID. Skip UUID validation and local existence checks in that case.\n        if (!sdkUrl) {\n          const validatedSessionId = validateUuid(sessionId)\n          if (!validatedSessionId) {\n            process.stderr.write(\n              chalk.red('Error: Invalid session ID. Must be a valid UUID.\\n'),\n            )\n            process.exit(1)\n          }\n\n          // Check if session ID already exists\n          if (sessionIdExists(validatedSessionId)) {\n            process.stderr.write(\n              chalk.red(\n                `Error: Session ID ${validatedSessionId} is already in use.\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n        }\n      }\n\n      // Download file resources if specified via --file flag\n      const fileSpecs = (options as { file?: string[] }).file\n      if (fileSpecs && fileSpecs.length > 0) {\n        // Get session ingress token (provided by EnvManager via CLAUDE_CODE_SESSION_ACCESS_TOKEN)\n        const sessionToken = getSessionIngressAuthToken()\n        if (!sessionToken) {\n          process.stderr.write(\n            chalk.red(\n              'Error: Session token required for file downloads. CLAUDE_CODE_SESSION_ACCESS_TOKEN must be set.\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        // Resolve session ID: prefer remote session ID, fall back to internal session ID\n        const fileSessionId =\n          process.env.CLAUDE_CODE_REMOTE_SESSION_ID || getSessionId()\n\n        const files = parseFileSpecs(fileSpecs)\n        if (files.length > 0) {\n          // Use ANTHROPIC_BASE_URL if set (by EnvManager), otherwise use OAuth config\n          // This ensures consistency with session ingress API in all environments\n          const config: FilesApiConfig = {\n            baseUrl:\n              process.env.ANTHROPIC_BASE_URL || getOauthConfig().BASE_API_URL,\n            oauthToken: sessionToken,\n            sessionId: fileSessionId,\n          }\n\n          // Start download without blocking startup - await before REPL renders\n          fileDownloadPromise = downloadSessionFiles(files, config)\n        }\n      }\n\n      // Get isNonInteractiveSession from state (was set before init())\n      const isNonInteractiveSession = getIsNonInteractiveSession()\n\n      // Validate that fallback model is different from main model\n      if (fallbackModel && options.model && fallbackModel === options.model) {\n        process.stderr.write(\n          chalk.red(\n            'Error: Fallback model cannot be the same as the main model. Please specify a different model for --fallback-model.\\n',\n          ),\n        )\n        process.exit(1)\n      }\n\n      // Handle system prompt options\n      let systemPrompt = options.systemPrompt\n      if (options.systemPromptFile) {\n        if (options.systemPrompt) {\n          process.stderr.write(\n            chalk.red(\n              'Error: Cannot use both --system-prompt and --system-prompt-file. Please use only one.\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        try {\n          const filePath = resolve(options.systemPromptFile)\n          systemPrompt = readFileSync(filePath, 'utf8')\n        } catch (error) {\n          const code = getErrnoCode(error)\n          if (code === 'ENOENT') {\n            process.stderr.write(\n              chalk.red(\n                `Error: System prompt file not found: ${resolve(options.systemPromptFile)}\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n          process.stderr.write(\n            chalk.red(\n              `Error reading system prompt file: ${errorMessage(error)}\\n`,\n            ),\n          )\n          process.exit(1)\n        }\n      }\n\n      // Handle append system prompt options\n      let appendSystemPrompt = options.appendSystemPrompt\n      if (options.appendSystemPromptFile) {\n        if (options.appendSystemPrompt) {\n          process.stderr.write(\n            chalk.red(\n              'Error: Cannot use both --append-system-prompt and --append-system-prompt-file. Please use only one.\\n',\n            ),\n          )\n          process.exit(1)\n        }\n\n        try {\n          const filePath = resolve(options.appendSystemPromptFile)\n          appendSystemPrompt = readFileSync(filePath, 'utf8')\n        } catch (error) {\n          const code = getErrnoCode(error)\n          if (code === 'ENOENT') {\n            process.stderr.write(\n              chalk.red(\n                `Error: Append system prompt file not found: ${resolve(options.appendSystemPromptFile)}\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n          process.stderr.write(\n            chalk.red(\n              `Error reading append system prompt file: ${errorMessage(error)}\\n`,\n            ),\n          )\n          process.exit(1)\n        }\n      }\n\n      // Add teammate-specific system prompt addendum for tmux teammates\n      if (\n        isAgentSwarmsEnabled() &&\n        storedTeammateOpts?.agentId &&\n        storedTeammateOpts?.agentName &&\n        storedTeammateOpts?.teamName\n      ) {\n        const addendum =\n          getTeammatePromptAddendum().TEAMMATE_SYSTEM_PROMPT_ADDENDUM\n        appendSystemPrompt = appendSystemPrompt\n          ? `${appendSystemPrompt}\\n\\n${addendum}`\n          : addendum\n      }\n\n      const { mode: permissionMode, notification: permissionModeNotification } =\n        initialPermissionModeFromCLI({\n          permissionModeCli,\n          dangerouslySkipPermissions,\n        })\n\n      // Store session bypass permissions mode for trust dialog check\n      setSessionBypassPermissionsMode(permissionMode === 'bypassPermissions')\n      if (feature('TRANSCRIPT_CLASSIFIER')) {\n        // autoModeFlagCli is the \"did the user intend auto this session\" signal.\n        // Set when: --enable-auto-mode, --permission-mode auto, resolved mode\n        // is auto, OR settings defaultMode is auto but the gate denied it\n        // (permissionMode resolved to default with no explicit CLI override).\n        // Used by verifyAutoModeGateAccess to decide whether to notify on\n        // auto-unavailable, and by tengu_auto_mode_config opt-in carousel.\n        if (\n          (options as { enableAutoMode?: boolean }).enableAutoMode ||\n          permissionModeCli === 'auto' ||\n          permissionMode === 'auto' ||\n          (!permissionModeCli && isDefaultPermissionModeAuto())\n        ) {\n          autoModeStateModule?.setAutoModeFlagCli(true)\n        }\n      }\n\n      // Parse the MCP config files/strings if provided\n      let dynamicMcpConfig: Record<string, ScopedMcpServerConfig> = {}\n\n      if (mcpConfig && mcpConfig.length > 0) {\n        // Process mcpConfig array\n        const processedConfigs = mcpConfig\n          .map(config => config.trim())\n          .filter(config => config.length > 0)\n\n        let allConfigs: Record<string, McpServerConfig> = {}\n        const allErrors: ValidationError[] = []\n\n        for (const configItem of processedConfigs) {\n          let configs: Record<string, McpServerConfig> | null = null\n          let errors: ValidationError[] = []\n\n          // First try to parse as JSON string\n          const parsedJson = safeParseJSON(configItem)\n          if (parsedJson) {\n            const result = parseMcpConfig({\n              configObject: parsedJson,\n              filePath: 'command line',\n              expandVars: true,\n              scope: 'dynamic',\n            })\n            if (result.config) {\n              configs = result.config.mcpServers\n            } else {\n              errors = result.errors\n            }\n          } else {\n            // Try as file path\n            const configPath = resolve(configItem)\n            const result = parseMcpConfigFromFilePath({\n              filePath: configPath,\n              expandVars: true,\n              scope: 'dynamic',\n            })\n            if (result.config) {\n              configs = result.config.mcpServers\n            } else {\n              errors = result.errors\n            }\n          }\n\n          if (errors.length > 0) {\n            allErrors.push(...errors)\n          } else if (configs) {\n            // Merge configs, later ones override earlier ones\n            allConfigs = { ...allConfigs, ...configs }\n          }\n        }\n\n        if (allErrors.length > 0) {\n          const formattedErrors = allErrors\n            .map(err => `${err.path ? err.path + ': ' : ''}${err.message}`)\n            .join('\\n')\n          logForDebugging(\n            `--mcp-config validation failed (${allErrors.length} errors): ${formattedErrors}`,\n            { level: 'error' },\n          )\n          process.stderr.write(\n            `Error: Invalid MCP configuration:\\n${formattedErrors}\\n`,\n          )\n          process.exit(1)\n        }\n\n        if (Object.keys(allConfigs).length > 0) {\n          // SDK hosts (Nest/Desktop) own their server naming and may reuse\n          // built-in names — skip reserved-name checks for type:'sdk'.\n          const nonSdkConfigNames = Object.entries(allConfigs)\n            .filter(([, config]) => config.type !== 'sdk')\n            .map(([name]) => name)\n\n          let reservedNameError: string | null = null\n          if (nonSdkConfigNames.some(isClaudeInChromeMCPServer)) {\n            reservedNameError = `Invalid MCP configuration: \"${CLAUDE_IN_CHROME_MCP_SERVER_NAME}\" is a reserved MCP name.`\n          } else if (feature('CHICAGO_MCP')) {\n            const { isComputerUseMCPServer, COMPUTER_USE_MCP_SERVER_NAME } =\n              await import('src/utils/computerUse/common.js')\n            if (nonSdkConfigNames.some(isComputerUseMCPServer)) {\n              reservedNameError = `Invalid MCP configuration: \"${COMPUTER_USE_MCP_SERVER_NAME}\" is a reserved MCP name.`\n            }\n          }\n          if (reservedNameError) {\n            // stderr+exit(1) — a throw here becomes a silent unhandled\n            // rejection in stream-json mode (void main() in cli.tsx).\n            process.stderr.write(`Error: ${reservedNameError}\\n`)\n            process.exit(1)\n          }\n\n          // Add dynamic scope to all configs. type:'sdk' entries pass through\n          // unchanged — they're extracted into sdkMcpConfigs downstream and\n          // passed to print.ts. The Python SDK relies on this path (it doesn't\n          // send sdkMcpServers in the initialize message). Dropping them here\n          // broke Coworker (inc-5122). The policy filter below already exempts\n          // type:'sdk', and the entries are inert without an SDK transport on\n          // stdin, so there's no bypass risk from letting them through.\n          const scopedConfigs = mapValues(allConfigs, config => ({\n            ...config,\n            scope: 'dynamic' as const,\n          }))\n\n          // Enforce managed policy (allowedMcpServers / deniedMcpServers) on\n          // --mcp-config servers. Without this, the CLI flag bypasses the\n          // enterprise allowlist that user/project/local configs go through in\n          // getClaudeCodeMcpConfigs — callers spread dynamicMcpConfig back on\n          // top of filtered results. Filter here at the source so all\n          // downstream consumers see the policy-filtered set.\n          const { allowed, blocked } = filterMcpServersByPolicy(scopedConfigs)\n          if (blocked.length > 0) {\n            process.stderr.write(\n              `Warning: MCP ${plural(blocked.length, 'server')} blocked by enterprise policy: ${blocked.join(', ')}\\n`,\n            )\n          }\n          dynamicMcpConfig = { ...dynamicMcpConfig, ...allowed }\n        }\n      }\n\n      // Extract Claude in Chrome option and enforce claude.ai subscriber check (unless user is ant)\n      const chromeOpts = options as { chrome?: boolean }\n      // Store the explicit CLI flag so teammates can inherit it\n      setChromeFlagOverride(chromeOpts.chrome)\n      const enableClaudeInChrome =\n        shouldEnableClaudeInChrome(chromeOpts.chrome) &&\n        (\"external\" === 'ant' || isClaudeAISubscriber())\n      const autoEnableClaudeInChrome =\n        !enableClaudeInChrome && shouldAutoEnableClaudeInChrome()\n\n      if (enableClaudeInChrome) {\n        const platform = getPlatform()\n        try {\n          logEvent('tengu_claude_in_chrome_setup', {\n            platform:\n              platform as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n\n          const {\n            mcpConfig: chromeMcpConfig,\n            allowedTools: chromeMcpTools,\n            systemPrompt: chromeSystemPrompt,\n          } = setupClaudeInChrome()\n          dynamicMcpConfig = { ...dynamicMcpConfig, ...chromeMcpConfig }\n          allowedTools.push(...chromeMcpTools)\n          if (chromeSystemPrompt) {\n            appendSystemPrompt = appendSystemPrompt\n              ? `${chromeSystemPrompt}\\n\\n${appendSystemPrompt}`\n              : chromeSystemPrompt\n          }\n        } catch (error) {\n          logEvent('tengu_claude_in_chrome_setup_failed', {\n            platform:\n              platform as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n          logForDebugging(`[Claude in Chrome] Error: ${error}`)\n          logError(error)\n          // biome-ignore lint/suspicious/noConsole:: intentional console output\n          console.error(`Error: Failed to run with Claude in Chrome.`)\n          process.exit(1)\n        }\n      } else if (autoEnableClaudeInChrome) {\n        try {\n          const { mcpConfig: chromeMcpConfig } = setupClaudeInChrome()\n          dynamicMcpConfig = { ...dynamicMcpConfig, ...chromeMcpConfig }\n\n          const hint =\n            feature('WEB_BROWSER_TOOL') &&\n            typeof Bun !== 'undefined' &&\n            'WebView' in Bun\n              ? CLAUDE_IN_CHROME_SKILL_HINT_WITH_WEBBROWSER\n              : CLAUDE_IN_CHROME_SKILL_HINT\n          appendSystemPrompt = appendSystemPrompt\n            ? `${appendSystemPrompt}\\n\\n${hint}`\n            : hint\n        } catch (error) {\n          // Silently skip any errors for the auto-enable\n          logForDebugging(`[Claude in Chrome] Error (auto-enable): ${error}`)\n        }\n      }\n\n      // Extract strict MCP config flag\n      const strictMcpConfig = options.strictMcpConfig || false\n\n      // Check if enterprise MCP configuration exists. When it does, only allow dynamic MCP\n      // configs that contain special server types (sdk)\n      if (doesEnterpriseMcpConfigExist()) {\n        if (strictMcpConfig) {\n          process.stderr.write(\n            chalk.red(\n              'You cannot use --strict-mcp-config when an enterprise MCP config is present',\n            ),\n          )\n          process.exit(1)\n        }\n\n        // For --mcp-config, allow if all servers are internal types (sdk)\n        if (\n          dynamicMcpConfig &&\n          !areMcpConfigsAllowedWithEnterpriseMcpConfig(dynamicMcpConfig)\n        ) {\n          process.stderr.write(\n            chalk.red(\n              'You cannot dynamically configure MCP servers when an enterprise MCP config is present',\n            ),\n          )\n          process.exit(1)\n        }\n      }\n\n      // chicago MCP: guarded Computer Use (app allowlist + frontmost gate +\n      // SCContentFilter screenshots). Ant-only, GrowthBook-gated — failures\n      // are silent (this is dogfooding). Platform + interactive checks inline\n      // so non-macOS / print-mode ants skip the heavy @ant/computer-use-mcp\n      // import entirely. gates.js is light (type-only package import).\n      //\n      // Placed AFTER the enterprise-MCP-config check: that check rejects any\n      // dynamicMcpConfig entry with `type !== 'sdk'`, and our config is\n      // `type: 'stdio'`. An enterprise-config ant with the GB gate on would\n      // otherwise process.exit(1). Chrome has the same latent issue but has\n      // shipped without incident; chicago places itself correctly.\n      if (\n        feature('CHICAGO_MCP') &&\n        getPlatform() === 'macos' &&\n        !getIsNonInteractiveSession()\n      ) {\n        try {\n          const { getChicagoEnabled } = await import(\n            'src/utils/computerUse/gates.js'\n          )\n          if (getChicagoEnabled()) {\n            const { setupComputerUseMCP } = await import(\n              'src/utils/computerUse/setup.js'\n            )\n            const { mcpConfig, allowedTools: cuTools } = setupComputerUseMCP()\n            dynamicMcpConfig = { ...dynamicMcpConfig, ...mcpConfig }\n            allowedTools.push(...cuTools)\n          }\n        } catch (error) {\n          logForDebugging(\n            `[Computer Use MCP] Setup failed: ${errorMessage(error)}`,\n          )\n        }\n      }\n\n      // Store additional directories for CLAUDE.md loading (controlled by env var)\n      setAdditionalDirectoriesForClaudeMd(addDir)\n\n      // Channel server allowlist from --channels flag — servers whose\n      // inbound push notifications should register this session. The option\n      // is added inside a feature() block so TS doesn't know about it\n      // on the options type — same pattern as --assistant at main.tsx:1824.\n      // devChannels is deferred: showSetupScreens shows a confirmation dialog\n      // and only appends to allowedChannels on accept.\n      let devChannels: ChannelEntry[] | undefined\n      if (feature('KAIROS') || feature('KAIROS_CHANNELS')) {\n        // Parse plugin:name@marketplace / server:Y tags into typed entries.\n        // Tag decides trust model downstream: plugin-kind hits marketplace\n        // verification + GrowthBook allowlist, server-kind always fails\n        // allowlist (schema is plugin-only) unless dev flag is set.\n        // Untagged or marketplace-less plugin entries are hard errors —\n        // silently not-matching in the gate would look like channels are\n        // \"on\" but nothing ever fires.\n        const parseChannelEntries = (\n          raw: string[],\n          flag: string,\n        ): ChannelEntry[] => {\n          const entries: ChannelEntry[] = []\n          const bad: string[] = []\n          for (const c of raw) {\n            if (c.startsWith('plugin:')) {\n              const rest = c.slice(7)\n              const at = rest.indexOf('@')\n              if (at <= 0 || at === rest.length - 1) {\n                bad.push(c)\n              } else {\n                entries.push({\n                  kind: 'plugin',\n                  name: rest.slice(0, at),\n                  marketplace: rest.slice(at + 1),\n                })\n              }\n            } else if (c.startsWith('server:') && c.length > 7) {\n              entries.push({ kind: 'server', name: c.slice(7) })\n            } else {\n              bad.push(c)\n            }\n          }\n          if (bad.length > 0) {\n            process.stderr.write(\n              chalk.red(\n                `${flag} entries must be tagged: ${bad.join(', ')}\\n` +\n                  `  plugin:<name>@<marketplace>  — plugin-provided channel (allowlist enforced)\\n` +\n                  `  server:<name>                — manually configured MCP server\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n          return entries\n        }\n\n        const channelOpts = options as {\n          channels?: string[]\n          dangerouslyLoadDevelopmentChannels?: string[]\n        }\n        const rawChannels = channelOpts.channels\n        const rawDev = channelOpts.dangerouslyLoadDevelopmentChannels\n        // Always parse + set. ChannelsNotice reads getAllowedChannels() and\n        // renders the appropriate branch (disabled/noAuth/policyBlocked/\n        // listening) in the startup screen. gateChannelServer() enforces.\n        // --channels works in both interactive and print/SDK modes; dev-channels\n        // stays interactive-only (requires a confirmation dialog).\n        let channelEntries: ChannelEntry[] = []\n        if (rawChannels && rawChannels.length > 0) {\n          channelEntries = parseChannelEntries(rawChannels, '--channels')\n          setAllowedChannels(channelEntries)\n        }\n        if (!isNonInteractiveSession) {\n          if (rawDev && rawDev.length > 0) {\n            devChannels = parseChannelEntries(\n              rawDev,\n              '--dangerously-load-development-channels',\n            )\n          }\n        }\n        // Flag-usage telemetry. Plugin identifiers are logged (same tier as\n        // tengu_plugin_installed — public-registry-style names); server-kind\n        // names are not (MCP-server-name tier, opt-in-only elsewhere).\n        // Per-server gate outcomes land in tengu_mcp_channel_gate once\n        // servers connect. Dev entries go through a confirmation dialog after\n        // this — dev_plugins captures what was typed, not what was accepted.\n        if (channelEntries.length > 0 || (devChannels?.length ?? 0) > 0) {\n          const joinPluginIds = (entries: ChannelEntry[]) => {\n            const ids = entries.flatMap(e =>\n              e.kind === 'plugin' ? [`${e.name}@${e.marketplace}`] : [],\n            )\n            return ids.length > 0\n              ? (ids\n                  .sort()\n                  .join(\n                    ',',\n                  ) as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS)\n              : undefined\n          }\n          logEvent('tengu_mcp_channel_flags', {\n            channels_count: channelEntries.length,\n            dev_count: devChannels?.length ?? 0,\n            plugins: joinPluginIds(channelEntries),\n            dev_plugins: joinPluginIds(devChannels ?? []),\n          })\n        }\n      }\n\n      // SDK opt-in for SendUserMessage via --tools. All sessions require\n      // explicit opt-in; listing it in --tools signals intent. Runs BEFORE\n      // initializeToolPermissionContext so getToolsForDefaultPreset() sees\n      // the tool as enabled when computing the base-tools disallow filter.\n      // Conditional require avoids leaking the tool-name string into\n      // external builds.\n      if (\n        (feature('KAIROS') || feature('KAIROS_BRIEF')) &&\n        baseTools.length > 0\n      ) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const { BRIEF_TOOL_NAME, LEGACY_BRIEF_TOOL_NAME } =\n          require('./tools/BriefTool/prompt.js') as typeof import('./tools/BriefTool/prompt.js')\n        const { isBriefEntitled } =\n          require('./tools/BriefTool/BriefTool.js') as typeof import('./tools/BriefTool/BriefTool.js')\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        const parsed = parseToolListFromCLI(baseTools)\n        if (\n          (parsed.includes(BRIEF_TOOL_NAME) ||\n            parsed.includes(LEGACY_BRIEF_TOOL_NAME)) &&\n          isBriefEntitled()\n        ) {\n          setUserMsgOptIn(true)\n        }\n      }\n\n      // This await replaces blocking existsSync/statSync calls that were already in\n      // the startup path. Wall-clock time is unchanged; we just yield to the event\n      // loop during the fs I/O instead of blocking it. See #19661.\n      const initResult = await initializeToolPermissionContext({\n        allowedToolsCli: allowedTools,\n        disallowedToolsCli: disallowedTools,\n        baseToolsCli: baseTools,\n        permissionMode,\n        allowDangerouslySkipPermissions,\n        addDirs: addDir,\n      })\n      let toolPermissionContext = initResult.toolPermissionContext\n      const { warnings, dangerousPermissions, overlyBroadBashPermissions } =\n        initResult\n\n      // Handle overly broad shell allow rules for ant users (Bash(*), PowerShell(*))\n      if (\n        \"external\" === 'ant' &&\n        overlyBroadBashPermissions.length > 0\n      ) {\n        for (const permission of overlyBroadBashPermissions) {\n          logForDebugging(\n            `Ignoring overly broad shell permission ${permission.ruleDisplay} from ${permission.sourceDisplay}`,\n          )\n        }\n        toolPermissionContext = removeDangerousPermissions(\n          toolPermissionContext,\n          overlyBroadBashPermissions,\n        )\n      }\n\n      if (feature('TRANSCRIPT_CLASSIFIER') && dangerousPermissions.length > 0) {\n        toolPermissionContext = stripDangerousPermissionsForAutoMode(\n          toolPermissionContext,\n        )\n      }\n\n      // Print any warnings from initialization\n      warnings.forEach(warning => {\n        // biome-ignore lint/suspicious/noConsole:: intentional console output\n        console.error(warning)\n      })\n\n      void assertMinVersion()\n\n      // claude.ai config fetch: -p mode only (interactive uses useManageMCPConnections\n      // two-phase loading). Kicked off here to overlap with setup(); awaited\n      // before runHeadless so single-turn -p sees connectors. Skipped under\n      // enterprise/strict MCP to preserve policy boundaries.\n      const claudeaiConfigPromise: Promise<\n        Record<string, ScopedMcpServerConfig>\n      > =\n        isNonInteractiveSession &&\n        !strictMcpConfig &&\n        !doesEnterpriseMcpConfigExist() &&\n        // --bare / SIMPLE: skip claude.ai proxy servers (datadog, Gmail,\n        // Slack, BigQuery, PubMed — 6-14s each to connect). Scripted calls\n        // that need MCP pass --mcp-config explicitly.\n        !isBareMode()\n          ? fetchClaudeAIMcpConfigsIfEligible().then(configs => {\n              const { allowed, blocked } = filterMcpServersByPolicy(configs)\n              if (blocked.length > 0) {\n                process.stderr.write(\n                  `Warning: claude.ai MCP ${plural(blocked.length, 'server')} blocked by enterprise policy: ${blocked.join(', ')}\\n`,\n                )\n              }\n              return allowed\n            })\n          : Promise.resolve({})\n\n      // Kick off MCP config loading early (safe - just reads files, no execution).\n      // Both interactive and -p use getClaudeCodeMcpConfigs (local file reads only).\n      // The local promise is awaited later (before prefetchAllMcpResources) to\n      // overlap config I/O with setup(), commands loading, and trust dialog.\n      logForDebugging('[STARTUP] Loading MCP configs...')\n      const mcpConfigStart = Date.now()\n      let mcpConfigResolvedMs: number | undefined\n      // --bare skips auto-discovered MCP (.mcp.json, user settings, plugins) —\n      // only explicit --mcp-config works. dynamicMcpConfig is spread onto\n      // allMcpConfigs downstream so it survives this skip.\n      const mcpConfigPromise = (\n        strictMcpConfig || isBareMode()\n          ? Promise.resolve({\n              servers: {} as Record<string, ScopedMcpServerConfig>,\n            })\n          : getClaudeCodeMcpConfigs(dynamicMcpConfig)\n      ).then(result => {\n        mcpConfigResolvedMs = Date.now() - mcpConfigStart\n        return result\n      })\n\n      // NOTE: We do NOT call prefetchAllMcpResources here - that's deferred until after trust dialog\n\n      if (\n        inputFormat &&\n        inputFormat !== 'text' &&\n        inputFormat !== 'stream-json'\n      ) {\n        // biome-ignore lint/suspicious/noConsole:: intentional console output\n        console.error(`Error: Invalid input format \"${inputFormat}\".`)\n        process.exit(1)\n      }\n      if (inputFormat === 'stream-json' && outputFormat !== 'stream-json') {\n        // biome-ignore lint/suspicious/noConsole:: intentional console output\n        console.error(\n          `Error: --input-format=stream-json requires output-format=stream-json.`,\n        )\n        process.exit(1)\n      }\n\n      // Validate sdkUrl is only used with appropriate formats (formats are auto-set above)\n      if (sdkUrl) {\n        if (inputFormat !== 'stream-json' || outputFormat !== 'stream-json') {\n          // biome-ignore lint/suspicious/noConsole:: intentional console output\n          console.error(\n            `Error: --sdk-url requires both --input-format=stream-json and --output-format=stream-json.`,\n          )\n          process.exit(1)\n        }\n      }\n\n      // Validate replayUserMessages is only used with stream-json formats\n      if (options.replayUserMessages) {\n        if (inputFormat !== 'stream-json' || outputFormat !== 'stream-json') {\n          // biome-ignore lint/suspicious/noConsole:: intentional console output\n          console.error(\n            `Error: --replay-user-messages requires both --input-format=stream-json and --output-format=stream-json.`,\n          )\n          process.exit(1)\n        }\n      }\n\n      // Validate includePartialMessages is only used with print mode and stream-json output\n      if (effectiveIncludePartialMessages) {\n        if (!isNonInteractiveSession || outputFormat !== 'stream-json') {\n          writeToStderr(\n            `Error: --include-partial-messages requires --print and --output-format=stream-json.`,\n          )\n          process.exit(1)\n        }\n      }\n\n      // Validate --no-session-persistence is only used with print mode\n      if (options.sessionPersistence === false && !isNonInteractiveSession) {\n        writeToStderr(\n          `Error: --no-session-persistence can only be used with --print mode.`,\n        )\n        process.exit(1)\n      }\n\n      const effectivePrompt = prompt || ''\n      let inputPrompt = await getInputPrompt(\n        effectivePrompt,\n        (inputFormat ?? 'text') as 'text' | 'stream-json',\n      )\n      profileCheckpoint('action_after_input_prompt')\n\n      // Activate proactive mode BEFORE getTools() so SleepTool.isEnabled()\n      // (which returns isProactiveActive()) passes and Sleep is included.\n      // The later REPL-path maybeActivateProactive() calls are idempotent.\n      maybeActivateProactive(options)\n\n      let tools = getTools(toolPermissionContext)\n\n      // Apply coordinator mode tool filtering for headless path\n      // (mirrors useMergedTools.ts filtering for REPL/interactive path)\n      if (\n        feature('COORDINATOR_MODE') &&\n        isEnvTruthy(process.env.CLAUDE_CODE_COORDINATOR_MODE)\n      ) {\n        const { applyCoordinatorToolFilter } = await import(\n          './utils/toolPool.js'\n        )\n        tools = applyCoordinatorToolFilter(tools)\n      }\n\n      profileCheckpoint('action_tools_loaded')\n\n      let jsonSchema: ToolInputJSONSchema | undefined\n      if (\n        isSyntheticOutputToolEnabled({ isNonInteractiveSession }) &&\n        options.jsonSchema\n      ) {\n        jsonSchema = jsonParse(options.jsonSchema) as ToolInputJSONSchema\n      }\n\n      if (jsonSchema) {\n        const syntheticOutputResult = createSyntheticOutputTool(jsonSchema)\n        if ('tool' in syntheticOutputResult) {\n          // Add SyntheticOutputTool to the tools array AFTER getTools() filtering.\n          // This tool is excluded from normal filtering (see tools.ts) because it's\n          // an implementation detail for structured output, not a user-controlled tool.\n          tools = [...tools, syntheticOutputResult.tool]\n\n          logEvent('tengu_structured_output_enabled', {\n            schema_property_count: Object.keys(\n              (jsonSchema.properties as Record<string, unknown>) || {},\n            )\n              .length as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n            has_required_fields: Boolean(\n              jsonSchema.required,\n            ) as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n        } else {\n          logEvent('tengu_structured_output_failure', {\n            error:\n              'Invalid JSON schema' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n        }\n      }\n\n      // IMPORTANT: setup() must be called before any other code that depends on the cwd or worktree setup\n      profileCheckpoint('action_before_setup')\n      logForDebugging('[STARTUP] Running setup()...')\n      const setupStart = Date.now()\n      const { setup } = await import('./setup.js')\n      const messagingSocketPath = feature('UDS_INBOX')\n        ? (options as { messagingSocketPath?: string }).messagingSocketPath\n        : undefined\n      // Parallelize setup() with commands+agents loading. setup()'s ~28ms is\n      // mostly startUdsMessaging (socket bind, ~20ms) — not disk-bound, so it\n      // doesn't contend with getCommands' file reads. Gated on !worktreeEnabled\n      // since --worktree makes setup() process.chdir() (setup.ts:203), and\n      // commands/agents need the post-chdir cwd.\n      const preSetupCwd = getCwd()\n      // Register bundled skills/plugins before kicking getCommands() — they're\n      // pure in-memory array pushes (<1ms, zero I/O) that getBundledSkills()\n      // reads synchronously. Previously ran inside setup() after ~20ms of\n      // await points, so the parallel getCommands() memoized an empty list.\n      if (process.env.CLAUDE_CODE_ENTRYPOINT !== 'local-agent') {\n        initBuiltinPlugins()\n        initBundledSkills()\n      }\n      const setupPromise = setup(\n        preSetupCwd,\n        permissionMode,\n        allowDangerouslySkipPermissions,\n        worktreeEnabled,\n        worktreeName,\n        tmuxEnabled,\n        sessionId ? validateUuid(sessionId) : undefined,\n        worktreePRNumber,\n        messagingSocketPath,\n      )\n      const commandsPromise = worktreeEnabled ? null : getCommands(preSetupCwd)\n      const agentDefsPromise = worktreeEnabled\n        ? null\n        : getAgentDefinitionsWithOverrides(preSetupCwd)\n      // Suppress transient unhandledRejection if these reject during the\n      // ~28ms setupPromise await before Promise.all joins them below.\n      commandsPromise?.catch(() => {})\n      agentDefsPromise?.catch(() => {})\n      await setupPromise\n      logForDebugging(\n        `[STARTUP] setup() completed in ${Date.now() - setupStart}ms`,\n      )\n      profileCheckpoint('action_after_setup')\n\n      // Replay user messages into stream-json only when the socket was\n      // explicitly requested. The auto-generated socket is passive — it\n      // lets tools inject if they want to, but turning it on by default\n      // shouldn't reshape stream-json for SDK consumers who never touch it.\n      // Callers who inject and also want those injections visible in the\n      // stream pass --messaging-socket-path explicitly (or --replay-user-messages).\n      let effectiveReplayUserMessages = !!options.replayUserMessages\n      if (feature('UDS_INBOX')) {\n        if (!effectiveReplayUserMessages && outputFormat === 'stream-json') {\n          effectiveReplayUserMessages = !!(\n            options as { messagingSocketPath?: string }\n          ).messagingSocketPath\n        }\n      }\n\n      if (getIsNonInteractiveSession()) {\n        // Apply full merged settings env now (including project-scoped\n        // .claude/settings.json PATH/GIT_DIR/GIT_WORK_TREE) so gitExe() and\n        // the git spawn below see it. Trust is implicit in -p mode; the\n        // docstring at managedEnv.ts:96-97 says this applies \"potentially\n        // dangerous environment variables such as LD_PRELOAD, PATH\" from all\n        // sources. The later call in the isNonInteractiveSession block below\n        // is idempotent (Object.assign, configureGlobalAgents ejects prior\n        // interceptor) and picks up any plugin-contributed env after plugin\n        // init. Project settings are already loaded here:\n        // applySafeConfigEnvironmentVariables in init() called\n        // getSettings_DEPRECATED at managedEnv.ts:86 which merges all enabled\n        // sources including projectSettings/localSettings.\n        applyConfigEnvironmentVariables()\n\n        // Spawn git status/log/branch now so the subprocess execution overlaps\n        // with the getCommands await below and startDeferredPrefetches. After\n        // setup() so cwd is final (setup.ts:254 may process.chdir(worktreePath)\n        // for --worktree) and after the applyConfigEnvironmentVariables above\n        // so PATH/GIT_DIR/GIT_WORK_TREE from all sources (trusted + project)\n        // are applied. getSystemContext is memoized; the\n        // prefetchSystemContextIfSafe call in startDeferredPrefetches becomes\n        // a cache hit. The microtask from await getIsGit() drains at the\n        // getCommands Promise.all await below. Trust is implicit in -p mode\n        // (same gate as prefetchSystemContextIfSafe).\n        void getSystemContext()\n        // Kick getUserContext now too — its first await (fs.readFile in\n        // getMemoryFiles) yields naturally, so the CLAUDE.md directory walk\n        // runs during the ~280ms overlap window before the context\n        // Promise.all join in print.ts. The void getUserContext() in\n        // startDeferredPrefetches becomes a memoize cache-hit.\n        void getUserContext()\n        // Kick ensureModelStringsInitialized now — for Bedrock this triggers\n        // a 100-200ms profile fetch that was awaited serially at\n        // print.ts:739. updateBedrockModelStrings is sequential()-wrapped so\n        // the await joins the in-flight fetch. Non-Bedrock is a sync\n        // early-return (zero-cost).\n        void ensureModelStringsInitialized()\n      }\n\n      // Apply --name: cache-only so no orphan file is created before the\n      // session ID is finalized by --continue/--resume. materializeSessionFile\n      // persists it on the first user message; REPL's useTerminalTitle reads it\n      // via getCurrentSessionTitle.\n      const sessionNameArg = options.name?.trim()\n      if (sessionNameArg) {\n        cacheSessionTitle(sessionNameArg)\n      }\n\n      // Ant model aliases (capybara-fast etc.) resolve via the\n      // tengu_ant_model_override GrowthBook flag. _CACHED_MAY_BE_STALE reads\n      // disk synchronously; disk is populated by a fire-and-forget write. On a\n      // cold cache, parseUserSpecifiedModel returns the unresolved alias, the\n      // API 404s, and -p exits before the async write lands — crashloop on\n      // fresh pods. Awaiting init here populates the in-memory payload map that\n      // _CACHED_MAY_BE_STALE now checks first. Gated so the warm path stays\n      // non-blocking:\n      //  - explicit model via --model or ANTHROPIC_MODEL (both feed alias resolution)\n      //  - no env override (which short-circuits _CACHED_MAY_BE_STALE before disk)\n      //  - flag absent from disk (== null also catches pre-#22279 poisoned null)\n      const explicitModel = options.model || process.env.ANTHROPIC_MODEL\n      if (\n        \"external\" === 'ant' &&\n        explicitModel &&\n        explicitModel !== 'default' &&\n        !hasGrowthBookEnvOverride('tengu_ant_model_override') &&\n        getGlobalConfig().cachedGrowthBookFeatures?.[\n          'tengu_ant_model_override'\n        ] == null\n      ) {\n        await initializeGrowthBook()\n      }\n\n      // Special case the default model with the null keyword\n      // NOTE: Model resolution happens after setup() to ensure trust is established before AWS auth\n      const userSpecifiedModel =\n        options.model === 'default' ? getDefaultMainLoopModel() : options.model\n      const userSpecifiedFallbackModel =\n        fallbackModel === 'default' ? getDefaultMainLoopModel() : fallbackModel\n\n      // Reuse preSetupCwd unless setup() chdir'd (worktreeEnabled). Saves a\n      // getCwd() syscall in the common path.\n      const currentCwd = worktreeEnabled ? getCwd() : preSetupCwd\n      logForDebugging('[STARTUP] Loading commands and agents...')\n      const commandsStart = Date.now()\n      // Join the promises kicked before setup() (or start fresh if\n      // worktreeEnabled gated the early kick). Both memoized by cwd.\n      const [commands, agentDefinitionsResult] = await Promise.all([\n        commandsPromise ?? getCommands(currentCwd),\n        agentDefsPromise ?? getAgentDefinitionsWithOverrides(currentCwd),\n      ])\n      logForDebugging(\n        `[STARTUP] Commands and agents loaded in ${Date.now() - commandsStart}ms`,\n      )\n      profileCheckpoint('action_commands_loaded')\n\n      // Parse CLI agents if provided via --agents flag\n      let cliAgents: typeof agentDefinitionsResult.activeAgents = []\n      if (agentsJson) {\n        try {\n          const parsedAgents = safeParseJSON(agentsJson)\n          if (parsedAgents) {\n            cliAgents = parseAgentsFromJson(parsedAgents, 'flagSettings')\n          }\n        } catch (error) {\n          logError(error)\n        }\n      }\n\n      // Merge CLI agents with existing ones\n      const allAgents = [...agentDefinitionsResult.allAgents, ...cliAgents]\n      const agentDefinitions = {\n        ...agentDefinitionsResult,\n        allAgents,\n        activeAgents: getActiveAgentsFromList(allAgents),\n      }\n\n      // Look up main thread agent from CLI flag or settings\n      const agentSetting = agentCli ?? getInitialSettings().agent\n      let mainThreadAgentDefinition:\n        | (typeof agentDefinitions.activeAgents)[number]\n        | undefined\n      if (agentSetting) {\n        mainThreadAgentDefinition = agentDefinitions.activeAgents.find(\n          agent => agent.agentType === agentSetting,\n        )\n        if (!mainThreadAgentDefinition) {\n          logForDebugging(\n            `Warning: agent \"${agentSetting}\" not found. ` +\n              `Available agents: ${agentDefinitions.activeAgents.map(a => a.agentType).join(', ')}. ` +\n              `Using default behavior.`,\n          )\n        }\n      }\n\n      // Store the main thread agent type in bootstrap state so hooks can access it\n      setMainThreadAgentType(mainThreadAgentDefinition?.agentType)\n\n      // Log agent flag usage — only log agent name for built-in agents to avoid leaking custom agent names\n      if (mainThreadAgentDefinition) {\n        logEvent('tengu_agent_flag', {\n          agentType: isBuiltInAgent(mainThreadAgentDefinition)\n            ? (mainThreadAgentDefinition.agentType as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS)\n            : ('custom' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS),\n          ...(agentCli && {\n            source:\n              'cli' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          }),\n        })\n      }\n\n      // Persist agent setting to session transcript for resume view display and restoration\n      if (mainThreadAgentDefinition?.agentType) {\n        saveAgentSetting(mainThreadAgentDefinition.agentType)\n      }\n\n      // Apply the agent's system prompt for non-interactive sessions\n      // (interactive mode uses buildEffectiveSystemPrompt instead)\n      if (\n        isNonInteractiveSession &&\n        mainThreadAgentDefinition &&\n        !systemPrompt &&\n        !isBuiltInAgent(mainThreadAgentDefinition)\n      ) {\n        const agentSystemPrompt = mainThreadAgentDefinition.getSystemPrompt()\n        if (agentSystemPrompt) {\n          systemPrompt = agentSystemPrompt\n        }\n      }\n\n      // initialPrompt goes first so its slash command (if any) is processed;\n      // user-provided text becomes trailing context.\n      // Only concatenate when inputPrompt is a string. When it's an\n      // AsyncIterable (SDK stream-json mode), template interpolation would\n      // call .toString() producing \"[object Object]\". The AsyncIterable case\n      // is handled in print.ts via structuredIO.prependUserMessage().\n      if (mainThreadAgentDefinition?.initialPrompt) {\n        if (typeof inputPrompt === 'string') {\n          inputPrompt = inputPrompt\n            ? `${mainThreadAgentDefinition.initialPrompt}\\n\\n${inputPrompt}`\n            : mainThreadAgentDefinition.initialPrompt\n        } else if (!inputPrompt) {\n          inputPrompt = mainThreadAgentDefinition.initialPrompt\n        }\n      }\n\n      // Compute effective model early so hooks can run in parallel with MCP\n      // If user didn't specify a model but agent has one, use the agent's model\n      let effectiveModel = userSpecifiedModel\n      if (\n        !effectiveModel &&\n        mainThreadAgentDefinition?.model &&\n        mainThreadAgentDefinition.model !== 'inherit'\n      ) {\n        effectiveModel = parseUserSpecifiedModel(\n          mainThreadAgentDefinition.model,\n        )\n      }\n\n      setMainLoopModelOverride(effectiveModel)\n\n      // Compute resolved model for hooks (use user-specified model at launch)\n      setInitialMainLoopModel(getUserSpecifiedModelSetting() || null)\n      const initialMainLoopModel = getInitialMainLoopModel()\n      const resolvedInitialModel = parseUserSpecifiedModel(\n        initialMainLoopModel ?? getDefaultMainLoopModel(),\n      )\n\n      let advisorModel: string | undefined\n      if (isAdvisorEnabled()) {\n        const advisorOption = canUserConfigureAdvisor()\n          ? (options as { advisor?: string }).advisor\n          : undefined\n        if (advisorOption) {\n          logForDebugging(`[AdvisorTool] --advisor ${advisorOption}`)\n          if (!modelSupportsAdvisor(resolvedInitialModel)) {\n            process.stderr.write(\n              chalk.red(\n                `Error: The model \"${resolvedInitialModel}\" does not support the advisor tool.\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n          const normalizedAdvisorModel = normalizeModelStringForAPI(\n            parseUserSpecifiedModel(advisorOption),\n          )\n          if (!isValidAdvisorModel(normalizedAdvisorModel)) {\n            process.stderr.write(\n              chalk.red(\n                `Error: The model \"${advisorOption}\" cannot be used as an advisor.\\n`,\n              ),\n            )\n            process.exit(1)\n          }\n        }\n        advisorModel = canUserConfigureAdvisor()\n          ? (advisorOption ?? getInitialAdvisorSetting())\n          : advisorOption\n        if (advisorModel) {\n          logForDebugging(`[AdvisorTool] Advisor model: ${advisorModel}`)\n        }\n      }\n\n      // For tmux teammates with --agent-type, append the custom agent's prompt\n      if (\n        isAgentSwarmsEnabled() &&\n        storedTeammateOpts?.agentId &&\n        storedTeammateOpts?.agentName &&\n        storedTeammateOpts?.teamName &&\n        storedTeammateOpts?.agentType\n      ) {\n        // Look up the custom agent definition\n        const customAgent = agentDefinitions.activeAgents.find(\n          a => a.agentType === storedTeammateOpts.agentType,\n        )\n        if (customAgent) {\n          // Get the prompt - need to handle both built-in and custom agents\n          let customPrompt: string | undefined\n          if (customAgent.source === 'built-in') {\n            // Built-in agents have getSystemPrompt that takes toolUseContext\n            // We can't access full toolUseContext here, so skip for now\n            logForDebugging(\n              `[teammate] Built-in agent ${storedTeammateOpts.agentType} - skipping custom prompt (not supported)`,\n            )\n          } else {\n            // Custom agents have getSystemPrompt that takes no args\n            customPrompt = customAgent.getSystemPrompt()\n          }\n\n          // Log agent memory loaded event for tmux teammates\n          if (customAgent.memory) {\n            logEvent('tengu_agent_memory_loaded', {\n              ...(\"external\" === 'ant' && {\n                agent_type:\n                  customAgent.agentType as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n              }),\n              scope:\n                customAgent.memory as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n              source:\n                'teammate' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n            })\n          }\n\n          if (customPrompt) {\n            const customInstructions = `\\n# Custom Agent Instructions\\n${customPrompt}`\n            appendSystemPrompt = appendSystemPrompt\n              ? `${appendSystemPrompt}\\n\\n${customInstructions}`\n              : customInstructions\n          }\n        } else {\n          logForDebugging(\n            `[teammate] Custom agent ${storedTeammateOpts.agentType} not found in available agents`,\n          )\n        }\n      }\n\n      maybeActivateBrief(options)\n      // defaultView: 'chat' is a persisted opt-in — check entitlement and set\n      // userMsgOptIn so the tool + prompt section activate. Interactive-only:\n      // defaultView is a display preference; SDK sessions have no display, and\n      // the assistant installer writes defaultView:'chat' to settings.local.json\n      // which would otherwise leak into --print sessions in the same directory.\n      // Runs right after maybeActivateBrief() so all startup opt-in paths fire\n      // BEFORE any isBriefEnabled() read below (proactive prompt's\n      // briefVisibility). A persisted 'chat' after a GB kill-switch falls\n      // through (entitlement fails).\n      if (\n        (feature('KAIROS') || feature('KAIROS_BRIEF')) &&\n        !getIsNonInteractiveSession() &&\n        !getUserMsgOptIn() &&\n        getInitialSettings().defaultView === 'chat'\n      ) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const { isBriefEntitled } =\n          require('./tools/BriefTool/BriefTool.js') as typeof import('./tools/BriefTool/BriefTool.js')\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        if (isBriefEntitled()) {\n          setUserMsgOptIn(true)\n        }\n      }\n      // Coordinator mode has its own system prompt and filters out Sleep, so\n      // the generic proactive prompt would tell it to call a tool it can't\n      // access and conflict with delegation instructions.\n      if (\n        (feature('PROACTIVE') || feature('KAIROS')) &&\n        ((options as { proactive?: boolean }).proactive ||\n          isEnvTruthy(process.env.CLAUDE_CODE_PROACTIVE)) &&\n        !coordinatorModeModule?.isCoordinatorMode()\n      ) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const briefVisibility =\n          feature('KAIROS') || feature('KAIROS_BRIEF')\n            ? (\n                require('./tools/BriefTool/BriefTool.js') as typeof import('./tools/BriefTool/BriefTool.js')\n              ).isBriefEnabled()\n              ? 'Call SendUserMessage at checkpoints to mark where things stand.'\n              : 'The user will see any text you output.'\n            : 'The user will see any text you output.'\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        const proactivePrompt = `\\n# Proactive Mode\\n\\nYou are in proactive mode. Take initiative — explore, act, and make progress without waiting for instructions.\\n\\nStart by briefly greeting the user.\\n\\nYou will receive periodic <tick> prompts. These are check-ins. Do whatever seems most useful, or call Sleep if there's nothing to do. ${briefVisibility}`\n        appendSystemPrompt = appendSystemPrompt\n          ? `${appendSystemPrompt}\\n\\n${proactivePrompt}`\n          : proactivePrompt\n      }\n\n      if (feature('KAIROS') && kairosEnabled && assistantModule) {\n        const assistantAddendum =\n          assistantModule.getAssistantSystemPromptAddendum()\n        appendSystemPrompt = appendSystemPrompt\n          ? `${appendSystemPrompt}\\n\\n${assistantAddendum}`\n          : assistantAddendum\n      }\n\n      // Ink root is only needed for interactive sessions — patchConsole in the\n      // Ink constructor would swallow console output in headless mode.\n      let root!: Root\n      let getFpsMetrics!: () => FpsMetrics | undefined\n      let stats!: StatsStore\n\n      // Show setup screens after commands are loaded\n      if (!isNonInteractiveSession) {\n        const ctx = getRenderContext(false)\n        getFpsMetrics = ctx.getFpsMetrics\n        stats = ctx.stats\n        // Install asciicast recorder before Ink mounts (ant-only, opt-in via CLAUDE_CODE_TERMINAL_RECORDING=1)\n        if (\"external\" === 'ant') {\n          installAsciicastRecorder()\n        }\n\n        const { createRoot } = await import('./ink.js')\n        root = await createRoot(ctx.renderOptions)\n\n        // Log startup time now, before any blocking dialog renders. Logging\n        // from REPL's first render (the old location) included however long\n        // the user sat on trust/OAuth/onboarding/resume-picker — p99 was ~70s\n        // dominated by dialog-wait time, not code-path startup.\n        logEvent('tengu_timer', {\n          event:\n            'startup' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          durationMs: Math.round(process.uptime() * 1000),\n        })\n\n        logForDebugging('[STARTUP] Running showSetupScreens()...')\n        const setupScreensStart = Date.now()\n        const onboardingShown = await showSetupScreens(\n          root,\n          permissionMode,\n          allowDangerouslySkipPermissions,\n          commands,\n          enableClaudeInChrome,\n          devChannels,\n        )\n        logForDebugging(\n          `[STARTUP] showSetupScreens() completed in ${Date.now() - setupScreensStart}ms`,\n        )\n\n        // Now that trust is established and GrowthBook has auth headers,\n        // resolve the --remote-control / --rc entitlement gate.\n        if (feature('BRIDGE_MODE') && remoteControlOption !== undefined) {\n          const { getBridgeDisabledReason } = await import(\n            './bridge/bridgeEnabled.js'\n          )\n          const disabledReason = await getBridgeDisabledReason()\n          remoteControl = disabledReason === null\n          if (disabledReason) {\n            process.stderr.write(\n              chalk.yellow(`${disabledReason}\\n--rc flag ignored.\\n`),\n            )\n          }\n        }\n\n        // Check for pending agent memory snapshot updates (only for --agent mode, ant-only)\n        if (\n          feature('AGENT_MEMORY_SNAPSHOT') &&\n          mainThreadAgentDefinition &&\n          isCustomAgent(mainThreadAgentDefinition) &&\n          mainThreadAgentDefinition.memory &&\n          mainThreadAgentDefinition.pendingSnapshotUpdate\n        ) {\n          const agentDef = mainThreadAgentDefinition\n          const choice = await launchSnapshotUpdateDialog(root, {\n            agentType: agentDef.agentType,\n            scope: agentDef.memory!,\n            snapshotTimestamp:\n              agentDef.pendingSnapshotUpdate!.snapshotTimestamp,\n          })\n          if (choice === 'merge') {\n            const { buildMergePrompt } = await import(\n              './components/agents/SnapshotUpdateDialog.js'\n            )\n            const mergePrompt = buildMergePrompt(\n              agentDef.agentType,\n              agentDef.memory!,\n            )\n            inputPrompt = inputPrompt\n              ? `${mergePrompt}\\n\\n${inputPrompt}`\n              : mergePrompt\n          }\n          agentDef.pendingSnapshotUpdate = undefined\n        }\n\n        // Skip executing /login if we just completed onboarding for it\n        if (onboardingShown && prompt?.trim().toLowerCase() === '/login') {\n          prompt = ''\n        }\n\n        if (onboardingShown) {\n          // Refresh auth-dependent services now that the user has logged in during onboarding.\n          // Keep in sync with the post-login logic in src/commands/login.tsx\n          void refreshRemoteManagedSettings()\n          void refreshPolicyLimits()\n          // Clear user data cache BEFORE GrowthBook refresh so it picks up fresh credentials\n          resetUserCache()\n          // Refresh GrowthBook after login to get updated feature flags (e.g., for claude.ai MCPs)\n          refreshGrowthBookAfterAuthChange()\n          // Clear any stale trusted device token then enroll for Remote Control.\n          // Both self-gate on tengu_sessions_elevated_auth_enforcement internally\n          // — enrollTrustedDevice() via checkGate_CACHED_OR_BLOCKING (awaits\n          // the GrowthBook reinit above), clearTrustedDeviceToken() via the\n          // sync cached check (acceptable since clear is idempotent).\n          void import('./bridge/trustedDevice.js').then(m => {\n            m.clearTrustedDeviceToken()\n            return m.enrollTrustedDevice()\n          })\n        }\n\n        // Validate that the active token's org matches forceLoginOrgUUID (if set\n        // in managed settings). Runs after onboarding so managed settings and\n        // login state are fully loaded.\n        const orgValidation = await validateForceLoginOrg()\n        if (!orgValidation.valid) {\n          await exitWithError(root, orgValidation.message)\n        }\n      }\n\n      // If gracefulShutdown was initiated (e.g., user rejected trust dialog),\n      // process.exitCode will be set. Skip all subsequent operations that could\n      // trigger code execution before the process exits (e.g. we don't want apiKeyHelper\n      // to run if trust was not established).\n      if (process.exitCode !== undefined) {\n        logForDebugging(\n          'Graceful shutdown initiated, skipping further initialization',\n        )\n        return\n      }\n\n      // Initialize LSP manager AFTER trust is established (or in non-interactive mode\n      // where trust is implicit). This prevents plugin LSP servers from executing\n      // code in untrusted directories before user consent.\n      // Must be after inline plugins are set (if any) so --plugin-dir LSP servers are included.\n      initializeLspServerManager()\n\n      // Show settings validation errors after trust is established\n      // MCP config errors don't block settings from loading, so exclude them\n      if (!isNonInteractiveSession) {\n        const { errors } = getSettingsWithErrors()\n        const nonMcpErrors = errors.filter(e => !e.mcpErrorMetadata)\n        if (nonMcpErrors.length > 0) {\n          await launchInvalidSettingsDialog(root, {\n            settingsErrors: nonMcpErrors,\n            onExit: () => gracefulShutdownSync(1),\n          })\n        }\n      }\n\n      // Check quota status, fast mode, passes eligibility, and bootstrap data\n      // after trust is established. These make API calls which could trigger\n      // apiKeyHelper execution.\n      // --bare / SIMPLE: skip — these are cache-warms for the REPL's\n      // first-turn responsiveness (quota, passes, fastMode, bootstrap data). Fast\n      // mode doesn't apply to the Agent SDK anyway (see getFastModeUnavailableReason).\n      const bgRefreshThrottleMs = getFeatureValue_CACHED_MAY_BE_STALE(\n        'tengu_cicada_nap_ms',\n        0,\n      )\n      const lastPrefetched = getGlobalConfig().startupPrefetchedAt ?? 0\n      const skipStartupPrefetches =\n        isBareMode() ||\n        (bgRefreshThrottleMs > 0 &&\n          Date.now() - lastPrefetched < bgRefreshThrottleMs)\n\n      if (!skipStartupPrefetches) {\n        const lastPrefetchedInfo =\n          lastPrefetched > 0\n            ? ` last ran ${Math.round((Date.now() - lastPrefetched) / 1000)}s ago`\n            : ''\n        logForDebugging(\n          `Starting background startup prefetches${lastPrefetchedInfo}`,\n        )\n\n        checkQuotaStatus().catch(error => logError(error))\n\n        // Fetch bootstrap data from the server and update all cache values.\n        void fetchBootstrapData()\n\n        // TODO: Consolidate other prefetches into a single bootstrap request.\n        void prefetchPassesEligibility()\n        if (\n          !getFeatureValue_CACHED_MAY_BE_STALE('tengu_miraculo_the_bard', false)\n        ) {\n          void prefetchFastModeStatus()\n        } else {\n          // Kill switch skips the network call, not org-policy enforcement.\n          // Resolve from cache so orgStatus doesn't stay 'pending' (which\n          // getFastModeUnavailableReason treats as permissive).\n          resolveFastModeStatusFromCache()\n        }\n        if (bgRefreshThrottleMs > 0) {\n          saveGlobalConfig(current => ({\n            ...current,\n            startupPrefetchedAt: Date.now(),\n          }))\n        }\n      } else {\n        logForDebugging(\n          `Skipping startup prefetches, last ran ${Math.round((Date.now() - lastPrefetched) / 1000)}s ago`,\n        )\n        // Resolve fast mode org status from cache (no network)\n        resolveFastModeStatusFromCache()\n      }\n\n      if (!isNonInteractiveSession) {\n        void refreshExampleCommands() // Pre-fetch example commands (runs git log, no API call)\n      }\n\n      // Resolve MCP configs (started early, overlaps with setup/trust dialog work)\n      const { servers: existingMcpConfigs } = await mcpConfigPromise\n      logForDebugging(\n        `[STARTUP] MCP configs resolved in ${mcpConfigResolvedMs}ms (awaited at +${Date.now() - mcpConfigStart}ms)`,\n      )\n      // CLI flag (--mcp-config) should override file-based configs, matching settings precedence\n      const allMcpConfigs = { ...existingMcpConfigs, ...dynamicMcpConfig }\n\n      // Separate SDK configs from regular MCP configs\n      const sdkMcpConfigs: Record<string, McpSdkServerConfig> = {}\n      const regularMcpConfigs: Record<string, ScopedMcpServerConfig> = {}\n\n      for (const [name, config] of Object.entries(allMcpConfigs)) {\n        const typedConfig = config as ScopedMcpServerConfig | McpSdkServerConfig\n        if (typedConfig.type === 'sdk') {\n          sdkMcpConfigs[name] = typedConfig as McpSdkServerConfig\n        } else {\n          regularMcpConfigs[name] = typedConfig as ScopedMcpServerConfig\n        }\n      }\n\n      profileCheckpoint('action_mcp_configs_loaded')\n\n      // Prefetch MCP resources after trust dialog (this is where execution happens).\n      // Interactive mode only: print mode defers connects until headlessStore exists\n      // and pushes per-server (below), so ToolSearch's pending-client handling works\n      // and one slow server doesn't block the batch.\n      const localMcpPromise = isNonInteractiveSession\n        ? Promise.resolve({ clients: [], tools: [], commands: [] })\n        : prefetchAllMcpResources(regularMcpConfigs)\n      const claudeaiMcpPromise = isNonInteractiveSession\n        ? Promise.resolve({ clients: [], tools: [], commands: [] })\n        : claudeaiConfigPromise.then(configs =>\n            Object.keys(configs).length > 0\n              ? prefetchAllMcpResources(configs)\n              : { clients: [], tools: [], commands: [] },\n          )\n      // Merge with dedup by name: each prefetchAllMcpResources call independently\n      // adds helper tools (ListMcpResourcesTool, ReadMcpResourceTool) via\n      // local dedup flags, so merging two calls can yield duplicates. print.ts\n      // already uniqBy's the final tool pool, but dedup here keeps appState clean.\n      const mcpPromise = Promise.all([\n        localMcpPromise,\n        claudeaiMcpPromise,\n      ]).then(([local, claudeai]) => ({\n        clients: [...local.clients, ...claudeai.clients],\n        tools: uniqBy([...local.tools, ...claudeai.tools], 'name'),\n        commands: uniqBy([...local.commands, ...claudeai.commands], 'name'),\n      }))\n\n      // Start hooks early so they run in parallel with MCP connections.\n      // Skip for initOnly/init/maintenance (handled separately), non-interactive\n      // (handled via setupTrigger), and resume/continue (conversationRecovery.ts\n      // fires 'resume' instead — without this guard, hooks fire TWICE on /resume\n      // and the second systemMessage clobbers the first. gh-30825)\n      const hooksPromise =\n        initOnly ||\n        init ||\n        maintenance ||\n        isNonInteractiveSession ||\n        options.continue ||\n        options.resume\n          ? null\n          : processSessionStartHooks('startup', {\n              agentType: mainThreadAgentDefinition?.agentType,\n              model: resolvedInitialModel,\n            })\n\n      // MCP never blocks REPL render OR turn 1 TTFT. useManageMCPConnections\n      // populates appState.mcp async as servers connect (connectToServer is\n      // memoized — the prefetch calls above and the hook converge on the same\n      // connections). getToolUseContext reads store.getState() fresh via\n      // computeTools(), so turn 1 sees whatever's connected by query time.\n      // Slow servers populate for turn 2+. Matches interactive-no-prompt\n      // behavior. Print mode: per-server push into headlessStore (below).\n      const hookMessages: Awaited<NonNullable<typeof hooksPromise>> = []\n      // Suppress transient unhandledRejection — the prefetch warms the\n      // memoized connectToServer cache but nobody awaits it in interactive.\n      mcpPromise.catch(() => {})\n\n      const mcpClients: Awaited<typeof mcpPromise>['clients'] = []\n      const mcpTools: Awaited<typeof mcpPromise>['tools'] = []\n      const mcpCommands: Awaited<typeof mcpPromise>['commands'] = []\n\n      let thinkingEnabled = shouldEnableThinkingByDefault()\n      let thinkingConfig: ThinkingConfig =\n        thinkingEnabled !== false ? { type: 'adaptive' } : { type: 'disabled' }\n\n      if (options.thinking === 'adaptive' || options.thinking === 'enabled') {\n        thinkingEnabled = true\n        thinkingConfig = { type: 'adaptive' }\n      } else if (options.thinking === 'disabled') {\n        thinkingEnabled = false\n        thinkingConfig = { type: 'disabled' }\n      } else {\n        const maxThinkingTokens = process.env.MAX_THINKING_TOKENS\n          ? parseInt(process.env.MAX_THINKING_TOKENS, 10)\n          : options.maxThinkingTokens\n        if (maxThinkingTokens !== undefined) {\n          if (maxThinkingTokens > 0) {\n            thinkingEnabled = true\n            thinkingConfig = {\n              type: 'enabled',\n              budgetTokens: maxThinkingTokens,\n            }\n          } else if (maxThinkingTokens === 0) {\n            thinkingEnabled = false\n            thinkingConfig = { type: 'disabled' }\n          }\n        }\n      }\n\n      logForDiagnosticsNoPII('info', 'started', {\n        version: MACRO.VERSION,\n        is_native_binary: isInBundledMode(),\n      })\n\n      registerCleanup(async () => {\n        logForDiagnosticsNoPII('info', 'exited')\n      })\n\n      void logTenguInit({\n        hasInitialPrompt: Boolean(prompt),\n        hasStdin: Boolean(inputPrompt),\n        verbose,\n        debug,\n        debugToStderr,\n        print: print ?? false,\n        outputFormat: outputFormat ?? 'text',\n        inputFormat: inputFormat ?? 'text',\n        numAllowedTools: allowedTools.length,\n        numDisallowedTools: disallowedTools.length,\n        mcpClientCount: Object.keys(allMcpConfigs).length,\n        worktreeEnabled,\n        skipWebFetchPreflight: getInitialSettings().skipWebFetchPreflight,\n        githubActionInputs: process.env.GITHUB_ACTION_INPUTS,\n        dangerouslySkipPermissionsPassed: dangerouslySkipPermissions ?? false,\n        permissionMode,\n        modeIsBypass: permissionMode === 'bypassPermissions',\n        allowDangerouslySkipPermissionsPassed: allowDangerouslySkipPermissions,\n        systemPromptFlag: systemPrompt\n          ? options.systemPromptFile\n            ? 'file'\n            : 'flag'\n          : undefined,\n        appendSystemPromptFlag: appendSystemPrompt\n          ? options.appendSystemPromptFile\n            ? 'file'\n            : 'flag'\n          : undefined,\n        thinkingConfig,\n        assistantActivationPath:\n          feature('KAIROS') && kairosEnabled\n            ? assistantModule?.getAssistantActivationPath()\n            : undefined,\n      })\n\n      // Log context metrics once at initialization\n      void logContextMetrics(regularMcpConfigs, toolPermissionContext)\n\n      void logPermissionContextForAnts(null, 'initialization')\n\n      logManagedSettings()\n\n      // Register PID file for concurrent-session detection (~/.claude/sessions/)\n      // and fire multi-clauding telemetry. Lives here (not init.ts) so only the\n      // REPL path registers — not subcommands like `claude doctor`. Chained:\n      // count must run after register's write completes or it misses our own file.\n      void registerSession().then(registered => {\n        if (!registered) return\n        if (sessionNameArg) {\n          void updateSessionName(sessionNameArg)\n        }\n        void countConcurrentSessions().then(count => {\n          if (count >= 2) {\n            logEvent('tengu_concurrent_sessions', { num_sessions: count })\n          }\n        })\n      })\n\n      // Initialize versioned plugins system (triggers V1→V2 migration if\n      // needed). Then run orphan GC, THEN warm the Grep/Glob exclusion cache.\n      // Sequencing matters: the warmup scans disk for .orphaned_at markers,\n      // so it must see the GC's Pass 1 (remove markers from reinstalled\n      // versions) and Pass 2 (stamp unmarked orphans) already applied. The\n      // warm also lands before autoupdate (fires on first submit in REPL)\n      // can orphan this session's active version underneath us.\n      // --bare / SIMPLE: skip plugin version sync + orphan cleanup. These\n      // are install/upgrade bookkeeping that scripted calls don't need —\n      // the next interactive session will reconcile. The await here was\n      // blocking -p on a marketplace round-trip.\n      if (isBareMode()) {\n        // skip — no-op\n      } else if (isNonInteractiveSession) {\n        // In headless mode, await to ensure plugin sync completes before CLI exits\n        await initializeVersionedPlugins()\n        profileCheckpoint('action_after_plugins_init')\n        void cleanupOrphanedPluginVersionsInBackground().then(() =>\n          getGlobExclusionsForPluginCache(),\n        )\n      } else {\n        // In interactive mode, fire-and-forget — this is purely bookkeeping\n        // that doesn't affect runtime behavior of the current session\n        void initializeVersionedPlugins().then(async () => {\n          profileCheckpoint('action_after_plugins_init')\n          await cleanupOrphanedPluginVersionsInBackground()\n          void getGlobExclusionsForPluginCache()\n        })\n      }\n\n      const setupTrigger =\n        initOnly || init ? 'init' : maintenance ? 'maintenance' : null\n      if (initOnly) {\n        applyConfigEnvironmentVariables()\n        await processSetupHooks('init', { forceSyncExecution: true })\n        await processSessionStartHooks('startup', { forceSyncExecution: true })\n        gracefulShutdownSync(0)\n        return\n      }\n\n      // --print mode\n      if (isNonInteractiveSession) {\n        if (outputFormat === 'stream-json' || outputFormat === 'json') {\n          setHasFormattedOutput(true)\n        }\n\n        // Apply full environment variables in print mode since trust dialog is bypassed\n        // This includes potentially dangerous environment variables from untrusted sources\n        // but print mode is considered trusted (as documented in help text)\n        applyConfigEnvironmentVariables()\n\n        // Initialize telemetry after env vars are applied so OTEL endpoint env vars and\n        // otelHeadersHelper (which requires trust to execute) are available.\n        initializeTelemetryAfterTrust()\n\n        // Kick SessionStart hooks now so the subprocess spawn overlaps with\n        // MCP connect + plugin init + print.ts import below. loadInitialMessages\n        // joins this at print.ts:4397. Guarded same as loadInitialMessages —\n        // continue/resume/teleport paths don't fire startup hooks (or fire them\n        // conditionally inside the resume branch, where this promise is\n        // undefined and the ?? fallback runs). Also skip when setupTrigger is\n        // set — those paths run setup hooks first (print.ts:544), and session\n        // start hooks must wait until setup completes.\n        const sessionStartHooksPromise =\n          options.continue || options.resume || teleport || setupTrigger\n            ? undefined\n            : processSessionStartHooks('startup')\n        // Suppress transient unhandledRejection if this rejects before\n        // loadInitialMessages awaits it. Downstream await still observes the\n        // rejection — this just prevents the spurious global handler fire.\n        sessionStartHooksPromise?.catch(() => {})\n\n        profileCheckpoint('before_validateForceLoginOrg')\n        // Validate org restriction for non-interactive sessions\n        const orgValidation = await validateForceLoginOrg()\n        if (!orgValidation.valid) {\n          process.stderr.write(orgValidation.message + '\\n')\n          process.exit(1)\n        }\n\n        // Headless mode supports all prompt commands and some local commands\n        // If disableSlashCommands is true, return empty array\n        const commandsHeadless = disableSlashCommands\n          ? []\n          : commands.filter(\n              command =>\n                (command.type === 'prompt' && !command.disableNonInteractive) ||\n                (command.type === 'local' && command.supportsNonInteractive),\n            )\n\n        const defaultState = getDefaultAppState()\n        const headlessInitialState: AppState = {\n          ...defaultState,\n          mcp: {\n            ...defaultState.mcp,\n            clients: mcpClients,\n            commands: mcpCommands,\n            tools: mcpTools,\n          },\n          toolPermissionContext,\n          effortValue:\n            parseEffortValue(options.effort) ?? getInitialEffortSetting(),\n          ...(isFastModeEnabled() && {\n            fastMode: getInitialFastModeSetting(effectiveModel ?? null),\n          }),\n          ...(isAdvisorEnabled() && advisorModel && { advisorModel }),\n          // kairosEnabled gates the async fire-and-forget path in\n          // executeForkedSlashCommand (processSlashCommand.tsx:132) and\n          // AgentTool's shouldRunAsync. The REPL initialState sets this at\n          // ~3459; headless was defaulting to false, so the daemon child's\n          // scheduled tasks and Agent-tool calls ran synchronously — N\n          // overdue cron tasks on spawn = N serial subagent turns blocking\n          // user input. Computed at :1620, well before this branch.\n          ...(feature('KAIROS') ? { kairosEnabled } : {}),\n        }\n\n        // Init app state\n        const headlessStore = createStore(\n          headlessInitialState,\n          onChangeAppState,\n        )\n\n        // Check if bypassPermissions should be disabled based on Statsig gate\n        // This runs in parallel to the code below, to avoid blocking the main loop.\n        if (\n          toolPermissionContext.mode === 'bypassPermissions' ||\n          allowDangerouslySkipPermissions\n        ) {\n          void checkAndDisableBypassPermissions(toolPermissionContext)\n        }\n\n        // Async check of auto mode gate — corrects state and disables auto if needed.\n        // Gated on TRANSCRIPT_CLASSIFIER (not USER_TYPE) so GrowthBook kill switch runs for external builds too.\n        if (feature('TRANSCRIPT_CLASSIFIER')) {\n          void verifyAutoModeGateAccess(\n            toolPermissionContext,\n            headlessStore.getState().fastMode,\n          ).then(({ updateContext }) => {\n            headlessStore.setState(prev => {\n              const nextCtx = updateContext(prev.toolPermissionContext)\n              if (nextCtx === prev.toolPermissionContext) return prev\n              return { ...prev, toolPermissionContext: nextCtx }\n            })\n          })\n        }\n\n        // Set global state for session persistence\n        if (options.sessionPersistence === false) {\n          setSessionPersistenceDisabled(true)\n        }\n\n        // Store SDK betas in global state for context window calculation\n        // Only store allowed betas (filters by allowlist and subscriber status)\n        setSdkBetas(filterAllowedSdkBetas(betas))\n\n        // Print-mode MCP: per-server incremental push into headlessStore.\n        // Mirrors useManageMCPConnections — push pending first (so ToolSearch's\n        // pending-check at ToolSearchTool.ts:334 sees them), then replace with\n        // connected/failed as each server settles.\n        const connectMcpBatch = (\n          configs: Record<string, ScopedMcpServerConfig>,\n          label: string,\n        ): Promise<void> => {\n          if (Object.keys(configs).length === 0) return Promise.resolve()\n          headlessStore.setState(prev => ({\n            ...prev,\n            mcp: {\n              ...prev.mcp,\n              clients: [\n                ...prev.mcp.clients,\n                ...Object.entries(configs).map(([name, config]) => ({\n                  name,\n                  type: 'pending' as const,\n                  config,\n                })),\n              ],\n            },\n          }))\n          return getMcpToolsCommandsAndResources(\n            ({ client, tools, commands }) => {\n              headlessStore.setState(prev => ({\n                ...prev,\n                mcp: {\n                  ...prev.mcp,\n                  clients: prev.mcp.clients.some(c => c.name === client.name)\n                    ? prev.mcp.clients.map(c =>\n                        c.name === client.name ? client : c,\n                      )\n                    : [...prev.mcp.clients, client],\n                  tools: uniqBy([...prev.mcp.tools, ...tools], 'name'),\n                  commands: uniqBy([...prev.mcp.commands, ...commands], 'name'),\n                },\n              }))\n            },\n            configs,\n          ).catch(err =>\n            logForDebugging(`[MCP] ${label} connect error: ${err}`),\n          )\n        }\n        // Await all MCP configs — print mode is often single-turn, so\n        // \"late-connecting servers visible next turn\" doesn't help. SDK init\n        // message and turn-1 tool list both need configured MCP tools present.\n        // Zero-server case is free via the early return in connectMcpBatch.\n        // Connectors parallelize inside getMcpToolsCommandsAndResources\n        // (processBatched with Promise.all). claude.ai is awaited too — its\n        // fetch was kicked off early (line ~2558) so only residual time blocks\n        // here. --bare skips claude.ai entirely for perf-sensitive scripts.\n        profileCheckpoint('before_connectMcp')\n        await connectMcpBatch(regularMcpConfigs, 'regular')\n        profileCheckpoint('after_connectMcp')\n        // Dedup: suppress plugin MCP servers that duplicate a claude.ai\n        // connector (connector wins), then connect claude.ai servers.\n        // Bounded wait — #23725 made this blocking so single-turn -p sees\n        // connectors, but with 40+ slow connectors tengu_startup_perf p99\n        // climbed to 76s. If fetch+connect doesn't finish in time, proceed;\n        // the promise keeps running and updates headlessStore in the\n        // background so turn 2+ still sees connectors.\n        const CLAUDE_AI_MCP_TIMEOUT_MS = 5_000\n        const claudeaiConnect = claudeaiConfigPromise.then(claudeaiConfigs => {\n          if (Object.keys(claudeaiConfigs).length > 0) {\n            const claudeaiSigs = new Set<string>()\n            for (const config of Object.values(claudeaiConfigs)) {\n              const sig = getMcpServerSignature(config)\n              if (sig) claudeaiSigs.add(sig)\n            }\n            const suppressed = new Set<string>()\n            for (const [name, config] of Object.entries(regularMcpConfigs)) {\n              if (!name.startsWith('plugin:')) continue\n              const sig = getMcpServerSignature(config)\n              if (sig && claudeaiSigs.has(sig)) suppressed.add(name)\n            }\n            if (suppressed.size > 0) {\n              logForDebugging(\n                `[MCP] Lazy dedup: suppressing ${suppressed.size} plugin server(s) that duplicate claude.ai connectors: ${[...suppressed].join(', ')}`,\n              )\n              // Disconnect before filtering from state. Only connected\n              // servers need cleanup — clearServerCache on a never-connected\n              // server triggers a real connect just to kill it (memoize\n              // cache-miss path, see useManageMCPConnections.ts:870).\n              for (const c of headlessStore.getState().mcp.clients) {\n                if (!suppressed.has(c.name) || c.type !== 'connected') continue\n                c.client.onclose = undefined\n                void clearServerCache(c.name, c.config).catch(() => {})\n              }\n              headlessStore.setState(prev => {\n                let { clients, tools, commands, resources } = prev.mcp\n                clients = clients.filter(c => !suppressed.has(c.name))\n                tools = tools.filter(\n                  t => !t.mcpInfo || !suppressed.has(t.mcpInfo.serverName),\n                )\n                for (const name of suppressed) {\n                  commands = excludeCommandsByServer(commands, name)\n                  resources = excludeResourcesByServer(resources, name)\n                }\n                return {\n                  ...prev,\n                  mcp: { ...prev.mcp, clients, tools, commands, resources },\n                }\n              })\n            }\n          }\n          // Suppress claude.ai connectors that duplicate an enabled\n          // manual server (URL-signature match). Plugin dedup above only\n          // handles `plugin:*` keys; this catches manual `.mcp.json` entries.\n          // plugin:* must be excluded here — step 1 already suppressed\n          // those (claude.ai wins); leaving them in suppresses the\n          // connector too, and neither survives (gh-39974).\n          const nonPluginConfigs = pickBy(\n            regularMcpConfigs,\n            (_, n) => !n.startsWith('plugin:'),\n          )\n          const { servers: dedupedClaudeAi } = dedupClaudeAiMcpServers(\n            claudeaiConfigs,\n            nonPluginConfigs,\n          )\n          return connectMcpBatch(dedupedClaudeAi, 'claudeai')\n        })\n        let claudeaiTimer: ReturnType<typeof setTimeout> | undefined\n        const claudeaiTimedOut = await Promise.race([\n          claudeaiConnect.then(() => false),\n          new Promise<boolean>(resolve => {\n            claudeaiTimer = setTimeout(\n              r => r(true),\n              CLAUDE_AI_MCP_TIMEOUT_MS,\n              resolve,\n            )\n          }),\n        ])\n        if (claudeaiTimer) clearTimeout(claudeaiTimer)\n        if (claudeaiTimedOut) {\n          logForDebugging(\n            `[MCP] claude.ai connectors not ready after ${CLAUDE_AI_MCP_TIMEOUT_MS}ms — proceeding; background connection continues`,\n          )\n        }\n        profileCheckpoint('after_connectMcp_claudeai')\n\n        // In headless mode, start deferred prefetches immediately (no user typing delay)\n        // --bare / SIMPLE: startDeferredPrefetches early-returns internally.\n        // backgroundHousekeeping (initExtractMemories, pruneShellSnapshots,\n        // cleanupOldMessageFiles) and sdkHeapDumpMonitor are all bookkeeping\n        // that scripted calls don't need — the next interactive session reconciles.\n        if (!isBareMode()) {\n          startDeferredPrefetches()\n          void import('./utils/backgroundHousekeeping.js').then(m =>\n            m.startBackgroundHousekeeping(),\n          )\n          if (\"external\" === 'ant') {\n            void import('./utils/sdkHeapDumpMonitor.js').then(m =>\n              m.startSdkMemoryMonitor(),\n            )\n          }\n        }\n\n        logSessionTelemetry()\n        profileCheckpoint('before_print_import')\n        const { runHeadless } = await import('src/cli/print.js')\n        profileCheckpoint('after_print_import')\n        void runHeadless(\n          inputPrompt,\n          () => headlessStore.getState(),\n          headlessStore.setState,\n          commandsHeadless,\n          tools,\n          sdkMcpConfigs,\n          agentDefinitions.activeAgents,\n          {\n            continue: options.continue,\n            resume: options.resume,\n            verbose: verbose,\n            outputFormat: outputFormat,\n            jsonSchema,\n            permissionPromptToolName: options.permissionPromptTool,\n            allowedTools,\n            thinkingConfig,\n            maxTurns: options.maxTurns,\n            maxBudgetUsd: options.maxBudgetUsd,\n            taskBudget: options.taskBudget\n              ? { total: options.taskBudget }\n              : undefined,\n            systemPrompt,\n            appendSystemPrompt,\n            userSpecifiedModel: effectiveModel,\n            fallbackModel: userSpecifiedFallbackModel,\n            teleport,\n            sdkUrl,\n            replayUserMessages: effectiveReplayUserMessages,\n            includePartialMessages: effectiveIncludePartialMessages,\n            forkSession: options.forkSession || false,\n            resumeSessionAt: options.resumeSessionAt || undefined,\n            rewindFiles: options.rewindFiles,\n            enableAuthStatus: options.enableAuthStatus,\n            agent: agentCli,\n            workload: options.workload,\n            setupTrigger: setupTrigger ?? undefined,\n            sessionStartHooksPromise,\n          },\n        )\n        return\n      }\n\n      // Log model config at startup\n      logEvent('tengu_startup_manual_model_config', {\n        cli_flag:\n          options.model as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        env_var: process.env\n          .ANTHROPIC_MODEL as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        settings_file: (getInitialSettings() || {})\n          .model as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        subscriptionType:\n          getSubscriptionType() as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n        agent:\n          agentSetting as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      })\n\n      // Get deprecation warning for the initial model (resolvedInitialModel computed earlier for hooks parallelization)\n      const deprecationWarning =\n        getModelDeprecationWarning(resolvedInitialModel)\n\n      // Build initial notification queue\n      const initialNotifications: Array<{\n        key: string\n        text: string\n        color?: 'warning'\n        priority: 'high'\n      }> = []\n      if (permissionModeNotification) {\n        initialNotifications.push({\n          key: 'permission-mode-notification',\n          text: permissionModeNotification,\n          priority: 'high',\n        })\n      }\n      if (deprecationWarning) {\n        initialNotifications.push({\n          key: 'model-deprecation-warning',\n          text: deprecationWarning,\n          color: 'warning',\n          priority: 'high',\n        })\n      }\n      if (overlyBroadBashPermissions.length > 0) {\n        const displayList = uniq(\n          overlyBroadBashPermissions.map(p => p.ruleDisplay),\n        )\n        const displays = displayList.join(', ')\n        const sources = uniq(\n          overlyBroadBashPermissions.map(p => p.sourceDisplay),\n        ).join(', ')\n        const n = displayList.length\n        initialNotifications.push({\n          key: 'overly-broad-bash-notification',\n          text: `${displays} allow ${plural(n, 'rule')} from ${sources} ${plural(n, 'was', 'were')} ignored \\u2014 not available for Ants, please use auto-mode instead`,\n          color: 'warning',\n          priority: 'high',\n        })\n      }\n\n      const effectiveToolPermissionContext = {\n        ...toolPermissionContext,\n        mode:\n          isAgentSwarmsEnabled() && getTeammateUtils().isPlanModeRequired()\n            ? ('plan' as const)\n            : toolPermissionContext.mode,\n      }\n      // All startup opt-in paths (--tools, --brief, defaultView) have fired\n      // above; initialIsBriefOnly just reads the resulting state.\n      const initialIsBriefOnly =\n        feature('KAIROS') || feature('KAIROS_BRIEF') ? getUserMsgOptIn() : false\n      const fullRemoteControl =\n        remoteControl || getRemoteControlAtStartup() || kairosEnabled\n      let ccrMirrorEnabled = false\n      if (feature('CCR_MIRROR') && !fullRemoteControl) {\n        /* eslint-disable @typescript-eslint/no-require-imports */\n        const { isCcrMirrorEnabled } =\n          require('./bridge/bridgeEnabled.js') as typeof import('./bridge/bridgeEnabled.js')\n        /* eslint-enable @typescript-eslint/no-require-imports */\n        ccrMirrorEnabled = isCcrMirrorEnabled()\n      }\n\n      const initialState: AppState = {\n        settings: getInitialSettings(),\n        tasks: {},\n        agentNameRegistry: new Map(),\n        verbose: verbose ?? getGlobalConfig().verbose ?? false,\n        mainLoopModel: initialMainLoopModel,\n        mainLoopModelForSession: null,\n        isBriefOnly: initialIsBriefOnly,\n        expandedView: getGlobalConfig().showSpinnerTree\n          ? 'teammates'\n          : getGlobalConfig().showExpandedTodos\n            ? 'tasks'\n            : 'none',\n        showTeammateMessagePreview: isAgentSwarmsEnabled() ? false : undefined,\n        selectedIPAgentIndex: -1,\n        coordinatorTaskIndex: -1,\n        viewSelectionMode: 'none',\n        footerSelection: null,\n        toolPermissionContext: effectiveToolPermissionContext,\n        agent: mainThreadAgentDefinition?.agentType,\n        agentDefinitions,\n        mcp: {\n          clients: [],\n          tools: [],\n          commands: [],\n          resources: {},\n          pluginReconnectKey: 0,\n        },\n        plugins: {\n          enabled: [],\n          disabled: [],\n          commands: [],\n          errors: [],\n          installationStatus: {\n            marketplaces: [],\n            plugins: [],\n          },\n          needsRefresh: false,\n        },\n        statusLineText: undefined,\n        kairosEnabled,\n        remoteSessionUrl: undefined,\n        remoteConnectionStatus: 'connecting',\n        remoteBackgroundTaskCount: 0,\n        replBridgeEnabled: fullRemoteControl || ccrMirrorEnabled,\n        replBridgeExplicit: remoteControl,\n        replBridgeOutboundOnly: ccrMirrorEnabled,\n        replBridgeConnected: false,\n        replBridgeSessionActive: false,\n        replBridgeReconnecting: false,\n        replBridgeConnectUrl: undefined,\n        replBridgeSessionUrl: undefined,\n        replBridgeEnvironmentId: undefined,\n        replBridgeSessionId: undefined,\n        replBridgeError: undefined,\n        replBridgeInitialName: remoteControlName,\n        showRemoteCallout: false,\n        notifications: {\n          current: null,\n          queue: initialNotifications,\n        },\n        elicitation: {\n          queue: [],\n        },\n        todos: {},\n        remoteAgentTaskSuggestions: [],\n        fileHistory: {\n          snapshots: [],\n          trackedFiles: new Set(),\n          snapshotSequence: 0,\n        },\n        attribution: createEmptyAttributionState(),\n        thinkingEnabled,\n        promptSuggestionEnabled: shouldEnablePromptSuggestion(),\n        sessionHooks: new Map(),\n        inbox: {\n          messages: [],\n        },\n        promptSuggestion: {\n          text: null,\n          promptId: null,\n          shownAt: 0,\n          acceptedAt: 0,\n          generationRequestId: null,\n        },\n        speculation: IDLE_SPECULATION_STATE,\n        speculationSessionTimeSavedMs: 0,\n        skillImprovement: {\n          suggestion: null,\n        },\n        workerSandboxPermissions: {\n          queue: [],\n          selectedIndex: 0,\n        },\n        pendingWorkerRequest: null,\n        pendingSandboxRequest: null,\n        authVersion: 0,\n        initialMessage: inputPrompt\n          ? { message: createUserMessage({ content: String(inputPrompt) }) }\n          : null,\n        effortValue:\n          parseEffortValue(options.effort) ?? getInitialEffortSetting(),\n        activeOverlays: new Set<string>(),\n        fastMode: getInitialFastModeSetting(resolvedInitialModel),\n        ...(isAdvisorEnabled() && advisorModel && { advisorModel }),\n        // Compute teamContext synchronously to avoid useEffect setState during render.\n        // KAIROS: assistantTeamContext takes precedence — set earlier in the\n        // KAIROS block so Agent(name: \"foo\") can spawn in-process teammates\n        // without TeamCreate. computeInitialTeamContext() is for tmux-spawned\n        // teammates reading their own identity, not the assistant-mode leader.\n        teamContext: feature('KAIROS')\n          ? (assistantTeamContext ?? computeInitialTeamContext?.())\n          : computeInitialTeamContext?.(),\n      }\n\n      // Add CLI initial prompt to history\n      if (inputPrompt) {\n        addToHistory(String(inputPrompt))\n      }\n\n      const initialTools = mcpTools\n\n      // Increment numStartups synchronously — first-render readers like\n      // shouldShowEffortCallout (via useState initializer) need the updated\n      // value before setImmediate fires. Defer only telemetry.\n      saveGlobalConfig(current => ({\n        ...current,\n        numStartups: (current.numStartups ?? 0) + 1,\n      }))\n      setImmediate(() => {\n        void logStartupTelemetry()\n        logSessionTelemetry()\n      })\n\n      // Set up per-turn session environment data uploader (ant-only build).\n      // Default-enabled for all ant users when working in an Anthropic-owned\n      // repo. Captures git/filesystem state (NOT transcripts) at each turn so\n      // environments can be recreated at any user message index. Gating:\n      //   - Build-time: this import is stubbed in external builds.\n      //   - Runtime: uploader checks github.com/anthropics/* remote + gcloud auth.\n      //   - Safety: CLAUDE_CODE_DISABLE_SESSION_DATA_UPLOAD=1 bypasses (tests set this).\n      // Import is dynamic + async to avoid adding startup latency.\n      const sessionUploaderPromise =\n        \"external\" === 'ant'\n          ? import('./utils/sessionDataUploader.js')\n          : null\n\n      // Defer session uploader resolution to the onTurnComplete callback to avoid\n      // adding a new top-level await in main.tsx (performance-critical path).\n      // The per-turn auth logic in sessionDataUploader.ts handles unauthenticated\n      // state gracefully (re-checks each turn, so auth recovery mid-session works).\n      const uploaderReady = sessionUploaderPromise\n        ? sessionUploaderPromise\n            .then(mod => mod.createSessionTurnUploader())\n            .catch(() => null)\n        : null\n\n      const sessionConfig = {\n        debug: debug || debugToStderr,\n        commands: [...commands, ...mcpCommands],\n        initialTools,\n        mcpClients,\n        autoConnectIdeFlag: ide,\n        mainThreadAgentDefinition,\n        disableSlashCommands,\n        dynamicMcpConfig,\n        strictMcpConfig,\n        systemPrompt,\n        appendSystemPrompt,\n        taskListId,\n        thinkingConfig,\n        ...(uploaderReady && {\n          onTurnComplete: (messages: MessageType[]) => {\n            void uploaderReady.then(uploader => uploader?.(messages))\n          },\n        }),\n      }\n\n      // Shared context for processResumedConversation calls\n      const resumeContext = {\n        modeApi: coordinatorModeModule,\n        mainThreadAgentDefinition,\n        agentDefinitions,\n        currentCwd,\n        cliAgents,\n        initialState,\n      }\n\n      if (options.continue) {\n        // Continue the most recent conversation directly\n        let resumeSucceeded = false\n        try {\n          const resumeStart = performance.now()\n\n          // Clear stale caches before resuming to ensure fresh file/skill discovery\n          const { clearSessionCaches } = await import(\n            './commands/clear/caches.js'\n          )\n          clearSessionCaches()\n\n          const result = await loadConversationForResume(\n            undefined /* sessionId */,\n            undefined /* sourceFile */,\n          )\n          if (!result) {\n            logEvent('tengu_continue', {\n              success: false,\n            })\n            return await exitWithError(\n              root,\n              'No conversation found to continue',\n            )\n          }\n\n          const loaded = await processResumedConversation(\n            result,\n            {\n              forkSession: !!options.forkSession,\n              includeAttribution: true,\n              transcriptPath: result.fullPath,\n            },\n            resumeContext,\n          )\n\n          if (loaded.restoredAgentDef) {\n            mainThreadAgentDefinition = loaded.restoredAgentDef\n          }\n\n          maybeActivateProactive(options)\n          maybeActivateBrief(options)\n\n          logEvent('tengu_continue', {\n            success: true,\n            resume_duration_ms: Math.round(performance.now() - resumeStart),\n          })\n          resumeSucceeded = true\n\n          await launchRepl(\n            root,\n            { getFpsMetrics, stats, initialState: loaded.initialState },\n            {\n              ...sessionConfig,\n              mainThreadAgentDefinition:\n                loaded.restoredAgentDef ?? mainThreadAgentDefinition,\n              initialMessages: loaded.messages,\n              initialFileHistorySnapshots: loaded.fileHistorySnapshots,\n              initialContentReplacements: loaded.contentReplacements,\n              initialAgentName: loaded.agentName,\n              initialAgentColor: loaded.agentColor,\n            },\n            renderAndRun,\n          )\n        } catch (error) {\n          if (!resumeSucceeded) {\n            logEvent('tengu_continue', {\n              success: false,\n            })\n          }\n          logError(error)\n          process.exit(1)\n        }\n      } else if (feature('DIRECT_CONNECT') && _pendingConnect?.url) {\n        // `claude connect <url>` — full interactive TUI connected to a remote server\n        let directConnectConfig\n        try {\n          const session = await createDirectConnectSession({\n            serverUrl: _pendingConnect.url,\n            authToken: _pendingConnect.authToken,\n            cwd: getOriginalCwd(),\n            dangerouslySkipPermissions:\n              _pendingConnect.dangerouslySkipPermissions,\n          })\n          if (session.workDir) {\n            setOriginalCwd(session.workDir)\n            setCwdState(session.workDir)\n          }\n          setDirectConnectServerUrl(_pendingConnect.url)\n          directConnectConfig = session.config\n        } catch (err) {\n          return await exitWithError(\n            root,\n            err instanceof DirectConnectError ? err.message : String(err),\n            () => gracefulShutdown(1),\n          )\n        }\n\n        const connectInfoMessage = createSystemMessage(\n          `Connected to server at ${_pendingConnect.url}\\nSession: ${directConnectConfig.sessionId}`,\n          'info',\n        )\n\n        await launchRepl(\n          root,\n          { getFpsMetrics, stats, initialState },\n          {\n            debug: debug || debugToStderr,\n            commands,\n            initialTools: [],\n            initialMessages: [connectInfoMessage],\n            mcpClients: [],\n            autoConnectIdeFlag: ide,\n            mainThreadAgentDefinition,\n            disableSlashCommands,\n            directConnectConfig,\n            thinkingConfig,\n          },\n          renderAndRun,\n        )\n        return\n      } else if (feature('SSH_REMOTE') && _pendingSSH?.host) {\n        // `claude ssh <host> [dir]` — probe remote, deploy binary if needed,\n        // spawn ssh with unix-socket -R forward to a local auth proxy, hand\n        // the REPL an SSHSession. Tools run remotely, UI renders locally.\n        // `--local` skips probe/deploy/ssh and spawns the current binary\n        // directly with the same env — e2e test of the proxy/auth plumbing.\n        const { createSSHSession, createLocalSSHSession, SSHSessionError } =\n          await import('./ssh/createSSHSession.js')\n        let sshSession\n        try {\n          if (_pendingSSH.local) {\n            process.stderr.write('Starting local ssh-proxy test session...\\n')\n            sshSession = createLocalSSHSession({\n              cwd: _pendingSSH.cwd,\n              permissionMode: _pendingSSH.permissionMode,\n              dangerouslySkipPermissions:\n                _pendingSSH.dangerouslySkipPermissions,\n            })\n          } else {\n            process.stderr.write(`Connecting to ${_pendingSSH.host}…\\n`)\n            // In-place progress: \\r + EL0 (erase to end of line). Final \\n on\n            // success so the next message lands on a fresh line. No-op when\n            // stderr isn't a TTY (piped/redirected) — \\r would just emit noise.\n            const isTTY = process.stderr.isTTY\n            let hadProgress = false\n            sshSession = await createSSHSession(\n              {\n                host: _pendingSSH.host,\n                cwd: _pendingSSH.cwd,\n                localVersion: MACRO.VERSION,\n                permissionMode: _pendingSSH.permissionMode,\n                dangerouslySkipPermissions:\n                  _pendingSSH.dangerouslySkipPermissions,\n                extraCliArgs: _pendingSSH.extraCliArgs,\n              },\n              isTTY\n                ? {\n                    onProgress: msg => {\n                      hadProgress = true\n                      process.stderr.write(`\\r  ${msg}\\x1b[K`)\n                    },\n                  }\n                : {},\n            )\n            if (hadProgress) process.stderr.write('\\n')\n          }\n          setOriginalCwd(sshSession.remoteCwd)\n          setCwdState(sshSession.remoteCwd)\n          setDirectConnectServerUrl(\n            _pendingSSH.local ? 'local' : _pendingSSH.host,\n          )\n        } catch (err) {\n          return await exitWithError(\n            root,\n            err instanceof SSHSessionError ? err.message : String(err),\n            () => gracefulShutdown(1),\n          )\n        }\n\n        const sshInfoMessage = createSystemMessage(\n          _pendingSSH.local\n            ? `Local ssh-proxy test session\\ncwd: ${sshSession.remoteCwd}\\nAuth: unix socket → local proxy`\n            : `SSH session to ${_pendingSSH.host}\\nRemote cwd: ${sshSession.remoteCwd}\\nAuth: unix socket -R → local proxy`,\n          'info',\n        )\n\n        await launchRepl(\n          root,\n          { getFpsMetrics, stats, initialState },\n          {\n            debug: debug || debugToStderr,\n            commands,\n            initialTools: [],\n            initialMessages: [sshInfoMessage],\n            mcpClients: [],\n            autoConnectIdeFlag: ide,\n            mainThreadAgentDefinition,\n            disableSlashCommands,\n            sshSession,\n            thinkingConfig,\n          },\n          renderAndRun,\n        )\n        return\n      } else if (\n        feature('KAIROS') &&\n        _pendingAssistantChat &&\n        (_pendingAssistantChat.sessionId || _pendingAssistantChat.discover)\n      ) {\n        // `claude assistant [sessionId]` — REPL as a pure viewer client\n        // of a remote assistant session. The agentic loop runs remotely; this\n        // process streams live events and POSTs messages. History is lazy-\n        // loaded by useAssistantHistory on scroll-up (no blocking fetch here).\n        const { discoverAssistantSessions } = await import(\n          './assistant/sessionDiscovery.js'\n        )\n\n        let targetSessionId = _pendingAssistantChat.sessionId\n\n        // Discovery flow — list bridge environments, filter sessions\n        if (!targetSessionId) {\n          let sessions\n          try {\n            sessions = await discoverAssistantSessions()\n          } catch (e) {\n            return await exitWithError(\n              root,\n              `Failed to discover sessions: ${e instanceof Error ? e.message : e}`,\n              () => gracefulShutdown(1),\n            )\n          }\n          if (sessions.length === 0) {\n            let installedDir: string | null\n            try {\n              installedDir = await launchAssistantInstallWizard(root)\n            } catch (e) {\n              return await exitWithError(\n                root,\n                `Assistant installation failed: ${e instanceof Error ? e.message : e}`,\n                () => gracefulShutdown(1),\n              )\n            }\n            if (installedDir === null) {\n              await gracefulShutdown(0)\n              process.exit(0)\n            }\n            // The daemon needs a few seconds to spin up its worker and\n            // establish a bridge session before discovery will find it.\n            return await exitWithMessage(\n              root,\n              `Assistant installed in ${installedDir}. The daemon is starting up — run \\`claude assistant\\` again in a few seconds to connect.`,\n              { exitCode: 0, beforeExit: () => gracefulShutdown(0) },\n            )\n          }\n          if (sessions.length === 1) {\n            targetSessionId = sessions[0]!.id\n          } else {\n            const picked = await launchAssistantSessionChooser(root, {\n              sessions,\n            })\n            if (!picked) {\n              await gracefulShutdown(0)\n              process.exit(0)\n            }\n            targetSessionId = picked\n          }\n        }\n\n        // Auth — call prepareApiRequest() once for orgUUID, but use a\n        // getAccessToken closure for the token so reconnects get fresh tokens.\n        const { checkAndRefreshOAuthTokenIfNeeded, getClaudeAIOAuthTokens } =\n          await import('./utils/auth.js')\n        await checkAndRefreshOAuthTokenIfNeeded()\n        let apiCreds\n        try {\n          apiCreds = await prepareApiRequest()\n        } catch (e) {\n          return await exitWithError(\n            root,\n            `Error: ${e instanceof Error ? e.message : 'Failed to authenticate'}`,\n            () => gracefulShutdown(1),\n          )\n        }\n        const getAccessToken = (): string =>\n          getClaudeAIOAuthTokens()?.accessToken ?? apiCreds.accessToken\n\n        // Brief mode activation: setKairosActive(true) satisfies BOTH opt-in\n        // and entitlement for isBriefEnabled() (BriefTool.ts:124-132).\n        setKairosActive(true)\n        setUserMsgOptIn(true)\n        setIsRemoteMode(true)\n\n        const remoteSessionConfig = createRemoteSessionConfig(\n          targetSessionId,\n          getAccessToken,\n          apiCreds.orgUUID,\n          /* hasInitialPrompt */ false,\n          /* viewerOnly */ true,\n        )\n\n        const infoMessage = createSystemMessage(\n          `Attached to assistant session ${targetSessionId.slice(0, 8)}…`,\n          'info',\n        )\n\n        const assistantInitialState: AppState = {\n          ...initialState,\n          isBriefOnly: true,\n          kairosEnabled: false,\n          replBridgeEnabled: false,\n        }\n\n        const remoteCommands = filterCommandsForRemoteMode(commands)\n        await launchRepl(\n          root,\n          { getFpsMetrics, stats, initialState: assistantInitialState },\n          {\n            debug: debug || debugToStderr,\n            commands: remoteCommands,\n            initialTools: [],\n            initialMessages: [infoMessage],\n            mcpClients: [],\n            autoConnectIdeFlag: ide,\n            mainThreadAgentDefinition,\n            disableSlashCommands,\n            remoteSessionConfig,\n            thinkingConfig,\n          },\n          renderAndRun,\n        )\n        return\n      } else if (\n        options.resume ||\n        options.fromPr ||\n        teleport ||\n        remote !== null\n      ) {\n        // Handle resume flow - from file (ant-only), session ID, or interactive selector\n\n        // Clear stale caches before resuming to ensure fresh file/skill discovery\n        const { clearSessionCaches } = await import(\n          './commands/clear/caches.js'\n        )\n        clearSessionCaches()\n\n        let messages: MessageType[] | null = null\n        let processedResume: ProcessedResume | undefined = undefined\n\n        let maybeSessionId = validateUuid(options.resume)\n        let searchTerm: string | undefined = undefined\n        // Store full LogOption when found by custom title (for cross-worktree resume)\n        let matchedLog: LogOption | null = null\n        // PR filter for --from-pr flag\n        let filterByPr: boolean | number | string | undefined = undefined\n\n        // Handle --from-pr flag\n        if (options.fromPr) {\n          if (options.fromPr === true) {\n            // Show all sessions with linked PRs\n            filterByPr = true\n          } else if (typeof options.fromPr === 'string') {\n            // Could be a PR number or URL\n            filterByPr = options.fromPr\n          }\n        }\n\n        // If resume value is not a UUID, try exact match by custom title first\n        if (\n          options.resume &&\n          typeof options.resume === 'string' &&\n          !maybeSessionId\n        ) {\n          const trimmedValue = options.resume.trim()\n          if (trimmedValue) {\n            const matches = await searchSessionsByCustomTitle(trimmedValue, {\n              exact: true,\n            })\n\n            if (matches.length === 1) {\n              // Exact match found - store full LogOption for cross-worktree resume\n              matchedLog = matches[0]!\n              maybeSessionId = getSessionIdFromLog(matchedLog) ?? null\n            } else {\n              // No match or multiple matches - use as search term for picker\n              searchTerm = trimmedValue\n            }\n          }\n        }\n\n        // --remote and --teleport both create/resume Claude Code Web (CCR) sessions.\n        // Remote Control (--rc) is a separate feature gated in initReplBridge.ts.\n        if (remote !== null || teleport) {\n          await waitForPolicyLimitsToLoad()\n          if (!isPolicyAllowed('allow_remote_sessions')) {\n            return await exitWithError(\n              root,\n              \"Error: Remote sessions are disabled by your organization's policy.\",\n              () => gracefulShutdown(1),\n            )\n          }\n        }\n\n        if (remote !== null) {\n          // Create remote session (optionally with initial prompt)\n          const hasInitialPrompt = remote.length > 0\n\n          // Check if TUI mode is enabled - description is only optional in TUI mode\n          const isRemoteTuiEnabled = getFeatureValue_CACHED_MAY_BE_STALE(\n            'tengu_remote_backend',\n            false,\n          )\n          if (!isRemoteTuiEnabled && !hasInitialPrompt) {\n            return await exitWithError(\n              root,\n              'Error: --remote requires a description.\\nUsage: claude --remote \"your task description\"',\n              () => gracefulShutdown(1),\n            )\n          }\n\n          logEvent('tengu_remote_create_session', {\n            has_initial_prompt: String(\n              hasInitialPrompt,\n            ) as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n\n          // Pass current branch so CCR clones the repo at the right revision\n          const currentBranch = await getBranch()\n          const createdSession = await teleportToRemoteWithErrorHandling(\n            root,\n            hasInitialPrompt ? remote : null,\n            new AbortController().signal,\n            currentBranch || undefined,\n          )\n          if (!createdSession) {\n            logEvent('tengu_remote_create_session_error', {\n              error:\n                'unable_to_create_session' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n            })\n            return await exitWithError(\n              root,\n              'Error: Unable to create remote session',\n              () => gracefulShutdown(1),\n            )\n          }\n          logEvent('tengu_remote_create_session_success', {\n            session_id:\n              createdSession.id as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n          })\n\n          // Check if new remote TUI mode is enabled via feature gate\n          if (!isRemoteTuiEnabled) {\n            // Original behavior: print session info and exit\n            process.stdout.write(\n              `Created remote session: ${createdSession.title}\\n`,\n            )\n            process.stdout.write(\n              `View: ${getRemoteSessionUrl(createdSession.id)}?m=0\\n`,\n            )\n            process.stdout.write(\n              `Resume with: claude --teleport ${createdSession.id}\\n`,\n            )\n            await gracefulShutdown(0)\n            process.exit(0)\n          }\n\n          // New behavior: start local TUI with CCR engine\n          // Mark that we're in remote mode for command visibility\n          setIsRemoteMode(true)\n          switchSession(asSessionId(createdSession.id))\n\n          // Get OAuth credentials for remote session\n          let apiCreds: { accessToken: string; orgUUID: string }\n          try {\n            apiCreds = await prepareApiRequest()\n          } catch (error) {\n            logError(toError(error))\n            return await exitWithError(\n              root,\n              `Error: ${errorMessage(error) || 'Failed to authenticate'}`,\n              () => gracefulShutdown(1),\n            )\n          }\n\n          // Create remote session config for the REPL\n          const { getClaudeAIOAuthTokens: getTokensForRemote } = await import(\n            './utils/auth.js'\n          )\n          const getAccessTokenForRemote = (): string =>\n            getTokensForRemote()?.accessToken ?? apiCreds.accessToken\n          const remoteSessionConfig = createRemoteSessionConfig(\n            createdSession.id,\n            getAccessTokenForRemote,\n            apiCreds.orgUUID,\n            hasInitialPrompt,\n          )\n\n          // Add remote session info as initial system message\n          const remoteSessionUrl = `${getRemoteSessionUrl(createdSession.id)}?m=0`\n          const remoteInfoMessage = createSystemMessage(\n            `/remote-control is active. Code in CLI or at ${remoteSessionUrl}`,\n            'info',\n          )\n\n          // Create initial user message from the prompt if provided (CCR echoes it back but we ignore that)\n          const initialUserMessage = hasInitialPrompt\n            ? createUserMessage({ content: remote })\n            : null\n\n          // Set remote session URL in app state for footer indicator\n          const remoteInitialState = {\n            ...initialState,\n            remoteSessionUrl,\n          }\n\n          // Pre-filter commands to only include remote-safe ones.\n          // CCR's init response may further refine the list (via handleRemoteInit in REPL).\n          const remoteCommands = filterCommandsForRemoteMode(commands)\n          await launchRepl(\n            root,\n            { getFpsMetrics, stats, initialState: remoteInitialState },\n            {\n              debug: debug || debugToStderr,\n              commands: remoteCommands,\n              initialTools: [],\n              initialMessages: initialUserMessage\n                ? [remoteInfoMessage, initialUserMessage]\n                : [remoteInfoMessage],\n              mcpClients: [],\n              autoConnectIdeFlag: ide,\n              mainThreadAgentDefinition,\n              disableSlashCommands,\n              remoteSessionConfig,\n              thinkingConfig,\n            },\n            renderAndRun,\n          )\n          return\n        } else if (teleport) {\n          if (teleport === true || teleport === '') {\n            // Interactive mode: show task selector and handle resume\n            logEvent('tengu_teleport_interactive_mode', {})\n            logForDebugging(\n              'selectAndResumeTeleportTask: Starting teleport flow...',\n            )\n            const teleportResult = await launchTeleportResumeWrapper(root)\n            if (!teleportResult) {\n              // User cancelled or error occurred\n              await gracefulShutdown(0)\n              process.exit(0)\n            }\n            const { branchError } = await checkOutTeleportedSessionBranch(\n              teleportResult.branch,\n            )\n            messages = processMessagesForTeleportResume(\n              teleportResult.log,\n              branchError,\n            )\n          } else if (typeof teleport === 'string') {\n            logEvent('tengu_teleport_resume_session', {\n              mode: 'direct' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n            })\n            try {\n              // First, fetch session and validate repository before checking git state\n              const sessionData = await fetchSession(teleport)\n              const repoValidation =\n                await validateSessionRepository(sessionData)\n\n              // Handle repo mismatch or not in repo cases\n              if (\n                repoValidation.status === 'mismatch' ||\n                repoValidation.status === 'not_in_repo'\n              ) {\n                const sessionRepo = repoValidation.sessionRepo\n                if (sessionRepo) {\n                  // Check for known paths\n                  const knownPaths = getKnownPathsForRepo(sessionRepo)\n                  const existingPaths = await filterExistingPaths(knownPaths)\n\n                  if (existingPaths.length > 0) {\n                    // Show directory switch dialog\n                    const selectedPath = await launchTeleportRepoMismatchDialog(\n                      root,\n                      {\n                        targetRepo: sessionRepo,\n                        initialPaths: existingPaths,\n                      },\n                    )\n\n                    if (selectedPath) {\n                      // Change to the selected directory\n                      process.chdir(selectedPath)\n                      setCwd(selectedPath)\n                      setOriginalCwd(selectedPath)\n                    } else {\n                      // User cancelled\n                      await gracefulShutdown(0)\n                    }\n                  } else {\n                    // No known paths - show original error\n                    throw new TeleportOperationError(\n                      `You must run claude --teleport ${teleport} from a checkout of ${sessionRepo}.`,\n                      chalk.red(\n                        `You must run claude --teleport ${teleport} from a checkout of ${chalk.bold(sessionRepo)}.\\n`,\n                      ),\n                    )\n                  }\n                }\n              } else if (repoValidation.status === 'error') {\n                throw new TeleportOperationError(\n                  repoValidation.errorMessage || 'Failed to validate session',\n                  chalk.red(\n                    `Error: ${repoValidation.errorMessage || 'Failed to validate session'}\\n`,\n                  ),\n                )\n              }\n\n              await validateGitState()\n\n              // Use progress UI for teleport\n              const { teleportWithProgress } = await import(\n                './components/TeleportProgress.js'\n              )\n              const result = await teleportWithProgress(root, teleport)\n              // Track teleported session for reliability logging\n              setTeleportedSessionInfo({ sessionId: teleport })\n              messages = result.messages\n            } catch (error) {\n              if (error instanceof TeleportOperationError) {\n                process.stderr.write(error.formattedMessage + '\\n')\n              } else {\n                logError(error)\n                process.stderr.write(\n                  chalk.red(`Error: ${errorMessage(error)}\\n`),\n                )\n              }\n              await gracefulShutdown(1)\n            }\n          }\n        }\n        if (\"external\" === 'ant') {\n          if (\n            options.resume &&\n            typeof options.resume === 'string' &&\n            !maybeSessionId\n          ) {\n            // Check for ccshare URL (e.g. https://go/ccshare/boris-20260311-211036)\n            const { parseCcshareId, loadCcshare } = await import(\n              './utils/ccshareResume.js'\n            )\n            const ccshareId = parseCcshareId(options.resume)\n            if (ccshareId) {\n              try {\n                const resumeStart = performance.now()\n                const logOption = await loadCcshare(ccshareId)\n                const result = await loadConversationForResume(\n                  logOption,\n                  undefined,\n                )\n                if (result) {\n                  processedResume = await processResumedConversation(\n                    result,\n                    {\n                      forkSession: true,\n                      transcriptPath: result.fullPath,\n                    },\n                    resumeContext,\n                  )\n                  if (processedResume.restoredAgentDef) {\n                    mainThreadAgentDefinition = processedResume.restoredAgentDef\n                  }\n                  logEvent('tengu_session_resumed', {\n                    entrypoint:\n                      'ccshare' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                    success: true,\n                    resume_duration_ms: Math.round(\n                      performance.now() - resumeStart,\n                    ),\n                  })\n                } else {\n                  logEvent('tengu_session_resumed', {\n                    entrypoint:\n                      'ccshare' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                    success: false,\n                  })\n                }\n              } catch (error) {\n                logEvent('tengu_session_resumed', {\n                  entrypoint:\n                    'ccshare' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                  success: false,\n                })\n                logError(error)\n                await exitWithError(\n                  root,\n                  `Unable to resume from ccshare: ${errorMessage(error)}`,\n                  () => gracefulShutdown(1),\n                )\n              }\n            } else {\n              const resolvedPath = resolve(options.resume)\n              try {\n                const resumeStart = performance.now()\n                let logOption\n                try {\n                  // Attempt to load as a transcript file; ENOENT falls through to session-ID handling\n                  logOption = await loadTranscriptFromFile(resolvedPath)\n                } catch (error) {\n                  if (!isENOENT(error)) throw error\n                  // ENOENT: not a file path — fall through to session-ID handling\n                }\n                if (logOption) {\n                  const result = await loadConversationForResume(\n                    logOption,\n                    undefined /* sourceFile */,\n                  )\n                  if (result) {\n                    processedResume = await processResumedConversation(\n                      result,\n                      {\n                        forkSession: !!options.forkSession,\n                        transcriptPath: result.fullPath,\n                      },\n                      resumeContext,\n                    )\n                    if (processedResume.restoredAgentDef) {\n                      mainThreadAgentDefinition =\n                        processedResume.restoredAgentDef\n                    }\n                    logEvent('tengu_session_resumed', {\n                      entrypoint:\n                        'file' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                      success: true,\n                      resume_duration_ms: Math.round(\n                        performance.now() - resumeStart,\n                      ),\n                    })\n                  } else {\n                    logEvent('tengu_session_resumed', {\n                      entrypoint:\n                        'file' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                      success: false,\n                    })\n                  }\n                }\n              } catch (error) {\n                logEvent('tengu_session_resumed', {\n                  entrypoint:\n                    'file' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                  success: false,\n                })\n                logError(error)\n                await exitWithError(\n                  root,\n                  `Unable to load transcript from file: ${options.resume}`,\n                  () => gracefulShutdown(1),\n                )\n              }\n            }\n          }\n        }\n\n        // If not loaded as a file, try as session ID\n        if (maybeSessionId) {\n          // Resume specific session by ID\n          const sessionId = maybeSessionId\n          try {\n            const resumeStart = performance.now()\n            // Use matchedLog if available (for cross-worktree resume by custom title)\n            // Otherwise fall back to sessionId string (for direct UUID resume)\n            const result = await loadConversationForResume(\n              matchedLog ?? sessionId,\n              undefined,\n            )\n\n            if (!result) {\n              logEvent('tengu_session_resumed', {\n                entrypoint:\n                  'cli_flag' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                success: false,\n              })\n              return await exitWithError(\n                root,\n                `No conversation found with session ID: ${sessionId}`,\n              )\n            }\n\n            const fullPath = matchedLog?.fullPath ?? result.fullPath\n            processedResume = await processResumedConversation(\n              result,\n              {\n                forkSession: !!options.forkSession,\n                sessionIdOverride: sessionId,\n                transcriptPath: fullPath,\n              },\n              resumeContext,\n            )\n\n            if (processedResume.restoredAgentDef) {\n              mainThreadAgentDefinition = processedResume.restoredAgentDef\n            }\n            logEvent('tengu_session_resumed', {\n              entrypoint:\n                'cli_flag' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n              success: true,\n              resume_duration_ms: Math.round(performance.now() - resumeStart),\n            })\n          } catch (error) {\n            logEvent('tengu_session_resumed', {\n              entrypoint:\n                'cli_flag' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n              success: false,\n            })\n            logError(error)\n            await exitWithError(root, `Failed to resume session ${sessionId}`)\n          }\n        }\n\n        // Await file downloads before rendering REPL (files must be available)\n        if (fileDownloadPromise) {\n          try {\n            const results = await fileDownloadPromise\n            const failedCount = count(results, r => !r.success)\n            if (failedCount > 0) {\n              process.stderr.write(\n                chalk.yellow(\n                  `Warning: ${failedCount}/${results.length} file(s) failed to download.\\n`,\n                ),\n              )\n            }\n          } catch (error) {\n            return await exitWithError(\n              root,\n              `Error downloading files: ${errorMessage(error)}`,\n            )\n          }\n        }\n\n        // If we have a processed resume or teleport messages, render the REPL\n        const resumeData =\n          processedResume ??\n          (Array.isArray(messages)\n            ? {\n                messages,\n                fileHistorySnapshots: undefined,\n                agentName: undefined,\n                agentColor: undefined as AgentColorName | undefined,\n                restoredAgentDef: mainThreadAgentDefinition,\n                initialState,\n                contentReplacements: undefined,\n              }\n            : undefined)\n        if (resumeData) {\n          maybeActivateProactive(options)\n          maybeActivateBrief(options)\n\n          await launchRepl(\n            root,\n            { getFpsMetrics, stats, initialState: resumeData.initialState },\n            {\n              ...sessionConfig,\n              mainThreadAgentDefinition:\n                resumeData.restoredAgentDef ?? mainThreadAgentDefinition,\n              initialMessages: resumeData.messages,\n              initialFileHistorySnapshots: resumeData.fileHistorySnapshots,\n              initialContentReplacements: resumeData.contentReplacements,\n              initialAgentName: resumeData.agentName,\n              initialAgentColor: resumeData.agentColor,\n            },\n            renderAndRun,\n          )\n        } else {\n          // Show interactive selector (includes same-repo worktrees)\n          // Note: ResumeConversation loads logs internally to ensure proper GC after selection\n          await launchResumeChooser(\n            root,\n            { getFpsMetrics, stats, initialState },\n            getWorktreePaths(getOriginalCwd()),\n            {\n              ...sessionConfig,\n              initialSearchQuery: searchTerm,\n              forkSession: options.forkSession,\n              filterByPr,\n            },\n          )\n        }\n      } else {\n        // Pass unresolved hooks promise to REPL so it can render immediately\n        // instead of blocking ~500ms waiting for SessionStart hooks to finish.\n        // REPL will inject hook messages when they resolve and await them before\n        // the first API call so the model always sees hook context.\n        const pendingHookMessages =\n          hooksPromise && hookMessages.length === 0 ? hooksPromise : undefined\n\n        profileCheckpoint('action_after_hooks')\n        maybeActivateProactive(options)\n        maybeActivateBrief(options)\n        // Persist the current mode for fresh sessions so future resumes know what mode was used\n        if (feature('COORDINATOR_MODE')) {\n          saveMode(\n            coordinatorModeModule?.isCoordinatorMode()\n              ? 'coordinator'\n              : 'normal',\n          )\n        }\n\n        // If launched via a deep link, show a provenance banner so the user\n        // knows the session originated externally. Linux xdg-open and\n        // browsers with \"always allow\" set dispatch the link with no OS-level\n        // confirmation, so this is the only signal the user gets that the\n        // prompt — and the working directory / CLAUDE.md it implies — came\n        // from an external source rather than something they typed.\n        let deepLinkBanner: ReturnType<typeof createSystemMessage> | null = null\n        if (feature('LODESTONE')) {\n          if (options.deepLinkOrigin) {\n            logEvent('tengu_deep_link_opened', {\n              has_prefill: Boolean(options.prefill),\n              has_repo: Boolean(options.deepLinkRepo),\n            })\n            deepLinkBanner = createSystemMessage(\n              buildDeepLinkBanner({\n                cwd: getCwd(),\n                prefillLength: options.prefill?.length,\n                repo: options.deepLinkRepo,\n                lastFetch:\n                  options.deepLinkLastFetch !== undefined\n                    ? new Date(options.deepLinkLastFetch)\n                    : undefined,\n              }),\n              'warning',\n            )\n          } else if (options.prefill) {\n            deepLinkBanner = createSystemMessage(\n              'Launched with a pre-filled prompt — review it before pressing Enter.',\n              'warning',\n            )\n          }\n        }\n        const initialMessages = deepLinkBanner\n          ? [deepLinkBanner, ...hookMessages]\n          : hookMessages.length > 0\n            ? hookMessages\n            : undefined\n\n        await launchRepl(\n          root,\n          { getFpsMetrics, stats, initialState },\n          {\n            ...sessionConfig,\n            initialMessages,\n            pendingHookMessages,\n          },\n          renderAndRun,\n        )\n      }\n    })\n    .version(\n      `${MACRO.VERSION} (Claude Code)`,\n      '-v, --version',\n      'Output the version number',\n    )\n\n  // Worktree flags\n  program.option(\n    '-w, --worktree [name]',\n    'Create a new git worktree for this session (optionally specify a name)',\n  )\n  program.option(\n    '--tmux',\n    'Create a tmux session for the worktree (requires --worktree). Uses iTerm2 native panes when available; use --tmux=classic for traditional tmux.',\n  )\n\n  if (canUserConfigureAdvisor()) {\n    program.addOption(\n      new Option(\n        '--advisor <model>',\n        'Enable the server-side advisor tool with the specified model (alias or full ID).',\n      ).hideHelp(),\n    )\n  }\n\n  if (\"external\" === 'ant') {\n    program.addOption(\n      new Option(\n        '--delegate-permissions',\n        '[ANT-ONLY] Alias for --permission-mode auto.',\n      ).implies({ permissionMode: 'auto' }),\n    )\n    program.addOption(\n      new Option(\n        '--dangerously-skip-permissions-with-classifiers',\n        '[ANT-ONLY] Deprecated alias for --permission-mode auto.',\n      )\n        .hideHelp()\n        .implies({ permissionMode: 'auto' }),\n    )\n    program.addOption(\n      new Option(\n        '--afk',\n        '[ANT-ONLY] Deprecated alias for --permission-mode auto.',\n      )\n        .hideHelp()\n        .implies({ permissionMode: 'auto' }),\n    )\n    program.addOption(\n      new Option(\n        '--tasks [id]',\n        '[ANT-ONLY] Tasks mode: watch for tasks and auto-process them. Optional id is used as both the task list ID and agent ID (defaults to \"tasklist\").',\n      )\n        .argParser(String)\n        .hideHelp(),\n    )\n    program.option(\n      '--agent-teams',\n      '[ANT-ONLY] Force Claude to use multi-agent mode for solving problems',\n      () => true,\n    )\n  }\n\n  if (feature('TRANSCRIPT_CLASSIFIER')) {\n    program.addOption(\n      new Option('--enable-auto-mode', 'Opt in to auto mode').hideHelp(),\n    )\n  }\n\n  if (feature('PROACTIVE') || feature('KAIROS')) {\n    program.addOption(\n      new Option('--proactive', 'Start in proactive autonomous mode'),\n    )\n  }\n\n  if (feature('UDS_INBOX')) {\n    program.addOption(\n      new Option(\n        '--messaging-socket-path <path>',\n        'Unix domain socket path for the UDS messaging server (defaults to a tmp path)',\n      ),\n    )\n  }\n\n  if (feature('KAIROS') || feature('KAIROS_BRIEF')) {\n    program.addOption(\n      new Option(\n        '--brief',\n        'Enable SendUserMessage tool for agent-to-user communication',\n      ),\n    )\n  }\n  if (feature('KAIROS')) {\n    program.addOption(\n      new Option(\n        '--assistant',\n        'Force assistant mode (Agent SDK daemon use)',\n      ).hideHelp(),\n    )\n  }\n  if (feature('KAIROS') || feature('KAIROS_CHANNELS')) {\n    program.addOption(\n      new Option(\n        '--channels <servers...>',\n        'MCP servers whose channel notifications (inbound push) should register this session. Space-separated server names.',\n      ).hideHelp(),\n    )\n    program.addOption(\n      new Option(\n        '--dangerously-load-development-channels <servers...>',\n        'Load channel servers not on the approved allowlist. For local channel development only. Shows a confirmation dialog at startup.',\n      ).hideHelp(),\n    )\n  }\n\n  // Teammate identity options (set by leader when spawning tmux teammates)\n  // These replace the CLAUDE_CODE_* environment variables\n  program.addOption(\n    new Option('--agent-id <id>', 'Teammate agent ID').hideHelp(),\n  )\n  program.addOption(\n    new Option('--agent-name <name>', 'Teammate display name').hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--team-name <name>',\n      'Team name for swarm coordination',\n    ).hideHelp(),\n  )\n  program.addOption(\n    new Option('--agent-color <color>', 'Teammate UI color').hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--plan-mode-required',\n      'Require plan mode before implementation',\n    ).hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--parent-session-id <id>',\n      'Parent session ID for analytics correlation',\n    ).hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--teammate-mode <mode>',\n      'How to spawn teammates: \"tmux\", \"in-process\", or \"auto\"',\n    )\n      .choices(['auto', 'tmux', 'in-process'])\n      .hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--agent-type <type>',\n      'Custom agent type for this teammate',\n    ).hideHelp(),\n  )\n\n  // Enable SDK URL for all builds but hide from help\n  program.addOption(\n    new Option(\n      '--sdk-url <url>',\n      'Use remote WebSocket endpoint for SDK I/O streaming (only with -p and stream-json format)',\n    ).hideHelp(),\n  )\n\n  // Enable teleport/remote flags for all builds but keep them undocumented until GA\n  program.addOption(\n    new Option(\n      '--teleport [session]',\n      'Resume a teleport session, optionally specify session ID',\n    ).hideHelp(),\n  )\n  program.addOption(\n    new Option(\n      '--remote [description]',\n      'Create a remote session with the given description',\n    ).hideHelp(),\n  )\n  if (feature('BRIDGE_MODE')) {\n    program.addOption(\n      new Option(\n        '--remote-control [name]',\n        'Start an interactive session with Remote Control enabled (optionally named)',\n      )\n        .argParser(value => value || true)\n        .hideHelp(),\n    )\n    program.addOption(\n      new Option('--rc [name]', 'Alias for --remote-control')\n        .argParser(value => value || true)\n        .hideHelp(),\n    )\n  }\n\n  if (feature('HARD_FAIL')) {\n    program.addOption(\n      new Option(\n        '--hard-fail',\n        'Crash on logError calls instead of silently logging',\n      ).hideHelp(),\n    )\n  }\n\n  profileCheckpoint('run_main_options_built')\n\n  // -p/--print mode: skip subcommand registration. The 52 subcommands\n  // (mcp, auth, plugin, skill, task, config, doctor, update, etc.) are\n  // never dispatched in print mode — commander routes the prompt to the\n  // default action. The subcommand registration path was measured at ~65ms\n  // on baseline — mostly the isBridgeEnabled() call (25ms settings Zod parse\n  // + 40ms sync keychain subprocess), both hidden by the try/catch that\n  // always returns false before enableConfigs(). cc:// URLs are rewritten to\n  // `open` at main() line ~851 BEFORE this runs, so argv check is safe here.\n  const isPrintMode =\n    process.argv.includes('-p') || process.argv.includes('--print')\n  const isCcUrl = process.argv.some(\n    a => a.startsWith('cc://') || a.startsWith('cc+unix://'),\n  )\n  if (isPrintMode && !isCcUrl) {\n    profileCheckpoint('run_before_parse')\n    await program.parseAsync(process.argv)\n    profileCheckpoint('run_after_parse')\n    return program\n  }\n\n  // claude mcp\n\n  const mcp = program\n    .command('mcp')\n    .description('Configure and manage MCP servers')\n    .configureHelp(createSortedHelpConfig())\n    .enablePositionalOptions()\n\n  mcp\n    .command('serve')\n    .description(`Start the Claude Code MCP server`)\n    .option('-d, --debug', 'Enable debug mode', () => true)\n    .option(\n      '--verbose',\n      'Override verbose mode setting from config',\n      () => true,\n    )\n    .action(\n      async ({ debug, verbose }: { debug?: boolean; verbose?: boolean }) => {\n        const { mcpServeHandler } = await import('./cli/handlers/mcp.js')\n        await mcpServeHandler({ debug, verbose })\n      },\n    )\n\n  // Register the mcp add subcommand (extracted for testability)\n  registerMcpAddCommand(mcp)\n\n  if (isXaaEnabled()) {\n    registerMcpXaaIdpCommand(mcp)\n  }\n\n  mcp\n    .command('remove <name>')\n    .description('Remove an MCP server')\n    .option(\n      '-s, --scope <scope>',\n      'Configuration scope (local, user, or project) - if not specified, removes from whichever scope it exists in',\n    )\n    .action(async (name: string, options: { scope?: string }) => {\n      const { mcpRemoveHandler } = await import('./cli/handlers/mcp.js')\n      await mcpRemoveHandler(name, options)\n    })\n\n  mcp\n    .command('list')\n    .description(\n      'List configured MCP servers. Note: The workspace trust dialog is skipped and stdio servers from .mcp.json are spawned for health checks. Only use this command in directories you trust.',\n    )\n    .action(async () => {\n      const { mcpListHandler } = await import('./cli/handlers/mcp.js')\n      await mcpListHandler()\n    })\n\n  mcp\n    .command('get <name>')\n    .description(\n      'Get details about an MCP server. Note: The workspace trust dialog is skipped and stdio servers from .mcp.json are spawned for health checks. Only use this command in directories you trust.',\n    )\n    .action(async (name: string) => {\n      const { mcpGetHandler } = await import('./cli/handlers/mcp.js')\n      await mcpGetHandler(name)\n    })\n\n  mcp\n    .command('add-json <name> <json>')\n    .description('Add an MCP server (stdio or SSE) with a JSON string')\n    .option(\n      '-s, --scope <scope>',\n      'Configuration scope (local, user, or project)',\n      'local',\n    )\n    .option(\n      '--client-secret',\n      'Prompt for OAuth client secret (or set MCP_CLIENT_SECRET env var)',\n    )\n    .action(\n      async (\n        name: string,\n        json: string,\n        options: { scope?: string; clientSecret?: true },\n      ) => {\n        const { mcpAddJsonHandler } = await import('./cli/handlers/mcp.js')\n        await mcpAddJsonHandler(name, json, options)\n      },\n    )\n\n  mcp\n    .command('add-from-claude-desktop')\n    .description('Import MCP servers from Claude Desktop (Mac and WSL only)')\n    .option(\n      '-s, --scope <scope>',\n      'Configuration scope (local, user, or project)',\n      'local',\n    )\n    .action(async (options: { scope?: string }) => {\n      const { mcpAddFromDesktopHandler } = await import('./cli/handlers/mcp.js')\n      await mcpAddFromDesktopHandler(options)\n    })\n\n  mcp\n    .command('reset-project-choices')\n    .description(\n      'Reset all approved and rejected project-scoped (.mcp.json) servers within this project',\n    )\n    .action(async () => {\n      const { mcpResetChoicesHandler } = await import('./cli/handlers/mcp.js')\n      await mcpResetChoicesHandler()\n    })\n\n  // claude server\n  if (feature('DIRECT_CONNECT')) {\n    program\n      .command('server')\n      .description('Start a Claude Code session server')\n      .option('--port <number>', 'HTTP port', '0')\n      .option('--host <string>', 'Bind address', '0.0.0.0')\n      .option('--auth-token <token>', 'Bearer token for auth')\n      .option('--unix <path>', 'Listen on a unix domain socket')\n      .option(\n        '--workspace <dir>',\n        'Default working directory for sessions that do not specify cwd',\n      )\n      .option(\n        '--idle-timeout <ms>',\n        'Idle timeout for detached sessions in ms (0 = never expire)',\n        '600000',\n      )\n      .option(\n        '--max-sessions <n>',\n        'Maximum concurrent sessions (0 = unlimited)',\n        '32',\n      )\n      .action(\n        async (opts: {\n          port: string\n          host: string\n          authToken?: string\n          unix?: string\n          workspace?: string\n          idleTimeout: string\n          maxSessions: string\n        }) => {\n          const { randomBytes } = await import('crypto')\n          const { startServer } = await import('./server/server.js')\n          const { SessionManager } = await import('./server/sessionManager.js')\n          const { DangerousBackend } = await import(\n            './server/backends/dangerousBackend.js'\n          )\n          const { printBanner } = await import('./server/serverBanner.js')\n          const { createServerLogger } = await import('./server/serverLog.js')\n          const { writeServerLock, removeServerLock, probeRunningServer } =\n            await import('./server/lockfile.js')\n\n          const existing = await probeRunningServer()\n          if (existing) {\n            process.stderr.write(\n              `A claude server is already running (pid ${existing.pid}) at ${existing.httpUrl}\\n`,\n            )\n            process.exit(1)\n          }\n\n          const authToken =\n            opts.authToken ??\n            `sk-ant-cc-${randomBytes(16).toString('base64url')}`\n\n          const config = {\n            port: parseInt(opts.port, 10),\n            host: opts.host,\n            authToken,\n            unix: opts.unix,\n            workspace: opts.workspace,\n            idleTimeoutMs: parseInt(opts.idleTimeout, 10),\n            maxSessions: parseInt(opts.maxSessions, 10),\n          }\n\n          const backend = new DangerousBackend()\n          const sessionManager = new SessionManager(backend, {\n            idleTimeoutMs: config.idleTimeoutMs,\n            maxSessions: config.maxSessions,\n          })\n          const logger = createServerLogger()\n\n          const server = startServer(config, sessionManager, logger)\n          const actualPort = server.port ?? config.port\n          printBanner(config, authToken, actualPort)\n\n          await writeServerLock({\n            pid: process.pid,\n            port: actualPort,\n            host: config.host,\n            httpUrl: config.unix\n              ? `unix:${config.unix}`\n              : `http://${config.host}:${actualPort}`,\n            startedAt: Date.now(),\n          })\n\n          let shuttingDown = false\n          const shutdown = async () => {\n            if (shuttingDown) return\n            shuttingDown = true\n            // Stop accepting new connections before tearing down sessions.\n            server.stop(true)\n            await sessionManager.destroyAll()\n            await removeServerLock()\n            process.exit(0)\n          }\n          process.once('SIGINT', () => void shutdown())\n          process.once('SIGTERM', () => void shutdown())\n        },\n      )\n  }\n\n  // `claude ssh <host> [dir]` — registered here only so --help shows it.\n  // The actual interactive flow is handled by early argv rewriting in main()\n  // (parallels the DIRECT_CONNECT/cc:// pattern above). If commander reaches\n  // this action it means the argv rewrite didn't fire (e.g. user ran\n  // `claude ssh` with no host) — just print usage.\n  if (feature('SSH_REMOTE')) {\n    program\n      .command('ssh <host> [dir]')\n      .description(\n        'Run Claude Code on a remote host over SSH. Deploys the binary and ' +\n          'tunnels API auth back through your local machine — no remote setup needed.',\n      )\n      .option(\n        '--permission-mode <mode>',\n        'Permission mode for the remote session',\n      )\n      .option(\n        '--dangerously-skip-permissions',\n        'Skip all permission prompts on the remote (dangerous)',\n      )\n      .option(\n        '--local',\n        'e2e test mode — spawn the child CLI locally (skip ssh/deploy). ' +\n          'Exercises the auth proxy and unix-socket plumbing without a remote host.',\n      )\n      .action(async () => {\n        // Argv rewriting in main() should have consumed `ssh <host>` before\n        // commander runs. Reaching here means host was missing or the\n        // rewrite predicate didn't match.\n        process.stderr.write(\n          'Usage: claude ssh <user@host | ssh-config-alias> [dir]\\n\\n' +\n            \"Runs Claude Code on a remote Linux host. You don't need to install\\n\" +\n            'anything on the remote or run `claude auth login` there — the binary is\\n' +\n            'deployed over SSH and API auth tunnels back through your local machine.\\n',\n        )\n        process.exit(1)\n      })\n  }\n\n  // claude connect — subcommand only handles -p (headless) mode.\n  // Interactive mode (without -p) is handled by early argv rewriting in main()\n  // which redirects to the main command with full TUI support.\n  if (feature('DIRECT_CONNECT')) {\n    program\n      .command('open <cc-url>')\n      .description(\n        'Connect to a Claude Code server (internal — use cc:// URLs)',\n      )\n      .option('-p, --print [prompt]', 'Print mode (headless)')\n      .option(\n        '--output-format <format>',\n        'Output format: text, json, stream-json',\n        'text',\n      )\n      .action(\n        async (\n          ccUrl: string,\n          opts: {\n            print?: string | boolean\n            outputFormat: string\n          },\n        ) => {\n          const { parseConnectUrl } = await import(\n            './server/parseConnectUrl.js'\n          )\n          const { serverUrl, authToken } = parseConnectUrl(ccUrl)\n\n          let connectConfig\n          try {\n            const session = await createDirectConnectSession({\n              serverUrl,\n              authToken,\n              cwd: getOriginalCwd(),\n              dangerouslySkipPermissions:\n                _pendingConnect?.dangerouslySkipPermissions,\n            })\n            if (session.workDir) {\n              setOriginalCwd(session.workDir)\n              setCwdState(session.workDir)\n            }\n            setDirectConnectServerUrl(serverUrl)\n            connectConfig = session.config\n          } catch (err) {\n            // biome-ignore lint/suspicious/noConsole: intentional error output\n            console.error(\n              err instanceof DirectConnectError ? err.message : String(err),\n            )\n            process.exit(1)\n          }\n\n          const { runConnectHeadless } = await import(\n            './server/connectHeadless.js'\n          )\n\n          const prompt = typeof opts.print === 'string' ? opts.print : ''\n          const interactive = opts.print === true\n          await runConnectHeadless(\n            connectConfig,\n            prompt,\n            opts.outputFormat,\n            interactive,\n          )\n        },\n      )\n  }\n\n  // claude auth\n\n  const auth = program\n    .command('auth')\n    .description('Manage authentication')\n    .configureHelp(createSortedHelpConfig())\n\n  auth\n    .command('login')\n    .description('Sign in to your Anthropic account')\n    .option('--email <email>', 'Pre-populate email address on the login page')\n    .option('--sso', 'Force SSO login flow')\n    .option(\n      '--console',\n      'Use Anthropic Console (API usage billing) instead of Claude subscription',\n    )\n    .option('--claudeai', 'Use Claude subscription (default)')\n    .action(\n      async ({\n        email,\n        sso,\n        console: useConsole,\n        claudeai,\n      }: {\n        email?: string\n        sso?: boolean\n        console?: boolean\n        claudeai?: boolean\n      }) => {\n        const { authLogin } = await import('./cli/handlers/auth.js')\n        await authLogin({ email, sso, console: useConsole, claudeai })\n      },\n    )\n\n  auth\n    .command('status')\n    .description('Show authentication status')\n    .option('--json', 'Output as JSON (default)')\n    .option('--text', 'Output as human-readable text')\n    .action(async (opts: { json?: boolean; text?: boolean }) => {\n      const { authStatus } = await import('./cli/handlers/auth.js')\n      await authStatus(opts)\n    })\n\n  auth\n    .command('logout')\n    .description('Log out from your Anthropic account')\n    .action(async () => {\n      const { authLogout } = await import('./cli/handlers/auth.js')\n      await authLogout()\n    })\n\n  /**\n   * Helper function to handle marketplace command errors consistently.\n   * Logs the error and exits the process with status 1.\n   * @param error The error that occurred\n   * @param action Description of the action that failed\n   */\n  // Hidden flag on all plugin/marketplace subcommands to target cowork_plugins.\n  const coworkOption = () =>\n    new Option('--cowork', 'Use cowork_plugins directory').hideHelp()\n\n  // Plugin validate command\n  const pluginCmd = program\n    .command('plugin')\n    .alias('plugins')\n    .description('Manage Claude Code plugins')\n    .configureHelp(createSortedHelpConfig())\n\n  pluginCmd\n    .command('validate <path>')\n    .description('Validate a plugin or marketplace manifest')\n    .addOption(coworkOption())\n    .action(async (manifestPath: string, options: { cowork?: boolean }) => {\n      const { pluginValidateHandler } = await import(\n        './cli/handlers/plugins.js'\n      )\n      await pluginValidateHandler(manifestPath, options)\n    })\n\n  // Plugin list command\n  pluginCmd\n    .command('list')\n    .description('List installed plugins')\n    .option('--json', 'Output as JSON')\n    .option(\n      '--available',\n      'Include available plugins from marketplaces (requires --json)',\n    )\n    .addOption(coworkOption())\n    .action(\n      async (options: {\n        json?: boolean\n        available?: boolean\n        cowork?: boolean\n      }) => {\n        const { pluginListHandler } = await import('./cli/handlers/plugins.js')\n        await pluginListHandler(options)\n      },\n    )\n\n  // Marketplace subcommands\n  const marketplaceCmd = pluginCmd\n    .command('marketplace')\n    .description('Manage Claude Code marketplaces')\n    .configureHelp(createSortedHelpConfig())\n\n  marketplaceCmd\n    .command('add <source>')\n    .description('Add a marketplace from a URL, path, or GitHub repo')\n    .addOption(coworkOption())\n    .option(\n      '--sparse <paths...>',\n      'Limit checkout to specific directories via git sparse-checkout (for monorepos). Example: --sparse .claude-plugin plugins',\n    )\n    .option(\n      '--scope <scope>',\n      'Where to declare the marketplace: user (default), project, or local',\n    )\n    .action(\n      async (\n        source: string,\n        options: { cowork?: boolean; sparse?: string[]; scope?: string },\n      ) => {\n        const { marketplaceAddHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await marketplaceAddHandler(source, options)\n      },\n    )\n\n  marketplaceCmd\n    .command('list')\n    .description('List all configured marketplaces')\n    .option('--json', 'Output as JSON')\n    .addOption(coworkOption())\n    .action(async (options: { json?: boolean; cowork?: boolean }) => {\n      const { marketplaceListHandler } = await import(\n        './cli/handlers/plugins.js'\n      )\n      await marketplaceListHandler(options)\n    })\n\n  marketplaceCmd\n    .command('remove <name>')\n    .alias('rm')\n    .description('Remove a configured marketplace')\n    .addOption(coworkOption())\n    .action(async (name: string, options: { cowork?: boolean }) => {\n      const { marketplaceRemoveHandler } = await import(\n        './cli/handlers/plugins.js'\n      )\n      await marketplaceRemoveHandler(name, options)\n    })\n\n  marketplaceCmd\n    .command('update [name]')\n    .description(\n      'Update marketplace(s) from their source - updates all if no name specified',\n    )\n    .addOption(coworkOption())\n    .action(async (name: string | undefined, options: { cowork?: boolean }) => {\n      const { marketplaceUpdateHandler } = await import(\n        './cli/handlers/plugins.js'\n      )\n      await marketplaceUpdateHandler(name, options)\n    })\n\n  // Plugin install command\n  pluginCmd\n    .command('install <plugin>')\n    .alias('i')\n    .description(\n      'Install a plugin from available marketplaces (use plugin@marketplace for specific marketplace)',\n    )\n    .option(\n      '-s, --scope <scope>',\n      'Installation scope: user, project, or local',\n      'user',\n    )\n    .addOption(coworkOption())\n    .action(\n      async (plugin: string, options: { scope?: string; cowork?: boolean }) => {\n        const { pluginInstallHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginInstallHandler(plugin, options)\n      },\n    )\n\n  // Plugin uninstall command\n  pluginCmd\n    .command('uninstall <plugin>')\n    .alias('remove')\n    .alias('rm')\n    .description('Uninstall an installed plugin')\n    .option(\n      '-s, --scope <scope>',\n      'Uninstall from scope: user, project, or local',\n      'user',\n    )\n    .option(\n      '--keep-data',\n      \"Preserve the plugin's persistent data directory (~/.claude/plugins/data/{id}/)\",\n    )\n    .addOption(coworkOption())\n    .action(\n      async (\n        plugin: string,\n        options: { scope?: string; cowork?: boolean; keepData?: boolean },\n      ) => {\n        const { pluginUninstallHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginUninstallHandler(plugin, options)\n      },\n    )\n\n  // Plugin enable command\n  pluginCmd\n    .command('enable <plugin>')\n    .description('Enable a disabled plugin')\n    .option(\n      '-s, --scope <scope>',\n      `Installation scope: ${VALID_INSTALLABLE_SCOPES.join(', ')} (default: auto-detect)`,\n    )\n    .addOption(coworkOption())\n    .action(\n      async (plugin: string, options: { scope?: string; cowork?: boolean }) => {\n        const { pluginEnableHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginEnableHandler(plugin, options)\n      },\n    )\n\n  // Plugin disable command\n  pluginCmd\n    .command('disable [plugin]')\n    .description('Disable an enabled plugin')\n    .option('-a, --all', 'Disable all enabled plugins')\n    .option(\n      '-s, --scope <scope>',\n      `Installation scope: ${VALID_INSTALLABLE_SCOPES.join(', ')} (default: auto-detect)`,\n    )\n    .addOption(coworkOption())\n    .action(\n      async (\n        plugin: string | undefined,\n        options: { scope?: string; cowork?: boolean; all?: boolean },\n      ) => {\n        const { pluginDisableHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginDisableHandler(plugin, options)\n      },\n    )\n\n  // Plugin update command\n  pluginCmd\n    .command('update <plugin>')\n    .description(\n      'Update a plugin to the latest version (restart required to apply)',\n    )\n    .option(\n      '-s, --scope <scope>',\n      `Installation scope: ${VALID_UPDATE_SCOPES.join(', ')} (default: user)`,\n    )\n    .addOption(coworkOption())\n    .action(\n      async (plugin: string, options: { scope?: string; cowork?: boolean }) => {\n        const { pluginUpdateHandler } = await import(\n          './cli/handlers/plugins.js'\n        )\n        await pluginUpdateHandler(plugin, options)\n      },\n    )\n  // END ANT-ONLY\n\n  // Setup token command\n  program\n    .command('setup-token')\n    .description(\n      'Set up a long-lived authentication token (requires Claude subscription)',\n    )\n    .action(async () => {\n      const [{ setupTokenHandler }, { createRoot }] = await Promise.all([\n        import('./cli/handlers/util.js'),\n        import('./ink.js'),\n      ])\n      const root = await createRoot(getBaseRenderOptions(false))\n      await setupTokenHandler(root)\n    })\n\n  // Agents command - list configured agents\n  program\n    .command('agents')\n    .description('List configured agents')\n    .option(\n      '--setting-sources <sources>',\n      'Comma-separated list of setting sources to load (user, project, local).',\n    )\n    .action(async () => {\n      const { agentsHandler } = await import('./cli/handlers/agents.js')\n      await agentsHandler()\n      process.exit(0)\n    })\n\n  if (feature('TRANSCRIPT_CLASSIFIER')) {\n    // Skip when tengu_auto_mode_config.enabled === 'disabled' (circuit breaker).\n    // Reads from disk cache — GrowthBook isn't initialized at registration time.\n    if (getAutoModeEnabledStateIfCached() !== 'disabled') {\n      const autoModeCmd = program\n        .command('auto-mode')\n        .description('Inspect auto mode classifier configuration')\n\n      autoModeCmd\n        .command('defaults')\n        .description(\n          'Print the default auto mode environment, allow, and deny rules as JSON',\n        )\n        .action(async () => {\n          const { autoModeDefaultsHandler } = await import(\n            './cli/handlers/autoMode.js'\n          )\n          autoModeDefaultsHandler()\n          process.exit(0)\n        })\n\n      autoModeCmd\n        .command('config')\n        .description(\n          'Print the effective auto mode config as JSON: your settings where set, defaults otherwise',\n        )\n        .action(async () => {\n          const { autoModeConfigHandler } = await import(\n            './cli/handlers/autoMode.js'\n          )\n          autoModeConfigHandler()\n          process.exit(0)\n        })\n\n      autoModeCmd\n        .command('critique')\n        .description('Get AI feedback on your custom auto mode rules')\n        .option('--model <model>', 'Override which model is used')\n        .action(async options => {\n          const { autoModeCritiqueHandler } = await import(\n            './cli/handlers/autoMode.js'\n          )\n          await autoModeCritiqueHandler(options)\n          process.exit()\n        })\n    }\n  }\n\n  // Remote Control command — connect local environment to claude.ai/code.\n  // The actual command is intercepted by the fast-path in cli.tsx before\n  // Commander.js runs, so this registration exists only for help output.\n  // Always hidden: isBridgeEnabled() at this point (before enableConfigs)\n  // would throw inside isClaudeAISubscriber → getGlobalConfig and return\n  // false via the try/catch — but not before paying ~65ms of side effects\n  // (25ms settings Zod parse + 40ms sync `security` keychain subprocess).\n  // The dynamic visibility never worked; the command was always hidden.\n  if (feature('BRIDGE_MODE')) {\n    program\n      .command('remote-control', { hidden: true })\n      .alias('rc')\n      .description(\n        'Connect your local environment for remote-control sessions via claude.ai/code',\n      )\n      .action(async () => {\n        // Unreachable — cli.tsx fast-path handles this command before main.tsx loads.\n        // If somehow reached, delegate to bridgeMain.\n        const { bridgeMain } = await import('./bridge/bridgeMain.js')\n        await bridgeMain(process.argv.slice(3))\n      })\n  }\n\n  if (feature('KAIROS')) {\n    program\n      .command('assistant [sessionId]')\n      .description(\n        'Attach the REPL as a client to a running bridge session. Discovers sessions via API if no sessionId given.',\n      )\n      .action(() => {\n        // Argv rewriting above should have consumed `assistant [id]`\n        // before commander runs. Reaching here means a root flag came first\n        // (e.g. `--debug assistant`) and the position-0 predicate\n        // didn't match. Print usage like the ssh stub does.\n        process.stderr.write(\n          'Usage: claude assistant [sessionId]\\n\\n' +\n            'Attach the REPL as a viewer client to a running bridge session.\\n' +\n            'Omit sessionId to discover and pick from available sessions.\\n',\n        )\n        process.exit(1)\n      })\n  }\n\n  // Doctor command - check installation health\n  program\n    .command('doctor')\n    .description(\n      'Check the health of your Claude Code auto-updater. Note: The workspace trust dialog is skipped and stdio servers from .mcp.json are spawned for health checks. Only use this command in directories you trust.',\n    )\n    .action(async () => {\n      const [{ doctorHandler }, { createRoot }] = await Promise.all([\n        import('./cli/handlers/util.js'),\n        import('./ink.js'),\n      ])\n      const root = await createRoot(getBaseRenderOptions(false))\n      await doctorHandler(root)\n    })\n\n  // claude update\n  //\n  // For SemVer-compliant versioning with build metadata (X.X.X+SHA):\n  // - We perform exact string comparison (including SHA) to detect any change\n  // - This ensures users always get the latest build, even when only the SHA changes\n  // - UI shows both versions including build metadata for clarity\n  program\n    .command('update')\n    .alias('upgrade')\n    .description('Check for updates and install if available')\n    .action(async () => {\n      const { update } = await import('src/cli/update.js')\n      await update()\n    })\n\n  // claude up — run the project's CLAUDE.md \"# claude up\" setup instructions.\n  if (\"external\" === 'ant') {\n    program\n      .command('up')\n      .description(\n        '[ANT-ONLY] Initialize or upgrade the local dev environment using the \"# claude up\" section of the nearest CLAUDE.md',\n      )\n      .action(async () => {\n        const { up } = await import('src/cli/up.js')\n        await up()\n      })\n  }\n\n  // claude rollback (ant-only)\n  // Rolls back to previous releases\n  if (\"external\" === 'ant') {\n    program\n      .command('rollback [target]')\n      .description(\n        '[ANT-ONLY] Roll back to a previous release\\n\\nExamples:\\n  claude rollback                                    Go 1 version back from current\\n  claude rollback 3                                  Go 3 versions back from current\\n  claude rollback 2.0.73-dev.20251217.t190658        Roll back to a specific version',\n      )\n      .option('-l, --list', 'List recent published versions with ages')\n      .option('--dry-run', 'Show what would be installed without installing')\n      .option(\n        '--safe',\n        'Roll back to the server-pinned safe version (set by oncall during incidents)',\n      )\n      .action(\n        async (\n          target?: string,\n          options?: { list?: boolean; dryRun?: boolean; safe?: boolean },\n        ) => {\n          const { rollback } = await import('src/cli/rollback.js')\n          await rollback(target, options)\n        },\n      )\n  }\n\n  // claude install\n  program\n    .command('install [target]')\n    .description(\n      'Install Claude Code native build. Use [target] to specify version (stable, latest, or specific version)',\n    )\n    .option('--force', 'Force installation even if already installed')\n    .action(\n      async (target: string | undefined, options: { force?: boolean }) => {\n        const { installHandler } = await import('./cli/handlers/util.js')\n        await installHandler(target, options)\n      },\n    )\n\n  // ant-only commands\n  if (\"external\" === 'ant') {\n    const validateLogId = (value: string) => {\n      const maybeSessionId = validateUuid(value)\n      if (maybeSessionId) return maybeSessionId\n      return Number(value)\n    }\n    // claude log\n    program\n      .command('log')\n      .description('[ANT-ONLY] Manage conversation logs.')\n      .argument(\n        '[number|sessionId]',\n        'A number (0, 1, 2, etc.) to display a specific log, or the sesssion ID (uuid) of a log',\n        validateLogId,\n      )\n      .action(async (logId: string | number | undefined) => {\n        const { logHandler } = await import('./cli/handlers/ant.js')\n        await logHandler(logId)\n      })\n\n    // claude error\n    program\n      .command('error')\n      .description(\n        '[ANT-ONLY] View error logs. Optionally provide a number (0, -1, -2, etc.) to display a specific log.',\n      )\n      .argument(\n        '[number]',\n        'A number (0, 1, 2, etc.) to display a specific log',\n        parseInt,\n      )\n      .action(async (number: number | undefined) => {\n        const { errorHandler } = await import('./cli/handlers/ant.js')\n        await errorHandler(number)\n      })\n\n    // claude export\n    program\n      .command('export')\n      .description('[ANT-ONLY] Export a conversation to a text file.')\n      .usage('<source> <outputFile>')\n      .argument(\n        '<source>',\n        'Session ID, log index (0, 1, 2...), or path to a .json/.jsonl log file',\n      )\n      .argument('<outputFile>', 'Output file path for the exported text')\n      .addHelpText(\n        'after',\n        `\nExamples:\n  $ claude export 0 conversation.txt                Export conversation at log index 0\n  $ claude export <uuid> conversation.txt           Export conversation by session ID\n  $ claude export input.json output.txt             Render JSON log file to text\n  $ claude export <uuid>.jsonl output.txt           Render JSONL session file to text`,\n      )\n      .action(async (source: string, outputFile: string) => {\n        const { exportHandler } = await import('./cli/handlers/ant.js')\n        await exportHandler(source, outputFile)\n      })\n\n    if (\"external\" === 'ant') {\n      const taskCmd = program\n        .command('task')\n        .description('[ANT-ONLY] Manage task list tasks')\n\n      taskCmd\n        .command('create <subject>')\n        .description('Create a new task')\n        .option('-d, --description <text>', 'Task description')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .action(\n          async (\n            subject: string,\n            opts: { description?: string; list?: string },\n          ) => {\n            const { taskCreateHandler } = await import('./cli/handlers/ant.js')\n            await taskCreateHandler(subject, opts)\n          },\n        )\n\n      taskCmd\n        .command('list')\n        .description('List all tasks')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .option('--pending', 'Show only pending tasks')\n        .option('--json', 'Output as JSON')\n        .action(\n          async (opts: {\n            list?: string\n            pending?: boolean\n            json?: boolean\n          }) => {\n            const { taskListHandler } = await import('./cli/handlers/ant.js')\n            await taskListHandler(opts)\n          },\n        )\n\n      taskCmd\n        .command('get <id>')\n        .description('Get details of a task')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .action(async (id: string, opts: { list?: string }) => {\n          const { taskGetHandler } = await import('./cli/handlers/ant.js')\n          await taskGetHandler(id, opts)\n        })\n\n      taskCmd\n        .command('update <id>')\n        .description('Update a task')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .option(\n          '-s, --status <status>',\n          `Set status (${TASK_STATUSES.join(', ')})`,\n        )\n        .option('--subject <text>', 'Update subject')\n        .option('-d, --description <text>', 'Update description')\n        .option('--owner <agentId>', 'Set owner')\n        .option('--clear-owner', 'Clear owner')\n        .action(\n          async (\n            id: string,\n            opts: {\n              list?: string\n              status?: string\n              subject?: string\n              description?: string\n              owner?: string\n              clearOwner?: boolean\n            },\n          ) => {\n            const { taskUpdateHandler } = await import('./cli/handlers/ant.js')\n            await taskUpdateHandler(id, opts)\n          },\n        )\n\n      taskCmd\n        .command('dir')\n        .description('Show the tasks directory path')\n        .option('-l, --list <id>', 'Task list ID (defaults to \"tasklist\")')\n        .action(async (opts: { list?: string }) => {\n          const { taskDirHandler } = await import('./cli/handlers/ant.js')\n          await taskDirHandler(opts)\n        })\n    }\n\n    // claude completion <shell>\n    program\n      .command('completion <shell>', { hidden: true })\n      .description('Generate shell completion script (bash, zsh, or fish)')\n      .option(\n        '--output <file>',\n        'Write completion script directly to a file instead of stdout',\n      )\n      .action(async (shell: string, opts: { output?: string }) => {\n        const { completionHandler } = await import('./cli/handlers/ant.js')\n        await completionHandler(shell, opts, program)\n      })\n  }\n\n  profileCheckpoint('run_before_parse')\n  await program.parseAsync(process.argv)\n  profileCheckpoint('run_after_parse')\n\n  // Record final checkpoint for total_time calculation\n  profileCheckpoint('main_after_run')\n\n  // Log startup perf to Statsig (sampled) and output detailed report if enabled\n  profileReport()\n\n  return program\n}\n\nasync function logTenguInit({\n  hasInitialPrompt,\n  hasStdin,\n  verbose,\n  debug,\n  debugToStderr,\n  print,\n  outputFormat,\n  inputFormat,\n  numAllowedTools,\n  numDisallowedTools,\n  mcpClientCount,\n  worktreeEnabled,\n  skipWebFetchPreflight,\n  githubActionInputs,\n  dangerouslySkipPermissionsPassed,\n  permissionMode,\n  modeIsBypass,\n  allowDangerouslySkipPermissionsPassed,\n  systemPromptFlag,\n  appendSystemPromptFlag,\n  thinkingConfig,\n  assistantActivationPath,\n}: {\n  hasInitialPrompt: boolean\n  hasStdin: boolean\n  verbose: boolean\n  debug: boolean\n  debugToStderr: boolean\n  print: boolean\n  outputFormat: string\n  inputFormat: string\n  numAllowedTools: number\n  numDisallowedTools: number\n  mcpClientCount: number\n  worktreeEnabled: boolean\n  skipWebFetchPreflight: boolean | undefined\n  githubActionInputs: string | undefined\n  dangerouslySkipPermissionsPassed: boolean\n  permissionMode: string\n  modeIsBypass: boolean\n  allowDangerouslySkipPermissionsPassed: boolean\n  systemPromptFlag: 'file' | 'flag' | undefined\n  appendSystemPromptFlag: 'file' | 'flag' | undefined\n  thinkingConfig: ThinkingConfig\n  assistantActivationPath: string | undefined\n}): Promise<void> {\n  try {\n    logEvent('tengu_init', {\n      entrypoint:\n        'claude' as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      hasInitialPrompt,\n      hasStdin,\n      verbose,\n      debug,\n      debugToStderr,\n      print,\n      outputFormat:\n        outputFormat as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      inputFormat:\n        inputFormat as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      numAllowedTools,\n      numDisallowedTools,\n      mcpClientCount,\n      worktree: worktreeEnabled,\n      skipWebFetchPreflight,\n      ...(githubActionInputs && {\n        githubActionInputs:\n          githubActionInputs as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      }),\n      dangerouslySkipPermissionsPassed,\n      permissionMode:\n        permissionMode as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      modeIsBypass,\n      inProtectedNamespace: isInProtectedNamespace(),\n      allowDangerouslySkipPermissionsPassed,\n      thinkingType:\n        thinkingConfig.type as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      ...(systemPromptFlag && {\n        systemPromptFlag:\n          systemPromptFlag as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      }),\n      ...(appendSystemPromptFlag && {\n        appendSystemPromptFlag:\n          appendSystemPromptFlag as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      }),\n      is_simple: isBareMode() || undefined,\n      is_coordinator:\n        feature('COORDINATOR_MODE') &&\n        coordinatorModeModule?.isCoordinatorMode()\n          ? true\n          : undefined,\n      ...(assistantActivationPath && {\n        assistantActivationPath:\n          assistantActivationPath as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      }),\n      autoUpdatesChannel: (getInitialSettings().autoUpdatesChannel ??\n        'latest') as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n      ...(\"external\" === 'ant'\n        ? (() => {\n            const cwd = getCwd()\n            const gitRoot = findGitRoot(cwd)\n            const rp = gitRoot ? relative(gitRoot, cwd) || '.' : undefined\n            return rp\n              ? {\n                  relativeProjectPath:\n                    rp as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n                }\n              : {}\n          })()\n        : {}),\n    })\n  } catch (error) {\n    logError(error)\n  }\n}\n\nfunction maybeActivateProactive(options: unknown): void {\n  if (\n    (feature('PROACTIVE') || feature('KAIROS')) &&\n    ((options as { proactive?: boolean }).proactive ||\n      isEnvTruthy(process.env.CLAUDE_CODE_PROACTIVE))\n  ) {\n    // eslint-disable-next-line @typescript-eslint/no-require-imports\n    const proactiveModule = require('./proactive/index.js')\n    if (!proactiveModule.isProactiveActive()) {\n      proactiveModule.activateProactive('command')\n    }\n  }\n}\n\nfunction maybeActivateBrief(options: unknown): void {\n  if (!(feature('KAIROS') || feature('KAIROS_BRIEF'))) return\n  const briefFlag = (options as { brief?: boolean }).brief\n  const briefEnv = isEnvTruthy(process.env.CLAUDE_CODE_BRIEF)\n  if (!briefFlag && !briefEnv) return\n  // --brief / CLAUDE_CODE_BRIEF are explicit opt-ins: check entitlement,\n  // then set userMsgOptIn to activate the tool + prompt section. The env\n  // var also grants entitlement (isBriefEntitled() reads it), so setting\n  // CLAUDE_CODE_BRIEF=1 alone force-enables for dev/testing — no GB gate\n  // needed. initialIsBriefOnly reads getUserMsgOptIn() directly.\n  // Conditional require: static import would leak the tool name string\n  // into external builds via BriefTool.ts → prompt.ts.\n  /* eslint-disable @typescript-eslint/no-require-imports */\n  const { isBriefEntitled } =\n    require('./tools/BriefTool/BriefTool.js') as typeof import('./tools/BriefTool/BriefTool.js')\n  /* eslint-enable @typescript-eslint/no-require-imports */\n  const entitled = isBriefEntitled()\n  if (entitled) {\n    setUserMsgOptIn(true)\n  }\n  // Fire unconditionally once intent is seen: enabled=false captures the\n  // \"user tried but was gated\" failure mode in Datadog.\n  logEvent('tengu_brief_mode_enabled', {\n    enabled: entitled,\n    gated: !entitled,\n    source: (briefEnv\n      ? 'env'\n      : 'flag') as AnalyticsMetadata_I_VERIFIED_THIS_IS_NOT_CODE_OR_FILEPATHS,\n  })\n}\n\nfunction resetCursor() {\n  const terminal = process.stderr.isTTY\n    ? process.stderr\n    : process.stdout.isTTY\n      ? process.stdout\n      : undefined\n  terminal?.write(SHOW_CURSOR)\n}\n\ntype TeammateOptions = {\n  agentId?: string\n  agentName?: string\n  teamName?: string\n  agentColor?: string\n  planModeRequired?: boolean\n  parentSessionId?: string\n  teammateMode?: 'auto' | 'tmux' | 'in-process'\n  agentType?: string\n}\n\nfunction extractTeammateOptions(options: unknown): TeammateOptions {\n  if (typeof options !== 'object' || options === null) {\n    return {}\n  }\n  const opts = options as Record<string, unknown>\n  const teammateMode = opts.teammateMode\n  return {\n    agentId: typeof opts.agentId === 'string' ? opts.agentId : undefined,\n    agentName: typeof opts.agentName === 'string' ? opts.agentName : undefined,\n    teamName: typeof opts.teamName === 'string' ? opts.teamName : undefined,\n    agentColor:\n      typeof opts.agentColor === 'string' ? opts.agentColor : undefined,\n    planModeRequired:\n      typeof opts.planModeRequired === 'boolean'\n        ? opts.planModeRequired\n        : undefined,\n    parentSessionId:\n      typeof opts.parentSessionId === 'string'\n        ? opts.parentSessionId\n        : undefined,\n    teammateMode:\n      teammateMode === 'auto' ||\n      teammateMode === 'tmux' ||\n      teammateMode === 'in-process'\n        ? teammateMode\n        : undefined,\n    agentType: typeof opts.agentType === 'string' ? opts.agentType : undefined,\n  }\n}\n"],"mappings":"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","ignoreList":[]} diff --git a/src/services/policyLimits/index.ts b/src/services/policyLimits/index.ts index e328875..3e47eaa 100644 --- a/src/services/policyLimits/index.ts +++ b/src/services/policyLimits/index.ts @@ -165,6 +165,10 @@ function computeChecksum( * getSettings() to avoid circular dependencies during settings loading. */ export function isPolicyLimitsEligible(): boolean { + if (process.env.CLAUDE_CODE_LOCAL_SKIP_REMOTE_PREFETCH === '1') { + return false + } + // 3p provider users should not hit the policy limits endpoint if (getAPIProvider() !== 'firstParty') { return false diff --git a/src/services/remoteManagedSettings/syncCache.ts b/src/services/remoteManagedSettings/syncCache.ts index da65f65..73bfb5f 100644 --- a/src/services/remoteManagedSettings/syncCache.ts +++ b/src/services/remoteManagedSettings/syncCache.ts @@ -49,6 +49,10 @@ export function resetSyncCache(): void { export function isRemoteManagedSettingsEligible(): boolean { if (cached !== undefined) return cached + if (process.env.CLAUDE_CODE_LOCAL_SKIP_REMOTE_PREFETCH === '1') { + return (cached = setEligibility(false)) + } + // 3p provider users should not hit the settings endpoint if (getAPIProvider() !== 'firstParty') { return (cached = setEligibility(false)) diff --git a/src/setup.ts b/src/setup.ts index 985e857..1c0c322 100644 --- a/src/setup.ts +++ b/src/setup.ts @@ -159,6 +159,16 @@ export async function setup( // IMPORTANT: setCwd() must be called before any other code that depends on the cwd setCwd(cwd) + setOriginalCwd(cwd) + setProjectRoot(cwd) + + // Local recovery mode: when CLAUDE_CODE_LOCAL_RECOVERY=1 is explicitly set, + // trim startup to minimum. Otherwise run full setup for the Ink TUI. + if (process.env.CLAUDE_CODE_LOCAL_RECOVERY === '1') { + process.stderr.write('[local-recovery] setup early return\n') + profileCheckpoint('setup_local_recovery_early_return') + return + } // Capture hooks configuration snapshot to avoid hidden hook modifications. // IMPORTANT: Must be called AFTER setCwd() so hooks are loaded from the correct directory diff --git a/src/skills/bundled/index.ts b/src/skills/bundled/index.ts index fdd9dde..b1b9131 100644 --- a/src/skills/bundled/index.ts +++ b/src/skills/bundled/index.ts @@ -1,16 +1,5 @@ import { feature } from 'bun:bundle' import { shouldAutoEnableClaudeInChrome } from 'src/utils/claudeInChrome/setup.js' -import { registerBatchSkill } from './batch.js' -import { registerClaudeInChromeSkill } from './claudeInChrome.js' -import { registerDebugSkill } from './debug.js' -import { registerKeybindingsSkill } from './keybindings.js' -import { registerLoremIpsumSkill } from './loremIpsum.js' -import { registerRememberSkill } from './remember.js' -import { registerSimplifySkill } from './simplify.js' -import { registerSkillifySkill } from './skillify.js' -import { registerStuckSkill } from './stuck.js' -import { registerUpdateConfigSkill } from './updateConfig.js' -import { registerVerifySkill } from './verify.js' /** * Initialize all bundled skills. @@ -22,58 +11,48 @@ import { registerVerifySkill } from './verify.js' * 3. Import and call that function here */ export function initBundledSkills(): void { - registerUpdateConfigSkill() - registerKeybindingsSkill() - registerVerifySkill() - registerDebugSkill() - registerLoremIpsumSkill() - registerSkillifySkill() - registerRememberSkill() - registerSimplifySkill() - registerBatchSkill() - registerStuckSkill() + /* eslint-disable @typescript-eslint/no-require-imports */ + require('./updateConfig.js').registerUpdateConfigSkill() + require('./keybindings.js').registerKeybindingsSkill() + require('./verify.js').registerVerifySkill() + require('./debug.js').registerDebugSkill() + require('./loremIpsum.js').registerLoremIpsumSkill() + require('./skillify.js').registerSkillifySkill() + require('./remember.js').registerRememberSkill() + require('./simplify.js').registerSimplifySkill() + require('./batch.js').registerBatchSkill() + require('./stuck.js').registerStuckSkill() if (feature('KAIROS') || feature('KAIROS_DREAM')) { - /* eslint-disable @typescript-eslint/no-require-imports */ const { registerDreamSkill } = require('./dream.js') - /* eslint-enable @typescript-eslint/no-require-imports */ registerDreamSkill() } if (feature('REVIEW_ARTIFACT')) { - /* eslint-disable @typescript-eslint/no-require-imports */ const { registerHunterSkill } = require('./hunter.js') - /* eslint-enable @typescript-eslint/no-require-imports */ registerHunterSkill() } if (feature('AGENT_TRIGGERS')) { - /* eslint-disable @typescript-eslint/no-require-imports */ const { registerLoopSkill } = require('./loop.js') - /* eslint-enable @typescript-eslint/no-require-imports */ // /loop's isEnabled delegates to isKairosCronEnabled() — same lazy // per-invocation pattern as the cron tools. Registered unconditionally; // the skill's own isEnabled callback decides visibility. registerLoopSkill() } if (feature('AGENT_TRIGGERS_REMOTE')) { - /* eslint-disable @typescript-eslint/no-require-imports */ const { registerScheduleRemoteAgentsSkill, } = require('./scheduleRemoteAgents.js') - /* eslint-enable @typescript-eslint/no-require-imports */ registerScheduleRemoteAgentsSkill() } if (feature('BUILDING_CLAUDE_APPS')) { - /* eslint-disable @typescript-eslint/no-require-imports */ const { registerClaudeApiSkill } = require('./claudeApi.js') - /* eslint-enable @typescript-eslint/no-require-imports */ registerClaudeApiSkill() } if (shouldAutoEnableClaudeInChrome()) { - registerClaudeInChromeSkill() + require('./claudeInChrome.js').registerClaudeInChromeSkill() } if (feature('RUN_SKILL_GENERATOR')) { - /* eslint-disable @typescript-eslint/no-require-imports */ const { registerRunSkillGeneratorSkill } = require('./runSkillGenerator.js') - /* eslint-enable @typescript-eslint/no-require-imports */ registerRunSkillGeneratorSkill() } + /* eslint-enable @typescript-eslint/no-require-imports */ } diff --git a/src/skills/bundled/verify/SKILL.md b/src/skills/bundled/verify/SKILL.md new file mode 100644 index 0000000..c690d1c --- /dev/null +++ b/src/skills/bundled/verify/SKILL.md @@ -0,0 +1,6 @@ +--- +name: verify +description: Verify a code change does what it should by running the app. +--- + +Verify the code change works as expected. diff --git a/src/skills/bundled/verify/examples/cli.md b/src/skills/bundled/verify/examples/cli.md new file mode 100644 index 0000000..0df4108 --- /dev/null +++ b/src/skills/bundled/verify/examples/cli.md @@ -0,0 +1 @@ +# CLI verification example diff --git a/src/skills/bundled/verify/examples/server.md b/src/skills/bundled/verify/examples/server.md new file mode 100644 index 0000000..3a1460d --- /dev/null +++ b/src/skills/bundled/verify/examples/server.md @@ -0,0 +1 @@ +# Server verification example diff --git a/src/tools/TungstenTool/TungstenLiveMonitor.tsx b/src/tools/TungstenTool/TungstenLiveMonitor.tsx new file mode 100644 index 0000000..5b01a6d --- /dev/null +++ b/src/tools/TungstenTool/TungstenLiveMonitor.tsx @@ -0,0 +1,5 @@ +import React from 'react' + +export function TungstenLiveMonitor(): React.JSX.Element | null { + return null +} diff --git a/src/tools/TungstenTool/TungstenTool.ts b/src/tools/TungstenTool/TungstenTool.ts new file mode 100644 index 0000000..fd4593f --- /dev/null +++ b/src/tools/TungstenTool/TungstenTool.ts @@ -0,0 +1,43 @@ +import { z } from 'zod/v4' + +const inputSchema = z.object({}).passthrough() + +export const TungstenTool = { + name: 'tungsten', + aliases: [], + maxResultSizeChars: 0, + inputSchema, + async description() { + return 'Unavailable in this local recovery build.' + }, + async prompt() { + return 'TungstenTool is unavailable in this local recovery build.' + }, + async call() { + return { + data: { + success: false, + error: 'TungstenTool is unavailable in this local recovery build.', + }, + } + }, + isConcurrencySafe() { + return true + }, + isEnabled() { + return false + }, + isReadOnly() { + return true + }, + async checkPermissions() { + return { + behavior: 'deny' as const, + message: 'TungstenTool is unavailable in this local recovery build.', + } + }, +} + +export function clearSessionsWithTungstenUsage(): void {} + +export function resetInitializationState(): void {} diff --git a/src/tools/WorkflowTool/constants.ts b/src/tools/WorkflowTool/constants.ts new file mode 100644 index 0000000..444a03a --- /dev/null +++ b/src/tools/WorkflowTool/constants.ts @@ -0,0 +1 @@ +export const WORKFLOW_TOOL_NAME = 'workflow' diff --git a/src/types/connectorText.ts b/src/types/connectorText.ts new file mode 100644 index 0000000..88e3b9b --- /dev/null +++ b/src/types/connectorText.ts @@ -0,0 +1,20 @@ +export type ConnectorTextBlock = { + type: 'connector_text'; + text?: string; +}; + +export type ConnectorTextDelta = { + type: 'connector_text_delta'; + text?: string; +}; + +export function isConnectorTextBlock( + value: unknown, +): value is ConnectorTextBlock { + return ( + typeof value === 'object' && + value !== null && + 'type' in value && + (value as { type?: unknown }).type === 'connector_text' + ); +} diff --git a/src/utils/filePersistence/types.ts b/src/utils/filePersistence/types.ts new file mode 100644 index 0000000..1563f71 --- /dev/null +++ b/src/utils/filePersistence/types.ts @@ -0,0 +1,22 @@ +// Local recovery stub for missing filePersistence types + +export const DEFAULT_UPLOAD_CONCURRENCY = 5 +export const FILE_COUNT_LIMIT = 100 +export const OUTPUTS_SUBDIR = 'outputs' + +export interface FailedPersistence { + filePath: string + error: string +} + +export interface PersistedFile { + filePath: string + fileId?: string +} + +export interface FilesPersistedEventData { + persisted: PersistedFile[] + failed: FailedPersistence[] +} + +export type TurnStartTime = number diff --git a/src/utils/modifiers.ts b/src/utils/modifiers.ts index 08bde4b..02d8c52 100644 --- a/src/utils/modifiers.ts +++ b/src/utils/modifiers.ts @@ -28,9 +28,13 @@ export function isModifierPressed(modifier: ModifierKey): boolean { if (process.platform !== 'darwin') { return false } - // Dynamic import to avoid loading native module at top level - const { isModifierPressed: nativeIsModifierPressed } = - // eslint-disable-next-line @typescript-eslint/no-require-imports - require('modifiers-napi') as { isModifierPressed: (m: string) => boolean } - return nativeIsModifierPressed(modifier) + try { + // Dynamic import to avoid loading native module at top level + const { isModifierPressed: nativeIsModifierPressed } = + // eslint-disable-next-line @typescript-eslint/no-require-imports + require('modifiers-napi') as { isModifierPressed: (m: string) => boolean } + return nativeIsModifierPressed(modifier) + } catch { + return false + } } diff --git a/src/utils/ultraplan/prompt.txt b/src/utils/ultraplan/prompt.txt new file mode 100644 index 0000000..4fdd525 --- /dev/null +++ b/src/utils/ultraplan/prompt.txt @@ -0,0 +1 @@ +You are a planning assistant. diff --git a/stubs/ant-claude-for-chrome-mcp.ts b/stubs/ant-claude-for-chrome-mcp.ts new file mode 100644 index 0000000..40cfd27 --- /dev/null +++ b/stubs/ant-claude-for-chrome-mcp.ts @@ -0,0 +1,24 @@ +export type PermissionMode = + | 'ask' + | 'skip_all_permission_checks' + | 'follow_a_plan'; + +export type Logger = { + silly?: (...args: unknown[]) => void; + debug?: (...args: unknown[]) => void; + info?: (...args: unknown[]) => void; + warn?: (...args: unknown[]) => void; + error?: (...args: unknown[]) => void; +}; + +export type ClaudeForChromeContext = Record; + +export const BROWSER_TOOLS: Array<{ name: string }> = []; + +export function createClaudeForChromeMcpServer( + _context: ClaudeForChromeContext, +) { + return { + async connect(_transport: unknown): Promise {}, + }; +} diff --git a/stubs/color-diff-napi.ts b/stubs/color-diff-napi.ts new file mode 100644 index 0000000..b0b6fd1 --- /dev/null +++ b/stubs/color-diff-napi.ts @@ -0,0 +1,19 @@ +export type SyntaxTheme = { + name: string; +}; + +export class ColorDiff { + format(input: string): string { + return input; + } +} + +export class ColorFile { + format(input: string): string { + return input; + } +} + +export function getSyntaxTheme(themeName: string): SyntaxTheme { + return { name: themeName }; +} diff --git a/tsconfig.json b/tsconfig.json new file mode 100644 index 0000000..44c9330 --- /dev/null +++ b/tsconfig.json @@ -0,0 +1,24 @@ +{ + "compilerOptions": { + "target": "ESNext", + "module": "ESNext", + "moduleResolution": "bundler", + "allowJs": true, + "jsx": "react-jsx", + "baseUrl": ".", + "paths": { + "@ant/claude-for-chrome-mcp": [ + "./stubs/ant-claude-for-chrome-mcp.ts" + ], + "color-diff-napi": [ + "./stubs/color-diff-napi.ts" + ], + "src/*": [ + "./src/*" + ] + }, + "types": [ + "bun-types" + ] + } +}