Vulnerabilidad en SecureDrop Client (CVE-2025-24888)
Gravedad CVSS v3.1:
ALTA
Tipo:
CWE-22
Limitación incorrecta de nombre de ruta a un directorio restringido (Path Traversal)
Fecha de publicación:
13/02/2025
Última modificación:
13/02/2025
Descripción
SecureDrop Client es una aplicación de escritorio para que los periodistas se comuniquen con las fuentes y trabajen con los envíos en la Estación de trabajo SecureDrop. Antes de la versión 0.14.1, un Servidor SecureDrop malicioso podía obtener la ejecución de código en la máquina virtual del Cliente SecureDrop (`sd-app`). El Servidor SecureDrop en sí tiene múltiples capas de protección integradas y es una máquina física dedicada expuesta en Internet solo a través de servicios ocultos de Tor para las interfaces de Fuente y Periodista, y opcionalmente a través de acceso SSH remoto a través de otro servicio oculto de Tor. La Estación de trabajo SecureDrop de una sala de redacción se comunica solo con su propio Servidor SecureDrop dedicado. El Cliente SecureDrop se ejecuta en una máquina virtual Qubes dedicada, llamada `sd-app`, como parte de la Estación de trabajo SecureDrop. La clave privada OpenPGP utilizada para descifrar los envíos y las respuestas se almacena en una máquina virtual separada y nunca se accede a ella directamente. La vulnerabilidad reside en el código responsable de descargar las respuestas. El nombre de archivo de la respuesta se obtiene del encabezado HTTP `Content-Disposition` y se utiliza para escribir la respuesta cifrada en el disco. Tenga en cuenta que los nombres de archivo se generan y se depuran en el servidor, y los archivos se descargan en un formato cifrado, por lo que un atacante remoto que no haya logrado comprometer el servidor, como uno que se haga pasar por una fuente, no podría manipular la respuesta HTTP necesaria para este ataque. Si bien el nombre de archivo se verifica más tarde para protegerse contra el path traversal antes de moverlo al directorio de almacenamiento de datos del cliente, el archivo ya se ha escrito en una ubicación potencialmente arbitraria. En este caso, `safe_move()` detectaría el path traversal y fallaría, dejando el archivo descargado original en el directorio elegido por el atacante. La ejecución del código se puede obtener escribiendo un archivo de inicio automático en `/home/user/.config/autostart/`. La versión 0.14.1 corrige el problema. Al momento de la publicación, no hay evidencia conocida de explotación en la naturaleza. Este ataque requiere un servidor SecureDrop previamente comprometido.
Impacto
Puntuación base 3.x
8.10
Gravedad 3.x
ALTA
Referencias a soluciones, herramientas e información
- https://github.com/freedomofpress/securedrop-client/blob/0.14.0/client/securedrop_client/utils.py#L79
- https://github.com/freedomofpress/securedrop-client/blob/main/client/securedrop_client/api_jobs/downloads.py#L164
- https://github.com/freedomofpress/securedrop-client/blob/release/0.14.0/client/securedrop_client/sdk/__init__.py#L956-L957
- https://github.com/freedomofpress/securedrop-client/commit/120bac14649db0bcf5f24f2eb82731c76843b1ba
- https://github.com/freedomofpress/securedrop-client/security/advisories/GHSA-6c3p-chq6-q3j2
- https://www.qubes-os.org/doc/split-gpg