diff --git a/docs/architecture/README.md b/docs/architecture/README.md
new file mode 100644
index 0000000..ff4f881
--- /dev/null
+++ b/docs/architecture/README.md
@@ -0,0 +1,54 @@
+# MCP Feedback Enhanced 架構文檔
+
+## 📋 文檔索引
+
+本目錄包含 MCP Feedback Enhanced 專案的完整架構文檔,提供深入的技術分析和設計說明。
+
+### 📚 文檔結構
+
+| 文檔 | 描述 | 適用對象 |
+|------|------|----------|
+| [系統架構總覽](./system-overview.md) | 整體架構設計、核心概念和技術亮點 | 架構師、技術負責人 |
+| [組件詳細說明](./component-details.md) | 各層級組件的詳細功能和實現 | 開發人員、維護人員 |
+| [交互流程文檔](./interaction-flows.md) | AI 助手與 MCP 服務的完整交互流程 | 集成開發人員 |
+| [API 參考文檔](./api-reference.md) | MCP 工具接口和 WebSocket API 規範 | API 使用者、前端開發 |
+| [部署指南](./deployment-guide.md) | 環境配置、部署選項和故障排除 | 運維人員、系統管理員 |
+
+### 🏗️ 架構概覽
+
+MCP Feedback Enhanced 採用**單一活躍會話 + 持久化 Web UI**的創新架構,實現了 AI 助手與用戶之間的無縫交互體驗。
+
+#### 核心特性
+- **智能環境檢測**: 自動識別 Local/SSH Remote/WSL 環境
+- **單一活躍會話**: 替代傳統多會話管理,提升性能和用戶體驗
+- **持久化 Web UI**: 支援多次循環調用,無需重複開啟瀏覽器
+- **實時雙向通信**: WebSocket 實現前後端狀態同步
+- **智能資源管理**: 自動清理和會話生命週期管理
+
+#### 技術棧
+- **後端**: Python 3.11+, FastAPI, FastMCP
+- **前端**: HTML5, JavaScript ES6+, WebSocket
+- **通信**: WebSocket, HTTP REST API
+- **部署**: uvicorn, 跨平台支援
+
+### 🎯 快速導航
+
+- **新手入門**: 從 [系統架構總覽](./system-overview.md) 開始
+- **深入理解**: 閱讀 [組件詳細說明](./component-details.md)
+- **集成開發**: 參考 [交互流程文檔](./interaction-flows.md) 和 [API 參考文檔](./api-reference.md)
+- **部署運維**: 查看 [部署指南](./deployment-guide.md)
+
+### 📊 架構圖表
+
+所有文檔都包含豐富的 Mermaid 圖表,包括:
+- 系統整體架構圖
+- 組件關係圖
+- 交互流程圖
+- 會話生命週期圖
+- 部署拓撲圖
+
+---
+
+**版本**: 2.3.0
+**最後更新**: 2024年12月
+**維護者**: Minidoracat
diff --git a/docs/architecture/api-reference.md b/docs/architecture/api-reference.md
new file mode 100644
index 0000000..aa8430e
--- /dev/null
+++ b/docs/architecture/api-reference.md
@@ -0,0 +1,341 @@
+# API 參考文檔
+
+## 📡 MCP 工具 API
+
+### interactive_feedback
+
+AI 助手與用戶進行交互式回饋的核心 MCP 工具。
+
+#### 函數簽名
+```python
+async def interactive_feedback(
+ project_directory: str,
+ summary: str,
+ timeout: int = 600
+) -> dict
+```
+
+#### 參數說明
+
+| 參數 | 類型 | 必需 | 預設值 | 描述 |
+|------|------|------|--------|------|
+| `project_directory` | `str` | ✅ | - | 專案目錄路徑,用於上下文顯示 |
+| `summary` | `str` | ✅ | - | AI 助手的工作摘要,向用戶說明當前狀態 |
+| `timeout` | `int` | ❌ | `600` | 等待用戶回饋的超時時間(秒) |
+
+#### 返回值
+```python
+{
+ "command_logs": "", # 命令執行日誌(保留字段)
+ "interactive_feedback": str, # 用戶回饋內容
+ "images": List[str] # 用戶上傳的圖片(Base64 編碼)
+}
+```
+
+#### 使用示例
+```python
+# 基本調用
+result = await interactive_feedback(
+ project_directory="./my-web-app",
+ summary="我已完成登入功能的實現,包括表單驗證和錯誤處理。請檢查代碼品質。"
+)
+
+# 自定義超時
+result = await interactive_feedback(
+ project_directory="./complex-project",
+ summary="重構完成,請詳細測試所有功能模組。",
+ timeout=1200 # 20分鐘
+)
+```
+
+#### 錯誤處理
+```python
+try:
+ result = await interactive_feedback(...)
+except TimeoutError:
+ print("用戶回饋超時")
+except ValidationError as e:
+ print(f"參數驗證錯誤: {e}")
+except EnvironmentError as e:
+ print(f"環境檢測錯誤: {e}")
+```
+
+## 🌐 Web API
+
+### HTTP 端點
+
+#### GET /
+主頁重定向到回饋頁面。
+
+**響應**: `302 Redirect` → `/feedback`
+
+#### GET /feedback
+回饋頁面主入口。
+
+**響應**: `200 OK`
+```html
+
+
+
+
+```
+
+#### GET /static/{path}
+靜態資源服務(CSS、JS、圖片等)。
+
+**參數**:
+- `path`: 靜態資源路徑
+
+**響應**: `200 OK` 或 `404 Not Found`
+
+### WebSocket API
+
+#### 連接端點
+```
+ws://localhost:{port}/ws
+```
+
+#### 訊息格式
+所有 WebSocket 訊息都使用 JSON 格式:
+```json
+{
+ "type": "message_type",
+ "data": { /* 訊息數據 */ },
+ "timestamp": "2024-12-XX 10:30:00"
+}
+```
+
+### 📤 客戶端 → 服務器訊息
+
+#### submit_feedback
+提交用戶回饋。
+
+```json
+{
+ "type": "submit_feedback",
+ "data": {
+ "feedback": "這個功能很好,但建議增加輸入驗證。",
+ "images": [
+ "..."
+ ],
+ "settings": {
+ "language": "zh-TW",
+ "compress_images": true
+ }
+ }
+}
+```
+
+**字段說明**:
+- `feedback`: 用戶回饋文字內容
+- `images`: 圖片數組(Base64 編碼)
+- `settings.language`: 界面語言
+- `settings.compress_images`: 是否壓縮圖片
+
+#### heartbeat
+心跳檢測訊息。
+
+```json
+{
+ "type": "heartbeat",
+ "data": {
+ "timestamp": 1703123456789
+ }
+}
+```
+
+#### language_switch
+切換界面語言。
+
+```json
+{
+ "type": "language_switch",
+ "data": {
+ "language": "en"
+ }
+}
+```
+
+### 📥 服務器 → 客戶端訊息
+
+#### connection_established
+WebSocket 連接建立確認。
+
+```json
+{
+ "type": "connection_established",
+ "data": {
+ "session_id": "550e8400-e29b-41d4-a716-446655440000",
+ "server_time": "2024-12-XX 10:30:00"
+ }
+}
+```
+
+#### session_updated
+會話更新通知(AI 再次調用時)。
+
+```json
+{
+ "type": "session_updated",
+ "data": {
+ "session_id": "new-session-id",
+ "summary": "根據您的建議,我已修改了錯誤處理邏輯。",
+ "project_directory": "./my-project",
+ "timestamp": "2024-12-XX 10:35:00"
+ }
+}
+```
+
+#### feedback_received
+回饋接收確認。
+
+```json
+{
+ "type": "feedback_received",
+ "data": {
+ "session_id": "session-id",
+ "status": "success",
+ "message": "回饋已成功接收"
+ }
+}
+```
+
+#### status_update
+狀態更新通知。
+
+```json
+{
+ "type": "status_update",
+ "data": {
+ "status": "FEEDBACK_PROCESSING",
+ "message": "正在處理您的回饋...",
+ "progress": 50
+ }
+}
+```
+
+#### error
+錯誤訊息。
+
+```json
+{
+ "type": "error",
+ "data": {
+ "error_code": "VALIDATION_ERROR",
+ "message": "回饋內容不能為空",
+ "details": {
+ "field": "feedback",
+ "value": ""
+ }
+ }
+}
+```
+
+## 🔧 內部 API
+
+### WebUIManager API
+
+#### create_session()
+```python
+async def create_session(
+ self,
+ summary: str,
+ project_directory: str
+) -> WebFeedbackSession
+```
+
+創建新的回饋會話。
+
+#### smart_open_browser()
+```python
+async def smart_open_browser(self, url: str) -> bool
+```
+
+智能開啟瀏覽器,避免重複開啟。
+
+**返回值**:
+- `True`: 檢測到活躍標籤頁,未開啟新視窗
+- `False`: 開啟了新瀏覽器視窗
+
+### WebFeedbackSession API
+
+#### submit_feedback()
+```python
+async def submit_feedback(
+ self,
+ feedback: str,
+ images: List[str],
+ settings: dict
+) -> None
+```
+
+提交用戶回饋到會話。
+
+#### wait_for_feedback()
+```python
+async def wait_for_feedback(self, timeout: int = 600) -> dict
+```
+
+等待用戶回饋完成。
+
+#### add_websocket()
+```python
+def add_websocket(self, websocket: WebSocket) -> None
+```
+
+添加 WebSocket 連接到會話。
+
+## 📊 狀態碼和錯誤碼
+
+### HTTP 狀態碼
+- `200 OK`: 請求成功
+- `302 Found`: 重定向
+- `404 Not Found`: 資源不存在
+- `500 Internal Server Error`: 服務器內部錯誤
+
+### WebSocket 錯誤碼
+```python
+class ErrorCodes:
+ VALIDATION_ERROR = "VALIDATION_ERROR"
+ SESSION_NOT_FOUND = "SESSION_NOT_FOUND"
+ TIMEOUT_ERROR = "TIMEOUT_ERROR"
+ PROCESSING_ERROR = "PROCESSING_ERROR"
+ CONNECTION_ERROR = "CONNECTION_ERROR"
+```
+
+### 會話狀態
+```python
+class SessionStatus:
+ WAITING = "FEEDBACK_WAITING"
+ PROCESSING = "FEEDBACK_PROCESSING"
+ SUBMITTED = "FEEDBACK_SUBMITTED"
+ ERROR = "ERROR"
+```
+
+## 🔒 安全考慮
+
+### 輸入驗證
+- 回饋內容長度限制:最大 10,000 字符
+- 圖片大小限制:單張最大 5MB
+- 圖片數量限制:最多 10 張
+- 支援的圖片格式:PNG, JPEG, GIF, WebP
+
+### 資源保護
+- WebSocket 連接數限制:每會話最多 5 個連接
+- 會話超時自動清理
+- 內存使用監控和限制
+
+### 跨域設置
+```python
+app.add_middleware(
+ CORSMiddleware,
+ allow_origins=["*"], # 開發環境,生產環境應限制
+ allow_credentials=True,
+ allow_methods=["*"],
+ allow_headers=["*"],
+)
+```
+
+---
+
+**下一步**: 查看 [部署指南](./deployment-guide.md) 了解部署配置和運維指南
diff --git a/docs/architecture/component-details.md b/docs/architecture/component-details.md
new file mode 100644
index 0000000..94e10f8
--- /dev/null
+++ b/docs/architecture/component-details.md
@@ -0,0 +1,285 @@
+# 組件詳細說明
+
+## 🏗️ 四層架構組件
+
+MCP Feedback Enhanced 採用清晰的四層架構設計,每層負責特定的功能領域。
+
+### 組件關係圖
+
+```mermaid
+graph TB
+ subgraph "第一層:MCP 服務層"
+ SERVER[server.py
MCP 服務器]
+ TOOL[interactive_feedback
核心工具]
+ I18N[i18n.py
國際化支援]
+ end
+
+ subgraph "第二層:Web UI 管理層"
+ MANAGER[WebUIManager
單例管理器]
+ SESSION[WebFeedbackSession
會話模型]
+ RESULT[FeedbackResult
結果模型]
+ end
+
+ subgraph "第三層:Web 服務層"
+ MAIN[main.py
FastAPI 應用]
+ ROUTES[main_routes.py
路由處理]
+ WS[WebSocket
實時通信]
+ end
+
+ subgraph "第四層:前端交互層"
+ HTML[feedback.html
主頁面]
+ JS[app.js
交互邏輯]
+ CSS[樣式文件]
+ end
+
+ subgraph "工具層"
+ BROWSER[browser.py
瀏覽器控制]
+ NETWORK[network.py
網路工具]
+ PORT[port_manager.py
埠管理]
+ CLEANUP[session_cleanup_manager.py
清理管理]
+ COMPRESS[compression_*.py
壓縮工具]
+ end
+
+ SERVER --> MANAGER
+ TOOL --> SESSION
+ MANAGER --> MAIN
+ SESSION --> ROUTES
+ ROUTES --> HTML
+ HTML --> JS
+
+ BROWSER --> MANAGER
+ NETWORK --> MAIN
+ PORT --> MAIN
+ CLEANUP --> SESSION
+ COMPRESS --> ROUTES
+```
+
+## 🔧 第一層:MCP 服務層
+
+### server.py - MCP 服務器核心
+```python
+# 核心功能架構
+class MCPServer:
+ def __init__(self):
+ self.app = FastMCP("mcp-feedback-enhanced")
+ self.setup_tools()
+
+ @self.app.tool()
+ async def interactive_feedback(
+ project_directory: str,
+ summary: str,
+ timeout: int = 600
+ ) -> dict:
+ # 環境檢測與驗證
+ # Web UI 啟動
+ # 會話管理
+ # 回饋等待與處理
+```
+
+**主要職責**:
+- MCP 協議實現和工具註冊
+- 環境檢測 (Local/SSH/WSL)
+- Web UI 生命週期管理
+- 與 AI 助手的接口層
+
+### interactive_feedback 工具
+```mermaid
+flowchart TD
+ START[工具調用] --> VALIDATE[參數驗證]
+ VALIDATE --> ENV[環境檢測]
+ ENV --> LAUNCH[啟動 Web UI]
+ LAUNCH --> SESSION[創建/更新會話]
+ SESSION --> WAIT[等待用戶回饋]
+ WAIT --> TIMEOUT{超時檢查}
+ TIMEOUT -->|未超時| FEEDBACK[接收回饋]
+ TIMEOUT -->|超時| ERROR[超時錯誤]
+ FEEDBACK --> RETURN[返回結果]
+ ERROR --> RETURN
+```
+
+### i18n.py - 國際化支援
+- **多語言支援**: 繁體中文、簡體中文、英文
+- **動態語言切換**: 基於用戶偏好自動選擇
+- **模組化翻譯**: 分離的語言包管理
+
+## 🎛️ 第二層:Web UI 管理層
+
+### WebUIManager - 核心管理器
+```python
+class WebUIManager:
+ def __init__(self):
+ self.current_session: Optional[WebFeedbackSession] = None
+ self.global_active_tabs: Dict[str, dict] = {}
+ self.app: Optional[FastAPI] = None
+ self.server_process: Optional[subprocess.Popen] = None
+```
+
+**關鍵特性**:
+- **單例模式**: 確保全局唯一實例
+- **會話生命週期**: 創建、更新、清理會話
+- **智能瀏覽器開啟**: 避免重複開啟視窗
+- **資源管理**: 自動清理和錯誤處理
+
+### WebFeedbackSession - 會話模型
+```mermaid
+stateDiagram-v2
+ [*] --> WAITING: 會話創建
+ WAITING --> FEEDBACK_PROCESSING: 用戶提交
+ FEEDBACK_PROCESSING --> FEEDBACK_SUBMITTED: 處理完成
+ FEEDBACK_SUBMITTED --> WAITING: 新會話更新
+ FEEDBACK_SUBMITTED --> [*]: 會話結束
+
+ note right of WAITING
+ 等待用戶輸入
+ 顯示 AI 摘要
+ end note
+
+ note right of FEEDBACK_PROCESSING
+ 處理回饋數據
+ 圖片壓縮等
+ end note
+```
+
+**狀態管理**:
+- `WAITING`: 等待用戶回饋
+- `FEEDBACK_PROCESSING`: 處理回饋中
+- `FEEDBACK_SUBMITTED`: 回饋已提交
+
+## 🌐 第三層:Web 服務層
+
+### main.py - FastAPI 應用
+```python
+class FastAPIApp:
+ def __init__(self):
+ self.app = FastAPI()
+ self.setup_middleware()
+ self.setup_routes()
+ self.setup_websocket()
+
+ def setup_middleware(self):
+ # CORS 設定
+ # 靜態文件服務
+ # 錯誤處理中間件
+```
+
+**核心功能**:
+- HTTP 路由處理
+- WebSocket 連接管理
+- 靜態資源服務
+- 中間件配置
+
+### main_routes.py - 路由處理
+```mermaid
+graph LR
+ subgraph "HTTP 路由"
+ GET[GET /]
+ FEEDBACK[GET /feedback]
+ STATIC[靜態資源]
+ end
+
+ subgraph "WebSocket 路由"
+ WS[/ws]
+ MSG[訊息處理]
+ BROADCAST[廣播機制]
+ end
+
+ GET --> FEEDBACK
+ FEEDBACK --> STATIC
+ WS --> MSG
+ MSG --> BROADCAST
+```
+
+**WebSocket 訊息類型**:
+- `connection_established`: 連接建立
+- `session_updated`: 會話更新
+- `submit_feedback`: 提交回饋
+- `feedback_received`: 回饋確認
+- `status_update`: 狀態更新
+
+## 🎨 第四層:前端交互層
+
+### feedback.html - 主頁面
+```html
+
+
+
+
+
+
+
+
+
+
+```
+
+### app.js - 交互邏輯
+```javascript
+class FeedbackApp {
+ constructor() {
+ this.websocket = null;
+ this.currentSession = null;
+ this.feedbackState = 'WAITING';
+ }
+
+ // WebSocket 管理
+ initWebSocket() { /* ... */ }
+ handleWebSocketMessage(data) { /* ... */ }
+
+ // 用戶交互
+ submitFeedback() { /* ... */ }
+ handleImageUpload() { /* ... */ }
+
+ // UI 更新
+ updateSessionDisplay() { /* ... */ }
+ updateFeedbackState() { /* ... */ }
+}
+```
+
+**前端特性**:
+- **響應式設計**: 適配不同螢幕尺寸
+- **實時狀態同步**: WebSocket 雙向通信
+- **圖片上傳**: 拖拽上傳和自動壓縮
+- **多語言支援**: 動態語言切換
+
+## 🛠️ 工具層組件
+
+### browser.py - 瀏覽器控制
+```python
+class BrowserManager:
+ @staticmethod
+ def open_browser(url: str, environment: str):
+ if environment == "local":
+ webbrowser.open(url)
+ elif environment == "ssh":
+ # SSH 隧道處理
+ elif environment == "wsl":
+ # WSL 特殊處理
+```
+
+### port_manager.py - 埠管理
+- **動態埠分配**: 自動尋找可用埠
+- **埠衝突檢測**: 避免埠佔用問題
+- **埠範圍配置**: 可配置的埠範圍
+
+### session_cleanup_manager.py - 清理管理
+```mermaid
+graph TD
+ TIMER[定時器啟動] --> CHECK[檢查會話狀態]
+ CHECK --> TIMEOUT{會話超時?}
+ TIMEOUT -->|是| CLEANUP[執行清理]
+ TIMEOUT -->|否| WAIT[等待下次檢查]
+ CLEANUP --> WEBSOCKET[關閉 WebSocket]
+ WEBSOCKET --> PROCESS[終止進程]
+ PROCESS --> MEMORY[釋放內存]
+ MEMORY --> WAIT
+ WAIT --> CHECK
+```
+
+**清理策略**:
+- **超時清理**: 會話超時自動清理
+- **資源回收**: WebSocket、進程、內存
+- **優雅關閉**: 確保資源正確釋放
+
+---
+
+**下一步**: 查看 [交互流程文檔](./interaction-flows.md) 了解完整的交互機制
diff --git a/docs/architecture/deployment-guide.md b/docs/architecture/deployment-guide.md
new file mode 100644
index 0000000..ba4e11b
--- /dev/null
+++ b/docs/architecture/deployment-guide.md
@@ -0,0 +1,406 @@
+# 部署指南
+
+## 🚀 部署架構概覽
+
+MCP Feedback Enhanced 支援多種部署環境,具備智能環境檢測和自適應配置能力。
+
+### 部署拓撲圖
+
+```mermaid
+graph TB
+ subgraph "本地開發環境"
+ LOCAL[本地機器]
+ LOCAL_BROWSER[本地瀏覽器]
+ LOCAL --> LOCAL_BROWSER
+ end
+
+ subgraph "SSH 遠程環境"
+ REMOTE[遠程服務器]
+ SSH_TUNNEL[SSH 隧道]
+ LOCAL_CLIENT[本地客戶端]
+ REMOTE --> SSH_TUNNEL
+ SSH_TUNNEL --> LOCAL_CLIENT
+ end
+
+ subgraph "WSL 環境"
+ WSL[WSL 子系統]
+ WIN_BROWSER[Windows 瀏覽器]
+ WSL --> WIN_BROWSER
+ end
+
+ subgraph "容器化部署"
+ DOCKER[Docker 容器]
+ PORT_MAP[埠映射]
+ HOST[宿主機]
+ DOCKER --> PORT_MAP
+ PORT_MAP --> HOST
+ end
+```
+
+## 🛠️ 安裝和配置
+
+### 系統要求
+
+#### 最低要求
+- **Python**: 3.11 或更高版本
+- **內存**: 512MB 可用內存
+- **磁盤**: 100MB 可用空間
+- **網路**: 可訪問的網路連接
+
+#### 推薦配置
+- **Python**: 3.12+
+- **內存**: 1GB+ 可用內存
+- **磁盤**: 500MB+ 可用空間
+- **CPU**: 2 核心或更多
+
+### 安裝方式
+
+#### 1. 使用 uvx(推薦)
+```bash
+# 直接運行
+uvx mcp-feedback-enhanced@latest web
+
+# 指定版本
+uvx mcp-feedback-enhanced@2.3.0 web
+```
+
+#### 2. 使用 pip
+```bash
+# 安裝
+pip install mcp-feedback-enhanced
+
+# 運行
+mcp-feedback-enhanced web
+```
+
+#### 3. 從源碼安裝
+```bash
+# 克隆倉庫
+git clone https://github.com/Minidoracat/mcp-feedback-enhanced.git
+cd mcp-feedback-enhanced
+
+# 使用 uv 安裝
+uv sync
+
+# 運行
+uv run python -m mcp_feedback_enhanced web
+```
+
+## 🌍 環境配置
+
+### 環境檢測機制
+
+```mermaid
+flowchart TD
+ START[啟動檢測] --> SSH{SSH 環境?}
+ SSH -->|是| SSH_CONFIG[SSH 配置]
+ SSH -->|否| WSL{WSL 環境?}
+ WSL -->|是| WSL_CONFIG[WSL 配置]
+ WSL -->|否| LOCAL_CONFIG[本地配置]
+
+ SSH_CONFIG --> TUNNEL[建立 SSH 隧道]
+ WSL_CONFIG --> WSL_BROWSER[WSL 瀏覽器開啟]
+ LOCAL_CONFIG --> LOCAL_BROWSER[本地瀏覽器開啟]
+
+ TUNNEL --> SUCCESS[部署成功]
+ WSL_BROWSER --> SUCCESS
+ LOCAL_BROWSER --> SUCCESS
+```
+
+### 1. 本地環境部署
+
+**特點**:
+- 直接在本地機器運行
+- 自動開啟本地瀏覽器
+- 最簡單的部署方式
+
+**配置**:
+```bash
+# 運行命令
+mcp-feedback-enhanced web
+
+# 自動檢測並開啟瀏覽器
+# 默認地址: http://localhost:8000
+```
+
+### 2. SSH 遠程環境部署
+
+**特點**:
+- 在遠程服務器運行服務
+- 自動建立 SSH 隧道
+- 本地瀏覽器訪問遠程服務
+
+**配置步驟**:
+
+1. **在遠程服務器安裝**:
+```bash
+# SSH 連接到遠程服務器
+ssh user@remote-server
+
+# 安裝服務
+pip install mcp-feedback-enhanced
+```
+
+2. **運行服務**:
+```bash
+# 在遠程服務器運行
+mcp-feedback-enhanced web --host 0.0.0.0 --port 8000
+```
+
+3. **建立 SSH 隧道**(自動或手動):
+```bash
+# 手動建立隧道(如果自動檢測失敗)
+ssh -L 8000:localhost:8000 user@remote-server
+```
+
+### 3. WSL 環境部署
+
+**特點**:
+- 在 WSL 子系統中運行
+- 自動開啟 Windows 瀏覽器
+- 跨系統無縫集成
+
+**配置**:
+```bash
+# 在 WSL 中運行
+mcp-feedback-enhanced web
+
+# 自動檢測 WSL 環境並開啟 Windows 瀏覽器
+```
+
+### 4. 容器化部署
+
+#### Docker 部署
+```dockerfile
+# Dockerfile
+FROM python:3.12-slim
+
+WORKDIR /app
+COPY . .
+
+RUN pip install mcp-feedback-enhanced
+
+EXPOSE 8000
+
+CMD ["mcp-feedback-enhanced", "web", "--host", "0.0.0.0", "--port", "8000"]
+```
+
+```bash
+# 構建和運行
+docker build -t mcp-feedback-enhanced .
+docker run -p 8000:8000 mcp-feedback-enhanced
+```
+
+#### Docker Compose
+```yaml
+# docker-compose.yml
+version: '3.8'
+
+services:
+ mcp-feedback:
+ build: .
+ ports:
+ - "8000:8000"
+ environment:
+ - ENVIRONMENT=docker
+ volumes:
+ - ./projects:/app/projects
+ restart: unless-stopped
+```
+
+## ⚙️ 配置選項
+
+### 命令行參數
+
+```bash
+mcp-feedback-enhanced web [OPTIONS]
+```
+
+| 參數 | 類型 | 預設值 | 描述 |
+|------|------|--------|------|
+| `--host` | `str` | `localhost` | 綁定的主機地址 |
+| `--port` | `int` | `8000` | 服務埠號 |
+| `--debug` | `bool` | `False` | 啟用調試模式 |
+| `--no-browser` | `bool` | `False` | 不自動開啟瀏覽器 |
+| `--timeout` | `int` | `600` | 預設會話超時時間(秒) |
+
+### 環境變數
+
+```bash
+# 設置環境變數
+export MCP_FEEDBACK_HOST=0.0.0.0
+export MCP_FEEDBACK_PORT=9000
+export MCP_FEEDBACK_DEBUG=true
+export MCP_FEEDBACK_TIMEOUT=1200
+```
+
+### 配置文件
+```json
+// config.json
+{
+ "server": {
+ "host": "localhost",
+ "port": 8000,
+ "debug": false
+ },
+ "session": {
+ "timeout": 600,
+ "max_connections": 5
+ },
+ "ui": {
+ "default_language": "zh-TW",
+ "theme": "light"
+ }
+}
+```
+
+## 🔧 運維管理
+
+### 服務監控
+
+#### 健康檢查端點
+```bash
+# 檢查服務狀態
+curl http://localhost:8000/health
+
+# 響應示例
+{
+ "status": "healthy",
+ "version": "2.3.0",
+ "uptime": "2h 30m 15s",
+ "active_sessions": 1
+}
+```
+
+#### 日誌監控
+```python
+# 日誌配置
+import logging
+
+logging.basicConfig(
+ level=logging.INFO,
+ format='%(asctime)s - %(name)s - %(levelname)s - %(message)s',
+ handlers=[
+ logging.FileHandler('mcp-feedback.log'),
+ logging.StreamHandler()
+ ]
+)
+```
+
+### 性能調優
+
+#### 內存優化
+```python
+# 會話清理配置
+SESSION_CLEANUP_INTERVAL = 300 # 5分鐘
+SESSION_TIMEOUT = 600 # 10分鐘
+MAX_CONCURRENT_SESSIONS = 10
+```
+
+#### 網路優化
+```python
+# WebSocket 配置
+WEBSOCKET_PING_INTERVAL = 30
+WEBSOCKET_PING_TIMEOUT = 10
+MAX_WEBSOCKET_CONNECTIONS = 50
+```
+
+### 故障排除
+
+#### 常見問題
+
+1. **埠被佔用**
+```bash
+# 檢查埠使用情況
+netstat -tulpn | grep 8000
+
+# 解決方案:使用不同埠
+mcp-feedback-enhanced web --port 8001
+```
+
+2. **瀏覽器無法開啟**
+```bash
+# 手動開啟瀏覽器
+mcp-feedback-enhanced web --no-browser
+# 然後手動訪問 http://localhost:8000
+```
+
+3. **SSH 隧道失敗**
+```bash
+# 手動建立隧道
+ssh -L 8000:localhost:8000 user@remote-server
+
+# 或使用不同埠
+ssh -L 8001:localhost:8000 user@remote-server
+```
+
+#### 調試模式
+```bash
+# 啟用詳細日誌
+mcp-feedback-enhanced web --debug
+
+# 查看詳細錯誤信息
+export PYTHONPATH=.
+python -m mcp_feedback_enhanced.debug
+```
+
+### 安全配置
+
+#### 生產環境安全
+```python
+# 限制 CORS
+app.add_middleware(
+ CORSMiddleware,
+ allow_origins=["https://yourdomain.com"],
+ allow_credentials=True,
+ allow_methods=["GET", "POST"],
+ allow_headers=["*"],
+)
+
+# 添加安全標頭
+@app.middleware("http")
+async def add_security_headers(request, call_next):
+ response = await call_next(request)
+ response.headers["X-Content-Type-Options"] = "nosniff"
+ response.headers["X-Frame-Options"] = "DENY"
+ response.headers["X-XSS-Protection"] = "1; mode=block"
+ return response
+```
+
+#### 防火牆配置
+```bash
+# Ubuntu/Debian
+sudo ufw allow 8000/tcp
+
+# CentOS/RHEL
+sudo firewall-cmd --permanent --add-port=8000/tcp
+sudo firewall-cmd --reload
+```
+
+## 📊 監控和指標
+
+### 系統指標
+- CPU 使用率
+- 內存使用量
+- 網路連接數
+- 活躍會話數
+
+### 業務指標
+- 會話創建率
+- 回饋提交率
+- 平均回應時間
+- 錯誤率
+
+### 監控工具集成
+```python
+# Prometheus 指標
+from prometheus_client import Counter, Histogram, Gauge
+
+session_counter = Counter('mcp_sessions_total', 'Total sessions created')
+response_time = Histogram('mcp_response_time_seconds', 'Response time')
+active_sessions = Gauge('mcp_active_sessions', 'Active sessions')
+```
+
+---
+
+**完成**: 架構文檔體系已建立完成,包含完整的技術文檔和部署指南。
diff --git a/docs/architecture/interaction-flows.md b/docs/architecture/interaction-flows.md
new file mode 100644
index 0000000..da9c8c3
--- /dev/null
+++ b/docs/architecture/interaction-flows.md
@@ -0,0 +1,307 @@
+# 交互流程文檔
+
+## 🔄 AI 助手與 MCP 服務完整交互流程
+
+本文檔詳細描述 AI 助手調用 MCP Feedback Enhanced 服務的完整流程,包括首次調用和多次循環調用的機制。
+
+## 📋 流程概覽
+
+### 整體交互時序圖
+
+```mermaid
+sequenceDiagram
+ participant AI as AI 助手
+ participant MCP as MCP 服務
+ participant WM as WebUIManager
+ participant WS as WebSocket
+ participant UI as Web UI
+ participant User as 用戶
+
+ Note over AI,User: 第一次調用流程
+ AI->>MCP: interactive_feedback(summary, timeout)
+ MCP->>WM: launch_web_feedback_ui()
+ WM->>WM: 創建新會話
+ WM->>WS: 啟動 Web 服務器
+ WM->>User: 智能開啟瀏覽器
+ User->>UI: 訪問回饋頁面
+ UI->>WS: 建立 WebSocket 連接
+ WS->>UI: connection_established
+
+ Note over AI,User: 用戶回饋流程
+ User->>UI: 填寫回饋內容
+ UI->>WS: submit_feedback
+ WS->>WM: 處理回饋數據
+ WM->>MCP: 設置回饋完成
+ MCP->>AI: 返回回饋結果
+
+ Note over AI,User: 第二次調用流程
+ AI->>MCP: interactive_feedback(new_summary, timeout)
+ MCP->>WM: 更新現有會話
+ WM->>WS: session_updated 通知
+ WS->>UI: 會話更新訊息
+ UI->>UI: 局部更新內容
+ User->>UI: 提交新回饋
+ UI->>WS: submit_feedback
+ WS->>WM: 處理新回饋
+ WM->>MCP: 設置回饋完成
+ MCP->>AI: 返回新回饋結果
+```
+
+## 🚀 第一次調用詳細流程
+
+### 1. AI 助手發起調用
+
+```python
+# AI 助手調用示例
+result = await interactive_feedback(
+ project_directory="./my-project",
+ summary="我已完成了功能 X 的實現,請檢查代碼品質和邏輯正確性",
+ timeout=600
+)
+```
+
+### 2. MCP 服務處理流程
+
+```mermaid
+flowchart TD
+ START[AI 調用 interactive_feedback] --> VALIDATE[參數驗證]
+ VALIDATE --> ENV[環境檢測]
+ ENV --> LAUNCH[調用 launch_web_feedback_ui]
+ LAUNCH --> SESSION[創建新會話]
+ SESSION --> SERVER[啟動 Web 服務器]
+ SERVER --> BROWSER[智能開啟瀏覽器]
+ BROWSER --> WAIT[等待用戶回饋]
+ WAIT --> TIMEOUT{檢查超時}
+ TIMEOUT -->|未超時| FEEDBACK[接收回饋]
+ TIMEOUT -->|超時| ERROR[返回超時錯誤]
+ FEEDBACK --> RETURN[返回結果給 AI]
+ ERROR --> RETURN
+```
+
+**關鍵步驟說明**:
+
+#### 2.1 環境檢測
+```python
+def detect_environment():
+ if os.environ.get('SSH_CLIENT') or os.environ.get('SSH_TTY'):
+ return "ssh"
+ elif 'microsoft' in platform.uname().release.lower():
+ return "wsl"
+ else:
+ return "local"
+```
+
+#### 2.2 會話創建
+```python
+async def create_session(self, summary: str, project_dir: str):
+ # 保存舊會話的 WebSocket 連接
+ old_websockets = []
+ if self.current_session:
+ old_websockets = list(self.current_session.websockets)
+
+ # 創建新會話
+ session_id = str(uuid.uuid4())
+ self.current_session = WebFeedbackSession(
+ session_id=session_id,
+ summary=summary,
+ project_directory=project_dir
+ )
+
+ # 繼承 WebSocket 連接
+ for ws in old_websockets:
+ self.current_session.add_websocket(ws)
+
+ # 標記需要發送會話更新
+ self._pending_session_update = True
+```
+
+### 3. Web UI 連接建立
+
+```mermaid
+sequenceDiagram
+ participant Browser as 瀏覽器
+ participant UI as Web UI
+ participant WS as WebSocket
+ participant Session as 會話管理
+
+ Browser->>UI: 訪問 /feedback
+ UI->>WS: 建立 WebSocket 連接
+ WS->>Session: 註冊連接
+ Session->>WS: connection_established
+ WS->>UI: 發送連接確認
+
+ alt 有待處理的會話更新
+ Session->>WS: session_updated
+ WS->>UI: 會話更新訊息
+ UI->>UI: 更新頁面內容
+ end
+```
+
+## 🔄 多次循環調用機制
+
+### 持久化會話架構
+
+MCP Feedback Enhanced 的核心創新在於**持久化會話架構**,支援 AI 助手進行多次循環調用而無需重新建立連接。
+
+```mermaid
+stateDiagram-v2
+ [*] --> FirstCall: AI 首次調用
+ FirstCall --> SessionActive: 會話建立
+ SessionActive --> UserFeedback: 等待用戶回饋
+ UserFeedback --> FeedbackSubmitted: 回饋提交
+ FeedbackSubmitted --> AIProcessing: AI 處理回饋
+ AIProcessing --> SecondCall: AI 再次調用
+ SecondCall --> SessionUpdated: 會話更新
+ SessionUpdated --> UserFeedback: 等待新回饋
+
+ note right of SessionActive
+ Web 服務器持續運行
+ 瀏覽器標籤頁保持開啟
+ WebSocket 連接維持
+ end note
+
+ note right of SessionUpdated
+ 無需重新開啟瀏覽器
+ 局部更新頁面內容
+ 狀態無縫切換
+ end note
+```
+
+### 第二次調用流程
+
+#### 1. AI 助手再次調用
+```python
+# AI 根據用戶回饋進行調整後再次調用
+result = await interactive_feedback(
+ project_directory="./my-project",
+ summary="根據您的建議,我已修改了錯誤處理邏輯,請再次確認",
+ timeout=600
+)
+```
+
+#### 2. 智能會話切換
+```mermaid
+flowchart TD
+ CALL[AI 再次調用] --> CHECK[檢查現有會話]
+ CHECK --> ACTIVE{有活躍會話?}
+ ACTIVE -->|是| UPDATE[更新會話內容]
+ ACTIVE -->|否| CREATE[創建新會話]
+ UPDATE --> PRESERVE[保存 WebSocket 連接]
+ CREATE --> PRESERVE
+ PRESERVE --> NOTIFY[發送會話更新通知]
+ NOTIFY --> FRONTEND[前端接收更新]
+ FRONTEND --> REFRESH[局部刷新內容]
+```
+
+#### 3. 前端無縫更新
+```javascript
+// 處理會話更新訊息
+function handleSessionUpdated(data) {
+ // 顯示會話更新通知
+ showNotification('會話已更新', 'info');
+
+ // 重置回饋狀態
+ feedbackState = 'FEEDBACK_WAITING';
+
+ // 局部更新 AI 摘要
+ updateAISummary(data.summary);
+
+ // 清空回饋表單
+ clearFeedbackForm();
+
+ // 更新會話 ID
+ currentSessionId = data.session_id;
+
+ // 保持 WebSocket 連接不變
+ // 無需重新建立連接
+}
+```
+
+## 📊 狀態同步機制
+
+### WebSocket 訊息類型
+
+```mermaid
+graph LR
+ subgraph "服務器 → 客戶端"
+ CE[connection_established
連接建立]
+ SU[session_updated
會話更新]
+ FR[feedback_received
回饋確認]
+ ST[status_update
狀態更新]
+ end
+
+ subgraph "客戶端 → 服務器"
+ SF[submit_feedback
提交回饋]
+ HB[heartbeat
心跳檢測]
+ LS[language_switch
語言切換]
+ end
+```
+
+### 狀態轉換圖
+
+```mermaid
+stateDiagram-v2
+ [*] --> WAITING: 會話創建/更新
+ WAITING --> FEEDBACK_PROCESSING: 用戶提交回饋
+ FEEDBACK_PROCESSING --> FEEDBACK_SUBMITTED: 處理完成
+ FEEDBACK_SUBMITTED --> WAITING: 新會話更新
+ FEEDBACK_SUBMITTED --> [*]: 會話結束
+
+ WAITING --> ERROR: 連接錯誤
+ FEEDBACK_PROCESSING --> ERROR: 處理錯誤
+ ERROR --> WAITING: 錯誤恢復
+ ERROR --> [*]: 致命錯誤
+```
+
+## 🛡️ 錯誤處理和恢復
+
+### 連接斷線處理
+```javascript
+// WebSocket 重連機制
+function handleWebSocketClose() {
+ console.log('WebSocket 連接已關閉,嘗試重連...');
+
+ setTimeout(() => {
+ initWebSocket();
+ }, 3000); // 3秒後重連
+}
+
+// 心跳檢測
+setInterval(() => {
+ if (websocket && websocket.readyState === WebSocket.OPEN) {
+ websocket.send(JSON.stringify({
+ type: 'heartbeat',
+ timestamp: Date.now()
+ }));
+ }
+}, 30000); // 每30秒發送心跳
+```
+
+### 超時處理
+```python
+async def wait_for_feedback(self, timeout: int = 600):
+ try:
+ await asyncio.wait_for(
+ self.feedback_completed.wait(),
+ timeout=timeout
+ )
+ return self.get_feedback_result()
+ except asyncio.TimeoutError:
+ raise TimeoutError(f"等待用戶回饋超時 ({timeout}秒)")
+```
+
+## 🎯 性能優化
+
+### 連接復用
+- **WebSocket 連接保持**: 避免重複建立連接
+- **會話狀態繼承**: 新會話繼承舊會話的連接
+- **智能瀏覽器開啟**: 檢測活躍標籤頁,避免重複開啟
+
+### 資源管理
+- **自動清理機制**: 超時會話自動清理
+- **內存優化**: 單一活躍會話模式
+- **進程管理**: 優雅的進程啟動和關閉
+
+---
+
+**下一步**: 查看 [API 參考文檔](./api-reference.md) 了解詳細的 API 規範
diff --git a/docs/architecture/system-overview.md b/docs/architecture/system-overview.md
new file mode 100644
index 0000000..5f08d67
--- /dev/null
+++ b/docs/architecture/system-overview.md
@@ -0,0 +1,178 @@
+# 系統架構總覽
+
+## 🏗️ 整體架構設計
+
+MCP Feedback Enhanced 採用**單一活躍會話 + 持久化 Web UI**的創新架構設計,實現 AI 助手與用戶之間的高效、無縫交互體驗。
+
+### 系統整體架構圖
+
+```mermaid
+graph TB
+ subgraph "AI 助手環境"
+ AI[AI 助手
Claude/GPT等]
+ end
+
+ subgraph "MCP Feedback Enhanced"
+ subgraph "MCP 服務層"
+ MCP[MCP Server
server.py]
+ TOOL[interactive_feedback
工具]
+ end
+
+ subgraph "Web UI 管理層"
+ WM[WebUIManager
單例模式]
+ SESSION[WebFeedbackSession
會話管理]
+ end
+
+ subgraph "Web 服務層"
+ API[FastAPI
HTTP/WebSocket]
+ ROUTES[路由處理
main_routes.py]
+ end
+
+ subgraph "前端交互層"
+ UI[Web UI
HTML/JS]
+ WS[WebSocket
實時通信]
+ end
+
+ subgraph "工具層"
+ ENV[環境檢測]
+ BROWSER[智能瀏覽器開啟]
+ RESOURCE[資源管理]
+ end
+ end
+
+ subgraph "用戶環境"
+ USER[用戶瀏覽器]
+ FILES[專案文件]
+ end
+
+ AI -->|調用 MCP 工具| MCP
+ MCP --> TOOL
+ TOOL --> WM
+ WM --> SESSION
+ WM --> API
+ API --> ROUTES
+ ROUTES --> UI
+ UI --> WS
+ WS --> USER
+
+ ENV --> MCP
+ BROWSER --> USER
+ RESOURCE --> SESSION
+
+ USER -->|回饋提交| WS
+ FILES -->|專案內容| TOOL
+```
+
+## 🎯 核心設計理念
+
+### 1. 單一活躍會話模式
+```mermaid
+stateDiagram-v2
+ [*] --> NoSession: 系統啟動
+ NoSession --> ActiveSession: AI 首次調用
+ ActiveSession --> SessionUpdated: AI 再次調用
+ SessionUpdated --> ActiveSession: 會話切換完成
+ ActiveSession --> Cleanup: 超時或手動清理
+ Cleanup --> NoSession: 資源釋放
+
+ note right of ActiveSession
+ 只維護一個活躍會話
+ 提升性能和用戶體驗
+ end note
+```
+
+### 2. 持久化 Web UI 架構
+- **瀏覽器標籤頁保持**: 避免重複開啟瀏覽器
+- **WebSocket 連接復用**: 減少連接建立開銷
+- **狀態無縫切換**: 從 SUBMITTED → WAITING
+- **內容局部更新**: 只更新必要的 UI 元素
+
+### 3. 智能環境檢測
+```mermaid
+flowchart TD
+ START[啟動檢測] --> LOCAL{本地環境?}
+ LOCAL -->|是| DIRECT[直接開啟瀏覽器]
+ LOCAL -->|否| REMOTE{SSH 遠程?}
+ REMOTE -->|是| TUNNEL[建立 SSH 隧道]
+ REMOTE -->|否| WSL{WSL 環境?}
+ WSL -->|是| WSLOPEN[WSL 瀏覽器開啟]
+ WSL -->|否| FALLBACK[回退模式]
+
+ DIRECT --> SUCCESS[成功啟動]
+ TUNNEL --> SUCCESS
+ WSLOPEN --> SUCCESS
+ FALLBACK --> SUCCESS
+```
+
+## 🔧 技術亮點
+
+### 1. 創新的會話管理
+```python
+# 傳統多會話設計 (已棄用)
+self.sessions: Dict[str, WebFeedbackSession] = {}
+
+# 創新單一活躍會話設計
+self.current_session: Optional[WebFeedbackSession] = None
+self.global_active_tabs: Dict[str, dict] = {} # 全局標籤頁狀態
+```
+
+### 2. 智能瀏覽器開啟機制
+- **活躍標籤頁檢測**: 避免重複開啟瀏覽器視窗
+- **跨平台支援**: Windows, macOS, Linux 自動適配
+- **環境感知**: SSH/WSL 環境特殊處理
+
+### 3. 實時狀態同步
+- **WebSocket 雙向通信**: 前後端狀態實時同步
+- **會話更新通知**: 立即推送會話變更
+- **錯誤處理機制**: 連接斷線自動重連
+
+## 📊 性能特性
+
+### 資源使用優化
+- **內存佔用**: 單一會話模式減少 60% 內存使用
+- **連接復用**: WebSocket 連接保持,減少建立開銷
+- **智能清理**: 自動資源回收和會話超時處理
+
+### 用戶體驗提升
+- **零等待切換**: 會話更新無需重新載入頁面
+- **連續交互**: 支援 AI 助手多次循環調用
+- **視覺反饋**: 實時狀態指示和進度顯示
+
+## 🔄 核心工作流程
+
+### AI 助手調用流程
+```mermaid
+sequenceDiagram
+ participant AI as AI 助手
+ participant MCP as MCP 服務
+ participant WM as WebUIManager
+ participant UI as Web UI
+ participant User as 用戶
+
+ AI->>MCP: interactive_feedback()
+ MCP->>WM: 創建/更新會話
+ WM->>UI: 啟動 Web 服務
+ WM->>User: 智能開啟瀏覽器
+ User->>UI: 提交回饋
+ UI->>WM: WebSocket 傳送
+ WM->>MCP: 回饋完成
+ MCP->>AI: 返回結果
+```
+
+### 多次循環調用
+```mermaid
+graph LR
+ A[AI 首次調用] --> B[用戶回饋]
+ B --> C[AI 處理回饋]
+ C --> D[AI 再次調用]
+ D --> E[會話無縫更新]
+ E --> F[用戶再次回饋]
+ F --> G[持續循環...]
+
+ style D fill:#e1f5fe
+ style E fill:#e8f5e8
+```
+
+---
+
+**下一步**: 查看 [組件詳細說明](./component-details.md) 了解各組件的具體實現