macOS Dirty NIB

Apprenez le piratage AWS de zéro à héros avec htARTE (Expert Red Team AWS HackTricks)!

Autres façons de soutenir HackTricks :

Pour plus de détails sur la technique, consultez l'article original sur : https://blog.xpnsec.com/dirtynib/**. Voici un résumé :

Les fichiers NIB, faisant partie de l'écosystème de développement d'Apple, sont destinés à définir les éléments d'interface utilisateur et leurs interactions dans les applications. Ils englobent des objets sérialisés tels que des fenêtres et des boutons, et sont chargés à l'exécution. Malgré leur utilisation continue, Apple préconise désormais l'utilisation de Storyboards pour une visualisation plus complète du flux d'interface utilisateur.

Problèmes de sécurité avec les fichiers NIB

Il est crucial de noter que les fichiers NIB peuvent représenter un risque de sécurité. Ils ont le potentiel d'exécuter des commandes arbitraires, et les modifications apportées aux fichiers NIB dans une application n'empêchent pas Gatekeeper d'exécuter l'application, ce qui constitue une menace significative.

Processus d'injection Dirty NIB

Création et configuration d'un fichier NIB

  1. Configuration initiale :

    • Créer un nouveau fichier NIB à l'aide de XCode.

    • Ajouter un objet à l'interface, en définissant sa classe sur NSAppleScript.

    • Configurer la propriété initiale source via les attributs d'exécution définis par l'utilisateur.

  2. Gadget d'exécution de code :

    • La configuration facilite l'exécution d'AppleScript à la demande.

    • Intégrer un bouton pour activer l'objet Apple Script, déclenchant spécifiquement le sélecteur executeAndReturnError:.

  3. Test :

    • Un simple Apple Script à des fins de test :

    set theDialogText to "PWND"
    display dialog theDialogText
    • Tester en exécutant dans le débogueur XCode et en cliquant sur le bouton.

Ciblage d'une application (Exemple : Pages)

  1. Préparation :

    • Copier l'application cible (par exemple, Pages) dans un répertoire séparé (par exemple, /tmp/).

    • Lancer l'application pour contourner les problèmes de Gatekeeper et la mettre en cache.

  2. Remplacement du fichier NIB :

    • Remplacer un fichier NIB existant (par exemple, le NIB du panneau À propos) par le fichier DirtyNIB créé.

  3. Exécution :

    • Déclencher l'exécution en interagissant avec l'application (par exemple, en sélectionnant l'élément de menu À propos).

Preuve de concept : Accès aux données utilisateur

  • Modifier l'AppleScript pour accéder et extraire des données utilisateur, telles que des photos, sans le consentement de l'utilisateur.

Exemple de code : Fichier .xib malveillant

Traitement des contraintes de lancement

  • Les contraintes de lancement empêchent l'exécution de l'application à partir d'emplacements inattendus (par exemple, /tmp).

  • Il est possible d'identifier les applications non protégées par les contraintes de lancement et de les cibler pour l'injection de fichiers NIB.

Protections supplémentaires macOS

À partir de macOS Sonoma, les modifications à l'intérieur des bundles d'applications sont restreintes. Cependant, les méthodes antérieures impliquaient :

  1. Copier l'application dans un emplacement différent (par exemple, /tmp/).

  2. Renommer les répertoires à l'intérieur du bundle de l'application pour contourner les protections initiales.

  3. Après avoir exécuté l'application pour s'enregistrer auprès de Gatekeeper, modifier le bundle de l'application (par exemple, remplacer MainMenu.nib par Dirty.nib).

  4. Renommer les répertoires et relancer l'application pour exécuter le fichier NIB injecté.

Remarque : Les récentes mises à jour de macOS ont atténué cette faille en empêchant les modifications de fichiers à l'intérieur des bundles d'applications après la mise en cache par Gatekeeper, rendant l'exploit inefficace.

Apprenez le piratage AWS de zéro à héros avec htARTE (Expert Red Team AWS HackTricks)!

Autres façons de soutenir HackTricks :

Dernière mise à jour