CVE-2026-42284 PUBLISHED

GitPython: Unsafe option check validates multi_options before shlex.split transforms it

Assigner: GitHub_M
Reserved: 26.04.2026 Published: 07.05.2026 Updated: 07.05.2026

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.

Metrics

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

Product Status

Vendor gitpython-developers
Product GitPython
Versions
  • Version < 3.1.47 is affected

References

Problem Types

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