← volver
CVE-2022-41903

Integer overflow in `git archive`, `git log --format` leading to RCE in git

CVSS 9.8 CRITICALEPSS 44.3%CWE-190
En resumen

Git tiene una falla de desbordamiento de enteros en su sistema de formateo que puede ser activada mediante comandos `git log --format` o `git archive`, permitiendo potencialmente que atacantes ejecuten código arbitrario al causar escrituras incorrectas en memoria.

Detalle técnico

Un desbordamiento de enteros en `pretty.c::format_and_pad_commit()` almacena incorrectamente un valor `size_t` como `int`, que luego se usa como desplazamiento en memcpy, habilitando escrituras arbitrarias en heap. La explotación ocurre al procesar operadores de padding en especificadores de formato; la vulnerabilidad puede ser activada directamente por usuarios ejecutando git log con argumentos `--format` manipulados o indirectamente a través de git archive vía gitattributes export-subst, resultando en ejecución remota de código si se procesan repositorios no confiables.

Resumen generado y traducido por IA a partir de la descripción oficial.
Git is distributed revision control system. `git log` can display commits in an arbitrary format using its `--format` specifiers. This functionality is also exposed to `git archive` via the `export-subst` gitattribute. When processing the padding operators, there is a integer overflow in `pretty.c::format_and_pad_commit()` where a `size_t` is stored improperly as an `int`, and then added as an offset to a `memcpy()`. This overflow can be triggered directly by a user running a command which invokes the commit formatting machinery (e.g., `git log --format=...`). It may also be triggered indirectly through git archive via the export-subst mechanism, which expands format specifiers inside of files within the repository during a git archive. This integer overflow can result in arbitrary heap writes, which may result in arbitrary code execution. The problem has been patched in the versions published on 2023-01-17, going back to v2.30.7. Users are advised to upgrade. Users who are unable to upgrade should disable `git archive` in untrusted repositories. If you expose git archive via `git daemon`, disable it by running `git config --global daemon.uploadArch false`.
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:H/A:H
Productos afectados
git · git
PoCs públicas encontradas1
githubgithub.com/sondermc/git-cveissues0
⚠ Recursos públicos, para evaluar la exposición de sistemas que controlas o estás autorizado a probar. Prueba solo con autorización.

¿Quieres saber si tu infraestructura está expuesta a esto?

Hablar con TrueHacking →