Brand-New HavanaCrypt Ransomware Poses as Google Software Update App, Uses Microsoft Hosting Service IP Address as C&C Server
We recently found a new ransomware family, which we have dubbed as HavanaCrypt, that disguises itself as a Google Software Update application and uses a Microsoft web hosting service IP address as its command-and-control server to circumvent detection.
Ransomware is not at all novel, but it continues to be one of the top cyberthreats in the world today. In fact, according to data from Trend Micro™ Smart Protection Network™, we detected and blocked more than 4.4 million ransomware threats across email, URL, and file layers in the first quarter of 2022 — a 37% increase in overall ransomware threats from the fourth quarter of 2021.
Ransomware’s pervasiveness is rooted in its being evolutionary: It employs ever-changing tactics and schemes to deceive unwitting victims and successfully infiltrate environments. For example, this year, there have been reports of ransomware being distributed as fake Windows 10, Google Chrome, and Microsoft Exchange updates to fool potential victims into downloading malicious files.
Recently, we found a brand-new ransomware family that employs a similar scheme: It disguises itself as a Google Software Update application and uses a Microsoft web hosting service IP address as its command-and-control (C&C) server to circumvent detection. Our investigation also shows that this ransomware uses the QueueUserWorkItem function, a .NET System.Threading namespace method that queues a method for execution, and the modules of KeePass Password Safe, an open-source password manager, during its file encryption routine.
In this blog entry, we provide an in-depth technical analysis of the infection techniques of this new ransomware family, which we have dubbed HavanaCrypt.
Arrival
HavanaCrypt arrives as a fake Google Software Update application.
data:image/s3,"s3://crabby-images/66fbb/66fbb05972d88c94278336c334d4d837b222d8a2" alt="The file description of the binary file of HavanaCrypt"
This malware is a .NET-compiled application and is protected by Obfuscar, an open-source .NET obfuscator used to help secure codes in a .NET assembly.
data:image/s3,"s3://crabby-images/a166f/a166f6045ad7b426c1cd273a77d933649600fc2a" alt="The properties of the binary file of HavanaCrypt as shown in the Detect It Easy tool, a program used to determine file types"
The malware also has multiple anti-virtualization techniques that help it avoid dynamic analysis when executed in a virtual machine. To analyze the sample and generate the deobfuscated code, we used tools such as de4dot and DeObfuscar.
data:image/s3,"s3://crabby-images/a5547/a55470c8750493b785734b91d6f55a37fe646563" alt="An obfuscated HavanaCrypt ransomware code sample"
data:image/s3,"s3://crabby-images/44830/4483039ac2831364779632bd8cdb4f922209966d" alt="A deobfuscated HavanaCrypt ransomware code sample"
Upon execution, HavanaCrypt hides its window by using the ShowWindow function with parameter 0 (SW_HIDE).
data:image/s3,"s3://crabby-images/f2c78/f2c78c785b2079692c36010795dba0e6eae8c6f7" alt="The ShowWindow function as it is used by HavanaCrypt"
HavanaCrypt then checks the AutoRun registry to see whether the “GoogleUpdate” registry is present. If the registry is not present, the malware continues with its malicious routine.
data:image/s3,"s3://crabby-images/1688f/1688f86488fb1cf9eff15cefb540145cd374a843" alt="The function containing the parameters used by HavanaCrypt in checking the registry key"
data:image/s3,"s3://crabby-images/a973e/a973e9655362e4adc4ce122670ddd27eb9f78c54" alt="The function containing the parameters used by HavanaCrypt in checking the registry key"
It then proceeds with its anti-virtualization routine, where it terminates itself if the system is found running in a virtual machine environment.
Antivirtualization
HavanaCrypt has four stages of checking whether the infected machine is running in a virtualized environment.
data:image/s3,"s3://crabby-images/b8e1d/b8e1d59096dac4b49698e5a86d67edae2d0267f6" alt="The function used by HavanaCrypt to implement its antivirtualization mechanism."
data:image/s3,"s3://crabby-images/75c76/75c76da47e46366e9b89e37ab075286653c63c3b" alt="The entire antivirtualization routine of HavanaCrypt"
First, it checks for services used by virtual machines such as VMWare Tools and vmmouse.
data:image/s3,"s3://crabby-images/f9e66/f9e668949295dcff1cdbf601892c43a731f02c4c" alt="The services being checked by HavanaCrypt"
data:image/s3,"s3://crabby-images/29fac/29fac7d231c377250a7320b5b26b9885686f3116" alt="The services being checked by HavanaCrypt"
Second, it checks for the usual files that are related to virtual machine applications.
data:image/s3,"s3://crabby-images/ad006/ad0063d0853adc0d524950b2a1d22b6359cc5231" alt="The virtual machine files being checked by HavanaCrypt"
data:image/s3,"s3://crabby-images/60876/6087672a165ba73ff5aa8105eb25a203fa63fef9" alt="The virtual machine files being checked by HavanaCrypt"
Third, it checks for file names used by virtual machines for their executables.
data:image/s3,"s3://crabby-images/9655a/9655a2db9593030c29fd98e885edcaba1e105123" alt="The virtual machine executables being checked by HavanaCrypt"
data:image/s3,"s3://crabby-images/3bb27/3bb275e0a2acf0940530858528b66c1011a0c34b" alt="The virtual machine executables being checked by HavanaCrypt"
Last, it checks the machine’s MAC address and compares it to organizationally unique identifier (OUI) prefixes that are typically used by virtual machines.
data:image/s3,"s3://crabby-images/42a75/42a75e28082d4c97a768a4c75b2813856fef1f7e" alt="The OUI prefixes being checked by HavanaCrypt"
data:image/s3,"s3://crabby-images/308a9/308a9a2dbc6f559b26a6d7cc17ee04578d0e71fe" alt="The OUI prefixes being checked by HavanaCrypt"
Range or prefix | Product |
00:05:69 | VMware ESX and VMware GSX Server |
00:0C:29 | Standalone VMware vSphere, VMware Workstation, and VMware Horizon |
00:1C:14 | VMWare |
00:50:56 | VMware vSphere, VMware Workstation, and VMware ESX Server |
08:00:27 | Oracle VirtualBox 5.2 |
Table 1. Virtual machines’ OUI ranges or prefixes
After verifying that the victim machine is not running in a virtual machine, HavanaCrypt downloads a file named “2.txt” from 20[.]227[.]128[.]33, a Microsoft web hosting service IP address, and saves it as a batch (.bat) file with a file name containing between 20 and 25 random characters.
data:image/s3,"s3://crabby-images/4d8c7/4d8c7c9cf58a400e535c8435bf205d305d1d10de" alt="The details of the Microsoft web hosting service IP address"
(Image source: AbuseIPDB)
It then proceeds to execute the batch file using cmd.exe with a “/c start” parameter. The batch file contains commands that are used to configure Windows Defender scan preferences to allow any detected threat in the “%Windows%” and “%User%” directories.
data:image/s3,"s3://crabby-images/26f3f/26f3fbd5e71ac8cf624856b518634d1aeffb8139" alt="The function that contains the downloading and execution of the batch file"
data:image/s3,"s3://crabby-images/52535/52535fdaf034912b117ed0f3bd248ca973cbbff8" alt="The Base64-encoded 2.txt file as seen on the Microsoft web hosting service IP address"
data:image/s3,"s3://crabby-images/706b5/706b52d18eef85d174782c804dd09236ec30d376" alt="The decoded batch file downloaded from the Microsoft web hosting service IP address"
HavanaCrypt also terminates certain processes that are found running in the machine:
- agntsvc
- axlbridge
- ccevtmgr
- ccsetmgr
- contoso1
- culserver
- culture
- dbeng50
- dbeng8
- dbsnmp
- dbsrv12
- defwatch
- encsvc
- excel
- fdlauncher
- firefoxconfig
- httpd
- infopath
- isqlplussvc
- msaccess
- msdtc
- msdtsrvr
- msftesql
- msmdsrv
- mspub
- mssql
- mssqlserver
- mydesktopqos
- mydesktopservice
- mysqld
- mysqld-nt
- mysqld-opt
- ocautoupds
- ocomm
- ocssd
- onenote
- oracle
- outlook
- powerpnt
- qbcfmonitorservice
- qbdbmgr
- qbidpservice
- qbupdate
- qbw32
- quickboooks.fcs
- ragui
- rtvscan
- savroam
- sqbcoreservice
- sqladhlp
- sqlagent
- sqlbrowser
- sqlserv
- sqlserveragent
- sqlservr
- sqlwriter
- steam
- supervise
- synctime
- tbirdconfig
- thebat
- thebat64
- thunderbird
- tomcat6
- vds
- visio
- vmware-converter
- vmware-usbarbitator64
- winword
- word
- wordpad
- wrapper
- wxserver
- wxserverview
- xfssvccon
- zhudongfangyu
- zhundongfangyu
data:image/s3,"s3://crabby-images/3d7ad/3d7ad2944faab1acfb549af8ebbdc31d2cb248a5" alt="The processes that HavanaCrypt terminates"
It should be noted that this list includes processes that are part of database-related applications, such as Microsoft SQL Server and MySQL. Desktop apps such as Microsoft Office and Steam are also terminated.
After it terminates all relevant processes, HavanaCrypt queries all available disk drives and proceeds to delete the shadow copies and resize the maximum amount of storage space to 401 MB.
data:image/s3,"s3://crabby-images/592e4/592e4115218891e3be16f2f0b5577fc7f0b9a85b" alt="HavanaCrypt deleting shadow copies and resizing the maximum storage space of available drives to 401 MB"
It also checks for system restore instances via Windows Management Instrumentation (WMI) and proceeds to delete them by using the SRRemoveRestorePoint function.
data:image/s3,"s3://crabby-images/946bc/946bc9dca42b3b4eeb8a49146f46ccf2305a9c5d" alt="HavanaCrypt deleting system restore instances via WMI"
It then drops copies of itself in the %ProgramData% and %StartUp% folders in the form of executable (.exe) files with different file names containing between 10 and 15 random characters. Their attributes are then set to “Hidden” and “System File.”
data:image/s3,"s3://crabby-images/d6390/d63903cdc8cbe1716a16520e7f7782993b03f930" alt="HavanaCrypt dropping copies of itself in the %ProgramData% and %StartUp% folders"
data:image/s3,"s3://crabby-images/6a1e3/6a1e3fe1f4812cecfd73b9bfa9ce8e4a3f584f38" alt="HavanaCrypt setting the dropped files as “Hidden” and “System File”"
HavanaCrypt also drops a file named “vallo.bat” onto %User Startup%, which contains functions that can disable the Task Manager.
data:image/s3,"s3://crabby-images/c42d4/c42d478d584013e708d62b56a081225151dbc740" alt="HavanaCrypt dropping vallo.bat onto %User Startup%"
data:image/s3,"s3://crabby-images/9b631/9b6315fa9fc5eeb3d7ef88212eb5e55556442258" alt="The content of vallo.bat"
Gathering of machine information
HavanaCrypt uses the QueueUserWorkItem function to implement thread pooling for its other payloads and encryption threads. This function is used to execute a task when a thread pool becomes available.
data:image/s3,"s3://crabby-images/8192c/8192c2f509f73771478a7cec5d6043f1a8a4c5d0" alt="The QueueUserWorkItem function as it is used by HavanaCrypt"
It also uses the DebuggerStepThrough attribute, which causes it to step through the code during debugging instead of stepping into it. This attribute must be removed before one can analyze the function inside.
data:image/s3,"s3://crabby-images/feb9e/feb9e72fb2de3f269ffadd4ae4c0db9891e0925b" alt="The DebuggerStepThrough attribute as it is used by HavanaCrypt"
Before it proceeds with its encryption routine, HavanaCrypt gathers certain pieces of information and sends them to its C&C server, 20[.]227[.]128[.]33/index.php. These are the unique identifier (UID) and the token and date.
UID
The UID contains the machine’s system fingerprint. HavanaCrypt gathers pieces of machine information and combines them, by appending one to another, before converting the information into its SHA-256 hash in the format:
[{Number of Cores}{ProcessorID}{Name}{SocketDesignation}] BIOS Information [{Manufacturer}{BIOS Name}{Version}] Baseboard Information [{Name}]
data:image/s3,"s3://crabby-images/ee3a2/ee3a262e1759d10118a9d06af6865c069b4a06fb" alt="The function used by HavanaCrypt to gather machine information"
data:image/s3,"s3://crabby-images/4bf6d/4bf6d9a49768532fee864accf372d3f71098d325" alt="HavanaCrypt converting its gathered machine information into a SHA-256 hash"
The pieces of machine information that HavanaCrypt gathers include:
- The number of processor cores
- The processor ID
- The processor name
- The socket designation
- The motherboard manufacturer
- The motherboard name
- The BIOS version
- The product number
Token and date
HavanaCrypt replaces the string “index.php” with “ham.php” to send a GET request to its C&C server (hxxp[:]//20[.]227[.]128[.]33/ham.php) using “Havana/1.0” as the user agent.
data:image/s3,"s3://crabby-images/116b1/116b1d746f57af5cc93036437825de18701156db" alt="The function used by HavanaCrypt to send a GET request to its C&C server"
data:image/s3,"s3://crabby-images/73080/7308042a85b26bbd7c193360ba79183f1bebab39" alt="The function used by HavanaCrypt to send a GET request to its C&C server"
![The response from 20[.]227[.]128[.]33/ham.php that we obtained via Fiddler, a web application debugging tool](/content/dam/trendmicro/global/en/research/22/g/brand-new-havanacrypt-ransomware-poses-as-google-software-update-app-uses-microsoft-hosting-service-ip-address-as-c-c-server/havanacrypt-figure29.png)
HavanaCrypt decodes the response from ham.php in Base64 and decrypts it via the AES decryption algorithm using these parameters:
- Aes.key: d8045c7174c2649e96e68a01a5d77f7dec4846ebebb7ed04fa8b1325c14d84b0 (SHA-256 of “HOLAKiiaa##~~@#!2100”)
- Aes.IV: consists of 16 sets of 00 bytes
HavanaCrypt then stores the output in two different arrays with “–” as their delimiter. The first array is used as the token, while the second is used as the date.
data:image/s3,"s3://crabby-images/88d79/88d7902bcb2ba96dc1394c7c536524d76ca4b743" alt="The initialization of parameters to be used by HavanaCrypt in AES decryption"
data:image/s3,"s3://crabby-images/e89cc/e89ccac47121d3bd1d33844729202afebca4849a" alt="Decryption by HavanaCrypt via AES"
Using CyberChef, a web app that provides operations such as encoding and encryption, we replicated HavanaCrypt’s decryption routine using the response from 20[.]227[.]128[.]33/ham.php:
- Output: d388ed2139d0703b7c2a810b09e513652eb9402c92304addd34679e21a826537-1655449622
- Token: d388ed2139d0703b7c2a810b09e513652eb9402c92304addd34679e21a826537
- Date: 1655449622
data:image/s3,"s3://crabby-images/67653/67653f9cd0bf502635aafa8a0f7a99d3591d6fd5" alt="Our replication of HavanaCrypt’s decryption routine using the CyberChef app"
After gathering all the necessary machine information, HavanaCrypt sends it via a POST request to hxxp://20[.]227[.]128[.]33/index.php using “Havana/1.0” as the user agent.
![HavanaCrypt’s POST request to hxxp[:]20[.]227[.]128[.]33/index[.]php that we obtained using Fiddler](/content/dam/trendmicro/global/en/research/22/g/brand-new-havanacrypt-ransomware-poses-as-google-software-update-app-uses-microsoft-hosting-service-ip-address-as-c-c-server/Fig%2033_HavanaCrypt%20Ransomware.png)
If the request is successful, HavanaCrypt receives a response that contains the encryption key, the secret key, and other details.
![The response from hxxp[:]20[.]227[.]128[.]33/index[.]php that we obtained using Fiddler](/content/dam/trendmicro/global/en/research/22/g/brand-new-havanacrypt-ransomware-poses-as-google-software-update-app-uses-microsoft-hosting-service-ip-address-as-c-c-server/Fig%2034_HavanaCrypt%20Ransomware.png)
HavanaCrypt checks whether hava.info is already present in “%AppDataLocal%/Google/Google Software Update/1.0.0.0”. If it does not find the file, it drops the hava.info file, which contains the RSA key generated by HavanaCrypt using the RSACryptoServiceProvider function.
data:image/s3,"s3://crabby-images/216cb/216cb43d851dbf82070a5c98b71384ef93781581" alt="The contents of hava.info that we obtained using HIEW, a console hex editor"
data:image/s3,"s3://crabby-images/3b6d0/3b6d0d6694b88c1f67ac8591c0ecfbf8efe6a149" alt="HavanaCrypt’s generation of an RSA key using the RSACryptoServiceProvider function"
Encryption routine
We have observed that HavanaCrypt uses KeePass Password Safe modules during its encryption routine. In particular, it uses the CryptoRandom function to generate random keys needed for encryption. The similarity between the function used by HavanaCrypt and the KeePass Password Safe module from GitHub is evident.
data:image/s3,"s3://crabby-images/b708b/b708b459a283ef48086e88700290de26c06d2c36" alt="The functions used by HavanaCrypt in generating random bytes"
data:image/s3,"s3://crabby-images/1db24/1db24ccb6a1a33f58fb8778e8cdea1cc8e4c498f" alt="A snippet of KeePass Password Safe’s code from GitHub"
HavanaCrypt encrypts files and appends “.Havana” as a file name extension.
data:image/s3,"s3://crabby-images/7cab6/7cab60fa3fb9e3955bb6620b547bbabd1449e1ed" alt="HavanaCrypt’s encryption routine"
It avoids encrypting files with certain extensions, including files that already have the appended “.Havana” extension.
data:image/s3,"s3://crabby-images/0b734/0b734b0a9bb4d8902cc85de7b48aefcfb6814267" alt="The function used by HavanaCrypt to avoid certain file name extensions"
data:image/s3,"s3://crabby-images/48c4d/48c4d486b0b5e252eb64268081a30e09b1c5c737" alt="The file name extensions files of which HavanaCrypt avoids encrypting"
HavanaCrypt also avoids encrypting files found in certain directories.
data:image/s3,"s3://crabby-images/eb13f/eb13f8d5ac1b607e32ae7f052189c6f9d0169935" alt="The directories in which HavanaCrypt avoids encrypting files"
data:image/s3,"s3://crabby-images/d80f0/d80f0db1aa1576118882cdbb4df77757b66f8d4f" alt="The function used by HavanaCrypt to avoid certain directories"
data:image/s3,"s3://crabby-images/6f35d/6f35de489cf23e54869405e64bac82782b1db7fe" alt="Some files encrypted by HavanaCrypt"
During encryption, HavanaCrypt creates a text file called “foo.txt”, which logs all the directories containing the encrypted files.
data:image/s3,"s3://crabby-images/2e2b9/2e2b97e810450cbd340c8cc93430aba99e344452" alt="The foo.txt text file that contains logs of directories that contain encrypted files"
Conclusion and Trend Micro solutions
The HavanaCrypt ransomware’s disguising itself as a Google Software Update application is meant to trick potential victims into executing the malicious binary. The malware also implements many antivirtualization techniques by checking for processes, files, and services related to virtual machine applications.
It is uncommon for ransomware to use a C&C server that is part of Microsoft web hosting services and is possibly used as a web hosting service to avoid detection. Aside from its unusual C&C server, HavanaCrypt also uses KeePass Password Safe’s legitimate modules during its encryption phase.
It is highly possible that the ransomware’s author is planning to communicate via the Tor browser, because Tor’s is among the directories that it avoids encrypting files in. It should be noted that HavanaCrypt also encrypts the text file foo.txt and does not drop a ransom note. This might be an indication that HavanaCrypt is still in its development phase. Nevertheless, it is important to detect and block it before it evolves further and does even more damage.
Organizations and users can benefit from having the following multilayered defense solutions that can detect ransomware threats before operators can launch their attacks:
- Trend Micro Vision One™ provides multilayered protection and behavior detection, which helps block questionable behavior and tools early on, before the ransomware can do irreversible damage to the system.
- Trend Micro Apex One™ offers next-level automated threat detection and response against advanced concerns such as fileless threats and ransomware, ensuring the protection of endpoints.
Additional insights by Nathaniel Gregory Ragasa
Indicators of compromise
Files
SHA-256 | Detection name | Description |
b37761715d5a2405a3fa75abccaf6bb15b7298673aaad91a158725be3c518a87 | Ransom.MSIL.HAVANACRYPT.THFACBB | Obfuscated HAVANACRYPT ransomware |
bf58fe4f2c96061b8b01e0f077e0e891871ff22cf2bc4972adfa51b098abb8e0 | Ransom.MSIL.HAVANACRYPT.THFACBB | Deobfuscated HAVANACRYPT ransomware |
aa75211344aa7f86d7d0fad87868e36b33db1c46958b5aa8f26abefbad30ba17 | Ransom.MSIL.HAVANACRYPT.THFBABB | Deobfuscated HAVANACRYPT ransomware |
URLs
http://20[.]227[.]128[.]33/2.txt |
http://20[.]227[.]128[.]33/index.php |
http://20[.]227[.]128[.]33/ham.php |