hacktricks/macos-hardening/macos-security-and-privilege-escalation/macos-files-folders-and-binaries
2023-08-31 16:01:08 +00:00
..
macos-bundles.md f 2023-06-05 20:30:03 +02:00
macos-installer-packages-pkg.md Translated ['macos-hardening/macos-security-and-privilege-escalation/REA 2023-06-08 00:35:36 +00:00
macos-installers-abuse.md Translated ['README.md', 'macos-hardening/macos-red-teaming/README.md', 2023-06-25 23:32:46 +00:00
macos-memory-dumping.md f 2023-06-05 20:30:03 +02:00
macos-sensitive-locations.md Translated ['macos-hardening/macos-security-and-privilege-escalation/mac 2023-06-26 19:15:13 +00:00
README.md Translated ['macos-hardening/macos-security-and-privilege-escalation/REA 2023-06-08 10:11:56 +00:00
universal-binaries-and-mach-o-format.md Translated ['README.md', 'backdoors/salseo.md', 'forensics/basic-forensi 2023-08-31 16:01:08 +00:00

Archivos, Carpetas, Binarios y Memoria de macOS

Diseño de jerarquía de archivos

  • /Applications: Las aplicaciones instaladas deberían estar aquí. Todos los usuarios podrán acceder a ellas.
  • /bin: Binarios de línea de comandos
  • /cores: Si existe, se utiliza para almacenar volcados de núcleo
  • /dev: Todo se trata como un archivo, por lo que puede ver dispositivos de hardware almacenados aquí.
  • /etc: Archivos de configuración
  • /Library: Se pueden encontrar muchos subdirectorios y archivos relacionados con preferencias, cachés y registros. Existe una carpeta Library en la raíz y en el directorio de cada usuario.
  • /private: No documentado, pero muchos de los directorios mencionados son enlaces simbólicos al directorio privado.
  • /sbin: Binarios esenciales del sistema (relacionados con la administración)
  • /System: Archivo para hacer que OS X funcione. Debería encontrar principalmente solo archivos específicos de Apple aquí (no de terceros).
  • /tmp: Los archivos se eliminan después de 3 días (es un enlace suave a /private/tmp)
  • /Users: Directorio de inicio para usuarios.
  • /usr: Configuración y binarios del sistema
  • /var: Archivos de registro
  • /Volumes: Las unidades montadas aparecerán aquí.
  • /.vol: Al ejecutar stat a.txt, se obtiene algo como 16777223 7545753 -rw-r--r-- 1 username wheel ..., donde el primer número es el número de identificación del volumen donde existe el archivo y el segundo es el número de inodo. Puede acceder al contenido de este archivo a través de /.vol/ con esa información ejecutando cat /.vol/16777223/7545753

Carpetas de aplicaciones

  • Las aplicaciones del sistema se encuentran en /System/Applications
  • Las aplicaciones instaladas generalmente se instalan en /Applications o en ~/Applications
  • Los datos de la aplicación se pueden encontrar en /Library/Application Support para las aplicaciones que se ejecutan como root y ~/Library/Application Support para las aplicaciones que se ejecutan como el usuario.
  • Los daemonios de aplicaciones de terceros que necesitan ejecutarse como root generalmente se encuentran en /Library/PrivilegedHelperTools/
  • Las aplicaciones sandboxed se asignan a la carpeta ~/Library/Containers. Cada aplicación tiene una carpeta con el nombre del identificador de paquete de la aplicación (com.apple.Safari).
  • El núcleo se encuentra en /System/Library/Kernels/kernel
  • Las extensiones de kernel de Apple se encuentran en /System/Library/Extensions
  • Las extensiones de kernel de terceros se almacenan en /Library/Extensions

Archivos con información sensible

macOS almacena información como contraseñas en varios lugares:

{% content-ref url="macos-sensitive-locations.md" %} macos-sensitive-locations.md {% endcontent-ref %}

Instaladores pkg vulnerables

{% content-ref url="macos-installers-abuse.md" %} macos-installers-abuse.md {% endcontent-ref %}

Extensiones específicas de OS X

  • .dmg: Los archivos de imagen de disco de Apple son muy frecuentes para los instaladores.
  • .kext: Debe seguir una estructura específica y es la versión de OS X de un controlador. (es un paquete)
  • .plist: También conocido como lista de propiedades, almacena información en formato XML o binario.
    • Pueden ser XML o binarios. Los binarios se pueden leer con:
      • defaults read config.plist
      • /usr/libexec/PlistBuddy -c print config.plsit
      • plutil -p ~/Library/Preferences/com.apple.screensaver.plist
      • plutil -convert xml1 ~/Library/Preferences/com.apple.screensaver.plist -o -
      • plutil -convert json ~/Library/Preferences/com.apple.screensaver.plist -o -
  • .app: Aplicaciones de Apple que siguen la estructura de directorios (es un paquete).
  • .dylib: Bibliotecas dinámicas (como los archivos DLL de Windows)
  • .pkg: Son iguales que xar (formato de archivo de archivo extensible). El comando installer se puede usar para instalar el contenido de estos archivos.
  • .DS_Store: Este archivo está en cada directorio, guarda los atributos y personalizaciones del directorio.
  • .Spotlight-V100: Esta carpeta aparece en el directorio raíz de cada volumen del sistema.
  • .metadata_never_index: Si este archivo está en la raíz de un volumen, Spotlight no indexará ese volumen.
  • .noindex: Los archivos y carpetas con esta extensión no serán indexados por Spotlight.

Paquetes de macOS

Básicamente, un paquete es una estructura de directorios dentro del sistema de archivos. Curiosamente, por defecto este directorio parece un objeto único en Finder (como .app).

{% content-ref url="macos-bundles.md" %} macos-bundles.md {% endcontent-ref %}

Permisos especiales de archivos

Permisos de carpeta

En una carpeta, leer permite listarla, escribir permite eliminar y escribir archivos en ella, y ejecutar permite atravesar el directorio. Por lo tanto, por ejemplo, un usuario con permiso de lectura sobre un archivo dentro de un directorio donde no tiene permiso de ejecución no podrá leer el archivo.

Modificadores de bandera

Hay algunas banderas que se pueden establecer en los archivos que harán que el archivo se comporte de manera diferente. Puede verificar las banderas de los archivos dentro de un directorio con ls -lO /path/directory

  • uchg: Conocida como bandera uchange evitará cualquier acción que cambie o elimine el archivo. Para establecerlo, haga: chflags uchg file.txt
    • El usuario root podría eliminar la bandera y modificar el archivo
  • restricted: Esta bandera hace que el archivo esté protegido por SIP (no se puede agregar esta bandera a un archivo).
  • Sticky bit: Si un directorio tiene un bit pegajoso, solo el propietario de los directorios o root puede renombrar o eliminar archivos. Por lo general, esto se establece en el directorio /tmp para evitar que los usuarios ordinarios eliminen o muevan archivos de otros usuarios.

ACL de archivos

Las ACL de archivos contienen ACE (entradas de control de acceso) donde se pueden asignar permisos más granulares a diferentes usuarios.

Es posible otorgar a un directorio estos permisos: list, search, add_file, add_subdirectory, delete_child, delete_child.
Y a un archivo: read, write, append, execute.

Cuando el archivo contiene ACL, encontrará un "+" al listar los permisos como en:

ls -ld Movies
drwx------+   7 username  staff     224 15 Apr 19:42 Movies

Puedes leer los ACLs del archivo con:

ls -lde Movies
drwx------+ 7 username  staff  224 15 Apr 19:42 Movies
 0: group:everyone deny delete

Puedes encontrar todos los archivos con ACLs con (esto es muuuy lento):

ls -RAle / 2>/dev/null | grep -E -B1 "\d: "

Horquillas de Recursos | ADS de macOS

Esta es una forma de obtener Flujos de Datos Alternativos en máquinas MacOS. Puedes guardar contenido dentro de un atributo extendido llamado com.apple.ResourceFork dentro de un archivo al guardarlo en file/..namedfork/rsrc.

echo "Hello" > a.txt
echo "Hello Mac ADS" > a.txt/..namedfork/rsrc

xattr -l a.txt #Read extended attributes
com.apple.ResourceFork: Hello Mac ADS

ls -l a.txt #The file length is still q
-rw-r--r--@ 1 username  wheel  6 17 Jul 01:15 a.txt

Puedes encontrar todos los archivos que contienen este atributo extendido con:

{% code overflow="wrap" %}

find / -type f -exec ls -ld {} \; 2>/dev/null | grep -E "[x\-]@ " | awk '{printf $9; printf "\n"}' | xargs -I {} xattr -lv {} | grep "com.apple.ResourceFork"

Binarios universales y formato Mach-o

Los binarios de Mac OS generalmente se compilan como binarios universales. Un binario universal puede soportar múltiples arquitecturas en el mismo archivo.

{% content-ref url="universal-binaries-and-mach-o-format.md" %} universal-binaries-and-mach-o-format.md {% endcontent-ref %}

Volcado de memoria de macOS

{% content-ref url="macos-memory-dumping.md" %} macos-memory-dumping.md {% endcontent-ref %}

Archivos de categoría de riesgo de Mac OS

Los archivos /System/Library/CoreServices/CoreTypes.bundle/Contents/Resources/System contienen el riesgo asociado a los archivos dependiendo de la extensión del archivo.

Las posibles categorías incluyen las siguientes:

  • LSRiskCategorySafe: Totalmente seguro; Safari se abrirá automáticamente después de la descarga.
  • LSRiskCategoryNeutral: Sin advertencia, pero no se abre automáticamente.
  • LSRiskCategoryUnsafeExecutable: Desencadena una advertencia "Este archivo es una aplicación...".
  • LSRiskCategoryMayContainUnsafeExecutable: Esto es para cosas como archivos que contienen un ejecutable. Desencadena una advertencia a menos que Safari pueda determinar que todos los contenidos son seguros o neutrales.

Archivos de registro

  • $HOME/Library/Preferences/com.apple.LaunchServices.QuarantineEventsV2: Contiene información sobre archivos descargados, como la URL desde donde se descargaron.
  • /var/log/system.log: Registro principal de los sistemas OSX. com.apple.syslogd.plist es responsable de la ejecución del registro del sistema (puede verificar si está desactivado buscando "com.apple.syslogd" en launchctl list.
  • /private/var/log/asl/*.asl: Estos son los registros del sistema de Apple que pueden contener información interesante.
  • $HOME/Library/Preferences/com.apple.recentitems.plist: Almacena archivos y aplicaciones accedidos recientemente a través de "Finder".
  • $HOME/Library/Preferences/com.apple.loginitems.plsit: Almacena elementos para iniciar al arrancar el sistema.
  • $HOME/Library/Logs/DiskUtility.log: Archivo de registro para la aplicación DiskUtility (información sobre unidades, incluidas las USB).
  • /Library/Preferences/SystemConfiguration/com.apple.airport.preferences.plist: Datos sobre puntos de acceso inalámbricos.
  • /private/var/db/launchd.db/com.apple.launchd/overrides.plist: Lista de demonios desactivados.
☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥