CVE 8.7 HIGH

Atom table exhaustion via HTTP/2 :scheme pseudo-header in plug_cowboy_CVE-2026-32688

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

Description

Allocation of Resources Without Limits or Throttling vulnerability in elixir-plug plug_cowboy allows unauthenticated remote denial of service via atom table exhaustion.

Plug.Cowboy.Conn.conn/1 in lib/plug/cowboy/conn.ex calls String.to_atom/1 on the value returned by :cowboy_req.scheme/1. For HTTP/2 connections, cowlib passes the client-supplied :scheme pseudo-header value through verbatim without validation. Each unique value permanently allocates a new entry in the BEAM atom table. Since atoms are never garbage-collected and the atom table has a fixed limit (default 1,048,576), an unauthenticated attacker can exhaust the table by sending HTTP/2 requests with unique :scheme values, causing the Erlang VM to abort with system_limit and taking down the entire node.

This vulnerability does not affect HTTP/1.1, where cowboy derives the scheme from the listener type rather than from a client-supplied header.

This issue affects plug_cowboy: from 2.0.0 before 2.8.1.

AI Analysis

Unauthenticated remote denial of service via atom table exhaustion in elixir-plug plug_cowboy

Basic Information

ID CVE-2026-32688
Source EEF
Published Apr 27, 2026 at 13:45

Affected Product

Vendor elixir-plug
Product plug_cowboy
Version 2.0.0
Affected Versions elixir-plug plug_cowboy 2.0.0
elixir-plug plug_cowboy 12ecfd024bb179d48b018fecf074e43fe6a19c83

CWE Classification

AI Assessment

AI Score 8.7 / 10
AI Severity High
Vendor Elixir-Plug
Product plug_cowboy
Version 2.0.0 to 2.8.0

References

💭 Join the Security Discussion

🔒 Your email address will not be published. Required fields are marked *

⚠️ Please be respectful and constructive in your comments. Security discussions should remain professional.