Files
Arcrun/.agents/specs/data-exfil-warning/requirements.md
T
uncle6me-web 922a57fe34 arcrun — AI workflow execution engine (clean history)
Self-hosted 開源:WASM 零件 + recipe + cypher-executor,跑在你自己的 Cloudflare。

此為重建的乾淨歷史起點(移除曾誤 commit 的 GCP SA 金鑰,舊歷史保留在
richblack/arcrun 與本地 backup 分支)。含:
- acr init --self-hosted installer(建 KV/R2 + codeload 拉預編譯 wasm + wrangler deploy + seed recipe)
- recipe push 把關(資料外流提醒 + 打通檢查)
- 19 個正當零件預編譯 wasm(claude_api/km_writer/kbdb_upsert_block 排除:違反 DECISIONS §1)
- CLI / cypher-executor / registry / 完整 SDD

Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
2026-06-03 15:52:38 +08:00

3.9 KiB
Raw Blame History

Requirements: 資料外流警示(Data Exfiltration Warning

2026-05-30 建立(richblack 確認)。資安優先、及早做。 判準源:DECISIONS §7(讓 AI 不做歪 + 閉環)、§0(減少不可控依賴 / 風險);BACKLOG 步驟 5b。


背景與風險

arcrun 讓「產生 API / 把資料送出去」變很簡單(一堆資料 + webhook trigger = APIrecipe = 打某 endpoint)。 這個「簡單」本身是風險:簡單到 AI 可能在用戶不知情下,把含個資的東西變成可被呼叫的 endpoint,或把 敏感資料送到非預期對象。

richblack 的核心情境:用戶有個 Google Sheets 存所有朋友的個資。正確用法是「call 它查詢」(自用)。 但若 AI 把它變成一個 recipe / workflow送資料到非預期對象(公開 webhook、公司群、外部 endpoint), 且沒做認證 → 所有資料裸奔。

關鍵原則(richblack 2026-05-30):

  1. 不分公私庫都要警示。私人庫(公司用)一樣會出事(不小心把個資 POST 到公司群)。觸發點不是「推公共」, 是「這動作會讓資料流向某處」。
  2. 不禁止用戶公開 / 送資料(他要放什麼給誰是他的自由)——但要確定他自己明示同意了,不是 AI 替他決定。
  3. 兩道防線(a) hook 在 AI 動手前警告(防在前);(b) API 層在資料真送出前攔(防在後)。不論哪條路都攔。

需求

R1 — API 層警示(資料送出前需人類同意,不分公私庫)

任何「把資料送往某目的地」的 API 動作,在執行/儲存前需人類明示同意。涵蓋(待 design 盤準):

  • acr recipe pushrecipe 定義一個 endpoint(資料去向)。
  • acr pushworkflow):workflow 可能含「讀敏感源 → 送往某 endpoint」的節點。
  • webhook trigger 部署:把 workflow 變成可被呼叫的 API。
  • 未來「recipe 貢獻公共庫」路徑(BACKLOG 飛輪項)。

同意內容要讓人看得懂風險:這個動作會把 [什麼資料] 送到 [哪個目的地],需不需要 credential 保護?確認?

R2 — hook 在 AI 動手前警告

AI 要做這類動作(寫含外部 endpoint 的 recipe/workflow、跑會送資料的指令)前,hook 先警告 + 要人類確認。 這是「防在前」——在 AI 本機動手當下就提醒,不等到 API 層才攔(省一趟、且更早讓人看到)。

R3 — 誠實的偵測範圍(不假裝能全防)

「敏感資料送到非預期對象」機械上難完整偵測。本系統做可機械判斷的部分,誠實標明擋不住的:

  • 能偵測:動作含「外部 endpoint」(recipe endpoint / workflow http 節點 / webhook 對外)。
  • 難偵測:「這份資料是否敏感」「這個目的地是否非預期」——這需要語境,機器判不準。
  • 做法:偵測到「資料 → 外部目的地」的動作就警示,由人類判斷該資料/目的地是否該放行(人類同意是判斷點,機器只負責「攔下來問」)。

R4 — 不擋自用、不製造過度摩擦

  • 純自用、不送資料出去的動作(acr run 本機、查詢類)不該被警示淹沒。
  • 警示要精準在「資料外流」動作,不是每個動作都問(否則用戶會盲目按 yes,警示失效)。

R5 — 與既有閘門一致

  • 與「建零件人類閘門」(component-gatekeeping)同精神:AI 不可替人類決定有外洩風險的動作。
  • 與「arcrun 不做授權判斷」一致:不判斷「該不該送」,只「攔下來讓人類明示同意」。

非目標

  • 用戶自己的 API 保護機制(入站認證:發 key 給別人 / 權限 / 限流)—— 另列 BACKLOG 待決策。
  • 完整 DLP(資料外洩防護)系統 / 內容掃描判斷敏感度 —— 機器判不準,不做。
  • recipe 公共貢獻路徑本身 —— 未實作(飛輪項),本系統只要求它未來內建同意閘門。