Skip to content
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

FT handshake vulnerability #84

Open
ramonfontes opened this issue Apr 21, 2021 · 10 comments
Open

FT handshake vulnerability #84

ramonfontes opened this issue Apr 21, 2021 · 10 comments

Comments

@ramonfontes
Copy link

ramonfontes commented Apr 21, 2021

I have been trying to reproduce the FT handshake vulnerability with mac80211/hwsim and hostapd but it doesn't work anymore.

Firstly, I though that it could be related to the hostap version. Hence, I've installed v2.6 and I've moved the client to a new AP with the roam command provided by wpa_supplicant. According to the messages below, krack-ft-test.py can detect the FT reassociation but the AP doesn't reinstall the same IV.

[08:06:44] Detected Authentication frame, clearing client state
[08:06:44] Detected Authentication frame, clearing client state
[08:06:44] Detected FT reassociation frame
[08:06:45] Replaying Reassociation Request
[08:06:45] Detected FT reassociation frame
[08:06:46] Replaying Reassociation Request
[08:06:59] AP transmitted data using IV=1 (seq=24)
[08:06:59] Replaying Reassociation Request
[08:06:59] Detected FT reassociation frame
[08:06:59] AP transmitted data using IV=1 (seq=26)
[08:07:00] AP transmitted data using IV=2 (seq=27)
[08:07:00] Replaying Reassociation Request
[08:07:00] Detected FT reassociation frame
[08:07:00] AP transmitted data using IV=1 (seq=29)
[08:07:01] AP transmitted data using IV=2 (seq=30)
[08:07:01] Replaying Reassociation Request
[08:07:01] Detected FT reassociation frame
[08:07:01] AP transmitted data using IV=1 (seq=32)
[08:07:02] Replaying Reassociation Request
[08:07:02] Detected FT reassociation frame
[08:07:02] AP transmitted data using IV=1 (seq=35)

Then, I've found this commit and I though that it could be related to the kernel version. However, I've installed the kernel version 4.8 and the result is still the same.

Can you help me with this issue? I was able to reproduce the vulnerability three years ago and I don't know what I'm doing wrong now.

Thoughs?

@vanhoefm
Copy link
Owner

vanhoefm commented Apr 23, 2021

That kernel commit can indeed prevent the attack even when using an unpatched hostapd or wpa_supplicant. I think this patch also has been backported to older kernels due to its security impact. So you'll have to use a kernel that was released before the disclosure of the KRACK attacks and without maintenance/security patches beyond that date. Another option might be to install a "driver backports" that doesn't include this patch or where you revert this patch.

Another tip: run hostapd will extra debug output such as hostapd -dd -K and then see if it tries to reinstall the key.

@sacca97
Copy link

sacca97 commented Apr 27, 2021

I am testing various configurations too, in particular using as AP the latest Kali and trying to find something that reinstalls an all-zero key, but even theoretically vulnerable systems (Ubuntu 16.04/17.10 with old kernel and vulnerable wpa_supplicant) are reported as not vulnerable. (They reuse a key, but not the all-zero apparently)

For the AP test I'm in the same situation as Ramon and I am sure to be using a fully non-patched system.

@vanhoefm
Copy link
Owner

vanhoefm commented Jul 8, 2021

I realize this is an older issue. But if this still a problem (or for someone reading this now): feel free to attach a packet capture and a debug output log to investigate this further.

@fcucino
Copy link

fcucino commented Apr 26, 2023

I can reproduce the same output as Ramon using Ubuntu 16.04, kernel 4.4.0 and wpa_supplicant built from this report along with hostapd built from https://github.com/intrig-unicamp/mininet-wifi/tree/krack-attack .

IVs are reset after replaying reassociation request but the script doesn't output the "final" state "this is bad" or "this is good" (packet capture).
With recent version of packages, the same test doesn't reset IVs either, so should I consider anyway as an "half win"?

@vanhoefm
Copy link
Owner

The script should display something like IV reuse detected (IV=%d, seq=%d). AP is vulnerable!. It won't explicitly say this is "good" or "bad".

@fcucino
Copy link

fcucino commented Apr 26, 2023

Yeah sorry, I was referring to that line. It's not shown, like the snippet in the first post of this issue.

@vanhoefm
Copy link
Owner

I'm not sure why that's not shown. Are you using the virtual Python environment? I, unfortunately, don't have time to debug this currently. Manually seeing that IVs are being reused is currently probably sufficient to determine that the AP is vulnerable.

@fcucino
Copy link

fcucino commented Apr 27, 2023

Yes, I'm using the Python3 virtual environment. This is the output of the script krack-ft-test.py on sta1: Xterm.sta1.log.

Manually seeing that IVs are being reused is currently probably sufficient to determine that the AP is vulnerable.

Great, thanks

@vanhoefm
Copy link
Owner

Based on that output I would say the AP is vulnerable. I'm going to reopen this issue since there's indeed something wrong with the code (if anyone reads this: pull requests to fix it are welcome).

@vanhoefm vanhoefm reopened this Apr 27, 2023
@fcucino
Copy link

fcucino commented May 1, 2023

To get the message to appear in a likely vulnerable environment I checked out that removing an IV list reset on every FT reassoc packet makes IV reuse detected appear. You can see this commit.

For my needs at the moment it's good, but I did not test it in a not vulnerable environment, for example.

krack-ft-ping-ap2

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

4 participants