mirror of
https://github.com/pewdiepie-archdaemon/odysseus.git
synced 2026-06-15 17:25:26 -04:00
3c0e9fcb25
Bumps the actions group with 4 updates: [actions/checkout](https://github.com/actions/checkout), [actions/setup-python](https://github.com/actions/setup-python), [actions/setup-node](https://github.com/actions/setup-node) and [github/codeql-action](https://github.com/github/codeql-action). Updates `actions/checkout` from 4.3.1 to 6.0.3 - [Release notes](https://github.com/actions/checkout/releases) - [Changelog](https://github.com/actions/checkout/blob/main/CHANGELOG.md) - [Commits](https://github.com/actions/checkout/compare/v4.3.1...df4cb1c069e1874edd31b4311f1884172cec0e10) Updates `actions/setup-python` from 5.6.0 to 6.2.0 - [Release notes](https://github.com/actions/setup-python/releases) - [Commits](https://github.com/actions/setup-python/compare/v5.6.0...a309ff8b426b58ec0e2a45f0f869d46889d02405) Updates `actions/setup-node` from 4.4.0 to 6.4.0 - [Release notes](https://github.com/actions/setup-node/releases) - [Commits](https://github.com/actions/setup-node/compare/49933ea5288caeca8642d1e84afbd3f7d6820020...48b55a011bda9f5d6aeb4c2d9c7362e8dae4041e) Updates `github/codeql-action` from 3.36.0 to 4.36.2 - [Release notes](https://github.com/github/codeql-action/releases) - [Changelog](https://github.com/github/codeql-action/blob/main/CHANGELOG.md) - [Commits](https://github.com/github/codeql-action/compare/03e4368ac7daa2bd82b3e85262f3bf87ee112f57...8aad20d150bbac5944a9f9d289da16a4b0d87c1e) --- updated-dependencies: - dependency-name: actions/checkout dependency-version: 6.0.3 dependency-type: direct:production update-type: version-update:semver-major dependency-group: actions - dependency-name: actions/setup-python dependency-version: 6.2.0 dependency-type: direct:production update-type: version-update:semver-major dependency-group: actions - dependency-name: actions/setup-node dependency-version: 6.4.0 dependency-type: direct:production update-type: version-update:semver-major dependency-group: actions - dependency-name: github/codeql-action dependency-version: 4.36.2 dependency-type: direct:production update-type: version-update:semver-major dependency-group: actions ... Signed-off-by: dependabot[bot] <support@github.com> Co-authored-by: dependabot[bot] <49699333+dependabot[bot]@users.noreply.github.com>
81 lines
2.8 KiB
YAML
81 lines
2.8 KiB
YAML
# Workflow security (CI that audits the CI)
|
|
#
|
|
# Purpose: the GitHub Actions workflows themselves are an attack surface. A
|
|
# poorly written workflow can leak the repository token, run attacker-supplied
|
|
# code from a pull request, or pull in a tampered third-party action. These two
|
|
# tools check every workflow file in this repo for those mistakes:
|
|
#
|
|
# - actionlint: catches workflow syntax errors and shell-script bugs inside
|
|
# `run:` steps before they reach main.
|
|
# - zizmor: a security linter for Actions. Flags template-injection holes,
|
|
# unpinned actions, credential persistence, and over-broad token
|
|
# permissions -- exactly the patterns the rest of this CI is built to avoid.
|
|
#
|
|
# Add this early: it then audits every workflow added after it.
|
|
|
|
name: Workflow security
|
|
|
|
on:
|
|
pull_request:
|
|
push:
|
|
branches: [main]
|
|
workflow_dispatch:
|
|
|
|
# Default-deny token; each job grants only read access to the code.
|
|
permissions: {}
|
|
|
|
concurrency:
|
|
group: workflow-security-${{ github.workflow }}-${{ github.ref }}
|
|
cancel-in-progress: true
|
|
|
|
jobs:
|
|
actionlint:
|
|
name: actionlint
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
contents: read
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6.0.3
|
|
with:
|
|
persist-credentials: false
|
|
|
|
# Pinned version + checksum so a tampered binary cannot run here.
|
|
- name: Run actionlint (pinned, checksum-verified)
|
|
env:
|
|
ACTIONLINT_VERSION: 1.7.12
|
|
ACTIONLINT_SHA256: 8aca8db96f1b94770f1b0d72b6dddcb1ebb8123cb3712530b08cc387b349a3d8
|
|
run: |
|
|
set -euo pipefail
|
|
TARBALL="actionlint_${ACTIONLINT_VERSION}_linux_amd64.tar.gz"
|
|
curl -fsSL -o "${TARBALL}" \
|
|
"https://github.com/rhysd/actionlint/releases/download/v${ACTIONLINT_VERSION}/${TARBALL}"
|
|
echo "${ACTIONLINT_SHA256} ${TARBALL}" | sha256sum -c -
|
|
tar -xzf "${TARBALL}" actionlint
|
|
./actionlint -color
|
|
|
|
zizmor:
|
|
name: zizmor (Actions SAST)
|
|
runs-on: ubuntu-latest
|
|
permissions:
|
|
contents: read
|
|
steps:
|
|
- name: Checkout repository
|
|
uses: actions/checkout@df4cb1c069e1874edd31b4311f1884172cec0e10 # v6.0.3
|
|
with:
|
|
persist-credentials: false
|
|
|
|
- name: Set up Python
|
|
uses: actions/setup-python@a309ff8b426b58ec0e2a45f0f869d46889d02405 # v6.2.0
|
|
with:
|
|
python-version: '3.12'
|
|
|
|
# Pinned zizmor release. --offline keeps the audit hermetic (no network
|
|
# calls about the actions it inspects); --min-severity=low surfaces
|
|
# everything so nothing slips through under the gate.
|
|
- name: Run zizmor
|
|
run: |
|
|
set -euo pipefail
|
|
pip install zizmor==1.25.2
|
|
zizmor --offline --min-severity=low .github/workflows/
|