Files
kbdb-graph-plugin/docs/3-specs/blocks-edit-api/tasks.md
T
Leo efe8e165cf feat: KBDB-graph 插件獨立 — 全面改寫成走基本盤 API(API-as-Wall)
按 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>
2026-06-14 20:59:41 +08:00

2.9 KiB
Raw Blame History

KBDB Blocks Edit API — Tasks

對應 SDDdesign.md 上次更新:2026-05-06Phase 1 + Phase 2 完成)


Phase 1:補 PATCH endpoint 完成

1. PATCH /blocks/{id}

  • 1.1 zod schema 直接放在 route 檔(既有 pattern
  • 1.2 寫 src/actions/block-update.ts96 行,符合樂高法 < 100
    • 取既有 block + getBlock fallbackid 或 logseq_uuid
    • 權限檢查:partner key 比對 user_id 前綴
    • 自動重算 content_hash(如 content 變)
    • 觸發 embedding async 重算(不阻塞 PATCH 回應)
    • 寫回 D1
    • 回傳更新後的 block
  • 1.3 寫 tests/blocks-update.test.ts7 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 routeOpenAPI
  • 1.5 部署到 prodkbdb.finally.click+ smoke test 4 case 通過

2. Triplet 編輯:使用既有 PUT/DELETE /records/:id

  • 2.1 設計修正:v3 萬物皆 Blocktriplet 是 record,既有 endpoints 已涵蓋。本任務組無需新增 endpoint。
  • 2.2 在 mira-app 前端「異見牆」實作呼叫 PUT /records/:id(待 mira 階段 3

3. OpenAPI spec 同步

  • 3.1 OpenAPIHono 自動產 swagger.jsonroute 用 createRoute 已自動納入)
  • 3.2 部署後驗證 swagger UI 顯示新 route(待手動驗證)

Phase 2:建三個 templates 完成

  • 4.1 確認 KBDB 內無同名 template(透過 GET /templates 確認)
  • 4.2 用 internal token POST /templates 建 data-source-configid: tpl-data-source-config
  • 4.3 用 internal token POST /templates 建 source-skillid: tpl-source-skill
  • 4.4 用 internal token POST /templates 建 wiki-pageid: tpl-wiki-page
  • 4.5 驗證:3/3 templates 在 GET /templates 列表內

風險追蹤

  • 風險 1partner key 跨 org 越權 unit test 已涵蓋(403 partner 越權)
  • 風險 2embedding 重算造成 D1 寫入 spike 改成 fire-and-forget(不 await),不阻塞 PATCH
  • 風險 3content_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 SDD block-ingest-source-fix 處理。

部署紀錄

  • 2026-05-06: Worker version b7df3c38-e138-41fb-a16c-cc9d2dfeebea 部署上線
  • Smoke test 通過:content 改寫 + hash 重算、tags 改寫、400 空 body、404 不存在