data:image/s3,"s3://crabby-images/ca9c1/ca9c1ca9aa085fc33b1c20ef4eac776bb3e52ea1" alt=""
Hack The Box – Arctic Walkthrough
Introduction
This was an easy Windows machine that involved exploiting a directory traversal vulnerability in the Adobe ColdFusion web application to obtain user hashes, cracking them with an online hash lookup tool and using a scheduled task to gain remote access. Privilege escalation was possible through a Windows Kernel Exploit.
Enumeration
The first thing to do is to run a TCP Nmap scan against the 1000 most common ports, and using the following flags:
- -sC to run default scripts
- -sV to enumerate applications versions
- -Pn to skip the host discovery phase, as some hosts will not respond to ping requests
data:image/s3,"s3://crabby-images/e3062/e30627f65207c474210377ef8d43454d77bfb383" alt=""
The only port that stands out is 8500, as the others are standard Windows ports used for RPC.
Enumerating port 8500
When visiting port 8500 on a browser, the site displays the below file listing:
data:image/s3,"s3://crabby-images/19aa5/19aa560650076a5d755204c1dc132b42d28ff2ee" alt=""
When navigating to /CFIDE, it takes to another file listing:
data:image/s3,"s3://crabby-images/453b3/453b366b88d78c91efe7f9e5bef4b7f7ac343ccb" alt=""
When selecting administrator, this time an “Adobe ColdFusion 8” application is displayed:
data:image/s3,"s3://crabby-images/5c49a/5c49ae7aebdb9a574909f04cdd28e0fa36cd7af4" alt=""
Doing a simple searchsploit search and excluding Cross-Site scripting exploits and Metasploit modules, a few exploits are available
data:image/s3,"s3://crabby-images/d383c/d383cbc94ca90a228a5bcf0a1d407abc1ee1271a" alt=""
Directory Traversal Vulnerability
After checking a few of them, one seems to stands out as it can allow to retrieve user hashes through a Directory Traversal Vulnerability. Mirroring and analysing the exploit:
data:image/s3,"s3://crabby-images/e0341/e03410f244be1eb26828e30ad6e4114f589ab3de" alt=""
Testing the exploit on the target application – user hashes are displayed:
data:image/s3,"s3://crabby-images/ecbce/ecbceb4e05fe202bf60c825eaf609882d9d40914" alt=""
Using the Crackstation online hash cracker to obtain the clear-text credentials. The tool is available at https://crackstation.net/
data:image/s3,"s3://crabby-images/7a5a8/7a5a8d3a612fedb623b251d06dde697d31dc278a" alt=""
Logging into the web application using admin/happyday
data:image/s3,"s3://crabby-images/d51f4/d51f47a82c305e8e361290f6768134eebd761702" alt=""
data:image/s3,"s3://crabby-images/466f7/466f7ba1389e84d3e8b44f05f8b72a11f1b901b0" alt=""
Scheduled Task Exploitation
A scheduled task can be used to remotely execute commands. The first step is to generate some shellcode using MSFvenom with the following flags:
- -p to specify the payload type, in this case the Java reverse shell
- LHOST to specify the local host IP address to connect to
- LPORT to specify the local port to connect to
data:image/s3,"s3://crabby-images/6618e/6618e1a3d4c2d7c4066ba5cee6b96e4bc3c7378c" alt=""
Navigating to Server Settings -> Mappings
data:image/s3,"s3://crabby-images/b01cd/b01cd0895107537304e6283522d2005ed2b14dcf" alt=""
Setting up a Python webserver to host the reverse shell so that it can be downloaded by the target host:
data:image/s3,"s3://crabby-images/e458a/e458aa637c4acff0e5d316c1e1be5f5c1682a84e" alt=""
The next step is to set up a Netcat listener, which will catch our reverse shell when it is executed by the victim host, using the following flags:
- -l to listen for incoming connections
- -v for verbose output
- -n to skip the DNS lookup
- -p to specify the port to listen on
data:image/s3,"s3://crabby-images/c3dbc/c3dbc1da8177f4ff1aa16fe29c626c8e9a5187b2" alt=""
Navigating to debugging & logging -> scheduled tasks
data:image/s3,"s3://crabby-images/b0842/b0842b2b70442cebbee17a7274f11c35add1c8bd" alt=""
Setting up a scheduled task that will download the reverse shell and save it on C:\ColdFusion8\wwwroot\CFIDE\administrator\exploit.jsp
data:image/s3,"s3://crabby-images/10ad5/10ad5cb3113f1366d080fdc010ff5a143fd509ec" alt=""
The task has now been created. using the green button to execute it.
data:image/s3,"s3://crabby-images/03182/03182e1bd261e08874ff8d9b03212099c9b6351e" alt=""
The request was received in our Python webserver
data:image/s3,"s3://crabby-images/2ebb8/2ebb81ac96dc1735f274812a68e73f3f52bdf6c7" alt=""
The reverse shell can then be executed by navigating to the location of the .jspfile
data:image/s3,"s3://crabby-images/336ec/336ec7335f906c2547b767f3eb367d790161bc1d" alt=""
A call back was received which granted a reverse shell as the tolis user:
data:image/s3,"s3://crabby-images/2c891/2c891c77847b281d47abd2d5e1469f07ad3f76ce" alt=""
Privilege Escalation
Running the systeminfo command to enumerate the system version, build and any possible Kernel Exploits.
data:image/s3,"s3://crabby-images/d8a17/d8a1767842d24c09d491cee8dbc826fc21ac6a35" alt=""
Saving the output of the command to a text file on the Kali host
data:image/s3,"s3://crabby-images/42ad8/42ad821fb772725c92193b8e2e06939112c5791c" alt=""
Running the Windows Exploit Suggester script against the file to identify any vulnerabilities with this version of Windows. One of the options is MS10-059, a vulnerability that uses the Service Tracing feature of Windows as a way of capturing a SYSTEM token using a named pipe. As long as you have the “SeImpersonatePrivilege” privilege, you can then execute arbitrary code in the security context of this user.
data:image/s3,"s3://crabby-images/98ca1/98ca17fa8d09a37f9dcf8058eaf12996e191081f" alt=""
Searching for proof of concepts available on GitHub for MS10-059:
data:image/s3,"s3://crabby-images/d09c1/d09c1026a3bf0f92c5a237b583392f140a21c896" alt=""
Found an interesting script that can be used to exploit this vulnerability
data:image/s3,"s3://crabby-images/7f490/7f490c46c22bfa3b34ba9f7da415f96cb8e5d979" alt=""
Cloning the exploit from GitHub
data:image/s3,"s3://crabby-images/73db9/73db9df322fe2126533deb3a595acfbb8e521d9a" alt=""
Setting up a Python web server to host the exploit
data:image/s3,"s3://crabby-images/5c6e1/5c6e1b7b9e9a00c02c8f32f3da64b6e3af56e017" alt=""
Downloading it from the target host using the certutil tool
data:image/s3,"s3://crabby-images/78ba0/78ba0c7046ab5112e3a93c6179d77e02cd84cc07" alt=""
Setting up a Netcat listener, which will catch our reverse shell when it is executed by the victim host:
data:image/s3,"s3://crabby-images/101c2/101c2eebeeb643ea35a36894b340d505ec59c939" alt=""
After executing the exploit this grants SYSTEM level access to the machine
data:image/s3,"s3://crabby-images/3a58e/3a58efaaccfc97fde14ddeaccf6b5c0a88ac8160" alt=""
Conclusion
I found this box quite interesting as there was quite a lot of research involved, first of all to find the directory traversal vulnerability, then to learn how to exploit scheduled tasks on Adobe ColdFusion and finally to escalate privileges using a known Windows vulnerability in the service tracking feature.