diff --git a/.github/workflows/trivy-analysis.yml b/.github/workflows/trivy-analysis.yml new file mode 100644 index 0000000000..361e233878 --- /dev/null +++ b/.github/workflows/trivy-analysis.yml @@ -0,0 +1,64 @@ +name: Trivy +on: + workflow_dispatch: + # Run the job twice a day + schedule: + - cron: "0 0 * * *" + +jobs: + quarkus-dist: + name: Vulnerability scanner for Quarkus distribution images + runs-on: "ubuntu-18.04" + steps: + - name: Run Trivy vulnerability scanner + uses: aquasecurity/trivy-action@296212627a1e693efa09c00adc3e03b2ba8edf18 + with: + image-ref: 'quay.io/keycloak/keycloak:nightly' + format: 'template' + template: '@/contrib/sarif.tpl' + output: 'trivy-results.sarif' + severity: 'MEDIUM,CRITICAL,HIGH' + ignore-unfixed: true + + - name: Upload Trivy scan results to GitHub Security tab + uses: github/codeql-action/upload-sarif@v1 + with: + sarif_file: 'trivy-results.sarif' + + legacy-dist: + name: Vulnerability scanner for WildFly distribution images + runs-on: "ubuntu-18.04" + steps: + - name: Run Trivy vulnerability scanner + uses: aquasecurity/trivy-action@296212627a1e693efa09c00adc3e03b2ba8edf18 + with: + image-ref: 'quay.io/keycloak/keycloak:legacy' + format: 'template' + template: '@/contrib/sarif.tpl' + output: 'legacy-results.sarif' + severity: 'MEDIUM,CRITICAL,HIGH' + ignore-unfixed: true + + - name: Upload Trivy scan results to GitHub Security tab + uses: github/codeql-action/upload-sarif@v1 + with: + sarif_file: 'legacy-results.sarif' + + keycloak-operator: + name: Vulnerability scanner for Keycloak Operator distribution images + runs-on: "ubuntu-18.04" + steps: + - name: Run Trivy vulnerability scanner + uses: aquasecurity/trivy-action@296212627a1e693efa09c00adc3e03b2ba8edf18 + with: + image-ref: 'quay.io/keycloak/keycloak-operator:nightly' + format: 'template' + template: '@/contrib/sarif.tpl' + output: 'operator-results.sarif' + severity: 'MEDIUM,CRITICAL,HIGH' + ignore-unfixed: true + + - name: Upload Trivy scan results to GitHub Security tab + uses: github/codeql-action/upload-sarif@v1 + with: + sarif_file: 'operator-results.sarif'