-
Notifications
You must be signed in to change notification settings - Fork 510
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Feature: determine if publishing is credential-based or OIDC-based #2761
Comments
This would be great! On the detection side: I think this could be detected by checking the combination of effective permissions and explicit inputs for the configured |
As an example, here's an instance of the change that would be necessary to move from less-secure long-lived credentials to more secure OIDC-based publishing: sigstore/sigstore-python#566 |
Would this be a new metric for the Packaging check or a new check in itself? It seems a good fit for Packaging, but then that raises the issue of how to score projects in different ecosystems (those that support OIDC and those that don't). As a separate check this becomes easy to handle: if a project belongs to an OIDC-friendly ecosystem, it gets scored. Otherwise, the check is ignored. The same thing could be done within Packaging, but it might seem odd to the maintainer that a Python project gets an 8/10 for publishing (without OIDC) while an R project gets a 10/10 for the exact same thing. |
I'm not sure! If it should be part of I would argue yes, because 10/10 score should be the best a project can do at that time, but a project that doesn't respond or enact new/better security features as they become available shouldn't expect to remain at 10/10 indefinitely. |
+1 from me. Great to encourage users to use OIDC instead of long-lived tokens. |
JFYI - I have created an issue in https://github.com/step-security/secure-repo to automate transformation of GitHub Actions workflows to use OIDC. |
More examples of this already available other ecosystems: https://dart.dev/tools/pub/automated-publishing |
I'm +1 to have this under Packaging check. Folks who have a 10 today will drop to a lower score (say, 8) and it will encourage them to update. IMO, we don't need "backward compatibility" on the score when best practices are updated based on changes in the ecosystems / attacks, etc |
Stale issue message - this issue will be closed in 7 days |
Not stale 🙂 |
This issue is stale because it has been open for 60 days with no activity. |
Not stale. Is there a way to disable the stale check on this issue? I believe it can't really go "stale" per se, since it's purely a feature request. |
Yes, the Action has "exempt labels" for issues and PRs. However, Scorecard currently only has that for "bug", "good first issue" and something else. Maybe should add a "never-stale" label. |
Makes sense. I think "good first issue" would also make sense in this specific case 🙂 |
Here's another one we should detect https://blog.rubygems.org/2023/12/14/trusted-publishing.html |
Is your feature request related to a problem? Please describe.
GitHub Actions supports OIDC identities for workflow runs: https://docs.github.com/en/actions/deployment/security-hardening-your-deployments/about-security-hardening-with-openid-connect
Some ecosystems now support OIDC-based publishing with these identities, e.g. for PyPI: pypi/warehouse#12465 (currently in closed beta), which can be identified based on the usage of the official action without supplying credentials: https://github.com/pypa/gh-action-pypi-publish#publishing-with-openid-connect
This should be considered more secure than using long-lived credentials like API tokens or username/passwords for publishing. It also has the added benefit of linking the source repository to the published artifact in a verifiable way.
Describe the solution you'd like
For ecosystems that support OIDC-based publishing, Scorecard should penalize repositories that use long-lived credentials for publishing, and reward projects that adopt OIDC-based publishing, either via a new check or an existing check.
The text was updated successfully, but these errors were encountered: