Chapardeur de mots de passe
Énoncé :
Un ami vous demande de l'aide pour déterminer si l'email qu'il vient d'ouvrir au sujet du Covid-19 était malveillant et si c'était le cas, ce qu'il risque.
Il prétend avoir essayé d'ouvrir le fichier joint à cet mail sans y parvenir. Peu de temps après, une fenêtre liée à l'anti-virus a indiqué, entre autre, le mot KPOT v2.0 mais rien d'apparent n'est arrivé en dehors de cela.
Après une analyse préliminaire, votre ami vous informe qu'il est probable que ce malware ait été légèrement modifié, étant donné que le contenu potentiellement exfiltré (des parties du format de texte et de fichier avant chiffrement) ne semble plus prédictible. Il vous recommande donc de chercher d'autres éléments pour parvenir à l'aider.
Vous disposez d'une capture réseau de son trafic pour l'aider à déterminer si des données ont bien été volées et lui dire s'il doit rapidement changer ses mots de passe !
Étape 1 - Recherche sur le malware
Pour commencer, nous téléchargeons la capture de trames de ~500Mo. Cela nous laisse le temps de chercher quelques informations sur le malware KPOT v2.0.
Je tombe sur 2 sites :
https://www.proofpoint.com/us/threat-insight/post/new-kpot-v20-stealer-brings-zero-persistence-and-memory-features-silently-steal
https://labs.sentinelone.com/info-stealers-how-malware-hacks-private-user-data/
On apprend que le malware contamine les victimes généralement par des attaques phishing à partir de la pièce jointe. Kpot utilise http pour agîr, il communique avec un serveur distant pour l'informer de l'infection d'un poste.
Il envoie une requête GET à destination d'un serveur de ce type: http://lesitemalveillant.ru/lmpUNlwDfoybeulu/gate.php
La réponse du serveur est encodé en base64 et XOR'd avec une clé stocké sous forme de chaîne. Voici un exemple d'échantillon déja analysé :
Les données contenu dans cette réponse sont délimitées par "DELIMM" et sont réparties selon le type de données suivant :
Une chaîne de bit indiquant les commandes à éxécuter
L'adresse ip de la victime
Les règles GRABBER précisant les fichiers à rechercher et exfiltrer
Le premier composant de la réponse ci dessus est une chaîne de 16 bits. Chaque 1 active une fonctionnalité, 0 la désactive. Voici une liste de quelques fonctionnalités :
Voler les cookies, les mots de passe de Chrome
Voler les cookies, les mots de passe de Firefox
Voler les cookies, les mot de passe d'Internet Explorer
Voler les comptes Skype
Voler les comptes de Télégram
Voler des comptes Discord
Volez les comptes Steam
Prendre une capture d'écran
Voler divers comptes clients FTP
Se supprimer lui même
Récupérer un fichier en fonction de son extension, sa taille, son path
Enfin ! La capture de trames est téléchargé. Maintenant que nous avons une vision sur le fonctionnement général du malware, commençons à l'analyser !
Étape 2 - La communication post-infection
Vu le contexte du challenge, je commence par chercher des trames en rapport avec la pièce jointe télécharger par notre ami, mais RAS.
Je passe donc à la recherche de la requête GET envoyé au serveur malveillant sur le fichier ciblé "gate.php".
On tombe sur 4 requêtes, voyons voir la quelle à répondu par OK à cette demande !
Le serveur en 203.0.113.42 a l'air d'être le bon candidat.
Récupérons le contenu de sa réponse :
D'après la documentation sur le malware, les données ont été encodé en base64 puis XOR'd à l'aide d'une clé, cependant nous n'avons pas cette clé...
Étape 3 - La clé XOR
Quelques types d'attaques sont connues avec XOR :
plaintext ⊕ key = encrypted_text
encrypted_text ⊕ plaintext = key
encrypted_text ⊕ key = plaintext
Ici nous avons des données chiffrées, pas de clé, mais nous connaissons les potentiels données qui pourraient se trouver à l'intérieur (GRABBER, DELIM etc...).
Après quelque recherche je trouve un tool capable de gérer cette attaque :
https://blog.didierstevens.com/2017/06/06/update-xor-kpa-py-version-0-0-5/.
La description de son fonctionnement est ici :
https://isc.sans.edu/forums/diary/Malware+and+XOR+Part+1/22486/
https://isc.sans.edu/forums/diary/Malware+and+XOR+Part+2/22490/
Il ne reste plus qu'à tester !
L'outil xor-kpa.py prend 2 fichiers en entrée :
Le premier fichier contient le texte en clair, et le second le fichier encodé.
Dans son exemple, Monsieur Didier Stevens recherche la chaîne "This program cannot be run in DOS mode" contenu généralement dans les éxécutables.
Son programme est d'ailleurs adaptés pour travailler avec cette chaîne, mais nous cela ne nous intéresse pas.
Notre texte en clair est composé de :
Prenons un échantillon !
Je décide de modifier le script xor-kpa.py :
Je remplace This program cannot be run in DOS mode
par GRABBER__0__GRABBER__1024
Le script ne prend pas en compte l'encodage base64, je décode donc la chaîne
Je lance le script en indiquant que nous recherchons le plaintext contenu dans la variable dos dans le contenu du fichier cipher.txt
Nous voilà maintenant avec 3 clés !
D'après les deux sites que l'on a vu au début expliquant le fonctionnement du malware, la clé fait généralement 16 bits, oh ! comme la dernière :)
La clé XOR serait donc : tDlsdL5dv25c1Rhv 🍀
Nous retrouvons donc bien le texte en clair en utilisant cette clé :
Maintenant analysons la requête POST envoyé au serveur, cette requête exfiltre les données en utilisant la clé XOR.
Nous récupérons le résultat en hexa :
Même manipulation que toute à l'heure pour déchiffrer les données
Dernière mise à jour