-
Notifications
You must be signed in to change notification settings - Fork 0
57 lines (43 loc) · 1.58 KB
/
app-gitops-guardrails.yml
File metadata and controls
57 lines (43 loc) · 1.58 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
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
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: Setup Go for policy toolchain
uses: actions/setup-go@v5
with:
go-version: '1.22'
- name: Validate Kubernetes manifests with kubeconform
shell: bash
run: |
set -euo pipefail
go install github.com/yannh/kubeconform/cmd/kubeconform@latest
export PATH="$PATH:$(go env GOPATH)/bin"
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 checks with Conftest
shell: bash
run: |
set -euo pipefail
go install github.com/open-policy-agent/conftest@latest
export PATH="$PATH:$(go env GOPATH)/bin"
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
conftest test "${manifest_files[@]}" -p applications/policy