2.7 KiB
2.7 KiB
GitHub Primary Readiness Gate
| 項目 | 內容 |
|---|---|
| 日期 | 2026-05-13 |
| 狀態 | 草案,blocked by default |
| Schema | docs/schemas/source_control_primary_readiness_gate_v1.schema.json |
| Snapshot | docs/security/source-control-primary-readiness-gate.snapshot.json |
| 模式 | primary_readiness_gate_only |
| runtime 執行授權 | false |
0. 核心結論
source_control_primary_readiness_gate_v1 是 S4.0 的 GitHub primary readiness gate 草案。
它只回答一件事:如果長期方向要把 Gitea 降成本地 mirror / fallback,並把 GitHub 做成 primary,AwoooP 在任何切換前必須看到哪些 parity、owner、rollback 與人工批准 evidence。
它不是 cutover plan,也不是 refs sync plan。目前 primary_ready_count=0、github_primary_switch_authorized=false。
1. 目前狀態
| 指標 | 數量 |
|---|---|
| Candidate repos | 8 |
| In-scope repos | 7 |
| External scope review | 1 |
| Primary ready | 0 |
| Blocked in-scope | 7 |
| Approval required | 7 |
2. 全域 Gate
| Gate | 目前狀態 | 說明 |
|---|---|---|
| Gitea authenticated inventory | blocked | private/internal 全量 repo list 尚未完成 |
| refs truth / branch-tag parity | blocked | 3 個 mapped repos 仍有 refs drift |
| workflow / runner / secret name parity | missing evidence | S4.1 已建立 inventory 契約;尚未有實際 redacted workflow、webhook、runner、secret 名稱 snapshot |
| owner / visibility / canonical | pending review | 7 個 in-scope targets 仍需人工決策 |
| rollback ADR | not started | 尚未有逐 repo GitHub primary ADR 與 rollback plan |
3. AwoooP 可做
- 顯示每個 repo 的 readiness state、blockers 與 evidence refs。
- 顯示
primary_ready_count=0。 - 將 7 個 in-scope repos 維持在 approval / review lane。
- 顯示哪些 evidence 仍缺:Gitea authenticated inventory、refs truth、workflow/runner/secret name inventory、rollback ADR。
- 連到
source_control_workflow_secret_name_inventory_v1顯示 8 個 candidate repos 的 inventory lane 缺口與 S4.2 local evidence;只保存 secret 名稱與 owner,不保存 value。 - 把狀態寫入 Audit evidence 與 Operator Console。
4. AwoooP 不可做
- 不建立 GitHub repo。
- 不修改 repo visibility。
- 不 sync refs、不 delete refs、不 force push。
- 不切 GitHub primary。
- 不停用、刪除、封存或降級 Gitea repo。
- 不搬移或保存 secret value。
- 不顯示 repo、refs、primary switch 類 action button。
5. 階段定位
S4.0 只是把「切換前一定要看見什麼」先定義清楚。
這讓長期回到 GitHub 的方向可以繼續往前,但仍維持低摩擦:目前只 mirror、只顯示、只留痕,不執行。