Checking my devices for malware - Part 1 - OS X
data:image/s3,"s3://crabby-images/9dd92/9dd9298847c0bab4f1832ca53c1bf56f34d5c5f0" alt="Checking my devices for malware - Part 1 - OS X"
Christmas is that time of the year where I dismantle, burn and rebuild all my machines.
There are 4 operating systems that I use (as base operating systems):
In this series of posts I will cover the following topics for each operating system:
- The all important - WHY?
- Operating system check; &
- Checking for persistence.
Important to note, this is not a digital forensics or secure configuration procedure.
The all important - WHY?
If you're wondering if I run endpoint protection - I do. If you're wondering why I still need to perform these manual checks - I'm paranoid. My mantra in this regard,...
data:image/s3,"s3://crabby-images/ddef5/ddef52196ce2ae5cefbdfe0b8fdd6574bb0ef07a" alt=""
Here is a good example, of when a little paranoia goes a far way,...
data:image/s3,"s3://crabby-images/84360/84360fc1ddebde7e1b663fe3577009d3264dd230" alt=""
If you think that this won't happen to you (or us) - think again,...
data:image/s3,"s3://crabby-images/f6a81/f6a81cb58268eba859d4e05570d40b7b694dd641" alt=""
Operating system checks
This is my quick list to detect clear and present danger:
The essential mix
You first have to confirm the basic controls - I won't go into too much detail here:
- System update - this includes removing unnecessary services, creepware, etc.
- Secure configuration - this includes strong password, encryption, policies, etc.
- Security controls - this includes firewall, endpoint security, data backups, etc.
A good resource is the CIS security standard which details the most salient points.
data:image/s3,"s3://crabby-images/a9d40/a9d407550af55a70439d205bcbe718165e857f9f" alt=""
Initialisation check
On the initial boot - I like to check five things:
- Active user directory;
- Network connections;
- Files (active) opened;
- Processes running; &
- Trace potential issues.
This process (and even some commands) will be the same across any *nix system.
We can use the man page to display online documentation for any of the utilities.
man dscl
data:image/s3,"s3://crabby-images/b0484/b04844f9923382fe36c3eadb870350fe2f4978d1" alt=""
Active user directory
We can use dscl (directory service command line utility) to list all accounts:
dscl . list /Users
data:image/s3,"s3://crabby-images/7172f/7172fed7d05e63e8051631477458fbc0dc27197d" alt=""
If you're unsure about something (e.g., nobody user account) then check it out:
data:image/s3,"s3://crabby-images/6c3ca/6c3ca9d04971659ba78bee8bd715b45759f618d2" alt=""
We can use w and last utilities to analyse both current and past user behaviour:
w
last
data:image/s3,"s3://crabby-images/3c2d8/3c2d848bdb6a70822722de177c659d8b4d4cbe13" alt=""
Once we have confirmed there are no signs of malicious activity - we can move on.
Processes running
We use ps (process status utility) to analyse all running processes on the system:
ps -axo user,pid,ppid,start,time,command
data:image/s3,"s3://crabby-images/0b038/0b038d7247b41a43d4a367df6f3bef286d1b57a1" alt=""
You can also see the memory and CPU (central processing unit) utilisation using:
ps -axo user,pid,ppid,%cpu,%mem,start,time,command
data:image/s3,"s3://crabby-images/ebe99/ebe995f0767a84546182e943954d0ba0d0bce435" alt=""
Alternatively, use the top utility to see real-time system memory and CPU usage:
top
data:image/s3,"s3://crabby-images/6f1cc/6f1cc551c145f8ab129479ca4d39c0d3c82a59a6" alt=""
Let's say something catches your eye - like the process below (spidey senses tingle).
data:image/s3,"s3://crabby-images/686f8/686f8ff4a747101826cd059932e566bfb4a5f9e1" alt=""
Well let's check it out,... let's check if it's signed and where it launched from,...
sudo launchctl procinfo 346
data:image/s3,"s3://crabby-images/42eb1/42eb1d33eb7626741fa31b88a3e6cba8f727165e" alt=""
We can use ktrace (debugging) to analyse all system calls made by an application.
Network connections
Next, check network services exposed and any potentially malicious connections.
netstat -an | more
data:image/s3,"s3://crabby-images/22d3b/22d3b166af1695de2929e51ed0cc96c0b962e81d" alt=""
Again, if you see something you're not sure of - just confirm it with a quick check.
host 8.8.8.8
whois 8.8.8.8
data:image/s3,"s3://crabby-images/69ff3/69ff37bd1af41ca8fb48243221d3cbb54230f4bd" alt=""
Open files
To map or trace services and processes use lsof. It (lsof) lists the file handles open.
lsof
data:image/s3,"s3://crabby-images/2b209/2b209348eae81553eb2f79f37fcb41710aca9527" alt=""
Again, if you're unsure what something is - check it (from an authoritative source).
data:image/s3,"s3://crabby-images/5c139/5c13974004a0348372c0d45434173d64fa9c3f1a" alt=""
You can also use the -i option to select internet files or sockets.
lsof -i
data:image/s3,"s3://crabby-images/5cbb8/5cbb83a9764b4dac52b43df836058016026fbfcc" alt=""
You can go a step further and filter by protocol, IP address and even port number.
lsof i :443
data:image/s3,"s3://crabby-images/d35d1/d35d18afa15a70a9b8b7cfe3f89fbfc5208777dc" alt=""
Checking for persistence
Persistence is simply how malware ensures it remains active on an operating system.
There is a great resource from the book "The Art of Mac Malware" by Patrick Wardle.
data:image/s3,"s3://crabby-images/5ca53/5ca534398ed27863afc9b449a378d96ac64031e4" alt=""
This is Chapter 2 from the book, hosted on Patrick's website, covering persistence:
https://taomm.org/vol1/pdfs/CH%202%20Persistence.pdf
You can then download KnockKnock to help you process persistence checks.
data:image/s3,"s3://crabby-images/ba696/ba696b6164a55cac2113d2cfccf3031e20d37603" alt=""
Conclusion
This is the quickest and easiest way that I have to check for any malicious indicators.
I often run tools like Snort, OSquery and Zeek alongside my (commercial) endpoint protection suite. I highly recommend it as a learning exercise, since it never fails to produce interesting results.