CVE-2026-43970
Decompression Bomb in cow_spdy:inflate/2 Allows Memory Exhaustion via Crafted SPDY Frame
Weakness Type (CWE)
CWE-409 — CWE-409 Improper Handling of Highly Compressed Data (Data Amplification)
CAPEC
Vulnerability description
Improper Handling of Highly Compressed Data (Data Amplification) vulnerability in ninenines cowlib allows unauthenticated remote denial of service via memory exhaustion.
cow_spdy:inflate/2 in cowlib passes peer-supplied compressed bytes directly to zlib:inflate/2 with no output size bound. The SPDY header compression dictionary (?ZDICT) is public, and zlib compresses long runs of repeated bytes at roughly 1024:1, so a few kilobytes of SPDY frame payload can decompress to gigabytes on the BEAM heap, OOM-killing the node. A single unauthenticated SPDY frame is sufficient to trigger the condition. The parsers for syn_stream, syn_reply, and headers frame types are all affected via cow_spdy:parse_headers/2.
This issue affects cowlib from 0.1.0 before 2.16.1.
Affected
pkg:hex/cowlib
| Module | Source File | Routine |
|---|---|---|
cow_spdy
|
src/cow_spdy.erl
|
cow_spdy:parse/2
|
cow_spdy:inflate/2
|
||
cow_spdy:parse_headers/2
|
||
cow_spdy:parse_headers/4
|
pkg:github/ninenines/cowlib
| Module | Source File | Routine |
|---|---|---|
cow_spdy
|
src/cow_spdy.erl
|
cow_spdy:parse/2
|
cow_spdy:inflate/2
|
||
cow_spdy:parse_headers/2
|
||
cow_spdy:parse_headers/4
|
| Status | Type | Version | Changes / Fixed in |
|---|---|---|---|
| affected | git ⓘ | fad5c0049d
|
< 16aad3fb9f
|
Configurations
The application must use cow_spdy:parse/2 to parse SPDY frames from an untrusted peer. cowboy itself does not use cow_spdy; only direct callers of the cow_spdy API are affected.
Solutions
Upgrade to cowlib 2.16.1 or later, in which the cow_spdy module has been removed entirely. No patched version of cow_spdy will be provided. Migrate away from SPDY, which has been deprecated since 2015 in favour of HTTP/2.
References
- https://osv.dev/vulnerability/EEF-CVE-2026-43970 related
- https://github.com/ninenines/cowlib/commit/16aad3fb9f81f5cda4d1706ff0c54237c619c282 patch
Credits
- Finder: Peter Ullrich
- Remediation developer: Loïc Hoguin
CVE record as JSON:
GET /cves/CVE-2026-43970.json
OSV record as JSON:
GET /osv/EEF-CVE-2026-43970.json