CVE-2022-35949

undici is an HTTP/1.1 client, written from scratch for Node.js.`undici` is vulnerable to SSRF (Server-side Request Forgery) when an application takes in **user input** into the `path/pathname` option of `undici.request`. If a user specifies a URL such as `http://127.0.0.1` or `//127.0.0.1` ```js const undici = require("undici") undici.request({origin: "http://example.com", pathname: "//127.0.0.1"}) ``` Instead of processing the request as `http://example.org//127.0.0.1` (or `http://example.org/http://127.0.0.1` when `http://127.0.0.1 is used`), it actually processes the request as `http://127.0.0.1/` and sends it to `http://127.0.0.1`. If a developer passes in user input into `path` parameter of `undici.request`, it can result in an _SSRF_ as they will assume that the hostname cannot change, when in actual fact it can change because the specified path parameter is combined with the base URL. This issue was fixed in `undici@5.8.1`. The best workaround is to validate user input before passing it to the `undici.request` call.
SSRF
ProviderTypeBase ScoreAtk. VectorAtk. ComplexityPriv. RequiredVector
NISTPrimary
5.3 MEDIUM
NETWORK
LOW
NONE
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:N
Base Score
CVSS 3.x
EPSS Score
Percentile: 60%
Affected Products (NVD)
VendorProductVersion
nodejsundici
𝑥
≤ 5.8.1
𝑥
= Vulnerable software versions
Debian logo
Debian Releases
Debian Product
Codename
node-undici
bookworm
5.15.0+dfsg1+~cs20.10.9.3-1+deb12u4
fixed
bookworm (security)
5.15.0+dfsg1+~cs20.10.9.3-1+deb12u3
fixed
sid
5.28.4+dfsg1+~cs23.12.11-2
fixed
trixie
5.28.4+dfsg1+~cs23.12.11-2
fixed
Ubuntu logo
Ubuntu Releases
Ubuntu Product
Codename
node-undici
bionic
dne
focal
dne
jammy
dne
kinetic
not-affected
trusty
dne
xenial
dne
openSUSE logo
openSUSE / SLES Releases
openSUSE Product
Release
nodejs16
suse enterprise sap 15 SP3
16.17.0-150300.7.9.1
fixed
suse enterprise sap 15 SP4
16.17.0-150400.3.6.1
fixed
suse enterprise server 15 SP3
16.17.0-150300.7.9.1
fixed
suse enterprise server 15 SP4
16.17.0-150400.3.6.1
fixed
nodejs16-devel
suse enterprise sap 15 SP3
16.17.0-150300.7.9.1
fixed
suse enterprise sap 15 SP4
16.17.0-150400.3.6.1
fixed
suse enterprise server 15 SP3
16.17.0-150300.7.9.1
fixed
suse enterprise server 15 SP4
16.17.0-150400.3.6.1
fixed
nodejs16-docs
suse enterprise sap 15 SP3
16.17.0-150300.7.9.1
fixed
suse enterprise sap 15 SP4
16.17.0-150400.3.6.1
fixed
suse enterprise server 15 SP3
16.17.0-150300.7.9.1
fixed
suse enterprise server 15 SP4
16.17.0-150400.3.6.1
fixed
npm16
suse enterprise sap 15 SP3
16.17.0-150300.7.9.1
fixed
suse enterprise sap 15 SP4
16.17.0-150400.3.6.1
fixed
suse enterprise server 15 SP3
16.17.0-150300.7.9.1
fixed
suse enterprise server 15 SP4
16.17.0-150400.3.6.1
fixed