[VulnHub] Hemisphere Lynx Walkthrough
A walkthrough for the Hemisphere Lynx virtual machine, available from VulnHub.
![[VulnHub] Hemisphere Lynx Walkthrough](/content/images/size/w2000/2020/10/milky-way-4526277_1920.jpg)
Difficulty level: Easy
Aim: capture two flags (user and root)
Author: d4t4s3c
Download: https://www.vulnhub.com/entry/hemisphere-lynx,577/
Information Gathering
The IP address of the target can be obtained via arp-scan:
sudo arp-scan --interface=eth1 192.168.56.100/24
data:image/s3,"s3://crabby-images/5f095/5f09562288533fd338feadde8a0a2e1790e74622" alt=""
Target: 192.168.56.109
Scanning
We can then scan the target with nmap to determine open ports and services:
nmap -sC -sV -vv 192.168.56.109
data:image/s3,"s3://crabby-images/0d265/0d265aef07428f269a2c91e5319b9a8795c63084" alt=""
The output from nmap shows the following open ports and services:
- port 21/tcp - FTP - vsftpd 3.0.3
- port 22/tcp - SSH - OpenSSH 7.9p1
- port 80/tcp - HTTP - Apache httpd server 2.4.38
- port 139/tcp - SMB - Samba
- port 445/tcp - SMB - Samba
Enumeration
Let's take a look at the HTTP service running on port 80:
data:image/s3,"s3://crabby-images/8dab2/8dab2ceb2465499ba99c5ab9bb577938a7cf79e8" alt=""
I initially ran a scan with gobuster to brute-force hidden files and directories, but this did not return anything of use:
gobuster dir -u http://192.168.56.109 -w /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt
data:image/s3,"s3://crabby-images/136c1/136c1173a053510d01c80c472420b7af2ddf8c51" alt=""
From here, I decided to create a custom wordlist based on the content of the above webpage:
cewl -w wordlist.txt http://192.168.56.109
data:image/s3,"s3://crabby-images/752d9/752d9bd416581fc4513e4f4afd7eb01289782419" alt=""
At this stage, the only other option to explore was the SMB service.
enum4linux can be used to enumerate SMB on Linux and Windows systems to discover shares on a device, password policies, user listings etc:
enum4linux 192.168.56.109
data:image/s3,"s3://crabby-images/01094/010948a68f3f44014fad04e064ca9220378ebb3c" alt=""
This reveals a user called 'johannes' which can be used with our custom wordlist to potentially brute-force the FTP and/or SSH login.
Gaining Access
I decided to try brute-forcing the SSH service first, using the above information:
hydra -l johannes -P wordlist.txt 192.168.56.109 ssh
data:image/s3,"s3://crabby-images/03ff1/03ff1a472d2584ee2a4f0c60214555d6f0d90d88" alt=""
Success! We have a password for johannes.
(N.B. this username and password combination also works for the FTP service)
We can now login to the SSH service:
ssh [email protected]
data:image/s3,"s3://crabby-images/b8162/b81629d510c19dccca7bc9c8d8e70827b23edd65" alt=""
The user.txt flag can be found in the home directory of johannes:
ls
cat user.txt
data:image/s3,"s3://crabby-images/5b1ac/5b1ac3e88d83e116b36c673634b19e6457f6fbfb" alt=""
Privilege Escalation
Within the /Desktop directory of the current user there is a file named .creds which contains a Base64 encoded string:
data:image/s3,"s3://crabby-images/16a0c/16a0c424e682ee0ddd0c8274e5d5f8fbe2aea0c3" alt=""
This can be decoded by running:
echo "MjBLbDdpUzFLQ2FuaU84RFdNemg6dG9vcg==" | base64 -d
data:image/s3,"s3://crabby-images/0936f/0936f39c913eea3480bb3542ba6e07420a0d42d9" alt=""
The output from this reveals the root credentials in reverse.
To reverse this string into the correct format we can run:
echo "20Kl7iS1KCaniO8DWMzh:toor" | rev
data:image/s3,"s3://crabby-images/19eab/19eabbd0c5389b1deb7053da6ed03ead64b75fbf" alt=""
From here we can su to the root user and obtain the root.txt flag from the /root directory:
su root
cd /root
ls -l
cat root.txt
data:image/s3,"s3://crabby-images/50a81/50a81ba3e1137e16842d35d450f0f311cffe2cce" alt=""
Please feel free to contact me via Twitter and thanks for reading.