efe8e165cf
按 leo 鐵律(2026-06-14)把插件從「直接 SQL 操作基本盤表」改寫成 「只透過基本盤 arcrun/kbdb HTTP API 讀寫」。零建表、零 migration、零 SQL。 - 新增 src/lib/kbdb-client.ts:唯一對外通道,封裝 entries/templates/records API - 新增 src/lib/templates.ts:triplet/entity template 定義(替代建表) - 改寫 21 個違規 action(triplet/graph/entity/search)→ 走 client,圖在插件層記憶體組裝 - 移除所有 migrations、D1/Vectorize/AI 綁定;embedding/語意搜尋歸基本盤 optional 模組 - index.ts 只掛 triplets/graph/entities/search 路由;基本盤路由歸 arcrun/kbdb - 測試改走 mock client(純 node);裁剪 CLAUDE.md 只留 graph 插件 + 鐵律 - 修正 SDD design.md「讀現狀推翻鐵律」的錯誤判斷(共用 D1 → API-as-Wall) Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2.9 KiB
2.9 KiB
KBDB Blocks Edit API — Tasks
對應 SDD:design.md 上次更新:2026-05-06(Phase 1 + Phase 2 完成)
Phase 1:補 PATCH endpoint ✅ 完成
1. PATCH /blocks/{id}
- 1.1 zod schema 直接放在 route 檔(既有 pattern)
- 1.2 寫
src/actions/block-update.ts(96 行,符合樂高法 < 100)- 取既有 block + getBlock fallback(id 或 logseq_uuid)
- 權限檢查:partner key 比對 user_id 前綴
- 自動重算 content_hash(如 content 變)
- 觸發 embedding async 重算(不阻塞 PATCH 回應)
- 寫回 D1
- 回傳更新後的 block
- 1.3 寫
tests/blocks-update.test.ts(7 case 全通過)- happy: content + content_hash 重算
- happy: tags + refs 同改
- 400: 無欄位
- 404: 不存在
- 403: partner 越權
- 200: partner 改自己 namespace
- content_hash 在只改 tags 時不變
- 1.4 在
src/routes/blocks.ts加 PATCH route(OpenAPI) - 1.5 部署到 prod(kbdb.finally.click)+ smoke test 4 case 通過
2. Triplet 編輯:使用既有 PUT/DELETE /records/:id
- 2.1 設計修正:v3 萬物皆 Block,triplet 是 record,既有 endpoints 已涵蓋。本任務組無需新增 endpoint。
- 2.2 在 mira-app 前端「異見牆」實作呼叫
PUT /records/:id(待 mira 階段 3)
3. OpenAPI spec 同步
- 3.1 OpenAPIHono 自動產 swagger.json(route 用 createRoute 已自動納入)
- 3.2 部署後驗證 swagger UI 顯示新 route(待手動驗證)
Phase 2:建三個 templates ✅ 完成
- 4.1 確認 KBDB 內無同名 template(透過 GET /templates 確認)
- 4.2 用 internal token POST /templates 建
data-source-config(id:tpl-data-source-config) - 4.3 用 internal token POST /templates 建
source-skill(id:tpl-source-skill) - 4.4 用 internal token POST /templates 建
wiki-page(id:tpl-wiki-page) - 4.5 驗證:3/3 templates 在 GET /templates 列表內
風險追蹤
風險 1:partner key 跨 org 越權— ✅ unit test 已涵蓋(403 partner 越權)風險 2:embedding 重算造成 D1 寫入 spike— ✅ 改成 fire-and-forget(不 await),不阻塞 PATCH風險 3:content_hash 不一致— ✅ unit test 驗證 hash 重算對應內容
Known Issues(不在本 SDD 範圍,待另開)
POST /blocks/ingest不寫入source欄位:input 接受source參數但僅用於 id slug 生成,未寫進 block 的 source 欄位(block-ingest.ts:84 的 INSERT 缺欄位)。對 mira 影響:所有 source 區分目前無效,需等 KBDB 修復或直接走POST /blocks+ slots。建議下一份 KBDB SDDblock-ingest-source-fix處理。
部署紀錄
- 2026-05-06: Worker version
b7df3c38-e138-41fb-a16c-cc9d2dfeebea部署上線 - Smoke test 通過:content 改寫 + hash 重算、tags 改寫、400 空 body、404 不存在