Report release vulnerabilities #89
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
--- | |
# This workflow downloads the latest release and checks it for OS and Go vulnerabilities. | |
# An issue is opened with a summary | |
name: Report release vulnerabilities | |
on: | |
schedule: | |
- cron: '0 4 * * *' # 4:00 am UTC = 1 hour after base image build | |
release: | |
types: | |
- edited | |
- published | |
workflow_dispatch: {} | |
jobs: | |
report-vulnerabilities: | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout code | |
uses: actions/checkout@v4 | |
with: | |
path: main | |
- name: Install Go | |
uses: actions/setup-go@v5 | |
with: | |
go-version: '1.22.x' | |
cache: true | |
check-latest: true | |
- name: Install crane | |
run: curl --location --silent "https://github.com/google/go-containerregistry/releases/download/$(curl -s https://api.github.com/repos/google/go-containerregistry/releases/latest | jq -r '.tag_name')/go-containerregistry_$(uname -s)_$(uname -m | sed -e 's/aarch64/arm64/').tar.gz" | sudo tar -xzf - -C /usr/local/bin crane | |
- name: Install dyff | |
run: curl --silent --location https://raw.githubusercontent.com/homeport/dyff/main/scripts/download-latest.sh | bash | |
- name: Install Ko | |
uses: ko-build/setup-ko@v0.7 | |
with: | |
version: v0.17.1 | |
- name: Install Retry | |
run: curl --location --silent https://raw.githubusercontent.com/homeport/retry/main/hack/download.sh | bash | |
- name: Install semver | |
run: go install gitlab.com/usvc/utils/semver/cmd/semver@latest | |
- name: Install Trivy | |
run: make install-trivy | |
working-directory: ${{ github.workspace }}/main | |
- name: Update Trivy database | |
env: | |
TRIVY_USERNAME: ${{ github.repository_owner }} | |
TRIVY_PASSWORD: ${{ github.token }} | |
run: retry trivy image --download-db-only | |
- name: Install govulncheck | |
run: go install golang.org/x/vuln/cmd/govulncheck@latest | |
- name: Download latest release | |
id: download-latest-release | |
env: | |
GH_TOKEN: ${{ github.token }} | |
run: ./.github/download-latest-release.sh | |
working-directory: ${{ github.workspace }}/main | |
- name: Checkout release branch | |
uses: actions/checkout@v4 | |
with: | |
path: release-branch | |
ref: ${{ steps.download-latest-release.outputs.release-branch }} | |
- name: Install Go version of latest release | |
uses: actions/setup-go@v5 | |
with: | |
go-version: "${{ steps.download-latest-release.outputs.go-version }}.x" | |
cache: true | |
check-latest: true | |
- name: Report vulnerabilities | |
env: | |
GH_TOKEN: ${{ github.token }} | |
RELEASE_BRANCH: ${{ steps.download-latest-release.outputs.release-branch }} | |
RELEASE_TAG: ${{ steps.download-latest-release.outputs.release-tag }} | |
RELEASE_YAML: ${{ steps.download-latest-release.outputs.release-yaml }} | |
REPOSITORY: ${{ github.workspace }}/release-branch | |
run: ./.github/report-release-vulnerabilities.sh | |
working-directory: ${{ github.workspace }}/main |