refactor(claude): Phase B — momo CLAUDE.md 去重 + secrets.local.json

- CLAUDE.md V12.0: 移除與全域重複的 P7/P9/P10、三紅線、委派表、PUA/Loop Mode
  保留 momo 專屬:環境索引、容器架構、診斷指令、CI/CD、PPT 系統、安全架構
- 新增 .claude/hooks/secrets.local.json: Telegram/Gemini/Gitea token 偵測 pattern
  由全域 commit-quality.js 自動載入,補充 momo 環境的專屬保護
- 新增 .claude/skills/telegram-bot-menu-restoration.py (已存在,補 track)

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
ogt
2026-04-21 23:13:18 +08:00
parent 0c9a3cd875
commit a13683d655
3 changed files with 204 additions and 153 deletions

View File

@@ -0,0 +1,7 @@
[
{"pattern": "\\d{8,12}:[A-Za-z0-9_-]{35}", "label": "Telegram Bot Token"},
{"pattern": "TELEGRAM[_\\s]*(?:BOT[_\\s]*)?TOKEN\\s*=\\s*[\"']?[^\\s\"']{20,}", "label": "Telegram Token 環境變數"},
{"pattern": "GEMINI_API_KEY\\s*=\\s*[\"']?[A-Za-z0-9_-]{20,}", "label": "Gemini API Key"},
{"pattern": "glpat-[a-zA-Z0-9_-]{20}", "label": "Gitea/GitLab PAT"},
{"pattern": "GITEA[_\\s]*TOKEN\\s*=\\s*[\"']?[^\\s\"']{20,}", "label": "Gitea Token 環境變數"}
]

View File

@@ -0,0 +1,189 @@
#!/usr/bin/env python3
"""
Telegram Bot 菜單恢復技能記憶
記錄 2026-04-20 的完整 Telegram Bot 菜單系統恢復工作
包含完整的菜單架構、實作細節和最佳實踐
"""
import json
from datetime import datetime
# === 菜單恢復工作記憶 ===
MENU_RESTORATION_MEMORY = {
"work_date": "2026-04-20",
"issue": "用戶回報 Telegram Bot 菜單功能缺失原本6項簡單功能無法滿足業務需求",
"root_cause": "telegram_bot_service.py 使用簡化版菜單openclaw_bot_routes.py 包含完整7大類別系統",
"solution": "恢復完整的三層菜單架構系統",
# === 完整菜單架構 ===
"complete_menu_structure": {
"main_menu": {
"categories": 8, # 7大類別 + 使用說明
"items": [
"📊 業績查詢", "🏆 商品廠商", "🎯 目標管理",
"📈 智能分析", "📄 簡報報表", "🌐 市場情報",
"🔍 競品日報", "❓ 使用說明"
]
},
"submenus": {
"sales": {
"title": "業績查詢",
"features": ["今日/昨日業績", "每週/每月/每季業績", "趨勢分析", "同期比較", "分類業績", "日期區間"],
"callback_prefix": "cmd:sales, cmd:trend, cmd:history, cmd:compare, cmd:category, await:date_range_sales"
},
"products": {
"title": "商品廠商",
"features": ["熱銷商品/廠商", "商品健康", "補貨預測", "分類鑽取", "指定日期"],
"callback_prefix": "cmd:top, cmd:vendor, cmd:health, cmd:restock, menu:category, await:date_top"
},
"goals": {
"title": "目標管理",
"features": ["達成率查看", "日/月/季/半年/年目標設定"],
"callback_prefix": "cmd:goal, await:goal_daily, await:goal_monthly, await:goal_quarterly, await:goal_half, await:goal_yearly"
},
"analysis": {
"title": "智能分析",
"features": ["策略矩陣", "業績趨勢", "商品健康", "促銷追蹤", "趨勢圖表", "同期比較"],
"callback_prefix": "cmd:strategy, menu:trend, cmd:health, cmd:category, await:promo_range, cmd:restock, cmd:chart, cmd:compare"
},
"reports": {
"title": "簡報報表",
"features": ["日報/週報/月報", "策略報告", "促銷效益", "競品比較", "成長趨勢", "廠商業績"],
"callback_prefix": "cmd:ppt:daily, cmd:ppt:weekly, cmd:ppt:monthly, cmd:ppt:strategy, await:promo_range, menu:competitor, cmd:ppt:growth, cmd:ppt:vendor"
},
"market": {
"title": "市場情報",
"features": ["電商新聞", "天氣", "Google熱搜", "Dcard口碑", "台銀匯率", "電商節慶", "YouTube爆紅商品", "AI學習狀態", "關鍵字比價", "圖片比價說明"],
"callback_prefix": "cmd:news, cmd:weather, cmd:trends, cmd:dcard, cmd:exchange, cmd:calendar, cmd:youtube, cmd:learn, await:search_compare, cmd:photo_search_help"
},
"competitor": {
"title": "競品日報",
"features": ["今日/昨日簡報", "週/月/季比較", "指定日期", "長週期比較"],
"callback_prefix": "cmd:ppt:competitor, await:date_competitor, menu:competitor_ppt"
},
"competitor_ppt": {
"title": "競品PPT長週期",
"features": ["半年比較", "年比較"],
"callback_prefix": "cmd:ppt:competitor half, cmd:ppt:competitor yearly",
"level": 3 # 第三層菜單
},
"category": {
"title": "分類業績鑽取",
"features": ["15個完整商品分類"],
"categories": [
"美妝保養", "3C家電", "服飾配件", "居家生活", "母嬰用品",
"生鮮食品", "圖書文具", "戶外運動", "餐券票券", "醫療保健",
"美體保健", "寵物用品", "箱包精品", "車類百貨", "情趣用品"
],
"callback_prefix": "cmd:catdetail, cmd:category"
},
"trend": {
"title": "業績趨勢",
"features": ["近7日/1月/3月/半年/1年", "指定月份/年份/季度"],
"callback_prefix": "cmd:trend:7, cmd:trend:month, cmd:trend:quarter, cmd:trend:half, cmd:trend:year, await:date_trend_month, await:date_trend_year, await:date_trend_quarter"
}
}
},
# === 關鍵發現 ===
"key_discoveries": {
"market_intelligence_expansion": "市場情報從原本4項擴展為10項完整功能",
"three_layer_architecture": "建立主菜單 → 子菜單 → 特定功能的三層架構",
"category_system": "完整的15個商品分類系統",
"ppt_hierarchy": "競品PPT的第二層和第三層分離設計"
},
# === 實作細節 ===
"implementation_details": {
"files_modified": [
"services/telegram_bot_service.py"
],
"methods_added": [
"_get_market_submenu", "_get_competitor_submenu", "_get_competitor_ppt_submenu",
"_get_category_submenu", "_get_trend_submenu", "_handle_main_menu_callback"
],
"menu_layers": 3,
"total_menu_items": 60, # 總計約60個菜單選項
"callback_system": "menu: 前綴 + cmd: 前綴 + await: 前綴"
},
# === 最佳實踐 ===
"best_practices": {
"menu_hierarchy": "清晰的層次結構,避免過深的嵌套",
"naming_convention": "統一的 callback_data 命名規範",
"back_navigation": "每個子菜單都包含返回主選單按鈕",
"user_experience": "直觀的圖示和清晰的中文描述",
"maintainability": "模組化的子菜單方法,便於維護"
},
# === 驗證結果 ===
"validation_results": {
"main_menu_items": 8, # 從6項增加到8項
"submenu_systems": 10, # 10個完整子系統
"market_functions": 10, # 市場情報從4項擴展到10項
"category_count": 15, # 15個商品分類
"architecture_layers": 3, # 三層菜單架構
"backwards_compatibility": True # 保持向下相容
}
}
def get_menu_restoration_memory():
"""取得菜單恢復工作記憶"""
return MENU_RESTORATION_MEMORY
def save_menu_restoration_memory():
"""保存菜單恢復工作記憶到文件"""
timestamp = datetime.now().isoformat()
memory_log = {
"timestamp": timestamp,
"memory": MENU_RESTORATION_MEMORY,
"action": "telegram_bot_menu_restoration_2026_04_20"
}
# 這裡可以加入保存到文件或資料庫的邏輯
# 目前記憶已經在代碼中完整記錄
return memory_log
def get_menu_architecture_summary():
"""取得菜單架構摘要"""
memory = get_menu_restoration_memory()
summary = f"""
=== Telegram Bot 菜單恢復工作摘要 ===
日期: {memory['work_date']}
問題: {memory['issue']}
解決方案: {memory['solution']}
菜單架構:
- 主菜單: {memory['complete_menu_structure']['main_menu']['categories']} 項功能
- 子菜單系統: {len(memory['complete_menu_structure']['submenus'])}
- 架構層次: {memory['implementation_details']['menu_layers']}
- 總菜單項目: 約 {memory['implementation_details']['total_menu_items']}
關鍵成果:
✅ 市場情報功能擴展: 4 → 10 項
✅ 建立三層菜單架構
✅ 完整15個商品分類系統
✅ 向下相容性保持
✅ 模組化實作便於維護
記憶檔案: {__file__}
ADR記錄: ADR-015-telegram-bot-menu-restoration.md
"""
return summary
if __name__ == "__main__":
print(get_menu_architecture_summary())

161
CLAUDE.md
View File

@@ -1,6 +1,7 @@
# EwoooC (MOMO Pro System) — 核心索引
> **版本**: V11.0 | **目標**: AI 驅動 MOMO 商品監控、業績分析、策略自動化與 AIOps 自愈
> **版本**: V12.0 | **目標**: AI 驅動 MOMO 商品監控、業績分析、策略自動化與 AIOps 自愈
> **全域工作流程**P7/P9/P10、三紅線、委派表、PUA/Loop見 `~/.claude/CLAUDE.md`
## 治理
- **憲法**: [CONSTITUTION.md](CONSTITUTION.md) — 所有開發必須遵守
@@ -83,166 +84,20 @@ ssh wooo@192.168.0.110 "ssh ollama@192.168.0.188 \"\
---
## AI 開發鐵律(三條紅線
## momo 安全架構bypassPermissions
這三條紅線適用於所有模式、所有 Agent不可豁免
### 紅線一:狙擊手模式(事實驅動)
禁止在未獲授權的情況下,使用 `ls`, `grep`, `cat` 等指令在專案內盲搜。所有判斷必須基於**親自讀取的程式碼**,附上路徑與行號。「我猜」、「應該是」、「可能」是違規。
### 紅線二:精準打擊(閉包紀律)
統帥給定任務時,若已明確指出目標檔案路徑,直接修改該檔案,嚴禁漫無目的掃描關聯模組。每個任務有明確的 Definition of Done不允許「差不多完成」。
### 紅線三:上下文克制(徹底性)
不主動讀取超過 300 行的檔案,除非統帥明確要求。清單逐項確認,即使沒問題的項目也要標記「已查,無異狀」,不可跳過。
---
## 工作流程模式P7 / P9 / P10
根據任務範圍切換模式。這不是角色扮演,是執行紀律。
```
任務範圍 模式
─────────────────────────────────────────────────────
單一功能,範圍明確 P7 執行模式(狙擊手)
跨模組3+ 個檔案 P9 拆解 → P7 × N 執行
跨服務架構5+ 個 Agent / Sprint P10 戰略 → P9 × N 拆解
```
### P7 執行模式(預設)
1. **讀取現實** — 先用 Read / Grep / Glob 讀相關檔案,禁止憑記憶設計
2. **設計方案** — 寫下要改什麼、為什麼、捨棄了哪些替代方案
3. **影響分析** — 列出所有 caller、test、下游模組。漏一個是缺陷
4. **實作** — 執行方案,禁止中途改設計
5. **三問自審**(完成後必做):
- 方案正確嗎?有沒有誤解需求?
- 影響分析完整嗎?有沒有漏掉的 caller
- 有沒有 regression 風險?
**交付格式 `[P7-COMPLETION]`**(每個任務完成時必用):
```
[P7-COMPLETION]
任務: <原始需求>
方案: <選擇的做法 + 原因>
變更: <檔案清單 + 每個檔案的重點>
影響: <受影響的模組/呼叫者 + 為何安全>
自審:
- 方案正確: <答案>
- 影響完整: <答案>
- Regression 風險: <答案>
剩餘風險: <誠實列出未覆蓋的部分,或「無」>
```
### P9 管理模式(禁止自己寫程式碼)
觸發條件:任務涉及 3+ 個檔案或 2+ 個模組。
- **禁止自己寫程式碼**,輸出是任務拆解 + Task Prompt
- 每個 Task Prompt 必含六元素:目標、範圍(精確路徑)、輸入、輸出、驗收條件、禁止碰觸的邊界
- 每個子任務完成後必過 `critic` 審查才能繼續
### P10 戰略模式(極少用)
觸發條件:跨 3 個 Sprint 以上的重構、定義新的 Agent 協作拓撲。
輸出是戰略文件(非程式碼、非 Task Prompt含目標、成功指標、風險、時程。
---
## 12 人專家團隊Subagents
使用 `Agent` 工具呼叫,`subagent_type` 填入下表 Agent ID。
| Agent | ID | 何時使用 |
|-------|----|---------|
| 程式碼審查官 | `critic` | commit 前、部署前、PR 合併前、懷疑有 Bug |
| 弱點驗證師 | `vuln-verifier` | critic 找到弱點後,寫 PoC 確認是否可重現 |
| 除錯工程師 | `debugger` | 任何 Bug、容器掛掉、排程異常、Telegram 通知中斷 |
| 資料庫專家 | `db-expert` | schema 設計、migration 安全審查、pgvector 索引、SQL 優化 |
| 任務拆解師 | `planner` | 任務涉及 3+ 個檔案(自動切 P9 模式) |
| 全端工程師 | `fullstack-engineer` | 功能實作P7 流程:設計→影響分析→實作→自審) |
| 重構專家 | `refactor-specialist` | 10+ 個檔案的大規模重構、模組抽取、檔案搬移 |
| 遷移工程師 | `migration-engineer` | 框架/套件主版本升級、breaking change 處理 |
| 探索員 | `onboarder` | 第一次接觸某模組、快速建立程式碼心智模型 |
| 工具專家 | `tool-expert` | MCP 工具選擇、複雜工具鏈除錯、Claude Code Hook 設計 |
| 網路研究員 | `web-researcher` | 官方文件查詢、API spec、錯誤碼、版本差異確認 |
> Agent 定義檔位於 [.claude/agents/](.claude/agents/)
---
## 委派鐵律
### 必派(無條件執行)
| 情境 | 必派 Agent |
|------|-----------|
| 完成程式碼,即將 commit / 部署 | `critic` 審查 diff |
| 收到 Bug 回報、容器掛掉、排程異常 | `debugger`(第一反應,禁止猜測) |
| 任務涉及 3+ 個檔案或 2+ 個模組 | `planner` 先拆解(切 P9 模式) |
| schema 變更、migration 檔案 | `db-expert` 審查 |
| SSH 到 188 執行前,操作涉及 momo-db | `critic` 確認指令安全性 |
| 懷疑有安全漏洞 | `critic``vuln-verifier` |
| 大規模重構10+ 檔案、模組重命名) | `refactor-specialist` |
| 第一次接觸新模組 | `onboarder` 建立心智模型 |
| 需要查官方文件、API 行為確認 | `web-researcher`(禁止依賴記憶推測) |
### 禁派(自己處理)
- 單一檔案 1-2 行修改
- 純問答、概念解釋、技術 Q&A
- 統帥明確說「你自己做」
- 只是讀單一 log 或 grep 單一關鍵字
### 平行派遣
獨立任務應同時派出(單一訊息多個 Agent tool call例如
```python
# 前後端同時審查(不必等一個完成再派另一個)
Agent(subagent_type="critic", prompt="審查 services/ 的 diff...") # 同一訊息
Agent(subagent_type="critic", prompt="審查 web/templates/ 的 diff...") # 並行
```
---
## 高壓模式觸發條件PUA Mode
切換到「徹底、不退讓」工作狀態:
| 觸發條件 | 切換行為 |
|---------|---------|
| 同一任務失敗 2 次以上 | 停止重試舊方案,提出 3 個全新假設並逐一驗證 |
| 即將說「我無法解決」、「可能是環境問題」 | 禁止說。用 WebSearch 查官方文件,讀原始碼,逐一列舉可能原因 |
| 被抓到被動等待指示 | 自己找下一步,你是來解決問題的 |
| 統帥說「再努力一點」、「怎麼又失敗」 | 進入反思模式:寫下上一步為何失敗 + 這次必須改什麼 |
---
## Loop 模式(長時自主迭代)
統帥說「不要停」、「我去睡了」時進入 Loop 模式:
- 禁止 `AskUserQuestion`,自己做決定
-`<loop-pause>需要的資訊</loop-pause>` 暫停等待人工輸入
-`<loop-abort>原因</loop-abort>` 終止迴圈
- 每次迭代 = 一個完整 P7 週期,完成一個再開始下一個
- 統帥回來時,彙整成單一報告
---
## 安全架構說明bypassPermissions
本專案採用 `bypassPermissions: true` + Hook 自動政策替代人工確認對話框。
安全防線由 `.claude/hooks/` 的 Hook 自動執行,覆蓋範圍:
本專案採用 `permissions.defaultMode: "bypassPermissions"` + Hook 自動政策替代人工確認對話框
安全防線由 [.claude/hooks/](.claude/hooks/) 的 Hook 自動執行,覆蓋範圍:
| Hook | 觸發點 | 防護內容 |
|------|--------|---------|
| `momo-prod-guard.js` | PreToolUse | 阻擋 --remove-orphans、force push、遠端 docker rm momo-db、生產 SSH 稽核 |
| `commit-quality.js` | PreToolUse | 阻擋 hardcoded Token/API Key 進入 commit |
| `commit-quality.js` | PreToolUse | 阻擋 hardcoded Token/API Key(含 Telegram/Gemini/Gitea 模式)|
| `large-file-warner.js` | PreToolUse | >2MB 阻擋讀取,>500KB 警告 |
| `mcp-health.js` | PreToolUse | MCP 伺服器 cooldown 保護 |
| `audit-log.js` | PostToolUse | 所有 Bash 指令稽核,自動 redact Token |
| `suggest-compact.js` | PostToolUse | 50 次工具呼叫後建議 /compact |
| `cost-tracker.js` | Stop | Token 用量與成本追蹤 |
| `session-summary.js` | Stop | 對話快照存檔 |
全域 Hook`~/.claude/hooks/`)同時生效:`branch-protection.js`main 分支保護已透過 `.claude/hooks/branch-protection.local.json` 設為僅保護 `production`)。