Welcome welcome! To my first walkthrough. We start with a relatively simple CTF room on TryHackMe: Simple CTF. https://tryhackme.com/room/easyctf
Scanning & Enumeration
As always, begin with enumerating the machine ports:
I used the (slightly modified) Threader3000 to get the open ports of the machine:
data:image/s3,"s3://crabby-images/50a4b/50a4b388cda0403ae5905279e4eb08cddc1b4e16" alt=""
I then used nmap to scan those open ports found:
nmap -T4 -Pn -p21,80,2222 -A 10.10.206.93
data:image/s3,"s3://crabby-images/8bb27/8bb27924d17d829518e5bb2feda80ac269ddb459" alt=""
Breaking down the command:
-T4: speed of nmap scan is 4/5 (personal preference of mine)
-Pn: skip pinging the machine being scanned (we already know the host is up)
-p21,80,2222: only scan the ports specified (the ones we found open)
-A: do an extensive scan on these ports
Enumerating Services
Port 21- ftp
From the nmap scan we see that the ftp port allows anonymous login, so we try that:
ftp 10.10.150.11
cd pub
get ForMitch.txt
exit
data:image/s3,"s3://crabby-images/68b71/68b715ff3c3630f56402228dd9b460c3a8c5912b" alt=""
cat ForMitch.txt
From the anonymous login, we have access to 1 file on the box, which informs us that there is password is weak, reused, and that there is probably a user name 'Mitch' (or some variation).
Port 2222- ssh
We see that ssh is available on port 2222, but ssh usually isn't too vulnerable unless we have credentials, so I leave it alone for now.
Port 80- http
A website being run on a port is usually a great place to visit on CTFs, so let's check that out:
data:image/s3,"s3://crabby-images/69f84/69f8446e50d54d4f073133f9d788984b3ae4c9f9" alt=""
Just a default page, so let's try to enumerate and see if we can find any hidden directories:
I used dirsearch to do this
python3 /opt/dirsearch/dirsearch.py -u http://10.10.206.93/ -e * -r
data:image/s3,"s3://crabby-images/8e51c/8e51cce37746c0f944ea9ec35d7bcb818ba90dd6" alt=""
An interesting directory was found! Let's explore that.
Vulnerable WebApp
Navigating to the webpage, I have an extension called Wappalyzer which identifies webApp versions and as well as versions of services running on them:
data:image/s3,"s3://crabby-images/cd266/cd266ab6fb515826c6d6ce5a7a5aa14e0e832f59" alt=""
Using that (as well as looking around the web page), we can see that this app is running CMS Made Simple. A google search for exploits on this service leads me to this:
data:image/s3,"s3://crabby-images/4339c/4339ca0beb6be5e8c7ebae09de25ae72a0b39680" alt=""
After reading what the exploit does, I get retrieve it locally in hopes of obtaining some credentials:
searchsploit -m 46635
data:image/s3,"s3://crabby-images/75acd/75acdda9814833478d90c07e719b08245eac5db9" alt=""
Running the exploit with no parameters shows you how to run it. We know the URL from our enumeration earlier, and I figure rockyou.txt (which comes preinstalled on kali) will be enough to crack any password we find.
python 46635.py -u http://10.10.206.93/simple/ --crack -w /usr/share/wordlists/rockyou.txt
After running this and waiting for a bit, we obtain credentials!
data:image/s3,"s3://crabby-images/21c5c/21c5c0c8ebad5cdd038f088dfc7457c89b014aee" alt=""
Getting User
Now, these credentials we found are for the CMS site we saw earlier. But remember back to the beginning when I said ssh usually isn't useful until we have credentials. Well, now we have credentials so let's try that and see if some password reuse is going on!
I use medusa to check ssh validation. It's more useful for checking lists, but I'll show you the syntax anyway:
data:image/s3,"s3://crabby-images/4fd7d/4fd7d363baccb786abfd98e9a10060f2e2ad1ef1" alt=""
medusa -u mitch -p {password} -h 10.10.206.93 -M ssh -n 2222
Breaking down the command:
-u: use a single username to test
-p: test a single password
-h: the host we are checking
-M: the module
-n: the port number (necessary since this box didn't have the default port 22 for ssh)
After checking with medusa we see that it's a success!
We ssh into the machine with the retrieved credentials
ssh mitch@10.10.206.93 -p 2222
data:image/s3,"s3://crabby-images/29c35/29c351733730a5c7804b6e5ba2db42c924d06b21" alt=""
And we get the user flag!
Privilege Escalation
data:image/s3,"s3://crabby-images/4eb63/4eb6396850441e27bbc0e65a6dd65f6c1881945e" alt=""
After giving myself a normal shell with:
python -c "import pty; pty.spawn('/bin/bash')"
we check if we can go get the root flag. As expected we get a Permission Denied.
So the first thing I like to check when it comes to Linux Privesc is what commands we can run as sudo:
sudo -l
data:image/s3,"s3://crabby-images/6100c/6100c06d7f3ce5f2e5345fac6522a9b7871387ab" alt=""
Doing that, I see we can run vim as sudo! When you are in vim, you can run commands simply by prefacing them with '!'. I suspect we can spawn a root shell through this method:
data:image/s3,"s3://crabby-images/88086/88086a9f12e7a6b8d1812a0f2f5ee1fa665d6739" alt=""
data:image/s3,"s3://crabby-images/e9a7f/e9a7f222689264c430f18778753cd3fee81f420c" alt=""
sudo vim
Then, inside of vim:
:!/bin/bash
Running vim with sudo and then spawning a shell, we can see that we are now root!
data:image/s3,"s3://crabby-images/5b1ed/5b1ed386de58ac6d7a08287202246f1f2ff5413b" alt=""
And we have access to the root flag!
That's all for now, thanks for reading :)
If you want to reach out for questions/feedback you can reach me on the TryHackMe discord server under the name B10b#9228!
Comments