Tuesday, October 1, 2013

Sweet Orange In Action







This content has moved to http://oalabs.openanalysis.net/2013/10/01/sweet-orange-exploit-kit-2013/














In this write up we will examine an operational Sweet Orange Exploit Kit. The focus will be on the exploits delivered and the behaviour of the exploit kit.


The Drive-By

The Sweet Orange kit that we will be examining was using an iframe injected into a compromised website to load the exploit landing page. We can see that the iframe has clearly been injected as it sits above the <!DOCTYPE> tag.


The Exploit Kit Landing Page

The iframe loads the exploit kit landing page which contains some fairly simple obfuscated javascript and a Java applet. The landing page doesn't use any browser/plugin profiling to tailor it's exploits, but the server does use the user agent string to filter out un-exploitable os/browser combinations. If the server deems you un-exploitable you get a nice 404 error (this may also be used to avoid detection).



Once we de-obfuscate the javascript we can see that it's written a Java JNLP applet tag to the document. The JNLP applet tag includes a BASE64 encoded JNLP file in the "value" parameter (see ref. here). There is also another applet on the page that does not use JNLP. This writeup will focus on the JNLP applet as it targets victims who are running Java 1.7 while the second applet targets Java 1.6.



Once we decode the BASE64 JNLP file we can see just what this exploit kit is up to. We can see the parameter "__applet_ssv_validated" has been set to "true" which is a Java security warning (Click2Play) bypass released on April 24, 2013 (see ref. here).


Inside the Exploit

With the Java security warning safely circumvented the exploit kit is free to run the applet. Let's take a closer look at the applet JAR file "CNOeJXH.jar". We can see there are a few classes in the JAR and a file called "wgSqXvtqE.mp4". Spoiler alert: we find out later that the mp4 file is just a cleverly obfuscated class file.



Let's start by decompiling the main class "piXDw.class" and go from there. Once we decompile the class files we can see that they are obfuscated. At first these look pretty difficult to decipher but upon closer inspection we can see there is just some junk code added (all of the Math.ulp assignments are junk) and there is some string manipulation. To illustrate I've included a snip of some obfuscated code before de-obfuscation.



After we de-obfuscate we can see the init() for the applet simply checks to see if the victim is running Java 1.7+ then calls a method "wnYoY(piXDw pixdw, Class aclass[])" from "GVep.class". Lets investigate further.



Taking a look at "GVep.class" we can see that it reads in the mp4 file, de-obfuscates it, then transformed it into a binary file and loads it. We will get to just what is inside the mp4 file in a minute but for now we have spotted the exploit that is being used: CVE-2013-2460.



Well this is interesting, let's take a look at the "wgSqXvtqE.mp4" file and see if we can't extract the class. At first we see we will need to de-obfuscate the ascii by removing "------------|||||||||||||||||||||||||||||||||||||".



And now we are left with what appears to be an ascii representation of the hex bytes of a class file.



We can use some python to quickly convert this into binary and decompile into it's original java.



Judging by the similarity of the exploit structure to other examples of "Sweet Orange" we can assume that this is some variation of the Sweet Orange exploit kit. An excellent writeup on the the kit can be found here

Now that we have confirm that this is indeed CVE-2013-2460 what happens after the security manager is disabled? We can see that there is one line of code after the security manger has been disabled, let's start there. 


If we work backwards we can see that "String as[]" contains the applet params.


Let's decrypt these parameters and see what we have (you can download a copy of my terrible python script here).

ParamDecrypted Value
qUsNfnlczho.sytes.net:9101/community.php?stats=606&html=88&fedora=12&click=72&smiles=1251&about=345&image=197&bugs=60&nomic=102
uqXtHmNErDCdJOya
BqJfPJdcounter


If we follow this example all the way through we can see that the malware constructs a url request like so in order to download the binary payload (the count.exe parameter number is randomly generated) . 
hxxp://fnlczho.sytes.net:9101/community.php?stats=606&html=88&fedora=12&click=72&smiles=1251&about=345&image=197&bugs=60&nomic=102&count.exe=


After some manual testing it was confirmed that the "count.exe" parameter is not required to obtain the payload. 

Review

Before we move on to behavioural analysis we will recap what we have learned so far:

Behaviour and Indicators

The exploit kit uses dynamic DNS provided by http://www.noip.com under the domain "sytes.net". The kit uses a subdomain generation algorithm to generate a new subdomain every few minutes. Old subdomains are unregistered making research a bit more difficult. After tracking the subdomain generation for 24h it is confirmed that all subdomains that have been used resolve to this IP: 95.163.121.17 (AS12695), not a big surprise. 


A list of identified domains can be found below.
abnzzkpp.sytes.net
abtkslxy.sytes.net
ajijaohoo.sytes.net
ancezvwzvn.sytes.net
azrrfxcab.sytes.net
bnfjqksp.sytes.net
bvakjbktwg.sytes.net
cicduvlypf.sytes.net
cuwfhkb.sytes.net
czjzgxg.sytes.net
dbvutls.sytes.net
ddrejyp.sytes.net
dhwyscid.sytes.net
dwnqxcr.sytes.net
ezuhsvc.sytes.net
ezxpqqc.sytes.net
fsjdwdf.sytes.net
fxgzbecpr.sytes.net
gdeabjxtg.sytes.net
gpapzplefw.sytes.net
gvriojhkty.sytes.net
japurgy.sytes.net
kigtvaq.sytes.net
kwawgdrd.sytes.net
leaudwpnlv.sytes.net
lvvfafoylf.sytes.net
lwswemzjb.sytes.net
mcaezkmyyo.sytes.net
mnzzgocsjh.sytes.net
mobohcw.sytes.net
mpuizserdk.sytes.net
ncgaxjoaz.sytes.net
negzmzouug.sytes.net
ntihkyn.sytes.net
nubeujdblv.sytes.net
nucmbbpifo.sytes.net
olkkqzuip.sytes.net
ozaiuos.sytes.net
pqcscnx.sytes.net
pspnknzz.sytes.net
qdgfvnxryg.sytes.net
qjwyhoespm.sytes.net
qxbsotcgr.sytes.net
rhbftfmol.sytes.net
rlbzvjrub.sytes.net
rpsooqswrs.sytes.net
sumghmrs.sytes.net
tvdgikytl.sytes.net
uilzzkhw.sytes.net
uprcfozkd.sytes.net
vjbflqu.sytes.net
wfdminj.sytes.net
wyoncpoxyv.sytes.net
xdnxnmxnlj.sytes.net
ysofjyh.sytes.net
zbmwqzja.sytes.net
zhlwvmonc.sytes.net
znctlzy.sytes.net


The url pattern for landing page:
http://[a-z]+\.sytes\.net:9101/[a-z\/\.]+[^\?]\?spamnav=82

The url pattern for the payload binary is:
http://[a-z]+\.sytes\.net:9101/[a-z\/\.0-9\=\?\&]+


The payload is also re-generated every few minutes. It is UPX packed and has a low VT hit rate (about 5/46 for each new generation). Once I have some more time I will take a closer look.

File MD5Virus Total
50e073712917e5cc1c53005dc377bdb0 virustotal
43aa3c348f64c9f5ae7001aa461790c1virustotal
884d0a05f5136db78d7e806a1f007e1fvirustotal

Zip of some payloads can be found here.

*Update*

Updated indicators and analysis can be found here.

2 comments:

  1. Wow Oranges are sweet but grapes are still sour atleast for users who have purchased antiviruses and live under false impressions..
    Good work. Keep it up...

    ReplyDelete
  2. Your malware analysis is fantastic. Have you considered writing IOC's in the Open IOC format and posting them to a website like iocbucket.com?

    ReplyDelete