-
Notifications
You must be signed in to change notification settings - Fork 20
130 lines (109 loc) · 2.83 KB
/
ci.yml
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
## (5b) Pin to commits, not tags
name: CI Build and Check
on:
push:
branches:
- master
pull_request:
env:
IMAGE: rancher/kube-api-auth
permissions:
contents: read
security-events: write # upload Trivy Sarif results
jobs:
linter:
runs-on: ubuntu-latest
steps:
- name: Get Sources
uses: actions/checkout@v3
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version-file: 'go.mod'
cache: false
- name: Validate the sources
run: |
./scripts/validate
# Except for linting. That is done through the proper GH action
- name: Lint sources
uses: golangci/golangci-lint-action@v4
- name: Test
run: ./scripts/test
build-amd64:
runs-on: ubuntu-latest
needs:
- linter
steps:
- name: Get Sources
uses: actions/checkout@v3
- name: Determine Tag
id: get-TAG
run: |
export TAG=g$(git describe --always)
echo "TAG=$TAG"
echo "TAG=$TAG" >> "$GITHUB_ENV"
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version-file: 'go.mod'
cache: false
- name: Build
run: |
./scripts/build
echo Stage binary for packaging step
cp -rv ./bin/* ./package/
- name: Package up into container image
uses: docker/build-push-action@v5
with:
context: package
push: false
tags: ${{ env.IMAGE }}:${{ env.TAG }}-amd64
file: package/Dockerfile
- name: Scan for security vulnerabilities using Trivy
uses: aquasecurity/[email protected]
with:
image-ref: ${{ env.IMAGE }}:${{ env.TAG }}-amd64
ignore-unfixed: true
vuln-type: 'os,library'
severity: 'CRITICAL,HIGH'
format: 'sarif'
output: 'trivy-results.sarif'
- name: Upload Trivy scan results to GitHub Security tab
uses: github/codeql-action/upload-sarif@v3
if: always()
with:
sarif_file: 'trivy-results.sarif'
build-arm64:
runs-on: ubuntu-latest
needs:
- linter
steps:
- name: Get Sources
uses: actions/checkout@v3
- name: Determine Tag
id: get-TAG
run: |
export TAG=g$(git describe --always)
echo "TAG=$TAG"
echo "TAG=$TAG" >> "$GITHUB_ENV"
- name: Set up Go
uses: actions/setup-go@v5
with:
go-version-file: 'go.mod'
cache: false
- name: Build
env:
GOOS: linux
GOARCH: arm64
ARCH: arm64
run: |
./scripts/build
echo Stage binary for packaging step
cp -rv ./bin/* ./package/
- name: Package up into container image
uses: docker/build-push-action@v5
with:
context: package
push: false
tags: ${{ env.IMAGE }}:${{ env.TAG }}-arm64
file: package/Dockerfile