From 8eefeda87131fed0e2372725b4f27b4d56ea3df1 Mon Sep 17 00:00:00 2001 From: Naji Obeid Date: Mon, 6 Jan 2025 21:17:17 +0000 Subject: [PATCH] integrate zizmor in github actions --- .github/workflows/codeql-analysis.yml | 3 ++- .github/workflows/hugo.yml | 1 + .github/workflows/lint.yml | 4 +++ .github/workflows/zizmor.yml | 36 +++++++++++++++++++++++++++ 4 files changed, 43 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/zizmor.yml diff --git a/.github/workflows/codeql-analysis.yml b/.github/workflows/codeql-analysis.yml index 2d0ed701a..0e0cec0aa 100644 --- a/.github/workflows/codeql-analysis.yml +++ b/.github/workflows/codeql-analysis.yml @@ -21,7 +21,8 @@ jobs: uses: actions/checkout@v4 with: fetch-depth: 2 - + persist-credentials: false + - name: Initialize CodeQL uses: github/codeql-action/init@v3 diff --git a/.github/workflows/hugo.yml b/.github/workflows/hugo.yml index cde3ab98d..9b29737f1 100644 --- a/.github/workflows/hugo.yml +++ b/.github/workflows/hugo.yml @@ -15,6 +15,7 @@ jobs: with: submodules: true fetch-depth: 0 + persist-credentials: false - name: Setup Hugo uses: peaceiris/actions-hugo@v3 diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 3b8d1c8a3..96bc0d334 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -17,6 +17,8 @@ jobs: steps: - name: Checkout uses: actions/checkout@v4 + with: + persist-credentials: false - id: build run: echo "::set-output name=hash::${{ hashFiles('assets/**', 'content/**', 'layouts/**', 'static/**', '**/package.json', '**/package-lock.json') }}" @@ -32,6 +34,8 @@ jobs: steps: - name: Checkout uses: actions/checkout@v4 + with: + persist-credentials: false - uses: actions/setup-node@v4 with: diff --git a/.github/workflows/zizmor.yml b/.github/workflows/zizmor.yml new file mode 100644 index 000000000..d915605ef --- /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