CVE 8.7 HIGH

Infinite loop in Alt-Svc header parser in hackney_CVE-2026-47066

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

Loop with Unreachable Exit Condition ('Infinite Loop') vulnerability in benoitc hackney allows Excessive Allocation. The Alt-Svc response header parser in src/hackney_altsvc.erl does not guarantee forward progress. When parse_token/2 receives a non-token, non-whitespace, non-comma byte (e.g. !, @, =, ;), it returns the input unchanged. skip_comma/1 also returns the buffer unchanged when the first byte is not a comma. parse_entries/2 then recurses with identical data, creating a tight infinite tail-recursive loop that pins a scheduler at 100% CPU. The calling process never returns.

The entry point parse_and_cache/3 is called synchronously in the connection process on every HTTP response. A single-byte Alt-Svc: ! response header is sufficient to trigger the hang; the header is fully controlled by any HTTP origin the client connects to.

This issue affects hackney: from 2.0.0-beta.1 before 4.0.1.

AI Analysis

Infinite loop in Alt-Svc header parser in hackney due to lack of forward progress guarantee, allowing excessive allocation and potential denial-of-service

Basic Information

ID CVE-2026-47066
Source EEF
Published May 25, 2026 at 14:00

Affected Product

Vendor benoitc
Product hackney
Version 2.0.0-beta.1
Affected Versions benoitc hackney 2.0.0-beta.1
benoitc hackney 408e5fe20302226ea8c74dde2bcbd452d712b5b2

CWE Classification

AI Assessment

AI Score 8.7 / 10
AI Severity High
Vendor benoitc
Product hackney
Version 2.0.0-beta.1 to 4.0.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.