siunam's Website

My personal website

Home Writeups Research Blog Projects About

FunBox | Aug 19, 2022

Background

Have fun! ;)

Overall difficulty for me: Very easy

Service Enumeration

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

Rustscan Result:

According to rustscan result, we have 4 ports are opened:

Ports Open Service
21 ProFTPD
22 OpenSSH 8.2p1 Ubuntu
80 Apache httpd 2.4.41
33060 MySQL?

HTTP on Port 80

In the rustscan's nmap http-title:, it redirected to http://funbox.fritz.box/. Let's add this domain to /etc/hosts:

We also see there is a robots.txt that contains a /secret/ directory!

Nothing in there…

Found this website is running WordPress.

Some hint in the index.php.

Next, since the website is running WordPress, we can use wpscan to enumerate this WordPress website!

WPScan Result:

Found 2 users: admin and joe.

Brute forcing password:

Found both users password:

Armed with above information, we can now login into WordPress's admin page:

Login to http://funbox.fritz.box/wp-login.php/:

User joe is a low privilege user on WordPress, nothing useful.

Initial Foothold

Login to http://funbox.fritz.box/wp-login.php/ as admin:

User admin is a high privilege user on WordPress, which could gain an initial foothold on the target machine.

Looks like I wasn't able to upload a PHP reverse shell plugin.

How about modifying theme?

Nope. :(

Since the target machine has FTP port opened, let's try to use the above credentials to login into FTP!

Looks like we got joe's FTP!

How about SSH??

Looks like joe reuses his very weak password a LOT! XD

Hmm… User joe is using a rbash, or restricted bash.

To escape rbash, we can use the -t "bash --noprofile" trick in ssh!

local.txt:

Privilege Escalation

joe to funny

It seems like there is a backup script in funny's home directory, and it's running via a cronjob.

Unfortunately, the .backup.sh Bash script is world-writable! We can escalate our privilege to funny!

  1. Append a Bash reverse shell to .backup.sh:

  1. Setup a nc listener and wait for the cronjob runs:

funny to root

In the above image, we can see that user funny is inside the lxd group.

If the user is belong to lxd or lxc group, you can become root! (Similar to docker privilege escalation where you can mount a root container.)

A walkthrough can be found in HackTricks article.

  1. Build an Alpine image:

  1. Transfer the Alpine image to the target machine's home directory:

  1. Import the Alpine image:

Since I'm not in a stable shell and those steps in below will cause some trouble, so I'll add my SSH public key to funny's home directory:

  1. Start and configure the lxd storage pool as default: (Make sure to not using IPv6, otherwise it'll throw you an error.)

  1. Run the Alpine image:

  1. Mount the /root into the image:

  1. Interact with the container:

I'm root inside the container.

  1. Add a new user with root privilege in /mnt/root/etc/passwd:

  1. Exit the container and Switch User to the newly created user:

Now I'm the real root in the target machine! :D

Rooted

proof.txt:

Conclusion

What we've learned:

  1. Web Crawler (robots.txt)
  2. WordPress Enumeration
  3. Exploiting WordPress
  4. Password Reused in FTP and SSH
  5. Privilege Escalation via World-Writable Bash Script That's Automatically Ran By Cronjob
  6. Privilege Escalation via lxd Group, Running a Root Container and Modifying /etc/passwd