CVE-2020-52173
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.
- Public exploit or PoC is available
Exploitation evidence
1 of 7 sourcesExploitation momentum
413 days of EPSSCVSS:3.1/AV:N/AC:H/PR:L/UI:R/S:C/C:L/I:L/A:N- 23 Jan 2020Published to NVD
- 17 Jun 2026Last modified
Public Exploits & PoCs
3ATT&CK techniques
5Techniques this CVE enables. Pills with a solid outline are high confidence - named directly in ATT&CK or Nuclei, or human-curated by CTID; the rest are inferred from the weakness type using MITRE's CVE Mapping Methodology and the CWE → CAPEC chain. Broad, generic-weakness guesses are filtered out. A small N× marks a technique that N independent sources agree on.
CAPEC attack patterns
12Attack patterns this CVE enables - the bridge from weakness to ATT&CK technique.