Skip to main content

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 依赖关系

KAIROS (主开关)
├── KAIROS_BRIEF (BriefTool, 结构化输出)
├── KAIROS_CHANNELS (外部频道消息)
├── KAIROS_PUSH_NOTIFICATION (移动端推送)
├── KAIROS_GITHUB_WEBHOOKS (GitHub PR webhook)
└── KAIROS_DREAM (记忆蒸馏)
注意:PROACTIVE 与 KAIROS 强绑定。所有代码检查都是 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.tsStubisAssistantMode()initializeAssistantTeam()
Session 发现src/assistant/sessionDiscovery.tsStub发现可用 bridge session
Session 历史src/assistant/sessionHistory.tsStub持久化 session 历史
Gate 控制src/assistant/gate.tsStubGrowthBook 门控检查
Session 选择器src/assistant/AssistantSessionChooser.tsStubUI 选择 session
BriefToolsrc/tools/BriefTool/Stub结构化消息输出工具
Channel Notificationsrc/services/mcp/channelNotification.tsStub外部频道消息接入
Dream Tasksrc/components/tasks/src/tasks/DreamTask/Stub记忆蒸馏任务
Memory Directorysrc/memdir/memdir.tsStub记忆目录管理

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 服务器:
claude.ai web/app

      ▼ (HTTPS long-poll)
┌──────────────────────┐
│  Bridge API Client   │  src/bridge/bridgeApi.ts
│  (register/poll/     │
│   acknowledge)       │
└──────────┬───────────┘


┌──────────────────────┐
│  Session Runner      │  src/bridge/sessionRunner.ts
│  (创建/恢复 REPL)     │
└──────────┬───────────┘


┌──────────────────────┐
│  REPL + Proactive    │  Tick 驱动自主工作
│  Tick Loop           │
└──────────────────────┘

3.4 数据流

用户从 claude.ai 发送消息


Bridge pollForWork() 收到 WorkResponse


acknowledgeWork() 确认接收


sessionRunner 创建/恢复 REPL session


用户消息注入到 REPL 对话


模型处理 → 工具调用 → BriefTool 结构化输出


结果通过 Bridge API 回传到 claude.ai

四、关键设计决策

  1. Tick 驱动而非事件驱动:模型通过 SleepTool 自行控制唤醒频率,而非外部事件推送。简化架构但增加 API 调用开销
  2. KAIROS ⊃ PROACTIVE:所有 proactive 检查都包含 KAIROS,无需同时开启两个 flag
  3. Brief 显示/行为分离/brief toggle 只控制 UI 过滤,模型始终可以使用 BriefTool
  4. Terminal Focus 感知:模型根据用户是否在看终端自动调节自主程度
  5. GrowthBook 门控:部分功能(如推送通知)即使 feature flag 开启还需要服务端 GrowthBook 开关

五、使用方式

# 最小启用(常驻助手 + Brief)
FEATURE_KAIROS=1 FEATURE_KAIROS_BRIEF=1 bun run dev

# 全功能启用
FEATURE_KAIROS=1 \
FEATURE_KAIROS_BRIEF=1 \
FEATURE_KAIROS_CHANNELS=1 \
FEATURE_KAIROS_PUSH_NOTIFICATION=1 \
FEATURE_KAIROS_GITHUB_WEBHOOKS=1 \
FEATURE_PROACTIVE=1 \
bun run dev

# 配合 Token Budget 使用
FEATURE_KAIROS=1 FEATURE_TOKEN_BUDGET=1 bun run dev

六、外部依赖

  • Anthropic OAuth:必须使用 claude.ai 订阅登录(非 API key)
  • GrowthBook:服务端特性门控(tengu_ccr_bridge 等)
  • Bridge API/v1/environments/bridge 系列端点

七、文件索引

文件行数职责
src/assistant/index.ts9Assistant 模块入口(stub)
src/assistant/gate.tsGrowthBook 门控(stub)
src/assistant/sessionDiscovery.tsSession 发现(stub)
src/assistant/sessionHistory.tsSession 历史(stub)
src/assistant/AssistantSessionChooser.tsSession 选择 UI(stub)
src/tools/BriefTool/BriefTool 实现(stub)
src/tools/SleepTool/prompt.ts~30SleepTool 工具提示
src/services/mcp/channelNotification.ts5频道消息接入(stub)
src/memdir/memdir.ts记忆目录管理(stub)
src/constants/prompts.ts:552-554,843-91472系统提示注入
src/components/tasks/src/tasks/DreamTask/3Dream 任务(stub)
src/proactive/index.tsProactive 核心(stub,KAIROS 共享)