-
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
New Check: signed commits #379
Comments
Try to integrate with https://sigstore.dev/ |
Right now signed git commits are problematic. The only real method is gpg, and there's no real key-management story so in most cases signed commits add little value IMO. There's an effort here to improve the native git-commit signing: https://github.com/TrustFrame/git-cryptography-protocol And sigstore has some plans to improve git signing by "working around" git. It's all a fair ways out though... |
related sigstore/cosign#865 |
Would the idea be to see if branch protection requires signed commits? Or just that maintainers sign their commits? I'd be very much in favor of the latter (just maintainers), but significantly against the former (branch protection). Just checking whether maintainers sign their commitsChecking whether maintainers sign their commits makes a lot of sense, since it gives us stronger guarantees that the code is actually coming from the maintainer. The question just becomes how to identify maintainers, since GitHub doesn't make that information public (API requires an admin token). Checking that very active (and therefore perhaps trusted) external contributors sign their commits also makes sense, since their contributions may not be as closely vetted if maintainers trust them. But identifying such cases is even harder than identifying maintainers. This also has the added problem that it'd require traversing the git commit history, which means Scorecard would have to clone the repo (or make a bunch of API calls), not just download a tarball. Checking whether branch protection requires signed commitsI just think the cost-benefit of this makes little sense. On the benefit side... What value do you get from receiving a signed commit in an external PR from new contributor @uber_haxxer? All you know is that the PR really came from @uber_haxxer, but... you still don't trust them, so... what's the point? Meanwhile, on the cost side... ~0% of contributors cryptographically sign their commits*. Therefore, a project enabling "require signed commits" is roughly equivalent to "we don't accept external contributions", unless the maintainers are willing to spend time educating ~100% of new contributors on how to set up signed commits. I'd absolutely love for maintainers to make that effort to increase adoption of signed commits, but I also don't think Scorecard should punish projects for thinking that's not their job. * Ok, busted, I don't actually have data to back this up. It's just a general feeling I have from personal experience. But here's some anec-data instead: looking at the first page of merged CPython PRs (the first big, complex project I could think of, which I'm wildly assuming attracts more "serious" developers), I found 11 non-bot PRs by unique contributors, listed below along with whether the commits are signed (✅ / 🚫)
|
if maintainers are required to sign their commit but branch protection is not enabled, does it mean it allows detection but not prevention? I mean, the release process would have to walk the commit to determine if it was signed.. and by which people. Main problem is which people really. If scorecard only checks for signed commits, it says nothing: a compromised GitHub user may change the signing key... or if they use Sigstore with GitHub identity provider, account compromise leads to immediate key compromise. With a non-GitHub identity provider, you need to be sure there's 2FA enabled, otherwise it's just an account takeover. In general, I'm not really convinced that signed commit helps unless identity management is solved and its resists account compromises. At that point, it seems like 2FA is what we should be recommending. Everything else is internal GitHub infra threat? Caveats: PAT, fine-grained PATs: those escape the 2FA, so commit signing helps to detect them. Is there another way to identify PATs used for commits? |
I think this issue displays a total disconnect between the OSSF vs projects that actually have rules such as "all commits must be signed". As noted, requiring signed commits for people without a commit bit is nonsensically meaningless. But that is not even remotely the same as not accepting external contributions. There are six ways to merge a PR, in a matrix that covers: Merge strategy:
How it's done:
The distinction here is really just about how it's done. It doesn't matter what you try, who you are, which merge strategy you use, or anything else. You CANNOT sign commits by using the GitHub web UI. 1 Merging via the command line can be done with any strategy but only "merge via merge commit" will show up on the website as a merged PR -- the other two show up as a "closed PR". Here are some projects which just do the "rebase and sign all external contributions via the command line" approach:
Discussion related to asking GitHub for explicit support for closing the gap here, and showing PRs which were manually merged, as merged:
Tooling for automatically applying PRs locally:
Footnotes
|
@spencerschrock @afmarcum and others: From our Jan 25 meeting, we said we'd close this one as a "won't do." |
I don't think anyone was trying to make this distinction, rather the comment was pointing out that GitHub doesn't provide an API to identify project maintainers.
Thanks for the detailed response. I was familiar with the GitHub signing aspect of the web UI, but not with the interaction around how some projects manually merge results in closed PRs. |
It sort of does, you can use https://api.github.com/orgs/ORG/members but that only helps if the individuals in question publicly identify as organization members. Doesn't help for collaborators, either. It would be possible to go to the old standby of "expect projects to list additional information in a text file checked into the repository", I guess... |
In addition to signed release and tags, we may check for signed commits.
We need a good story around key management/storage. Long-term, it would be nice to suggest more recent algorithms such as ECDSA/EdDSA instead of RSA/DSA and more recent crypto libraries, such as Tink.
The text was updated successfully, but these errors were encountered: