diff --git a/apps/web/messages/en.json b/apps/web/messages/en.json
index 0b0d5c11..c28b69f3 100644
--- a/apps/web/messages/en.json
+++ b/apps/web/messages/en.json
@@ -4709,6 +4709,76 @@
}
}
},
+ "s49OwnerResponseEnvelopePreflightOutcome": {
+ "title": "S4.9 負責人回覆封套送件前結果分流",
+ "subtitle": "S2.104 把送件前檢查後的七種結果做成只讀分流。它只說明封套不通過時要補欄、修正判定、隔離敏感證據、修正範圍、拒收變更要求或維持等待;目前可進收件=0,不送出、不收件、不接受。",
+ "laneLabel": "結果分流",
+ "nextLabel": "下一步",
+ "guardLabel": "仍禁止",
+ "boundaryTitle": "結果分流邊界",
+ "summary": {
+ "lanes": {
+ "label": "分流",
+ "detail": "七條分流只供人工判讀。"
+ },
+ "ready": {
+ "label": "可進收件",
+ "detail": "目前仍是 0,不開收件。"
+ },
+ "quarantined": {
+ "label": "已隔離",
+ "detail": "目前仍是 0,不保存敏感載荷。"
+ },
+ "rejected": {
+ "label": "已拒收",
+ "detail": "目前仍是 0,不建立拒收紀錄。"
+ }
+ },
+ "items": {
+ "keepEnvelopeWaiting": {
+ "title": "維持封套等待",
+ "body": "封套尚未通過送件前檢查時,保持等待狀態,避免被誤認成已送出或已收到。",
+ "next": "回到封套欄位與送件前檢查,不建立任何收件事件。",
+ "guard": "不把等待狀態當進度增加、不開人工批准。"
+ },
+ "requestFieldCompletion": {
+ "title": "要求補齊欄位",
+ "body": "六欄任一缺漏時,要求補齊負責人角色 / 團隊、判定、理由、範圍、脫敏證據或後續負責人。",
+ "next": "只回到補欄,不標記可進收件。",
+ "guard": "不接受口頭補充、不用缺欄封套建立審批紀錄。"
+ },
+ "requestDispositionCorrection": {
+ "title": "要求修正判定",
+ "body": "判定值不在允許範圍或語意模糊時,要求負責人改成可驗收的明確判定。",
+ "next": "只要求修正判定,不推進主要來源或遷移判定。",
+ "guard": "不把同意、可進行或看起來沒問題當執行授權。"
+ },
+ "quarantineSensitiveEvidence": {
+ "title": "隔離敏感證據",
+ "body": "若封套含機密明文、權杖、私鑰、cookie、session 或私有憑證,必須先隔離。",
+ "next": "只進隔離與脫敏補證,不匯入原始載荷。",
+ "guard": "不保存機密明文、不轉送敏感載荷。"
+ },
+ "requestScopeCorrection": {
+ "title": "要求修正範圍",
+ "body": "受影響專案庫、端點、來源或範圍無法對應 S4.9 收件項時,要求補證或修正。",
+ "next": "只回到範圍補正,不自動擴大遷移範圍。",
+ "guard": "不讀取私有內容、不匯入來源。"
+ },
+ "rejectMutationRequest": {
+ "title": "拒收變更要求",
+ "body": "封套夾帶建立專案庫、改可見性、同步分支、修改工作流程或收集機密值時,直接分流為拒收。",
+ "next": "只記為需另開人工閘門的變更要求,不在封套內處理。",
+ "guard": "不從封套觸發 GitHub、Gitea、分支 / 標籤參照、工作流程、機密設定或執行器動作。"
+ },
+ "keepFollowupOwnerWaiting": {
+ "title": "維持後續負責人等待",
+ "body": "補證、隔離、拒收或後續 S4.10-S4.12 判定沒有可追溯角色或團隊時,維持等待。",
+ "next": "只要求補上後續負責人,不進入接受。",
+ "guard": "不把後續負責人當批准者、不開執行期閘門。"
+ }
+ }
+ },
"s49OwnerResponsePreflight": {
"title": "S4.9 Owner Response Intake Preflight",
"subtitle": "S2.48 surfaces the 6 S4.9 intake preflight checks in IwoooS: known attestation item, complete fields, allowed decision, redacted evidence, no execution request, and no accepted state until all five items are covered. This is preflight display only: no request send, received marking, or audit event creation.",
diff --git a/apps/web/messages/zh-TW.json b/apps/web/messages/zh-TW.json
index 64ec50ec..e263c80c 100644
--- a/apps/web/messages/zh-TW.json
+++ b/apps/web/messages/zh-TW.json
@@ -4710,6 +4710,76 @@
}
}
},
+ "s49OwnerResponseEnvelopePreflightOutcome": {
+ "title": "S4.9 負責人回覆封套送件前結果分流",
+ "subtitle": "S2.104 把送件前檢查後的七種結果做成只讀分流。它只說明封套不通過時要補欄、修正判定、隔離敏感證據、修正範圍、拒收變更要求或維持等待;目前可進收件=0,不送出、不收件、不接受。",
+ "laneLabel": "結果分流",
+ "nextLabel": "下一步",
+ "guardLabel": "仍禁止",
+ "boundaryTitle": "結果分流邊界",
+ "summary": {
+ "lanes": {
+ "label": "分流",
+ "detail": "七條分流只供人工判讀。"
+ },
+ "ready": {
+ "label": "可進收件",
+ "detail": "目前仍是 0,不開收件。"
+ },
+ "quarantined": {
+ "label": "已隔離",
+ "detail": "目前仍是 0,不保存敏感載荷。"
+ },
+ "rejected": {
+ "label": "已拒收",
+ "detail": "目前仍是 0,不建立拒收紀錄。"
+ }
+ },
+ "items": {
+ "keepEnvelopeWaiting": {
+ "title": "維持封套等待",
+ "body": "封套尚未通過送件前檢查時,保持等待狀態,避免被誤認成已送出或已收到。",
+ "next": "回到封套欄位與送件前檢查,不建立任何收件事件。",
+ "guard": "不把等待狀態當進度增加、不開人工批准。"
+ },
+ "requestFieldCompletion": {
+ "title": "要求補齊欄位",
+ "body": "六欄任一缺漏時,要求補齊負責人角色 / 團隊、判定、理由、範圍、脫敏證據或後續負責人。",
+ "next": "只回到補欄,不標記可進收件。",
+ "guard": "不接受口頭補充、不用缺欄封套建立審批紀錄。"
+ },
+ "requestDispositionCorrection": {
+ "title": "要求修正判定",
+ "body": "判定值不在允許範圍或語意模糊時,要求負責人改成可驗收的明確判定。",
+ "next": "只要求修正判定,不推進主要來源或遷移判定。",
+ "guard": "不把同意、可進行或看起來沒問題當執行授權。"
+ },
+ "quarantineSensitiveEvidence": {
+ "title": "隔離敏感證據",
+ "body": "若封套含機密明文、權杖、私鑰、cookie、session 或私有憑證,必須先隔離。",
+ "next": "只進隔離與脫敏補證,不匯入原始載荷。",
+ "guard": "不保存機密明文、不轉送敏感載荷。"
+ },
+ "requestScopeCorrection": {
+ "title": "要求修正範圍",
+ "body": "受影響專案庫、端點、來源或範圍無法對應 S4.9 收件項時,要求補證或修正。",
+ "next": "只回到範圍補正,不自動擴大遷移範圍。",
+ "guard": "不讀取私有內容、不匯入來源。"
+ },
+ "rejectMutationRequest": {
+ "title": "拒收變更要求",
+ "body": "封套夾帶建立專案庫、改可見性、同步分支、修改工作流程或收集機密值時,直接分流為拒收。",
+ "next": "只記為需另開人工閘門的變更要求,不在封套內處理。",
+ "guard": "不從封套觸發 GitHub、Gitea、分支 / 標籤參照、工作流程、機密設定或執行器動作。"
+ },
+ "keepFollowupOwnerWaiting": {
+ "title": "維持後續負責人等待",
+ "body": "補證、隔離、拒收或後續 S4.10-S4.12 判定沒有可追溯角色或團隊時,維持等待。",
+ "next": "只要求補上後續負責人,不進入接受。",
+ "guard": "不把後續負責人當批准者、不開執行期閘門。"
+ }
+ }
+ },
"s49OwnerResponsePreflight": {
"title": "S4.9 Owner Response 收件前 Preflight",
"subtitle": "S2.48 把 S4.9 的 6 個收件前檢查拉到 IwoooS:先確認回覆是否對應已知 attestation item、欄位完整、decision 合法、evidence 脫敏、沒有執行要求,且五個 items 到齊前不得 accepted。這裡只顯示 preflight,不寄送 request、不標記 received、不建立 audit event。",
diff --git a/apps/web/src/app/[locale]/iwooos/page.tsx b/apps/web/src/app/[locale]/iwooos/page.tsx
index 1b477216..bba4603a 100644
--- a/apps/web/src/app/[locale]/iwooos/page.tsx
+++ b/apps/web/src/app/[locale]/iwooos/page.tsx
@@ -119,6 +119,14 @@ type S49OwnerResponseEnvelopePreflightCheck = {
tone: 'steady' | 'warn' | 'locked'
}
+type S49OwnerResponseEnvelopePreflightOutcomeLane = {
+ key: string
+ lane: string
+ value: string
+ icon: typeof ShieldCheck
+ tone: 'steady' | 'warn' | 'locked'
+}
+
type Pillar = {
key: string
icon: typeof ShieldCheck
@@ -760,6 +768,41 @@ const s49OwnerResponseEnvelopePreflightBoundaries = [
'gitea_disablement_authorized=false',
]
+const s49OwnerResponseEnvelopePreflightOutcomeLanes: S49OwnerResponseEnvelopePreflightOutcomeLane[] = [
+ { key: 'keepEnvelopeWaiting', lane: 'L1', value: '等待', icon: Clock3, tone: 'warn' },
+ { key: 'requestFieldCompletion', lane: 'L2', value: '補欄', icon: ListChecks, tone: 'warn' },
+ { key: 'requestDispositionCorrection', lane: 'L3', value: '修正', icon: CheckCircle2, tone: 'warn' },
+ { key: 'quarantineSensitiveEvidence', lane: 'L4', value: '隔離', icon: Lock, tone: 'locked' },
+ { key: 'requestScopeCorrection', lane: 'L5', value: '補範圍', icon: Radar, tone: 'warn' },
+ { key: 'rejectMutationRequest', lane: 'L6', value: '拒收', icon: FileWarning, tone: 'locked' },
+ { key: 'keepFollowupOwnerWaiting', lane: 'L7', value: '等待', icon: SearchCheck, tone: 'warn' },
+]
+
+const s49OwnerResponseEnvelopePreflightOutcomeBoundaries = [
+ 's4_9_owner_response_envelope_preflight_outcome_lane_count=7',
+ 's4_9_owner_response_envelope_preflight_ready_for_intake_count=0',
+ 's4_9_owner_response_envelope_preflight_quarantined_count=0',
+ 's4_9_owner_response_envelope_preflight_rejected_count=0',
+ 's4_9_owner_response_envelope_submitted_count=0',
+ 's4_9_owner_response_envelope_accepted_count=0',
+ 's4_9_owner_response_request_sent=false',
+ 's4_9_owner_response_received_count=0',
+ 's4_9_owner_response_accepted_count=0',
+ 'owner_response_acceptance_gate_open=false',
+ 'audit_events_emitted=0',
+ 'progress_review_authorized=false',
+ 'runtime_execution_authorized=false',
+ 'active_runtime_gate_count=0',
+ 'action_buttons_allowed=false',
+ 'not_authorization=true',
+ 'secret_value_collection_allowed=false',
+ 'repo_creation_authorized=false',
+ 'refs_sync_authorized=false',
+ 'workflow_modification_authorized=false',
+ 'github_primary_switch_authorized=false',
+ 'gitea_disablement_authorized=false',
+]
+
const posturePillars: Pillar[] = [
{ key: 'exposure', icon: Radar, tone: 'warn' },
{ key: 'sourceControl', icon: GitBranch, tone: 'warn' },
@@ -2631,6 +2674,130 @@ function S49OwnerResponseEnvelopePreflightBoard() {
)
}
+function S49OwnerResponseEnvelopePreflightOutcomeCard({
+ item,
+}: {
+ item: S49OwnerResponseEnvelopePreflightOutcomeLane
+}) {
+ const t = useTranslations('iwooos.s49OwnerResponseEnvelopePreflightOutcome')
+ const Icon = item.icon
+ const textWrap = { overflowWrap: 'anywhere' as const, wordBreak: 'break-word' as const }
+ return (
+
+
+
+
+ {t('laneLabel')}
+
+
{item.lane}
+
+
+ {item.value}
+
+
+ {t(`items.${item.key}.title` as never)}
+
+
+ {t(`items.${item.key}.body` as never)}
+
+
+ {t('nextLabel')}
+
+ {t(`items.${item.key}.next` as never)}
+
+ {t('guardLabel')}
+
+ {t(`items.${item.key}.guard` as never)}
+
+
+
+ )
+}
+
+function S49OwnerResponseEnvelopePreflightOutcomeBoard() {
+ const t = useTranslations('iwooos.s49OwnerResponseEnvelopePreflightOutcome')
+ const summaryItems = [
+ { key: 'lanes', value: '7', tone: 'warn' as const },
+ { key: 'ready', value: '0', tone: 'locked' as const },
+ { key: 'quarantined', value: '0', tone: 'locked' as const },
+ { key: 'rejected', value: '0', tone: 'locked' as const },
+ ]
+ return (
+
+
+
{t('title')}
+
+ {t('subtitle')}
+
+
+
+ {summaryItems.map(item => (
+
+
+ {t(`summary.${item.key}.label` as never)}
+
+
+
+ {item.value}
+
+
+ {t(`summary.${item.key}.detail` as never)}
+
+
+ ))}
+
+
+ {s49OwnerResponseEnvelopePreflightOutcomeLanes.map(item => (
+
+ ))}
+
+
+
+
+
{t('boundaryTitle')}
+
+
+ {s49OwnerResponseEnvelopePreflightOutcomeBoundaries.map(item => (
+
+ {item}
+
+ ))}
+
+
+
+ )
+}
+
function PillarCard({ item }: { item: Pillar }) {
const t = useTranslations('iwooos.pillars')
const Icon = item.icon
@@ -6375,6 +6542,8 @@ export default function IwoooSPage({ params }: { params: { locale: string } }) {
+
+
{t('sourceControlReadiness.title')}
diff --git a/docs/LOGBOOK.md b/docs/LOGBOOK.md
index a491c39c..ecf680ee 100644
--- a/docs/LOGBOOK.md
+++ b/docs/LOGBOOK.md
@@ -1,3 +1,17 @@
+## 2026-05-24 | 資安供應鏈 S2.104:IwoooS S4.9 負責人回覆封套送件前結果分流
+
+**背景**:S2.103 已把封套送出前要檢查什麼放進 IwoooS;本輪補上檢查後會落到哪一種結果分流,避免使用者或 AwoooP 平行 Session 把補欄、修正、隔離、拒收或等待誤認成已送出、已收件或已接受。
+
+**完成**:
+- `/iwooos` 新增「S4.9 負責人回覆封套送件前結果分流」,顯示維持封套等待、要求補齊欄位、要求修正判定、隔離敏感證據、要求修正範圍、拒收變更要求、維持後續負責人等待七條分流。
+- 看板固定顯示分流=7、可進收件=0、已隔離=0、已拒收=0,並標示 `s4_9_owner_response_envelope_preflight_outcome_lane_count=7`、`s4_9_owner_response_envelope_preflight_ready_for_intake_count=0`、`s4_9_owner_response_envelope_preflight_quarantined_count=0`、`s4_9_owner_response_envelope_preflight_rejected_count=0`、`s4_9_owner_response_envelope_submitted_count=0`、`s4_9_owner_response_envelope_accepted_count=0`、`s4_9_owner_response_request_sent=false`、`owner_response_acceptance_gate_open=false`、`audit_events_emitted=0`、`progress_review_authorized=false`、`runtime_execution_authorized=false`、`active_runtime_gate_count=0`、`action_buttons_allowed=false`、`not_authorization=true`。
+- `security_mirror_status_rollup_v1` 新增 `s2_104_iwooos_s49_owner_response_envelope_preflight_outcome_board` 與 `show_iwooos_s49_owner_response_envelope_preflight_outcome_board`。
+- `security-mirror-progress-guard.py` 已納入送件前結果分流看板、i18n 鍵、七條分流與 false 邊界檢查。
+
+**仍禁止**:
+- S2.104 是 IwoooS 只讀送件前結果分流,不代表 request 已送出、owner response 已提交 / 已收到 / 已接受、audit event emitted、人工批准、審批紀錄建立、資安審批、機密明文值收集、Kali `/execute`、SSH 登入、主機更新、掃描 / 執行 / 修復、專案庫建立、分支 / 標籤參照同步、工作流程 / 機密設定修改、GitHub 主要來源切換、AwoooP production landing、Gitea 停用或執行期閘門。
+- 整體資安網百分比仍是 58%;下一次 headline 重估仍需實際 owner response evidence 通過 S4.9 preflight 與 S4.13 validation rollup。
+
## 2026-05-24 | 資安供應鏈 S2.103:IwoooS S4.9 負責人回覆封套送件前檢查
**背景**:S2.102 已把 S4.9 負責人回覆封套的六個必填欄位獨立呈現;本輪接著補上「封套送出前要先檢查什麼」,避免使用者或 AwoooP 平行 Session 把空白封套、欄位說明或未檢查回覆誤認成已送出、已收件或已接受。
diff --git a/docs/security/SECURITY-MIRROR-STATUS-ROLLUP.md b/docs/security/SECURITY-MIRROR-STATUS-ROLLUP.md
index 6694a152..b542569f 100644
--- a/docs/security/SECURITY-MIRROR-STATUS-ROLLUP.md
+++ b/docs/security/SECURITY-MIRROR-STATUS-ROLLUP.md
@@ -47,6 +47,7 @@
| IwoooS S4.9 人工收件工作單 | S2.101 已在 `/iwooos` 顯示 S4.9 Owner Response 人工收件工作單;收件項=5、每項必填欄位=6、已收到=0、已接受=0、已拒收=0;`s4_9_owner_response_request_sent=false`、`s4_9_owner_response_intake_open=false`、`owner_response_acceptance_gate_open=false`、`audit_events_emitted=0`、`progress_review_authorized=false`、`runtime_execution_authorized=false`、`active_runtime_gate_count=0`、`action_buttons_allowed=false`、`not_authorization=true`,仍不代表 request sent、owner response received / accepted、audit event emitted、人工批准、GitHub 主要來源切換、Gitea 停用、Kali / SSH / 主機更新或執行期授權 |
| IwoooS S4.9 回覆封套欄位 | S2.102 已在 `/iwooos` 顯示 S4.9 負責人回覆封套欄位;欄位=6、已填=0、已提交=0、已接受=0、已拒收=0;`s4_9_owner_response_envelope_field_count=6`、`s4_9_owner_response_envelope_filled_count=0`、`s4_9_owner_response_envelope_submitted_count=0`、`s4_9_owner_response_envelope_accepted_count=0`、`s4_9_owner_response_request_sent=false`、`owner_response_acceptance_gate_open=false`、`audit_events_emitted=0`、`progress_review_authorized=false`、`runtime_execution_authorized=false`、`active_runtime_gate_count=0`、`action_buttons_allowed=false`、`not_authorization=true`,仍不代表 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、GitHub 主要來源切換、Gitea 停用、Kali / SSH / 主機更新或執行期授權 |
| IwoooS S4.9 送件前檢查 | S2.103 已在 `/iwooos` 顯示 S4.9 負責人回覆封套送件前檢查;檢查項=6、通過=0、可送件=0、已提交=0、已接受=0;`s4_9_owner_response_envelope_preflight_check_count=6`、`s4_9_owner_response_envelope_preflight_passed_count=0`、`s4_9_owner_response_envelope_ready_to_submit_count=0`、`s4_9_owner_response_envelope_submitted_count=0`、`s4_9_owner_response_envelope_accepted_count=0`、`s4_9_owner_response_request_sent=false`、`owner_response_acceptance_gate_open=false`、`audit_events_emitted=0`、`progress_review_authorized=false`、`runtime_execution_authorized=false`、`active_runtime_gate_count=0`、`action_buttons_allowed=false`、`not_authorization=true`,仍不代表 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、GitHub 主要來源切換、Gitea 停用、Kali / SSH / 主機更新或執行期授權 |
+| IwoooS S4.9 送件前結果分流 | S2.104 已在 `/iwooos` 顯示 S4.9 負責人回覆封套送件前結果分流;分流=7、可進收件=0、已隔離=0、已拒收=0、已提交=0、已接受=0;`s4_9_owner_response_envelope_preflight_outcome_lane_count=7`、`s4_9_owner_response_envelope_preflight_ready_for_intake_count=0`、`s4_9_owner_response_envelope_preflight_quarantined_count=0`、`s4_9_owner_response_envelope_preflight_rejected_count=0`、`s4_9_owner_response_envelope_submitted_count=0`、`s4_9_owner_response_envelope_accepted_count=0`、`s4_9_owner_response_request_sent=false`、`owner_response_acceptance_gate_open=false`、`audit_events_emitted=0`、`progress_review_authorized=false`、`runtime_execution_authorized=false`、`active_runtime_gate_count=0`、`action_buttons_allowed=false`、`not_authorization=true`,仍不代表 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、GitHub 主要來源切換、Gitea 停用、Kali / SSH / 主機更新或執行期授權 |
| AwoooP approvals IwoooS owner response focus | S2.55 已把 S4.9-S4.12 owner response 下一個人工收件焦點放進 `/awooop/approvals` 只讀面板;received=0、accepted=0、active runtime gates=0、headline=58%、approval_record_created=false;仍不新增 approve、execute、deploy、primary switch、refs action 或 runtime gate |
| AwoooP contracts IwoooS security contract candidate | S2.56 已把四個 security mirror contract refs 放進 `/awooop/contracts` 只讀面板;total contracts=36、ready=33、partial=2、active runtime gates=0、contract_publish_authorized=false;仍不發布 contract revision、不改 lifecycle、不寫 platform contracts API、不新增 action button |
| AwoooP tenants IwoooS tenant scope candidate | S2.57 已把 AWOOOI first tenant、IwoooS security mirror、Kali 112 / Dev 168 / Dev 111 與 S4.9-S4.12 owner response waiting 放進 `/awooop/tenants` 只讀面板;host coverage=3、tenant policy changes=0、tenant_migration_mode_changed=false;仍不改 migration mode、不改 tenant policy、不寫 platform tenants API、不新增 action button |
@@ -235,6 +236,7 @@
| S2.101 IwoooS S4.9 Owner Response 人工收件工作單 | framework detail | 0 | 只在 `/iwooos` 顯示 S4.9 Owner Response 人工收件工作單,呈現 public-only / local gap 回覆、Gitea wooo endpoint 身分回覆、110 adjacent source scope 回覆、repo owner / canonical scope 回覆、legacy / inaccessible disposition 回覆五個收件項;s4_9_owner_response_work_order_item_count=5、s4_9_owner_response_required_field_count=6、s4_9_owner_response_received_count=0、s4_9_owner_response_accepted_count=0、s4_9_owner_response_rejected_count=0、s4_9_owner_response_request_sent=false、s4_9_owner_response_intake_open=false、owner_response_acceptance_gate_open=false、audit_events_emitted=0、progress_review_authorized=false、runtime_execution_authorized=false、active_runtime_gate_count=0、action_buttons_allowed=false、not_authorization=true,不把人工收件工作單當 request sent、owner response received / accepted、audit event emitted、人工批准、審批紀錄、專案庫建立、分支 / 標籤參照同步、工作流程 / 機密設定修改、主要來源切換、Gitea 停用、Kali / SSH / 主機更新或執行期授權 |
| S2.102 IwoooS S4.9 負責人回覆封套欄位 | framework detail | 0 | 只在 `/iwooos` 顯示 S4.9 負責人回覆封套欄位,呈現負責人角色 / 團隊、判定 / 處置、判定理由、受影響範圍、脫敏證據參照、後續負責人六個必填欄位;s4_9_owner_response_envelope_field_count=6、s4_9_owner_response_envelope_filled_count=0、s4_9_owner_response_envelope_submitted_count=0、s4_9_owner_response_envelope_accepted_count=0、s4_9_owner_response_envelope_rejected_count=0、s4_9_owner_response_request_sent=false、s4_9_owner_response_received_count=0、s4_9_owner_response_accepted_count=0、owner_response_acceptance_gate_open=false、audit_events_emitted=0、progress_review_authorized=false、runtime_execution_authorized=false、active_runtime_gate_count=0、action_buttons_allowed=false、not_authorization=true,不把回覆封套欄位當 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、審批紀錄、專案庫建立、分支 / 標籤參照同步、工作流程 / 機密設定修改、主要來源切換、Gitea 停用、Kali / SSH / 主機更新或執行期授權 |
| S2.103 IwoooS S4.9 負責人回覆封套送件前檢查 | framework detail | 0 | 只在 `/iwooos` 顯示 S4.9 負責人回覆封套送件前檢查,呈現六欄完整檢查、判定值允許檢查、脫敏證據檢查、範圍追溯檢查、變更要求拒收檢查、後續負責人追溯檢查六個檢查項;s4_9_owner_response_envelope_preflight_check_count=6、s4_9_owner_response_envelope_preflight_passed_count=0、s4_9_owner_response_envelope_ready_to_submit_count=0、s4_9_owner_response_envelope_submitted_count=0、s4_9_owner_response_envelope_accepted_count=0、s4_9_owner_response_request_sent=false、s4_9_owner_response_received_count=0、s4_9_owner_response_accepted_count=0、owner_response_acceptance_gate_open=false、audit_events_emitted=0、progress_review_authorized=false、runtime_execution_authorized=false、active_runtime_gate_count=0、action_buttons_allowed=false、not_authorization=true,不把送件前檢查當 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、審批紀錄、專案庫建立、分支 / 標籤參照同步、工作流程 / 機密設定修改、主要來源切換、Gitea 停用、Kali / SSH / 主機更新或執行期授權 |
+| S2.104 IwoooS S4.9 負責人回覆封套送件前結果分流 | framework detail | 0 | 只在 `/iwooos` 顯示 S4.9 負責人回覆封套送件前結果分流,呈現維持封套等待、要求補齊欄位、要求修正判定、隔離敏感證據、要求修正範圍、拒收變更要求、維持後續負責人等待七條分流;s4_9_owner_response_envelope_preflight_outcome_lane_count=7、s4_9_owner_response_envelope_preflight_ready_for_intake_count=0、s4_9_owner_response_envelope_preflight_quarantined_count=0、s4_9_owner_response_envelope_preflight_rejected_count=0、s4_9_owner_response_envelope_submitted_count=0、s4_9_owner_response_envelope_accepted_count=0、s4_9_owner_response_request_sent=false、s4_9_owner_response_received_count=0、s4_9_owner_response_accepted_count=0、owner_response_acceptance_gate_open=false、audit_events_emitted=0、progress_review_authorized=false、runtime_execution_authorized=false、active_runtime_gate_count=0、action_buttons_allowed=false、not_authorization=true,不把送件前結果分流當 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、審批紀錄、專案庫建立、分支 / 標籤參照同步、工作流程 / 機密設定修改、主要來源切換、Gitea 停用、Kali / SSH / 主機更新或執行期授權 |
headline 進度要再往上,至少需要下列任一高層 gate 有實質 evidence:
diff --git a/docs/security/SECURITY-SUPPLY-CHAIN-PROGRESS.md b/docs/security/SECURITY-SUPPLY-CHAIN-PROGRESS.md
index bd9b514e..ef412f67 100644
--- a/docs/security/SECURITY-SUPPLY-CHAIN-PROGRESS.md
+++ b/docs/security/SECURITY-SUPPLY-CHAIN-PROGRESS.md
@@ -5,7 +5,7 @@
| 日期 | 2026-05-17 |
| 狀態 | S0/S1 read-only evidence 建置中 |
| 本階段完成 | 資安供應鏈 contract manifest + Source Control Approval Board + Draft Reconcile Plan + Ref Detail Diff + Ref Truth Classification + Source Control Ref Truth Owner Response 收件包 + GitHub Primary Readiness Gate + GitHub Primary Rollback ADR + GitHub Target Owner Decision Response 收件包 + Gitea 認證清冊匯出請求 + Gitea 認證清冊匯入驗收契約 + Gitea 清冊覆蓋 Owner Attestation + Gitea Owner Attestation Approval Lane 對齊 + Gitea Owner Attestation Response 收件包 + Workflow / Secret Name Inventory + Workflow / Secret Name Local Evidence + Workflow / Secret Name Redacted Export Request + Workflow / Secret Name Owner Response 收件包 + Source Control Owner Response Validation Rollup + Kali 112 live integration status + Security Finding contract + Kali scan scope approval package + Security Approval Queue + S3 人工批准 Gate + S3 人工決策紀錄 + S3 人工審查封包 + S3 人工決策狀態轉移 + S3 後續 runtime gate 準備契約 + 鏡像 readiness index + 鏡像接收計畫 + 鏡像事件信封 + 鏡像路由矩陣 + 鏡像驗收契約 + 鏡像隔離契約 + 鏡像 dry-run 報告契約 + 鏡像狀態彙整契約 + IwoooS 前端態勢入口 + IwoooS posture projection contract + IwoooS 既有前端資安頁面整合 + IwoooS 覆蓋與邊界矩陣 + IwoooS 只讀資安處理旅程 + IwoooS owner evidence readiness board + IwoooS host coverage view + IwoooS host action gate matrix + IwoooS host evidence readiness board + IwoooS host evidence collection order + IwoooS host evidence intake preflight + IwoooS host evidence review outcome lanes + IwoooS host evidence review handoff packets + IwoooS host evidence reviewer checklist + IwoooS host evidence reviewer outcome lanes + IwoooS host owner decision candidate packets + IwoooS host owner decision review checklist + IwoooS host owner decision review outcome lanes + IwoooS host owner decision record draft packets + IwoooS host owner decision record draft review checklist + IwoooS host owner decision record draft review outcome lanes + IwoooS host owner decision record write-up packets + IwoooS host owner decision record write-up review checklist + IwoooS host owner decision record write-up review outcome lanes + IwoooS host owner decision record formal candidate packets + IwoooS host owner decision record formal candidate review checklist + IwoooS host owner decision record formal candidate review outcome lanes + IwoooS host owner decision record formal record queue packets + IwoooS host owner decision record formal record queue review checklist + IwoooS host owner decision record formal record queue review outcome lanes + IwoooS host owner decision record human handoff readiness packets + IwoooS host owner decision record human handoff readiness review checklist + IwoooS host owner decision record human handoff readiness review outcome lanes + IwoooS host owner decision record human record owner review candidate packets + IwoooS host owner decision record human record owner review candidate checklist + IwoooS host owner decision record human record owner review candidate outcome lanes + IwoooS host owner decision record human record owner review preparation packets + IwoooS host owner decision record human record owner review preparation checklist + IwoooS progress acceleration lanes + IwoooS owner response next-action focus + IwoooS S4.9 owner response preflight + IwoooS S4.9 owner response request templates + IwoooS progress hold movement gates + IwoooS AwoooP read-only landing readiness + IwoooS AwoooP cross-session handoff packets + AwoooP 首頁 IwoooS 資安鏡像候選 + AwoooP 工作鏈路 IwoooS 資安鏡像候選 + AwoooP 審批佇列 IwoooS owner response 只讀焦點 |
-| 本階段追加 | AwoooP 合約儀表板 IwoooS 資安契約只讀候選 + AwoooP 租戶管理 IwoooS 資安租戶範圍只讀候選 + AwoooP 執行監控 IwoooS 執行狀態只讀候選 + 既有安全 / 合規頁面 IwoooS 只讀反向橋接 + 告警 / 錯誤 / 授權 / 治理頁面 IwoooS 只讀反向橋接 + 稽核 / 工程審查頁面 IwoooS 深色只讀反向橋接 + IwoooS 前端資安頁面連接狀態板 + IwoooS GitHub 主要來源就緒度只讀狀態板 + AwoooP 工作鏈路 GitHub 主要來源就緒度只讀工作項 + AwoooP 合約儀表板 GitHub 主要來源就緒度合約只讀候選 + AwoooP 審批佇列 GitHub 主要來源就緒度審批邊界 + AwoooP 首頁 GitHub 主要來源就緒度只讀摘要 + AwoooP 租戶管理 GitHub 主要來源就緒度租戶範圍 + AwoooP 執行監控 GitHub 主要來源就緒度執行邊界 + IwoooS / AwoooP 資安可視區塊繁體中文呈現防護檢查 + AwoooP 執行詳情 / 審批詳情繁體中文呈現防護檢查 + AwoooP 首頁負責人回覆驗收總覽 + AwoooP 工作鏈路負責人回覆驗收只讀工作項 + AwoooP 合約儀表板負責人回覆驗收契約只讀候選 + AwoooP 審批佇列負責人回覆驗收只讀審查邊界 + AwoooP 租戶管理負責人回覆驗收租戶範圍 + AwoooP 執行監控負責人回覆驗收執行邊界 + AwoooP 執行詳情負責人回覆驗收詳情邊界 + AwoooP 審批決策負責人回覆驗收審批邊界 + IwoooS AwoooP 資安入口覆蓋狀態板 + IwoooS 階段式資安收斂節奏圖 + IwoooS 下一步人工收件作戰板 + IwoooS 人工回覆安全驗收閘道 + IwoooS 人工回覆審查結果分流 + IwoooS 人工決策準備佇列 + IwoooS 人工決策紀錄草稿防誤用 + IwoooS 人工決策正式紀錄負責人指派確認準備包 + IwoooS 人工決策正式紀錄負責人指派確認清單 + IwoooS 人工決策正式紀錄負責人指派確認結果分流 + IwoooS 人工決策正式紀錄負責人指派決策準備包 + IwoooS 人工決策正式紀錄負責人指派決策檢查清單 + IwoooS S4.9 負責人回覆封套欄位 + IwoooS S4.9 負責人回覆封套送件前檢查 |
+| 本階段追加 | AwoooP 合約儀表板 IwoooS 資安契約只讀候選 + AwoooP 租戶管理 IwoooS 資安租戶範圍只讀候選 + AwoooP 執行監控 IwoooS 執行狀態只讀候選 + 既有安全 / 合規頁面 IwoooS 只讀反向橋接 + 告警 / 錯誤 / 授權 / 治理頁面 IwoooS 只讀反向橋接 + 稽核 / 工程審查頁面 IwoooS 深色只讀反向橋接 + IwoooS 前端資安頁面連接狀態板 + IwoooS GitHub 主要來源就緒度只讀狀態板 + AwoooP 工作鏈路 GitHub 主要來源就緒度只讀工作項 + AwoooP 合約儀表板 GitHub 主要來源就緒度合約只讀候選 + AwoooP 審批佇列 GitHub 主要來源就緒度審批邊界 + AwoooP 首頁 GitHub 主要來源就緒度只讀摘要 + AwoooP 租戶管理 GitHub 主要來源就緒度租戶範圍 + AwoooP 執行監控 GitHub 主要來源就緒度執行邊界 + IwoooS / AwoooP 資安可視區塊繁體中文呈現防護檢查 + AwoooP 執行詳情 / 審批詳情繁體中文呈現防護檢查 + AwoooP 首頁負責人回覆驗收總覽 + AwoooP 工作鏈路負責人回覆驗收只讀工作項 + AwoooP 合約儀表板負責人回覆驗收契約只讀候選 + AwoooP 審批佇列負責人回覆驗收只讀審查邊界 + AwoooP 租戶管理負責人回覆驗收租戶範圍 + AwoooP 執行監控負責人回覆驗收執行邊界 + AwoooP 執行詳情負責人回覆驗收詳情邊界 + AwoooP 審批決策負責人回覆驗收審批邊界 + IwoooS AwoooP 資安入口覆蓋狀態板 + IwoooS 階段式資安收斂節奏圖 + IwoooS 下一步人工收件作戰板 + IwoooS 人工回覆安全驗收閘道 + IwoooS 人工回覆審查結果分流 + IwoooS 人工決策準備佇列 + IwoooS 人工決策紀錄草稿防誤用 + IwoooS 人工決策正式紀錄負責人指派確認準備包 + IwoooS 人工決策正式紀錄負責人指派確認清單 + IwoooS 人工決策正式紀錄負責人指派確認結果分流 + IwoooS 人工決策正式紀錄負責人指派決策準備包 + IwoooS 人工決策正式紀錄負責人指派決策檢查清單 + IwoooS S4.9 負責人回覆封套欄位 + IwoooS S4.9 負責人回覆封套送件前檢查 + IwoooS S4.9 負責人回覆封套送件前結果分流 |
| 原則 | 低摩擦分階段;文件、schema、read-only evidence 優先;不做 runtime enforcement、不切 primary |
## 0. 本階段完成後整體進度
@@ -28,7 +28,7 @@ python3 scripts/security/security-mirror-progress-guard.py
### 0.2 Headline 58% 不代表停滯
-近期 S4.10 請求包、範本狀態台帳、稽核事件範本、脫敏範例、收件檢查、收件預檢,S4.11 請求包 / 範本狀態台帳 / 稽核事件範本 / 脫敏範例 / 收件檢查 / 收件預檢,S4.12 請求包 / 範本狀態台帳 / 稽核事件範本 / 脫敏範例 / 收件檢查 / 收件預檢,S4.13 證據路由規則 / 顯示區塊 / 狀態轉移規則 / 審查清單 / 審查結果分流 / 審查稽核事件範本 / 審查稽核顯示區塊 / 審查稽核收件檢查 / 審查稽核脫敏範例 / 審查稽核保留規則 / 審查稽核保留檢查 / 審查稽核交接包 / 交接檢查 / 平行 Session 同步檢查 / 衝突分流 / 復原檢查 / 復原結果分流,S1.3 低摩擦非阻擋升級分流、S2.8 IwoooS 前端態勢入口,以及 S2.9-S2.103 IwoooS / AwoooP 資安投影契約都是有效進展,但它們是框架細節,不是負責人回覆、執行期閘門、生產匯入或 GitHub 主要來源就緒。因此整體百分比仍維持 58%,避免把只讀框架誤算成已落地執行。
+近期 S4.10 請求包、範本狀態台帳、稽核事件範本、脫敏範例、收件檢查、收件預檢,S4.11 請求包 / 範本狀態台帳 / 稽核事件範本 / 脫敏範例 / 收件檢查 / 收件預檢,S4.12 請求包 / 範本狀態台帳 / 稽核事件範本 / 脫敏範例 / 收件檢查 / 收件預檢,S4.13 證據路由規則 / 顯示區塊 / 狀態轉移規則 / 審查清單 / 審查結果分流 / 審查稽核事件範本 / 審查稽核顯示區塊 / 審查稽核收件檢查 / 審查稽核脫敏範例 / 審查稽核保留規則 / 審查稽核保留檢查 / 審查稽核交接包 / 交接檢查 / 平行 Session 同步檢查 / 衝突分流 / 復原檢查 / 復原結果分流,S1.3 低摩擦非阻擋升級分流、S2.8 IwoooS 前端態勢入口,以及 S2.9-S2.104 IwoooS / AwoooP 資安投影契約都是有效進展,但它們是框架細節,不是負責人回覆、執行期閘門、生產匯入或 GitHub 主要來源就緒。因此整體百分比仍維持 58%,避免把只讀框架誤算成已落地執行。
S2.50 也把「為什麼 58% 還不動」拆成五個可見 gate:owner response accepted、redacted payload ingestion、active runtime gate、GitHub primary ready、AwoooP read-only landing。這五個 gate 目前仍全部是 0 / false,所以 headline 不應被灌水提高。
@@ -166,6 +166,7 @@ S2.50 也把「為什麼 58% 還不動」拆成五個可見 gate:owner respons
| S2.101 IwoooS S4.9 Owner Response 人工收件工作單 | 已完成草案,在 `/iwooos` 顯示五個 S4.9 owner response 收件項、每項六個必填欄位、已收到=0、已接受=0、已拒收=0;仍不把人工收件工作單當成 request sent、owner response received / accepted、audit event emitted、人工批准、主要來源切換或執行期閘門 | 0 |
| S2.102 IwoooS S4.9 負責人回覆封套欄位 | 已完成草案,在 `/iwooos` 顯示六個 S4.9 負責人回覆封套欄位、已填=0、已提交=0、已接受=0、已拒收=0;仍不把回覆封套欄位當成 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、主要來源切換或執行期閘門 | 0 |
| S2.103 IwoooS S4.9 負責人回覆封套送件前檢查 | 已完成草案,在 `/iwooos` 顯示六個送件前檢查、通過=0、可送件=0、已提交=0、已接受=0;仍不把送件前檢查當成 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、主要來源切換或執行期閘門 | 0 |
+| S2.104 IwoooS S4.9 負責人回覆封套送件前結果分流 | 已完成草案,在 `/iwooos` 顯示七條送件前結果分流、可進收件=0、已隔離=0、已拒收=0、已提交=0、已接受=0;仍不把結果分流當成 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、主要來源切換或執行期閘門 | 0 |
headline 要再往上,需要 S4.9 / S4.10 / S4.11 / S4.12 任一 owner response 收到並通過脫敏驗收,或人工批准後出現 active runtime gate、redacted payload ingestion、GitHub primary readiness 這類落地 evidence。
@@ -288,6 +289,7 @@ headline 要再往上,需要 S4.9 / S4.10 / S4.11 / S4.12 任一 owner respons
| S2.101 IwoooS S4.9 Owner Response 人工收件工作單 | 完成草案 | `/iwooos` 新增 S4.9 Owner Response 人工收件工作單,看板列出 public-only / local gap、Gitea `wooo` endpoint 身分、110 adjacent source scope、repo owner / canonical scope、legacy / inaccessible disposition 五項回覆與六個必填欄位 | 使用者與另一個 AwoooP Session 能直接知道第一個會推動 58% 的 S4.9 owner response 要怎麼填、怎麼驗收與怎麼拒收;工作單仍不是 request sent、owner response received / accepted、audit event emitted、人工批准、主要來源切換或執行期閘門 |
| S2.102 IwoooS S4.9 負責人回覆封套欄位 | 完成草案 | `/iwooos` 新增 S4.9 負責人回覆封套欄位看板,列出負責人角色 / 團隊、判定 / 處置、判定理由、受影響範圍、脫敏證據參照、後續負責人六個欄位 | 使用者與另一個 AwoooP Session 能直接知道 S4.9 負責人回覆要用哪六欄填回、審查者要逐欄驗收什麼;封套欄位仍不是 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、主要來源切換或執行期閘門 |
| S2.103 IwoooS S4.9 負責人回覆封套送件前檢查 | 完成草案 | `/iwooos` 新增 S4.9 負責人回覆封套送件前檢查看板,列出六欄完整、判定值允許、脫敏證據、範圍追溯、變更要求拒收、後續負責人追溯六個檢查項 | 使用者與另一個 AwoooP Session 能直接知道封套送出前要先檢查什麼;送件前檢查仍不是 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、主要來源切換或執行期閘門 |
+| S2.104 IwoooS S4.9 負責人回覆封套送件前結果分流 | 完成草案 | `/iwooos` 新增 S4.9 負責人回覆封套送件前結果分流看板,列出維持封套等待、要求補齊欄位、要求修正判定、隔離敏感證據、要求修正範圍、拒收變更要求、維持後續負責人等待七條分流 | 使用者與另一個 AwoooP Session 能直接知道送件前檢查後要回到哪個補正或隔離分流;結果分流仍不是 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、主要來源切換或執行期閘門 |
| S3 approval gate | 進行中 | `security_approval_gate_v1` 已建立 8 個人工 gate items:7 pending、1 block candidate、0 approved | 不得繞過人工批准;批准後仍需 follow-up runtime gate |
| S3.0 人工批准 Gate 契約 | 完成草案 | 定義批准範圍、決策選項、required reviewers、still forbidden 與 follow-up runtime gate | AwoooP 可記錄決策,不可執行 gate item |
| S3.1 人工決策紀錄契約 | 完成草案 | `security_approval_decision_record_v1` 已建立;目前 0 筆 decision records、0 個 runtime action 授權 | AwoooP 可稽核決策,不可把決策當執行 |
diff --git a/docs/security/security-mirror-status-rollup.snapshot.json b/docs/security/security-mirror-status-rollup.snapshot.json
index de16d083..37827c7f 100644
--- a/docs/security/security-mirror-status-rollup.snapshot.json
+++ b/docs/security/security-mirror-status-rollup.snapshot.json
@@ -1706,6 +1706,18 @@
"runtime_delta": false,
"execution_authorized": false,
"not_authorization": true
+ },
+ {
+ "delta_id": "s2_104_iwooos_s49_owner_response_envelope_preflight_outcome_board",
+ "display_order": 133,
+ "completed_stage": "S2.104 IwoooS S4.9 負責人回覆封套送件前結果分流",
+ "progress_axis": "framework_detail",
+ "headline_percent_delta": 0,
+ "framework_delta_visible": true,
+ "why_headline_unchanged": "IwoooS 只新增 S4.9 負責人回覆封套送件前結果分流看板,顯示維持封套等待、要求補齊欄位、要求修正判定、隔離敏感證據、要求修正範圍、拒收變更要求與維持後續負責人等待七條只讀分流,並固定可進收件=0、已隔離=0、已拒收=0、已提交=0、已接受=0;s4_9_owner_response_envelope_preflight_outcome_lane_count=7、s4_9_owner_response_envelope_preflight_ready_for_intake_count=0、s4_9_owner_response_envelope_preflight_quarantined_count=0、s4_9_owner_response_envelope_preflight_rejected_count=0、s4_9_owner_response_envelope_submitted_count=0、s4_9_owner_response_envelope_accepted_count=0、s4_9_owner_response_request_sent=false、owner_response_acceptance_gate_open=false、audit_events_emitted=0、progress_review_authorized=false、runtime_execution_authorized=false、active_runtime_gate_count=0、action_buttons_allowed=false,不把送件前結果分流當 request sent、owner response submitted / received / accepted、audit event emitted、progress review、專案庫 / 分支與標籤參照 / 工作流程 / 機密設定、主要來源切換或執行期授權。",
+ "runtime_delta": false,
+ "execution_authorized": false,
+ "not_authorization": true
}
],
"next_safe_actions": [
@@ -2510,6 +2522,22 @@
"從 S4.9 送件前檢查呼叫 Kali、開 SSH、更新主機、切 GitHub 主要來源、停用 Gitea、收機密明文值或開執行期閘門"
]
},
+ {
+ "action_id": "show_iwooos_s49_owner_response_envelope_preflight_outcome_board",
+ "title": "IwoooS 顯示 S4.9 負責人回覆封套送件前結果分流",
+ "mode": "observe",
+ "source_contract": "source_control_owner_response_validation_rollup_v1",
+ "allowed_processing": [
+ "在 /iwooos 顯示 S2.104 S4.9 負責人回覆封套送件前結果分流",
+ "顯示維持封套等待、要求補齊欄位、要求修正判定、隔離敏感證據、要求修正範圍、拒收變更要求與維持後續負責人等待七條只讀分流",
+ "只讓人工知道送件前檢查後要回到哪個補正或隔離分流,不自動送出 request、不標記 submitted / received / accepted、不建立 audit event、不開 progress review"
+ ],
+ "blocked_processing": [
+ "把 S4.9 送件前結果分流當 request sent、owner response submitted / received / accepted、audit event emitted、人工批准、正式審批紀錄或 progress delta",
+ "從 S4.9 送件前結果分流建立專案庫、改可見性、同步 / 刪除 / 強制推送分支或標籤參照,或修改工作流程 / 機密設定",
+ "從 S4.9 送件前結果分流呼叫 Kali、開 SSH、更新主機、切 GitHub 主要來源、停用 Gitea、收機密明文值或開執行期閘門"
+ ]
+ },
{
"action_id": "enforce_traditional_chinese_security_surface_wording",
"title": "IwoooS / AwoooP 資安可視區塊維持繁體中文呈現",
diff --git a/scripts/security/security-mirror-progress-guard.py b/scripts/security/security-mirror-progress-guard.py
index 36db57c6..ab3c3ff9 100755
--- a/scripts/security/security-mirror-progress-guard.py
+++ b/scripts/security/security-mirror-progress-guard.py
@@ -352,6 +352,7 @@ def validate(root: Path) -> None:
"s2_101_iwooos_s49_owner_response_work_order_board",
"s2_102_iwooos_s49_owner_response_envelope_board",
"s2_103_iwooos_s49_owner_response_envelope_preflight_board",
+ "s2_104_iwooos_s49_owner_response_envelope_preflight_outcome_board",
]
assert_equal(
"progress_delta_ledger.delta_ids",
@@ -7719,6 +7720,90 @@ def validate(root: Path) -> None:
list(web_messages_en["iwooos"]["s49OwnerResponseEnvelopePreflight"]["items"].keys()),
key,
)
+ assert_text_contains(
+ "iwooos_page.s49_owner_response_envelope_preflight_outcome_lanes",
+ iwooos_projection_page,
+ "s49OwnerResponseEnvelopePreflightOutcomeLanes",
+ )
+ assert_text_contains(
+ "iwooos_page.s49_owner_response_envelope_preflight_outcome_testid",
+ iwooos_projection_page,
+ 'data-testid="iwooos-s49-owner-response-envelope-preflight-outcome-board"',
+ )
+ assert_text_contains(
+ "iwooos_page.s49_owner_response_envelope_preflight_outcome_component",
+ iwooos_projection_page,
+ "S49OwnerResponseEnvelopePreflightOutcomeBoard",
+ )
+ for text in [
+ "s4_9_owner_response_envelope_preflight_outcome_lane_count=7",
+ "s4_9_owner_response_envelope_preflight_ready_for_intake_count=0",
+ "s4_9_owner_response_envelope_preflight_quarantined_count=0",
+ "s4_9_owner_response_envelope_preflight_rejected_count=0",
+ "s4_9_owner_response_envelope_submitted_count=0",
+ "s4_9_owner_response_envelope_accepted_count=0",
+ "s4_9_owner_response_request_sent=false",
+ "s4_9_owner_response_received_count=0",
+ "s4_9_owner_response_accepted_count=0",
+ "owner_response_acceptance_gate_open=false",
+ "audit_events_emitted=0",
+ "progress_review_authorized=false",
+ "runtime_execution_authorized=false",
+ "active_runtime_gate_count=0",
+ "action_buttons_allowed=false",
+ "not_authorization=true",
+ "secret_value_collection_allowed=false",
+ "repo_creation_authorized=false",
+ "refs_sync_authorized=false",
+ "workflow_modification_authorized=false",
+ "github_primary_switch_authorized=false",
+ "gitea_disablement_authorized=false",
+ ]:
+ assert_text_contains(
+ "iwooos_page.s49_owner_response_envelope_preflight_outcome_boundary",
+ iwooos_projection_page,
+ text,
+ )
+ assert_contains(
+ "web_messages.zh-TW.iwooos.s49OwnerResponseEnvelopePreflightOutcome",
+ list(web_messages_zh["iwooos"].keys()),
+ "s49OwnerResponseEnvelopePreflightOutcome",
+ )
+ assert_contains(
+ "web_messages.en.iwooos.s49OwnerResponseEnvelopePreflightOutcome",
+ list(web_messages_en["iwooos"].keys()),
+ "s49OwnerResponseEnvelopePreflightOutcome",
+ )
+ for key in ["title", "subtitle", "summary", "items", "boundaryTitle"]:
+ assert_contains(
+ "web_messages.zh-TW.iwooos.s49OwnerResponseEnvelopePreflightOutcome.keys",
+ list(web_messages_zh["iwooos"]["s49OwnerResponseEnvelopePreflightOutcome"].keys()),
+ key,
+ )
+ assert_contains(
+ "web_messages.en.iwooos.s49OwnerResponseEnvelopePreflightOutcome.keys",
+ list(web_messages_en["iwooos"]["s49OwnerResponseEnvelopePreflightOutcome"].keys()),
+ key,
+ )
+ for key in [
+ "keepEnvelopeWaiting",
+ "requestFieldCompletion",
+ "requestDispositionCorrection",
+ "quarantineSensitiveEvidence",
+ "requestScopeCorrection",
+ "rejectMutationRequest",
+ "keepFollowupOwnerWaiting",
+ ]:
+ assert_contains(
+ "web_messages.zh-TW.iwooos.s49OwnerResponseEnvelopePreflightOutcome.items",
+ list(web_messages_zh["iwooos"]["s49OwnerResponseEnvelopePreflightOutcome"]["items"].keys()),
+ key,
+ )
+ assert_contains(
+ "web_messages.en.iwooos.s49OwnerResponseEnvelopePreflightOutcome.items",
+ list(web_messages_en["iwooos"]["s49OwnerResponseEnvelopePreflightOutcome"]["items"].keys()),
+ key,
+ )
for key in [
"title",
"subtitle",