* Supporting hashes other than SHA-1 @ 2009-05-11 19:52 Chris Frey 2009-05-11 21:04 ` Jakub Narebski 0 siblings, 1 reply; 5+ messages in thread From: Chris Frey @ 2009-05-11 19:52 UTC (permalink / raw) To: git Hi, Considering the recent news regarding SHA-1's newly found weaknesses, is there any general interest in making git flexible enough to support other hashes in the future? - Chris ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Supporting hashes other than SHA-1 2009-05-11 19:52 Supporting hashes other than SHA-1 Chris Frey @ 2009-05-11 21:04 ` Jakub Narebski 2009-05-12 12:55 ` Jakub Narebski 0 siblings, 1 reply; 5+ messages in thread From: Jakub Narebski @ 2009-05-11 21:04 UTC (permalink / raw) To: Chris Frey; +Cc: git Chris Frey <cdfrey@foursquare.net> writes: > Considering the recent news regarding SHA-1's newly found weaknesses, > is there any general interest in making git flexible enough to support > other hashes in the future? First, there isn't as far as I know any 'known preimage' attack against SHA-1, and only that would truly matter for Git. Second, this issue was discussed in depth in the past; check git mailing list archives, please... -- Jakub Narebski Poland ShadeHawk on #git ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Supporting hashes other than SHA-1 2009-05-11 21:04 ` Jakub Narebski @ 2009-05-12 12:55 ` Jakub Narebski 2009-05-12 13:59 ` Andreas Ericsson 0 siblings, 1 reply; 5+ messages in thread From: Jakub Narebski @ 2009-05-12 12:55 UTC (permalink / raw) To: Chris Frey; +Cc: git Jakub Narebski <jnareb@gmail.com> writes: > Chris Frey <cdfrey@foursquare.net> writes: > > > Considering the recent news regarding SHA-1's newly found weaknesses, > > is there any general interest in making git flexible enough to support > > other hashes in the future? > > First, there isn't as far as I know any 'known preimage' attack > against SHA-1, and only that would truly matter for Git. > > Second, this issue was discussed in depth in the past; check git > mailing list archives, please... See also this blog entry (and comments): http://kitenet.net/~joey/blog/entry/sha-1/ -- Jakub Narebski Poland ShadeHawk on #git ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Supporting hashes other than SHA-1 2009-05-12 12:55 ` Jakub Narebski @ 2009-05-12 13:59 ` Andreas Ericsson 2009-05-12 14:06 ` Johannes Schindelin 0 siblings, 1 reply; 5+ messages in thread From: Andreas Ericsson @ 2009-05-12 13:59 UTC (permalink / raw) To: Jakub Narebski; +Cc: Chris Frey, git Jakub Narebski wrote: > Jakub Narebski <jnareb@gmail.com> writes: > >> Chris Frey <cdfrey@foursquare.net> writes: >> >>> Considering the recent news regarding SHA-1's newly found weaknesses, >>> is there any general interest in making git flexible enough to support >>> other hashes in the future? >> First, there isn't as far as I know any 'known preimage' attack >> against SHA-1, and only that would truly matter for Git. >> >> Second, this issue was discussed in depth in the past; check git >> mailing list archives, please... > > See also this blog entry (and comments): > http://kitenet.net/~joey/blog/entry/sha-1/ > It's a bit harder than that, since both pre-images have to be the same size. Git does this when hashing an object to the database: static void write_sha1_file_prepare(const void *buf, unsigned long len, const char *type, unsigned char *sha1, char *hdr, int *hdrlen) { git_SHA_CTX c; /* Generate the header */ *hdrlen = sprintf(hdr, "%s %lu", type, len)+1; /* Sha1.. */ git_SHA1_Init(&c); git_SHA1_Update(&c, hdr, *hdrlen); git_SHA1_Update(&c, buf, len); git_SHA1_Final(sha1, &c); } Iow, the type and, more importantly, *size* of the object is added to the hash. AFAIK, the pre-image conflict generators all rely on being able to manipulate the size of the content it's creating hashes for. I don't know how hard that would be to change, so perhaps someone else can enlighten me. I'm not exactly overwhelmed by the attack vectors Joey describes either. First of all, it's rather trivial to add a check to git to make it decompress its own internal object when it receives a conflicting hash and then check the type, size and content of both objects and alert a user if there is a mismatch somewhere. It wouldn't even burn that much CPU, since conflicts are extremely rare without malevolent intervention. That would defeat the first scenario by alerting users rather promptly. The second scenario can't really be prevented, but unless Alice is really a server-admin on the server hosting the repository, she will leave traces in the ssh-logs. It also relies on the build-server being utterly stupid by re-cloning the entire project. Neither case is exactly foolproof. Both have a high risk of exposure. A far better and simpler thing to do (if one were so inclined) would be to just add whatever malicious code one wants but make it appear as if it was added in a patch-series from someone else and then hope noone notices until it's too late. Far less risk for the same gains. As both vectors outlined by Joey require a lot of community trust, I'm not particularly worried. -- Andreas Ericsson andreas.ericsson@op5.se OP5 AB www.op5.se Tel: +46 8-230225 Fax: +46 8-230231 Register now for Nordic Meet on Nagios, June 3-4 in Stockholm http://nordicmeetonnagios.op5.org/ Considering the successes of the wars on alcohol, poverty, drugs and terror, I think we should give some serious thought to declaring war on peace. ^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: Supporting hashes other than SHA-1 2009-05-12 13:59 ` Andreas Ericsson @ 2009-05-12 14:06 ` Johannes Schindelin 0 siblings, 0 replies; 5+ messages in thread From: Johannes Schindelin @ 2009-05-12 14:06 UTC (permalink / raw) To: Andreas Ericsson; +Cc: Jakub Narebski, Chris Frey, git Hi, On Tue, 12 May 2009, Andreas Ericsson wrote: > Jakub Narebski wrote: > > Jakub Narebski <jnareb@gmail.com> writes: > > > > > Chris Frey <cdfrey@foursquare.net> writes: > > > > > > > Considering the recent news regarding SHA-1's newly found weaknesses, > > > > is there any general interest in making git flexible enough to support > > > > other hashes in the future? > > > First, there isn't as far as I know any 'known preimage' attack > > > against SHA-1, and only that would truly matter for Git. > > > > > > Second, this issue was discussed in depth in the past; check git > > > mailing list archives, please... > > > > See also this blog entry (and comments): > > http://kitenet.net/~joey/blog/entry/sha-1/ > > > > It's a bit harder than that, since both pre-images have to be the same > size. They don't. The pre-images prefixed by the type identifier and the size in ASCII need to have the same hash. There is a difference. Ciao, Dscho ^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2009-05-12 14:06 UTC | newest] Thread overview: 5+ messages (download: mbox.gz follow: Atom feed -- links below jump to the message on this page -- 2009-05-11 19:52 Supporting hashes other than SHA-1 Chris Frey 2009-05-11 21:04 ` Jakub Narebski 2009-05-12 12:55 ` Jakub Narebski 2009-05-12 13:59 ` Andreas Ericsson 2009-05-12 14:06 ` Johannes Schindelin
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox