Home

Description

GitPython is a python library used to interact with Git repositories. Prior to version 3.1.47, _clone() validates multi_options as the original list, then executes shlex.split(" ".join(multi_options)). A string like "--branch main --config core.hooksPath=/x" passes validation (starts with --branch), but after split becomes ["--branch", "main", "--config", "core.hooksPath=/x"]. Git applies the config and executes attacker hooks during clone. This issue has been patched in version 3.1.47.

PUBLISHED Reserved 2026-04-26 | Published 2026-05-07 | Updated 2026-05-08 | Assigner GitHub_M




HIGH: 8.1CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H

Problem types

CWE-88: Improper Neutralization of Argument Delimiters in a Command ('Argument Injection')

Product status

< 3.1.47
affected

References

www.tenable.com/cve/CVE-2026-32686 exploit

github.com/...Python/security/advisories/GHSA-x2qx-6953-8485

github.com/...ython-developers/GitPython/releases/tag/3.1.47

cve.org (CVE-2026-42284)

nvd.nist.gov (CVE-2026-42284)

Download JSON