CVE-2024-23331
Severity CVSS v4.0:
Pending analysis
Type:
Unavailable / Other
Publication date:
19/01/2024
Last modified:
29/01/2024
Description
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.
Impact
Base Score 3.x
7.50
Severity 3.x
HIGH
Vulnerable products and versions
CPE | From | Up to |
---|---|---|
cpe:2.3:a:vitejs:vite:*:*:*:*:*:node.js:*:* | 2.7.0 (including) | 2.9.17 (excluding) |
cpe:2.3:a:vitejs:vite:*:*:*:*:*:node.js:*:* | 3.0.0 (including) | 3.2.8 (excluding) |
cpe:2.3:a:vitejs:vite:*:*:*:*:*:node.js:*:* | 4.0.0 (including) | 4.5.2 (excluding) |
cpe:2.3:a:vitejs:vite:*:*:*:*:*:node.js:*:* | 5.0.0 (including) | 5.0.12 (excluding) |
cpe:2.3:o:microsoft:windows:-:*:*:*:*:*:*:* |
To consult the complete list of CPE names with products and versions, see this page