data:image/s3,"s3://crabby-images/e8923/e8923fcaebd47e58fe2a923306b2e4ee2f1a1768" alt=""
Foothold
Starting with initial scan, we see 22 and 80 open. Taking a look at 80 as it is usually the lowest hanging fruit, we find a wordpress site.
data:image/s3,"s3://crabby-images/c5d15/c5d1518034c7833e14f354cba79abb6d502b9c28" alt=""
The wordpress site has a plugin called spritz, with a version number of 1.0. Quick research leads us to find that this plugin is vulnerable to Remote File Inclusion.
data:image/s3,"s3://crabby-images/7f9f9/7f9f91a17493c62baf16074adb576d7c88182a7d" alt=""
Using this RFI, we can grab /etc/passwd and wpconfig, which gives us the password for the wpadmin. We also pulled an apache config file which leads us to the subdomain cacti-admin.monitors.htb (added to /etc/hosts). From the new subdomain we can login using admin + the password we got earlier and it lands us in a new site that is running cacti 1.2.12 which is vulnerable to an RCE.
data:image/s3,"s3://crabby-images/86219/862194f0b374e9fc2b3d37f13df87f2438457da8" alt=""
After executing the Remote Code Execution, we are now www-data.
User
Now lets get to user creds. I copied over linpeas.sh using netcat and started running that, while also looking for mentions of the user marcus, where we find cacti-backup.service.
data:image/s3,"s3://crabby-images/7ec27/7ec2741e2d89b32430542262fa4e67cdcc8c8eb7" alt=""
This file points to /home/marcus/.backup/backup.sh If we read the file, we get the login creds to ssh in as marcus.
Privilege Escalation
Now that we have user, its time to privesc. I secure copied linpeas.sh over to the machine that we have access on and started privesc enumeration. While that ran, I decided to do two things: check for any listening ports on the machine that I didnt have access to, and to read note.txt in the user directory, which has a todo list that has not marked done “Update docker image for production use”. This gave me a notion that the privesc may be a docker container escape. Before we get there though, we will need to get root on this docker instance. I tunneled some listening ports on the machine through SSH to enumerate any additional paths for getting root on the docker container.
data:image/s3,"s3://crabby-images/525d8/525d85d3c7dfa98b5cc4f4d8624c1f8cf3063d0f" alt=""
Apache Tomcat 9.0.31 is vulnerable to a Java Deserialization attack which might get us to root on the machine. I spun up metasploit, running the module in the link above and successfully getting root.
data:image/s3,"s3://crabby-images/2f178/2f1783ef6dda6af2dfca41bc2116f3ada64f1179" alt=""
From here we may be able to abuse Linux capabilities by injecting a kernel module into the host’s kernel using docker. Lets list out all of the capabilities that we can run, using capsh --print
.
data:image/s3,"s3://crabby-images/6c8df/6c8df5946be5a53aa231e8abf57dc7dc9e50236e" alt=""
From here, we have the sys_module capability that we can abuse, with help of this lab article. I followed the article almost step for step and changed the ip address and port in the C code.
data:image/s3,"s3://crabby-images/b49ad/b49ad4825155a8e436b89b3780c70df6a56ad284" alt=""
data:image/s3,"s3://crabby-images/ca987/ca987d4c79921b86cea4cc1e91c7ea588ef27e1e" alt=""
After compiling the kernel module, I setup the listening port on the container and run the kernel module using insmod, escaping the docker container!
data:image/s3,"s3://crabby-images/bc638/bc638b687cc8d49246ae9184bee076cf6d8e99f0" alt=""