Loading HuntDB...

GHSA-x7cr-6qr6-2hh6

GitHub Security Advisory

Missing input validation can lead to command execution in composer

✓ GitHub Reviewed HIGH Has CVE

Advisory Details

The Composer method `VcsDriver::getFileContent()` with user-controlled `$file` or `$identifier` arguments is susceptible to an argument injection vulnerability. It can be leveraged to gain arbitrary command execution if the Mercurial or the Git driver are used.

This led to a vulnerability on Packagist.org and Private Packagist, i.e., using the composer.json `readme` field as a vector for injecting parameters into the `$file` argument for the Mercurial driver or via the `$identifier` argument for the Git and Mercurial drivers.

Composer itself can be attacked through branch names by anyone controlling a Git or Mercurial repository, which is explicitly listed by URL in a project's composer.json.

To the best of our knowledge, this was not actively exploited. The vulnerability has been patched on Packagist.org and Private Packagist within a day of the vulnerability report.

Affected Packages

Packagist composer/composer
Affected versions: 0 (fixed in 1.10.26)
Packagist composer/composer
Affected versions: 2.0 (fixed in 2.2.12)
Packagist composer/composer
Affected versions: 2.3 (fixed in 2.3.5)

Related CVEs

Key Information

GHSA ID
GHSA-x7cr-6qr6-2hh6
Published
April 22, 2022 8:15 PM
Last Modified
April 22, 2022 8:15 PM
CVSS Score
7.5 /10
Primary Ecosystem
Packagist
Primary Package
composer/composer
GitHub Reviewed
✓ Yes

Dataset

Last updated: August 5, 2025 6:46 AM

Data from GitHub Advisory Database. This information is provided for research and educational purposes.