Skip to content

Latest commit

 

History

History
182 lines (154 loc) · 8.17 KB

File metadata and controls

182 lines (154 loc) · 8.17 KB

ARCHITECTURE.md

CodePilot 是 Claude Code 的桌面 GUI 客户端。Electron 40 做外壳,Next.js 16 (App Router) 做前端和 API 层,better-sqlite3 做本地持久化,通过 Claude Agent SDK 与 Claude 交互。

目录结构

src/
├── app/            # Next.js App Router — 页面 + API 路由
│   ├── api/        #   52 个 REST 端点(chat, media, files, plugins, settings …)
│   ├── chat/       #   聊天页(主界面)
│   ├── plugins/    #   插件 / MCP 管理
│   ├── settings/   #   应用设置
│   ├── bridge/     #   IM Bridge 设置
│   ├── gallery/    #   图片画廊
│   └── …
├── components/     # React 组件(按功能分目录)
│   ├── ui/         #   Radix 基础组件 (Button, Dialog, Tabs …)
│   ├── chat/       #   聊天界面 (MessageList, CodeBlock, ImageThumbnail …)
│   ├── ai-elements/#   AI 响应渲染 (artifact, reasoning, tool, task …)
│   ├── layout/     #   布局 (AppShell, Header, NavRail, ChatListPanel …)
│   ├── plugins/    #   插件管理 UI
│   ├── settings/   #   设置面板
│   ├── bridge/     #   Bridge 设置 UI
│   ├── skills/     #   技能市场
│   ├── project/    #   项目文件树
│   └── gallery/    #   画廊视图
├── lib/            # 核心业务逻辑
│   ├── db.ts               # SQLite 数据库(schema 定义 + CRUD)
│   ├── claude-client.ts    # Claude Agent SDK 封装、消息流
│   ├── stream-session-manager.ts  # SSE 流生命周期管理
│   ├── conversation-registry.ts   # 活跃 SDK 会话全局注册
│   ├── image-generator.ts  # Gemini/Anthropic 图片生成
│   ├── job-executor.ts     # 批量图片生成任务执行器
│   ├── files.ts            # 文件系统浏览和预览
│   ├── claude-session-parser.ts   # 解析 Claude CLI .jsonl 会话
│   ├── platform.ts         # 平台检测 (macOS/Windows/Linux)
│   ├── error-classifier.ts # 错误分类(16 类结构化错误)
│   ├── provider-doctor.ts  # Provider 诊断引擎(5 探针 + 修复动作)
│   ├── runtime-log.ts      # console 环形缓冲(200 条,自动脱敏)
│   └── bridge/             # IM Bridge 子系统(见下方)
├── hooks/          # React Hooks (useSSEStream, useImageGen, useTranslation …)
├── types/          # TypeScript 类型
│   ├── index.ts            # 所有业务类型 (ChatSession, Message, MCPServerConfig …)
│   └── electron.d.ts       # Electron contextBridge API 类型
└── i18n/           # 国际化
    ├── en.ts               # 英文
    └── zh.ts               # 中文

electron/
├── main.ts         # Electron 主进程(窗口、IPC、Utility Process)
└── preload.ts      # contextBridge 暴露(install API, updater API)

数据流

用户输入 → MessageInput 组件
         → POST /api/chat/messages
         → claude-client.ts(创建 SDK conversation)
         → Claude Agent SDK SSE 流
         → stream-session-manager.ts 管理流
         → useSSEStream hook 订阅
         → MessageList 渲染
         → db.ts 持久化到 SQLite

Bridge 数据流(远程 IM 控制):

Telegram/Feishu 消息
  → Adapter 长轮询/WebSocket 接收
  → channelRouter 路由到 CodePilot session
  → conversationEngine 调用 SDK
  → SDK SSE 响应
  → deliveryLayer 格式化 + 分片
  → Adapter 发送回 IM

数据库(SQLite)

Schema 定义在 src/lib/db.ts,12 张表:

用途
chat_sessions 聊天会话元数据
messages 消息(content 为 JSON 数组)
settings 键值设置
tasks SDK TodoWrite 任务项
api_providers API 提供商配置(Anthropic, OpenAI …)
media_generations 生成的图片/媒体
media_tags 媒体标签
media_jobs 批量图片生成任务
media_job_items 批量任务中的单个项
media_context_events 批量任务上下文同步
channel_bindings Bridge: IM 频道 → CodePilot 会话绑定
channel_offsets Bridge: 轮询偏移量水位线

启用 WAL 模式 + 外键约束。数据目录:~/.codepilot/

Bridge 子系统

src/lib/bridge/ — 将外部 IM(Telegram、飞书)连接到 CodePilot 会话。

核心组件:

  • channel-adapter.ts — 适配器抽象基类 + 注册工厂
  • channel-router.ts — 消息路由(IM → session)
  • conversation-engine.ts — 消费 SSE 流、保存消息
  • permission-broker.ts — 权限请求转为 IM 内联按钮
  • delivery-layer.ts — 消息分片、速率限制、HTML 降级
  • bridge-manager.ts — 生命周期编排
  • markdown/ — Markdown → IR → 渠道特定格式(Telegram HTML / 飞书卡片)
  • adapters/telegram-adapter.ts — Telegram 长轮询
  • adapters/feishu-adapter.ts — 飞书薄代理(委托给 Channel Plugin)

Channel Plugin 层

src/lib/channels/ — 结构化渠道插件,提供 ChannelPlugin<T> 合约。

  • types.tsChannelPlugin/ChannelCapabilities/ProbeResult/CardStreamController 接口
  • channel-plugin-adapter.ts — Plugin → BaseChannelAdapter 桥接适配器
  • feishu/ — 飞书渠道插件(模块化拆分)
    • types.ts — 飞书内部类型常量
    • config.tsFeishuConfig 结构化配置 + 校验
    • gateway.ts — WSClient 生命周期 + 连接状态机 + probe
    • inbound.ts — 入站消息处理 + 资源下载
    • outbound.ts — 出站消息渲染(card/post/permission)
    • identity.ts — Bot 身份解析 + @mention 检测
    • policy.ts — 访问控制 + 群策略
    • card-controller.ts — CardStreamController 接口 + 占位
    • index.tsFeishuChannelPlugin 入口

Remote Core 层

src/lib/remote/ — 远程 Host/Controller/Session/Lease 合约(接口 + 骨架)。

  • types.tsRemoteHost/RemoteController/SessionLease/RemoteEvent 接口
  • remote-manager.ts — 轻量运行时骨架
  • index.ts — 公开导出

详细文档:docs/handover/bridge-system.md

新增功能标准触及点

添加新功能时通常需要修改以下位置:

触及点 路径 说明
类型定义 src/types/index.ts 新增接口/类型
数据库 src/lib/db.ts 新增表或字段(含迁移逻辑)
API 路由 src/app/api/{功能名}/route.ts 新增 REST 端点
页面 src/app/{功能名}/page.tsx 新增路由页面
组件 src/components/{功能名}/ UI 组件
Hook src/hooks/use{功能名}.ts 状态管理 Hook
国际化 src/i18n/en.ts + zh.ts 双语翻译键
Bridge src/lib/bridge/adapters/ + types.ts 如涉及 IM 集成

关键文档索引

文档 路径 内容
Bridge 系统 docs/handover/bridge-system.md 架构、适配器、渲染管线
Agent 工具集成 docs/handover/agent-tooling-todo-bridge.md SDK 工具调用、任务桥接
SDK 集成调研 docs/research/chat-sdk-integration-feasibility.md Chat SDK 可行性分析
上下文存储迁移(调研) docs/research/context-storage-migration-plan.md 数据库迁移详细方案
上下文存储迁移(执行) docs/exec-plans/active/context-storage-migration.md 分阶段进度 + 决策日志
技术债务 docs/exec-plans/tech-debt-tracker.md 已知技术债务清单
Provider/Error/Doctor docs/handover/provider-error-doctor.md 错误分类、Provider 生效、Auth 自动、诊断中心

技术栈

技术
桌面外壳 Electron 40
前端框架 Next.js 16 (App Router) + React 19
样式 Tailwind CSS 4 + Radix UI
数据库 better-sqlite3 (WAL)
AI 集成 Claude Agent SDK, @ai-sdk/anthropic, @ai-sdk/google, @ai-sdk/openai
IM 集成 Telegram Bot API, 飞书 SDK (@larksuiteoapi/node-sdk)
代码高亮 Shiki
Markdown react-markdown, streamdown, markdown-it
打包 electron-builder (DMG + NSIS)
测试 Playwright (E2E), tsx + node:test (单元)