2014-09-14 - Study
Say Hello to Astrum EK
|  | 
| Artist’s impression shows the structure of the Milky Way NASA/JPL-Caltech/ESO/R. Hurt | 
I was chasing something else (the Kovter adfraud's Sweet Orange thread - Kovter is not a ransomware anymore (since at least march 2014)) when I received bullets from an undocumented "weapon" : an exploit kit that seems to be private (for now?) and based on the infection path (between an Adxpansion badvert on a porn website and the https goo.gl link to the landing ) in use by a group that was traffing to Reveton team's EK threads (so via Cool then Angler EK) :
Say Hello to Astrum EK
|  | 
| Astrum EK 2014-09-06 - Real Name (not chosen) (Fast looking at the URI pattern we may find it a little Angler-ish...but it's not) | 
Astrum will accept to serve a landing only once per IP and is also denying connection from Tor and (at least) Russia.
The lifetime of the landing seems a little higher than on Angler or Nuclear Pack but where most of the time you need to fake some referer to avoid being rejected, with Astrum : show a referer and you'll get ignored and IP banned. Firefox, Chrome and Opera are also ignored (and i guess that they are filtered out upstream anyway).
A fast search lets think it's in use since at least 2014-08-15
A fast search lets think it's in use since at least 2014-08-15
Now let's take a look at the bullets and the ballistic.
CVE-2014-0515 - CVE-2013-0634 (Flash) :
Those days it's the most successful vuln targeted in exploit kits, followed by CVE-2013-2551.
|  | 
| CVE-2014-0515 successful path in Astrum EK 2014-09-06 | 
GET http://static.yarkiy-mir .org/duf5ibqshp.html
200 OK (text/html)
|  | 
| Piece of Astrum's Landing 2014-09-06 http://pastebin.com/Jc5k0kvi JsBeautified : http://pastebin.com/gvjskkG2 | 
Obfuscation in used as described by EKWatcher
An array of modifed-Base64 strings, that are each XORed with a different byte and then inserted (in random order) into the JS later - The Base64 is using "A-Za-z0-9-:" instead of "A-Za-z0-9+/"
After deobfuscating the "div" value via the function t (using malzilla for instance) we get this :
An array of modifed-Base64 strings, that are each XORed with a different byte and then inserted (in random order) into the JS later - The Base64 is using "A-Za-z0-9-:" instead of "A-Za-z0-9+/"
After deobfuscating the "div" value via the function t (using malzilla for instance) we get this :
There are sweet piece of code like those showing they had researcher/bots etc in mind while writing it :
|  | 
| On landing load, script will try to catch debugging tools (even phantom....) | 
|  | 
| and also check via loadXML if there are obvious researcher tools launched or if it's running in a VM. | 
|  | 
| check for Kaspersky BHO | 
And here is the data that will be posted  :
|  | 
| Fast sum-up of the data that will be encoded and posted in next call. Comment are obviously not in the original code | 
POST  http://static.yarkiy-mir .org/IVmTAccT_rdKYvlrrCSb3UJl-G-gc5uJSzOmaP8jldlPMKNo_iuSh1J_qjr5Ot7fTg..
200 OK (text/html)  CVE-2013-2551  and creation of the flash object.
Posted data (as Neutrino was doing) :
|  | 
| Astrum - 2014-09-06 Piece of the Post Call reply. | 
The obfuscation in use is the same as in the landing.
Once decoded here is the Flash insertion :
|  | 
| Astrum - Inserting the flash element. http://pastebin.com/GYehkmaC | 
GET http://static.yarkiy-mir .org/kZThMKU15rv6r4tazgKD0fKoil7CVYOF-_7UWZ0FjdX__dFZnA2Ki-Ky2AWYHMbT_g..
200 OK (application/x-shockwave-flash)  3fb2c3750d51268781fa608a42c3e4d7 CVE-2014-0515 & CVE-2013-0634 (Thanks to Arseny Levin (Spiderlabs) for the help)
GET http://static.yarkiy-mir .org/CjJXSImjvethCT0i4pTYgWkOPCbuw9jVYFhiIbGT1oVkW2chsJvR23kUbn27ip2DZQ..
200 OK (application/octet-stream) Once Decoded: 9d9eb3ceffd6596ebdf7fc9387cd5cb1 - Reveton
|  | 
| Xored Payload. Key : 98EB68248A2815474CFE8902C0603770 | 
|  | 
| Astrum EK -  2014-09-06 Silverlight Successful path | 
GET http://asset.yur88 .com/xawufyinv3lqr.html
200 OK (text/html)
|  | 
| To give an idea of the data being sent to the Exploit Kit on the following post request. (md5 is different) | 
POST http://asset.yur88 .com/xcC2oZh5Lpbyq4bPox1Hq_uv3M-oGkXzoa_Vy_IaEvr4_IyZokFE_Lbmj5qmUA7-qg..
200 OK (text/html)
The silverlight call, once decoded :
|  | 
| Astrum - 2014-09-06 Piece of the Post Call reply launching Silverligt and CVE-2013-2551 attack | 
|  | 
| Astrum : Post reply silverlight call once decoded 2014-09-06 http://pastebin.com/enPjFN96 | 
GET http://asset.yur88 .com/06RCA_viDC7kz3JtwIZlE-3LKG3LgWdLt8shaZGBMELumHg7wdpmRKCCeD_AyyxGvA..
200 OK (application/x-silverlight-app) 3b82c622a343317d14161206aa9f2fce
|  | 
| Silverlight Exploit | 
sl.dll : e332a8d62288b80f939fff7d50ac33d3
GET http://asset.yur88 .com/sKJTobP38yWHyWPPiJOaGI7NOc-DlJhA1M0wy9mUz0mNnmmZic-ZT8OEaZ2L3tNN3w..
200 OK (application/octet-stream)  9d9eb3ceffd6596ebdf7fc9387cd5cb1 Reveton again
Xor key : BFAD0475157E8E15F72903B5E80649B2
Xor key : BFAD0475157E8E15F72903B5E80649B2
CVE-2013-2551 :
|  | 
| CVE-2013-2551 successfully fired by Astrum EK 2014-09-11 | 
GET http://img.gestionartepyme .com.ar/omhq1t4pjx3fac.html
200 OK (text/html)
POST http://img.gestionartepyme .com.ar/C1BzyerkwKg1aE_30oT_kDU9S6TYgfyXZj0SqIGFqsUzbEzzgNv8w3h2SvLUzeDAZA..
200 OK (text/html)
After a first pass of decoding :
|  | 
| Piece of CVE-2013-2551 after first decoding pass. http://pastebin.com/g847kaSX | 
GET http://img.gestionartepyme .com.ar/Wi-S--HJ20lkF67F2ankcWRCqpbTrOd2N0LzmoqosSRiE63Bi_bnIikJq87f4PshNQ..
200 OK (application/octet-stream) a668806b4be0e3b02e3adf0130b70bd0 once decoded (reveton)
Xor Key: 3FF52A9A6B4C3E3DE93AD7183C0DFFA6
|  | 
| Payload written in %temp%\tmp1.log | 
If lock screen is activated you'll get for instance in the us :
|  | 
| Reveton - Screen locked - 2014-09-11 US. | 
CVE-2014-0322 :
I'll update if i get a successful pass.
GET http://img.gestionartepyme .com.ar/zy6qjw78b3f4vus.html
200 OK (text/html)
POST http://img.gestionartepyme .com.ar/Nly0S9lDj4daNYQm6nfh71U1jCjjc-buCzLSc-Uht-8IbI935Hm07UV6jXDnaq_vWQ..
200 OK (text/html)
I won't put the decoded one ;)
CVE-2010-0188 :
GET http://assets.dance .com.ar/oljm3dz7pnh.html
200 OK (text/html)
| For some reason I couldn't get that one working properly.  | 
| CVE-2014-0322 fired by Astrum But unsuccessful. | 
GET http://img.gestionartepyme .com.ar/zy6qjw78b3f4vus.html
200 OK (text/html)
|  | 
| Posted data after the landing, whispering the server to try CVE-2014-0322 - (md5 is different) | 
POST http://img.gestionartepyme .com.ar/Nly0S9lDj4daNYQm6nfh71U1jCjjc-buCzLSc-Uht-8IbI935Hm07UV6jXDnaq_vWQ..
200 OK (text/html)
|  | 
| Obfuscated piece of code to trigger CVE-2014-0322 Astrum 2014-09-11 | 
|  | 
| Piece of the B64 encoded shellcode | 
CVE-2010-0188 :
|  | 
| Astrum firing CVE-2010-0188 (and Flash exploit also) 2014-09-11 | 
GET http://assets.dance .com.ar/oljm3dz7pnh.html
200 OK (text/html)
|  | 
| Decoded posted data | 
POST http://assets.dance .com.ar/ZQc75hcLl-kOZATbKD-u1VpjA4kiO6-GDjgG2itsr4ZcOgeMKzOohBYhAt0pIreBCg..
200 OK (text/html)
200 OK (text/html)
|  | 
| Encoded part of the Post reply in charge of the call for CVE-2010-0188 Astrum - 2014-09-11 | 
Once decoded :
|  | 
| Iframe called for CVE-2010-0188 | 
GET http://assets.dance .com.ar/FCNKh1wkpvl_QHW6YxCfxStHcuhpFJ6Wfxx3u2BDnpYtHnbtYByZlGcFcLtiDYaRew..
200 OK (text/html)
|  | 
| Obfuscated : creation of the PDF object | 
|  | 
| Deobfuscated call for PDF | 
GET http://assets.dance .com.ar/4RkrZSI07MGKehRYHQDV_d59EwoXBNSuiiYWWR5T1K7YJBcPHgzTrJI_ElAfHcypjg..200 OK (application/x-shockwave-flash) (CVE-2013-0634/2014-0515)
GET http://assets.dance .com.ar/DQT9jPZKYcJmZ8KxyX5Y_jJgxePDelmtZjvAsMotWa00OcHmynJer34ix7DJY0GqYg..
200 OK (application/pdf) CVE-2010-0188 a3aa7a4499e7b89768ee82ea5c3c8b4a
We have the same kind of obfuscation here that in the landing and post response.
|  | 
| Object in the PDF containing the Encoded data | 
|  | 
| Piece of js in charge of deobuscating and triggering the exploit | 
GET http://assets.dance .com.ar/jnK3hV3Yt6HlEYi4YuyOnbEWj-po6I_O5U2KuWG_j863T4vvYeCIzP1UjrBv8ZfJ4Q..
200 OK (application/octet-stream)
GET http://assets.dance .com.ar/DqVkvx0HOxZlxluCIjMCKjHBXNAoNwN5ZZpZgyFgA3k3mFjVIT8Ee32DXoMhLht-YQ..
200 OK (application/octet-stream) Decoded : 154a5d50ee032dc32e4c64ecbde0eaa1 Reveton
Note that both payload (flash and PDF) in that pass have same Xor key ( 919DCE47A3DBD2518B2F1088604AE0DA )
No Java ?
This exploit kit had some java few weeks ago (CVE-2012-0507, CVE-2013-2460, CVE-2013-2465 - if you make a search on this IP in your log you might figure it ) but it seems java is not exploited anymore.
As I assumed for Flash EK, it's a trade of a now small percentage of infection for more stealth ( >> infection chain last longer >> less rebuild).
The exploitation Graph should be something like :
|  | 
| Astrum EK - Exploitation graph assumption 2014-09-14 | 
Files :
AstrumEK_2014-09-14.zip (Owncloud) 
PS: If you have some telemetry on this IP : 107.150.24.107 I would be really interested in the numbers. Seeing the infection path, I think traffic should be quite big.
		 
			