Module 3
How malware works and different types of malware
Last updated on: 27 December 2024
Edit this page on GitHubModule 3
Last updated on: 27 December 2024
Edit this page on GitHubIn order to start working with malware, we first need to learn about its different types. Viruses, spyware, backdoors, ransomware, and adware behave differently and are inspired by different motivations. This knowledge will help the protector to classify the type of malware detected.
After completing this subtopic, the practitioner should be able to do the following:
In general, malware is any software that is used to do unauthorized things on a user’s computer or mobile device. Wikipedia has a good introduction to malware in general.
Malware can do anything that any software can do, but there are several common capabilities that exist in malware. While some malware is single-purpose, other malware will have multiple capabilities. Frequently-used capabilities include:
This list above is not exhaustive, but outlines the most common malware capabilities. For a great overview of key malware which was discovered in the previous year, check out Patrick Wardle’s blogpost on The Mac Malware of 2023. While this post describes many concepts we will cover later on throughout this learning path (such as VirusTotal scans), it’s a fantastic introduction and overview to the world of malware.
Perhaps one of the most notoriously capable pieces of malware is the NSO Group Pegasus package, which is purpose-built for covert surveillance. Its capabilities are listed in this sales document from the NSO Group.
We highly recommend reading Chapter 5 of the Field Guide to incident response for civil society and media for thematically relevant overview of malware and related concepts, including:
Malware has to get on a targeted person’s device somehow. The methods to do this range from users being tricked into running malicious software to exploitation of vulnerable software and services, including true 0-click attacks.
Once the initial compromise is made, most malware will go through multiple stages of infection (Free, English).
Mobile operating systems have a slightly different architecture from desktop ones. They are usually more locked down and restrict what code can be run on them. This means that malware, too, has slightly different infection paths and methods. Check out the smartphone systems architecture section of the Mobile Forensics Guide for a good overview.
Standard iOS and Android configurations only allow the user to run software downloaded from the official app stores. Malware for those platforms is either installed through such an app store (which means that it was not discovered during Apple’s or Google’s security audits) or by exploiting holes in iOS and Android which stop unauthorized code from running. Alternatively, some malware authors also use social engineering to convince targeted persons to install malicious profiles or other device configurations.
Much of the malware you encounter in your work will be persistent, or able to start running automatically every time the targeted person logs in or restarts their system. Each operating system has mechanisms which automatically run certain software at login, at scheduled times, or when something happens (for example, when a new network connection is made or a program is launched).
Malware can use a wide array of persistence techniques; some of them are reasonably simple (such as adding itself to the list of programs which run automatically at login), with others far more complex and taking advantage of specialized operating system features. If you want to learn more about those, check out this deep dive into the topic and this advanced and comprehensive list of persistence techniques. Many of those techniques include advanced analysis that goes slightly outside of the scope of this learning path; at the same time, it’s a good idea for you to have a general idea of what persistence is and which mechanisms it could use.
Some malware will not aim for persistence. Instead it will run, extract data, and then disappear following a logout or a restart. If attackers want to use the malware’s capabilities again, they simply re-install it on the targeted person’s system. While this can limit the period for which the malware is active on a system and therefore the data it collects, it also makes the malware more difficult to detect, since it leaves fewer traces on a system.
In the process of being installed and performing malicious activities, malware leaves IoCs, or Indicators of Compromise. These are frequently used to identify particular pieces of malware. IoCs could include cryptographic hashes (we cover them later on this learning path) which represent specific executable files, but they can also be connections to network services or particular network traffic, patterns of execution, etc.
For a short summary of what IoCs are and how they could look like, check out pp. 37-40 (from indicators of compromise to defanging) of the Field Guide to Incident Response for Civil Society and Media.
For a long discussion on IoCs and their uses in incident response, see this webinar by CISA (English, 46 minutes).
Check out the IoCs outlined on page 52 of this Amnesty Report into a piece of powerful commercial spyware: they mostly consist of the names of domains which were used as infrastructure during this malware campaign. After you’ve done that, take a look at this page, which collects IoCs from various investigations Amnesty Tech conducted.
There are many different ways to spot indicators of compromise. They include looking through network logs to see if any device tried to contact a specific domain, and checking if any files on a device match certain hashes. If you would like to learn a little more about them, we recommend checking out those articles by Microsoft and Fortinet.
The vast majority of malware infections you will encounter in your career will have been caused by malware that the community knows about. This means that somebody else has already found this malware and shared the IoCs or samples thereof with malware scanning engines. Still, cybercriminals continue to write new malware and adapt existing programs. There is therefore always a small chance that the devices you’re investigating have been infected with malware which has not yet been documented. If you worry that this might be the case, we recommend checking out the Malware Analysis Learning Path, which guides you on how to analyze unknown samples to figure out whether they are malicious.
Not all malware that has been recognized has been extensively documented, either. Many of the samples that can be found on websites like MalwareBazaar might have IoCs associated with them and are known to be malicious, but analysts might not have written up what exactly such malware does. If you find a sample that others flagged up as malicious but which is nonetheless under-documented and you would like to learn more about how it functions and what it does, follow some of the guides on the analysis learning path.
Take a moment to look through Malware Bazaar’s list of recently submitted malware. Read through the descriptions and comments of several malware samples and note what form they take, which delivery mechanism they use, and the like. Some of the malware samples have comments attached to them; check those out as well. Note that not all malware samples will contain details such as IoCs or delivery mechanisms.
Do note that Malware Bazaar also contains some details such as hashes which are only covered in later phases of this learning path.
Do not download any samples at this moment. Simply glancing at the sample descriptions is sufficient at this stage.
Working with a peer or mentor, find two or three reports describing malware infections for a platform of your choice. Make sure that those reports include IoCs. If you cannot find any reports, you can just read through one of those:
Answer the following questions for one of those reports:
Discuss your answers to all those questions with your peer or mentor.
Malware chapter on Field Guide for Threat Labs (Chapter 5)
FreeGood introduction to malware from the perspective of a digital protector needing to understand
Malware - Wikipedia
FreeA good fundamental introduction to the topic which explains some of the basic and moderately advanced concepts needed
The Mac Malware of 2023
FreeAn important overview of macOS malware spotted in 2023. Includes types of malware, infection vectors, persistence mechanisms, and goals.
Pegasus sales document from the NSO group
FreeThis leaked document describes some of the capabilities of Pegasus, a piece of spyware that targets human rights activists among others. It gives a good introduction to how spyware is sold and marketed.
Zero click attacks explained
FreeDescribes what a zero-click attack is, why attackers might be so interested in using them, and why they are so dangerous.
Understanding indicators of compromise for incident response
FreeA video by the US CISA that gives a good overview and introduction to IoCs and how they could be used by incident responders.
Guide to Malware Incident Prevention and Handling for Desktops and Laptops
FreeAn older (2013) guide by the US NIST which comprehensively covers the topic.
Smartphone systems architecture
FreeA look at how mobile operating systems function and how malware can spread on them.
The Predator Files
FreeA malware investigation conducted by Amnesty Tech; includes lists of IoCs on page 52.
Indicators from Amnesty International's investigations
FreeA list of IoCs which Amnesty collected in the course of its investigations.
Microsoft Security: Indicators of compromise explained
FreeA summary of what IoCs are and which forms they could take.
Fortinet glossary: Indicators of compromise
FreeOne more, very useful, summary of IoCs.
Linux Detection Engineering - A primer on persistence mechanisms
FreeA walkthrough on how threat actors establish persistence on Linux systems and how to hunt for these techniques.
Congratulations on finishing Module 3!
Mark the checkbox to confirm your completion and continue to the next module.
Marks the current module as completed and saves the progress for the user.
You've completed all modules in this learning path.