I was recently playing around with my favourite C2 framework which is Sliver from Bishop Fox. For those of you who that haven’t used it, it runs completely in the terminal unlike for example, Cobalt Strike or Havoc.
Whilst using it,I noticed that a lot of times when I ran certain commands that Microsoft Defender would kill my connection between my implant and C2 server. This mainly occured when running commands like ‘execute’ and more specifically when I wanted to run ‘execute -o klist’ to view my cached Kerberos tickets.
The reason for this is the infamous ‘fork and run’ IOC (indicator of compromise) that Defender picks up on. Essentially when certain commands are run via a lot of C2’s they create a sacrifical process (the fork) to run the command. When Defender sees this forking it flags it as supicious and kills the connection.
To avoid this, ‘beacon object files’ (BOF’s) were created, which are small C programs that run within the current process without forking and are a lot more OPSEC friendly. These BOF’s are normally not meant to be long running programs but used to quickly get some information back so keep that in mind when designing them.
So to make a long story short, I noticed that the ‘klist’ command wasn’t supported as a BOF so I decided to port a klist BOF from Cobalt Strike to Sliver.
Before I go any further, I want to say that I am standing on the shoulders of giants here and that I didn’t build this from scratch but just refactored the Cobalt Strike BOF created by OutflankNL to now work with Sliver.
To get BOF’s to work with Sliver you ideally want 3 files:
extension.json:
The quickest way to add these 3 files to Sliver is as follows.
To display all the cached Kerberos tickets issue the command:
To purge all the cached Kerberos tickets issue the command:
After speaking to the Sliver devs over at the BloodHoundGang Slack channel, they have said they would like to include it in the Armory. They advised me to open an issue on their Github so it can be verified for inclusion. This is now located here and has gone live on the official repo:
https://github.com/BishopFox/sliver/issues/1433
This process has been lots of fun and a great learning experience. It gave me an opportunity to work with such an interesting C2 framework as Sliver and to improve my knowledge on how it’s BOF framework operates. Hope it proved to be informative and happy hacking!