<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div dir="ltr"><br></div><blockquote type="cite"><div dir="ltr"><div><blockquote type="cite"><div><span style="caret-color: rgb(0, 0, 0); font-family: CMUTypewriter-Regular; font-size: 13px; font-style: normal; font-variant-caps: normal; font-weight: 400; letter-spacing: normal; text-align: start; text-indent: 0px; text-transform: none; white-space: normal; word-spacing: 0px; -webkit-text-stroke-width: 0px; text-decoration: none; float: none; display: inline !important;">Lastly, there's another reason to use SipHash (or something else), and that is that there are people who will get triggered by MD5 and their brains will shut down….</span></div></blockquote></div><br><div>I am sympathetic. However, I have seen too many times where something broken-but-safe was used as a reference in a different context where something strong was needed. If one is adamant about keeping MD5, though, g<span style="caret-color: rgb(0, 0, 0); color: rgb(0, 0, 0);">ood comments can mitigate that risk.</span></div></div></blockquote>A number of years back, I used MD5 in a perfectly safe context - only to have the code called out by some security scanner that had a list of “verboten” library calls.  As I recall I simply re-implemented the algorithm and gave it a different name (as there were, and likely still are, scanners that trigger on the name itself.)  I think there was some persistent data that relied on sticking to the same algorithm so just replacing MD5 was not an option.<div><br></div><div>I could probably have convinced our own security team of the safety of the original code, it would still have needed to change as many customers run their own scanners and would raise issues.  Not worth the hassle.</div><div><br></div><div>While I understand the sentiment here - there are just too many *bad* uses of security primitives out there, so catching what at the time was plenty of inappropriate legacy uses was reasonable - I’m left wondering how many *bad* uses were found and “fixed” by the same subterfuge I used.</div><div><br></div><div><div dir="ltr">                                          -- Jerry</div><div dir="ltr"><br style="caret-color: rgb(0, 0, 0); color: rgb(0, 0, 0);"></div></div></body></html>