-
Notifications
You must be signed in to change notification settings - Fork 25
Trustable releases #69
Comments
I'm not understanding how this is useless. According to the Git Book, the blob contents are included in its hash, and tree objects are hashed with blob hashes. Are you saying there's some way to change the blob or tree contents without changing its hash? |
I'll explain it in more detail. See the git object model and how the objects are connected: http://shafiulazam.com/gitbook/1_the_git_object_model.html With git commit/tag signing you sign an object that has no content. Only blobs objects hold the actual content. Your tag or commit object is connected with the blob object via the tree object. Neither the tree nor the blob objects are signed. All of these are connected via SHA1. So you are effectively signing an SHA-1 Manifest file. SHA-1 has a proven collision: https://shattered.io/ Specific to git and it's broken GPG signing, this problem was also discussed numerous times on the git mailing list:
And even Linus himself said https://www.spinics.net/lists/git/msg09588.html
It has also been discussed on the gentoo mailing list when they switched from CVS to git. You can also easily verify it yourself with git tools:
You can try all combinations of commit and tag signing. Tree objects and blob objects will never be signed and they are connected to signed tags and commits via SHA-1. As such, the weakest link is SHA-1 and an attacker doesn't need to attack GPG, but only SHA-1. That is a fundamentally broken cryptographic model. You might also find http://gregoryszorc.com/blog/2017/02/28/mercurial,-sha-1,-and-trusting-version-control/#disqus_thread interesting and a new Commit signing plan of mercurial because of partly this exact problem https://www.mercurial-scm.org/wiki/CommitSigningPlan |
Ah ok. The whole argument was resting upon the cryptographically-weak SHA-1. Alright then. Thanks for the well written explanation anyway. |
Well, I had that lengthy explanation already written somewhere else, so I figured I'd sum it up instead of saying "because SHA-1" :P |
GitHub announced yesterday they're now checking for SHA-1 collisions on all pushes. While signing itself would be good (since it proves the source's identity even if the files aren't downloaded from GitHub), it seems the aforementioned attack would be prohibitively expensive to perform now, if possible at all. (Plus, Git is now working towards the infrastructure required to dump SHA-1, which solves the problem entirely in a year or two.) |
How's that relevant for an MITM attack on a user, performing a tarball download? The thing they want to defend against in that link is something different. |
Good idea, I'm definitly looking into that (but not for the 57.0.2987.98 release). Besides the SHA-1 issue it would be also nice to have some sort of deterministic builds in the long term. (i.e.: gitian-building, TL;DR: "Gitian is the deterministic build process that is used to build the Bitcoin Core executables. It provides a way to be reasonably sure that the executables are really built from the source on GitHub.") |
Well, static linking isn't probably within the scope and I'd argue against it. Sounds more like https://reproducible-builds.org maybe? |
Git tag and git commit signing are useless, since they only sign non-blob objects which which refer to tree and blob objects via SHA1.
Releases should be crypto-signed imo. The easiest solution is probably:
git archive --prefix=inox-patchset-${tag}/ --format=tar.gz -o inox-patchset-${tag}.tar.gz ${tag}
) since git tag based tarballs are not actually staticgpg --armor --detach-sig ...
) and the static tarball fileIf you want something more fancy, you can try signify, which is used by libressl, but it doesn't work too well with github imo (makes more sense when you have a whole directory of releases).
The text was updated successfully, but these errors were encountered: