Description
Vite is a frontend tooling framework for javascript. The contents of arbitrary files can be returned to the browser. By adding ?.svg with ?.wasm?init or with sec-fetch-dest: script header, the server.fs.deny restriction was able to bypass. This bypass is only possible if the file is smaller than build.assetsInlineLimit (default: 4kB) and when using Vite 6.0+. Only apps explicitly exposing the Vite dev server to the network (using --host or server.host config option) are affected. This vulnerability is fixed in 4.5.12, 5.4.17, 6.0.14, 6.1.4, and 6.2.5.
Problem types
CWE-200: Exposure of Sensitive Information to an Unauthorized Actor
CWE-284: Improper Access Control
Product status
>=5.0.0, < 5.4.17
>=6.0.0, < 6.0.14
>=6.1.0, < 6.1.4
>=6.2.0, < 6.2.5
References
github.com/...s/vite/security/advisories/GHSA-xcj6-pq6g-qj4x
github.com/...s/vite/security/advisories/GHSA-xcj6-pq6g-qj4x
github.com/...ommit/62d7e81ee189d65899bb65f3263ddbd85247b647
github.com/...13c48f/packages/vite/src/node/plugins/asset.ts