ci: harden workflows with least-privilege permissions, CodeQL, and actionlint#13
Merged
Conversation
…tionlint Tighten the CI/CD supply chain to close OpenSSF Scorecard gaps: - Set a least-privilege top-level `permissions: contents: read` on the backport-fixes, ci, cut-release, dependency-review, publish-pypi, and release workflows; jobs re-grant only the write scopes they need. - Add a CodeQL workflow running the security-extended query suite on the Python sources (SAST) for pushes, pull requests, and a weekly schedule. The analyze job is gated on public-repo visibility, since SARIF upload to code scanning requires public repos. - Add an actionlint workflow that lints `.github/workflows/**` at PR time. The actionlint installer is fetched by commit SHA and sha256-verified before it runs, and shellcheck is wired in explicitly. - Replace the fragile `grep`-based artifact version check in publish-pypi with a `compgen -G` glob match so version verification no longer depends on regex-escaping the version string.
|
You are seeing this message because GitHub Code Scanning has recently been set up for this repository, or this pull request contains the workflow file for the Code Scanning tool. What Enabling Code Scanning Means:
For more information about GitHub Code Scanning, check out the documentation. |
RobertoIskandarani
approved these changes
Jun 17, 2026
This file contains hidden or 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
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Tighten the CI/CD supply chain to close OpenSSF Scorecard gaps.
Changes
permissions: contents: readon thebackport-fixes,ci,cut-release,dependency-review,publish-pypi, andreleaseworkflows; jobs re-grant only the write scopes they need.codeql.ymlrunning thesecurity-extendedquery suite over the Python sources on pushes, pull requests, and a weekly schedule. The analyze job is gated on public-repo visibility, since SARIF upload to code scanning requires a public repo (and this keeps private forks from failing).workflows-lint.ymlrunningactionlinton changes under.github/workflows/**. The actionlint installer is fetched by commit SHA and sha256-verified before it runs (closes Scorecard's "downloadThenRun not pinned by hash" gap), andshellcheckis wired in explicitly.grep-based artifact version check with acompgen -Gglob match, so version verification no longer depends on regex-escaping the version string.Validation
actionlintpasses on all workflows.