siunam's Website

My personal website

Home Writeups Research Blog Projects About

BBSCute

Introduction

Welcome to my another writeup! In this Offensive Security's Proving Grounds Play BBSCute machine, there are tons of stuff that's worth learning! Without further ado, let's dive in.

Background

Cuteness level over 9000!

Service Enumeration

As usual, scan the machine for open ports via rustscan!

Rustscan Result:

According to rustscan result, we have several ports are open:

Ports Open Service
22 OpenSSH 7.9p1 Debian
80 Apache httpd 2.4.38
88 nginx 1.14.2
110 Courier pop3d (pop3)
995 Courier pop3d (ssl/pop3)

HTTP on Port 80

In the index.html, nothing seems to be interesting for us, thus we can enumerate hidden directory via gobuster.

Gobuster Result:

As we can see, we found two index page: index.html and index.php. The php one seems weird.

http://192.168.145.128/index.php:

Ohh, it's the CuteNews CMS (Content Management System), and it's version is exposed: CuteNews 2.1.2

Let's use searchsploit to find public exploits.

Searchsploit Result:

We found 4 exploits for CuteNews 2.1.2, the CuteNews 2.1.2 - Remote Code Execution looks good for us, we can mirror this exploit via searchsploit -m 48800.

Initial Foothold

I'll do the exploit in manully, as it's easier to do.

According to the 48800 python exploit, we need an authenticated user in order to have a remote code execution. Let's register a new user first.

  1. Register a new user:

However, we see the captcha is missing. If we inspect the form in Page Source, we'll see an interesting page, captcha.php.

Looks like it's the captcha's value!

We can use the Refresh captcha button to refresh it's value, and using Firefox's "Inspect" -> "Network" feature to see the GET response.

  1. Create a fake image file which contain PHP code:

In the exploit script, we can see it's using the GIF8 GIF header to trick the server into thinking it's an image file. We can create a php file which contain a GIF header and a PHP code.

  1. Upload the "image" file:

In the exploit script, we can see it's sending a POST request to avatar PHP to upload an "image". We can do this manully.

Go to "Dashboard" -> "Avatar":

Browse our "image" and click "Save Changes":

Go to http://MACHINE_IP/uploads/avatar_{your_user_name}_{your_uploaded_file_name}.php?cmd={command}:

Looks like we have a webshell now :D

We can use this webshell to gain an initial foothold to the machine!

  1. Reverse Shell:

Looks like the machine has python installed! We can use a python reverse shell to gain initial foothold!

Generate a python3 reverse shell: (From https://www.revshells.com/)

Setup a nc listener:

Trigger the reverse shell:

Reverse Shell call back:

local.txt:

Privilege Escalation

www-data to root

sudo -l:

Looks like www-data can run /usr/sbin/hping3 --icmp as root with no password!

SUID:

We can also see that hping3 has SUID bit set!

According to GTFOBins, if hping3 has SUID bit set, we can escalate our privilege! However, we can't use sudo to escalate our privilege, as we can only run sudo hping AND the --icmp option.

I'm root now! :D

Rooted

proof.txt:

Conclusion

What we've learned:

  1. Directory Enumeration
  2. File Upload Bypass
  3. Remote Code Execution
  4. Privilege Escalation via hping3