From 6cbf9ac88bd6aed93d04869631b798d9bb8c373b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?V=C3=ADctor=20Rold=C3=A1n=20Betancort?= Date: Mon, 17 Jul 2023 13:50:46 +0100 Subject: [PATCH] add trivy scan to release images --- .github/workflows/lint.yaml | 45 ++++++++++++++++++++++++++++--------- 1 file changed, 35 insertions(+), 10 deletions(-) diff --git a/.github/workflows/lint.yaml b/.github/workflows/lint.yaml index 8d3f26fa..d89e3d3d 100644 --- a/.github/workflows/lint.yaml +++ b/.github/workflows/lint.yaml @@ -47,20 +47,45 @@ jobs: - uses: "actions/checkout@v3" - uses: "authzed/actions/codeql@main" - trivy: - name: "Analyze with Trivy" + trivy-fs: + name: "Analyze FS with Trivy" runs-on: "ubuntu-latest" steps: - uses: "actions/checkout@v3" - - name: "Run Trivy vulnerability scanner" - uses: "aquasecurity/trivy-action@master" + - uses: "aquasecurity/trivy-action@master" with: scan-type: "fs" ignore-unfixed: true - format: "sarif" - output: "trivy-results.sarif" - severity: "CRITICAL" - - name: "Upload Trivy scan results to GitHub Security tab" - uses: "github/codeql-action/upload-sarif@v2" + format: 'table' + exit-code: '1' + severity: "CRITICAL,HIGH,MEDIUM" + + trivy-image: + name: "Analyze Release Image with Trivy" + runs-on: "ubuntu-latest" + steps: + - uses: "actions/checkout@v3" + - uses: "authzed/actions/setup-go@main" + with: + go-version: "${{ env.GO_VERSION }}" + # Workaround until goreleaser release supports --single-target + # makes the build faster by not building everything + - name: "modify goreleaser config to skip building all targets" + run: | + echo "partial: + by: target" >> .goreleaser.docker.yml + - uses: "goreleaser/goreleaser-action@v4" + id: "goreleaser" with: - sarif_file: "trivy-results.sarif" + distribution: "goreleaser-pro" + version: "latest" + args: "release -f .goreleaser.docker.yml --clean --split --snapshot" + env: + GITHUB_TOKEN: "${{ secrets.GITHUB_TOKEN }}" + GORELEASER_KEY: "${{ secrets.GORELEASER_KEY }}" + - name: "Obtain container image to scan" + run: 'echo "IMAGE_VERSION=$(jq .version dist/linux_amd64/metadata.json --raw-output)" >> $GITHUB_ENV' + - name: "run trivy on release image" + run: 'docker run -v /var/run/docker.sock:/var/run/docker.sock aquasec/trivy image --format table --exit-code 1 --ignore-unfixed --vuln-type os,library --no-progress --severity CRITICAL,HIGH,MEDIUM authzed/zed:v${{ env.IMAGE_VERSION }}-amd64' + - name: "run trivy on debug image" + run: 'docker run -v /var/run/docker.sock:/var/run/docker.sock aquasec/trivy image --format table --exit-code 1 --ignore-unfixed --vuln-type os,library --no-progress --severity CRITICAL,HIGH,MEDIUM authzed/zed:v${{ env.IMAGE_VERSION }}-amd64-debug'