Asymmetric denial of service In nodejs24
Description
Undici has Unbounded Memory Consumption in WebSocket permessage-deflate Decompression
Description
The undici WebSocket client is vulnerable to a denial-of-service attack via unbounded memory consumption during permessage-deflate decompression. When a WebSocket connection negotiates the permessage-deflate extension, the client decompresses incoming compressed frames without enforcing any limit on the decompressed data size. A malicious WebSocket server can send a small compressed frame (a "decompression bomb") that expands to an extremely large size in memory, causing the Node.js process to exhaust available memory and crash or become unresponsive.
The vulnerability exists in the PerMessageDeflate.decompress() method, which accumulates all decompressed chunks in memory and concatenates them into a single Buffer without checking whether the total size exceeds a safe threshold.
Impact
Remote denial of service against any Node.js application using undici's WebSocket client
A single compressed WebSocket frame of ~6 MB can decompress to ~1 GB or more
Memory exhaustion occurs in native/external memory, bypassing V8 heap limits
No application-level mitigation is possible as decompression occurs before message delivery
Patches
Users should upgrade to fixed versions.
Workarounds
No workaround are possible.
Mitigation
Update Impact
Minimal update. May introduce new vulnerabilities or breaking changes.
Ecosystem | Package | Affected version | Patched versions |
|---|---|---|---|
rpm rhel10 | 1:24.14.1-2.el10_1 | ||
rpm rhel8 | 1:22.22.2-1.module+el8.10.0+24148+847b6786 | ||
rpm rhel9 | 1:22.22.2-1.module+el9.7.0+24157+8ddb2461 | ||
rpm rhel10 | 1:22.22.2-1.el10_1 | ||
debian 13 | - | ||
debian 14 | 7.24.5+dfsg+~cs3.2.0-1 | ||
npm | 6.24.0, 7.24.0 | ||
rpm rhel10.0 | 1:22.22.2-2.el10_0 | ||
rpm rhel9.6 | 1:22.22.2-1.module+el9.6.0+24196+39669d4e |
Aliases
References