Skip to content

Use Case

There is a device of unknown security status and the owner wants to investigate the possibility of infection or previous compromise. Perhaps you have been handed this device physically, or perhaps you will support the client remotely. Use different off-the-shelf or built-in first party scanning tools as well as integrity checks to identify, analyze, and search for Indicators of compromise (IoC) to identify a breach, or a given suspicious malware.

Objectives

After completing this subtopic, practitioners should be able to do the following:

  • Use popular malware detection tools, such as antivirus or the built-in tools in your OS, to aid in your analysis
  • Understand some basic anti-malware protections within modern operating systems and how to check if they are running or if they have been disabled.

Main Section

Off-the-shelf anti-malware (all platforms)

The least labor-intensive method to detect known malware is to simply use a malware scanner to look at a client’s device’s live system. Note that the quality of antivirus products can vary wildly, but most products catch most known malware. Below are links to some common malware scanners for desktop systems:

  • 🧰 Windows: Microsoft Defender is free and built into Windows. Various commercial AV tools may be used, each with their own pros and cons. Here we will be suggesting MalwareBytes. Consider also AdwCleaner from MalwareBytes for a remover of Adware and Potentially Unwanted Programs1.

  • 🧰 MacOS: We similarly recommend using Malwarebytes. Avast Free Antivirus is also a free option.

  • 🧰 Linux: ClamAV is an open-source antivirus for Linux. It is also available for other platforms

  • 🧰 Android: Various providers such as LookOut provide free or paid Android antivirus and additional mobile security protections. ClamAV is implemented on Android in the Hypatia app via F-Droid.

    • Google Play Protect will scan apps on your phone, even those not downloaded from the Google Play Store. Click the link for more details and directions on how to initiate a scan.

💡 Compared to desktop operating systems, by design antivirus on Android is more limited in its ability; it can scan all installed apps, but isn’t able to look for possible advanced spyware hiding on the system. Moreover, it may not be able to remove malware it detects.

  • 🧰 iOS: There are no comprehensive malware scanners for iOS. The security built into iOS means that apps aren’t able to scan other installed apps. Several antivirus vendors have apps for iOS, but these tend to have other functions, such as blocking phishing websites or checking if the phone is up to date.

Advice and skills for using off-the-shelf antivirus to detect Malware

One of the first steps you can take when looking for malware is installing an antivirus program and letting it run a scan on its system. After the scan is complete, most programs will generate some kind of log that provides additional information about scan results, and we recommend taking a look at it. If antivirus programs catch a potentially suspicious file, they might ‘quarantine’ it, which means that the file will be locked away from the rest of the operating system so that it cannot be accidentally opened or cause further havoc. If you would like to do further analysis on that file, you might need to take it out of quarantine; check out your antivirus program’s documentation on this topic.

It should be noted that modern malware doesn’t always involve malicious files. Instead, it may involve legitimate scripts performing malicious tasks that are made persistent in some way. Antivirus apps will scan for such tasks, thus in the logs it provided, be mindful not to only expect ‘files’.

You should be aware of the limitations of antivirus programs and why they are not a total cure for malware. Different antivirus programs use different detection engines. Some engines will detect some types of viruses and other malware, but no engine is 100% effective.

For this reason, in case you have a sample, you may prefer to upload potentially suspicious files to VirusTotal, which checks the file using a suite of commercially available engines and provides other information that can help you determine whether a file is malicious. Do note that if you upload a file to VirusTotal, it will remain on the website and can be downloaded (and searched for) by anyone with a paid account on the site. As such, if you are dealing with files that contain potentially sensitive information or you don’t want the fact that this file is being analyzed to become publicly known, it’s best to generate a hash of the file2 and search for this on VirusTotal instead. Finally, remember that VirusTotal only uses static engines and its detection can therefore be less effective than that of an antivirus running on a live system. See Subtopic 8 on sample-based Detection for more on this skill. For more on VirusTotal skills, complete the activity in Chapter 7 of the Field Guide to Incident Response for Civil Society and Media.

While modern antivirus engines try to look for malware-like behavior and block executables which meet this criterion, those tests are still relatively rudimentary. Antivirus mostly recognizes malware based on IoCs that were submitted to it; as such, it rarely picks up on new or lesser-known malware.

In addition, adversaries will often test their malware against well-known antivirus programs and modify it so that it isn’t easily detected, for instance by using obfuscation, encoding, compression, and encryption. Some malware will attempt to disable antivirus programs or add itself to an exception list so that it is not scanned. Other malware can trick users into disabling them. For this reason, we recommend installing a new antivirus program on a potentially compromised system and running a scan with that. You can uninstall the program afterwards.

When you do find malware or adware on somebody’s computer, including in cases where it is commodity malware or adware, it is useful to work with the owner of the device to understand how the malware may have been installed on the device (described in Subtopic 10) and then clean up the infection (described in Subtopic 11). Understanding how the malware was installed may point to lack of controls, awareness about risky behavior, or even supply chain issues (e.g., devices shipped pre-installed with potentially unwanted programs) to be discussed and addressed.

Triage/Checklists To check for missing protections

All modern operating systems use some form of built-in protection or so-called ‘walled gardens’ (such as app stores or Smart Screen) which restrict users to executable files which the operating system deems safe. By checking to see if these protections have been disabled, removed, or put in an error state, you will gain a valuable triage indication that further compromise may have occurred. If any of those protections are not working, it does not necessarily mean that they were disabled by malware; a user could have turned them off manually in order to run certain software or they could have been targeted by a social engineering attack which convinced them to disable some of those features. If you re-enable those protections, it will likely stop a lot of malware from running or restrict the damage which it can cause to a system.

One thing you can do on all systems is check all web browsers that are installed and see if they have any new extensions which you do not recognize. If they have such extensions, run a web search to see what they do, if they could potentially be malicious, and, if they are potentially malicious, what sort of malware could have installed them.3

For all devices, we would recommend checking out this quick triage checklist.

Windows

Check out the Windows Defender Security Center (or Windows Security/Security at a glance), which lets you quickly glance at several Windows security settings, including whether Windows Defender is currently up and running. Do note that Windows Defender’s antivirus features might be automatically disabled if you install a third-party antivirus. This is expected behavior. In either case, a malicious program may have succeeded in adding itself to an exception list (allowlist) instructing the anti-malware tool not to check it. You can verify that there are no unwanted exceptions on Windows Defender using these instructions and other third party anti-malware products may offer the same functionality. The settings panel will let you check the status of several other built-in protections, such as Reputation-based Protection, Core isolation, and Secure boot, among others.

Windows uses Smart App Control (previously called SmartScreen before Window 11, which is now the web-based version of the product integrated in the Edge Browser) as a mechanism to check the reputation of executables before they are run. Check Smart App Control (Win 11) in the Windows Security settings to see in case it has been disabled. Look for Smart Screen settings in earlier versions of Windows.

MacOS

  • macOS has several mechanisms which aim to stop malware from running. Still, a malicious actor could find ways of bypassing those. Read about the different protections which exist on macOS. This advanced guide provides an in-depth look at macOS protections and at the databases they use. Advanced users could look through those databases to spot unusual activity, though this is in-depth forensics work which goes beyond the scope of this learning path.
  • One of the most important anti-malware mechanisms on macOS is called Gatekeeper. Every macOS system should have Gatekeeper enabled, especially for devices which run sensitive data. There have, however, been cases when malware disabled Gatekeeper protections so as to be able to run further malicious code on macOS systems. Users might have been targeted by social engineering attacks that persuaded them to turn off this feature. You can run “spctl –status” on the macOS Terminal to see whether Gatekeeper, its standard anti-malware measure, has been enabled or disabled.4 If Gatekeeper is disabled, make sure to turn it on (this will stop most malware from running) and investigate, perhaps by checking command line history, how this could have happened.

iOS

  • iOS supports loading up custom profiles. Those are typically used to connect to corporate or university networks, but an adversary could potentially use them to intercept your traffic. Go to the settings for your iOS device and check if any profiles have been installed. If any profiles look suspicious and the user does not recall installing them, it could be a sign of malicious activity. In this case, it’s good to document everything you can find about this profile, take screenshots, and then remove it.
  • iOS also has Shortcuts, which are typically used to automate certain functions on the device, such as compressing images or converting text. The app is usually quite good at describing what the shortcuts do in plain language (though some shortcuts allow you to run custom JavaScript). Just like with profiles, if you see any shortcuts which appear to be suspicious (note that each iOS version might install some new ones, so it’s best to read up on them as well), document them through screenshots and then remove them. In general, it’s incredibly difficult for malware to install custom profiles or shortcuts; it’s far easier for an attacker to load them through social engineering or by having brief access to an unlocked device.
  • Consider the security of the users’ iCloud account, as compromise of this account can lead to access to significant iOS device data. Complete a review of Apple ID account security and make changes such as password changes, 2FA, app access removal, and other device sign-out if necessary. Apple’s Safety Check contains a review feature which could help you with this.
  • Adversaries would sometimes send text messages or iMessages with malicious links to targeted persons. If clicked, this link could contain a malware or social engineering payload. It’s a good idea to look through recent iMessages and text messages to see if any contain suspicious links or other content.
  • For more on iOS triage basics, check out chapter 12 of the field guide.
  • Some adversaries try to add a new device which they control to the list of linked devices in a targeted person’s messenger such as WhatsApp or Signal. That way, all of the messages that the targeted person would send and receive would be copied to the adversary’s device as well. This attack is usually caused by an adversary having direct physical access rather than malware, but checking for unrecognized linked devices in WhatsApp, Signal, Telegram, and other messengers should also be a key part of the triage process.

Android

  • For Android, read through chapter 8 of the field guide, which shows how you can triage potentially suspicious apps by looking at the various permissions (such as access to your photos, camera, or microphone) that they are requesting.
  • Check for Apps given extra control over the device by reviewing apps listed and enabled under Device Admin Apps in Android settings. The user should know which apps have been granted these privileges - normally either corporate enterprise apps or official device theft apps which allow remote wipe. In case unrecognized apps have been granted admin permissions, disable them and investigate further.
  • Install Unknown Sources is another Android permission which can be granted to an app to allow it to install other apps. This circumvents the ‘walled garden’ protection of official app stores like Google Play Store or Galaxy Store. In some cases this may be desirable, as in the case of the F-Droid open source app store. However if you find that bluetooth, a browser, an instant messenger, a files app or sending/transfer app have been granted this permission, it indicates the device owner has installed apps from outside of safe app sources and further investigations will be required.
  • Adversaries would sometimes send text messages with malicious links to targeted persons. If clicked, this link could contain a malware or social engineering payload. It’s a good idea to look through recent text messages to see if any contain suspicious links or other content.
  • Check in the App Info for the app in the if it is possible to uninstall the app. If it isn’t, this is a pre-installed app. This could still be an issue (some cheaper phones have malware pre-installed) but excludes targeting and also far less likely on more expensive phones.
  • Check if Google Play Protect is enabled.
  • Some adversaries try to add a new device which they control to the list of linked devices in a targeted person’s messenger such as WhatsApp or Signal. That way, all of the messages that the targeted person would send and receive would be copied to the adversary’s device as well. This attack is usually caused by an adversary having direct physical access rather than malware, but checking for unrecognized linked devices in WhatsApp, Signal, Telegram, and other messengers should also be a key part of the triage process.

It’s worth noting that security configurations vary between different versions of iOS and Android. More recent versions of iOS, for example, require profiles to be digitally signed, which should make it harder for adversaries to leverage them. Similarly, many software updates change the way systems deal with permissions or notifications. A good rule of thumb is that successive versions of iOS and Android tend to have stricter security requirements when it comes to automations, apps, and permissions.

Practice

Windows and macOS

  1. Windows: look through the Windows Defender Security Center. Do you notice anything suspicious?
  2. macOS: use the command line to check if Gatekeeper is enabled.

Android and iOS

  1. Look through several of your apps and see which permissions they have. Are there any apps you do not recognize or some which ask for too many permissions? On Android: are any of those apps which you do not recognize pre-installed?
  2. iOS only: check your device for shortcuts and installed profiles you do not recognize
  3. Use a search engine to find the full text of a text message you have received that might have looked weird or suspicious. If you have no weird or suspicious text messages, search for a standard message from your network operator. How much information can you find online about the number which sent this message and about the message itself?

Skill Check

Android and iOS

  1. Android: Read through the Android documentation on permissions. There is no need for you to understand the source code, the goal is just to gain a general understanding of how permissions work.
    Think about what a malicious application could do and what data it could extract with the permissions outlined in the Android specification, and also about what steps the operating system takes to minimize the risk of apps abusing permissions. Write down a list of five to ten actions a malicious application that has wide system permissions could do, and note down two to three undesirable situations which app permissions best practices could mitigate.
    If you are working with a peer or mentor, discuss the list you compiled above with them, and have them verify that you have correctly understood app permissions, how they could be abused, and Android mitigations which prevent this from happening.
  2. iOS: Read through the description of iOS Lockdown Mode, a special setting for individuals at high risk of targeted attacks, especially through mercenary spyware. List some answers to the following questions. Do note that there are no exact right or wrong answers to those questions, since Lockdown Mode, like all other security mechanisms, aims for a fine balance between security and usability. Some of those questions require deeper knowledge of prior attacks against iOS (we encourage learners to look up ‘jailbreaking’ when researching the topic) and might require a little additional research.
    1. Why does Lockdown Mode block most attachments on Apple Messages? Why does it not block them on applications such as WhatsApp?
    2. Can you think of a reason why Lockdown Mode restricts certain web browsing features?
    3. Lockdown Mode, once enabled, does not allow for the installation of custom profiles. Why do you think profiles which were installed before the user turned on Lockdown Mode are still allowed to operate? If you are working with a peer or mentor, discuss your answers to the above questions with them and have them verify that you have understood Lockdown Mode.

Learning Resources

Windows Defender

Free with an active Windows license

An anti-malware solution made by Microsoft, available to all Windows users for free.

Languages: Multiple
Visit Site

MalwareBytes

Free with premium features

A popular antivirus scanner often used within civil society.

Languages: Multiple
Visit Site

Avast

Free with premium features

Another antivirus scanner with a solid free tier.

Languages: Multiple
Visit Site

ClamAV

Free

An open source virus scanner.

Languages: Multiple
Visit Site

Lookout

Multiple pricing tiers

A well-known company providing Android security services.

Languages: Multiple
Visit Site

Hypatia

Free

An open source malware scanner for Android, based on ClamAV.

Languages: English
Visit Site

Google Play Protect

Free

Quick documentation on Google Play Protect, an additional and highly recommended security tool for Android.

Languages: Multiple
Visit Site

Identifying compromised devices: an intermediate guide

Free

Some quick signs we can look for when trying to figure out if a device is potentially compromised by malware. Note that these steps are just the start and do not replace scans and deeper analysis.

Languages: English
Visit Site

Windows Security

Free with every Windows install

A central point in a Windows operating system where you can check at a glance which security measures have been enabled and which have not.

Languages: Multiple
Visit Site

Protecting against malware in macOS

Free

An article by Apple outlining some of the security mechanisms present within macOS.

Languages: Multiple
Visit Site

Gatekeeping on macOS

Free

A more in-depth article describing how Gatekeeper, a key macOS security mechanism, functions.

Languages: English
Visit Site

macOS trojan disables gatekeeper to deploy malicious payloads

Free

A case study of how malware managed to disable macOS security mechanisms in order to spread itself on a system.

Languages: English
Visit Site

How to look at your command history list in macOS terminal

Free

A brief guide to browsing through command line history on macOS terminal, which can be useful if you’re trying to figure out what prior commands were typed and if any of them affected security mechanisms.

Languages: English
Visit Site

iOS security checks and mechanisms

Free with macOS and iOS systems

Some security checks you can conduct when doing triage on iOS systems:

Languages: Multiple
Visit Site

iOS security checks and mechanisms

Free with macOS and iOS systems

Check for app tracking permissions on iOS systems

Languages: Multiple
Visit Site

iOS security checks and mechanisms

Free with macOS and iOS systems

Apple’s Safety Check tool

Languages: Multiple
Visit Site

Checking for linked devices on WhatsApp

Free

Articles for:

Languages: English, with apps and help guides localized into many other languages as well
Visit Site

Checking for linked devices on Signal

Free

Articles for:

Languages: English, with apps and help guides localized into many other languages as well
Visit Site

Checking for linked devices on Telegram

Free

Articles for:

Languages: English, with apps and help guides localized into many other languages as well
Visit Site

Notes


  1. A Potentially Unwanted Program is something that the user does not want on their system, even if they might have downloaded and run it themselves. It could include programs which mis-advertise their functionality or run many ads. ↩︎

  2. A hash is like a short fingerprint of a file—it can be used to identify a unique file without revealing its contents. You can calculate a hash by using the command line on Windows, macOS, and Linux↩︎

  3. Having a malicious extension on your system does not necessarily mean that you have other types of malware as well. An attacker could also use social engineering to convince a user to install malware. ↩︎

  4. If you want to learn more about the spctl command, which is responsible for Gatekeeper, run man spctl in the macOS Terminal to see the manual/ documentation page. ↩︎