Use of Insufficiently Random Values Affecting nodejs:20/npm package, versions <1:10.8.2-1.20.18.2.1.module+el8.10.0+22767+a3309b10


Severity

Recommended
high

Based on Red Hat Enterprise Linux security rating.

Threat Intelligence

Exploit Maturity
Not Defined
EPSS
0.04% (13th percentile)

Do your applications use this vulnerable package?

In a few clicks we can analyze your entire application and see what components are vulnerable in your application, and suggest you quick fixes.

Test your applications

Snyk Learn

Learn about Use of Insufficiently Random Values vulnerabilities in an interactive lesson.

Start learning
  • Snyk IDSNYK-RHEL8-NODEJS-8730312
  • published15 Feb 2025
  • disclosed21 Jan 2025

Introduced: 21 Jan 2025

NewCVE-2025-22150  (opens in a new tab)
CWE-330  (opens in a new tab)

How to fix?

Upgrade RHEL:8 nodejs:20/npm to version 1:10.8.2-1.20.18.2.1.module+el8.10.0+22767+a3309b10 or higher.
This issue was patched in RHSA-2025:1351.

NVD Description

Note: Versions mentioned in the description apply only to the upstream nodejs:20/npm package and not the nodejs:20/npm package as distributed by RHEL. See How to fix? for RHEL:8 relevant fixed versions and status.

Undici is an HTTP/1.1 client. Starting in version 4.5.0 and prior to versions 5.28.5, 6.21.1, and 7.2.3, undici uses Math.random() to choose the boundary for a multipart/form-data request. It is known that the output of Math.random() can be predicted if several of its generated values are known. If there is a mechanism in an app that sends multipart requests to an attacker-controlled website, they can use this to leak the necessary values. Therefore, an attacker can tamper with the requests going to the backend APIs if certain conditions are met. This is fixed in versions 5.28.5, 6.21.1, and 7.2.3. As a workaround, do not issue multipart requests to attacker controlled servers.

CVSS Scores

version 3.1