Ende Mai entdeckten wir eine Kampagne zur Verbreitung der Schadsoftware Remote Access Trojan (RAT) – Programme, die es Angreifern ermöglichen, ein infiziertes System fernzusteuern.
Die von uns betrachtete Gruppe zeichnete sich dadurch aus, dass sie keine bestimmte RAT-Familie für die Infektion auswählte. Im Rahmen der Kampagne wurden bei Angriffen mehrere Trojaner (alle weit verbreitet) entdeckt. Dieses Merkmal erinnerte uns an den Rattenkönig, ein Fabelwesen aus Nagetieren mit ineinander verschlungenen Schwänzen.

Das Original stammt aus der Monographie von K. N. Rossikov „Mäuse und mausähnliche Nagetiere, die wirtschaftlich wichtigsten“ (1908).
Zu Ehren dieser Kreatur haben wir die Gruppe, die wir in Betracht ziehen, RATKing genannt. In diesem Beitrag gehen wir detailliert darauf ein, wie die Angreifer den Angriff durchgeführt haben, welche Tools sie verwendet haben, und teilen unsere Gedanken zur Zuordnung dieser Kampagne.
Der Verlauf des Angriffs
Alle Angriffe dieser Kampagne folgten dem folgenden Algorithmus:
- Der Benutzer erhielt eine Phishing-E-Mail mit einem Link zu Google Drive.
- Der Link führte das Opfer dazu, ein bösartiges VBS-Skript herunterzuladen, das eine DLL-Bibliothek installierte, um die endgültige Nutzlast in die Registrierung zu laden. Windows und startete PowerShell, um es auszuführen.
- Die DLL-Bibliothek injizierte die endgültige Nutzlast – einen der von den Angreifern verwendeten RATs – in den Systemprozess und schrieb ein VBS-Skript in den Autostart, um auf dem infizierten Computer Fuß zu fassen.
- Die endgültige Nutzlast wurde in einem Systemprozess ausgeführt und gab dem Angreifer die Möglichkeit, den infizierten Computer zu steuern.
Schematisch lässt es sich so darstellen:

Als nächstes konzentrieren wir uns auf die ersten drei Phasen, da wir am Mechanismus der Malware-Verbreitung interessiert sind. Wir werden den Funktionsmechanismus der Schadsoftware selbst nicht im Detail beschreiben. Sie sind überall verfügbar – sie werden entweder in spezialisierten Foren verkauft oder als Open-Source-Projekte vertrieben – und sind daher nicht nur der RATKing-Gruppe vorbehalten.
Analyse der Angriffsphasen
Phase 1. Phishing-Mailing
Der Angriff begann damit, dass das Opfer eine bösartige E-Mail erhielt (die Angreifer verwendeten verschiedene Vorlagen mit Text, der Screenshot unten zeigt ein Beispiel). Die Nachricht enthielt einen Link zu einem legitimen Repository. drive.google.com, die angeblich zu einer Seite zum Herunterladen eines PDF-Dokuments führte.

Beispiel einer Phishing-E-Mail
In Wirklichkeit wurde jedoch kein PDF-Dokument geladen, sondern ein VBS-Skript.
Wenn Sie auf den Link aus der E-Mail im Screenshot oben klicken, wird eine Datei mit dem Namen Cargo Flight Details.vbs. In diesem Fall haben die Angreifer nicht einmal versucht, die Datei als legitimes Dokument zu tarnen.
Gleichzeitig entdeckten wir im Rahmen dieser Kampagne ein Skript namens Cargo Trip Detail.pdf.vbsEs könnte bereits als legitimes PDF durchgehen, da es standardmäßig Windows Die Dateierweiterungen werden ausgeblendet. Allerdings könnte in diesem Fall das Symbol, das einem VBS-Skript entsprach, dennoch Verdacht erregen.
In diesem Stadium konnte das Opfer die Täuschung erkennen: Es genügte, sich eine Sekunde Zeit zu nehmen und die heruntergeladenen Dateien genau anzuschauen. Bei solchen Phishing-Kampagnen setzen Angreifer jedoch häufig auf unaufmerksame oder in Eile befindliche Benutzer.
Schritt 2. VBS-Skriptoperation
Ein VBS-Skript, das ein Benutzer möglicherweise versehentlich öffnet, würde eine DLL-Bibliothek in die Registrierung schreiben. WindowsDas Skript wurde verschleiert: Die darin enthaltenen Zeichenketten wurden als Bytes geschrieben, die durch ein beliebiges Zeichen getrennt waren.

Beispiel für ein verschleiertes Skript
Der Deobfuskationsalgorithmus ist recht einfach: Jedes dritte Zeichen wurde aus der verschleierten Zeichenfolge ausgeschlossen, wonach das Ergebnis von Base16 in die ursprüngliche Zeichenfolge dekodiert wurde. Zum Beispiel aus der Bedeutung 57Q53s63t72s69J70r74e2El53v68m65j6CH6Ct (im Screenshot oben hervorgehoben) war die resultierende Zeile WScript.Shell.
Um die Zeichenfolgen zu entschlüsseln, haben wir eine Python-Funktion verwendet:
def decode_str(data_enc):
return binascii.unhexlify(''.join([data_enc[i:i+2] for i in range(0, len(data_enc), 3)]))Unten, in den Zeilen 9–10, ist der Wert hervorgehoben, der nach der Deobfuskierung eine DLL-Datei erzeugte. Dieses wurde im nächsten Schritt mittels PowerShell gestartet.
![]()
Zeile mit verschleierter DLL
Jede Funktion im VBS-Skript wurde ausgeführt, während die Zeichenfolgen deobfuskiert wurden.
Nach dem Ausführen des Skripts wurde die Funktion aufgerufen wscript.sleep — Mit seiner Hilfe wurde eine aufgeschobene Hinrichtung durchgeführt.
Als Nächstes arbeitete das Skript mit der Registrierung. WindowsEr nutzte hierfür die WMI-Technologie. Diese erstellte einen eindeutigen Schlüssel, und der Inhalt der ausführbaren Datei wurde in dessen Parameter geschrieben. Der Zugriff auf die Registrierung über WMI erfolgte mit folgendem Befehl:
GetObject(winmgmts {impersonationLevel=impersonate}!\.rootdefault:StdRegProv) 
Ein Eintrag in der Registrierung durch ein VBS-Skript
Schritt 3. DLL-Bibliotheksoperation
In der dritten Phase lud die bösartige DLL-Bibliothek die endgültige Nutzlast herunter, injizierte sie in den Systemprozess und stellte sicher, dass das VBS-Skript automatisch gestartet wurde, wenn sich der Benutzer beim System anmeldete.
Ausführen über PowerShell
Die DLL wurde mit dem folgenden Befehl in PowerShell ausgeführt:
[System.Threading.Thread]::GetDomain().Load((ItemProperty HKCU:///Software///<rnd_sub_key_name> ).<rnd_value_name>);
[GUyyvmzVhebFCw]::EhwwK('WScript.ScriptFullName', 'rWZlgEtiZr', 'WScript.ScriptName'),0Dieser Befehl bewirkte Folgendes:
- erhaltene Registrierungswertdaten mit dem Namen
rnd_value_name– diese Daten waren eine DLL-Datei, die auf der .Net-Plattform geschrieben wurde; - das resultierende .Net-Modul in den Prozessspeicher geladen
powershell.exemit der Funktion[System.Threading.Thread]::GetDomain().Load()(detaillierte Beschreibung der Load()-Funktion ); - die Funktion ausgeführt
GUyyvmzVhebFCw]::EhwwK()— die Ausführung der DLL-Bibliothek begann damit — mit ParameternvbsScriptPath,xorKey,vbsScriptName. ParameterxorKeygespeichert den Schlüssel zum Entschlüsseln der endgültigen Nutzlast und die ParametervbsScriptPathиvbsScriptNamewurden übertragen um ein VBS-Skript im Autorun anzumelden.
Beschreibung der DLL-Bibliothek
Nach der Dekompilierung sah der Bootloader folgendermaßen aus:

Der Loader in dekompilierter Form (die Funktion, von der aus die Ausführung der DLL-Bibliothek begann, ist rot unterstrichen)
Der Loader wird durch den .Net Reactor Protector geschützt. Das Dienstprogramm de4dot leistet hervorragende Arbeit beim Entfernen dieses Schutzes.
Dieser Bootloader:
- die Nutzlast in den Systemprozess eingefügt (in diesem Beispiel ist es
svchost.exe); - Ich habe ein VBS-Skript im Autostart registriert.
Nutzlasteinspeisung
Sehen wir uns die Funktion an, die das PowerShell-Skript aufgerufen hat.

Vom PowerShell-Skript aufgerufene Funktion
Diese Funktion führte die folgenden Aktionen aus:
- entschlüsselte zwei Daten-Arrays (
arrayиarray2(im Screenshot). Sie wurden ursprünglich gzip-komprimiert und mit dem XOR-Algorithmus mit einem Schlüssel verschlüsseltxorKey; - kopierte Daten in zugewiesene Speicherbereiche. Daten aus
array— in den Speicherbereich, auf den verwiesen wirdintPtr(payload pointerim Screenshot); Daten vonarray2— in den Speicherbereich, auf den verwiesen wirdintPtr2(shellcode pointerim Screenshot); - aufgerufen die Funktion
CallWindowProcA( diese Funktion ist auf der Microsoft-Website) mit den folgenden Parametern (die Parameternamen sind unten aufgeführt, im Screenshot sind sie in der gleichen Reihenfolge, aber mit funktionierenden Werten):lpPrevWndFunc— Zeiger auf Daten vonarray2;hWnd— ein Zeiger auf eine Zeichenfolge, die den Pfad zur ausführbaren Datei enthältsvchost.exe;Msg— Zeiger auf Daten vonarray;wParam,lParam— Nachrichtenparameter (in diesem Fall wurden diese Parameter nicht verwendet und hatten den Wert 0);
- eine Datei erstellt
%AppData%MicrosoftWindowsStart MenuProgramsStartup<name>.urlWo<name>- das sind die ersten 4 Zeichen des ParametersvbsScriptName(im Screenshot beginnt das Codefragment mit dieser Aktion mit dem BefehlFile.Copy). Auf diese Weise fügte die Malware die URL-Datei zur Liste der Dateien hinzu, die automatisch ausgeführt werden sollten, wenn sich der Benutzer beim System anmeldete, und etablierte sich so auf dem infizierten Computer. Die URL-Datei enthielt einen Link zum Skript:
[InternetShortcut]
URL = file : ///<vbsScriptPath>
Um zu verstehen, wie die Injektion durchgeführt wurde, haben wir die Datenarrays entschlüsselt. array и array2. Dazu haben wir die folgende Python-Funktion verwendet:
def decrypt(data, key):
return gzip.decompress(
bytearray([data[i] ^ key[i % len(key)] for i in range(len(data))])[4:])
Als Ergebnis haben wir Folgendes herausgefunden:
arraywar eine PE-Datei – dies ist die endgültige Nutzlast;array2stellte den Shellcode dar, der zum Durchführen der Injektion erforderlich ist.
Shellcode aus Array array2 wurde als Funktionswert übergeben lpPrevWndFunc in Funktion CallWindowProcA. lpPrevWndFunc — Rückruffunktion, ihr Prototyp sieht folgendermaßen aus:
LRESULT WndFunc(
HWND hWnd,
UINT Msg,
WPARAM wParam,
LPARAM lParam
);
Wenn die Funktion ausgeführt wird CallWindowProcA mit Parametern hWnd, Msg, wParam, lParam Shellcode aus Array wird ausgeführt array2 mit Argumenten hWnd и Msg. hWnd — ist ein Zeiger auf eine Zeichenfolge, die den Pfad zur ausführbaren Datei enthält svchost.exeUnd Msg – Zeiger auf die endgültige Nutzlast.
Der Shellcode erhielt Funktionsadressen von kernel32.dll и ntdll32.dll basierend auf den Hash-Werten ihrer Namen und injizierte die endgültige Nutzlast in den Prozessspeicher svchost.exe, unter Verwendung der Process Hollowing-Technik (Sie können ausführlich darüber in diesem ). Beim Einfügen von Shellcode:
- den Prozess erstellt
svchost.exein einem suspendierten Zustand mit der FunktionCreateProcessW; - dann versteckte sich die Abschnittsanzeige im Prozessadressraum
svchost.exemit der FunktionNtUnmapViewOfSection. Auf diese Weise gab das Programm den Speicher des ursprünglichen Prozesses frei.svchost.exe, um dann an dieser Adresse Speicher für die Nutzlast zu reservieren; - zugewiesener Speicher für die Nutzlast im Prozessadressraum
svchost.exemit der FunktionVirtualAllocEx;

Beginn des Einspritzvorgangs
- schrieb den Inhalt der Nutzlast in den Adressraum des Prozesses
svchost.exemit der FunktionWriteProcessMemory(wie im Screenshot unten); - den Prozess wieder aufgenommen
svchost.exemit der FunktionResumeThread.

Abschluss des Injektionsvorgangs
Herunterladbare Malware
Als Ergebnis der beschriebenen Aktionen wurde eines von mehreren Schadprogrammen der RAT-Klasse auf dem infizierten System installiert. In der folgenden Tabelle ist die bei dem Angriff verwendete Schadsoftware aufgeführt. Wir können sie mit Sicherheit derselben Angreifergruppe zuordnen, da die Samples auf denselben Befehls- und Kontrollserver zugegriffen haben.
Name des VPO
Zum ersten Mal gesehen
SHA-256
C & C
Der Prozess, bei dem die Injektion durchgeführt wird
Darktrack
16-04-2020
ea64fe672c953adc19553ea3b9118ce4ee88a14d92fc7e75aa04972848472702
kimjoy007.dyndns[.]org:2017
svchost
Parallaxe
24-04-2020
b4ecd8dbbceaadd482f1b23b712bcddc5464bccaac11fe78ea5fd0ba932a4043
kimjoy007.dyndns[.]org:2019
svchost
KRIEGSGEBIET
18-05-2020
3786324ce3f8c1ea3784e5389f84234f81828658b22b8a502b7d48866f5aa3d3
kimjoy007.dyndns[.]org:9933
svchost
Netwire
20-05-2020
6dac218f741b022f5cad3b5ee01dbda80693f7045b42a0c70335d8a729002f2d
kimjoy007.dyndns[.]org:2000
svchost
Beispiele für verteilte Malware mit demselben Kontrollserver
Hierbei sind zwei Dinge zu beachten.
Erstens die Tatsache, dass die Angreifer mehrere verschiedene RAT-Familien gleichzeitig verwendeten. Dieses Verhalten ist nicht typisch für bekannte Cyber-Gruppen, die oft ungefähr dieselben Tools verwenden, mit denen sie vertraut sind.
Zweitens verwendete RATKing Malware, die entweder in spezialisierten Foren zu einem geringen Preis verkauft wird oder sogar ein Open-Source-Projekt ist.
Eine umfassendere Liste der in der Kampagne verwendeten Schadsoftware finden Sie – mit einem wichtigen Vorbehalt – am Ende des Artikels.
Über die Gruppe
Wir können die beschriebene bösartige Kampagne keinem bekannten Angreifer zuschreiben. Derzeit gehen wir davon aus, dass diese Angriffe von einer grundlegend neuen Gruppe durchgeführt wurden. Wie wir am Anfang geschrieben haben, haben wir es RATKing genannt.
Zur Erstellung des VBS-Skripts verwendete die Gruppe wahrscheinlich ein Tool ähnlich dem Dienstprogramm vom Entwickler . Darauf deutet die Ähnlichkeit des von diesem Programm erstellten Skripts mit dem Skript der Angreifer hin. Insbesondere haben beide:
- Implementieren Sie die verzögerte Ausführung mithilfe einer Funktion
Sleep; - WMI verwenden;
- Registrieren Sie den Hauptteil der ausführbaren Datei als Registrierungsschlüsselparameter.
- Führen Sie diese Datei mit PowerShell in ihrem eigenen Adressraum aus.
Vergleichen Sie zur Verdeutlichung den PowerShell-Befehl zum Ausführen einer Datei aus der Registrierung, der vom mit VBS-Crypter erstellten Skript verwendet wird:
((Get-ItemPropertyHKCU:SoftwareNYANxCAT).NYANxCAT);$text=-join$text[-1..-$text.Length];[AppDomain]::CurrentDomain.Load([Convert]::FromBase64String($text)).EntryPoint.Invoke($Null,$Null);mit einem ähnlichen Befehl, der vom Skript der Angreifer verwendet wurde:
[System.Threading.Thread]::GetDomain().Load((ItemProperty HKCU:///Software///<rnd_sub_key_name> ).<rnd_value_name>);
[GUyyvmzVhebFCw]::EhwwK('WScript.ScriptFullName', 'rWZlgEtiZr', 'WScript.ScriptName'),0
Beachten Sie, dass die Angreifer ein weiteres Dienstprogramm von NYAN-x-CAT als eine der Nutzlasten verwendeten — .
Die Adressen der C&C-Server weisen auf eine weitere Besonderheit von RATKing hin: Die Gruppe bevorzugt dynamische DNS-Dienste (siehe die Liste der C&C-Server in der Tabelle mit IoC).
IOC
Die folgende Tabelle enthält eine vollständige Liste der VBS-Skripte, die wahrscheinlich mit der beschriebenen Kampagne in Verbindung stehen. Alle diese Skripte sind ähnlich und führen im Wesentlichen dieselbe Abfolge von Aktionen aus. Sie alle injizieren RAT-Malware in einen vertrauenswürdigen Prozess. WindowsAlle verfügen über C&C-Adressen, die mithilfe von Dynamic-DNS-Diensten registriert sind.
Wir können jedoch nicht mit Sicherheit sagen, dass alle diese Skripte von denselben Angreifern verbreitet wurden, mit Ausnahme der Beispiele mit denselben C&C-Adressen (z. B. kimjoy007.dyndns.org).
Name des VPO
SHA-256
C & C
Der Prozess, bei dem die Injektion durchgeführt wird
Parallaxe
b4ecd8dbbceaadd482f1b23b712bcddc5464bccaac11fe78ea5fd0ba932a4043
kimjoy007.dyndns.org
svchost
00edb8200dfeee3bdd0086c5e8e07c6056d322df913679a9f22a2b00b836fd72
hope.doomdns.org
svchost
504cbae901c4b3987aa9ba458a230944cb8bd96bbf778ceb54c773b781346146
kimjoy007.dyndns.org
svchost
1487017e087b75ad930baa8b017e8388d1e99c75d26b5d1deec8b80e9333f189
kimjoy007.dyndns.org
svchost
c4160ec3c8ad01539f1c16fb35ed9c8c5a53a8fda8877f0d5e044241ea805891
franco20.dvrdns.org
svchost
515249d6813bb2dde1723d35ee8eb6eeb8775014ca629ede017c3d83a77634ce
kimjoy007.dyndns.org
svchost
1b70f6fee760bcfe0c457f0a85ca451ed66e61f0e340d830f382c5d2f7ab803f
franco20.dvrdns.org
svchost
b2bdffa5853f29c881d7d9bff91b640bc1c90e996f85406be3b36b2500f61aa1
hope.doomdns.org
svchost
c9745a8f33b3841fe7bfafd21ad4678d46fe6ea6125a8fedfcd2d5aee13f1601
kimjoy007.dyndns.org
svchost
1dfc66968527fbd4c0df2ea34c577a7ce7a2ba9b54ba00be62120cc88035fa65
franco20.dvrdns.org
svchost
c6c05f21e16e488eed3001d0d9dd9c49366779559ad77fcd233de15b1773c981
kimjoy007.dyndns.org
cmd
3b785cdcd69a96902ee62499c25138a70e81f14b6b989a2f81d82239a19a3aed
hope.doomdns.org
svchost
4d71ceb9d6c53ac356c0f5bdfd1a5b28981061be87e38e077ee3a419e4c476f9
2004para.ddns.net
svchost
00185cc085f284ece264e3263c7771073a65783c250c5fd9afc7a85ed94acc77
hope.doomdns.org
svchost
0342107c0d2a069100e87ef5415e90fd86b1b1b1c975d0eb04ab1489e198fc78
franco20.dvrdns.org
svchost
de33b7a7b059599dc62337f92ceba644ac7b09f60d06324ecf6177fff06b8d10
kimjoy007.dyndns.org
svchost
80a8114d63606e225e620c64ad8e28c9996caaa9a9e87dd602c8f920c2197007
kimjoy007.dyndns.org
svchost
acb157ba5a48631e1f9f269e6282f042666098614b66129224d213e27c1149bb
hope.doomdns.org
cmd
bf608318018dc10016b438f851aab719ea0abe6afc166c8aea6b04f2320896d3
franco20.dvrdns.org
svchost
4d0c9b8ad097d35b447d715a815c67ff3d78638b305776cde4d90bfdcb368e38
hope.doomdns.org
svchost
e7c676f5be41d49296454cd6e4280d89e37f506d84d57b22f0be0d87625568ba
kimjoy007.dyndns.org
svchost
9375d54fcda9c7d65f861dfda698e25710fda75b5ebfc7a238599f4b0d34205f
franco20.dvrdns.org
svchost
128367797fdf3c952831c2472f7a308f345ca04aa67b3f82b945cfea2ae11ce5
kimjoy007.dyndns.org
svchost
09bd720880461cb6e996046c7d6a1c937aa1c99bd19582a562053782600da79d
hope.doomdns.org
svchost
0a176164d2e1d5e2288881cc2e2d88800801001d03caedd524db365513e11276
paradickhead.homeip.net
svchost
0af5194950187fd7cbd75b1b39aab6e1e78dae7c216d08512755849c6a0d1cbe
hope.doomdns.org
svchost
Warzone
3786324ce3f8c1ea3784e5389f84234f81828658b22b8a502b7d48866f5aa3d3
kimjoy007.dyndns.org
svchost
db0d5a67a0ced6b2de3ee7d7fc845a34b9d6ca608e5fead7f16c9a640fa659eb
kimjoy007.dyndns.org
svchost
Netwire
6dac218f741b022f5cad3b5ee01dbda80693f7045b42a0c70335d8a729002f2d
kimjoy007.dyndns.org
svchost
Darktrack
ea64fe672c953adc19553ea3b9118ce4ee88a14d92fc7e75aa04972848472702
kimjoy007.dyndns.org
svchost
WSH RAT
d410ced15c848825dcf75d30808cde7784e5b208f9a57b0896e828f890faea0e
anekesolution.linkpc.net
RegAsm
Gelb
896604d27d88c75a475b28e88e54104e66f480bcab89cc75b6cdc6b29f8e438b
softmy.duckdns.org
RegAsm
Quasar RAT
bd1e29e9d17edbab41c3634649da5c5d20375f055ccf968c022811cd9624be57
darkhate-23030.portmap.io
RegAsm
12044aa527742282ad5154a4de24e55c9e1fae42ef844ed6f2f890296122153b
darkhate-23030.portmap.io
RegAsm
be93cc77d864dafd7d8c21317722879b65cfbb3297416bde6ca6edbfd8166572
darkhate-23030.portmap.io
RegAsm
933a136f8969707a84a61f711018cd21ee891d5793216e063ac961b5d165f6c0
darkhate-23030.portmap.io
RegAsm
71dea554d93728cce8074dbdb4f63ceb072d4bb644f0718420f780398dafd943
chrom1.myq-see.com
RegAsm
0d344e8d72d752c06dc6a7f3abf2ff7678925fde872756bf78713027e1e332d5
darkhate-23030.portmap.io
RegAsm
0ed7f282fd242c3f2de949650c9253373265e9152c034c7df3f5f91769c6a4eb
darkhate-23030.portmap.io
RegAsm
aabb6759ce408ebfa2cc57702b14adaec933d8e4821abceaef0c1af3263b1bfa
darkhate-23030.portmap.io
RegAsm
1699a37ddcf4769111daf33b7d313cf376f47e92f6b92b2119bd0c860539f745
darkhate-23030.portmap.io
RegAsm
3472597945f3bbf84e735a778fd75c57855bb86aca9b0a4d0e4049817b508c8c
darkhate-23030.portmap.io
RegAsm
809010d8823da84cdbb2c8e6b70be725a6023c381041ebda8b125d1a6a71e9b1
darkhate-23030.portmap.io
RegAsm
4217a2da69f663f1ab42ebac61978014ec4f562501efb2e040db7ebb223a7dff
darkhate-23030.portmap.io
RegAsm
08f34b3088af792a95c49bcb9aa016d4660609409663bf1b51f4c331b87bae00
darkhate-23030.portmap.io
RegAsm
79b4efcce84e9e7a2e85df7b0327406bee0b359ad1445b4f08e390309ea0c90d
darkhate-23030.portmap.io
RegAsm
12ea7ce04e0177a71a551e6d61e4a7916b1709729b2d3e9daf7b1bdd0785f63a
darkhate-23030.portmap.io
RegAsm
d7b8eb42ae35e9cc46744f1285557423f24666db1bde92bf7679f0ce7b389af9
darkhate-23030.portmap.io
RegAsm
def09b0fed3360c457257266cb851fffd8c844bc04a623c210a2efafdf000d5c
darkhate-23030.portmap.io
RegAsm
50119497c5f919a7e816a37178d28906fb3171b07fc869961ef92601ceca4c1c
darkhate-23030.portmap.io
RegAsm
ade5a2f25f603bf4502efa800d3cf5d19d1f0d69499b0f2e9ec7c85c6dd49621
darkhate-23030.portmap.io
RegAsm
189d5813c931889190881ee34749d390e3baa80b2c67b426b10b3666c3cc64b7
darkhate-23030.portmap.io
RegAsm
c3193dd67650723753289a4aebf97d4c72a1afe73c7135bee91c77bdf1517f21
darkhate-23030.portmap.io
RegAsm
a6f814f14698141753fc6fb7850ead9af2ebcb0e32ab99236a733ddb03b9eec2
darkhate-23030.portmap.io
RegAsm
a55116253624641544175a30c956dbd0638b714ff97b9de0e24145720dcfdf74
darkhate-23030.portmap.io
RegAsm
d6e0f0fb460d9108397850169112bd90a372f66d87b028e522184682a825d213
darkhate-23030.portmap.io
RegAsm
522ba6a242c35e2bf8303e99f03a85d867496bbb0572226e226af48cc1461a86
darkhate-23030.portmap.io
RegAsm
fabfdc209b02fe522f81356680db89f8861583da89984c20273904e0cf9f4a02
darkhate-23030.portmap.io
RegAsm
08ec13b7da6e0d645e4508b19ba616e4cf4e0421aa8e26ac7f69e13dc8796691
darkhate-23030.portmap.io
RegAsm
8433c75730578f963556ec99fbc8d97fa63a522cef71933f260f385c76a8ee8d
darkhate-23030.portmap.io
RegAsm
99f6bfd9edb9bf108b11c149dd59346484c7418fc4c455401c15c8ac74b70c74
darkhate-23030.portmap.io
RegAsm
d13520e48f0ff745e31a1dfd6f15ab56c9faecb51f3d5d3d87f6f2e1abe6b5cf
darkhate-23030.portmap.io
RegAsm
9e6978b16bd52fcd9c331839545c943adc87e0fbd7b3f947bab22ffdd309f747
darkhate-23030.portmap.io
RegAsm
Source: habr.com
