Логотип exploitDog
Консоль
Логотип exploitDog

exploitDog

github логотип

GHSA-8jhw-289h-jh2g

Опубликовано: 03 апр. 2024
Источник: github
Github: Прошло ревью
CVSS3: 5.9

Описание

Vite's server.fs.deny did not deny requests for patterns with directories.

Summary

Vite dev server option server.fs.deny did not deny requests for patterns with directories. An example of such a pattern is /foo/**/*.

Impact

Only apps setting a custom server.fs.deny that includes a pattern with directories, and explicitly exposing the Vite dev server to the network (using --host or server.host config option) are affected.

Patches

Fixed in vite@5.2.6, vite@5.1.7, vite@5.0.13, vite@4.5.3, vite@3.2.10, vite@2.9.18

Details

server.fs.deny uses picomatch with the config of { matchBase: true }. matchBase only matches the basename of the file, not the path due to a bug (https://github.com/micromatch/picomatch/issues/89). The vite config docs read like you should be able to set fs.deny to glob with picomatch. Vite also does not set { dot: true } and that causes dotfiles not to be denied unless they are explicitly defined.

Reproduction

Set fs.deny to ['**/.git/**'] and then curl for /.git/config.

  • with matchBase: true, you can get any file under .git/ (config, HEAD, etc).
  • with matchBase: false, you cannot get any file under .git/ (config, HEAD, etc).

Пакеты

Наименование

vite

npm
Затронутые версииВерсия исправления

>= 2.7.0, <= 2.9.17

2.9.18

Наименование

vite

npm
Затронутые версииВерсия исправления

>= 3.0.0, <= 3.2.8

3.2.10

Наименование

vite

npm
Затронутые версииВерсия исправления

>= 4.0.0, <= 4.5.2

4.5.3

Наименование

vite

npm
Затронутые версииВерсия исправления

>= 5.0.0, <= 5.0.12

5.0.13

Наименование

vite

npm
Затронутые версииВерсия исправления

>= 5.1.0, <= 5.1.6

5.1.7

Наименование

vite

npm
Затронутые версииВерсия исправления

>= 5.2.0, <= 5.2.5

5.2.6

EPSS

Процентиль: 40%
0.00182
Низкий

5.9 Medium

CVSS3

Дефекты

CWE-200
CWE-284

Связанные уязвимости

CVSS3: 5.9
redhat
почти 2 года назад

Vite (French word for "quick", pronounced /vit/, like "veet") is a frontend build tooling to improve the frontend development experience.`server.fs.deny` does not deny requests for patterns with directories. This vulnerability has been patched in version(s) 5.2.6, 5.1.7, 5.0.13, 4.5.3, 3.2.10 and 2.9.18.

CVSS3: 5.9
nvd
почти 2 года назад

Vite (French word for "quick", pronounced /vit/, like "veet") is a frontend build tooling to improve the frontend development experience.`server.fs.deny` does not deny requests for patterns with directories. This vulnerability has been patched in version(s) 5.2.6, 5.1.7, 5.0.13, 4.5.3, 3.2.10 and 2.9.18.

CVSS3: 5.9
fstec
почти 2 года назад

Уязвимость локального сервера разработки приложений Vite, связанная с недостатками контроля доступа, позволяющая нарушителю выполнить произвольный код

EPSS

Процентиль: 40%
0.00182
Низкий

5.9 Medium

CVSS3

Дефекты

CWE-200
CWE-284