Technical analysis and information sharing in the handling of high-profile targeted attacks Boldizsár Bencsáth Laboratory of Cryptography and System Security (CrySyS) Budapest University of Technology and Economics Department of Telecommunications this is joint work with Gábor Pék, Levente Buttyán, and Márk Félegyházi and the “Flame/sKyWIper” Team
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 2 Who are we CrySyS Lab, BME discovered Duqu, sibling of Stuxnet Our Lab participated in an international collaboration and published paper on “sKyWIper/Flame” malware Duqu team of 4 researchers We’ve been working solutions against targeted attacks since 1999 Duqu, Flame came as an opportunity and we seized it current work: results + expertise dependable security solution(s) to mitigate “Advanced (Persisent) Threat” attacks
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 3 Duqu Stuxnet and Duqu, sophisticated targeted attacks of recent times Stuxnet: self-replicating malware to harm Iran’s uranium enrichment centrifuges Duqu: information gathering Duqu is a malware that we discovered in the wild in an incident reponse investigation Naming: infostealer component creates files starting with the string “~DQ” Duqu = Stuxnet ? –striking similarity in terms of design philosophy, internal structure and mechanisms, implementation details, and the estimated amount of effort needed to create it Human dropper
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 4 Our main contributions Discovery, naming, and first analysis of Duqu –wrote the first 60-pages report – show the striking similarities with Stuxnet –shared our analysis with major anti-virus vendors and with Microsoft –an anonymized and shortened version of this report was published as an appendix of the first Symantec report on Duqu Identification of the dropper –MS word document with a 0-day Windows kernel exploit –made the dropper available to Symantec that sanitized and shared it with other anti-virus vendors and Microsoft Development and open-source distribution of a Duqu Detector Toolkit –based on heuristics, follows a different approach than signature based malware detection –detects live Duqu instances and remains of an earlier infection by Duqu –a real-life experiment resulting in much insight on the whole case Mediators of information sharing for efficient security response –delicate position – lot of trust needed –How and what to share? –Conflict of interest among parties –Successful sharing of the sample from a private company – privacy, anonymity concerns –Took the most time
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium sKyWIper/Flame In May/2012 we participated in an international collaboration to investigate a novel malware, we called it sKyWIper 27/05 – National CERT of IRAN (Maher) disclosed they are investigating a malware “Flamer” 28/05 – CrySyS released initial tech report on Flame/sKyWIper; Kasperksy released details about their work on “Flame”. We give no details what was exactly the collaboration, with whom we were working on and how -> potential personal risks to be avoided.
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Flame Flame is possibly the most complex malware ever We produced an initial detailed analysis of Flame with the help of others: We wrote some blog entries on insights of Flame (USB storage, GPL license violation of Duqu, WuSetupV.exe URL creation sKyWIper name is for ~KWI temporary files and the possible connection between “wiper” malware of Iran
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Stuxnet/Duqu vs. flame FeatureDuqu, Stuxnet, ~DsKyWIper Modular malware Kernel driver based rootkit fltmgr usage Valid digital signature on driverRealtek, JMicron, C-mediaNot found Injection based on A/V list Different Imports based on checksum Not seen 3 Config files, all encrypted, etc. Totally diferrent Keylogger module (Duqu) PLC functionality (Stuxnet)Not found (yet) Infection through local shares (Stuxnet) Very likely Exploits Some from Stuxnet! 0-day exploits Not yet found DLL injection to system processes (but different) DLL with modules as resources RPC communication ? RPC control in LAN ? RPC Based C&C ? Port 80/443, TLS based C&C SSL+SSH found Special “ magic ” keys, e.g , AE Only 0xAE is similar Virtual file based access to modules Not seen Usage of LZO libMod. LZONo LZO: Zlib, PPMd, bzip2 Visual C++ payload UPX compressed payload, some Careful error handling ? Deactivation timer Self-kill logic inside Initial Delay? SomeDifferent from Duqu Configurable starting in safe mode/dbg Not like Stuxnet
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium So what is Stuxnet/Duqu/Flame Duqu/Stuxnet are built on a common platform (also called it as “TildeD”) –Duqu is an info stealer created from the lego kit –Stuxnet is a sabotage tool created from a bit different pieces of the plaftorm Flame is developed by totally different way of thinking: Totally different team Flame compontent was found in Stuxnet/2009: independent teams, but cooperated some times
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium How to work with such malware? Clueless: You obtain information about strange things but you cannot decide how important it is. –It should be possible to guess the importance of such things. It needs general expertise. Flexibility: You decide to work on some unimportant/marginal topic, or an important one without funding. –You need an environment where it is possible to rearrange work at personal level, or in the group. Secrecy: You find something very important that cannot be told to others even inside the company –Again, a very flexible environment is needed to be able to keep secrets. You also need good friends to trust, inside and outside of the company.
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Skills needed Responsibility Reverse engineering Forensics: Pinpoint important in big data, use tools efficiently Knowing some about encryptions (but not cryptographer) Skill to understand complex systems and select next tiny part to focus on Programming (small scripts etc., but efficiency is not important) Flexibility to learn novel things (think Lua) Knowing how malware works (but knowing them all is not needed) Knowing networking technologies (including how to make MiTM for SSL connections, etc.) Knowing how Windows/Linux works (internals) Knowing some tools to work with to find clues Virtualization and sandboxing. Thinking like an attacker is thinking (tricks, etc.) Having friends and contacts
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 11 Duqu components found at CrySyS case Keylogger Registry data jminet7.sys (loader) jminet7.sys (loader) cmi4432.sys (loader) cmi4432.sys (loader) netp191.pnf (payload) netp191.pnf (payload) netp192.pnf (config) netp192.pnf (config) cmi4432.pnf (payload) cmi4432.pnf (payload) cmi4464.pnf (config) cmi4464.pnf (config) nep191_ res302.dll netp191.zdata. mz cmi4432_ res302.dll cmi4432_ (exe?) (comm module) internal DLL (keylogger)
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium OCX files mssecmgr.ocx 6M -resource 146 (2,5M) advnetcfg.ocx 0,6M msglu32.ocx 1,6M nteps32.ocx 0.8M soapr32.ocx 0,2M Local data files dstrlog.dat lmcache.dat mscrypt.dat ntcache.dat rccache.dat ssitable Temp data files ~HLV084.tmp 0,6k ~HLV294.tmp 0,2M ~KWI ~rf288.tmp Temp code files To691.tmp 1,5M sqlite Encrypted sqllite file list log, no reproduction at C Created during startup ccalc32.sys boot32drv.sys Zlib compr. Just the first round of modules of Flame
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium #Flame: list of affected files (partial) preg.exe ntcache.dat lmcache.dat rccache.dat dcomm.dat dmmsapi.dat ~dra52.tmp commgr32 target.lnk ccalc32.sys ~DEB13DE.tmp zff042 urpd.ocx Pcldrvx.ocx ~KWI guninst32 ~HLV ~DEB93D.tmp lib.ocx lss.ocx ~DEB83C.tmp stamn32 ~dra53.tmp nteps32 cmutlcfg.ocx ~DFL983.tmp ~DF05AC8.tmp ~DFD85D3.tmp ~a29.tmp dsmgr.ocx ~f28.tmp desc.ini fib32.bat ~d43a37b.tmp ~dfc855.tmp Ef_trace.log contents.btr wrm3f0 scrcons.exe Wavesup3.ocx Ntep32.ocx m4aaux.dat mpgaud.dat msaudio mspbee32 ~a49.tmp wpgfilter.dat Ssitable urpd.ocx lib.ocx lss.ocx target.lnk stamn32 guninst32
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Complexity vs. analysis Flame is just too complex to analyze within limited timeframe
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium WuSetupV structure of flame Took some weeks to get someone disclose details
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Duqu keylogger internal part No detailed analysis on some aspects, after half a yer
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Duqu – jminet7 driver structure Still some find out interesting things in the code
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Browse32 Flame Suicide module, Browse32 is 450k large High complexity: Why? – Known for weeks, detailed analysis: N/A
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Duqu/ Netp191 main module uncompressed Maybe just a bunch of libraries, but who no one can be sure
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Process of finding new malware vs. outsiders think about Outsiders think it’s “You found something, you analyze it, you share it” Reality: You obtain (receive/find) some sample – and you find it is a normal OS file You obtain other sample – and you find it’s a modified version of malware X You obtain a sample of an ultra-important malware – but it’s not a code, just an encrypted data file or similar. You cannot do too much even if you exactly know it is important. Otherwise you dismiss it (most likely happened many times) You obtain a part of a malware that can be analyzed – finally you can work, but most likely it’s just a partial data. Maybe elements are missing and you need more forensics to go on. You obtained a number of pieces of the malware – You cannot be sure that it is total. You cannot handle so many modules/much information, you cannot categorize things, you cannot keep on with the different versions of the same malware –Need to share findings to get others with more knowledge etc. work –We think that the best way to go forward is what we did: Producing technical document detailing with all findings in detail and even all questions The major goal is not publicity, but helping other tech people For publicity producing high-level material is much better and easier
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Management and mediator role 70-80% of the work is non-technical, much of that is after disclosure –What to tell, share, disclose –What not to tell, share or disclose –What permissions needed –Obtaining legitimate contact points to partners –Checking identity (legitimity) of parties) –Encryption related problems (key exchange, key check etc) –Checking press, twitter, webinars, etc. to keep up status –Selecting, saving important information found on the net
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Sharing problems Duqu: Code/sample cannot be shared until prooved that no data related victim is in the sample Flame: Sample cannot be shared in full depth as it can contain sensitive/victim related information Both: Even if the malware had victims in Europe, it is still a question if, or when public disclosure of informations should be done Duqu: Company wanted to remain anonymous –We had to have our report published as anonymous appendix of Symantec report –Many newspapers stated Symantec found Duqu –Reputation/trust is more important than publicity
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Ccalc32.sys Obviously it’s encrypted But what it is, should I share?
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Ccalc32.sys after decryption It’s not executable, but data Maybe it contains target sepecific values Sharing is problematic
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium WuSetupV.exe URL – May I share it? GET /view.php?mp=1&jz= &fd= &am=55597C801D1 4&ef= &pr=0&ec=0&ov= pl=gs pnZGygMcK0Gnng|spnZGy|nynn|0ncnn|TWvDKoKv|nGcRW0Gn|Dn ann|Rya0ZjD8|nR0jKnZ|nR0jKnZ|nR0jKnZ|nR0jKnZ|nR0jKnZ|n8KKD nR|GU8DKcGc|- 2TacGCcap|RyZKKDne|RyZKKDne|aDo|Tn0vZLp|Txax0DZ|qxsGZx 8-4GUg|cGoGeWZ|qxsGZx8-| HTTP/1.1 May I share it? No! e.g. Pl is list of processes running would be disclosed at victim: _System_Process_ System smss csrss winlogon services lsass vmacthlp svchost svchost svchost svchost svchost spoolsv explorer VMwareTray vmtoolsd vmtoolsd alg wscntfy wuauclt WuSetupV.ex_ regedit WuSetupV
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium WuSetupV.exe list of URL parameters usage mp: is fixed 1 for first query jz: session identifier fd: computer identifier am: MAC address of interface ef: IP address pr: is 0 if StandardSize already exists, pr=1 for new installations ec: generally 0, probably some error checking related to ~DHF593.tmp file ov: Windows version number pl: Process list ac: is fixed 1; used in second query gb: 0, ?? rt: is a0b0c0d, ?? dd: value of StandardDateBias, if set (see for details)
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 27 Targeted attacks – what’s new? Targeted attacks are asymmetric attacks (like sniper attacks) The sniper can aim at any time, any means, any target, any vulnerability, etc. – consumer grade products cannot protect against them Traditional tools can help, but don’t solve the problem (firewalls, IDS, IPS, UTM, spam filtering, etc.) What we propose to be used against such threats (proved to work): –Anomaly detection –Baits, honeypots, traps –Whitelisting and anomaly detection –Event correlation, situation analysis, manual analysis and professional care –Innovative and individual solutions (tailored to the customer)
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 28 Discussion on code signing code signing is extensively used today to authenticate the identity of the producer of a software and the integrity of the code –unsigned software can no longer be installed on recent and future versions of Windows without warning messages a common assumption is that if code is signed then it can be trusted FALSE !!! –signature key may be compromised –a valid signature does not tell anything about the trustworthiness of the signer (even if the signature key is intact) –there are multiple ways to get a piece of malware signed in practice (see CARO’10 slides of Jarno Niemela, F-Secure) –The Flame Microsoft certificate abuse (MD5 collision + PKI architecture problems) is one of the most important problems lately. – –PKI / code signing can have flaws.
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 29 Problems with code signing misplaced incentives and scalability issues negligent key management limited effectiveness in establishing trust in software Software companies do not really care: CAs have strict authentication policies when evaluating a certicate request, but… no periodic audits aiming at the verication of how the private keys are handled and used by the certificate owner –has there been any case when the certificate of a software maker was revoked due to its negligence in key management and code signing procedures??? as a consequence, software companies have no real incentives to follow strict key management policies –code signing keys are often stored on development machines without strong protection
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 30 Problems with code signing misplaced incentives and scalability issues negligent key management limited effectiveness in establishing trust in software CA’s do not really care either: who actually should perform the auditing of software companies? –CA’s may be interested, but it would not be scalable, and it would be too costly for them what if a software company is detected negligent? –CA revokes its keys and does not issue new certificates –company obtains certificates from another CA with weaker requirements –strict CAs lose their customers –CAs have no incentive to do strict verifications
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 31 Discussion on signature based detection signature based malware detection is important, as it is the most effective way of detecting known malware – not good to targeted attacks however, Duqu and other recent targeted attacks clearly show that it is not sufficient –creators of high-profile targeted threats have the resources to fine-tune their malware until it passes the verication of all known anti-virus products, –such threats will basically never be detected by signature based tools before they are identified and their signatures are added to the signature database possible approach: heuristic anomaly detection –main problem is false positive alarms –more work on white listing techniques and cloud based information sharing may improve the situation –academic research could contribute a lot in this area –In some application domains, false positives are acceptable
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 32 What are we working on? – CrySyS ATM CrySyS Advanced Threat Mitigation technology – 10+ years in designing security solutions and proposing solutions against this kind of threat –Integration of results –Adaptation to CI and similar environment –Make our solutions more scalable Our solutions already proved to work, but there are challenges in commercial deployment: –prove that the solution does not affect the operation of existing infrastructure –lowering the need of trust in the company who runs such mitigation services by controlling what they can do –adaptation to processes of the host –adaptation of techniques to different areas,e.g. PLC, embedded system honeypot –Protecting the protector: our solutions should not elevate the risk in any sense
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium 33 Questions?
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium Duqu known versions (Kaspersky)
Laboratory of Cryptography and System Security CrySyS Adat- és Rendszerbiztonság Laboratórium