flowchart
Spec["📘 規格 / 任務定義"]
Human["🧑⚖️ 人工審查"]
Policy["📏 政策 / 護欄"]
CI["⚙️ GitHub Actions"]
Agent["🤖 代理執行器"]
Job["🧠 Runner Job"]
PR["📬 Pull Request / 程式碼變更"]
Artifact["📦 建置成品"]
Deploy["🚀 GitHub Pages 部署"]
OTel["📡 OpenTelemetry Collector"]
ELK["📊 ELK 日誌 / 指標 / 事件"]
Eval["📈 評估 / 評分"]
Decide["🧭 決策引擎"]
Feedback["🔁 回饋迴圈"]
Spec --> Human
Human --> Policy
Policy --> CI
CI --> Agent
Agent --> Job
Job --> PR
Job --> Artifact
Artifact --> Deploy
Job -->|OTLP 遙測| OTel
OTel -->|索引訊號| ELK
ELK --> Eval
Eval --> Decide
Decide -->|核准| PR
Decide -->|重試 / 修補| Agent
Decide -->|升級處理| Human
Decide --> Feedback
Feedback --> Spec
subgraph L1["🧩 控制平面"]
Spec
Human
Policy
end
subgraph L2["⚙️ 執行平面"]
CI
Agent
Job
end
subgraph L3["📡 可觀測性平面"]
OTel
ELK
Eval
end
subgraph L4["🧠 決策層"]
Decide
Feedback
end
subgraph L5["🚀 交付輸出"]
PR
Artifact
Deploy
end
classDef control fill:#182235,color:#f8fafc,stroke:#94a3b8,stroke-width:2px
classDef exec fill:#082f49,color:#e0f2fe,stroke:#38bdf8,stroke-width:2px
classDef obs fill:#064e3b,color:#dcfce7,stroke:#34d399,stroke-width:2px
classDef decision fill:#431407,color:#ffedd5,stroke:#fb923c,stroke-width:2px
classDef output fill:#312e81,color:#ede9fe,stroke:#a78bfa,stroke-width:2px
class Spec,Human,Policy control
class CI,Agent,Job exec
class OTel,ELK,Eval obs
class Decide,Feedback decision
class PR,Artifact,Deploy output
style L1 fill:#0f172a,stroke:#64748b,color:#e2e8f0,stroke-width:2px
style L2 fill:#071b2f,stroke:#0ea5e9,color:#e0f2fe,stroke-width:2px
style L3 fill:#06251f,stroke:#22c55e,color:#dcfce7,stroke-width:2px
style L4 fill:#2a1206,stroke:#f97316,color:#ffedd5,stroke-width:2px
style L5 fill:#17133a,stroke:#8b5cf6,color:#ede9fe,stroke-width:2px
linkStyle 0 stroke:#94a3b8,stroke-width:2px
linkStyle 1 stroke:#94a3b8,stroke-width:2px
linkStyle 2 stroke:#38bdf8,stroke-width:2px
linkStyle 3 stroke:#38bdf8,stroke-width:2px
linkStyle 4 stroke:#38bdf8,stroke-width:2px
linkStyle 5 stroke:#a78bfa,stroke-width:2px
linkStyle 6 stroke:#a78bfa,stroke-width:2px
linkStyle 7 stroke:#a78bfa,stroke-width:2px
linkStyle 8 stroke:#22c55e,stroke-width:2px,stroke-dasharray: 5 5
linkStyle 9 stroke:#22c55e,stroke-width:2px,stroke-dasharray: 5 5
linkStyle 10 stroke:#22c55e,stroke-width:2px
linkStyle 11 stroke:#f97316,stroke-width:2px
linkStyle 12 stroke:#f97316,stroke-width:2px
linkStyle 13 stroke:#f97316,stroke-width:2px
linkStyle 14 stroke:#f97316,stroke-width:2px
linkStyle 15 stroke:#f97316,stroke-width:2px
linkStyle 16 stroke:#f97316,stroke-width:2px,stroke-dasharray: 5 5