Phase 7: Built-in Hooks (audit_log, dangerous_confirmation, security_scan) Phase 8: Plugin system (PluginManager, PluginSandbox, PluginManifest) Phase 9: Skills registry (SkillRegistry, local/plugin/MCP loaders) Phase 10: TeamLeader, RemoteTransport, BackgroundTaskManager
166 lines
4.8 KiB
Markdown
166 lines
4.8 KiB
Markdown
# Phase 2:受控协作阶段(Controlled Collaboration)
|
||
|
||
日期:2026-04-03
|
||
状态:已实现基线,进入增量完善
|
||
|
||
---
|
||
|
||
## 1. 阶段目标
|
||
|
||
让 Jarvis 具备复杂请求下的**结构化协作编排能力**,而不是所有请求都走单一路由或单 agent 顺序执行。
|
||
|
||
Phase 2 的核心不是“无限协作”,而是:
|
||
|
||
- 复杂请求可切换到 `collaboration` 模式
|
||
- 请求会被拆成有 owner 的子任务
|
||
- 子任务结果会被结构化回收
|
||
- 最终输出必须经过 verifier 收尾
|
||
- Direct Mode 继续保持独立稳定
|
||
|
||
---
|
||
|
||
## 2. 当前代码中已落地的能力
|
||
|
||
当前 Jarvis 后端已经在 `backend/app/agents/graph.py` 中实现了 Phase 2 的最小闭环。
|
||
|
||
### 2.1 Mode 切换
|
||
|
||
已具备:
|
||
|
||
- `master_node()` 根据请求复杂度选择 `direct` 或 `collaboration`
|
||
- `_select_request_mode()` 会结合角色数量、多步骤信号、显式协作表达进行判断
|
||
- 简单请求保持 Direct Mode,不被协作逻辑污染
|
||
|
||
### 2.2 任务拆解
|
||
|
||
已具备:
|
||
|
||
- `_build_collaboration_tasks()` 将复杂请求拆成 2~4 个结构化子任务
|
||
- 每个 task 带有:
|
||
- `task_id`
|
||
- `role`
|
||
- `owner_agent_id`
|
||
- `goal`
|
||
- `expected_evidence`
|
||
- 父子任务关系
|
||
|
||
### 2.3 Owner 分配与执行
|
||
|
||
已具备:
|
||
|
||
- 每个 task 在构建时已有明确 owner
|
||
- `_assign_agent_for_task_role()` 将 task role 映射到具体执行角色
|
||
- `_run_collaboration_flow()` 逐个调度子任务执行
|
||
|
||
### 2.4 结果回收
|
||
|
||
已具备:
|
||
|
||
- `_collect_task_result()` 汇总单 task 的 summary / evidence / status
|
||
- `_apply_task_result_to_state()` 将结果写回 runtime state
|
||
- `task_results` / `active_tasks` / `task_hierarchy` 形成结构化回收链路
|
||
|
||
### 2.5 verifier 收尾
|
||
|
||
已具备:
|
||
|
||
- `_verify_collaboration_results()` 对协作结果做完整性验证
|
||
- 若任务缺失 / evidence 缺失 / 有失败任务,则 verifier 会给出 failed verdict
|
||
- 最终结果统一写入:
|
||
- `verification_status`
|
||
- `verification_summary`
|
||
- `verification_evidence`
|
||
|
||
---
|
||
|
||
## 3. 本次补强:Phase / Checkpoint 显式化
|
||
|
||
本次实现不是从零做 Phase 2,而是把已经存在的协作流程**显式建模**。
|
||
|
||
### 3.1 新增 runtime phase 字段
|
||
|
||
在 `backend/app/agents/state.py` 中补充:
|
||
|
||
- `current_phase`
|
||
- `phase_history`
|
||
- `current_checkpoint`
|
||
- `checkpoint_history`
|
||
|
||
初始化默认值:
|
||
|
||
- `current_phase = "phase_0_bootstrap"`
|
||
- `current_checkpoint = "bootstrap.initialized"`
|
||
|
||
### 3.2 新增 Phase 2 关键 checkpoint
|
||
|
||
在 `_run_collaboration_flow()` 中,当前已记录:
|
||
|
||
- `collaboration.tasks_planning`
|
||
- `collaboration.tasks_ready`
|
||
- `collaboration.task_dispatch`
|
||
- `collaboration.task_result_collected`
|
||
|
||
这使得 Phase 2 不再只是“逻辑存在”,而是已经具备**阶段感知和关键节点回溯能力**。
|
||
|
||
---
|
||
|
||
## 4. 当前实现对应关系
|
||
|
||
| 设计目标 | 当前状态 | 落点 |
|
||
|------|------|------|
|
||
| Mode 切换 | 已实现 | `master_node`, `_select_request_mode` |
|
||
| 任务拆解 | 已实现 | `_build_collaboration_tasks` |
|
||
| Owner 分配 | 已实现 | task schema + role assignment |
|
||
| 结果回收 | 已实现 | `task_results`, `_collect_task_result` |
|
||
| verifier 收尾 | 已实现 | `_verify_collaboration_results` |
|
||
| Phase/Checkpoint 显式化 | 已实现 | `state.py`, `graph.py` |
|
||
| 独立 Coordinator 类 | 未单独抽出 | 当前仍内嵌在 `graph.py` |
|
||
| 独立 MessageBus 实例 | 未单独抽出 | 当前以 `message_trace` 代替 |
|
||
|
||
---
|
||
|
||
## 5. 与原方案相比的调整
|
||
|
||
原文档把 Coordinator、MessageBus、Assigner 设计成独立模块;当前代码并未完全按该物理结构落地,而是采用了**先在 graph 内完成闭环,再逐步抽象模块**的路线。
|
||
|
||
因此文档需要调整为:
|
||
|
||
### 已有基线
|
||
|
||
- 结构化协作逻辑已可运行
|
||
- message trace / task trace / verifier trace 已存在
|
||
- 不需要为了“Phase 2 完成”而强行拆出新文件
|
||
|
||
### 后续可选增强
|
||
|
||
- 将 `_run_collaboration_flow()` 中的分解 / 分配 / 汇总逻辑抽成 `coordinator.py`
|
||
- 将 message trace 提升为显式 `message_bus.py`
|
||
- 将 task decomposition 策略独立为 `collaboration/decomposer.py`
|
||
|
||
---
|
||
|
||
## 6. 验收结论
|
||
|
||
当前 Phase 2 可以按“已实现基线”验收:
|
||
|
||
- [x] 复杂请求会进入协作模式
|
||
- [x] 子任务具备结构化 task schema
|
||
- [x] 每个子任务有明确 owner
|
||
- [x] 子任务结果可被统一回收
|
||
- [x] verifier 强制参与结果收尾
|
||
- [x] Direct Mode 保持独立
|
||
- [x] phase / checkpoint 已可记录
|
||
- [ ] 仍未拆成独立 coordinator/message bus 模块
|
||
|
||
---
|
||
|
||
## 7. 真实边界
|
||
|
||
当前 Phase 2 **已经不是草案**,但也还不是最终工程形态。
|
||
|
||
它目前代表的是:
|
||
|
||
> Jarvis 已经具备受控协作运行能力,并且这条协作链路已经进入“可追踪、可验证、可持续增强”的状态。
|
||
|
||
仍未完成的,只是工程层面的进一步解耦,而不是能力从 0 到 1。
|