// For flags

CVE-2025-24964

Remote Code Execution when accessing a malicious website while Vitest API server is listening

Severity Score

9.6
*CVSS v3.1

Exploit Likelihood

*EPSS

Affected Versions

*CPE

Public Exploits

0
*Multiple Sources

Exploited in Wild

-
*KEV

Decision

-
*SSVC
Descriptions

Vitest is a testing framework powered by Vite. Affected versions are subject to arbitrary remote Code Execution when accessing a malicious website while Vitest API server is listening by Cross-site WebSocket hijacking (CSWSH) attacks. When `api` option is enabled (Vitest UI enables it), Vitest starts a WebSocket server. This WebSocket server did not check Origin header and did not have any authorization mechanism and was vulnerable to CSWSH attacks. This WebSocket server has `saveTestFile` API that can edit a test file and `rerun` API that can rerun the tests. An attacker can execute arbitrary code by injecting a code in a test file by the `saveTestFile` API and then running that file by calling the `rerun` API. This vulnerability can result in remote code execution for users that are using Vitest serve API. This issue has been patched in versions 1.6.1, 2.1.9 and 3.0.5. Users are advised to upgrade. There are no known workarounds for this vulnerability.

*Credits: N/A
CVSS Scores
Attack Vector
Network
Attack Complexity
Low
Privileges Required
None
User Interaction
Required
Scope
Changed
Confidentiality
High
Integrity
High
Availability
High
* Common Vulnerability Scoring System
SSVC
  • Decision:-
Exploitation
-
Automatable
-
Tech. Impact
-
* Organization's Worst-case Scenario
Timeline
  • 2025-01-29 CVE Reserved
  • 2025-02-04 CVE Published
  • 2025-02-04 CVE Updated
  • ---------- EPSS Updated
  • ---------- Exploited in Wild
  • ---------- KEV Due Date
  • ---------- First Exploit
CWE
  • CWE-1385: Missing Origin Validation in WebSockets
CAPEC
Affected Vendors, Products, and Versions
Vendor Product Version Other Status
Vendor Product Version Other Status <-- --> Vendor Product Version Other Status
Vitest-dev
Search vendor "Vitest-dev"
Vitest
Search vendor "Vitest-dev" for product "Vitest"
<= 0.0.125
Search vendor "Vitest-dev" for product "Vitest" and version " <= 0.0.125"
en
Affected
Vitest-dev
Search vendor "Vitest-dev"
Vitest
Search vendor "Vitest-dev" for product "Vitest"
>= 1.0.0 < 1.6.1
Search vendor "Vitest-dev" for product "Vitest" and version " >= 1.0.0 < 1.6.1"
en
Affected
Vitest-dev
Search vendor "Vitest-dev"
Vitest
Search vendor "Vitest-dev" for product "Vitest"
>= 2.0.0 < 2.1.9
Search vendor "Vitest-dev" for product "Vitest" and version " >= 2.0.0 < 2.1.9"
en
Affected
Vitest-dev
Search vendor "Vitest-dev"
Vitest
Search vendor "Vitest-dev" for product "Vitest"
>= 3.0.0 < 3.0.5
Search vendor "Vitest-dev" for product "Vitest" and version " >= 3.0.0 < 3.0.5"
en
Affected