Wannacry Ransomware Analysis - Part 1
Table of Contents
Hey there! Welcome to my first ever attempt at analysing a piece of malware. What’s a better place to start than the infamous Wannacry Ransomware. The malware analysis will be broken into 2 parts. This first part will consist of what I call the “basic” analysis where we look at the file properties and signatures. We will also be detonating the malware and look what it does through tools like procmon and TCPview. In the second part, we look deeper into the code of the malware by opening it in some static and dynamic reverse engineering tools such as Ghidra and x64dbg. I would like to mention that this analysis was done completely blind, I have not looked at any other writeups online and the information presented in this blog post was found and presented solely by me. Now let’s get right to it.
What is the Wannacry Ransomware?
Before we start looking into what Wannacry does, let’s talk about what Wannacry is. Wannacry is the name of a crypto ransomware that spread everywhere in May 2017. A ransomware is a type of malicious software (malware) which holds your files and data hostage for a ransom. If you don’t pay the ransom, you will not get access back to your files/data. A crypto ransomware is a ransomware that encrypts your data and only decrypts it when the ransom is paid.
Wannacry takes advantage of EternalBlue to propagate to other potential victims. EternalBlue was an exploit of the Server Message Block (SMB) protocol on Microsoft Windows developed by the National Security Agency (NSA) and leaked by a group called The Shadow Brokers (TSB). The USA and UK officially blame North Korea for the development of Wannacry but there are conflicting reports regarding it.
Wannacry affected approximately 230,000 computers including major industries such as logistics, advertising, automotive etc. The EternalBlue vulnerability has since been fixed and Wannacry has also been neutralised by other means which we shall get into later.
The malware sample has been obtained from theZoo, which a github repo of live malware samples FOR EDUCATIONAL PURPOSES ONLY.
Static Analysis
In this section, we shall perform some basic static analysis on the executable file. We shall look at some properties and some other characteristics. For the sake of completion, we will be treating the sample as an unknown piece of malware and perform the full suite of analysis on it without any assumptions.
Hash Values and VirusTotal
First thing we do is to check the hash values of the file and search for it on an online malware database such as VirusTotal.
We get the SHA256 and MD5 hashes of the sample using CertUtil.
data:image/s3,"s3://crabby-images/f0e8f/f0e8f095cc6dc5e1f3ed69e808bf8fc906d39d7b" alt=""
There are multiple samples of the Wannacry that are functionally similar. These are the hashes of the sample we will be working with:
MD5: 84c82835a5d21bbcf75a61706d8ab549
SHA256: ed01ebfbc9eb5bbea545af4d01bf5f1071661840480439c6e5babe8e080e41aa
Next step is checking these hash values on VirusTotal and see if we get any matches in the database.
data:image/s3,"s3://crabby-images/707f7/707f79d4aa683d1b03e0ab8be983605e271b2e16" alt=""
VirusTotal shows that 71 out of 75 security vendors have marked this file as malicious and most of them have identified it as Wannacry or some variation of it. VirusTotal Search Results.
Floss
Next step, we pass the sample through floss, a commandline utility that extracts and deobfuscastes strings present in binaries.
data:image/s3,"s3://crabby-images/f486b/f486ba2faa05e9a454b5adddbfb0905c2c980459" alt=""
data:image/s3,"s3://crabby-images/a4c5f/a4c5f7a5ac14f3de43c2568ea37063b0a69a0e20" alt=""
data:image/s3,"s3://crabby-images/2c702/2c702a4c3394ca670ac38aea2eef927008ec1ccd" alt=""
data:image/s3,"s3://crabby-images/364dc/364dcb76ff968ec34c068e9ab33bdc58adc6f749" alt=""
There are hundreds of identified strings. Here are the points to note from the floss output:
- The string
cmd.exe /c "%s"
, this allows the executable to run aribitrary cmd commands. - There is also a string
icacls . /grant Everyone:F /T /C /Q
present. We will see what this does in later. - There are strings for different languages, maybe to generate messages in different languages.
- Strings like
%s\Intel
and%s\ProgramData
can provide direct access to critical folders if used correctly. - We see a number of system functions that are used in the executable regarding directories and files.
PEStudio
Now, lets look at the malware sample in PEStudio. PEStudio is an all-in-one (mostly) tool that allows us to statically look at a ton of informtaion about PE (Portable Executable) files.
Under the the general properties of the file, we see some basic information of the file.
data:image/s3,"s3://crabby-images/831ba/831ba47cbc06a2795e3fee17f49060d414adf4cf" alt=""
Some relevant ones are:
size
: 3514368 bytes
description
: DiskPart
Compile Stamp
: Sat Nov 20 09:05:05 2010 | UTC
The description shows up as DiskPart
which is one of the aliases that VirusTotal showed for the file.
Then we look at the raw and virtual size of the file.
data:image/s3,"s3://crabby-images/e1ea1/e1ea10fc8fd30e6b971edee13a0901b8a13b2987" alt=""
We see that the raw file size (3510272 bytes) and the virtual size (3506712 bytes ) of the file is approximately the same. This would indicate that the file is not packed and would not need to be unpacked to analyse further.
We can also look at the Windows libraries (.dll files) that are imported by the malware.
data:image/s3,"s3://crabby-images/33862/3386234b268aa07f314543cfead4e1b8dd678e40" alt=""
While these imports are not inherently malicous and are used by benign programs, but these do allow for some pretty serious control over the operating system.
Now we can look at the functions from the library that are imported by the executable. PEStudio is pretty smart and flags functions that are potentially malicious.
data:image/s3,"s3://crabby-images/02df0/02df09a748d1a6f414151900f97a895988dc1f08" alt=""
Out of the 114 functions imported by the program, PEStudio flags 15 of them as malicious. These include functions to set current directory (SetCurrentDirectoryW/SetCurrentDirectoryA), random functions (srand/rand), create and set registry key values (RegCeateKeyW/RegSetValueExA) among others. Seeing these functions in context of what Wannacry does, it makes sense to flag these as malicious functions.
The resources section gives us some useful information.
data:image/s3,"s3://crabby-images/32953/329538ea4ed119189475d1e9173eb30a5824c85d" alt=""
We see a resource called XIA
which is a .zip
file. We extract that file and find 2 executables and some files with a .wnry
extension
data:image/s3,"s3://crabby-images/f23a1/f23a1572d914bc378c87a98ce2e041d864ff25d8" alt=""
Unfortunately, these files are password protected and we do not know the password at this time. We can try looking at these again if we find a password.
That concludes our inital static analysis of the malware.
Dynamic Analysis
What’s a better way to understand what a piece of malware does if not by running it. In dynamic analysis, we run the malware and observe its behabviour. We use certain tools to see what the malware executes on the computer and can trace the sequence of events. It goes without saying that this has to be done under very controlled conditions. Ideally, on a virutal machine in an isolated network. We do not know if/ how the malware propogates and not isolating it on the network could get the host machine infected.
Our lab test environment consists of a FlareVM machine running the malware and a REMnux box running inetsim and wireshark to act as a fake internet connection. These 2 machines are running on Oracle VirtualBox in an isolated network so they cannot reach the host machine or the actual internet.
Regshot
The first dynamic analysis tool we use is Regshot. Regshot is an open-source registry compare utility that allows you to quickly take a snapshot of your registry and then compare it with a second one. This way we can compare the what the malware does to our registry. We take a shot before and one after the malware detonation. Snippets of the comparison results are included. Comparing the output, we see the whole HKLM\DRIVERS
key has been deleted. This could be done to prevent the victim machine from performing properly and could potentially prevent any recovery actions.
----------------------------------
Keys deleted: 20287
----------------------------------
HKLM\DRIVERS
HKLM\DRIVERS\DriverDatabase
HKLM\DRIVERS\DriverDatabase\DeviceIds
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AEI0276
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AEI9240
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AIW1038
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AKY00A1
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AKY1001
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AKY1005
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AKY1009
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AKY1013
HKLM\DRIVERS\DriverDatabase\DeviceIds\*ANX2101
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AZT0003
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AZT3001
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AZT4001
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AZT4004
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AZT4017
HKLM\DRIVERS\DriverDatabase\DeviceIds\*AZT4021
HKLM\DRIVERS\DriverDatabase\DeviceIds\*BDP0156
HKLM\DRIVERS\DriverDatabase\DeviceIds\*BDP2336
HKLM\DRIVERS\DriverDatabase\DeviceIds\*BDP3336
HKLM\DRIVERS\DriverDatabase\DeviceIds\*BRI1400
Additionally, registry keys regarding firewall rules have also been deleted along with some keys for Windows Error Reporting.
HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\StickyUpdates\657943f1-1efb-430a-a6c8-f77993103709: 0x000001908FF987AC
HKLM\SOFTWARE\Microsoft\Windows\CurrentVersion\WindowsUpdate\StickyUpdates\46535ccb-755d-4cf3-9c00-8f36a4f7060b: 0x000001908FFC0D23
HKLM\SOFTWARE\Microsoft\Windows\Windows Error Reporting\TermReason\6060\Terminator: "HAM"
HKLM\SOFTWARE\Microsoft\Windows\Windows Error Reporting\TermReason\6060\Reason: 0x00000004
HKLM\SOFTWARE\Microsoft\Windows\Windows Error Reporting\TermReason\6060\CreationTime: 0x01DAF28F12F51679
HKLM\SOFTWARE\Microsoft\Windows\Windows Error Reporting\TermReason\6624\Terminator: "HAM"
HKLM\SOFTWARE\Microsoft\Windows\Windows Error Reporting\TermReason\6624\Reason: 0x00000004
HKLM\SOFTWARE\Microsoft\Windows\Windows Error Reporting\TermReason\6624\CreationTime: 0x01DAF28F1B0CF517
HKLM\SYSTEM\ControlSet001\Control\hivelist\\REGISTRY\MACHINE\DRIVERS: 5C 00 44 00 65 00 76 00 69 00 63 00 65 00 5C 00 48 00 61 00 72 00 64 00 64 00 69 00 73 00 6B 00 56 00 6F 00 6C 00 75 00 6D 00 65 00 31 00 5C 00 57 00 69 00 6E 00 64 00 6F 00 77 00 73 00 5C 00 53 00 79 00 73 00 74 00 65 00 6D 00 33 00 32 00 5C 00 63 00 6F 00 6E 00 66 00 69 00 67 00 5C 00 44 00 52 00 49 00 56 00 45 00 52 00 53 00 00 00 00 00
HKLM\SYSTEM\ControlSet001\Services\SharedAccess\Parameters\FirewallPolicy\FirewallRules\{3D860988-2D74-4B56-9311-8CEC8F26648C}: "v2.30|Action=Allow|Active=TRUE|Dir=Out|Profile=Domain|Profile=Private|Profile=Public|Name=@{Microsoft.DesktopAppInstaller_1.0.30251.0_x64__8wekyb3d8bbwe?ms-resource://Microsoft.DesktopAppInstaller/Resources/appDisplayName}|Desc=@{Microsoft.DesktopAppInstaller_1.0.30251.0_x64__8wekyb3d8bbwe?ms-resource://Microsoft.DesktopAppInstaller/Resources/appDisplayName}|LUOwn=S-1-5-21-2468057532-1901412999-489411066-1000|AppPkgId=S-1-15-2-2473817148-3930944034-1235795307-187980641-3967865409-1804095407-1113801530|EmbedCtxt=@{Microsoft.DesktopAppInstaller_1.0.30251.0_x64__8wekyb3d8bbwe?ms-resource://Microsoft.DesktopAppInstaller/Resources/appDisplayName}|Platform=2:6:2|Platform2=GTEQ|"
HKLM\SYSTEM\ControlSet001\Services\SharedAccess\Parameters\FirewallPolicy\FirewallRules\{3A3FF571-CC7C-41F5-9091-9B1370BB0794}: "v2.30|Action=Allow|Active=TRUE|Dir=In|Profile=Domain|Profile=Private|Name=@{Microsoft.DesktopAppInstaller_1.0.30251.0_x64__8wekyb3d8bbwe?ms-resource://Microsoft.DesktopAppInstaller/Resources/appDisplayName}|Desc=@{Microsoft.DesktopAppInstaller_1.0.30251.0_x64__8wekyb3d8bbwe?ms-resource://Microsoft.DesktopAppInstaller/Resources/appDisplayName}|LUOwn=S-1-5-21-2468057532-1901412999-489411066-1000|AppPkgId=S-1-15-2-2473817148-3930944034-1235795307-187980641-3967865409-1804095407-1113801530|EmbedCtxt=@{Microsoft.DesktopAppInstaller_1.0.30251.0_x64__8wekyb3d8bbwe?ms-resource://Microsoft.DesktopAppInstaller/Resources/appDisplayName}|Platform=2:6:2|Platform2=GTEQ|"
There are a 136 new registry values added. Not all of them may be relevant to our purpose. Browsing through the list, we find a few that may be of relevance.
HKU\S-1-5-21-2468057532-1901412999-489411066-1000\SOFTWARE\Microsoft\Windows\CurrentVersion\Run\ksroqtsyfbvuio971: ""C:\Users\taygr\Desktop\tasksche.exe""
HKU\S-1-5-21-2468057532-1901412999-489411066-1000\SOFTWARE\WanaCrypt0r\wd: "C:\Users\taygr\Desktop"
The first entry is a value under SOFTWARE\Microsoft\Windows\CurrentVersion\Run\
. Values under the Run
key are executed automatically at startup. The program being run is one of the executables we found in the resources of the malware sample. This is done to ensure persistence on the victim machine. The second entry is clearly made by the wannnacry malware. The key value is just the desktop directory (We will see where this comes from later).
There are 265 modified regsitry values. Out of all of them, only a few are relevant. These are the reason our desktop wallpaper changes.
HKU\S-1-5-21-2468057532-1901412999-489411066-1000\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Wallpapers\BackgroundHistoryPath0: "C:\ProgramData\_VM\background.png"
HKU\S-1-5-21-2468057532-1901412999-489411066-1000\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Wallpapers\BackgroundHistoryPath0: "C:\Users\taygr\Desktop\@WanaDecryptor@.bmp"
HKU\S-1-5-21-2468057532-1901412999-489411066-1000\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Wallpapers\BackgroundHistoryPath1: "C:\Windows\web\wallpaper\Windows\img0.jpg"
HKU\S-1-5-21-2468057532-1901412999-489411066-1000\SOFTWARE\Microsoft\Windows\CurrentVersion\Explorer\Wallpapers\BackgroundHistoryPath1: "C:\ProgramData\_VM\background.png"
Procmon
Procmon or Process Monitor is a built-in Windows tool that is extremely useful to keep track of what programs do. We can look at the operations, target files, target paths, links between different processes and undestand the relationships between different processes. To begin our analysis, we filter the entries whose process name is the name of our malware sample ed01ebfbc9eb5bbea545af4d01bf5f1071661840480439c6e5babe8e080e41aa.exe
.
data:image/s3,"s3://crabby-images/a38a6/a38a6ae0bf7acf8099c41cc40643120008b7017d" alt=""
Filtering just by the process name gives us close to a million entries. That is of no use to us. We need a way to filter into the entries that matter. One filter that I particularly like to use is to filter for cmd.exe
. These are usually ways for programs to interact with the system. Further, earlier during the static analysis of the strings, we saw cmd.exe /c %s
. That should show up somewhere in the logs and we can see what sort of commands were run.
data:image/s3,"s3://crabby-images/2fa06/2fa06e2baaa135ba302e96518fc9b3b180628111" alt=""
As expected, there are a number of entries that use cmd.exe
. 2 of them are particularly interesting. The first one is the command line to start @WanaDecryptor@.exe
data:image/s3,"s3://crabby-images/a1280/a1280be72cb09e3c55ddb01220e0817aa27203d7" alt=""
The second entry of note is one that creates the Run
registry entry that we saw earlier in Regshot.
data:image/s3,"s3://crabby-images/45864/45864281d12ae5abf1a661fb1b876ed87715e767" alt=""
Procmon also lets us filter processes that were spawned by a given process. We can use this to see what processes were spawned by our executable. There are a LOT of entries for processes spawned by our executable.
data:image/s3,"s3://crabby-images/f67f6/f67f6fd12938165f493020570ac07f0dfe49f22c" alt=""
The first one we see is this cmd command attrib +h .
. This command is used to set the hidden attribute of the current directory. The malware probably creates some hidden files/folders (sneaky).
Another entry we see is for icacls.exe
data:image/s3,"s3://crabby-images/d6866/d686623d3f85a88a1a13bc38e64a3417f04163dd" alt=""
The command icacls ./grant Everyone:F /T /C /Q
grants all users permission to the current directory and all subdirectories and files in the current directory. It ensures that the command continues even on failure and suppresses completion and error messages, ensuring the whole process is invisible to the victim.
We see a few more tasks spawned, one of which is the taskdl.exe
file we saw earlier.
data:image/s3,"s3://crabby-images/31369/313690806bbad6b92cdb61cbecf2f21d97ddb0ed" alt=""
Looking through the entries for this process doesn’t reveal much about what it does. Maybe we can come back to this at a later stage when we reverse engineer the executables. Next is a cmd process launching a 299281724124687.bat
file. Similarly, this the entries for this process don’t help much and we skip it for now.
The last process that is spawned is @WanaDecryptor@.exe
. There are multiple instances of this executable being spawned, most of which look similar.
data:image/s3,"s3://crabby-images/f00a8/f00a80a05586efd4d0d61db9c4a62cbed5acb9ac" alt=""
This one is also a difficult to say what it is doing exactly, but we can notice a few behaviours.
data:image/s3,"s3://crabby-images/44dd9/44dd9dafaa87f12de80e0c5197df21afad0eb4f5" alt=""
It seems to be working using Tor. This may be to exfiltrate data or talk to a remote server. Additionally, it is performing a lot of read actions on s.wnry
. And most tellingly, it performs TCP sends and receives.
data:image/s3,"s3://crabby-images/ab03a/ab03a08d9fbfc70f634d61d381ce8e9280df78dd" alt=""
We look at TCPView and see WanaDecryptor
is communicating over port 9050 to the localhost.
data:image/s3,"s3://crabby-images/fdaed/fdaed4674e0e4d1a95ac753fd47f8ab06c04599e" alt=""
Opening wireshark on victim machine and looking for traffic to and from port 9050 shows packets that have .onion
. This confirms that Tor is being used to exfiltrate some sort of information from the computer. However, this is done on the localhost only so it may not be reaching out to a C2 server or a attacker machine. We can confirm more when we look at the decompile of the program.
data:image/s3,"s3://crabby-images/c9515/c95158f516b1822b6d6d4235d324c89dbf07dba7" alt=""
Conclusion
This concludes our initial analysis of the Wannacry Ransomware. We now have general idea of what the malware does, what sort of commands it executes, registry keys made and some modes of persistence. In the next part, we shall perform a deeper analysis by reverse engineering the sample and running it in a debugger. Stay tuned and thanks for reading this! Feel free to reach out on LinkedIn/ Discord/ Email to share your comments and suggestions :)