Instituto Nacional de ciberseguridad. Sección Incibe
Instituto Nacional de Ciberseguridad. Sección INCIBE-CERT

Vulnerabilidad en PsySH (CVE-2026-25129)

Gravedad CVSS v3.1:
MEDIA
Tipo:
CWE-427 Elemento no controlado en la ruta de búsqueda
Fecha de publicación:
30/01/2026
Última modificación:
27/02/2026

Descripción

PsySH es una consola de desarrollador en tiempo de ejecución, depurador interactivo y REPL para PHP. Antes de las versiones 0.11.23 y 0.12.19, PsySH carga y ejecuta automáticamente un archivo '.psysh.php' desde el Directorio de Trabajo Actual (CWD) al inicio. Si un atacante puede escribir en un directorio que una víctima usa posteriormente como su CWD al iniciar PsySH, el atacante puede desencadenar la ejecución de código arbitrario en el contexto de la víctima. Cuando la víctima ejecuta PsySH con grandes privilegios (por ejemplo, root), esto resulta en una escalada de privilegios local. Este es un problema de envenenamiento de la configuración del CWD que conduce a la ejecución de código arbitrario en el contexto del usuario víctima. Si un usuario privilegiado (por ejemplo, root, un ejecutor de CI o una cuenta de operaciones/depuración) inicia PsySH con el CWD configurado en un directorio escribible por el atacante que contiene un '.psysh.php' malicioso, el atacante puede ejecutar comandos con los permisos de ese usuario privilegiado, lo que resulta en una escalada de privilegios local. Los consumidores posteriores que incrustan PsySH heredan este riesgo. Por ejemplo, Laravel Tinker (php artisan tinker) usa PsySH. Si un usuario privilegiado ejecuta Tinker mientras su shell está en un directorio escribible por el atacante, el comportamiento de carga automática del '.psysh.php' puede ser abusado de la misma manera para ejecutar código controlado por el atacante bajo los privilegios de la víctima. Las versiones 0.11.23 y 0.12.19 resuelven el problema.

Productos y versiones vulnerables

CPE Desde Hasta
cpe:2.3:a:psysh:psysh:*:*:*:*:*:*:*:* 0.11.23 (excluyendo)
cpe:2.3:a:psysh:psysh:*:*:*:*:*:*:*:* 0.12.0 (incluyendo) 0.12.19 (excluyendo)