Home / vulnerabilities Duo Push Timing Attack
Posted on 20 June 2015
Source : packetstormsecurity.org Link
DUO push Timing Attack
PSC Risk Assessment
CVSS 7.3, (AV:N/AC:L/Au:M/C:C/I:N/A:C/E:F/RL:ND/RC:ND)
Description
Duo push authentications are susceptible to a low-profile timing-based attack that permits an intruder to steal an authenticated session from an end-user accessing Duo-protected resources. Specifically, when multiple push notifications arrive simultaneously (or nearly so), only the final one is shown to the user. When the user authenticates that notification, only the corresponding session will actually be authenticated. If an attacker can initiate an equivalent connection slightly after the clients session, then the user will typically authorize the malicious session rather than his or her own.
Proof of Concept
PSC has created a software agent that targets Duo push authentications for remote desktop (RDP) services. This agent collects the client systems netstat information twenty or more times per second, looking for outbound connections to the Duo-protected resource.
Once detected, the agent then monitors the RDP connection to determine when the desktop has been created and the push notification has been sent. The agent then sends a notification across the network to the attackers system, where another agent immediately initiates another connection to the RDP service.
Since the malicious session begins slightly after the clients legitimate session (typically less than one second), the victims mobile device will display a single push notification representing the malicious session, rather than the legitimate one. The user will likely authorize (since a mobile authorization is expected).
The attackers system gains an authenticated session, while the victims session times out. In practical execution, most users will assume that there was a glitch of some sort, and try again without recognizing the security import of the failed connection. The timeout provides sufficient opportunity for a prepared attacker to make use of the stolen session (consider also that an attacker may target another RDP server or the RDP console session, and thus produce two simultaneous, valid RDP sessions).
Preconditions
The intruder must possess the following in order to carry out this attack:
1. Knowledge of the credentials used by the victim when accessing the resource.
a. This can usually be obtained by keylogging, collection of password vaults, file shares, etc.
2. The ability to execute code on the victims system.
Configurations Affected
Duo Security Authentication Proxy 2.4.8
Duo Win Login 1.1.8
PSCs current software agent is designed specifically for remote desktop (RDP). This design can be adapted to target other services, such as web applications, VPNs, etc. The key observation is that the malicious agent must be able to determine with reasonable precision (within one second) when the push notification has been initiated.
Also, this attack assumes that push notifications are used for authentications. If the user prefers the numeric entry method, this type of attack will not work. That said, there are practical attacks against keyboard entry as well, so this should not be considered a secure workaround or alternative.
Research Credit
Josh Stone, PSC Penetration Tester
Patrick Fussell, PSC Penetration Tester
Timeline
2015-02-04 Successful proof of concept
2015-02-13 Disclosure submitted to security@duosecurity.com
2015-02-25 Vendor Confirmation of Vulnerability
2015-06-08 Vendor Fix Released: https://www.duosecurity.com/blog/raising-the-bar-anomaly-detection