From cc750679c9b3a955610d1c4b4e7e207d8efa83d2 Mon Sep 17 00:00:00 2001 From: Naji Obeid Date: Thu, 2 Jan 2025 21:47:46 +0000 Subject: [PATCH] integrate zizmor in github actions --- .github/workflows/codeql-analysis.yml | 1 + .github/workflows/go.yml | 2 ++ .github/workflows/golangci-lint.yml | 2 ++ .github/workflows/modver.yml | 1 + .github/workflows/zizmor.yml | 36 +++++++++++++++++++++++++++ 5 files changed, 42 insertions(+) create mode 100644 .github/workflows/zizmor.yml diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index 9362cb8..f415921 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -20,6 +20,7 @@ jobs: # We must fetch at least the immediate parents so that if this is # a pull request then we can checkout the head. fetch-depth: 2 + persist-credentials: false # If this run was triggered by a pull request event, then checkout # the head of the pull request instead of the merge commit. diff --git a/.github/workflows/go.yml b/.github/workflows/go.yml index ac37853..3c2edb0 100644 --- a/.github/workflows/go.yml +++ b/.github/workflows/go.yml @@ -27,6 +27,8 @@ jobs: - name: Check out code into the Go module directory uses: actions/checkout@v4 + with: + persist-credentials: false - name: Get dependencies run: go get -v -t -d ./... diff --git a/.github/workflows/golangci-lint.yml b/.github/workflows/golangci-lint.yml index a6a174d..79d7280 100644 --- a/.github/workflows/golangci-lint.yml +++ b/.github/workflows/golangci-lint.yml @@ -15,6 +15,8 @@ jobs: with: go-version: 1.22 - uses: actions/checkout@v4 + with: + persist-credentials: false - name: golangci-lint uses: golangci/golangci-lint-action@v6 with: diff --git a/.github/workflows/modver.yml b/.github/workflows/modver.yml index 20a1049..2cee3f4 100644 --- a/.github/workflows/modver.yml +++ b/.github/workflows/modver.yml @@ -15,6 +15,7 @@ jobs: - uses: actions/checkout@v4 with: fetch-depth: 0 + persist-credentials: false - uses: bobg/modver@v2.10.2 with: github_token: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/zizmor.yml b/.github/workflows/zizmor.yml new file mode 100644 index 0000000..d915605 --- /dev/null +++ b/.github/workflows/zizmor.yml @@ -0,0 +1,36 @@ +name: GitHub Actions Security Analysis with zizmor + +on: + push: + branches: ["main"] + pull_request: + branches: ["**"] + +jobs: + zizmor: + name: zizmor latest via PyPI + runs-on: ubuntu-latest + permissions: + security-events: write + # required for workflows in private repositories + contents: read + actions: read + steps: + - name: Checkout repository + uses: actions/checkout@v4 + with: + persist-credentials: false + + - name: Install the latest version of uv + uses: astral-sh/setup-uv@v5 + + - name: Run zizmor + run: uvx zizmor --format sarif . > results.sarif + env: + GH_TOKEN: ${{ secrets.GITHUB_TOKEN }} + + - name: Upload SARIF file + uses: github/codeql-action/upload-sarif@v3 + with: + sarif_file: results.sarif + category: zizmor