Skip to content

Latest commit

 

History

History
105 lines (85 loc) · 4.33 KB

README.md

File metadata and controls

105 lines (85 loc) · 4.33 KB

AggressorScripts

Disclaimer: These scripts are to help you audit your machines or machines you're authorized to audit. Don't use these on anything you don't have the owner's explicit permission to test on. That's mean. Also illegal.

cdolla.cna

Find targets where you're local admin and list users who logged in within the last 90 days.

Like Chris King's (raikiasec) CredNinja but less fancy. And in Aggressor. (See also: https://github.com/Raikia/CredNinja)

Usage:

1. To scan a list of targets
 > Select all hosts in the Targets tab, right click, add note "cdolla"
 > From the beacon with the correct token: cdolla [-users]
2. To scan a single target
 > cdolla 10.10.10.10 [-users]

Notes:

  • c is an alias for cdolla
  • if -users is specified, will also print users who logged in within last 90 days
  • The list of users will look like "UserName1 (31), Username2 (48)" where the numbers in parentheses are days since last login

compromised_log.rpt

This report generates an appendix with tables of all hosts where a beacon was spawned and all users that were compromised/added to the "Credentials" tab.

Usage:

1. Import by clicking Cobalt Strike > Preferences > Reporting > Select template
2. Generate by clicking Reporting > 1. Compromise Log

Notes on "Affected Hosts":

  • Deduplicated by hostname
  • AccountsUsed -> User accounts that beacons were spawned under.
  • FirstSession -> Date/time of first session/beacon opened on a host.

Notes on "Affected Users":

  • Deduplicated by "username::realm"
  • Domain -> will include hostname if it's a local account
  • Source -> host where the credential was gathered
  • Cleartext -> if password is not NTLM hash && source == mimikatz
  • Cracked -> if password is not NTLM hash && source == manual (generalized but assuming was added after cracking)
  • Hash -> at least one password entry for the user was an NTLM hash

credpocalypse.cna

Monitor beacons and pick off users as they log in. Set the time interval (default 5m) and Credpocalypse will watch your beacons for new users in the running processes. If they aren't in the Credentials tab already, Credpocalypse will run logonpasswords.

Pro Tip: Load/run with ./agscript to watch all beacons headlessly. Output will include timestamp/beacon IDs to track when logonpasswords was run.

NOTE: Your beacon will only be interrupted if logonpasswords is run. There's no callback, so I can't smother the output. :-/

NOTE AGAIN: In the Watchlist and Script Console you'll see "Running on PIDs: x". X is the PID of the beacon process on the remote system (what you see on the right side of your beacon list). In the background, it's actually using the beacon IDs assigned by Cobalt. I just print the PID to make it easier for you to glance at beacons and know where Credpocalypse is running.

Usage:

  1. Aliases
begin_credpocalypse		- watch current beacon
end_credpocalypse [all]		- stop watching current/all beacon/s
credpocalypse_interval [time]	- 1m, 5m (default), 10m, 30m, 60m
  1. Commands
begin_credpocalypse		- watch *all* beacons
end_credpocalypse [all]		- stop watching all beacons
credpocalypse_interval [time]	- 1m, 5m (default), 10m, 30m, 60m
  1. Right click beacon(s) to get a pop up menu that lets you
  • Add to watchlist
  • Remove from watchlist
  • Change time interval that Credpocalypse checks watchlist
  • View the watchlist

save_log.cna

Use to export command output, so you don't have to grep beacon logs for info.

Usage:

start_log
[commands]
stop_log

Output: cobaltstrike/saved_logs/[beacon id]_yyyyMMdd_HHmmssSSS.log

[2017-12-27 11:36:24 EST] BID: 12345 Tasked beacon to run: whoami
received output: 
WORKSTATION\Administrator

utils.cna

A collection of "sub" functions to do random things. Copy into your CNAs and refer to the "alias" functions at the bottom of the file for examples on how to call each utility.

Included:

get_env COMSPEC					- print value of env variable
get_pid explorer				- print 1st PID for given proc name
get_users					- return array of logged on users
lower C:\Users\Public\Downloads\tmp.txt 	- lc() without breaking on \'s 
parse_args -arg1 val1 -arg2 val2 -switch1	- easier than positional arguments
upper C:\Users\Public\Downloads\tmp.txt 	- uc() without breaking on \'s

Note: Raffi wrote the get_pid function (https://www.cobaltstrike.com/aggressor-script/functions.html#bppid). Included here for easy reference.