RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan

Sa katapusan ng Mayo, natuklasan namin ang isang kampanya upang ipamahagi ang Remote Access Trojan (RAT) malwareβ€”mga programang nagbibigay-daan sa mga umaatake na malayuang kontrolin ang isang nahawaang system.

Ang pangkat na aming sinuri ay nakikilala sa katotohanan na hindi ito pumili ng anumang partikular na pamilya ng RAT para sa impeksyon. Maraming Trojan ang nakita sa mga pag-atake bilang bahagi ng kampanya (lahat ay malawak na magagamit). Gamit ang tampok na ito, ipinaalala sa amin ng grupo ang hari ng daga - isang gawa-gawa na hayop na binubuo ng mga daga na may magkadugtong na buntot.

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan
Ang orihinal ay kinuha mula sa monograp ni K. N. Rossikov "Mga daga at tulad ng daga, ang pinakamahalaga sa ekonomiya" (1908)

Bilang parangal sa nilalang na ito, pinangalanan namin ang grupo na aming isinasaalang-alang na RATKing. Sa post na ito, isasaalang-alang namin ang detalye tungkol sa kung paano isinagawa ng mga umaatake ang pag-atake, anong mga tool ang kanilang ginamit, at ibabahagi rin ang aming mga saloobin sa pagpapatungkol para sa kampanyang ito.

Pag-unlad ng pag-atake

Ang lahat ng mga pag-atake sa kampanyang ito ay naganap ayon sa sumusunod na algorithm:

  1. Nakatanggap ang user ng phishing email na may link sa Google Drive.
  2. Gamit ang link, nag-download ang biktima ng malisyosong VBS script na tumutukoy sa isang DLL library para i-load ang final payload sa Windows registry at inilunsad ang PowerShell para isagawa ito.
  3. Ang DLL library ay nag-inject ng final payload - sa katunayan, isa sa mga RAT na ginagamit ng mga attacker - sa proseso ng system at nagrehistro ng VBS script sa autorun upang makakuha ng foothold sa infected na makina.
  4. Ang huling payload ay naisakatuparan sa isang proseso ng system at binigyan ang umaatake ng kakayahang kontrolin ang nahawaang computer.

Sa eskematiko, maaari itong ilarawan tulad nito:

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan

Susunod, tututuon namin ang unang tatlong yugto, dahil interesado kami sa mekanismo ng paghahatid ng malware. Hindi namin ilalarawan nang detalyado ang mekanismo ng pagpapatakbo ng malware mismo. Malawakang magagamit ang mga ito - maaaring ibinebenta sa mga dalubhasang forum, o kahit na ibinahagi bilang mga open source na proyekto - at samakatuwid ay hindi natatangi sa pangkat ng RATKing.

Pagsusuri ng mga yugto ng pag-atake

Stage 1. Phishing email

Nagsimula ang pag-atake sa pagtanggap ng biktima ng malisyosong sulat (gumamit ang mga umaatake ng iba't ibang mga template na may teksto; ang screenshot sa ibaba ay nagpapakita ng isang halimbawa). Ang mensahe ay naglalaman ng isang link sa isang lehitimong repositoryo drive.google.com, na diumano ay humantong sa isang pahina ng pag-download ng dokumentong PDF.

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan
Halimbawa ng email sa phishing

Gayunpaman, sa katunayan, ito ay hindi isang PDF na dokumento na na-load sa lahat, ngunit isang VBS script.

Kapag nag-click ka sa link mula sa email sa screenshot sa itaas, isang file na pinangalanan Cargo Flight Details.vbs. Sa kasong ito, hindi man lang sinubukan ng mga umaatake na itago ang file bilang isang lehitimong dokumento.

Kasabay nito, bilang bahagi ng kampanyang ito, natuklasan namin ang isang script na pinangalanan Cargo Trip Detail.pdf.vbs. Maaari na itong pumasa para sa isang lehitimong PDF dahil itinatago ng Windows ang mga extension ng file bilang default. Totoo, sa kasong ito, ang hinala ay maaari pa ring pukawin ng icon nito, na tumutugma sa script ng VBS.

Sa yugtong ito, makikilala ng biktima ang panlilinlang: tingnan lamang ang mga na-download na file nang isang segundo. Gayunpaman, sa gayong mga kampanya sa phishing, ang mga umaatake ay madalas na umaasa sa isang walang pansin o nagmamadaling user.

Stage 2. VBS script operation

Ang VBS script, na maaaring mabuksan ng user nang hindi sinasadya, ay nagrehistro ng isang DLL library sa Windows registry. Ang script ay na-obfuscated: ang mga linya sa loob nito ay isinulat bilang mga byte na pinaghihiwalay ng isang arbitrary na character.

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan
Halimbawa ng isang obfuscated na script

Ang deobfuscation algorithm ay medyo simple: bawat ikatlong character ay hindi kasama sa obfuscated string, pagkatapos nito ang resulta ay na-decode mula sa base16 patungo sa orihinal na string. Halimbawa, mula sa halaga 57Q53s63t72s69J70r74e2El53v68m65j6CH6Ct (naka-highlight sa screenshot sa itaas) ang nagresultang linya ay WScript.Shell.

Upang i-deobfuscate ang mga string, ginamit namin ang Python function:

def decode_str(data_enc):   
    return binascii.unhexlify(''.join([data_enc[i:i+2] for i in range(0, len(data_enc), 3)]))

Sa ibaba, sa mga linya 9–10, itinatampok namin ang halaga na nagresulta ang pag-deobfuscation sa isang DLL file. Siya ang inilunsad sa susunod na yugto gamit ang PowerShell.

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan
String na may obfuscated DLL

Ang bawat function sa VBS script ay naisakatuparan habang ang mga string ay na-deobfuscate.

Pagkatapos patakbuhin ang script, tinawag ang function wscript.sleep β€” ito ay ginamit upang maisagawa ang ipinagpaliban na pagpapatupad.

Susunod, gumana ang script sa Windows registry. Ginamit niya ang teknolohiya ng WMI para dito. Sa tulong nito, isang natatanging susi ang nilikha, at ang katawan ng maipapatupad na file ay isinulat sa parameter nito. Na-access ang registry sa pamamagitan ng WMI gamit ang sumusunod na command:

GetObject(winmgmts {impersonationLevel=impersonate}!\.rootdefault:StdRegProv)

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan
Isang entry na ginawa sa registry ng isang VBS script

Stage 3. Operasyon ng DLL library

Sa ikatlong yugto, ni-load ng malisyosong DLL ang panghuling kargamento, ini-inject ito sa proseso ng system, at tiniyak na ang script ng VBS ay awtomatikong nagsimula kapag nag-log in ang user.

Patakbuhin sa pamamagitan ng PowerShell

Ang DLL ay naisakatuparan gamit ang sumusunod na command sa PowerShell:

[System.Threading.Thread]::GetDomain().Load((ItemProperty HKCU:///Software///<rnd_sub_key_name> ).<rnd_value_name>);
[GUyyvmzVhebFCw]::EhwwK('WScript.ScriptFullName', 'rWZlgEtiZr', 'WScript.ScriptName'),0

Ginawa ng utos na ito ang sumusunod:

  • nakatanggap ng data ng halaga ng registry na may pangalan rnd_value_name β€” ang data na ito ay isang DLL file na nakasulat sa .Net platform;
  • na-load ang nagresultang .Net module sa memorya ng proseso powershell.exe gamit ang function [System.Threading.Thread]::GetDomain().Load() (detalyadong paglalarawan ng Load() function magagamit sa website ng Microsoft);
  • ginanap ang function GUyyvmzVhebFCw]::EhwwK() - nagsimula dito ang pagpapatupad ng library ng DLL - na may mga parameter vbsScriptPath, xorKey, vbsScriptName. Parameter xorKey nag-imbak ng susi para sa pag-decrypting ng huling kargamento, at ang mga parameter vbsScriptPath ΠΈ vbsScriptName ay inilipat upang makapagrehistro ng VBS script sa autorun.

Paglalarawan ng DLL library

Sa decompiled form, ang bootloader ay ganito ang hitsura:

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan
Loader sa decompiled form (ang function kung saan nagsimula ang pagpapatupad ng DLL library ay may salungguhit na pula)

Ang bootloader ay protektado ng .Net Reactor protector. Ang de4dot utility ay gumagawa ng isang mahusay na trabaho sa pag-alis ng tagapagtanggol na ito.

Ang loader na ito:

  • nag-inject ng payload sa proseso ng system (sa halimbawang ito ito svchost.exe);
  • Nagdagdag ako ng VBS script sa autorun.

Payload injection

Tingnan natin ang function na tinawag ng PowerShell script.

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan
Function na tinatawag ng PowerShell script

Ginawa ng function na ito ang mga sumusunod na aksyon:

  • na-decrypt ang dalawang set ng data (array ΠΈ array2 sa screenshot). Ang mga ito ay orihinal na na-compress gamit ang gzip at naka-encrypt gamit ang XOR algorithm na may susi xorKey;
  • kinopya ang data sa mga inilalaang lugar ng memorya. Data mula sa array - sa lugar ng memorya na itinuro intPtr (payload pointer sa screenshot); data mula sa array2 - sa lugar ng memorya na itinuro intPtr2 (shellcode pointer sa screenshot);
  • tinatawag na function CallWindowProcA (описаниС Available ang function na ito sa website ng Microsoft) na may mga sumusunod na parameter (ang mga pangalan ng mga parameter ay nakalista sa ibaba, sa screenshot sila ay nasa parehong pagkakasunud-sunod, ngunit may mga gumaganang halaga):
    • lpPrevWndFunc - pointer sa data mula sa array2;
    • hWnd β€” pointer sa isang string na naglalaman ng path sa executable file svchost.exe;
    • Msg - pointer sa data mula sa array;
    • wParamlParam β€” mga parameter ng mensahe (sa kasong ito, ang mga parameter na ito ay hindi ginamit at may mga halaga ng 0);
  • lumikha ng isang file %AppData%MicrosoftWindowsStart MenuProgramsStartup<name>.urlSaan <name> - ito ang unang 4 na character ng parameter vbsScriptName (sa screenshot, ang code fragment na may ganitong aksyon ay nagsisimula sa command File.Copy). Sa ganitong paraan, nagdagdag ang malware ng URL file sa listahan ng mga autorun file kapag nag-log in ang user at sa gayo'y naging attached sa infected na computer. Ang URL file ay naglalaman ng isang link sa script:

[InternetShortcut]
URL = file : ///<vbsScriptPath>

Upang maunawaan kung paano isinagawa ang iniksyon, na-decrypt namin ang mga arrays ng data array ΠΈ array2. Upang gawin ito ginamit namin ang sumusunod na function ng Python:

def decrypt(data, key):
    return gzip.decompress(
        bytearray([data[i] ^ key[i % len(key)] for i in range(len(data))])[4:])
    

Bilang resulta, nalaman namin na:

  • array ay isang PE file - ito ang huling payload;
  • array2 ay ang shellcode na kinakailangan upang maisagawa ang iniksyon.

Shellcode mula sa isang array array2 ipinasa bilang isang halaga ng function lpPrevWndFunc sa isang function CallWindowProcA. lpPrevWndFunc β€” callback function, ang prototype nito ay ganito ang hitsura:

LRESULT WndFunc(
  HWND    hWnd,
  UINT    Msg,
  WPARAM  wParam,
  LPARAM  lParam
);

Kaya kapag pinatakbo mo ang function CallWindowProcA may mga parameter hWnd, Msg, wParam, lParam Ang shellcode mula sa array ay naisakatuparan array2 may mga argumento hWnd ΠΈ Msg. hWnd ay isang pointer sa isang string na naglalaman ng path sa executable file svchost.exeAt Msg β€” pointer sa huling payload.

Nakatanggap ang shellcode ng mga address ng function mula sa kernel32.dll ΠΈ ntdll32.dll batay sa mga halaga ng hash mula sa kanilang mga pangalan at iniksyon ang huling payload sa memorya ng proseso svchost.exegamit ang Process Hollowing technique (maaari kang magbasa ng higit pa tungkol dito Artikulo). Kapag nag-inject ng shellcode:

  • lumikha ng isang proseso svchost.exe sa isang suspendido na estado gamit ang function CreateProcessW;
  • pagkatapos ay itinago ang display ng seksyon sa address space ng proseso svchost.exe gamit ang function NtUnmapViewOfSection. Kaya, pinalaya ng programa ang memorya ng orihinal na proseso svchost.exeupang pagkatapos ay maglaan ng memorya para sa payload sa address na ito;
  • inilaan na memorya para sa payload sa puwang ng address ng proseso svchost.exe gamit ang function VirtualAllocEx;

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan
Pagsisimula ng proseso ng pag-iniksyon

  • isinulat ang mga nilalaman ng payload sa puwang ng address ng proseso svchost.exe gamit ang function WriteProcessMemory (tulad ng sa screenshot sa ibaba);
  • ipinagpatuloy ang proseso svchost.exe gamit ang function ResumeThread.

RATKing: bagong kampanya na may malayuang pag-access ng mga Trojan
Pagkumpleto ng proseso ng pag-iniksyon

Nada-download na malware

Bilang resulta ng mga inilarawang aksyon, isa sa ilang RAT-class na malware ang na-install sa nahawaang system. Inililista ng talahanayan sa ibaba ang malware na ginamit sa pag-atake, na maaari naming kumpiyansa na maiugnay sa isang pangkat ng mga umaatake, dahil na-access ng mga sample ang parehong command at control server.

Pangalan ng malware

Unang nakita

SHA-256

C&C

Ang proseso kung saan isinasagawa ang iniksyon

Darktrack

16-04-2020

ea64fe672c953adc19553ea3b9118ce4ee88a14d92fc7e75aa04972848472702

kimjoy007.dyndns[.]org:2017

svchost

Paralaks

24-04-2020

b4ecd8dbbceaadd482f1b23b712bcddc5464bccaac11fe78ea5fd0ba932a4043

kimjoy007.dyndns[.]org:2019

svchost

WAR ZONE

18-05-2020

3786324ce3f8c1ea3784e5389f84234f81828658b22b8a502b7d48866f5aa3d3

kimjoy007.dyndns[.]org:9933

svchost

Netwire

20-05-2020

6dac218f741b022f5cad3b5ee01dbda80693f7045b42a0c70335d8a729002f2d

kimjoy007.dyndns[.]org:2000

svchost

Mga halimbawa ng distributed malware na may parehong control server

Dalawang bagay ang kapansin-pansin dito.

Una, ang mismong katotohanan na ang mga umaatake ay gumamit ng maraming magkakaibang pamilya ng RAT nang sabay-sabay. Ang pag-uugali na ito ay hindi pangkaraniwan para sa mga kilalang cyber group, na kadalasang gumagamit ng humigit-kumulang sa parehong hanay ng mga tool na pamilyar sa kanila.

Pangalawa, gumamit ang RATKing ng malware na ibinebenta sa mga espesyal na forum sa mababang presyo, o kahit isang open source na proyekto.

Ang isang mas kumpletong listahan ng malware na ginamit sa campaignβ€”na may isang mahalagang caveatβ€”ay ibinibigay sa dulo ng artikulo.

Tungkol sa grupo

Hindi namin maaaring iugnay ang inilarawan na nakakahamak na kampanya sa sinumang kilalang umaatake. Sa ngayon, naniniwala kami na ang mga pag-atakeng ito ay isinagawa ng isang pangunahing bagong grupo. Tulad ng isinulat namin sa simula, tinawag namin itong RATKing.

Upang lumikha ng script ng VBS, malamang na gumamit ang grupo ng isang tool na katulad ng utility VBS-Crypter mula sa developer NYAN-x-CAT. Ito ay ipinahiwatig ng pagkakapareho ng script na nilikha ng program na ito sa script ng mga umaatake. Sa partikular, silang dalawa:

  • magsagawa ng naantalang pagpapatupad gamit ang function Sleep;
  • gumamit ng WMI;
  • irehistro ang katawan ng executable file bilang isang registry key parameter;
  • i-execute ang file na ito gamit ang PowerShell sa sarili nitong address space.

Para sa kalinawan, ihambing ang PowerShell command upang magpatakbo ng isang file mula sa registry, na ginagamit ng isang script na ginawa gamit ang VBS-Crypter:

((Get-ItemPropertyHKCU:SoftwareNYANxCAT).NYANxCAT);$text=-join$text[-1..-$text.Length];[AppDomain]::CurrentDomain.Load([Convert]::FromBase64String($text)).EntryPoint.Invoke($Null,$Null);

na may katulad na utos na ginamit ng script ng mga attackers:

[System.Threading.Thread]::GetDomain().Load((ItemProperty HKCU:///Software///<rnd_sub_key_name> ).<rnd_value_name>);
[GUyyvmzVhebFCw]::EhwwK('WScript.ScriptFullName', 'rWZlgEtiZr', 'WScript.ScriptName'),0

Tandaan na ang mga umaatake ay gumamit ng isa pang utility mula sa NYAN-x-CAT bilang isa sa mga payload - LimeRAT.

Ang mga address ng mga server ng C&C ay nagpapahiwatig ng isa pang natatanging tampok ng RATKing: mas gusto ng grupo ang mga dynamic na serbisyo ng DNS (tingnan ang listahan ng mga C&C sa talahanayan ng IoC).

IoC

Ang talahanayan sa ibaba ay nagbibigay ng kumpletong listahan ng mga script ng VBS na malamang na maiugnay sa inilarawang kampanya. Ang lahat ng mga script na ito ay magkatulad at gumaganap ng humigit-kumulang sa parehong pagkakasunud-sunod ng mga aksyon. Lahat sila ay nag-inject ng RAT class na malware sa isang pinagkakatiwalaang proseso ng Windows. Lahat sila ay may mga C&C address na nakarehistro gamit ang mga serbisyo ng Dynamic DNS.

Gayunpaman, hindi namin masasabi na ang lahat ng mga script na ito ay ipinamahagi ng parehong mga umaatake, maliban sa mga sample na may parehong mga C&C address (halimbawa, kimjoy007.dyndns.org).

Pangalan ng malware

SHA-256

C&C

Ang proseso kung saan isinasagawa ang iniksyon

Paralaks

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 DAGA

d410ced15c848825dcf75d30808cde7784e5b208f9a57b0896e828f890faea0e

anekesolution.linkpc.net

RegAsm

dayap

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

Pinagmulan: www.habr.com

Magdagdag ng komento