CVE-2022-39260
Git vulnerable to Remote Code Execution via Heap overflow in `git shell`
En resumen
El shell restringido de Git (`git shell`) contiene una vulnerabilidad de desbordamiento de heap que permite a atacantes ejecutar código arbitrario en un servidor. Un atacante con acceso SSH a `git shell` puede crear un comando malicioso que desborda la memoria y toma control del sistema.
Detalle técnico
La vulnerabilidad existe en la función que divide argumentos de `git shell`, que utiliza un entero de 32 bits para rastrear el tamaño del array, permitiendo desbordamiento de entero. Un atacante autenticado puede enviar un comando especialmente elaborado vía SSH que desborda el heap, corrompe memoria y pasa un array de argumentos malicioso a `execv()`, logrando ejecución remota de código. La explotación requiere acceso SSH previo a `git shell` como shell de inicio de sesión.
Resumen generado y traducido por IA a partir de la descripción oficial.
Git is an open source, scalable, distributed revision control system. `git shell` is a restricted login shell that can be used to implement Git's push/pull functionality via SSH. In versions prior to 2.30.6, 2.31.5, 2.32.4, 2.33.5, 2.34.5, 2.35.5, 2.36.3, and 2.37.4, the function that splits the command arguments into an array improperly uses an `int` to represent the number of entries in the array, allowing a malicious actor to intentionally overflow the return value, leading to arbitrary heap writes. Because the resulting array is then passed to `execv()`, it is possible to leverage this attack to gain remote code execution on a victim machine. Note that a victim must first allow access to `git shell` as a login shell in order to be vulnerable to this attack. This problem is patched in versions 2.30.6, 2.31.5, 2.32.4, 2.33.5, 2.34.5, 2.35.5, 2.36.3, and 2.37.4 and users are advised to upgrade to the latest version. Disabling `git shell` access via remote logins is a viable short-term workaround.
CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:C/C:H/I:H/A:H