What is Gootkit malware?
Gootkit is a banking Trojan – a malware created to steal banking credentials. In fact, Gootkit is classified as one top sophisticated banking Trojans ever created. It relies on complex anti-evasion and persistence mechanisms, as well as complex techniques like dynamic web injections.
Since its initial discovery in 2014, Goodkit has been utilized in multiple attacks which targeted bank accounts across Europe, some of which were very destructive.
Gootkit is known to affect the most widely used web-browsers, namely IE, Firefox, and Chrome. Interestingly, this trojan is coded mostly using the node.js programming language – not the first choice when it comes to the majority of operators. What’s more, while a lot of similar malicious programs heavily utilize leaked source code of older samples, Gootkit appears to be written almost 100% from scratch.
General description of Gootkit
The roots of this malware go all the way back to the year 2010 when what can be called the predecessor of Gootkit was first documented. Classified at the time as an information stealer which did not pose a significant danger, Gootkit has since evolved into a full-fledged banking Trojan.
The malware has been documented in its present form of a Trojan since 2014, involved in attacks targeting both private and corporate victims in Europe, mainly targeting banks in France and England, although, Spanish and Italian banks have also been reportedly attacked.
Unlike some other Trojans, Gootkit is not available for sale on the internet. It’s code also hasn’t been leaked and all attacks involving this malware have been carried out by a Russian-speaking group of hackers.
Creators of this Trojan have implemented some of the most cutting-edge anti-evasion tricks to make sure the payload will stay hidden for as long as possible and to prevent successful analysis by cybersecurity researchers. Comprised of two main parts, the dropper and the Trojan itself – Gootkit carries out sandbox checks on every stage of its life cycle. Meaning, that both the dropper and the actual trojan have unique anti-evasion procedures.
Once the dropper makes its way into a machine, it will conduct the initial VM check, making sure that the malware is not being launched in a virtual environment. This is achieved by verifying the system’s processor value inside the Windows Registry by checking for specific names of virtual servers. In addition, BIOS is also checked to find any values which could point at the malware being launched on a VM. If the malware detects that it is not being launched on a real machine, it terminates all activities and connects to the control server to blacklist the endpoint it was launched in.
However, if the initial test is passed, the loader installs the main Gootkit executable which, in turn, repeats some of the previous checks, while adding several new ones. In one of the new checks, the malware checks the whitelist of names admissible for the CPU to determine that a VM name is absent from the list. Following this test, the malware scans to find VMWare, VBOX or SONI values on IDE/SCSI hard drives.
Such thorough virtual machine checks are not the only jack up the sleeve that Gootkit has when it comes to evasion. To increase the success rate of installs, the malware creators frequently make modifications to the Trojan, changing the targeted processes for injections and filetypes of the executable.
For example, instead of running an .exe file, some samples of Gootkit load a DLL directly into a target process. What’s more, while the majority of malware select the explorer.exe process, as their injection target, Goodkit targets a service host (svchost) process instead. Presumably, this is done to further evade detections, since injecting into a process with several instances makes Gootkit easier to hide.
In addition to advanced anti-detection methods, Gootkit employs equally sophisticated persistence techniques to ensure that its deletion from an infected machine will prove as complicated as possible. The malware provides two main persistence mechanisms which are used depending on the available system rights. When launched from an admin account, Gootkit can mymic a Windows service with a random name, which helps to confuse users. This way, it is able to launch before a victim logs on and continue running even after he or she logs off.
However, if launched from a least-privilege user account, the virus writes itself as a scheduled task, also with a random name. This task is programmed to run every minute and on every boot, ensuring that the malware will remain on a machine after antivirus software scans and system reboots.
Gootkit malware analysis
A video of the simulation recorded in the ANY.RUN malware hunting service allows us to take a closer look at the execution of Gootkit and see this malware in action. The video is available here.
Figure 1: the lifecycle of Gootkit can be viewed in a visual format on the process graph generated by the ANY.RUN online analysis sandbox.
Figure 2: This text report available at this link provides more detailed information about Gootkit execution processes, artifacts and more.
Gootkit execution process
Gootkit often gets into the system as an email attachment in the form of a Microsoft Word file. After the user opens the malicious file, it starts Powershell to download the main payload.
It should be noted that in some cases, Gootkit postpones the execution by putting itself in scheduled tasks. After the main payload execution starts, Gootkit unpacks and launches itself. This process provides the main malicious activity - stealing personal information, downloading other malware, grabbing video of the victim’s desktop, hijacking banking credentials, connecting to C2 servers and so on. In the given example Gootkit also uses WMIC.EXE to obtain a list of AntiViruses.
Distribution of Gootkit
Gootkit utilizes multiple attack vectors to infect its victims, including popular exploit kits like Neutrino and Angler, allowing the malware to get into machines with not-up-to-date operating systems.
The second used attack vector is email spam, where Gootkit is delivered to users as a malicious email attachment and social engineering is used to trick the user into downloading the malicious file.
How to avoid infection by Gootkit?
There are several rules of online safety that can be followed to greatly reduce the risk of infection by malware such as Gootkit. For instance, users are advised to install the freshest OS updates, as well as update applications which users utilize on a regular basis.
At the same time, those applications that are rarely opened should be deleted from the machine. In addition, it is advised to disable ads in the browser and avoid visiting suspicious websites. Furthermore, if a private inbox is used at work instead of a corporate one, a user should restrain from sending sensitive information to and from this personal email address.
It should be noted, that opening email attachments in suspicious emails always poses a high risk of injection, therefore users must never run suspicious programs downloaded from emails sent from unrecognized addresses.
How to export data from the analysis of Gootkit malware using ANY.RUN?
If analysts want to do additional work with events from tasks or just want to share them with colleagues thay can export to different formats. Just click on the "Export" button and choose the most suitable format in the drop-down menu
Figure 3: Options for export events from tasks with Gootkit
Although Gootkit is responsible for a negligible percentage of the overall attacks by financial malware, this Trojan should be considered an extremely high-risk danger. Thanks to its sophisticated persistence and anti-evasion functions, it is capable of potentially very damaging attacks.
What’s more, following the development of this Trojan over the years, it is safe to assume that its evolution will continue and cybercriminals behind the malware will keep producing ways to evade modern security solutions.
That’s why, utilizing the most reliable and cutting edge analysis tools, such as the ANY.RUN malware hunting service can be a key to setting up a secure cyber defense against serious threats like Gootkit.