CVE-2022-39218 – @fastly/js-compute
Package
Manager: npm
Name: @fastly/js-compute
Vulnerable Version: >=0.4.0 <0.5.3
Severity
Level: High
CVSS v3.1: CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N
CVSS v4.0: CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:H/VI:N/VA:N/SC:N/SI:N/SA:N
EPSS: 0.00127 pctl0.32772
Details
Fastly Compute@Edge JS Runtime has fixed random number seed during compilation ### Impact `Math.random` and `crypto.getRandomValues` methods failed to use sufficiently random values. The initial value to seed the CSPRNG (cryptographically secure pseudorandom number generator) was baked-in to the final WebAssembly module meaning the sequence of numbers generated was predictable for that specific WebAssembly module. An attacker with access to that same WebAssembly module that calls the affected methods could use the fixed seed to predict random numbers generated by these functions. This information could be used to bypass cryptographic security controls, for example to disclose sensitive data encrypted by functions that use these generators. ### Patches The problem has been fixed in version 0.5.3. Corrected `Math.random` and `crypto.getRandomValues` methods to always use sufficiently random values. The previous versions would use a CSPRNG (cryptographically secure pseudorandom number generator) which we would seed with a random value. However, due to our use of Wizer, the initial value to seed the CSPRNG was baked-in to the final WebAssembly module meaning the sequence of numbers generated was predictable for that specific WebAssembly module. The new implementations of both Math.random and `crypto.getRandomValues` do not use a CSPRNG and instead pull random values from WASI (WebAssembly System Interface) libc’s random_get function, which is always a sufficiently random value. ### Workarounds There are no workarounds, you must upgrade to version 0.5.3 or later.
Metadata
Created: 2022-09-20T20:45:10Z
Modified: 2022-09-21T19:22:40Z
Source: https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2022/09/GHSA-cmr8-5w4c-44v8/GHSA-cmr8-5w4c-44v8.json
CWE IDs: ["CWE-330", "CWE-335"]
Alternative ID: GHSA-cmr8-5w4c-44v8
Finding: F034
Auto approve: 1