CVE-2024-45614

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.
HTTP Request/Response Smuggling
ProviderTypeBase ScoreAtk. VectorAtk. ComplexityPriv. RequiredVector
NISTNIST
5.4 MEDIUM
NETWORK
HIGH
NONE
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:C/C:L/I:L/A:N
GitHub_MCNA
5.4 MEDIUM
NETWORK
HIGH
NONE
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:C/C:L/I:L/A:N
CISA-ADPADP
---
---
Base Score
CVSS 3.x
EPSS Score
Percentile: 14%
VendorProductVersion
pumapuma
𝑥
< 5.6.9
pumapuma
6.0.0 ≤
𝑥
< 6.4.3
𝑥
= Vulnerable software versions
Debian logo
Debian Releases
Debian Product
Codename
puma
bullseye
vulnerable
bullseye (security)
4.3.8-1+deb11u3
fixed
bookworm
5.6.5-3+deb12u1
fixed
sid
6.6.0-2
fixed
trixie
6.6.0-2
fixed
Ubuntu logo
Ubuntu Releases
Ubuntu Product
Codename
puma
plucky
Fixed 6.4.2-5ubuntu4
released
oracular
Fixed 6.4.2-5ubuntu4
released
noble
Fixed 6.4.2-4ubuntu4.3
released
jammy
Fixed 5.5.2-2ubuntu2+esm2
released
focal
Fixed 3.12.4-1ubuntu2+esm2
released