/** * api-recipe-seeds.ts(server 端,唯一真相) * * 現役 API recipe 的種子定義。self-host 新帳號裝好後,POST /init/seed 端點把這些灌進空的 RECIPES KV。 * * API recipe = http_request + 固定設定(endpoint/method 模板)。 * 不需 deploy Worker,cypher-executor 執行時直接 fetch(見 routes/recipes.ts)。 * * 為何放在 cypher-executor/src(薄殼原則 rule 07 + 壓測 §5.5): * - 「裝好之後預設有哪些 recipe」是 API 的能力,不是 CLI 的。seed 應由 API 端點完成 * (POST /init/seed),CLI/MCP 只呼叫一次。種子資料是這個能力的一部分,故放 server。 * - 種子的 endpoint 字串(sheets.googleapis.com 等)是 recipe 的「資料欄位」(宣告打哪), * 非 TS 裡的呼叫實作;真正呼叫仍走零件 / http_request。rule 02 §2.2 hook 已對本檔加例外 * (richblack 2026-06-06 授權,與 auth-recipe-seeds.ts 同理由)。 * * 來源:2026-06-01 從 prod cypher.arcrun.dev/recipes 逐一查得的現役定義。 * 對應 SDD:.agents/specs/arcrun/sdk-and-website/self-hosted-init.md §5 * * KBDB recipe(kbdb_*)採 Supabase 模式(richblack 2026-06-02): * 進 seed = 展示能力(引子)。使用者要用 → 去 arcrun 取統一 API Key 當 credential。 * FOLLOW-UP(KBDB 端):endpoint 現為 kbdb.finally.click,KBDB 應改用統一對外網址; * KBDB 改網址後同步更新此處。seed 先照現況進。 */ export interface ApiRecipeSeed { canonical_id: string; display_name: string; description?: string; endpoint: string; method: string; auth_service?: string; } export const API_RECIPE_SEEDS: ApiRecipeSeed[] = [ // ── KBDB(Supabase 模式,auth_service=kbdb static_key)── { canonical_id: 'kbdb_get', display_name: 'KBDB Get', description: 'GET 讀取 block / 查詢。_path 帶查詢路徑。auth: kbdb static_key。', endpoint: 'https://kbdb.finally.click{{_path}}', method: 'GET', auth_service: 'kbdb', }, { canonical_id: 'kbdb_create_block', display_name: 'KBDB Create Block', description: 'POST /blocks 建立 block。body 帶 block 欄位(content/type/page_name/source/user_id 等)。auth: kbdb static_key。', endpoint: 'https://kbdb.finally.click/blocks', method: 'POST', auth_service: 'kbdb', }, { canonical_id: 'kbdb_patch_block', display_name: 'KBDB Patch Block', description: 'PATCH /blocks/:id 局部更新。_path 帶 /blocks/{id},body 帶要改的欄位。auth: kbdb static_key。', endpoint: 'https://kbdb.finally.click{{_path}}', method: 'PATCH', auth_service: 'kbdb', }, { canonical_id: 'kbdb_delete', display_name: 'KBDB Delete', description: 'DELETE /blocks/:id 刪除 block。_path 帶 /blocks/{id}。auth: kbdb static_key。', endpoint: 'https://kbdb.finally.click{{_path}}', method: 'DELETE', auth_service: 'kbdb', }, { canonical_id: 'kbdb_ingest', display_name: 'KBDB Ingest', description: 'POST /blocks/ingest 批次寫入。body 帶 input。auth: kbdb static_key。', endpoint: 'https://kbdb.finally.click/blocks/ingest', method: 'POST', auth_service: 'kbdb', }, // ── Google(service_account)── { canonical_id: 'gmail_send', display_name: 'Gmail Send', description: '寄 Gmail。POST messages/send,body 帶 raw(base64url MIME)。auth: google service_account。', endpoint: 'https://gmail.googleapis.com/gmail/v1/users/me/messages/send', method: 'POST', auth_service: 'google_gmail_sa', }, { canonical_id: 'google_sheets_append', display_name: 'Google Sheets Append', // 壓測階段 12 修正:append 官方 API 是 POST .../values/{range}:append(PUT 是 values.update 覆寫的動詞), // 種子寫死 PUT 導致每個 self-host 用戶 seed 到壞 recipe(PUT :append → Google 400)。 // body 形狀屬工作流,泛用種子不寫死欄位 → 由工作流的 _path + body 處理(body_from 機制待 §13.4 補)。 description: '追加一列到 Sheets。POST .../values/{range}:append?valueInputOption=RAW,body 帶 {values:[[...]]}。auth: google service_account。', endpoint: 'https://sheets.googleapis.com{{_path}}', method: 'POST', auth_service: 'google_sheets_sa', }, { canonical_id: 'google_sheets_read', display_name: 'Google Sheets Read', description: '讀 Sheets。GET values。_path 帶完整路徑。auth: google service_account。', endpoint: 'https://sheets.googleapis.com{{_path}}', method: 'GET', auth_service: 'google_sheets_sa', }, // ── 訊息(static_key)── { canonical_id: 'telegram_send', display_name: 'Telegram Send', description: 'Telegram sendMessage。token 在 URL path({{auth.bot_token}}),body 帶 chat_id+text。auth: static_key path 注入。', endpoint: 'https://api.telegram.org/bot{{auth.bot_token}}/sendMessage', method: 'POST', auth_service: 'telegram', }, { canonical_id: 'line_notify_send', display_name: 'LINE Notify', description: 'LINE Notify 推訊息。POST notify,body 帶 message(form-urlencoded)。auth: static_key Bearer line token。', endpoint: 'https://notify-api.line.me/api/notify', method: 'POST', auth_service: 'line_notify', }, ];