Skip to content

架构设计

从 Tauri 窗口到 CLI 子进程,桌面端的三层通信架构。


技术栈

前端

技术版本职责
React18UI 框架
Zustand5状态管理
Vite6构建工具
Tailwind CSS4样式
Shiki4代码高亮
Mermaid11图表渲染
marked + DOMPurify-Markdown 渲染
react-diff-viewer4Diff 展示
Lucide React-图标

桌面层

技术版本职责
Tauri2跨平台桌面框架 (Rust)
tauri-plugin-shell2Sidecar 进程管理
tauri-plugin-dialog2原生对话框
tauri-plugin-process2进程生命周期
tauri-plugin-updater2自动更新

服务端

技术职责
Bun运行时 + 构建工具
Bun.serveHTTP/WebSocket 服务器

字体

  • Inter — 正文
  • Manrope — 标题
  • JetBrains Mono — 代码
  • Material Symbols Outlined — 图标

三层架构

┌─────────────────────────────────────┐
│         Tauri 主进程 (Rust)           │
│  ┌─────────────────────────────┐    │
│  │   WebView (React App)       │    │  ← 用户界面
│  └───────────┬─────────────────┘    │
│              │ HTTP + WebSocket      │
│  ┌───────────▼─────────────────┐    │
│  │   Server Sidecar (Bun)      │    │  ← API 服务 + 会话管理
│  │   Port: 动态分配             │    │
│  └───────────┬─────────────────┘    │
│              │ 子进程 spawn          │
│  ┌───────────▼─────────────────┐    │
│  │   CLI 子进程                 │    │  ← AI 对话 + 工具执行
│  └─────────────────────────────┘    │
│                                     │
│  ┌─────────────────────────────┐    │
│  │   Adapter Sidecar (可选)    │    │  ← Telegram/飞书接入
│  └─────────────────────────────┘    │
└─────────────────────────────────────┘

第一层:Tauri 主进程

职责:窗口管理、Sidecar 进程编排、原生 API 桥接

核心文件 desktop/src-tauri/src/lib.rs,暴露两个 Tauri Command:

Command说明
get_server_url前端获取 Server Sidecar 的 HTTP 地址
restart_adapters_sidecar热重启 Adapter Sidecar(修改配置后生效)

状态管理

Struct说明
ServerStateMutex<ServerStatus> — 含 server URL 和 Child 进程 handle
AdapterStateMutex<Option<CommandChild>> — adapter 子进程 handle

启动流程

  1. reserve_local_port() — 绑定 127.0.0.1:0 获取 OS 随机端口,再释放
  2. start_server_sidecar(port) — 启动 claude-sidecar server --host 127.0.0.1 --port {port}
  3. wait_for_server() — TCP 探活轮询,150ms 间隔,10s 超时
  4. WebView 加载 React 应用
  5. start_adapters_sidecar() — 启动 claude-sidecar adapters --feishu --telegram,注入 ADAPTER_SERVER_URL 环境变量

退出处理RunEvent::Exit / ExitRequested 时自动 kill 两个 sidecar。

平台差异

  • macOS:overlay titlebar + 自定义菜单(关于、设置 Cmd+,、编辑、窗口)
  • Windowsset_decorations(false) 隐藏原生标题栏,前端自定义渲染 TitleBar + WindowControls

第二层:Server Sidecar

职责:HTTP REST API + WebSocket 网关 + 会话管理 + 协议代理

核心文件 src/server/(项目根目录),分层结构:

src/server/
├── index.ts              # 入口
├── server.ts             # HTTP 服务器
├── router.ts             # 路由注册
├── sessionManager.ts     # 会话管理器
├── api/                  # REST 路由层 (14 个模块)
├── services/             # 业务服务层 (14 个模块)
├── ws/                   # WebSocket 处理
├── proxy/                # API 代理(Anthropic/OpenAI 协议转换)
├── middleware/            # auth、cors、errorHandler
└── config/               # Provider 预设

第三层:CLI 子进程

职责:AI 对话核心、工具执行、Agent 编排

Server 为每个 Session spawn 一个 CLI 子进程,通过 stdin/stdout JSON 通信。

Sidecar 构建

使用 Bun 编译为独立二进制(desktop/scripts/build-sidecars.ts):

三种模式共用一个入口 desktop/sidecars/claude-sidecar.ts

  • server — 启动 HTTP/WS 服务
  • cli — 启动 CLI 子进程
  • adapters — 启动 IM 适配器(解析 --feishu/--telegram 参数,检查凭据后按需加载)

编译产物放置在 desktop/src-tauri/binaries/,Tauri 打包时自动包含。


WebSocket 通信协议

连接地址

ws://127.0.0.1:{port}/ws/{sessionId}

前端通过 WebSocketManager(per-session 连接)管理,支持自动重连、消息队列缓冲、ping 心跳保活。

客户端 → 服务端

type说明
user_message用户消息(含 content, attachments)
permission_response权限审批(requestId, allowed, rule)
set_permission_mode切换权限模式
stop_generation停止生成
ping心跳

服务端 → 客户端

type说明
connected连接成功
status状态变更(thinking/generating)
content_start / content_delta流式文本
thinkingExtended Thinking
tool_use_complete工具调用就绪
tool_result工具执行结果
permission_request权限请求
message_complete消息完成(含 Token 统计)
error错误通知
session_title_updated标题更新
team_update / team_created / team_deleted团队事件
task_update任务变更
pong心跳响应

连接管理

  • 心跳:30s 间隔 ping/pong
  • 重连:指数退避 min(1000ms × 2^n, 30000ms),最多 10 次
  • 缓冲:未连接时消息暂存队列,恢复后自动发送

HTTP API

会话

方法端点说明
GET/api/sessions列表(支持 project/limit/offset 筛选)
POST/api/sessions创建
GET/api/sessions/:id/messages历史消息
PATCH/api/sessions/:id重命名
DELETE/api/sessions/:id删除
GET/api/sessions/:id/git-infoGit 信息
GET/api/sessions/:id/slash-commands可用斜杠命令
GET/api/sessions/recent-projects最近项目

模型与提供商

方法端点说明
GET/PUT/api/models/current当前模型
GET/api/models可用模型列表
GET/PUT/api/effortEffort 级别
GET/POST/PUT/DELETE/api/providers提供商 CRUD
POST/api/providers/:id/activate激活
POST/api/providers/:id/test测试连接
GET/api/providers/presets预设列表

定时任务

方法端点说明
GET/POST/PUT/DELETE/api/scheduled-tasks任务 CRUD
POST/api/scheduled-tasks/:id/run手动运行
GET/api/scheduled-tasks/runs运行记录

其他

方法端点说明
GET/api/teamsAgent 团队
GET/api/teams/:name/members/:agentId/transcript成员转录
GET/api/agentsAgent 定义
GET/api/skills技能列表
GET/PUT/api/adapters适配器配置
GET/PUT/api/settings/user用户设置
GET/PUT/api/permissions/mode权限模式
GET/api/tasks/listsCLI 任务清单
GET/health健康检查

状态管理

使用 Zustand,按领域拆分为 12 个 Store:

Store核心状态
chatStoreper-session 消息、流式状态、权限请求、Token 统计
sessionStore会话列表、activeSessionId、项目筛选
tabStore标签页顺序(localStorage 持久化)
settingsStore权限模式、当前模型、effort、语言
providerStoreProvider 列表、activeId
uiStore主题、侧边栏、activeView、Toast、设置标签页
taskStore定时任务、运行记录
teamStore团队列表、成员转录轮询
agentStoreAgent 定义列表
skillStore技能元数据、详情
adapterStore适配器配置、配对码
cliTaskStoreper-session CLI 任务追踪

数据流

用户操作 → Component → Store → API/WebSocket → Server → Store → Component 重渲染

持久化

数据存储
标签页状态localStorage
语言偏好localStorage
会话数据Server JSONL (~/.claude/sessions/)
设置Server API
适配器配置~/.claude/adapters.json

协议代理层

Server 内置代理层(src/server/proxy/),统一不同 AI 提供商的 API 格式。

支持格式

格式典型提供商
anthropicAnthropic、OpenRouter、MiniMax
openai_chatOpenAI、DeepSeek、Ollama
openai_responsesOpenAI Responses API

模型映射

每个 Provider 配置 4 个模型槽位:mainhaikusonnetopus,前端按槽位名调用,代理层自动映射为实际模型名。


适配器架构

适配器系统让 Telegram/飞书等 IM 平台接入 Claude Code。

IM 平台 → Adapter 进程 → HTTP + WebSocket → Server → CLI

共享模块 adapters/common/

模块职责
config.ts配置加载(env > JSON > 默认值)
ws-bridge.tsWebSocket 桥接(心跳、重连、消息路由)
pairing.ts用户配对(6 位安全码、速率限制)
session-store.tsChat → Session 映射持久化
message-buffer.ts流式缓冲(500ms / 200 字符阈值)
message-dedup.ts消息去重
chat-queue.ts同一 Chat 消息串行队列
http-client.tsHTTP 客户端

分片限制

  • Telegram: 4000 字符/消息
  • 飞书: 30000 字符/消息

项目目录结构

desktop/
├── src/                              # React 前端
│   ├── api/                         #   API 客户端 (15 个模块)
│   ├── components/
│   │   ├── layout/                  #   AppShell, Sidebar, TabBar, TitleBar,
│   │   │                            #   WindowControls, StatusBar, ContentRouter,
│   │   │                            #   ProjectFilter
│   │   ├── chat/                    #   ChatInput, MessageList, AssistantMessage,
│   │   │                            #   ToolCallBlock, ToolCallGroup, ThinkingBlock,
│   │   │                            #   PermissionDialog, CodeViewer, DiffViewer,
│   │   │                            #   ImageGalleryModal, StreamingIndicator ...
│   │   ├── shared/                  #   Button, Modal, Toast, Spinner,
│   │   │                            #   UpdateChecker, DirectoryPicker ...
│   │   ├── controls/                #   ModelSelector, PermissionModeSelector
│   │   ├── markdown/                #   MarkdownRenderer, MermaidRenderer
│   │   ├── skills/                  #   SkillList, SkillDetail
│   │   ├── tasks/                   #   TaskList, TaskRow, NewTaskModal,
│   │   │                            #   DayOfWeekPicker, PromptEditor ...
│   │   └── teams/                   #   TeamStatusBar
│   ├── pages/                       #   ActiveSession, EmptySession, Settings,
│   │                                #   AdapterSettings, AgentTeams, ScheduledTasks,
│   │                                #   ComputerUseSettings, ToolInspection ...
│   ├── stores/                      #   12 个 Zustand store
│   ├── types/                       #   TypeScript 类型 (9 个模块)
│   ├── hooks/                       #   useKeyboardShortcuts
│   ├── i18n/                        #   中/英 国际化
│   ├── config/                      #   providerPresets, spinnerVerbs
│   └── lib/                         #   desktopRuntime, cronDescribe, parseRunOutput
├── src-tauri/
│   ├── src/main.rs                  #   入口
│   ├── src/lib.rs                   #   核心(~415 行)
│   ├── Cargo.toml
│   └── tauri.conf.json
├── sidecars/
│   └── claude-sidecar.ts            #   统一入口 (server/cli/adapters)
└── scripts/
    ├── build-sidecars.ts
    ├── build-macos-arm64.sh
    └── build-windows-x64.ps1

src/server/                           # 服务端(项目根目录)
├── api/                             #   REST 路由 (14 个模块)
├── services/                        #   业务服务 (14 个模块)
├── ws/                              #   WebSocket 处理
├── proxy/                           #   协议代理转换
├── middleware/                      #   auth, cors, errorHandler
└── config/                          #   Provider 预设

adapters/                             # IM 适配器
├── common/                          #   共享模块 (8 个)
├── telegram/                        #   Telegram Bot
└── feishu/                          #   飞书 Bot

Released under the MIT License.