Good afternoon, today we will be walkthrough the second machine from SunCSR Team called Geisha.
Foothold
Let's scan the local network in search of our goal.
data:image/s3,"s3://crabby-images/864c8/864c8959076d9386700c94ebd2a50e1a8b6713fd" alt=""
arp-scan -l
Now we need to scan the open ports of our target
data:image/s3,"s3://crabby-images/b8495/b849556e970b901cbaf3adb59df587c31e6d633b" alt=""
nmap -A -T4 -p20-9000 192.168.2.102 > nmap_scan.txt && cat nmap_scan.txt
When scanning ports, I saw a lot of web servers. These were nginx, LiteSpeed, Apache2. After 5 minutes of enumeration, I found what I need namely Nginx on 7125 port.
data:image/s3,"s3://crabby-images/f2cb0/f2cb07d44b004eed6ab0c25366d916820402d2bc" alt=""
Geisha
When listing files in the web directory, I found the passwd file and the shadow file, but the shadow file gives us the code 403 (forbidden) so we can only read the passwd file
data:image/s3,"s3://crabby-images/4e232/4e23258185bed0046d8e7f1d806215bbb4c0fd5c" alt=""
gobuster dir -u http://192.168.2.102:7125/ -w /usr/share/wordlists/dirbuster/directory-list-1.0.txt
After I downloaded the file using curl, I look at its contents with cat and find out the username of the user for brute force
data:image/s3,"s3://crabby-images/a9f04/a9f0409932fd0c663de04654479abc0f1bf90bdf" alt=""
curl http://192.168.2.102:7125/passwd -o passwd && cat passwd | grep home
geisha
With Hydra, I attack passwords using the username from the passwd file and get authorization data
data:image/s3,"s3://crabby-images/dfd9d/dfd9d6d48c73768eef8ab2b5741986346d129c65" alt=""
hydra -l geisha -P ~/wordlists/rockyou.txt ssh://192.168.2.102
geisha:letmein
Now i connect via ssh and got user.
data:image/s3,"s3://crabby-images/b9a4b/b9a4bf9ab436691d799de5e3485d43220d0dcc26" alt=""
Path to root
On the system, I find a base32 SUID file that allows you to read files with root access
data:image/s3,"s3://crabby-images/62fdd/62fdded0bd8004809110dd1cd56aced0efdfa6df" alt=""
find / -perm -u=s -type f 2>/dev/null
With base32, I get the contents of the /root/.ssh/id_rsa file encoded in base32 encoding, in order to decrypt it I use the decode option.
data:image/s3,"s3://crabby-images/55d40/55d407b9b31ad39c1a5f7d074fb4cd3ce1b4ba46" alt=""
Now when I have an ssh authorization key, I connect to the root user via ssh and get the root flag
data:image/s3,"s3://crabby-images/c0356/c0356299cb881dfd11c25fc3567fedef4e647368" alt=""
Flag{Sun_CTF_220_5_G31sha}