CVE-2026-32873

HIGH

ewe: Loop with Unreachable Exit Condition ('Infinite Loop')

Title source: cna
STIX 2.1

Description

ewe is a Gleam web server. Versions 0.8.0 through 3.0.4 contain a bug in the handle_trailers function where rejected trailer headers (forbidden or undeclared) cause an infinite loop. When handle_trailers encounters such a trailer, three code paths (lines 520, 523, 526) recurse with the original buffer (rest) instead of advancing past the rejected header (Buffer(header_rest, 0)), causing decoder.decode_packet to re-parse the same header on every iteration. The resulting loop has no timeout or escape — the BEAM process permanently wedges at 100% CPU. Any application that calls ewe.read_body on chunked requests is affected, and this is exploitable by any unauthenticated remote client before control returns to application code, making an application-level workaround impossible. This issue is fixed in version 3.0.5.

Scores

CVSS v3 7.5
EPSS 0.0002
EPSS Percentile 3.6%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H

CISA SSVC

Vulnrichment
Exploitation poc
Automatable yes
Technical Impact partial

Details

CWE
CWE-825 CWE-835
Status published
Products (3)
Hex/ewe 0.8.0 - 3.0.5Hex
vshakitskiy/ewe 0.8.0 - 3.0.5
vshakitskiy/ewe >= 0.8.0, < 3.0.5
Published Mar 20, 2026
Tracked Since Mar 20, 2026