CVE-2024-23331
Vite is a frontend tooling framework for javascript. The Vite dev server option `server.fs.deny` can be bypassed on case-insensitive file systems using case-augmented versions of filenames. Notably this affects servers hosted on Windows. This bypass is similar to CVE-2023-34092 -- with surface area reduced to hosts having case-insensitive filesystems. Since `picomatch` defaults to case-sensitive glob matching, but the file server doesn't discriminate; a blacklist bypass is possible. By requesting raw filesystem paths using augmented casing, the matcher derived from `config.server.fs.deny` fails to block access to sensitive files. This issue has been addressed in vite@5.0.12, vite@4.5.2, vite@3.2.8, and vite@2.9.17. Users are advised to upgrade. Users unable to upgrade should restrict access to dev servers.
EPSS 0.48% · 65.5th percentile
Risk Scores
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| npm | vite | 2.7.0, 3.0.0, 4.0.0 |
| vitejs | vite | 2.7.0, 3.0.0, >=2.7.0, < 2.9.17 |
Exploit Intelligence
Timeline
- Jan 21, 1970 Security Advisory
- Jan 19, 2024 CVE Published
- Jan 24, 2024 EPSS Score
- Feb 21, 2024 EPSS Score
- Mar 20, 2024 EPSS Score
- Apr 16, 2024 EPSS Score
- May 14, 2024 EPSS Score
- Jun 11, 2024 EPSS Score
- Jul 9, 2024 EPSS Score
- Aug 6, 2024 EPSS Score
- Sep 30, 2024 EPSS Score
- Oct 4, 2024 Coalition ESS Score
References
- https://github.com/vitejs/vite/security/advisories/GHSA-c24v-8rfc-w8vw url
- https://github.com/vitejs/vite/commit/91641c4da0a011d4c5352e88fc68389d4e1289a5 url
- https://vitejs.dev/config/server-options.html#server-fs-deny url
- https://nvd.nist.gov/vuln/detail/CVE-2023-34092 advisory
- https://nvd.nist.gov/vuln/detail/CVE-2024-23331 advisory
- https://github.com/vitejs/vite/commit/0cd769c279724cf27934b1270fbdd45d68217691 url
- https://github.com/vitejs/vite/commit/a26c87d20f9af306b5ce3ff1648be7fa5146c278 url
- https://github.com/vitejs/vite/commit/eeec23bbc9d476c54a3a6d36e78455867185a7cb url
- https://github.com/vitejs/vite package