Files
Arcrun/.agents/specs/component-gatekeeping/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.7 KiB
Raw Blame History

Requirements: Component Gatekeeping(零件投稿真把關)

2026-05-29 建立(richblack 確認)。對應第一期 BACKLOG 步驟 4(補零件庫真把關)+ 步驟 5(人類閘門 + 白名單 hook)。 判準源:DECISIONS.md §1(工作流是 default / 建零件人類閘門 / ABC 三管齊下)、§7(讓 AI 不做歪三層機制 + 閉環)、§3c/§7(禁假綠)。


背景

第一期要把「零件投稿」從「無審核」變成「真的會擋」的把關。現況:

  • registry/src/actions/sandboxAcceptance.tssize_check / syscall_scan 已實作;cold_start / gherkin_tests / runtime_compat 是 return null mock。
  • submitComponent.ts:跑 sandboxAcceptance → 派 hash → 寫 KV。無假零件偵測、無人類閘門。
  • 風險(DECISIONS):CC 把自用服務(通訊錄/帳本)做成零件進公共庫 → 全生態能打 → 機密外洩。

需求

R1 — Gherkin 驗收真實作(取代 mock

  • runGherkinTests 要真的跑零件 WASM:對每個 gherkin_tests[] 的 given → 餵 stdin → 比對 stdout 是否 then_contains
  • 失敗 → 退稿,回明確 reason + guide anchor。
  • recipe 不適用 GherkinDECISIONS §1recipe 驗收 = 2xx);本需求只針對 WASM 零件投稿。

R2 — 假零件偵測(退稿並指回正路)

依 DECISIONS §1 判準,投稿零件若滿足任一,退稿:

  • (a) contract 或(可得的)原碼出現具體外部服務 URL / domain
  • (b) 宣告能力是 http_request 子集(打某固定 endpoint) 退稿訊息要指回正路:「這該是 recipe / 工作流,不是零件」。

R3 — 純 WASI preview1 / 零宿主依賴把關

  • 擴充 syscall 掃描:確認零件只依賴 WASI preview1 + u6u host functions 白名單,無其他宿主特定依賴(避免 runtime 鎖定債,DECISIONS §4)。
  • 冷啟動 / runtime 相容兩步可暫留 mock,但明確標「未實作」,不可假裝通過(§3c/§7 禁假綠)。

R4 — 建零件的人類閘門(核心,BACKLOG 步驟 5 強化規格)

  • 把關點 = 建立零件的 API 本身registry submit endpoint),不是寫檔案。CLI / MCP / Python lib / JS lib 四路全收斂到這關。
  • submit 預設拒絕,除非請求帶:
    • (a) 人類已確認憑證(CLI acr component create 強制互動式問人類,AI 非互動環境生不出)
    • (b) 舉證 reason_why_not_workflow(AI 須證明工作流為何做不到;舉證責任在 AI,預設假設工作流能做)
  • 缺 → 403 + 指回正路(先試工作流)。
  • 誠實限制:沒技術能 100% 防 AI 假冒人類確認;靠閘門 + 舉證留記錄 + mindset 明示「絕不代替人類確認」+ 軌跡可審計,讓假冒成明確越界。

R5 — 白名單 + 本機 hook 兜底

  • MVP_COMPONENTS.txt 白名單檔。
  • pre-write / pre-bash hookCC 直接在 registry/components/{白名單外新名}/ 造目錄或 mkdir → exit 2(擋繞過 API 直接改 repo 等 CI 部署的旁門)。
  • pre-write hookregistry/components/ 下出現 .ts(非 AssemblyScript)→ exit 2(現有 hook 已部分做)。

R6 — 不限制自由

  • 不做「audience 宣告 / 禁止自用進公共庫」式的限制(DECISIONS:別人要建零件是他的自由)。
  • 唯一硬約束:零件 = 只打一個 endpoint 的薄殼。閘門是「要建得先說服人 + 舉證」的摩擦,非禁止。
  • arcrun 不做授權判斷(能否打通由發 key 的服務裁決)——把關針對「是否該是零件」,不針對「誰能打哪個 API」。

非目標

  • Phase 5 用戶自製零件 R2 上傳(未啟用)。
  • registry KV schema 大改(用既有結構)。
  • 完整的 audit trail 系統(DECISIONS §7 事後機制第一層,另議)。