CVE-2022-39253
Git subject to exposure of sensitive information via local clone of symbolic links
En resumen
Git puede exponer archivos sensibles de tu computadora cuando clonas un repositorio malicioso localmente. Un atacante puede engañarte para clonar un repositorio con enlaces simbólicos que apunten a datos privados, y Git puede copiar o vincular esa información sensible en el repositorio clonado.
Detalle técnico
Durante la clonación local con hardlinks o copia (CWE-200: Exposición de Información), un repositorio malicioso que contiene enlaces simbólicos en $GIT_DIR/objects puede exponer archivos sensibles del sistema local. El vector de ataque implica ingeniería social para clonar un repositorio malicioso localmente o mediante --recurse-submodules con repositorios bare incrustados; Git no filtra enlaces simbólicos durante la copia del directorio de objetos, permitiendo acceso no autorizado a información sensible de la máquina de la víctima.
Resumen generado y traducido por IA a partir de la descripción oficial.
Git is an open source, scalable, distributed revision control system. 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 are subject to exposure of sensitive information to a malicious actor. When performing a local clone (where the source and target of the clone are on the same volume), Git copies the contents of the source's `$GIT_DIR/objects` directory into the destination by either creating hardlinks to the source contents, or copying them (if hardlinks are disabled via `--no-hardlinks`). A malicious actor could convince a victim to clone a repository with a symbolic link pointing at sensitive information on the victim's machine. This can be done either by having the victim clone a malicious repository on the same machine, or having them clone a malicious repository embedded as a bare repository via a submodule from any source, provided they clone with the `--recurse-submodules` option. Git does not create symbolic links in the `$GIT_DIR/objects` directory. The problem has been patched in the versions published on 2022-10-18, and backported to v2.30.x. Potential workarounds: Avoid cloning untrusted repositories using the `--local` optimization when on a shared machine, either by passing the `--no-local` option to `git clone` or cloning from a URL that uses the `file://` scheme. Alternatively, avoid cloning repositories from untrusted sources with `--recurse-submodules` or run `git config --global protocol.file.allow user`.
CVSS:3.1/AV:L/AC:L/PR:N/UI:R/S:U/C:H/I:N/A:N