hacktricks/macos-hardening/macos-security-and-privilege-escalation/macos-files-folders-and-binaries/README.md

15 KiB

Fichiers, Dossiers, Binaires et Mémoire macOS

☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥

Structure de la hiérarchie des fichiers

  • /Applications : Les applications installées doivent être ici. Tous les utilisateurs pourront y accéder.
  • /bin : Binaires de ligne de commande
  • /cores : S'il existe, il est utilisé pour stocker les vidages de cœur.
  • /dev : Tout est traité comme un fichier, vous pouvez donc trouver des périphériques matériels stockés ici.
  • /etc : Fichiers de configuration
  • /Library : De nombreux sous-répertoires et fichiers liés aux préférences, caches et journaux peuvent être trouvés ici. Un dossier Library existe à la racine et dans le répertoire de chaque utilisateur.
  • /private : Non documenté, mais de nombreux dossiers mentionnés sont des liens symboliques vers le répertoire privé.
  • /sbin : Binaires système essentiels (liés à l'administration)
  • /System : Fichier pour faire fonctionner OS X. Vous devriez trouver principalement des fichiers spécifiques à Apple ici (pas de tiers).
  • /tmp : Les fichiers sont supprimés après 3 jours (c'est un lien symbolique vers /private/tmp)
  • /Users : Répertoire personnel des utilisateurs.
  • /usr : Configuration et binaires système
  • /var : Fichiers journaux
  • /Volumes : Les lecteurs montés apparaîtront ici.
  • /.vol : En exécutant stat a.txt, vous obtenez quelque chose comme 16777223 7545753 -rw-r--r-- 1 nom_utilisateur wheel ... où le premier nombre est le numéro d'identification du volume où se trouve le fichier et le deuxième est le numéro d'inode. Vous pouvez accéder au contenu de ce fichier via /.vol/ avec ces informations en exécutant cat /.vol/16777223/7545753

Dossiers d'applications

  • Les applications système sont situées sous /System/Applications
  • Les applications installées sont généralement installées dans /Applications ou dans ~/Applications
  • Les données de l'application peuvent être trouvées dans /Library/Application Support pour les applications s'exécutant en tant que root et ~/Library/Application Support pour les applications s'exécutant en tant qu'utilisateur.
  • Les daemons d'applications tierces qui doivent s'exécuter en tant que root sont généralement situés dans /Library/PrivilegedHelperTools/
  • Les applications sandbox sont mappées dans le dossier ~/Library/Containers. Chaque application a un dossier portant le nom de l'ID de bundle de l'application (com.apple.Safari).
  • Le noyau est situé dans /System/Library/Kernels/kernel
  • Les extensions de noyau d'Apple sont situées dans /System/Library/Extensions
  • Les extensions de noyau tierces sont stockées dans /Library/Extensions

Fichiers contenant des informations sensibles

macOS stocke des informations telles que les mots de passe à plusieurs endroits :

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

Installateurs pkg vulnérables

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

Extensions spécifiques à OS X

  • .dmg : Les fichiers d'image disque Apple sont très fréquents pour les installateurs.
  • .kext : Il doit suivre une structure spécifique et c'est la version OS X d'un pilote. (c'est un bundle)
  • .plist : Aussi connu sous le nom de liste de propriétés, il stocke des informations au format XML ou binaire.
  • Peut être XML ou binaire. Les fichiers binaires peuvent être lus avec :
  • 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 : Applications Apple qui suivent une structure de répertoire (c'est un bundle).
  • .dylib : Bibliothèques dynamiques (comme les fichiers DLL de Windows)
  • .pkg : Ce sont les mêmes que xar (format d'archive extensible). La commande installer peut être utilisée pour installer le contenu de ces fichiers.
  • .DS_Store : Ce fichier est présent dans chaque répertoire, il enregistre les attributs et les personnalisations du répertoire.
  • .Spotlight-V100 : Ce dossier apparaît à la racine de chaque volume du système.
  • .metadata_never_index : Si ce fichier se trouve à la racine d'un volume, Spotlight n'indexera pas ce volume.
  • .noindex : Les fichiers et dossiers avec cette extension ne seront pas indexés par Spotlight.

Bundles macOS

Fondamentalement, un bundle est une structure de répertoires dans le système de fichiers. Curieusement, par défaut, ce répertoire ressemble à un objet unique dans Finder (comme .app).

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

Cache partagé Dyld

Sur macOS (et iOS), toutes les bibliothèques système partagées, telles que les frameworks et les dylibs, sont regroupées dans un seul fichier, appelé cache partagé Dyld. Cela améliore les performances, car le code peut être chargé plus rapidement.

De manière similaire au cache partagé Dyld, le noyau et les extensions du noyau sont également compilés dans un cache de noyau, qui est chargé au démarrage.

Pour extraire les bibliothèques du fichier unique du cache partagé dylib, il était possible d'utiliser le binaire dyld_shared_cache_util qui pourrait ne pas fonctionner de nos jours:

{% code overflow="wrap" %}

dyld_shared_cache_util -extract ~/shared_cache/ /System/Volumes/Preboot/Cryptexes/OS/System/Library/dyld/dyld_shared_cache_arm64e

{% endcode %}

Autorisations spéciales des fichiers

Autorisations des dossiers

Dans un dossier, la lecture permet de lister son contenu, l'écriture permet de supprimer et écrire des fichiers, et l'exécution permet de traverser le répertoire. Par exemple, un utilisateur avec l'autorisation de lecture sur un fichier à l'intérieur d'un répertoire où il n'a pas l'autorisation d'exécution ne pourra pas lire le fichier.

Modificateurs de drapeau

Il existe des drapeaux qui peuvent être définis dans les fichiers et qui feront que le fichier se comportera différemment. Vous pouvez vérifier les drapeaux des fichiers à l'intérieur d'un répertoire avec ls -lO /chemin/répertoire

  • uchg: Connue sous le nom de drapeau uchange, elle empêche toute action de modification ou de suppression du fichier. Pour le définir, utilisez : chflags uchg fichier.txt
  • L'utilisateur root peut supprimer le drapeau et modifier le fichier.
  • restricted: Ce drapeau rend le fichier protégé par SIP (vous ne pouvez pas ajouter ce drapeau à un fichier).
  • Sticky bit: Si un répertoire a le sticky bit, seul le propriétaire du répertoire ou root peut renommer ou supprimer des fichiers. Cela est généralement défini sur le répertoire /tmp pour empêcher les utilisateurs ordinaires de supprimer ou déplacer les fichiers d'autres utilisateurs.

ACL des fichiers

Les ACL des fichiers contiennent des ACE (entrées de contrôle d'accès) où des autorisations plus granulaires peuvent être attribuées à différents utilisateurs.

Il est possible d'accorder ces autorisations à un répertoire : list, search, add_file, add_subdirectory, delete_child, delete_child.
Et à un fichier : read, write, append, execute.

Lorsque le fichier contient des ACL, vous trouverez un "+" lors de l'affichage des autorisations, comme dans :

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

Vous pouvez lire les ACL du fichier avec :

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

Vous pouvez trouver tous les fichiers avec des ACL avec (cela est trèèès lent) :

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

Fourches de ressources | ADS macOS

Ceci est une façon d'obtenir des flux de données alternatifs sur les machines macOS. Vous pouvez enregistrer du contenu à l'intérieur d'un attribut étendu appelé com.apple.ResourceFork à l'intérieur d'un fichier en le sauvegardant dans 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

Vous pouvez trouver tous les fichiers contenant cet attribut étendu avec :

{% 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"

{% endcode %}

Binaires universels et Format Mach-o

Les binaires Mac OS sont généralement compilés en tant que binaires universels. Un binaire universel peut prendre en charge plusieurs architectures dans le même fichier.

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

Dumping de mémoire macOS

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

Catégorie de risque des fichiers Mac OS

Les fichiers /System/Library/CoreServices/CoreTypes.bundle/Contents/Resources/System contiennent le risque associé aux fichiers en fonction de leur extension.

Les catégories possibles comprennent les suivantes :

  • LSRiskCategorySafe : Totalement sûr ; Safari s'ouvrira automatiquement après le téléchargement.
  • LSRiskCategoryNeutral : Aucun avertissement, mais non ouvert automatiquement.
  • LSRiskCategoryUnsafeExecutable : Déclenche un avertissement "Ce fichier est une application..."
  • LSRiskCategoryMayContainUnsafeExecutable : Cela concerne des choses comme les archives qui contiennent un exécutable. Il déclenche un avertissement à moins que Safari puisse déterminer que tout le contenu est sûr ou neutre.

Fichiers journaux

  • $HOME/Library/Preferences/com.apple.LaunchServices.QuarantineEventsV2 : Contient des informations sur les fichiers téléchargés, comme l'URL à partir de laquelle ils ont été téléchargés.
  • /var/log/system.log : Journal principal des systèmes OSX. com.apple.syslogd.plist est responsable de l'exécution de la journalisation système (vous pouvez vérifier s'il est désactivé en recherchant "com.apple.syslogd" dans launchctl list).
  • /private/var/log/asl/*.asl : Il s'agit des journaux système Apple qui peuvent contenir des informations intéressantes.
  • $HOME/Library/Preferences/com.apple.recentitems.plist : Stocke les fichiers et applications récemment consultés via "Finder".
  • $HOME/Library/Preferences/com.apple.loginitems.plsit : Stocke les éléments à lancer au démarrage du système.
  • $HOME/Library/Logs/DiskUtility.log : Fichier journal pour l'application DiskUtility (informations sur les lecteurs, y compris les clés USB).
  • /Library/Preferences/SystemConfiguration/com.apple.airport.preferences.plist : Données sur les points d'accès sans fil.
  • /private/var/db/launchd.db/com.apple.launchd/overrides.plist : Liste des démons désactivés.
☁️ HackTricks Cloud ☁️ -🐦 Twitter 🐦 - 🎙️ Twitch 🎙️ - 🎥 Youtube 🎥