Over the past few days I have been trying to get back into playing around with Cobalt Strike to up my Red Teaming game. As part of that, and to get some practice, I thought I would try to write a simple aggressor script.
The sole purpose of the script would be to email me when a beacon checks in. I imagine after a phishing campaign is sent out, you don’t want to be sitting by your screen constantly waiting for a beacon, so this might make life easier.
The two pieces of code required are:
An aggressor script loaded into Cobalt Strike to monitor when a beacon checks in. This I simply called ‘email.cna’.
A Python script named ‘emailme.py’ that is called by the aggressor script to send an email on check in.
Scripts
The aggressor script can be seen below, and is simply placed within the ‘on beacon_initial’ function which gets called on beacon check in. It then extracts some fields of interest from the beacon such as the IP, computer name and username and passes them to the Python email script.
email.cna:
Next up we have to build the Python script which I have also shown below. It is quite self explanatory but I guess some mail providers might require app passwords and the like, such as Gmail which might make it trickier.
If this is the case try to use a more basic email account if you have one that maybe offers you more control.
emailme.py:
Finally the last thing to do is to load the Aggressor script into Cobalt Strike as shown below, by using the ‘Script Manager’ window.
The next time a beacon checks in you should receive an email that it has done so. This has been fun playing around with CS again and hopefully this saves you some time.
I think next up I might build a complete C2 infrastructure on Azure, with redirectors back to my C2 hosted elsewhere, just to practice that aspect of Red Teaming. Stay tuned!