-
Notifications
You must be signed in to change notification settings - Fork 1.9k
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
Remove a timing channel in Password matching #1556
Comments
Improved logic to avoid timing attacks: now the password length cannot be inferred.
Is there a CVE ID assigned to this issue? |
Not yet. Shall I create one? |
Ideally yes. A CVE ID raises the awareness of the security issue and allows downstream users like Linux distributions to notice it and quickly publish a fix. |
Sure, I will do it later today and attach the CVE ID. |
Downstream bug in Debian: https://bugs.debian.org/864898 |
This has been assigned CVE-2017-9735 |
Thanks! |
But I got the following error message: |
It only has been assigned around 10 minutes ago. It needs some time to update the MITRE website with the newest CVE entries AFAIK. |
|
@securinator all versions of Jetty 6 through 8 are EOL (End of Life). |
@adioss look at the commit in github, you'll see that the commit exists in the releases: |
I know, I just wondered if anyone could confirm if they were affected or not. |
@securinator nobody has confirmed that it's possible on Jetty 9 in a remote scenario. However, if you are local and are doing a timing channel attack on local passwords (in configuration files for example) then its very possible. But if you have this scenario you have much bigger issues then a timing channel attack on the Password class. |
## What changes were proposed in this pull request? This PR upgrades jetty to the latest version 9.3.20.v20170531. The version includes the fix of CVE-2017-9735. Here are links to descriptions for CVE-2017-9735. * https://nvd.nist.gov/vuln/detail/CVE-2017-9735 * jetty/jetty.project#1556 Here is [a release note](https://github.com/eclipse/jetty.project/blob/jetty-9.3.x/VERSION.txt) for the latest jetty ## How was this patch tested? tested by existing test suites Author: Kazuaki Ishizaki <[email protected]> Closes #18601 from kiszk/SPARK-21373.
@joakime, can I echo the request of @securinator: does this threat affect jetty 6-8? The wording of the CVE would indicate that they are affected ("Jetty through 9.4.x"). I ask the question in full understanding that these versions are now way past EOL. But knowing for certain that an EOL component that one is using does have a security threat does help with motivating that an application be updated to use a secure version of the vulnerable component. Ideally, I would like to see the CVE updated with accurate CPE information... this should help static analysis tools such as Dependency-Checker (or Black Duck, White Source, Nexus IQ, etc). |
Jetty 6 through Jetty 8 are long ago declared EOL (End of Life) they shouldn't be used for production (unless heavily modified, like Google App Engine does). We do not test archived / EOL products. The question of If a specific CVE affects an EOL product is meaningless. The various specs and protocols that define the general internet and web change and evolve, what was once considered acceptable is now considered a vulnerability. This evolution is not steady either, the number of changes is increasing year to year. It is our opinion that you must keep your Jetty and JVM up to date. If the CVE as written says "Jetty through 9.4.x" then that's wholly inaccurate statement, as there are Jetty 9.3.x and Jetty 9.2.x releases without the issue reported in the CVE. |
@msymons We cannot make any statements about the vulnerability or otherwise of old releases without doing the due diligence to actually analyse the software and the particular vulnerability. We do such due diligence on our current releases, plus several old release branches for which we have commercial support relationships. But we do not have the resources nor responsibility to do so for release branches that are many years old. I think it would be safest to assume that jetty 6, last release in 2010, will be vulnerable in some form or other, but we are not in a position to be able to say definitively that it is or is not vulnerable to a specific attack vector. The software is open source and open to inspection, so if anybody is still running such old releases in production, then they are free to check the code and make their own assessment of vulnerability. Finally, for this particular issue, we are not even sure the current release branches were vulnerable as no exploit was demonstrated and I expect it would only be possible in ideal circumstances unlikely to exist in any real deployment. However, we appreciate the issue being brought to our attention and were happy to make changes in order to be prudent. We can say that we have fixed all known timing issues in the current releases, but we cannot say if prior release were or were not vulnerable. |
I think this fix is broken.
|
Yes, you are right. It should be '&' instead of '|'. |
I've updated the fix to always loop for precisely the length of the unknown credential, so we do not reveal the length of the real credential. |
@gregw have you applied this from 9.2.x onwards ? |
oops no. will cherry pick back. |
@gregw Will there a patch release for |
There are no 9.2.x releases planned. If security is important to you, then you should not be running Jetty 9.2.x or Java 1.7 Also, why are you not running the latest 9.2.x release? |
Yes you are right. We havent upgraded our jetty server in a while. We'll update it to the latest version of 9.2. Thanks, |
Jetty 9.2.x is old now. You should update to Jetty 9.4.x (and JDK 8). |
, fixed in jetty/jetty.project#1556
, fixed in jetty/jetty.project#1556
Hi,
I found a timing channel in Password.java:
https://github.com/eclipse/jetty.project/blob/jetty-9.4.x/jetty-util/src/main/java/org/eclipse/jetty/util/security/Password.java#L105
By using Arrays.equals, it actually violates the "constant-time-implementation" discipline.
For more information about timing attack:
https://codahale.com/a-lesson-in-timing-attacks/
The text was updated successfully, but these errors were encountered: