Your RSA-2048 keys break in 2030. Find every one of them before attackers do.
Maven

GHSA-54w6-vxfh-fw7f

HIGH

Http4s improperly parses User-Agent and Server headers

Also known asCVE-2023-22465
Published
Jan 6, 2023
Updated
Dec 11, 2025
Affected
10 pkgs
Patched
7 / 10
Exploits
1 known

EPSS Exploitation Probability

via FIRST.org ↗
0.8%probability of exploitation in next 30 days
Lower Risk53th percentile+0.51%
0.00%0.45%0.90%1.34%0.1%0.8%Dec 25Apr 26Jun 26

EPSS (Exploit Prediction Scoring System) is a daily probability model maintained by FIRST.org. It estimates the likelihood a CVE will be exploited in production environments within the next 30 days, derived from real-world threat intelligence signals.

Blast Radius

10 pkgs affected
org.http4s:http4s-core_2.13org.http4s:http4s-core_2.13org.http4s:http4s-core_2.13org.http4s:http4s-core_2.13org.http4s:http4s-core_2.10org.http4s:http4s-core_2.11org.http4s:http4s-core_2.12org.http4s:http4s-core_2.12+2 more

Real-time download stats are indexed for npm and PyPI packages. This vulnerability affects Maven packages — download data is not available via public APIs for these ecosystems.

Description

Impact

The User-Agent and Server header parsers are susceptible to a fatal error on certain inputs. In http4s, modeled headers are lazily parsed, so this only applies to services that explicitly request these typed headers.

v0.21.x

val unsafe: Option[`User-Agent`] = req.headers.get(`User-Agent`)

v0.22.x, v0.23.x, v1.x

val unsafe: Option[`User-Agent`] = req.headers.get[`User-Agent`]
val alsoUnsafe: Option[`Server`] = req.headers.get[Server]

Patches

Fixes are released in 0.21.34, 0.22.15, 0.23.17, and 1.0.0-M38.

Workarounds

Use the weakly typed header interface

v0.21.x
val safe: Option[Header] = req.headers.get("User-Agent".ci)
// but don't do this
val unsafe = header.map(_.parsed) 
v0.22.x, v0.23.x, v1.x
val safe: Option[Header] = req.headers.get(ci"User-Agent")

Affected Packages

10 total 7 fixed
EcosystemPackageVulnerable rangeFix
Mavenorg.http4s:http4s-core_2.130.1.0&&< 0.21.340.21.34
Mavenorg.http4s:http4s-core_2.130.22.0&&< 0.22.150.22.15
Mavenorg.http4s:http4s-core_2.130.23.0&&< 0.23.170.23.17
Mavenorg.http4s:http4s-core_2.131.0.0-M1&&< 1.0.0-M381.0.0-M38
Mavenorg.http4s:http4s-core_2.100.1.0No fix
Mavenorg.http4s:http4s-core_2.110.1.0No fix
Exploits & PoCs
1

Research use only. For defensive security, authorized penetration testing, and academic research only. Never execute exploit code against systems without explicit written authorization.

Detection & mitigation playbook

Open-source dependency
  1. Detect

    Scan your dependency tree (package-lock.json, pnpm-lock.yaml, requirements.txt, go.sum, etc.) for org.http4s:http4s-core_2.13. O3's reachability analysis confirms whether the vulnerable code path is actually invoked in your application, so you act on real exposure instead of every transitive match.

  2. Fix

    Update org.http4s:http4s-core_2.13 to 0.21.34 or later, then make sure no transitive (indirect) dependency still pins the vulnerable range — O3 confirms GHSA-54w6-vxfh-fw7f is resolved across your whole dependency graph.

  3. Workarounds

    If you can't upgrade right away: gate or disable the affected feature, validate untrusted input at the boundary, and avoid passing attacker-controlled data into the vulnerable path. O3's runtime protection blocks exploitation in production as an interim safeguard until the upgrade lands.

  4. How O3 protects you

    O3 pinpoints whether GHSA-54w6-vxfh-fw7f is reachable in your code and exactly where to fix it, then blocks exploitation in production at runtime until the patched version is deployed.

Tailored to GHSA-54w6-vxfh-fw7f. Runtime protection reduces exposure until a permanent patch is applied and verified — it complements patching, it doesn't replace it.

Frequently Asked Questions

### Impact The `User-Agent` and `Server` header parsers are susceptible to a fatal error on certain inputs. In http4s, modeled headers are lazily parsed, so this only applies to services that explicitly request these typed headers. #### v0.21.x ```scala val unsafe: Option[`User-Agent`] = req.headers.get(`User-Agent`) ``` #### v0.22.x, v0.23.x, v1.x ```scala val unsafe: Option[`User-Agent`] = req.headers.get[`User-Agent`] val alsoUnsafe: Option[`Server`] = req.headers.get[Server] ``` ### Patches Fixes are released in 0.21.34, 0.22.15, 0.23.17, and 1.0.0-M38. ### Workarounds #### Use
O3 Security · Impact-Aware SCA

Is GHSA-54w6-vxfh-fw7f in your dependencies?

O3 detects GHSA-54w6-vxfh-fw7f across Maven dependencies and uses function-level reachability to confirm whether the vulnerable code path is actually reachable — not just present. No false positives.