Name | CVE-2024-27983 |
Description | An attacker can make the Node.js HTTP/2 server completely unavailable by sending a small amount of HTTP/2 frames packets with a few HTTP/2 frames inside. It is possible to leave some data in nghttp2 memory after reset when headers with HTTP/2 CONTINUATION frame are sent to the server and then a TCP connection is abruptly closed by the client triggering the Http2Session destructor while header frames are still being processed (and stored in memory) causing a race condition. |
Source | CVE (at NVD; CERT, LWN, oss-sec, fulldisc, Red Hat, Ubuntu, Gentoo, SUSE bugzilla/CVE, GitHub advisories/code/issues, web search, more) |
References | DLA-3886-1 |
Debian Bugs | 1068347 |
Vulnerable and fixed packages
The table below lists information on source packages.
Source Package | Release | Version | Status |
---|
nodejs (PTS) | jessie | 0.10.29~dfsg-2 | vulnerable |
| stretch | 4.8.2~dfsg-1 | vulnerable |
| buster (security), buster, buster (lts) | 10.24.0~dfsg-1~deb10u4 | fixed |
| bullseye | 12.22.12~dfsg-1~deb11u4 | vulnerable |
| bullseye (security) | 12.22.12~dfsg-1~deb11u5 | fixed |
| bookworm | 18.19.0+dfsg-6~deb12u2 | vulnerable |
| bookworm (security) | 18.19.0+dfsg-6~deb12u1 | vulnerable |
| sid, trixie | 20.18.1+dfsg-1 | fixed |
The information below is based on the following data on fixed versions.
Package | Type | Release | Fixed Version | Urgency | Origin | Debian Bugs |
---|
nodejs | source | jessie | (unfixed) | end-of-life | | |
nodejs | source | stretch | (unfixed) | end-of-life | | |
nodejs | source | buster | (not affected) | | | |
nodejs | source | bullseye | 12.22.12~dfsg-1~deb11u5 | | DLA-3886-1 | |
nodejs | source | (unstable) | 18.20.1+dfsg-1 | | | 1068347 |
Notes
https://nodejs.org/en/blog/vulnerability/april-2024-security-releases/
Fixed by: https://github.com/nodejs/node/commit/0fb816dbccde955cd24acc1b16497a91fab507c8 (v18.20.1)
[buster] - nodejs <not-affected> (Exploit does not lead to segfault and exit quietly. Vulnerable code introduced in refactoring in V12)