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
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/。
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)
src/lib/channels/ — 结构化渠道插件,提供 ChannelPlugin<T> 合约。
types.ts—ChannelPlugin/ChannelCapabilities/ProbeResult/CardStreamController接口channel-plugin-adapter.ts— Plugin →BaseChannelAdapter桥接适配器feishu/— 飞书渠道插件(模块化拆分)types.ts— 飞书内部类型常量config.ts—FeishuConfig结构化配置 + 校验gateway.ts— WSClient 生命周期 + 连接状态机 + probeinbound.ts— 入站消息处理 + 资源下载outbound.ts— 出站消息渲染(card/post/permission)identity.ts— Bot 身份解析 + @mention 检测policy.ts— 访问控制 + 群策略card-controller.ts— CardStreamController 接口 + 占位index.ts—FeishuChannelPlugin入口
src/lib/remote/ — 远程 Host/Controller/Session/Lease 合约(接口 + 骨架)。
types.ts—RemoteHost/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 (单元) |