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

exploitDog

github логотип

GHSA-r39x-jcww-82v6

Опубликовано: 28 янв. 2026
Источник: github
Github: Прошло ревью
CVSS3: 6.3

Описание

Symfony's incorrect argument escaping under MSYS2/Git Bash can lead to destructive file operations on Windows

Summary

The Symfony Process component did not correctly treat some characters (notably =) as “special” when escaping arguments on Windows. When PHP is executed from an MSYS2-based environment (e.g. Git Bash) and Symfony Process spawns native Windows executables, MSYS2’s argument/path conversion can mishandle unquoted arguments containing these characters.

This can cause the spawned process to receive corrupted/truncated arguments compared to what Symfony intended.

Impact

If an application (or tooling such as Composer scripts) uses Symfony Process to invoke file-management commands (e.g. rmdir, del, etc.) with a path argument containing =, the MSYS2 conversion layer may alter the argument at runtime. In affected setups this can result in operations being performed on an unintended path, up to and including deletion of the contents of a broader directory or drive.

The issue is particularly relevant when untrusted input can influence process arguments (directly or indirectly, e.g. via repository paths, extracted archive paths, temporary directories, or user-controlled configuration).

Resolution

Upgrade to a Symfony release that includes the fix from symfony/symfony#63164 (which updates Windows argument escaping to ensure arguments containing = and other MSYS2-sensitive characters are properly quoted/escaped). The patch for branch 5.4 is available at https://github.com/symfony/symfony/commit/ec154f6f95f8c60f831998ec4d246a857e9d179b

Workarounds / Mitigations

Avoid running PHP/your tooling from MSYS2-based shells on Windows; prefer cmd.exe or PowerShell for workflows that spawn native executables. Avoid passing paths containing = (and similar MSYS2-sensitive characters) to Symfony Process when operating under Git Bash/MSYS2. Where applicable, configure MSYS2 to disable or restrict argument conversion (e.g. via MSYS2_ARG_CONV_EXCL), understanding this may affect other tooling behavior.

Пакеты

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

symfony/process

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

< 5.4.51

5.4.51

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

symfony/process

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

>= 6.4, < 6.4.33

6.4.33

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

symfony/process

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

>= 7.3, < 7.3.11

7.3.11

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

symfony/process

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

>= 7.4, < 7.4.5

7.4.5

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

symfony/process

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

>= 8.0, < 8.0.5

8.0.5

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

symfony/symfony

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

< 5.4.51

5.4.51

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

symfony/symfony

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

>= 6.4, < 6.4.33

6.4.33

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

symfony/symfony

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

>= 7.3, < 7.3.11

7.3.11

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

symfony/symfony

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

>= 7.4, < 7.4.5

7.4.5

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

symfony/symfony

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

>= 8.0, < 8.0.5

8.0.5

EPSS

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

6.3 Medium

CVSS3

Дефекты

CWE-88

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

CVSS3: 6.3
nvd
7 дней назад

Symfony is a PHP framework for web and console applications and a set of reusable PHP components. Prior to versions 5.4.51, 6.4.33, 7.3.11, 7.4.5, and 8.0.5, the Symfony Process component did not correctly treat some characters (notably `=`) as “special” when escaping arguments on Windows. When PHP is executed from an MSYS2-based environment (e.g. Git Bash) and Symfony Process spawns native Windows executables, MSYS2’s argument/path conversion can mis-handle unquoted arguments containing these characters. This can cause the spawned process to receive corrupted/truncated arguments compared to what Symfony intended. If an application (or tooling such as Composer scripts) uses Symfony Process to invoke file-management commands (e.g. `rmdir`, `del`, etc.) with a path argument containing `=`, the MSYS2 conversion layer may alter the argument at runtime. In affected setups this can result in operations being performed on an unintended path, up to and including deletion of the contents

CVSS3: 6.3
debian
7 дней назад

Symfony is a PHP framework for web and console applications and a set ...

EPSS

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

6.3 Medium

CVSS3

Дефекты

CWE-88