CVE-2023-31147Use of Insufficiently Random Values in C-ares

Severity
6.5MEDIUMNVD
CNA5.9
EPSS
0.1%
top 74.04%
CISA KEV
Not in KEV
Exploit
No known exploits
Timeline
PublishedMay 25

Description

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

CVSS vector

CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:L/I:L/A:NExploitability: 3.9 | Impact: 2.5

Affected Packages3 packages

CVEListV5c-ares/c-ares< 1.19.1
NVDc-ares_project/c-ares< 1.19.1
Debianc-ares/c-ares< 1.19.1-2+1

Also affects: Fedora 37, 38

🔴Vulnerability Details

2
OSV
CVE-2023-31147: c-ares is an asynchronous resolver library2023-05-25
CVEList
Insufficient randomness in generation of DNS query IDs in c-ares2023-05-25

📋Vendor Advisories

3
Red Hat
c-ares: Insufficient randomness in generation of DNS query IDs2023-05-22
Microsoft
Insufficient randomness in generation of DNS query IDs in c-ares2023-05-09
Debian
CVE-2023-31147: c-ares - c-ares is an asynchronous resolver library. When /dev/urandom or RtlGenRandom() ...2023
CVE-2023-31147 — Use of Insufficiently Random Values | cvebase