macOS Dirty NIB
Для отримання додаткової інформації про техніку перегляньте оригінальний пост за адресою: https://blog.xpnsec.com/dirtynib/ та наступний пост від https://sector7.computest.nl/post/2024-04-bringing-process-injection-into-view-exploiting-all-macos-apps-using-nib-files/. Ось короткий виклад:
Що таке Nib файли
Nib (скорочення від NeXT Interface Builder) файли, частина екосистеми розробки Apple, призначені для визначення UI елементів та їх взаємодій в додатках. Вони містять серіалізовані об'єкти, такі як вікна та кнопки, і завантажуються під час виконання. Незважаючи на їхнє постійне використання, Apple тепер рекомендує Storyboards для більш комплексної візуалізації потоку UI.
Основний Nib файл згадується в значенні NSMainNibFile
всередині файлу Info.plist
додатку і завантажується функцією NSApplicationMain
, яка виконується в функції main
додатку.
Процес ін'єкції Dirty Nib
Створення та налаштування NIB файлу
Початкове налаштування:
Створіть новий NIB файл за допомогою XCode.
Додайте об'єкт до інтерфейсу, встановивши його клас на
NSAppleScript
.Налаштуйте початкову властивість
source
через атрибути часу виконання, визначені користувачем.
Гаджет виконання коду:
Налаштування дозволяє виконувати AppleScript за запитом.
Інтегруйте кнопку для активації об'єкта
Apple Script
, спеціально викликаючи селекторexecuteAndReturnError:
.
Тестування:
Простий Apple Script для тестування:
Тестуйте, запустивши в налагоджувачі XCode та натиснувши кнопку.
Цілеве застосування (приклад: Pages)
Підготовка:
Скопіюйте цільовий додаток (наприклад, Pages) в окрему директорію (наприклад,
/tmp/
).Запустіть додаток, щоб обійти проблеми з Gatekeeper і кешувати його.
Перезапис NIB файлу:
Замініть існуючий NIB файл (наприклад, NIB панелі "Про програму") на створений DirtyNIB файл.
Виконання:
Запустіть виконання, взаємодіючи з додатком (наприклад, вибравши пункт меню
About
).
Доказ концепції: доступ до даних користувача
Змініть AppleScript, щоб отримати доступ і витягти дані користувача, такі як фотографії, без згоди користувача.
Приклад коду: Зловмисний .xib файл
Отримайте доступ і перегляньте зразок зловмисного .xib файлу, який демонструє виконання довільного коду.
Інший приклад
У пості https://sector7.computest.nl/post/2024-04-bringing-process-injection-into-view-exploiting-all-macos-apps-using-nib-files/ ви можете знайти навчальний посібник про те, як створити dirty nib.
Вирішення обмежень запуску
Обмеження запуску заважають виконанню додатків з несподіваних місць (наприклад,
/tmp
).Можливо виявити додатки, які не захищені обмеженнями запуску, і націлити їх для ін'єкції NIB файлів.
Додаткові захисти macOS
З macOS Sonoma і далі, модифікації всередині пакетів додатків обмежені. Однак раніше методи включали:
Копіювання додатку в інше місце (наприклад,
/tmp/
).Перейменування директорій всередині пакету додатку, щоб обійти початкові захисти.
Після запуску додатку для реєстрації з Gatekeeper, модифікація пакету додатку (наприклад, заміна MainMenu.nib на Dirty.nib).
Повернення директорій назад і повторний запуск додатку для виконання ін'єкованого NIB файлу.
Примітка: Останні оновлення macOS зменшили ефективність цього експлойту, заборонивши модифікацію файлів у пакетах додатків після кешування Gatekeeper, що робить експлойт неефективним.
Last updated