Skip to main content

Vite CVE-2026-39363

HIGH
Information Exposure (CWE-200)
2026-04-06 https://github.com/vitejs/vite GHSA-p9ff-h696-f583
8.2
CVSS 4.0 · GitHub Advisory
Share

Severity by source

GitHub Advisory PRIMARY
8.2 HIGH
CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:N/VC:H/VI:N/VA:N/SC:N/SI:N/SA:N/E:X/CR:X/IR:X/AR:X/MAV:X/MAC:X/MAT:X/MPR:X/MUI:X/MVC:X/MVI:X/MVA:X/MSC:X/MSI:X/MSA:X/S:X/AU:X/R:X/V:X/RE:X/U:X
Red Hat
7.5 HIGH
qualitative

Primary rating from GitHub Advisory.

CVSS VectorGitHub Advisory

CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:N/VC:H/VI:N/VA:N/SC:N/SI:N/SA:N/E:X/CR:X/IR:X/AR:X/MAV:X/MAC:X/MAT:X/MPR:X/MUI:X/MVC:X/MVI:X/MVA:X/MSC:X/MSI:X/MSA:X/S:X/AU:X/R:X/V:X/RE:X/U:X
Attack Vector
Network
Attack Complexity
Low
Privileges Required
None
User Interaction
None
Scope
X

Lifecycle Timeline

4
Re-analysis Queued
Apr 15, 2026 - 20:22 vuln.today
cvss_changed
Analysis Generated
Apr 07, 2026 - 00:15 vuln.today
Patch released
Apr 07, 2026 - 00:15 nvd
Patch available
CVE Published
Apr 06, 2026 - 18:03 nvd
HIGH 8.2

Blast Radius

ecosystem impact
† from your stack dependencies † transitive graph · vuln.today resolves 4-path depth
  • 31 npm packages depend on vite (27 direct, 4 indirect)

Ecosystem-wide dependent count for version 8.0.0.

DescriptionGitHub Advisory

Summary

server.fs check was not enforced to the fetchModule method that is exposed in Vite dev server's WebSocket.

Impact

Only apps that match the following conditions are affected:

  • explicitly exposes the Vite dev server to the network (using --host or server.host config option)
  • WebSocket is not disabled by server.ws: false

Arbitrary files on the server (development machine, CI environment, container, etc.) can be exposed.

Details

If it is possible to connect to the Vite dev server’s WebSocket without an Origin header, an attacker can invoke fetchModule via the custom WebSocket event vite:invoke and combine file://... with ?raw (or ?inline) to retrieve the contents of arbitrary files on the server as a JavaScript string (e.g., export default "...").

The access control enforced in the HTTP request path (such as server.fs.allow) is not applied to this WebSocket-based execution path.

PoC

  1. Start the dev server on the target

Example (used during validation with this repository):

bash
   pnpm -C playground/alias exec vite --host 0.0.0.0 --port 5173
  1. Confirm that access is blocked via the HTTP path (example: arbitrary file)
bash
   curl -i 'http://localhost:5173/@fs/etc/passwd?raw'

Result: 403 Restricted (outside the allow list) <img width="3898" height="1014" alt="image" src="https://github.com/user-attachments/assets/f6593377-549c-45d7-b562-5c19833438af" />

  1. Confirm that the same file can be retrieved via the WebSocket path

By connecting to the HMR WebSocket without an Origin header and sending a vite:invoke request that calls fetchModule with a file://... URL and ?raw, the file contents are returned as a JavaScript module. <img width="1049" height="296" alt="image" src="https://github.com/user-attachments/assets/af969f7b-d34e-4af4-8adb-5e2b83b31972" /> <img width="1382" height="955" alt="image" src="https://github.com/user-attachments/assets/6a230d2e-197a-4c9c-b373-d0129756d5d7" />

AnalysisAI

Vite dev server WebSocket allows unauthorized file system access, bypassing server.fs.allow restrictions when developers expose dev servers to networks (via --host). Attackers exploiting this can read arbitrary files (credentials, source code, secrets) from the development machine or CI environment through a WebSocket vite:invoke event calling fetchModule with file:// URLs. …

Unlock full vulnerability intelligence

  • Risk assessment & exploitation conditions
  • Attack chain visualization
  • Remediation with exact patch versions
  • Threat intelligence from 22 sources
  • Personal watchlist & email alerts

Free forever · No credit card required

Attack ChainAIDerived

Hypothetical attack flow derived from CVE metadata

Access
Connect to exposed Vite dev server WebSocket
Exploit
Call fetchModule method without fs restrictions
Execution
Read arbitrary files from server filesystem
Impact
Exfiltrate sensitive development or environment files

Vulnerability AssessmentAI

Exploitation Vite dev server must be explicitly exposed to network using `--host` flag or `server.host` config option, with WebSocket enabled (default). … Additional conditions and limiting factors are described in the full assessment.
Risk Assessment Real-world risk is HIGH for development teams exposing Vite dev servers beyond localhost, particularly in containerized CI/CD environments or remote development setups. … Full risk analysis with EPSS, KEV, and SSVC signal comparison available after sign-in.
Exploit Scenario An attacker discovers a development team running Vite with --host 0.0.0.0 exposed on their network or in a cloud-based development environment. Using a simple WebSocket client, the attacker connects to the Vite dev server's HMR endpoint without providing an Origin header, bypassing CORS-like protections. …
Remediation Immediately upgrade to patched Vite versions: 6.4.2 or later for the 6.x branch, 7.3.2 or later for the 7.x branch, or 8.0.5 or later for the 8.x branch as documented in GitHub releases at github.com/vitejs/vite/releases. … Detailed patch versions, workarounds, and compensating controls in full report.

Recommended ActionAI

Within 24 hours: Audit all Vite dev server deployments to identify instances running versions before 6.4.2, 7.3.2, or 8.0.5, and document exposure scope (internal networks, public exposure via --host). …

Sign in for detailed remediation steps and compensating controls.

Threat intelligence, references, and detailed analysis are available after sign-in.

Vendor StatusVendor

Share

CVE-2026-39363 vulnerability details – vuln.today

This site uses cookies essential for authentication and security. No tracking or analytics cookies are used. Privacy Policy