Amazon Linux 2023 Security Advisory: ALAS2023-2026-1525
Advisory Released Date: 2026-04-01
Advisory Updated Date: 2026-04-01
FAQs regarding Amazon Linux ALAS/CVE Severity
Undici allows duplicate HTTP Content-Length headers when they are provided in an array with case-variant names (e.g., Content-Length and content-length). This produces malformed HTTP/1.1 requests with multiple conflicting Content-Length values on the wire.
Who is impacted:
* Applications using undici.request(), undici.Client, or similar low-level APIs with headers passed as flat arrays
* Applications that accept user-controlled header names without case-normalization
Potential consequences:
* Denial of Service: Strict HTTP parsers (proxies, servers) will reject requests with duplicate Content-Length headers (400 Bad Request)
* HTTP Request Smuggling: In deployments where an intermediary and backend interpret duplicate headers inconsistently (e.g., one uses the first value, the other uses the last), this can enable request smuggling attacks leading to ACL bypass, cache poisoning, or credential hijacking (CVE-2026-1525)
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. (CVE-2026-1526)
ImpactWhen an application passes user-controlled input to the upgrade option of client.request(), an attacker can inject CRLF sequences (\r\n) to:
* Inject arbitrary HTTP headers
* Terminate the HTTP request prematurely and smuggle raw data to non-HTTP services (Redis, Memcached, Elasticsearch)
The vulnerability exists because undici writes the upgrade value directly to the socket without validating for invalid header characters:
// lib/dispatcher/client-h1.js:1121
if (upgrade) {
header += `connection: upgrade\r\nupgrade: ${upgrade}\r\n`
} (CVE-2026-1527)
ImpactA server can reply with a WebSocket frame using the 64-bit length form and an extremely large length. undici's ByteParser overflows internal math, ends up in an invalid state, and throws a fatal TypeError that terminates the process.
Patches
Patched in the undici version v7.24.0 and v6.24.0. Users should upgrade to this version or later. (CVE-2026-1528)
ImpactThe 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 (CVE-2026-2229)
Affected Packages:
nodejs22
Issue Correction:
Run dnf update nodejs22 --releasever 2023.10.20260330 or dnf update --advisory ALAS2023-2026-1525 --releasever 2023.10.20260330 to update your system.
More information on how to update your system can be found on this page: Amazon Linux 2023 documentation
aarch64:
nodejs22-libs-debuginfo-22.22.1-1.amzn2023.0.2.aarch64
v8-12.4-devel-12.4.254.21-1.22.22.1.1.amzn2023.0.2.aarch64
nodejs22-full-i18n-22.22.1-1.amzn2023.0.2.aarch64
nodejs22-devel-22.22.1-1.amzn2023.0.2.aarch64
nodejs22-debuginfo-22.22.1-1.amzn2023.0.2.aarch64
nodejs22-22.22.1-1.amzn2023.0.2.aarch64
nodejs22-libs-22.22.1-1.amzn2023.0.2.aarch64
nodejs22-npm-10.9.4-1.22.22.1.1.amzn2023.0.2.aarch64
nodejs22-debugsource-22.22.1-1.amzn2023.0.2.aarch64
noarch:
nodejs22-docs-22.22.1-1.amzn2023.0.2.noarch
src:
nodejs22-22.22.1-1.amzn2023.0.2.src
x86_64:
nodejs22-libs-debuginfo-22.22.1-1.amzn2023.0.2.x86_64
nodejs22-debuginfo-22.22.1-1.amzn2023.0.2.x86_64
nodejs22-full-i18n-22.22.1-1.amzn2023.0.2.x86_64
nodejs22-devel-22.22.1-1.amzn2023.0.2.x86_64
v8-12.4-devel-12.4.254.21-1.22.22.1.1.amzn2023.0.2.x86_64
nodejs22-22.22.1-1.amzn2023.0.2.x86_64
nodejs22-libs-22.22.1-1.amzn2023.0.2.x86_64
nodejs22-npm-10.9.4-1.22.22.1.1.amzn2023.0.2.x86_64
nodejs22-debugsource-22.22.1-1.amzn2023.0.2.x86_64