Home

Description

Unexpected Status Code or Return Value vulnerability in ninenines gun (gun_http module) allows a malicious HTTP server to force the client into raw protocol mode via an unsolicited 101 Switching Protocols response. In gun_http:handle_inform/8, when a 101 Switching Protocols response is received over HTTP/1.1, the function verifies only that the Upgrade header is syntactically valid and that the stream reference is a plain reference(). It does not check whether the client ever sent an Upgrade or Connection: upgrade header on the corresponding request. Because this check is absent, any 101 response (solicited or not) causes gun to dispatch a gun_upgrade message to the caller and transition the entire connection to raw protocol mode. A malicious or compromised HTTP server can send an unsolicited 101 response to any HTTP/1.1 request, causing the gun client to abandon HTTP framing for that connection. Once in raw mode, gun_raw applies no flow control (flow=infinity) and re-arms socket active mode after every received packet, so the server can flood the client with arbitrary bytes. These are forwarded as unbounded gun_data messages to the owner process, exhausting its mailbox and BEAM memory, ultimately crashing the VM. This issue affects gun: from 2.0.0 before 2.4.0.

PUBLISHED Reserved 2026-05-04 | Published 2026-06-08 | Updated 2026-06-08 | Assigner EEF




HIGH: 8.7CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:N/VA:H/SC:N/SI:N/SA:N

Problem types

CWE-841 Improper Enforcement of Behavioral Workflow

Product status

Default status
unaffected

2.0.0 (semver) before 2.4.0
affected

Default status
unaffected

a3c2edbb8c807717e2f10520c6cf1e77a62eab2e (git) before 5b48068c29ce5e112cb149b5857c7d4dc319a81b
affected

Credits

Peter Ullrich finder

Loïc Hoguin remediation developer

References

cna.erlef.org/cves/CVE-2026-43974.html related third-party-advisory

osv.dev/vulnerability/EEF-CVE-2026-43974 related

github.com/...ommit/5b48068c29ce5e112cb149b5857c7d4dc319a81b patch

cve.org (CVE-2026-43974)

nvd.nist.gov (CVE-2026-43974)

Download JSON