diff --git a/.github/workflows/trivy.yml b/.github/workflows/trivy.yml new file mode 100644 index 0000000..d5e0508 --- /dev/null +++ b/.github/workflows/trivy.yml @@ -0,0 +1,39 @@ +name: Trivy + +on: + push: + branches: [ "main" ] + schedule: + - cron: '44 1 * * 3' + +permissions: + contents: read + +jobs: + analyze: + permissions: + contents: read + security-events: write + name: Analyze + runs-on: "ubuntu-18.04" + steps: + - name: Checkout code + uses: actions/checkout@v3 + + - name: Build an image from Dockerfile + run: | + docker build -t ghcr.io/geowerkstatt/ews-boda:${{ github.sha }} . + + - name: Run Trivy vulnerability scanner + uses: aquasecurity/trivy-action@7b7aa264d83dc58691451798b4d117d53d21edfe + with: + image-ref: 'ghcr.io/geowerkstatt/ews-boda:${{ github.sha }}' + format: 'template' + template: '@/contrib/sarif.tpl' + output: 'trivy-results.sarif' + severity: 'CRITICAL' + + - name: Upload Trivy scan results to GitHub Security tab + uses: github/codeql-action/upload-sarif@v2 + with: + sarif_file: 'trivy-results.sarif'