diff --git a/apps/web/src/app/[locale]/iwooos/page.tsx b/apps/web/src/app/[locale]/iwooos/page.tsx
index f9e7eeb8..b07224eb 100644
--- a/apps/web/src/app/[locale]/iwooos/page.tsx
+++ b/apps/web/src/app/[locale]/iwooos/page.tsx
@@ -36,6 +36,7 @@ import Link from 'next/link'
import { useTranslations } from 'next-intl'
import { useEffect, useRef, useState, type ReactNode } from 'react'
import { AppLayout } from '@/components/layout'
+import { publicBoundaryText } from '@/lib/public-security-redaction'
import {
apiClient,
type IwoooSHighValueConfigControlCoverageCategory,
@@ -2936,7 +2937,7 @@ const ownerEvidenceIntakePreflightFallbackItems: OwnerEvidenceIntakePreflightDis
rank: 'P0',
title: '機密中繼資料 / 工作流程 / 執行器',
state: 'coverage-derived candidate',
- body: '只收 secret name、workflow diff、runner attestation、run readback 與 log redaction;secret value / runner token 拒收。',
+ body: '只收機密名稱、工作流程差異、執行器證明、run 讀回與日誌遮罩證據;機密明文與執行器憑證一律拒收。',
icon: Lock,
tone: 'locked',
},
@@ -9959,11 +9960,11 @@ function IwoooSWazuhManagerRegistryReviewerValidationBoard() {
}}
>
{slot.slot_id}
-
{slot.title}
+ {publicBoundaryText(slot.title)}
{t('slotReceivedLabel')}:{slot.received ? '1' : '0'}
{t('slotAcceptedLabel')}:{slot.accepted ? '1' : '0'}
- {t('slotNextGateLabel')}:{slot.next_gate}
+ {t('slotNextGateLabel')}:{publicBoundaryText(slot.next_gate)}
)) : (
@@ -9988,12 +9989,12 @@ function IwoooSWazuhManagerRegistryReviewerValidationBoard() {
{check.check_id}
- {check.title}
+ {publicBoundaryText(check.title)}
- {check.required_evidence}
+ {publicBoundaryText(check.required_evidence)}
- {check.failure_lane}
+ {publicBoundaryText(check.failure_lane)}
)) : (
@@ -10034,7 +10035,7 @@ function IwoooSWazuhManagerRegistryReviewerValidationBoard() {
overflowWrap: 'anywhere',
}}
>
- {item}
+ {publicBoundaryText(item)}
))}
diff --git a/apps/web/src/lib/public-security-redaction.ts b/apps/web/src/lib/public-security-redaction.ts
index e2c19348..8b6349c3 100644
--- a/apps/web/src/lib/public-security-redaction.ts
+++ b/apps/web/src/lib/public-security-redaction.ts
@@ -1,4 +1,11 @@
export function publicBoundaryText(value: string): string {
+ const redacted = value
+ .replace(/live Wazuh/gi, "只讀管理端")
+ .replace(/runtime action/gi, "執行期變更")
+ .replace(/host write/gi, "主機變更")
+ .replace(/active response/gi, "主動回應流程")
+ .replace(/secret value/gi, "機密明文")
+ .replace(/raw secret/gi, "原始機密");
const labels: Record = {
"security_compliance_route_preserved=true": "安全合規路由已保留,並整合到 IwoooS 權威入口。",
"security_compliance_removed=false": "安全合規頁沒有被移除,但不再作為孤立入口。",
@@ -16,44 +23,44 @@ export function publicBoundaryText(value: string): string {
"security_compliance_rollout_runtime_phase_enabled=false": "執行期階段尚未開放。",
"security_compliance_rollout_enforcement_enabled=false": "強制執行尚未開放。",
};
- if (labels[value]) return labels[value];
- if (value.includes("runtime_execution_authorized=false")) return "執行期操作未授權。";
- if (value.includes("action_buttons_allowed=false")) return "此頁不提供可執行操作按鈕。";
- if (value.includes("active_runtime_gate_count=0")) return "執行期閘門維持關閉。";
- if (value.includes("owner_response_validation_received_count=0")) return "負責人回覆尚未收到。";
- if (value.includes("owner_response_validation_accepted_count=0")) return "負責人回覆尚未接受。";
- if (value.includes("owner_response_validation_rejected_count=0")) return "目前沒有正式拒收紀錄。";
- if (value.includes("repo_creation_authorized=false")) return "未核准建立專案庫或修改可見性。";
- if (value.includes("refs_mutation_authorized=false") || value.includes("refs_sync_authorized=false")) {
+ if (labels[redacted]) return labels[redacted];
+ if (redacted.includes("runtime_execution_authorized=false")) return "執行期操作未授權。";
+ if (redacted.includes("action_buttons_allowed=false")) return "此頁不提供可執行操作按鈕。";
+ if (redacted.includes("active_runtime_gate_count=0")) return "執行期閘門維持關閉。";
+ if (redacted.includes("owner_response_validation_received_count=0")) return "負責人回覆尚未收到。";
+ if (redacted.includes("owner_response_validation_accepted_count=0")) return "負責人回覆尚未接受。";
+ if (redacted.includes("owner_response_validation_rejected_count=0")) return "目前沒有正式拒收紀錄。";
+ if (redacted.includes("repo_creation_authorized=false")) return "未核准建立專案庫或修改可見性。";
+ if (redacted.includes("refs_mutation_authorized=false") || redacted.includes("refs_sync_authorized=false")) {
return "未核准同步、刪除或強制推送分支 / 標籤。";
}
- if (value.includes("workflow_modification_authorized=false") || value.includes("workflow_secret_modification_authorized=false")) {
+ if (redacted.includes("workflow_modification_authorized=false") || redacted.includes("workflow_secret_modification_authorized=false")) {
return "未核准修改工作流程、runner 或機密設定。";
}
- if (value.includes("secret_value_collection_allowed=false")) return "不得收集或顯示任何機密明文值。";
- if (value.includes("github_primary_switch_authorized=false")) return "GitHub primary 尚未核准切換。";
- if (value.includes("gitea_disablement_authorized=false")) return "Gitea 不得停用,仍是目前 CI/CD 來源。";
- if (value.includes("execution_router_linked=false")) return "尚未連接執行路由。";
- if (value.includes("security_run_created=false") || value.includes("github_primary_run_created=false")) {
+ if (redacted.includes("secret_value_collection_allowed=false")) return "不得收集或顯示任何機密明文值。";
+ if (redacted.includes("github_primary_switch_authorized=false")) return "GitHub primary 尚未核准切換。";
+ if (redacted.includes("gitea_disablement_authorized=false")) return "Gitea 不得停用,仍是目前 CI/CD 來源。";
+ if (redacted.includes("execution_router_linked=false")) return "尚未連接執行路由。";
+ if (redacted.includes("security_run_created=false") || redacted.includes("github_primary_run_created=false")) {
return "目前沒有建立資安執行 run。";
}
- if (value.includes("approval_record_created=false") || value.includes("security_approval_record_created=false")) {
+ if (redacted.includes("approval_record_created=false") || redacted.includes("security_approval_record_created=false")) {
return "目前沒有建立審批紀錄。";
}
- if (value.includes("platform_run_creation_authorized=false")) return "未核准建立平台 run。";
- if (value.includes("not_authorization=true")) return "此區塊僅為只讀證據,不代表授權。";
- if (value.includes("contract_publish_authorized=false")) return "未核准發布或改版合約。";
- if (value.includes("contract_mutation_authorized=false")) return "未核准修改合約內容。";
- if (value.includes("send_owner_request_allowed=false")) return "未核准送出負責人請求。";
- if (value.includes("mark_received_allowed=false")) return "未核准標記已收到。";
- if (value.includes("mark_accepted_allowed=false")) return "未核准標記已接受。";
- if (value.includes("nginx_reload_authorized=false")) return "未核准 Nginx reload 或公開入口變更。";
- if (value.includes("agent_bounty_runtime_authorized=false")) return "agent-bounty-protocol 執行期維持關閉。";
- if (value.includes("github_primary_approval_granted=false")) return "GitHub primary 尚未獲得審批。";
- if (value.includes("owner_response_accepted_count=0")) return "負責人回覆接受數仍為 0。";
- if (value.includes("_count=0")) return "目前計數仍為 0,僅供只讀觀測。";
- if (value.includes("=false")) return "目前狀態為未授權,僅供只讀觀測。";
- return value;
+ if (redacted.includes("platform_run_creation_authorized=false")) return "未核准建立平台 run。";
+ if (redacted.includes("not_authorization=true")) return "此區塊僅為只讀證據,不代表授權。";
+ if (redacted.includes("contract_publish_authorized=false")) return "未核准發布或改版合約。";
+ if (redacted.includes("contract_mutation_authorized=false")) return "未核准修改合約內容。";
+ if (redacted.includes("send_owner_request_allowed=false")) return "未核准送出負責人請求。";
+ if (redacted.includes("mark_received_allowed=false")) return "未核准標記已收到。";
+ if (redacted.includes("mark_accepted_allowed=false")) return "未核准標記已接受。";
+ if (redacted.includes("nginx_reload_authorized=false")) return "未核准 Nginx reload 或公開入口變更。";
+ if (redacted.includes("agent_bounty_runtime_authorized=false")) return "agent-bounty-protocol 執行期維持關閉。";
+ if (redacted.includes("github_primary_approval_granted=false")) return "GitHub primary 尚未獲得審批。";
+ if (redacted.includes("owner_response_accepted_count=0")) return "負責人回覆接受數仍為 0。";
+ if (redacted.includes("_count=0")) return "目前計數仍為 0,僅供只讀觀測。";
+ if (redacted.includes("=false")) return "目前狀態為未授權,僅供只讀觀測。";
+ return redacted;
}
export function publicContractText(value: string): string {