usd-2020-0048 | Gophish v0.10.1
Advisory ID: usd-2020-0048
CVE Number: CVE-2020-24708
Affected Product: Gophish
Affected Version: v0.10.1
Vulnerability Type: Stored Cross-Site Scripting
Security Risk: Medium
Vendor URL: https://getgophish.com/
Vendor Status: Fixed
Description
Gophish is vulnerable to stored self-XSS. In v0.10.1 Gophish introduced an impersonation button, which allows normal users to exploit administrative users.
The new sending profile form’s “Host“ input field is vulnerable to XSS. The payload executes when sending a test email. The XSS gets stored when saving the profile. A rogue user could exploit an admin by asking him to impersonate him and test his broken sending profile.
Proof of Concept (PoC)
The rogue user injects an XSS payload into a new Sending Profile (/sending_profiles). By saving the Sending Profile, also the injected XSS payload gets stored. The rogue user then requests assistance from an admin user to check out his ”broken” sending profile.
data:image/s3,"s3://crabby-images/c2702/c2702c8443cff7cd253826fab9cda167f76d2af0" alt="usd20200048-1-300x135"
The admin user impersonates the user that he wants to assist
data:image/s3,"s3://crabby-images/641c0/641c0a0efa93607d49dba59eb985d8aa72041478" alt="usd20200048-2"
The admin user edits the user’s Sending Profile
data:image/s3,"s3://crabby-images/c0f75/c0f7535153a28503e7740cec2ed0f1502aca05ff" alt="usd20200048-3"
The admin user sends a test email
data:image/s3,"s3://crabby-images/13ef5/13ef5abbd1580302b35edcf69b4d8c89e4fe39d4" alt="usd20200048-4"
The XSS payload executes in the admin user’s browser
data:image/s3,"s3://crabby-images/2e930/2e930270d81eafdab9c891961c5a2c1f13fd1af2" alt="usd20200048-5"
Fix
It is recommended to treat all input on the website as potentially dangerous. Hence, all output that is dynamically generated based on user-controlled data should be encoded according to its context. The majority of programming languages support standard procedures for encoding meta characters. For example, PHP has the built-in function htmlspecialchars().
Additionally, all input should be validated on the server-side. Where possible, whitelist filters should be used. The more restrictive a filter can be specified, the better the protection it provides. Whitelisting is especially recommended if input values have a well defined format or a list of valid input values exists. Invalid values should not be sanitized and forwarded to the application. Instead, requests with invalid values should be rejected.
Timeline
- 2020-06-18 First contact request via security@getgophish.com
- 2020-06-22 Vendor responds to initial contact
- 2020-08-07 Vendor publishes a fix on https://github.com/gophish/gophish/commit/90fed5a575628b89eaf941e1627b49e0f3693812
- 2020-09-29 Security advisory released
Credits
This security vulnerabilities were found by Marcus Nilsson of usd AG.