CVE-2024-45614
MEDIUMPuma < 5.6.9 - HTTP Request Smuggling
Title source: ruleDescription
Puma is a Ruby/Rack web server built for parallelism. In affected versions clients could clobber values set by intermediate proxies (such as X-Forwarded-For) by providing a underscore version of the same header (X-Forwarded_For). Any users relying on proxy set variables is affected. v6.4.3/v5.6.9 now discards any headers using underscores if the non-underscore version also exists. Effectively, allowing the proxy defined headers to always win. Users are advised to upgrade. Nginx has a underscores_in_headers configuration variable to discard these headers at the proxy level as a mitigation. Any users that are implicitly trusting the proxy defined headers for security should immediately cease doing so until upgraded to the fixed versions.
Exploits (1)
nomisec
WORKING POC
by ooooooo-q · poc
https://github.com/ooooooo-q/puma_header_normalization-CVE-2024-45614
Scores
CVSS v3
5.4
EPSS
0.0074
EPSS Percentile
73.0%
Attack Vector
NETWORK
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:C/C:L/I:L/A:N
Details
CWE
CWE-639
CWE-444
Status
published
Products (2)
puma/puma
< 5.6.9
rubygems/puma
0 - 5.6.9RubyGems
Published
Sep 19, 2024
Tracked Since
Feb 18, 2026