← voltar
CVE-2022-39260

Git vulnerable to Remote Code Execution via Heap overflow in `git shell`

CVSS 8.5 HIGHEPSS 2.9%CWE-122CWE-787
Em resumo

O shell restrito do Git (`git shell`) possui uma falha de transbordamento de memória que permite a atacantes executar código arbitrário em um servidor. Um atacante com acesso SSH ao `git shell` pode criar um comando malicioso que invade a memória e toma controle do sistema.

Detalhe técnico

A vulnerabilidade está na função que separa argumentos do `git shell`, que usa um inteiro de 32 bits para rastrear o tamanho do array, permitindo transbordamento inteiro. Um atacante autenticado pode enviar um comando especialmente elaborado via SSH que transborda a memória do heap, corrompe dados e passa um array de argumentos malicioso para `execv()`, conseguindo execução remota de código. A exploração requer acesso SSH prévio ao `git shell` como shell de login.

Resumo gerado e traduzido por IA a partir da descrição 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
Produtos afetados
git · git

Quer saber se a sua infraestrutura está exposta a isto?

Falar com a TrueHacking →