Pada penghujung bulan Mei, kami menemui kempen yang mengedarkan program perisian hasad Remote Access Trojan (RAT) yang membenarkan penyerang mengawal sistem yang dijangkiti dari jauh.
Kumpulan yang kami siasat terkenal kerana tidak menyasarkan keluarga RAT tertentu. Beberapa Trojan (semuanya tersedia secara meluas) diperhatikan dalam serangan semasa kempen. Sifat ini mengingatkan kita kepada Raja Tikus, makhluk mitos yang terdiri daripada tikus dengan ekor berjalin.

Asal diambil dari monograf oleh K. N. Rossikov "Tikus dan tikus seperti tikus, yang paling penting dari segi ekonomi" (1908)
Kami menamakan kumpulan yang kami siasat sebagai RATKing untuk menghormati makhluk ini. Dalam siaran ini, kami akan memperincikan cara penyerang melakukan serangan, alatan yang mereka gunakan dan berkongsi pendapat kami tentang atribusi.
Perjalanan serangan
Semua serangan dalam kempen ini mengikut algoritma berikut:
- Pengguna menerima e-mel pancingan data dengan pautan ke Google Drive.
- Pautan itu membenarkan mangsa memuat turun skrip VBS berniat jahat yang akan menulis perpustakaan DLL untuk memuatkan muatan akhir ke dalam pendaftaran Windows dan melancarkan PowerShell untuk melaksanakannya.
- DLL menyuntik muatan akhir—salah satu RAT yang digunakan oleh penyerang—ke dalam proses sistem dan menambahkan skrip VBS untuk dimulakan untuk mendapatkan tempat pada mesin yang dijangkiti.
- Muatan akhir telah dilaksanakan dalam proses sistem dan memberikan penyerang keupayaan untuk mengawal komputer yang dijangkiti.
Secara skematik, ini boleh diwakili seperti berikut:

Di bawah, kami akan menumpukan pada tiga peringkat pertama, kerana kami secara khusus berminat dengan mekanisme penghantaran perisian hasad. Kami tidak akan menerangkan perisian hasad itu sendiri secara terperinci. Ia tersedia secara meluas—sama ada dijual di forum khusus atau diedarkan sebagai projek sumber terbuka—dan oleh itu ia tidak unik untuk kumpulan RATKing.
Analisis peringkat serangan
Peringkat 1. E-mel pancingan data
Serangan bermula dengan mangsa menerima e-mel berniat jahat (penyerang menggunakan templat berbeza; tangkapan skrin di bawah menunjukkan satu contoh). Mesej itu mengandungi pautan ke lokasi storan yang sah. drive.google.com, yang didakwa membawa kepada halaman untuk memuat turun dokumen PDF.

Contoh e-mel pancingan data
Walau bagaimanapun, pada hakikatnya, ia bukan dokumen PDF yang dimuat turun, tetapi skrip VBS.
Apabila mengklik pada pautan dari e-mel dalam tangkapan skrin di atas, fail bernama Cargo Flight Details.vbsDalam kes ini, penyerang tidak cuba untuk menyamar fail sebagai dokumen yang sah.
Pada masa yang sama, sebagai sebahagian daripada kempen ini, kami menemui skrip bernama Cargo Trip Detail.pdf.vbsIa sudah boleh lulus untuk PDF yang sah, kerana Windows menyembunyikan sambungan fail secara lalai. Walau bagaimanapun, dalam kes ini, ikonnya, yang menyerupai skrip VBS, masih boleh menimbulkan syak wasangka.
Pada ketika ini, mangsa mungkin menyedari penipuan itu: cuma luangkan masa sebentar untuk melihat dengan teliti fail yang dimuat turun. Walau bagaimanapun, dalam kempen pancingan data sedemikian, penyerang sering menjadi mangsa pengguna yang lalai atau tergesa-gesa.
Langkah 2. Menjalankan skrip VBS
Skrip VBS, yang mungkin dibuka oleh pengguna secara tidak sengaja, menulis DLL ke dalam pendaftaran Windows. Skrip itu dikaburkan: rentetannya ditulis sebagai bait yang dipisahkan oleh aksara sewenang-wenangnya.

Contoh skrip yang dikelirukan
Algoritma penyahkeliruan agak mudah: setiap aksara ketiga dikecualikan daripada rentetan yang dikelirukan, selepas itu hasilnya dinyahkodkan daripada base16 ke dalam rentetan asal. Sebagai contoh, daripada nilai 57Q53s63t72s69J70r74e2El53v68m65j6CH6Ct (diserlahkan dalam tangkapan skrin di atas) rentetan yang terhasil ialah WScript.Shell.
Untuk menyahkelirukan rentetan, kami menggunakan fungsi Python:
def decode_str(data_enc):
return binascii.unhexlify(''.join([data_enc[i:i+2] for i in range(0, len(data_enc), 3)]))Di bawah, pada baris 9–10, nilai yang, apabila dinyahkelirukan, menghasilkan fail DLL diserlahkan. Ini ialah fail DLL yang dijalankan dalam langkah seterusnya menggunakan PowerShell.
![]()
Baris dengan DLL yang dikelirukan
Setiap fungsi dalam skrip VBS telah dilaksanakan apabila rentetan dinyahkelirukan.
Selepas menjalankan skrip, fungsi itu dipanggil wscript.sleep — dengan bantuannya, pelaksanaan tertunda telah dijalankan.
Skrip itu kemudiannya mengakses pendaftaran Windows menggunakan teknologi WMI. Ia mencipta kunci unik, dan badan fail boleh laku telah ditulis pada parameternya. Pendaftaran telah diakses melalui WMI menggunakan arahan berikut:
GetObject(winmgmts {impersonationLevel=impersonate}!\.rootdefault:StdRegProv) 
Entri yang dibuat dalam pendaftaran oleh skrip VBS
Langkah 3. Operasi DLL
Pada peringkat ketiga, DLL berniat jahat memuat turun muatan akhir, menyuntiknya ke dalam proses sistem dan memastikan skrip VBS akan dijalankan secara automatik apabila pengguna log masuk.
Jalankan melalui PowerShell
DLL telah dilaksanakan menggunakan arahan berikut dalam PowerShell:
[System.Threading.Thread]::GetDomain().Load((ItemProperty HKCU:///Software///<rnd_sub_key_name> ).<rnd_value_name>);
[GUyyvmzVhebFCw]::EhwwK('WScript.ScriptFullName', 'rWZlgEtiZr', 'WScript.ScriptName'),0Perintah ini melakukan perkara berikut:
- menerima data nilai pendaftaran dengan nama
rnd_value_name— data ini ialah fail DLL yang ditulis pada platform .Net; - memuatkan modul .Net yang terhasil ke dalam memori proses
powershell.exemenggunakan fungsi tersebut[System.Threading.Thread]::GetDomain().Load()(huraian terperinci tentang fungsi Load(). ); - melaksanakan fungsi tersebut
GUyyvmzVhebFCw]::EhwwK()— pelaksanaan perpustakaan DLL bermula dengannya — dengan parametervbsScriptPath,xorKey,vbsScriptName. ParameterxorKeymenyimpan kunci untuk menyahsulit muatan akhir, dan parametervbsScriptPathиvbsScriptNametelah dipindahkan untuk mendaftarkan skrip VBS dalam permulaan.
Penerangan mengenai perpustakaan DLL
Apabila dinyahkompilasi, pemuat but kelihatan seperti ini:

Pemuat dalam bentuk decompiled (fungsi dari mana pelaksanaan perpustakaan DLL bermula digariskan dengan warna merah)
Pemuat but dilindungi oleh .Net Reactor. Utiliti de4dot sangat baik untuk mengeluarkan pelindung ini.
Pemuat but ini:
- menyuntik muatan ke dalam proses sistem (dalam contoh ini ialah
svchost.exe); - Saya mendaftarkan skrip VBS dalam permulaan.
Suntikan muatan
Mari lihat fungsi yang dipanggil oleh skrip PowerShell.

Fungsi yang dipanggil oleh skrip PowerShell
Fungsi ini melakukan tindakan berikut:
- menyahsulit dua tatasusunan data (
arrayиarray2(dalam tangkapan skrin). Mereka pada asalnya dimampatkan dengan gzip dan disulitkan dengan algoritma XOR dengan kuncixorKey; - menyalin data ke kawasan memori yang diperuntukkan. Data daripada
array— ke kawasan ingatan yang ditunjukintPtr(payload pointerdalam tangkapan skrin); data daripadaarray2— ke kawasan ingatan yang ditunjukintPtr2(shellcode pointerdalam tangkapan skrin); - dipanggil fungsi
CallWindowProcA( Fungsi ini tersedia di laman web Microsoft) dengan parameter berikut (nama parameter disenaraikan di bawah, dalam tangkapan skrin mereka berada dalam susunan yang sama, tetapi dengan nilai yang berfungsi):lpPrevWndFunc— penunjuk kepada data daripadaarray2;hWnd— penunjuk kepada rentetan yang mengandungi laluan ke fail boleh lakusvchost.exe;Msg— penunjuk kepada data daripadaarray;wParam,lParam— parameter mesej (dalam kes ini parameter ini tidak digunakan dan mempunyai nilai 0);
- mencipta fail
%AppData%MicrosoftWindowsStart MenuProgramsStartup<name>.urlJika<name>- ini ialah 4 aksara pertama parametervbsScriptName(dalam tangkapan skrin, serpihan kod dengan tindakan ini bermula dengan arahanFile.Copy). Oleh itu, perisian hasad menambah fail URL pada senarai fail untuk dijalankan secara automatik semasa log masuk pengguna, dengan itu mewujudkan kehadiran kekal pada komputer yang dijangkiti. Fail URL mengandungi pautan ke skrip:
[InternetShortcut]
URL = file : ///<vbsScriptPath>
Untuk memahami cara suntikan dijalankan, kami mentafsir tatasusunan data array и array2Untuk ini kami menggunakan fungsi Python berikut:
def decrypt(data, key):
return gzip.decompress(
bytearray([data[i] ^ key[i % len(key)] for i in range(len(data))])[4:])
Hasilnya, kami mendapati bahawa:
arrayialah fail PE - ini ialah muatan akhir;array2mewakili shellcode yang diperlukan untuk melakukan suntikan.
Shellcode daripada tatasusunan array2 telah diluluskan sebagai nilai fungsi lpPrevWndFunc menjadi fungsi CallWindowProcA. lpPrevWndFunc — fungsi panggil balik, prototaipnya kelihatan seperti ini:
LRESULT WndFunc(
HWND hWnd,
UINT Msg,
WPARAM wParam,
LPARAM lParam
);
Jadi apabila anda menjalankan fungsi CallWindowProcA dengan parameter hWnd, Msg, wParam, lParam shellcode daripada tatasusunan dilaksanakan array2 dengan hujah hWnd и Msg. hWnd - ialah penunjuk kepada rentetan yang mengandungi laluan ke fail boleh laku svchost.exeDan Msg — penunjuk kepada muatan akhir.
Kod shell menerima alamat fungsi daripada kernel32.dll и ntdll32.dll berdasarkan nilai hash dari nama mereka dan menyuntik muatan akhir ke dalam memori proses svchost.exe, menggunakan teknik Process Hollowing (anda boleh membacanya secara terperinci dalam ini ). Apabila menyuntik kod shell:
- mencipta proses
svchost.exedalam keadaan digantung menggunakan fungsi tersebutCreateProcessW; - kemudian menyembunyikan paparan bahagian dalam ruang alamat proses
svchost.exemenggunakan fungsi tersebutNtUnmapViewOfSectionDengan cara ini, program membebaskan memori proses asal.svchost.exe, untuk kemudian memperuntukkan memori untuk muatan di alamat ini; - memori yang diperuntukkan untuk muatan dalam ruang alamat proses
svchost.exemenggunakan fungsi tersebutVirtualAllocEx;

Permulaan proses suntikan
- menulis kandungan muatan ke dalam ruang alamat proses
svchost.exemenggunakan fungsi tersebutWriteProcessMemory(seperti dalam tangkapan skrin di bawah); - meneruskan proses itu
svchost.exemenggunakan fungsi tersebutResumeThread.

Selesai proses suntikan
perisian hasad yang boleh dimuat turun
Hasil daripada tindakan yang diterangkan, salah satu daripada beberapa program perisian hasad kelas RAT telah dipasang pada sistem yang dijangkiti. Jadual di bawah menyenaraikan perisian hasad yang digunakan dalam serangan, yang kami yakin boleh mengaitkan kepada kumpulan penyerang tunggal, kerana sampel mengakses pelayan arahan dan kawalan yang sama.
Nama VPO
Mula-mula perasan
SHA-256
C&C
Proses di mana suntikan dijalankan
Darktrack
16-04-2020
ea64fe672c953adc19553ea3b9118ce4ee88a14d92fc7e75aa04972848472702
kimjoy007.dyndns[.]org:2017
Svchost
Parallax
24-04-2020
b4ecd8dbbceaadd482f1b23b712bcddc5464bccaac11fe78ea5fd0ba932a4043
kimjoy007.dyndns[.]org:2019
Svchost
ZON PERANG
18-05-2020
3786324ce3f8c1ea3784e5389f84234f81828658b22b8a502b7d48866f5aa3d3
kimjoy007.dyndns[.]org:9933
Svchost
Netwire
20-05-2020
6dac218f741b022f5cad3b5ee01dbda80693f7045b42a0c70335d8a729002f2d
kimjoy007.dyndns[.]org:2000
Svchost
Contoh perisian hasad yang diedarkan dengan pelayan kawalan yang sama
Terdapat dua perkara yang perlu diperhatikan di sini.
Pertama, fakta bahawa penyerang menggunakan beberapa keluarga RAT yang berbeza secara serentak. Tingkah laku ini adalah luar biasa untuk kumpulan penjenayah siber yang terkenal, yang sering menggunakan set alat biasa yang serupa.
Kedua, RATKing menggunakan perisian hasad yang sama ada dijual di forum khusus dengan harga yang kecil atau sebenarnya projek sumber terbuka.
Senarai yang lebih lengkap bagi perisian hasad yang digunakan dalam kempen—dengan satu kaveat penting—disediakan di penghujung artikel.
Mengenai kumpulan itu
Kami tidak boleh mengaitkan kempen berniat jahat yang diterangkan kepada mana-mana pelaku ancaman yang diketahui. Pada masa ini kami percaya serangan ini dilakukan oleh kumpulan yang pada asasnya baru. Seperti yang kami tulis pada mulanya, kami telah menggelarkannya sebagai RATKing.
Untuk mencipta skrip VBS, kumpulan itu mungkin menggunakan alat yang serupa dengan utiliti daripada pemaju Ini ditunjukkan oleh persamaan antara skrip yang dibuat oleh program ini dan skrip penyerang. Secara khusus, mereka berdua:
- melaksanakan pelaksanaan tertunda menggunakan fungsi
Sleep; - gunakan WMI;
- daftarkan badan fail boleh laku sebagai parameter kunci pendaftaran;
- laksanakan fail ini menggunakan PowerShell dalam ruang alamatnya sendiri.
Untuk kejelasan, bandingkan perintah PowerShell untuk menjalankan fail daripada pendaftaran, yang digunakan oleh skrip yang dibuat dengan VBS-Crypter:
((Get-ItemPropertyHKCU:SoftwareNYANxCAT).NYANxCAT);$text=-join$text[-1..-$text.Length];[AppDomain]::CurrentDomain.Load([Convert]::FromBase64String($text)).EntryPoint.Invoke($Null,$Null);dengan arahan yang serupa dengan yang digunakan oleh skrip penyerang:
[System.Threading.Thread]::GetDomain().Load((ItemProperty HKCU:///Software///<rnd_sub_key_name> ).<rnd_value_name>);
[GUyyvmzVhebFCw]::EhwwK('WScript.ScriptFullName', 'rWZlgEtiZr', 'WScript.ScriptName'),0
Ambil perhatian bahawa penyerang menggunakan utiliti lain daripada NYAN-x-CAT sebagai salah satu muatan — .
Alamat pelayan C&C menunjukkan satu lagi ciri tersendiri RATKing: kumpulan itu memilih perkhidmatan DNS dinamik (lihat senarai C&C dalam jadual IoC).
IoC
Jadual di bawah menyediakan senarai lengkap skrip VBS yang mungkin berkaitan dengan kempen yang diterangkan. Semua skrip ini adalah serupa dan melakukan urutan tindakan yang hampir sama. Kesemuanya menyuntik perisian hasad kelas RAT ke dalam proses Windows yang dipercayai. Kesemua mereka mempunyai alamat C&C yang didaftarkan menggunakan perkhidmatan DNS Dinamik.
Walau bagaimanapun, kami tidak dapat memastikan dengan pasti bahawa semua skrip ini diedarkan oleh penyerang yang sama, kecuali untuk sampel dengan alamat C&C yang sama (mis. kimjoy007.dyndns.org).
Nama VPO
SHA-256
C&C
Proses di mana suntikan dijalankan
Parallax
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
Zon perang
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
Lime
896604d27d88c75a475b28e88e54104e66f480bcab89cc75b6cdc6b29f8e438b
softmy.duckdns.org
RegAsm
QuasarRAT
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
Sumber: www.habr.com
