Use of Insufficiently Random Values Affecting nodejs:18/npm package, versions <1:9.5.0-1.18.14.2.3.module+el9.2.0.z+18964+42696395


Severity

Recommended
high

Based on Red Hat Enterprise Linux security rating.

Threat Intelligence

EPSS
0.14% (51st 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-RHEL9-NODEJS-7869361
  • published3 Sept 2024
  • disclosed22 May 2023

Introduced: 22 May 2023

CVE-2023-31147  (opens in a new tab)
CWE-330  (opens in a new tab)

How to fix?

Upgrade RHEL:9 nodejs:18/npm to version 1:9.5.0-1.18.14.2.3.module+el9.2.0.z+18964+42696395 or higher.
This issue was patched in RHSA-2023:3577.

NVD Description

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

c-ares is an asynchronous resolver library. When /dev/urandom or RtlGenRandom() are unavailable, c-ares uses rand() to generate random numbers used for DNS query ids. This is not a CSPRNG, and it is also not seeded by srand() so will generate predictable output. Input from the random number generator is fed into a non-compilant RC4 implementation and may not be as strong as the original RC4 implementation. No attempt is made to look for modern OS-provided CSPRNGs like arc4random() that is widely available. This issue has been fixed in version 1.19.1.

CVSS Scores

version 3.1