RATKing: fushatë e re me Trojans me qasje në distancë

Në fund të majit, ne zbuluam një fushatë për shpërndarjen e malware të Trojanit me qasje në distancë (RAT) - programe që lejojnë sulmuesit të kontrollojnë nga distanca një sistem të infektuar.

Grupi që ne ekzaminuam u dallua nga fakti se nuk zgjodhi asnjë familje specifike RAT për infeksion. Disa trojanë u vunë re në sulmet brenda fushatës (të gjithë ishin gjerësisht të disponueshëm). Me këtë veçori, grupi na kujtoi mbretin e minjve - një kafshë mitike që përbëhet nga brejtës me bishta të ndërthurur.

RATKing: fushatë e re me Trojans me qasje në distancë
Origjinali është marrë nga monografia e K. N. Rossikov "Minjtë dhe brejtësit e ngjashëm me miun, më të rëndësishmit ekonomikisht" (1908)

Për nder të kësaj krijese, ne e emërtuam grupin që po konsiderojmë RATKing. Në këtë postim, ne do të shkojmë në detaje se si sulmuesit e kryen sulmin, çfarë mjetesh përdorën dhe gjithashtu do të ndajmë mendimet tona për atribuimin për këtë fushatë.

Ecuria e sulmit

Të gjitha sulmet në këtë fushatë u zhvilluan sipas algoritmit të mëposhtëm:

  1. Përdoruesi mori një email phishing me një lidhje në Google Drive.
  2. Duke përdorur lidhjen, viktima shkarkoi një skrip me qëllim të keq VBS që specifikonte një bibliotekë DLL për të ngarkuar ngarkesën përfundimtare në regjistrin e Windows dhe nisi PowerShell për ta ekzekutuar atë.
  3. Biblioteka DLL injektoi ngarkesën përfundimtare - në fakt, një nga RAT-të e përdorur nga sulmuesit - në procesin e sistemit dhe regjistroi një skript VBS në autorun në mënyrë që të fitonte një terren në makinën e infektuar.
  4. Ngarkesa përfundimtare u ekzekutua në një proces sistemi dhe i dha sulmuesit mundësinë për të kontrolluar kompjuterin e infektuar.

Skematikisht mund të paraqitet si kjo:

RATKing: fushatë e re me Trojans me qasje në distancë

Më pas, ne do të përqendrohemi në tre fazat e para, pasi jemi të interesuar për mekanizmin e shpërndarjes së malware. Ne nuk do të përshkruajmë në detaje mekanizmin e funksionimit të vetë malware. Ato janë gjerësisht të disponueshme - ose shiten në forume të specializuara, ose shpërndahen edhe si projekte me burim të hapur - dhe për këtë arsye nuk janë unike për grupin RATKing.

Analiza e fazave të sulmit

Faza 1. Email phishing

Sulmi filloi me marrjen e një letre keqdashëse nga viktima (sulmuesit përdorën shabllone të ndryshëm me tekst; pamja e ekranit më poshtë tregon një shembull). Mesazhi përmbante një lidhje me një depo legjitime drive.google.com, e cila supozohet se çoi në një faqe të shkarkimit të dokumentit PDF.

RATKing: fushatë e re me Trojans me qasje në distancë
Shembull phishing email

Sidoqoftë, në fakt, nuk ishte një dokument PDF që u ngarkua fare, por një skenar VBS.

Kur klikoni në lidhjen nga emaili në pamjen e mësipërme, një skedar me emrin Cargo Flight Details.vbs. Në këtë rast, sulmuesit as nuk u përpoqën ta maskonin dosjen si një dokument legjitim.

Në të njëjtën kohë, si pjesë e kësaj fushate, ne zbuluam një skenar të quajtur Cargo Trip Detail.pdf.vbs. Ai tashmë mund të kalojë për një PDF të ligjshëm sepse Windows fsheh shtesat e skedarëve si parazgjedhje. Vërtetë, në këtë rast, dyshimi mund të ngjallte ende nga ikona e tij, e cila korrespondonte me skenarin VBS.

Në këtë fazë, viktima mund ta njohë mashtrimin: thjesht hidhini një vështrim më të afërt skedarëve të shkarkuar për një sekondë. Megjithatë, në fushata të tilla phishing, sulmuesit shpesh mbështeten te një përdorues i pavëmendshëm ose i nxituar.

Faza 2. Operacioni i skriptit VBS

Skripti VBS, të cilin përdoruesi mund ta hapte pa dashje, regjistroi një bibliotekë DLL në regjistrin e Windows. Skenari ishte i turbullt: rreshtat në të ishin shkruar si bajt të ndara nga një karakter arbitrar.

RATKing: fushatë e re me Trojans me qasje në distancë
Shembull i një skenari të turbullt

Algoritmi i deobfuzimit është mjaft i thjeshtë: çdo karakter i tretë u përjashtua nga vargu i errësuar, pas së cilës rezultati u deshifrua nga baza16 në vargun origjinal. Për shembull, nga vlera 57Q53s63t72s69J70r74e2El53v68m65j6CH6Ct (e theksuar në pamjen e mësipërme) vija që rezulton ishte WScript.Shell.

Për të zbërthyer vargjet, ne përdorëm funksionin Python:

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

Më poshtë, në rreshtat 9–10, ne theksojmë vlerën deobfuscimi i së cilës rezultoi në një skedar DLL. Ishte ai që u nis në fazën tjetër duke përdorur PowerShell.

RATKing: fushatë e re me Trojans me qasje në distancë
Varg me DLL të turbullt

Secili funksion në skriptin VBS u ekzekutua pasi vargjet u deobfuscate.

Pas ekzekutimit të skriptit, funksioni u thirr wscript.sleep - është përdorur për të kryer ekzekutimin e shtyrë.

Më pas, skripti funksionoi me regjistrin e Windows. Ai përdori teknologjinë WMI për këtë. Me ndihmën e tij, u krijua një çelës unik dhe trupi i skedarit të ekzekutueshëm u shkrua në parametrin e tij. Regjistri u aksesua përmes WMI duke përdorur komandën e mëposhtme:

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

RATKing: fushatë e re me Trojans me qasje në distancë
Një hyrje e bërë në regjistër nga një skript VBS

Faza 3. Funksionimi i bibliotekës DLL

Në fazën e tretë, DLL-ja me qëllim të keq ngarkoi ngarkesën përfundimtare, e injektoi atë në procesin e sistemit dhe siguroi që skripti VBS të fillonte automatikisht kur përdoruesi hynte.

Ekzekutoni përmes PowerShell

DLL u ekzekutua duke përdorur komandën e mëposhtme në PowerShell:

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

Kjo komandë bëri si më poshtë:

  • mori të dhënat e vlerës së regjistrit me emër rnd_value_name — këto të dhëna ishin një skedar DLL i shkruar në platformën .Net;
  • ngarkoi modulin .Net që rezulton në memorien e procesit powershell.exe duke përdorur funksionin [System.Threading.Thread]::GetDomain().Load() (përshkrim i detajuar i funksionit Load(). në dispozicion në faqen e internetit të Microsoft);
  • kryer funksionin GUyyvmzVhebFCw]::EhwwK() - ekzekutimi i bibliotekës DLL filloi me të - me parametra vbsScriptPath, xorKey, vbsScriptName... Parametri xorKey ruajti çelësin për deshifrimin e ngarkesës përfundimtare dhe parametrat vbsScriptPath и vbsScriptName u transferuan për të regjistruar një skript VBS në autorun.

Përshkrimi i bibliotekës DLL

Në formë të dekompiluar, bootloader dukej kështu:

RATKing: fushatë e re me Trojans me qasje në distancë
Ngarkues në formë të dekompiluar (funksioni me të cilin filloi ekzekutimi i bibliotekës DLL është nënvizuar me të kuqe)

Bootloader mbrohet nga mbrojtësi .Net Reactor. Shërbimi de4dot bën një punë të shkëlqyer për heqjen e këtij mbrojtësi.

Ky ngarkues:

  • injektoi ngarkesën në procesin e sistemit (në këtë shembull ai svchost.exe);
  • Shtova një skript VBS në autorun.

Injeksioni i ngarkesës

Le të shohim funksionin që thirri skripti PowerShell.

RATKing: fushatë e re me Trojans me qasje në distancë
Funksioni i thirrur nga skripti PowerShell

Ky funksion kryente veprimet e mëposhtme:

  • deshifroi dy grupe të dhënash (array и array2 në pamjen e ekranit). Ato fillimisht u kompresuan duke përdorur gzip dhe u koduan me algoritmin XOR me çelës xorKey;
  • të dhënat e kopjuara në zonat e alokuara të memories. Të dhënat nga array - në zonën e kujtesës ku tregohet intPtr (payload pointer në pamjen e ekranit); të dhëna nga array2 - në zonën e kujtesës ku tregohet intPtr2 (shellcode pointer në pamjen e ekranit);
  • quhet funksioni CallWindowProcA (описание Ky funksion është i disponueshëm në faqen e internetit të Microsoft) me parametrat e mëposhtëm (emrat e parametrave janë renditur më poshtë, në pamjen e ekranit ato janë në të njëjtin rend, por me vlera pune):
    • lpPrevWndFunc - tregues për të dhënat nga array2;
    • hWnd — treguesi i një vargu që përmban shtegun për në skedarin e ekzekutueshëm svchost.exe;
    • Msg - tregues për të dhënat nga array;
    • wParamlParam - parametrat e mesazhit (në këtë rast, këto parametra nuk u përdorën dhe kishin vlera 0);
  • krijoi një skedar %AppData%MicrosoftWindowsStart MenuProgramsStartup<name>.urlKu <name> - këto janë 4 karakteret e para të parametrit vbsScriptName (në pamjen e ekranit, fragmenti i kodit me këtë veprim fillon me komandën File.Copy). Në këtë mënyrë, malware shtoi një skedar URL në listën e skedarëve autorun kur përdoruesi u identifikua dhe kështu u lidh me kompjuterin e infektuar. Skedari URL përmbante një lidhje me skriptin:

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

Për të kuptuar se si u krye injektimi, ne deshifruam grupet e të dhënave array и array2. Për ta bërë këtë, ne përdorëm funksionin e mëposhtëm Python:

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

Si rezultat, ne zbuluam se:

  • array ishte një skedar PE - kjo është ngarkesa përfundimtare;
  • array2 ishte shellkodi i kërkuar për të kryer injeksionin.

Shellcode nga një grup array2 kalohet si vlerë funksioni lpPrevWndFunc në një funksion CallWindowProcA. lpPrevWndFunc — funksioni i kthimit të thirrjes, prototipi i tij duket si ky:

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

Pra, kur ekzekutoni funksionin CallWindowProcA me parametra hWnd, Msg, wParam, lParam shellcode nga grupi është ekzekutuar array2 me argumente hWnd и Msg. hWnd është një tregues në një varg që përmban shtegun për në skedarin e ekzekutueshëm svchost.exeDhe Msg - treguesi për ngarkesën përfundimtare.

Shellcode mori adresat e funksionit nga kernel32.dll и ntdll32.dll bazuar në vlerat hash nga emrat e tyre dhe injektuan ngarkesën përfundimtare në kujtesën e procesit svchost.exeduke përdorur teknikën Process Hollowing (mund të lexoni më shumë rreth saj në këtë artikull). Kur injektoni kodin shell:

  • krijoi një proces svchost.exe në gjendje të pezulluar duke përdorur funksionin CreateProcessW;
  • pastaj fshehu shfaqjen e seksionit në hapësirën e adresave të procesit svchost.exe duke përdorur funksionin NtUnmapViewOfSection. Kështu, programi çliroi kujtesën e procesit origjinal svchost.exepër të ndarë më pas memorien për ngarkesën në këtë adresë;
  • memoria e alokuar për ngarkesën në hapësirën e adresave të procesit svchost.exe duke përdorur funksionin VirtualAllocEx;

RATKing: fushatë e re me Trojans me qasje në distancë
Fillimi i procesit të injektimit

  • shkruajti përmbajtjen e ngarkesës në hapësirën e adresave të procesit svchost.exe duke përdorur funksionin WriteProcessMemory (si në pamjen e mëposhtme të ekranit);
  • rifilloi procesin svchost.exe duke përdorur funksionin ResumeThread.

RATKing: fushatë e re me Trojans me qasje në distancë
Përfundimi i procesit të injektimit

Malware i shkarkueshëm

Si rezultat i veprimeve të përshkruara, një nga disa malware të klasës RAT u instalua në sistemin e infektuar. Tabela e mëposhtme liston malware-in e përdorur në sulm, të cilin mund t'ia atribuojmë me siguri një grupi sulmuesish, pasi mostrat kishin akses në të njëjtin server komandimi dhe kontrolli.

Emri i malware

Parë për herë të parë

SHA-256

C&C

Procesi në të cilin kryhet injeksioni

Darktrack

16-04-2020

ea64fe672c953adc19553ea3b9118ce4ee88a14d92fc7e75aa04972848472702

kimjoy007.dyndns[.]org:2017

svchost

paralaks

24-04-2020

b4ecd8dbbceaadd482f1b23b712bcddc5464bccaac11fe78ea5fd0ba932a4043

kimjoy007.dyndns[.]org:2019

svchost

ZONE LUFTE

18-05-2020

3786324ce3f8c1ea3784e5389f84234f81828658b22b8a502b7d48866f5aa3d3

kimjoy007.dyndns[.]org:9933

svchost

Rrjeti

20-05-2020

6dac218f741b022f5cad3b5ee01dbda80693f7045b42a0c70335d8a729002f2d

kimjoy007.dyndns[.]org:2000

svchost

Shembuj të malware të shpërndarë me të njëjtin server kontrolli

Dy gjëra janë të rëndësishme këtu.

Së pari, vetë fakti që sulmuesit përdorën disa familje të ndryshme RAT menjëherë. Kjo sjellje nuk është tipike për grupet e njohura kibernetike, të cilat shpesh përdorin afërsisht të njëjtin grup mjetesh që janë të njohura për ta.

Së dyti, RATKing përdori malware që ose shitet në forume të specializuara për një çmim të ulët, ose është edhe një projekt me burim të hapur.

Një listë më e plotë e malware të përdorur në fushatë - me një paralajmërim të rëndësishëm - jepet në fund të artikullit.

Rreth grupit

Ne nuk mund t'ia atribuojmë fushatën e përshkruar keqdashëse ndonjë sulmuesi të njohur. Tani për tani, ne besojmë se këto sulme janë kryer nga një grup thelbësisht i ri. Siç kemi shkruar në fillim, e quajtëm RATKing.

Për të krijuar skriptin VBS, grupi ndoshta ka përdorur një mjet të ngjashëm me programin VBS-Crypter nga zhvilluesi NYAN-x-CAT. Kjo tregohet nga ngjashmëria e skriptit që krijon ky program me skenarin e sulmuesve. Konkretisht, ata të dy:

  • kryeni ekzekutim të vonuar duke përdorur funksionin Sleep;
  • përdorni WMI;
  • regjistroni trupin e skedarit të ekzekutueshëm si një parametër kyç të regjistrit;
  • ekzekutoni këtë skedar duke përdorur PowerShell në hapësirën e tij të adresave.

Për qartësi, krahasoni komandën PowerShell për të ekzekutuar një skedar nga regjistri, i cili përdoret nga një skript i krijuar duke përdorur VBS-Crypter:

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

me një komandë të ngjashme që përdori skripti i sulmuesve:

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

Vini re se sulmuesit përdorën një mjet tjetër nga NYAN-x-CAT si një nga ngarkesat - LimeRAT.

Adresat e serverëve C&C tregojnë një veçori tjetër dalluese të RATKing: grupi preferon shërbimet dinamike DNS (shih listën e C&C në tabelën IoC).

IoC

Tabela më poshtë ofron një listë të plotë të skripteve VBS që ka shumë të ngjarë t'i atribuohen fushatës së përshkruar. Të gjitha këto skripta janë të ngjashëm dhe kryejnë afërsisht të njëjtën sekuencë veprimesh. Të gjithë ata injektojnë malware të klasës RAT në një proces të besuar të Windows. Të gjithë ata kanë adresa C&C të regjistruara duke përdorur shërbimet Dynamic DNS.

Megjithatë, ne nuk mund të pretendojmë se të gjithë këta skripta janë shpërndarë nga të njëjtët sulmues, me përjashtim të mostrave me të njëjtat adresa C&C (për shembull, kimjoy007.dyndns.org).

Emri i malware

SHA-256

C&C

Procesi në të cilin kryhet injeksioni

paralaks

b4ecd8dbbceaadd482f1b23b712bcddc5464bccaac11fe78ea5fd0ba932a4043

kimjoy007.dyndns.org

svchost

00edb8200dfeee3bdd0086c5e8e07c6056d322df913679a9f22a2b00b836fd72

shpresoj.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

shpresoj.doomdns.org

svchost

c9745a8f33b3841fe7bfafd21ad4678d46fe6ea6125a8fedfcd2d5aee13f1601

kimjoy007.dyndns.org

svchost

1dfc66968527fbd4c0df2ea34c577a7ce7a2ba9b54ba00be62120cc88035fa65

franco20.dvrdns.org

svchost

c6c05f21e16e488eed3001d0d9dd9c49366779559ad77fcd233de15b1773c981

kimjoy007.dyndns.org

cmd

3b785cdcd69a96902ee62499c25138a70e81f14b6b989a2f81d82239a19a3aed

shpresoj.doomdns.org

svchost

4d71ceb9d6c53ac356c0f5bdfd1a5b28981061be87e38e077ee3a419e4c476f9

2004para.ddns.net

svchost

00185cc085f284ece264e3263c7771073a65783c250c5fd9afc7a85ed94acc77

shpresoj.doomdns.org

svchost

0342107c0d2a069100e87ef5415e90fd86b1b1b1c975d0eb04ab1489e198fc78

franco20.dvrdns.org

svchost

de33b7a7b059599dc62337f92ceba644ac7b09f60d06324ecf6177fff06b8d10

kimjoy007.dyndns.org

svchost

80a8114d63606e225e620c64ad8e28c9996caaa9a9e87dd602c8f920c2197007

kimjoy007.dyndns.org

svchost

acb157ba5a48631e1f9f269e6282f042666098614b66129224d213e27c1149bb

shpresoj.doomdns.org

cmd

bf608318018dc10016b438f851aab719ea0abe6afc166c8aea6b04f2320896d3

franco20.dvrdns.org

svchost

4d0c9b8ad097d35b447d715a815c67ff3d78638b305776cde4d90bfdcb368e38

shpresoj.doomdns.org

svchost

e7c676f5be41d49296454cd6e4280d89e37f506d84d57b22f0be0d87625568ba

kimjoy007.dyndns.org

svchost

9375d54fcda9c7d65f861dfda698e25710fda75b5ebfc7a238599f4b0d34205f

franco20.dvrdns.org

svchost

128367797fdf3c952831c2472f7a308f345ca04aa67b3f82b945cfea2ae11ce5

kimjoy007.dyndns.org

svchost

09bd720880461cb6e996046c7d6a1c937aa1c99bd19582a562053782600da79d

shpresoj.doomdns.org

svchost

0a176164d2e1d5e2288881cc2e2d88800801001d03caedd524db365513e11276

paradickhead.homeip.net

svchost

0af5194950187fd7cbd75b1b39aab6e1e78dae7c216d08512755849c6a0d1cbe

shpresoj.doomdns.org

svchost

Warzone

3786324ce3f8c1ea3784e5389f84234f81828658b22b8a502b7d48866f5aa3d3

kimjoy007.dyndns.org

svchost

db0d5a67a0ced6b2de3ee7d7fc845a34b9d6ca608e5fead7f16c9a640fa659eb

kimjoy007.dyndns.org

svchost

Rrjeti

6dac218f741b022f5cad3b5ee01dbda80693f7045b42a0c70335d8a729002f2d

kimjoy007.dyndns.org

svchost

Darktrack

ea64fe672c953adc19553ea3b9118ce4ee88a14d92fc7e75aa04972848472702

kimjoy007.dyndns.org

svchost

RAT WSH

d410ced15c848825dcf75d30808cde7784e5b208f9a57b0896e828f890faea0e

anekesolution.linkpc.net

RegAsm

gëlqere

896604d27d88c75a475b28e88e54104e66f480bcab89cc75b6cdc6b29f8e438b

softmy.duckdns.org

RegAsm

KuasarRAT

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

Burimi: www.habr.com

Shto një koment