# PROACTIVE — 主动模式 > Feature Flag: `FEATURE_PROACTIVE=1`(与 `FEATURE_KAIROS=1` 共享功能) > 实现状态:核心循环与 SleepTool 已落地,部分外围文档仍在补齐 > 引用数:37 ## 一、功能概述 PROACTIVE 实现 Tick 驱动的自主代理。CLI 在用户不输入时也能持续工作:定时唤醒执行任务,配合 SleepTool 控制节奏。适用于长时间运行的后台任务(等待 CI、监控文件变化、定时检查等)。 ### 与 KAIROS 的关系 所有代码检查都是 `feature('PROACTIVE') || feature('KAIROS')`,即: - 单独开 `FEATURE_PROACTIVE=1` → 获得 proactive 能力 - 单独开 `FEATURE_KAIROS=1` → 自动获得 proactive 能力 - 两者都开 → 相同效果(不重复) ## 二、实现架构 ### 2.1 模块状态 | 模块 | 文件 | 状态 | 说明 | |------|------|------|------| | 核心逻辑 | `src/proactive/index.ts` | **已实现** | `activateProactive()`、`deactivateProactive()`、`pause/resume`、`nextTickAt` 调度状态 | | SleepTool 提示 | `src/tools/SleepTool/prompt.ts` | **完整** | 工具提示定义(工具名:`Sleep`) | | 命令注册 | `src/commands.ts:62-65` | **布线** | 动态加载 `./commands/proactive.js` | | 工具注册 | `src/tools.ts:26-28` | **布线** | SleepTool 动态加载 | | REPL 集成 | `src/screens/REPL.tsx` | **已实现** | tick 驱动、standby/sleeping 状态、页脚与 bridge automation metadata 上报 | | 系统提示 | `src/constants/prompts.ts:860-914` | **完整** | 自主工作行为指令(~55 行详细 prompt) | | 远控状态镜像 | `src/utils/sessionState.ts` | **已实现** | 向 remote-control/CCR 暴露 `automation_state` 元数据 | ### 2.2 系统提示内容 `getProactiveSection()` 注入的自主工作指令包含: | 章节 | 内容 | |------|------| | Tick 驱动 | `` prompt 保持存活,包含用户本地时间 | | 节奏控制 | SleepTool 控制等待间隔,prompt cache 5 分钟过期 | | 空操作规则 | 无事可做时**必须**调用 Sleep,禁止输出 "still waiting" | | 首次唤醒 | 简短问候,等待方向(不主动探索) | | 后续唤醒 | 寻找有用工作:调查、验证、检查(不 spam 用户) | | 偏向行动 | 读文件、搜索代码、commit — 不需询问 | | 终端焦点 | `terminalFocus` 字段调节自主程度 | ### 2.3 数据流 ``` activateProactive() │ ▼ Tick 调度器启动 │ ├── 定时生成 消息 │ ├── 包含用户当前本地时间 │ └── 注入到对话流(sessionStorage) │ ▼ 模型处理 tick │ ├── 有事可做 → 使用工具执行 → 可能再次 Sleep └── 无事可做 → 必须调用 SleepTool │ ▼ SleepTool 等待 │ ├── 用户插入新工作 / 队列中有命令 → 立即唤醒 ├── proactive 被关闭 → 立即中断 └── 进入休眠时向远端 surfaces 上报 `automation_state = sleeping` │ ▼ 下一个 tick 到达 ``` ## 三、当前行为补充 - `standby`:proactive 已开启,当前没有执行中的 turn,且已调度下一个 tick。 - `sleeping`:模型显式调用 `SleepTool` 进入等待窗口。 - remote-control/CCR 通过 `external_metadata.automation_state` 接收这两个状态,用于 Web UI 的 Autopilot 状态显示。 - `SleepTool` 现在不是纯定时器;它会在共享命令队列出现新工作时提前醒来。 ## 四、关键设计决策 1. **Tick 驱动**:模型通过 SleepTool 自行控制唤醒频率,不是外部事件推送 2. **空操作必须 Sleep**:防止 "still waiting" 类空消息浪费 turn 和 token 3. **Prompt cache 考量**:SleepTool 提示中提到 cache 5 分钟过期,建议平衡等待时间 4. **Terminal Focus 感知**:模型根据用户是否在看终端调整自主程度 ## 五、使用方式 ```bash # 单独启用 proactive FEATURE_PROACTIVE=1 bun run dev # 通过 KAIROS 间接启用 FEATURE_KAIROS=1 bun run dev # 组合使用 FEATURE_PROACTIVE=1 FEATURE_KAIROS=1 FEATURE_KAIROS_BRIEF=1 bun run dev ``` ## 六、文件索引 | 文件 | 职责 | |------|------| | `src/proactive/index.ts` | 核心逻辑与 next-tick 状态 | | `src/tools/SleepTool/prompt.ts` | SleepTool 工具提示 | | `src/tools/SleepTool/SleepTool.ts` | 休眠/唤醒执行逻辑 | | `src/constants/prompts.ts:860-914` | 自主工作系统提示 | | `src/screens/REPL.tsx` | REPL tick 集成与 automation 状态上报 | | `src/utils/sessionStorage.ts:4892-4912` | Tick 消息注入 | | `src/utils/sessionState.ts` | bridge/CCR metadata 镜像 | | `src/components/PromptInput/PromptInputFooterLeftSide.tsx` | 页脚 UI 状态 |