ACTIVE
- Layout for this exercise:
data:image/s3,"s3://crabby-images/0328f/0328fbf7103fae065a4aabc22383d590af7c378f" alt=""
1 - INTRODUCTION
- The goal of this exercise is to develop a hacking process for the vulnerable machine Active, what is a retired machine from the Hack The Box pentesting platform:
https://www.hackthebox.eu/
2 - ENUMERATION
- Active's IP is 10.10.10.100:
data:image/s3,"s3://crabby-images/ce40b/ce40b9f9533da8ef0a118668047d9c93d8b15fd8" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/e8234/e823460d423afd1d7ab6b8017d38a94972cba1d2" alt=""
- So we have a Microsoft Windows Server 2008 R2 SP1 running an Active Directory with a domain active.htb
- Also, as we will see later it is of crucial importance the fact that Active has a Kerberos server running at port 88.
- Because port 445 is open we run enum4linux to enumerate SMB and detect potential shared folders:
data:image/s3,"s3://crabby-images/1e6f0/1e6f072c2ec271fd1ae011273669210984a68281" alt=""
data:image/s3,"s3://crabby-images/bf63c/bf63cc878146fb3c0a82e6cbfa149ba38400f9e0" alt=""
- The share Replication allows Anonymous login, and it is probably a replication of SYSVOL
- SYSVOL stores the Group Policy Preferences holding information about users and groups of the network, so it will be a promising vector attack.
3 - EXPLOITATION
- Let's access /Replication with smbclient and Anonymous login:
data:image/s3,"s3://crabby-images/8038c/8038c7d42cfb0eaa837590df1696cbb93819cae1" alt=""
- Listing content:
data:image/s3,"s3://crabby-images/6aa95/6aa95627faaae9ff7c148b9659debde410860be5" alt=""
data:image/s3,"s3://crabby-images/6decb/6decb010b725c2308be526269eb1238497a974e6" alt=""
- Inside Policies there are two folders:
data:image/s3,"s3://crabby-images/d3aa2/d3aa2deeb7063e47f8838c1febf654a676f168c2" alt=""
- Going with the first one:
data:image/s3,"s3://crabby-images/ba694/ba694f8879962efed9d56d9ff05393fe9d9de747" alt=""
- Inside /MACHINE/Preferences/Groups there is the file Groups.xml associated with the Group Policy Preferences (GPP):
data:image/s3,"s3://crabby-images/57af3/57af32e6a4ae0def7c7a9eed17eca924f523457d" alt=""
data:image/s3,"s3://crabby-images/87edb/87edbea0b5b237add9f05c3477a191bb7ea61f81" alt=""
data:image/s3,"s3://crabby-images/9ba9b/9ba9bf8db5041f382d75475d91402f92552277be" alt=""
- Also, /Replication could be explored recursively in this way:
data:image/s3,"s3://crabby-images/b2ae5/b2ae56689b8f192f97a21fcac9e413d3e344d218" alt=""
- Anyway, downloading and reading Groups.xml:
data:image/s3,"s3://crabby-images/b5899/b58990b5a570a1a0f74a7e44b1080d5de001e4ff" alt=""
data:image/s3,"s3://crabby-images/2e8cb/2e8cb89aaa8e2b0f7cc660c4a23abe0f6efa0515" alt=""
- So we have found the username and the cpassword atributes.
- cpassword is the name of the attribute that stores passwords in a Group Policy Preferences item:
data:image/s3,"s3://crabby-images/2a756/2a7569ce57ee395a6d08cf75fb0abfdc26a972f5" alt=""
data:image/s3,"s3://crabby-images/d5f92/d5f92d3f4cad7a01f83f2888713477e5b61dba25" alt=""
- Let's store these credentials for later usage:
data:image/s3,"s3://crabby-images/e625b/e625be1fc42d1cdbb7aec666fea399b7dee34828" alt=""
- The script Gpprefdecrypt.py decrypts local user password cpassword:
data:image/s3,"s3://crabby-images/98995/98995c1ca6188427c8f2e5b510175c89b7fd9672" alt=""
data:image/s3,"s3://crabby-images/33d53/33d53e8b0bfb09d6a49d107943162660e564fe00" alt=""
data:image/s3,"s3://crabby-images/0e54b/0e54bb12ace41bd741bcb67ee8979e8e84b4682d" alt=""
- Applying gpprefdecrypt.py over cpassword:
data:image/s3,"s3://crabby-images/7d9d4/7d9d495fb0c179c533ba8e4d1bc74082291cfb1b" alt=""
- Connecting again with smbclient, now with the recently achieved credentials:
data:image/s3,"s3://crabby-images/58a35/58a35b50f3d9ea164111583cc745255fb1e6ba28" alt=""
- Listing content:
data:image/s3,"s3://crabby-images/c2855/c28554dfce98e473bc5163d1b14a775a46fce24e" alt=""
- ldapsearch and this complicated command yields active accounts for Active Directory:
https://www.openldap.org/software//man.cgi?query=ldapsearch&apropos=0&sektion=1&manpath=OpenLDAP+2.4-Release&format=html
data:image/s3,"s3://crabby-images/d9378/d937816d66bf0720d3d83419fe97d44e8dbaa1ad" alt=""
- Also, GetADUsers.py is useful to enumerate the Active Directory user accounts:
https://github.com/SecureAuthCorp/impacket/blob/master/examples/GetADUsers.py
data:image/s3,"s3://crabby-images/36214/3621480e509f93de78830d11273fee6b9a063706" alt=""
data:image/s3,"s3://crabby-images/ffa5b/ffa5bf29bf5e1bcb0123e20e3aa5d44b408b9979" alt=""
4 - CAPTURING THE 1st FLAG
- Going to the user SVC_TGS home folder:
data:image/s3,"s3://crabby-images/cdffc/cdffc08d708f1f914cf2302d0bc1e06f7563ffc9" alt=""
- Getting and reading user.txt we are able to read the 1st flag:
data:image/s3,"s3://crabby-images/d06df/d06dfc85aadf3f6d596f6775760a76c24805cc9e" alt=""
data:image/s3,"s3://crabby-images/340f3/340f34ab81522fe0614dbcc31eadc802f6cc4a94" alt=""
data:image/s3,"s3://crabby-images/598a6/598a665e345088a9b5080e2895248a1d9d76623d" alt=""
5 - PRIVILEGE ESCALATION
- However, access to the Administrator home folder is denied, so we need Privilege Escalation:
data:image/s3,"s3://crabby-images/f7ddc/f7ddc0b36559510c7061b890158db733369d7b54" alt=""
- The Nmap scan yielded the result that Kerberos service was running at port 88, as we saw before.
- The Kerberoasting attack was the subject of Tim Medin’s presentation Attacking Microsoft Kerberos: Kicking the Guard Dog of Hades at Derbycon 2014.
https://www.scip.ch/en/?labs.20181011
- The attack involves an effective method that allows normal domain users to get their hands on credentials for service accounts.
- This attack is most likely to succeed when service accounts have weak passwords.
- Kerberoasting works by extracting the hash of the Kerberos TGS (Ticket Granting Service) ticket reply, what is encrypted with the NTLM password hash of the account.
- Kerberos uses Service Principal Names (SPN) to identify an account associated with a service instance.
- The Python script GetUserSPNs.py is able to extract hashes of Service Principal Names that are associated with normal user accounts:
https://github.com/SecureAuthCorp/impacket/blob/master/examples/GetUserSPNs.py
data:image/s3,"s3://crabby-images/da8a9/da8a97c46c8c00f6b07038be503e6140bf8ce0cc" alt=""
- Downloading the script and giving execution permissions:
data:image/s3,"s3://crabby-images/16d16/16d1614d0e729384e21fa2c942d7aade0c7ac2ee" alt=""
- Options -request and -dc-ip will be used:
data:image/s3,"s3://crabby-images/6f8d6/6f8d638d9ebdd12b3fead602e3789c78d2142208" alt=""
data:image/s3,"s3://crabby-images/aba73/aba735f3e9597dbd9961571f16e55f9acadfeb36" alt=""
- After launching GetUserSPNs.py the hash for user Administrator is extracted:
data:image/s3,"s3://crabby-images/1861f/1861f23c8cd023239cca88db47a6c40f4bee0d53" alt=""
- Storing the hash at a text file:
data:image/s3,"s3://crabby-images/51061/5106170aaae753bc6a78053daf26490d64b8df5f" alt=""
- Now, to decrypt the hash it could be used both John The Ripper and hashcat (locally or online):
data:image/s3,"s3://crabby-images/d9554/d95540938c4d32aba8a074bc03fa8b5a10626c65" alt=""
- Finally we have a decrypted password Ticketmaster1968 for the Administrator:
data:image/s3,"s3://crabby-images/37195/371959dbbfc68ac0a3d69d4e423bc82e22a522ea" alt=""
- The Metasploit psexec exploit is able to get a System shell:
data:image/s3,"s3://crabby-images/5413e/5413ef97a7543591dd77ba9a766ebdc5b9760fe6" alt=""
data:image/s3,"s3://crabby-images/c06a2/c06a2e3c0cf73ddc99ea5dcbf1f60a50746dae79" alt=""
- An alternative to Metasploit for getting a System shell is the Python script wmiexec.py:
https://github.com/SecureAuthCorp/impacket/blob/master/examples/wmiexec.py
data:image/s3,"s3://crabby-images/233c9/233c991c922ee03b98da6cc6e78aa56b51e3cfab" alt=""
data:image/s3,"s3://crabby-images/f280c/f280c65f566af73548d2ae3ee7d43dc5671faf87" alt=""
6 - CAPTURING THE 2nd FLAG
- Reading root.txt:
data:image/s3,"s3://crabby-images/7ab15/7ab15fdf30d4c7904877737a9d1c3fcedc75e0ba" alt=""