Trivy Scan #148
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Trivy Scan | |
on: | |
schedule: | |
- cron: "0 0 * * *" | |
jobs: | |
trivy-scan: | |
permissions: | |
contents: read # for actions/checkout to fetch code | |
security-events: write # for github/codeql-action/upload-sarif to upload SARIF results | |
actions: read # only required for a private repository by github/codeql-action/upload-sarif to get the Action run status | |
runs-on: ubuntu-22.04 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v4 | |
- name: Free disk space | |
# https://github.com/actions/virtual-environments/issues/709 | |
run: | | |
echo "=========original CI disk space" | |
df -h | |
sudo rm -rf "/usr/local/share/boost" | |
sudo rm -rf "$AGENT_TOOLSDIRECTORY" | |
echo "=========after clean up, the left CI disk space" | |
df -h | |
- name: Checkout submodule | |
uses: Mushus/[email protected] | |
with: | |
basePath: # optional, default is . | |
submodulePath: libvgpu | |
- name: Get branch name | |
uses: nelonoel/[email protected] | |
- name: Docker Login | |
uses: docker/[email protected] | |
with: | |
username: ${{ secrets.DOCKERHUB_TOKEN }} | |
password: ${{ secrets.DOCKERHUB_PASSWD }} | |
- name: Set up Docker Buildx | |
id: buildx | |
uses: docker/setup-buildx-action@v3 | |
- name: install Go | |
uses: actions/setup-go@v5 | |
with: | |
go-version-file: go.mod | |
- name: Generating image tag | |
id: runtime-tag | |
run: | | |
echo tag="$(git rev-parse --short HEAD)" >> $GITHUB_OUTPUT | |
- run: make tidy | |
- run: SHORT_VERSION=${{ steps.runtime-tag.outputs.tag }} bash ./hack/build.sh | |
- name: Run Trivy vulnerability scanner (table output) | |
# Prevent running from the forked repository that doesn't need to upload coverage. | |
# In addition, running on the forked repository would fail as missing the necessary secret. | |
if: ${{ github.repository == 'Project-HAMi/HAMi' }} | |
uses: aquasecurity/[email protected] | |
with: | |
image-ref: "projecthami/hami:${{ steps.runtime-tag.outputs.tag }}" | |
format: "table" | |
ignore-unfixed: true | |
severity: "CRITICAL" | |
vuln-type: "os,library" | |
trivyignores: .trivyignore | |
- name: Run Trivy vulnerability scanner (SARIF) | |
uses: aquasecurity/[email protected] | |
with: | |
image-ref: "projecthami/hami:${{ steps.runtime-tag.outputs.tag }}" | |
format: "sarif" | |
output: "trivy-results.sarif" | |
ignore-unfixed: true | |
severity: "CRITICAL" | |
vuln-type: "os,library" | |
trivyignores: .trivyignore | |
if: always() && github.repository == 'Project-HAMi/HAMi' | |
- name: Upload Trivy scan results to GitHub Security tab | |
uses: github/codeql-action/upload-sarif@v3 | |
with: | |
sarif_file: "trivy-results.sarif" | |
if: always() && github.repository == 'Project-HAMi/HAMi' |