CVE-2026-42284

HIGH

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

Title source: cna
STIX 2.1

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.

References (3)

Core 3

Scores

CVSS v3 8.1
EPSS 0.0002
EPSS Percentile 6.1%
Attack Vector NETWORK
CVSS:3.1/AV:N/AC:H/PR:N/UI:N/S:U/C:H/I:H/A:H

CISA SSVC

Vulnrichment
Exploitation poc
Automatable no
Technical Impact total

Details

CWE
CWE-88
Status published
Products (3)
gitpython-developers/GitPython < 3.1.47
gitpython_project/gitpython < 3.1.47
pypi/GitPython 0 - 3.1.47PyPI
Published May 07, 2026
Tracked Since May 08, 2026