[VulnHub] OnSystem: ShellDredd #1 Hannah Walkthrough
A walkthrough for the ShellDredd #1 Hannah virtual machine, available from VulnHub.
![[VulnHub] OnSystem: ShellDredd #1 Hannah Walkthrough](/content/images/size/w2000/2020/09/cheers-839865_1920.jpg)
Difficulty level: Easy
Aim: Capture the user.txt and root.txt flags
Author: d4t4s3c
Download: https://www.vulnhub.com/entry/onsystem-shelldredd-1-hannah,545/
Information Gathering
No information has been provided relating to the IP address of the target machine, but this can easily be found using arp-scan:
sudo arp-scan --interface=eth1 192.168.56.100/24
data:image/s3,"s3://crabby-images/6db3a/6db3a9c4bbc6398f6c5c724753dbf97976aa7290" alt=""
Target: 192.168.56.104
Scanning
Now that we have the IP address, nmap can be used to scan the target to discover open ports and services. Here, I am running a scan with default scripts (-sC) and version detection (-sV) against all ports from 1 through 65535 (-p-):
nmap -sC -sV -vv -p- 192.168.56.104
data:image/s3,"s3://crabby-images/ec9d9/ec9d982223a7b146c8598726295fbc0160ac3079" alt=""
The output from nmap shows the following open ports and services:
- port 21/tcp - FTP - vsftpd 3.0.3 (anonymous login allowed)
- port 61000/tcp - SSH - OpenSSH 7.9p1
Gaining Access
Not many options available to us at the moment, apart from the anonymous FTP login, so let's take a look at that:
ftp 192.168.56.104
anonymous
<blank password>
data:image/s3,"s3://crabby-images/85c04/85c04b2d77d77fe77ca687282a63b7292da824f5" alt=""
Listing the contents shows a directory named .hannah and within that we find an id_rsa file which we will download to our local machine:
data:image/s3,"s3://crabby-images/31447/3144780d55b34bf2d164cedda6ace25d6407f7e8" alt=""
Before we attempt to log in to the SSH service using the id_rsa file, the permissions will need updating. A permission level of 600 ensures the owner has full read and write access to the file, while no other user can access the file:
chmod 600 id_rsa
We can now try and login via SSH:
ssh -i id_rsa [email protected] -p 61000
data:image/s3,"s3://crabby-images/10a5d/10a5de36a15d417239b284eb51486ee7dfdf22f4" alt=""
Success!
We have got an initial shell as hannah and the user.txt flag can be found in the /home/hannah directory.
Privilege Escalation
Running the sudo command shows we have no access to this:
data:image/s3,"s3://crabby-images/df4c5/df4c5ae99e6d08a5990636bec0aa6a1301d71b62" alt=""
We will need to carry out some more enumeration to find a path to root.
To check for binaries with the SUID bit set, we can run:
find / -perm -4000 2>/dev/null
data:image/s3,"s3://crabby-images/2e505/2e50571f68220331d5e6b7452a9a51972894fae1" alt=""
/usr/bin/mawk stands out as a possible way of escalating our privileges.
As the SUID bit is set on this binary, we can use mawk to do a privileged read of the /root/root.txt file.
First, we'll set an environment variable of the file we want to read (/root/root.txt):
ROOT_FLAG=/root/root.txt
We can then run the mawk command and pass in the above variable:
mawk '//' "$ROOT_FLAG"
data:image/s3,"s3://crabby-images/1cd69/1cd6911f480117c499c6ca92d4df537e18f9ad71" alt=""
...and that's the root flag captured!
Please feel free to contact me via Twitter and thanks for reading.