CVE-2020-5217
Last modified
CVE-2020-5217 is a medium-severity vulnerability rated 5.8/10 on the CVSS scale. In Secure Headers (RubyGem secure_headers), a directive injection vulnerability is present in versions before 3.8.0, 5.1.0, and 6.2.0. If user-supplied input was passed into append/override_content_security_policy_directives, a semicolon could be injected leading to directive injection. EPSS estimates a 1.81% chance of exploitation in the next 30 days.
Description
In Secure Headers (RubyGem secure_headers), a directive injection vulnerability is present in versions before 3.8.0, 5.1.0, and 6.2.0. If user-supplied input was passed into append/override_content_security_policy_directives, a semicolon could be injected leading to directive injection. This could be used to e.g. override a script-src directive. Duplicate directives are ignored and the first one wins. The directives in secure_headers are sorted alphabetically so they pretty much all come before script-src. A previously undefined directive would receive a value even if SecureHeaders::OPT_OUT was supplied. The fixed versions will silently convert the semicolons to spaces and emit a deprecation warning when this happens. This will result in innocuous browser console messages if being exploited/accidentally used. In future releases, we will raise application errors resulting in 500s. Depending on what major version you are using, the fixed versions are 6.2.0, 5.1.0, 3.8.0.
Metrics
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:C/C:N/I:L/A:N
Weakness Enumeration
Affected Software
| Vendor | Product | Versions |
|---|---|---|
| Secure Headers | < 3.8.0 | |
| Secure Headers | >= 5.0.0, < 5.1.0 | |
| Secure Headers | >= 6.0.0, < 6.2.0 |
References
- https://github.com/twitter/secure_headers/issues/418Exploit, Third Party Advisory
- https://github.com/twitter/secure_headers/pull/421Third Party Advisory
- https://github.com/twitter/secure_headers/security/advisories/GHSA-xq52-rv6w-397cMitigation, Third Party Advisory
- https://github.com/twitter/secure_headers/issues/418Exploit, Third Party Advisory
- https://github.com/twitter/secure_headers/pull/421Third Party Advisory
- https://github.com/twitter/secure_headers/security/advisories/GHSA-xq52-rv6w-397cMitigation, Third Party Advisory
Timeline
- Published
- Last Modified
- Status
- Modified
Frequently Asked Questions
What is CVE-2020-5217?
How severe is CVE-2020-5217?
How do I fix CVE-2020-5217?
Are you affected by CVE-2020-5217?
Run a free Strix scan to check your systems for this vulnerability.
Scan your code nowSource: NVD / NIST
