5.2 KiB
Información Básica
Un paquete de instalación de macOS (también conocido como archivo .pkg
) es un formato de archivo utilizado por macOS para distribuir software. Estos archivos son como una caja que contiene todo lo que un software necesita para instalarse y ejecutarse correctamente.
El archivo del paquete en sí es un archivo que contiene una jerarquía de archivos y directorios que se instalarán en el equipo de destino. También puede incluir scripts para realizar tareas antes y después de la instalación, como configurar archivos de configuración o limpiar versiones antiguas del software.
Jerarquía
- Distribución (xml): Personalizaciones (título, texto de bienvenida...) y comprobaciones de script/instalación
- PackageInfo (xml): Información, requisitos de instalación, ubicación de instalación, rutas a scripts para ejecutar
- Lista de materiales (bom): Lista de archivos para instalar, actualizar o eliminar con permisos de archivo
- Carga útil (archivo CPIO comprimido con gzip): Archivos para instalar en la
ubicación de instalación
de PackageInfo - Scripts (archivo CPIO comprimido con gzip): Scripts de pre y post instalación y más recursos extraídos a un directorio temporal para su ejecución.
Descompresión
# Tool to directly get the files inside a package
pkgutil —expand "/path/to/package.pkg" "/path/to/out/dir"
# Get the files ina. more manual way
mkdir -p "/path/to/out/dir"
cd "/path/to/out/dir"
xar -xf "/path/to/package.pkg"
# Decompress also the CPIO gzip compressed ones
cat Scripts | gzip -dc | cpio -i
cpio -i < Scripts
Privesc a través del abuso de paquetes
Ejecución desde directorios públicos
Si un script de pre o post instalación se está ejecutando desde /var/tmp/Installerutil
, un atacante podría controlar ese script para escalar privilegios cada vez que se ejecute. Otro ejemplo similar:
AuthorizationExecuteWithPrivileges
Esta es una función pública que varios instaladores y actualizadores llamarán para ejecutar algo como root. Esta función acepta la ruta del archivo a ejecutar como parámetro, sin embargo, si un atacante pudiera modificar este archivo, podría abusar de su ejecución con root para escalar privilegios.
# Breakpoint in the function to check wich file is loaded
(lldb) b AuthorizationExecuteWithPrivileges
# You could also check FS events to find this missconfig
Para obtener más información, consulte esta charla: https://www.youtube.com/watch?v=lTOItyjTTkw
Ejecución mediante montaje
Si un instalador escribe en /tmp/fixedname/bla/bla
, es posible crear un montaje sobre /tmp/fixedname
sin propietarios para que pueda modificar cualquier archivo durante la instalación para abusar del proceso de instalación.
Un ejemplo de esto es CVE-2021-26089 que logró sobrescribir un script periódico para obtener la ejecución como root. Para obtener más información, consulte la charla: OBTS v4.0: "Mount(ain) of Bugs" - Csaba Fitzl
Referencias
☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥
- ¿Trabajas en una empresa de ciberseguridad? ¿Quieres ver tu empresa anunciada en HackTricks? ¿O quieres tener acceso a la última versión de PEASS o descargar HackTricks en PDF? ¡Consulta los PLANES DE SUSCRIPCIÓN!
- Descubre The PEASS Family, nuestra colección exclusiva de NFTs
- Obtén el swag oficial de PEASS y HackTricks
- Únete al 💬 grupo de Discord o al grupo de telegram o sígueme en Twitter 🐦@carlospolopm.
- Comparte tus trucos de hacking enviando PR al repositorio de hacktricks y al repositorio de hacktricks-cloud.