Certipy
About
Certipy is a tool for Active Directory Certificate Services enumeration and abuse. It's is an offensive tool for enumerating and abusing Active Directory Certificate Services (AD CS). If you're not familiar with AD CS and the various domain escalation techniques,from the github, a good resource is: Certified Pre-Owned by Will Schroeder and Lee Christensen.
Install
Using pip
Usage
We can use the find
argument to enumerate AD CS certificate templates, certificate authorities and other configurations and with -vulnerable
it can show us what "ESC#"(Escalation number, for a full list, checkout the Github they are vulnerable to. In this example, it's Vulnable to ESC7, which is when a user has the Manage CA
or Manage Certificates
access right on a CA.
So in this example we have Ravens credentials and can upgrade her account to have additional permissions. If you only have the Manage CA
access right, you can grant yourself the Manage Certificates
access right by adding your user as a new officer.
The SubCA
template can be enabled on the CA with the -enable-template
parameter. By default, the SubCA
template is enabled.
If we have fulfilled the prerequisites for this attack, we can start by requesting a certificate based on the SubCA
template. This request will be denied, but we will save the private key and note down the request ID. With our Manage CA
and Manage Certificates
, we can then issue the failed certificate request with the ca
command and the -issue-request <request ID>
parameter.
With our Manage CA
and Manage Certificates
, we can then issue the failed certificate request with the ca
command and the -issue-request <request ID>
parameter.
And finally, we can retrieve the issued certificate with the req
command and the -retrieve <request ID>
parameter.
Now that we have the Administrator.pfx file we can obtain the admin hash using the auth
argument. From the github "The auth
command will use either the PKINIT Kerberos extension or Schannel protocol for authentication with the provided certificate. Kerberos can be used to retrieve a TGT and the NT hash for the target user, whereas Schannel will open a connection to LDAPS and drop into an interactive shell with limited LDAP commands. See the blog posts for more information on when to use which option"
Last updated