VYPR
High severity7.5NVD Advisory· Published May 13, 2026· Updated May 21, 2026

CVE-2026-39803

CVE-2026-39803

Description

Allocation of Resources Without Limits or Throttling vulnerability in mtrudel bandit allows unauthenticated remote denial of service via memory exhaustion.

The chunked clause of 'Elixir.Bandit.HTTP1.Socket':read_data/2 in lib/bandit/http1/socket.ex ignores the caller-supplied :length option when reading HTTP/1 chunked request bodies. Instead of capping the accumulated body at the configured limit (e.g. Plug.Parsers' default 8 MB), do_read_chunked_data!/5 buffers every received chunk into an iolist unconditionally and materializes the entire body as a single binary. The function always returns {:ok, body, ...}, so callers cannot interpose a 413 response.

Because Plug.Parsers runs before routing and authentication in the standard Phoenix endpoint, an unauthenticated attacker needs no valid route or credentials. Sending a single Transfer-Encoding: chunked POST request with an arbitrarily large body to any path causes the BEAM process to exhaust available memory and be terminated by the OS OOM killer.

The content-length path in the same function correctly enforces the limit and is not affected.

This issue affects bandit: from 1.4.0 before 1.11.1.

AI Insight

LLM-synthesized narrative grounded in this CVE's description and references.

Affected packages

Versions sourced from the GitHub Security Advisory.

PackageAffected versionsPatched versions
banditHex
>= 1.4.0, < 1.11.11.11.1

Affected products

4
  • Mtrudel/Banditreferences3 versions
    (expand)+ 2 more
    • (no CPE)
    • cpe:2.3:a:mtrudel:bandit:*:*:*:*:*:*:*:*range: >=1.4.0,<1.11.1
    • (no CPE)range: >=1.4.0 <1.11.1
  • ghsa-coords
    Range: >= 1.4.0, < 1.11.1

Patches

Vulnerability mechanics

References

6

News mentions

0

No linked articles in our index yet.