2.1 KiB
2.1 KiB
2026-03-14 Codex External Cooperative Mode
目标
按 external-first 顺序完成 XWorkmate 的 Code Agent 集成:
- 先交付外部 Codex CLI 协同模式
- 同时保留其他外部 CLI 的统一接入 contract
- 内置 Codex / Rust FFI 延后
范围
包含
SettingsSnapshot.codeAgentRuntimeModeSettingsSnapshot.codexCliPath- Codex bridge control panel
- 外部 Codex CLI 显式启停
- AI Gateway 配置导出 / 写入
- OpenClaw
agent/register协同注册 chat.send的 app-mediated node metadata- Gateway 不可用时的本地降级
不包含
- 自动开机启动 bridge
- 其他 provider 的选择 UI
- 任务写接口
- 记忆 CRUD
- Rust FFI 实现
关键实现点
设置与状态
builtIn保留在运行时枚举中,作为 experimental 选项可见但不作为稳定交付承诺codexCliPath与cliPath分离:codexCliPath仅用于 Codex CLIcliPath继续用于 OpenClaw/bootstrap CLI
Bridge 顺序
- 校验 AI Gateway URL 和 Codex binary
- 调用
configureCodexForGateway() - 启动外部 Codex CLI
- 通过
CodeAgentNodeOrchestrator生成 App node dispatch metadata - Gateway 已连接时执行
agent/register
协同 metadata
providerId = codexruntimeMode = externalClitransport = stdio-bridge- capabilities:
chatcode-editgateway-bridgememory-sync
涉及文件
lib/runtime/runtime_models.dartlib/runtime/runtime_coordinator.dartlib/runtime/code_agent_node_orchestrator.dartlib/runtime/agent_registry.dartlib/app/app_controller.dartlib/features/ai_gateway/ai_gateway_page.dartlib/features/tasks/tasks_page.dart
验收
自动化
SettingsSnapshot序列化测试RuntimeCoordinator外部 / built-in 行为测试AgentRegistrytransport metadata 测试AppController.enableCodexBridge()协同注册与降级测试- Tasks Scheduled 只读 widget test
人工
- 已安装
codex且 AI Gateway 已配置 - Gateway 在线时检查一次
agent/register - Gateway 离线时检查 bridgeOnly 降级
- UI 中 Built-in 始终显示为 experimental