Home

Description

Allocation of Resources Without Limits or Throttling vulnerability in mtrudel bandit allows unauthenticated remote denial of service via memory exhaustion when WebSocket permessage-deflate compression is enabled. 'Elixir.Bandit.WebSocket.PerMessageDeflate':inflate/2 in lib/bandit/websocket/permessage_deflate.ex calls :zlib.inflate/2 with no output-size cap, then materializes the entire decompressed payload as a single binary via IO.iodata_to_binary/1. The websocket_options.max_frame_size option only bounds the on-the-wire (compressed) frame size, not the decompressed output. A high-ratio compressed frame (e.g. uniform data at ~1024:1 ratio) can stay well under any wire-size limit while forcing GiB-scale heap allocations in the connection process before any application code runs. An unauthenticated attacker who can open a WebSocket connection can send a single such frame to exhaust the BEAM node's memory and trigger an OOM kill. This vulnerability requires both Bandit's server-level websocket_options.compress and the per-upgrade compress: true option passed to WebSockAdapter.upgrade/4 to be enabled. Stock Phoenix and LiveView applications are not affected as they default to compress: false. This issue affects bandit: from 0.5.9 before 1.11.0.

PUBLISHED Reserved 2026-04-07 | Published 2026-05-01 | Updated 2026-05-02 | Assigner EEF




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

Problem types

CWE-770 Allocation of Resources Without Limits or Throttling

Product status

Default status
unaffected

0.5.9 (semver) before 1.11.0
affected

Default status
unaffected

da4027cff7d2b80319e76fe7a32f84beceec490a (git) before 1.11.0
affected

Credits

Peter Ullrich finder

References

github.com/...bandit/security/advisories/GHSA-frh3-6pv6-rc8j exploit

github.com/...bandit/security/advisories/GHSA-frh3-6pv6-rc8j vendor-advisory related

cna.erlef.org/cves/CVE-2026-39804.html related

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

github.com/...ommit/8156921a51e684a951221da7bc30a70a022f722e patch

cve.org (CVE-2026-39804)

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

Download JSON