KAIROS — 常驻助手模式
Feature Flag: FEATURE_KAIROS=1(及子 Feature)
实现状态:核心框架完整,部分子模块为 stub
引用数:154(全库最大)
一、功能概述
KAIROS 将 Claude Code CLI 从”问答工具”转变为”常驻助手”。开启后,CLI 持续运行在后台,支持:- 持久化 bridge 会话:跨终端重启复用 session,通过 Anthropic OAuth 连接 claude.ai
- 后台执行任务:用户离开终端时继续工作(配合 PROACTIVE feature)
- 推送通知到移动端:任务完成或需要输入时推送(配合
KAIROS_PUSH_NOTIFICATION) - 每日记忆日志:自动记录和回顾工作内容(配合
KAIROS_DREAM) - 外部频道消息接入:Slack/Discord/Telegram 消息转发到 CLI(配合
KAIROS_CHANNELS) - 结构化 Brief 输出:通过 BriefTool 输出结构化消息(配合
KAIROS_BRIEF)
子 Feature 依赖关系
feature('PROACTIVE') || feature('KAIROS'),即 KAIROS 开启时自动获得 proactive 能力。
二、系统提示
KAIROS 在系统提示中注入两大段落:2.1 Brief 段落 (getBriefSection)
文件:src/constants/prompts.ts:843-858
当 feature('KAIROS') || feature('KAIROS_BRIEF') 时注入。Brief 工具(SendUserMessage)的结构化消息输出指令。/brief toggle 和 --brief flag 只控制显示过滤,不影响模型行为。
2.2 Proactive/Autonomous Work 段落 (getProactiveSection)
文件:src/constants/prompts.ts:860-914
当 feature('PROACTIVE') || feature('KAIROS') 且 isProactiveActive() 时注入。核心行为指令:
- Tick 驱动:通过
<tick_tag>prompt 保持存活,每个 tick 包含用户当前本地时间 - 节奏控制:使用
SleepTool控制等待间隔(prompt cache 5 分钟过期) - 空操作时必须 Sleep:禁止输出 “still waiting” 类文本(浪费 turn 和 token)
- 偏向行动:读文件、搜索代码、修改文件、commit — 都不需询问
- 终端焦点感知:
terminalFocus字段指示用户是否在看终端- Unfocused → 高度自主行动
- Focused → 更协作,展示选择
三、实现架构
3.1 核心模块
| 模块 | 文件 | 状态 | 职责 |
|---|---|---|---|
| Assistant 入口 | src/assistant/index.ts | Stub | isAssistantMode()、initializeAssistantTeam() |
| Session 发现 | src/assistant/sessionDiscovery.ts | Stub | 发现可用 bridge session |
| Session 历史 | src/assistant/sessionHistory.ts | Stub | 持久化 session 历史 |
| Gate 控制 | src/assistant/gate.ts | Stub | GrowthBook 门控检查 |
| Session 选择器 | src/assistant/AssistantSessionChooser.ts | Stub | UI 选择 session |
| BriefTool | src/tools/BriefTool/ | Stub | 结构化消息输出工具 |
| Channel Notification | src/services/mcp/channelNotification.ts | Stub | 外部频道消息接入 |
| Dream Task | src/components/tasks/src/tasks/DreamTask/ | Stub | 记忆蒸馏任务 |
| Memory Directory | src/memdir/memdir.ts | Stub | 记忆目录管理 |
3.2 SleepTool(与 Proactive 共享)
文件:src/tools/SleepTool/prompt.ts
SleepTool 是 KAIROS/Proactive 的节奏控制核心。工具描述让模型理解”休眠”概念:
- 工具名:
Sleep - 功能:等待指定时间后响应 tick prompt
- 与
<tick_tag>配合实现心跳式自主工作
3.3 Bridge 集成
KAIROS 通过 Bridge Mode(src/bridge/)连接到 claude.ai 服务器:
3.4 数据流
四、关键设计决策
- Tick 驱动而非事件驱动:模型通过 SleepTool 自行控制唤醒频率,而非外部事件推送。简化架构但增加 API 调用开销
- KAIROS ⊃ PROACTIVE:所有 proactive 检查都包含 KAIROS,无需同时开启两个 flag
- Brief 显示/行为分离:
/brieftoggle 只控制 UI 过滤,模型始终可以使用 BriefTool - Terminal Focus 感知:模型根据用户是否在看终端自动调节自主程度
- GrowthBook 门控:部分功能(如推送通知)即使 feature flag 开启还需要服务端 GrowthBook 开关
五、使用方式
六、外部依赖
- Anthropic OAuth:必须使用 claude.ai 订阅登录(非 API key)
- GrowthBook:服务端特性门控(
tengu_ccr_bridge等) - Bridge API:
/v1/environments/bridge系列端点
七、文件索引
| 文件 | 行数 | 职责 |
|---|---|---|
src/assistant/index.ts | 9 | Assistant 模块入口(stub) |
src/assistant/gate.ts | — | GrowthBook 门控(stub) |
src/assistant/sessionDiscovery.ts | — | Session 发现(stub) |
src/assistant/sessionHistory.ts | — | Session 历史(stub) |
src/assistant/AssistantSessionChooser.ts | — | Session 选择 UI(stub) |
src/tools/BriefTool/ | — | BriefTool 实现(stub) |
src/tools/SleepTool/prompt.ts | ~30 | SleepTool 工具提示 |
src/services/mcp/channelNotification.ts | 5 | 频道消息接入(stub) |
src/memdir/memdir.ts | — | 记忆目录管理(stub) |
src/constants/prompts.ts:552-554,843-914 | 72 | 系统提示注入 |
src/components/tasks/src/tasks/DreamTask/ | 3 | Dream 任务(stub) |
src/proactive/index.ts | — | Proactive 核心(stub,KAIROS 共享) |