Magic was a medium rated Linux box that required you to find a hidden upload function then bypass its upload restrictions to execute code and catch a shell as www-data. From here, creds for mysql were stored in plaintext, allowing you to dump the database and get more creds for the user Theseus. Finally a SUID binary did not use quoted paths and this was exploited to gain a root shell. I added magic.htb to /etc/hosts and got started.
Enumeration
nmap scan:
data:image/s3,"s3://crabby-images/e6955/e69550fbf1592522e3d70b338bb900f2cffb7d4f" alt=""
With no creds, let's check out http:
data:image/s3,"s3://crabby-images/eca13/eca136235e01c9c8ac1321a76b2fb86027121ac7" alt=""
I clicked on the 'login' link:
data:image/s3,"s3://crabby-images/132fb/132fb2245c4fdef40cbe78f368d45d14c4a12538" alt=""
After trying admin/admin and such, I decided to enumerate more with gobuster:
data:image/s3,"s3://crabby-images/438f2/438f284dc1cda7ec98ed4814e75538f02a6b43c6" alt=""
Initial Foothold
Upload.php looked juicy but it redirected when I tried to access it. I loaded up Burp, set it to intercept and changed the '302' shown below to a '200':
data:image/s3,"s3://crabby-images/b7c7a/b7c7a02b72a088ca1394fb963994588195679fe8" alt=""
This worked and I was shown an upload interface:
data:image/s3,"s3://crabby-images/731a9/731a9f5fb7586cdcb32abe6d04558ea591404bdd" alt=""
I immediately tried to upload a php reverse shell but was booted back to the login. I checked Burp's history and saw the reason why:
data:image/s3,"s3://crabby-images/0b82a/0b82a92fe0a82480c599b59aaf4642038d4bb4c2" alt=""
Okay, let's see what a legit upload looks like:
data:image/s3,"s3://crabby-images/18e28/18e28f6bad28efc6343f06c836c2c0145622fccf" alt=""
Cat pic uploaded successfully:
data:image/s3,"s3://crabby-images/3b7fe/3b7fed290af88e8d70f14b1255f2b6a97b36f8e1" alt=""
I tried various things here - null bytes, double extensions (e.g. shell.php.jpg) and got nowhere. Eventually I googled around and found this article that detailed using exiftool
to bypass file upload filtering. Sadly my notes here are spotty but I believe I did exiftool -Comment=$(cat webshell.php) meow.jpg
, where webshell.php can be found here. I then renamed it to 'meow2.php.jpg', uploaded it, accessed it directly and was pleased to see it had worked:
data:image/s3,"s3://crabby-images/2d370/2d370f8c83bb7608b3bdcc7052060041f6b078f5" alt=""
Since the box is running php, I went with a php reverse shell:
data:image/s3,"s3://crabby-images/a81cf/a81cf8d4c9c6ad446276cb1798926934bdab5967" alt=""
With a netcat listener, I caught a shell as www-data:
data:image/s3,"s3://crabby-images/a0779/a0779610ee70295ea5694b256c7a82008a058c5f" alt=""
User Pivot
There were some interesting files in /var/www/Magic:
data:image/s3,"s3://crabby-images/1b134/1b134ab7c219f9b1f758d9dd3d74d9e99ef06ce2" alt=""
There were plaintext creds in db.php5:
data:image/s3,"s3://crabby-images/d3e49/d3e4963125f5af32ed96d6afc0391511d87c8e11" alt=""
Those creds worked for mysql. Whoever left the 'all_databases.sql' saved me the trouble of doing it myself but I believe mysqldump -u thesus Magic -p
would have dumped the database to that file. Within it, are another set of creds:
data:image/s3,"s3://crabby-images/853a9/853a9eac7d50481e2723cf65560f5d7da5d0566a" alt=""
That password works for su
:
data:image/s3,"s3://crabby-images/e3c27/e3c27a923e6f165904980cd99123d6ac10fcd825" alt=""
User flag:
data:image/s3,"s3://crabby-images/350df/350df2661ae030e2f8bbdc2b655573ef779b24c5" alt=""
Privilege Escalation
I ran LinPEAS, which spit out a bunch of SUID files. One of them had a plausible name but I had never seen it before anywhere:
data:image/s3,"s3://crabby-images/56051/56051f7b27421450f5b8909d3961086198a94b2e" alt=""
I ran strings /bin/sysinfo
to take a peek at what it might be doing:
data:image/s3,"s3://crabby-images/53ea1/53ea13e2629ced11b9d874f73aeabcfffba3a75b" alt=""
A bunch of commands (lshw, fdisk, cat, free) are being run without quoted paths and this is ripe for abuse. I chose free
to be my victim and created a short bash reverse shell script named 'free' in /tmp:
data:image/s3,"s3://crabby-images/c3bb0/c3bb013d1caf8d6c8b4be61c11c27f8060172433" alt=""
I made it executable:
data:image/s3,"s3://crabby-images/9a674/9a674fad22d2cc9cd780558f087bcceeadbad8b1" alt=""
Now, the important step of setting the path to /tmp so that /bin/sysinfo
would look there for free
first:
data:image/s3,"s3://crabby-images/bec06/bec06d3918113ae5d261cfce26acb896d0ff57d8" alt=""
I really should have done PATH=/tmp:$PATH
so I could keep using standard commands without having to type their full path. Oops. Anyway, with that in place I ran /bin/sysinfo
and with a netcat listener, I caught a root shell:
data:image/s3,"s3://crabby-images/74b30/74b30d823176faaeac54eeddfd9bfd8823bd29ef" alt=""
data:image/s3,"s3://crabby-images/d2a3f/d2a3f4828e07b42fb32838ba11c679a0f88a23ad" alt=""
Root flag:
data:image/s3,"s3://crabby-images/5296d/5296dafda8941ea5bb5f5498f56253d80e76660e" alt=""