Asymmetric denial of service In node-undici
Description
Undici has Unhandled Exception in WebSocket Client Due to Invalid server_max_window_bits Validation
Impact
The undici WebSocket client is vulnerable to a denial-of-service attack due to improper validation of the server_max_window_bits parameter in the permessage-deflate extension. When a WebSocket client connects to a server, it automatically advertises support for permessage-deflate compression. A malicious server can respond with an out-of-range server_max_window_bits value (outside zlib's valid range of 8-15). When the server subsequently sends a compressed frame, the client attempts to create a zlib InflateRaw instance with the invalid windowBits value, causing a synchronous RangeError exception that is not caught, resulting in immediate process termination.
The vulnerability exists because:
The isValidClientWindowBits() function only validates that the value contains ASCII digits, not that it falls within the valid range 8-15
The createInflateRaw() call is not wrapped in a try-catch block
The resulting exception propagates up through the call stack and crashes the Node.js process
Patches
Has the problem been patched? What versions should users upgrade to?
Workarounds
Is there a way for users to fix or remediate the vulnerability without upgrading?
Mitigation
Update Impact
Minimal update. May introduce new vulnerabilities or breaking changes.
Ecosystem | Package | Affected version | Patched versions |
|---|---|---|---|
debian 12 | - | ||
npm | 6.24.0, 7.24.0 | ||
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 | ||
rpm rhel9.6 | 1:22.22.2-1.module+el9.6.0+24196+39669d4e | ||
rpm rhel10.0 | 1:22.22.2-2.el10_0 |
Aliases
References