macOS Office Sandbox Bypasses

Reading time: 4 minutes

tip

Impara e pratica l'Hacking AWS:HackTricks Training AWS Red Team Expert (ARTE)
Impara e pratica l'Hacking GCP: HackTricks Training GCP Red Team Expert (GRTE)

Supporta HackTricks

Bypass del Sandbox di Word tramite Launch Agents

L'applicazione utilizza un Sandbox personalizzato usando l'entitlement com.apple.security.temporary-exception.sbpl e questo sandbox personalizzato consente di scrivere file ovunque purché il nome del file inizi con ~$: (require-any (require-all (vnode-type REGULAR-FILE) (regex #"(^|/)~$[^/]+$")))

Pertanto, l'escape è stato facile come scrivere un plist LaunchAgent in ~/Library/LaunchAgents/~$escape.plist.

Controlla il report originale qui.

Bypass del Sandbox di Word tramite Login Items e zip

Ricorda che dal primo escape, Word può scrivere file arbitrari il cui nome inizia con ~$, anche se dopo la patch della vulnerabilità precedente non era possibile scrivere in /Library/Application Scripts o in /Library/LaunchAgents.

È stato scoperto che dall'interno del sandbox è possibile creare un Login Item (app che verranno eseguite quando l'utente accede). Tuttavia, queste app non verranno eseguite a meno che non siano notarizzate e non è possibile aggiungere argomenti (quindi non puoi semplicemente eseguire una reverse shell usando bash).

Dalla precedente bypass del Sandbox, Microsoft ha disabilitato l'opzione di scrivere file in ~/Library/LaunchAgents. Tuttavia, è stato scoperto che se metti un file zip come Login Item l'Archive Utility semplicemente decomprimerà il file nella sua posizione attuale. Quindi, poiché per impostazione predefinita la cartella LaunchAgents di ~/Library non viene creata, è stato possibile zipare un plist in LaunchAgents/~$escape.plist e posizionare il file zip in ~/Library in modo che, quando viene decompresso, raggiunga la destinazione di persistenza.

Controlla il report originale qui.

Bypass del Sandbox di Word tramite Login Items e .zshenv

(Ricorda che dal primo escape, Word può scrivere file arbitrari il cui nome inizia con ~$).

Tuttavia, la tecnica precedente aveva una limitazione, se la cartella ~/Library/LaunchAgents esiste perché qualche altro software l'ha creata, fallirebbe. Quindi è stata scoperta una diversa catena di Login Items per questo.

Un attaccante potrebbe creare i file .bash_profile e .zshenv con il payload da eseguire e poi zipparli e scrivere lo zip nella cartella dell'utente vittima: ~/~$escape.zip.

Poi, aggiungere il file zip ai Login Items e poi all'app Terminal. Quando l'utente effettua nuovamente il login, il file zip verrebbe decompresso nella cartella dell'utente, sovrascrivendo .bash_profile e .zshenv e quindi, il terminale eseguirà uno di questi file (a seconda se viene utilizzato bash o zsh).

Controlla il report originale qui.

Bypass del Sandbox di Word con Open e variabili env

Dai processi sandboxed è ancora possibile invocare altri processi utilizzando l'utility open. Inoltre, questi processi verranno eseguiti all'interno del proprio sandbox.

È stato scoperto che l'utility open ha l'opzione --env per eseguire un'app con variabili env specifiche. Pertanto, è stato possibile creare il file .zshenv all'interno di una cartella dentro il sandbox e utilizzare open con --env impostando la variabile HOME su quella cartella aprendo l'app Terminal, che eseguirà il file .zshenv (per qualche motivo era anche necessario impostare la variabile __OSINSTALL_ENVIROMENT).

Controlla il report originale qui.

Bypass del Sandbox di Word con Open e stdin

L'utility open supportava anche il parametro --stdin (e dopo il bypass precedente non era più possibile utilizzare --env).

Il fatto è che anche se python era firmato da Apple, non eseguirà uno script con l'attributo quarantine. Tuttavia, era possibile passargli uno script da stdin in modo che non controllasse se fosse stato quarantinato o meno:

  1. Rilascia un file ~$exploit.py con comandi Python arbitrari.
  2. Esegui open –stdin='~$exploit.py' -a Python, che esegue l'app Python con il nostro file rilasciato che funge da input standard. Python esegue felicemente il nostro codice, e poiché è un processo figlio di launchd, non è vincolato alle regole del sandbox di Word.

tip

Impara e pratica l'Hacking AWS:HackTricks Training AWS Red Team Expert (ARTE)
Impara e pratica l'Hacking GCP: HackTricks Training GCP Red Team Expert (GRTE)

Supporta HackTricks