-
Notifications
You must be signed in to change notification settings - Fork 0
40 lines (31 loc) · 1.09 KB
/
app-gitops-guardrails.yml
File metadata and controls
40 lines (31 loc) · 1.09 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
name: app-gitops-guardrails
on:
pull_request:
branches: [ main ]
paths:
- 'applications/**'
- '.github/workflows/app-gitops-guardrails.yml'
permissions:
contents: read
jobs:
app-policy-checks:
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Validate Kubernetes manifests with kubeconform
shell: bash
run: |
set -euo pipefail
curl -sSL -o kubeconform.tar.gz \
https://github.com/yannh/kubeconform/releases/latest/download/kubeconform-linux-amd64.tar.gz
tar -xzf kubeconform.tar.gz kubeconform
mapfile -t manifest_files < <(find applications/gitops/base -type f \( -name '*.yaml' -o -name '*.yml' \) | sort)
if [ "${#manifest_files[@]}" -eq 0 ]; then
echo "No Kubernetes manifests found in applications/gitops/base"
exit 1
fi
./kubeconform -strict -summary "${manifest_files[@]}"
- name: Policy test placeholder (OPA/Kyverno)
run: |
echo "Run conftest / kyverno CLI checks here"