webtransport-go: Memory Exhaustion Attack due to Missing Cleanup of Streams Map
Moderate severity
GitHub Reviewed
Published
Feb 12, 2026
in
quic-go/webtransport-go
•
Updated Feb 12, 2026
Description
Published to the GitHub Advisory Database
Feb 12, 2026
Reviewed
Feb 12, 2026
Published by the National Vulnerability Database
Feb 12, 2026
Last updated
Feb 12, 2026
Summary
An attacker can cause unbounded memory consumption repeatedly creating and closing many WebTransport streams. Closed streams were not removed from an internal session map, preventing garbage collection of their resources.
Details
webtransport-go maintains an internal map tracking WebTransport streams (both unidirectional and bidirectional) belonging to a session. In affected versions, entries for closed streams were not removed from this map, causing the map to grow indefinitely as streams were created and closed.
A malicious peer can exploit this by opening large numbers of streams and closing them, leading to steady memory growth proportional to the number of closed streams.
The Fix
webtransport-go now removes closed streams from the internal map upon closure. This allows the associated resources to be garbage collected, bounding memory usage to active streams only.
References