Tabby is an easy Linux based machine from Hackthebox. The initial foothold to this box is obtained by Tomcat Manager app exploit and an LFI. Gaining user access requires a decent amount of enumeration. Root access obtained by exploiting the LXC.
In this blog I have tried to separate each process
- Enumeration
2. Initial foothold
3. Lateral movement
4. Privilage escalation
Lets get started…
1. Enumeration
Currently, I am using nmapAutomator to make my work easy. You can install nmapAutomator from the below Github link
https://github.com/21y4d/nmapAutomator
So initial results from nmapAutomator is
data:image/s3,"s3://crabby-images/fa942/fa942901e783125c1fd06a1744be2b76ccd0edfd" alt=""
port 80 and 8080 seems to run http and 8080 has Tomcat running on it
at port 80
data:image/s3,"s3://crabby-images/140d7/140d7312fc3429301fdcbb2f4054ff43bbe9c430" alt=""
From here i decided to add megahosting.htb and tabby.htb to /etc/hosts file
and port 8080 we can see few details about tomcat application installed
data:image/s3,"s3://crabby-images/6505e/6505e111c2836207eede02068628f2213ca94d76" alt=""
on inspecting the pagesource of port 80, I saw some thing intresting
data:image/s3,"s3://crabby-images/1f59f/1f59fda8b0fa55b6df7df7f28aa6bac2b8c91b33" alt=""
here we can try a local file inclusion. so instead of statements we can try to read sensitive files like shadow or passwd files.
data:image/s3,"s3://crabby-images/ebad4/ebad498ec42b2c21af37b205291fd39fc59d428a" alt=""
In the background nmapAutomator helped me with gobuster results on port 8080
data:image/s3,"s3://crabby-images/e0132/e01329c7c7bc31b33a43ad924fad0368f295f209" alt=""
On visiting /manager is saw a new path conf/tomcat-users.xml
data:image/s3,"s3://crabby-images/de30b/de30bc7580bdaf28c1561f170f6c58e17211adad" alt=""
Maybe by visiting that xml file we could get something interesting
Now we need to access this file by LFI which we discovered before
From google I get to know that tomcat xml file is stored at /usr/share/tomcat9/etc/tomcat-users.xml
data:image/s3,"s3://crabby-images/71b08/71b0865fa7680cef034ef91839aa936334bd9f32" alt=""
From the same page i got credential for tomcat user
data:image/s3,"s3://crabby-images/2d293/2d293225e5409d6e2e971c87eb7a2e9883b591d1" alt=""
username: tomcat
password: $3cureP4s5w0rd123!
2. Initial Foothold
Now it time to to exploit the tomcat application
https://www.hackingarticles.in/multiple-ways-to-exploit-tomcat-manager/
Since there are no gui option to upload the war shell, we need to do it using curl command
https://stackoverflow.com/questions/25029707/how-to-deploy-war-file-to-tomcat-using-command-prompt
Lets create the war file using msfvenom
data:image/s3,"s3://crabby-images/59653/596533805156395da204ccea3acfaac7f56f4924" alt=""
now uploading the shell using curl
curl -u 'tomcat':'$3cureP4s5w0rd123!' --upload-file shell.war "http://megahosting.htb:8080/manager/text/deploy?path=/shell.war"
data:image/s3,"s3://crabby-images/dc5a7/dc5a709c4002d55f6428655fc006cf30e92d68ee" alt=""
Now we need to set up netcat listener and execute the shell.war payload at http://megahosting.htb:8080/shell.war
data:image/s3,"s3://crabby-images/59bf5/59bf5f466d1c8821cbb7642aa4603dbf3dca3b73" alt=""
3. Lateral Movement
on the box, i searched for files owned by ash
data:image/s3,"s3://crabby-images/4c88f/4c88fb7578dc6c8580e36f2b959b970e18d511cc" alt=""
I setup a server using python3 on the tabby box and downloaded the zip file
data:image/s3,"s3://crabby-images/c045e/c045e534120809a1757a867862ab2aee3bd50478" alt=""
I was able to crack the password protected file using fcrackzip
data:image/s3,"s3://crabby-images/eccdd/eccdd05d6f5f1d688d5618244fdd126a33ded352" alt=""
On unziping the file i was unable to find anything useful
I tried to su as ash using the same password
data:image/s3,"s3://crabby-images/3cdcf/3cdcf65e3b324e017fe1c699e0bba69a62508f21" alt=""
user: ash
password: admin@it
We own the user now!!
4. Privilege escalation
This part is really easy. Detailed explanation is givien in the below link from hacking articles blog
I downloaded the image from my kali
data:image/s3,"s3://crabby-images/2d94d/2d94d7ca08f936aaddcd4cd07335ea92c82c493a" alt=""
I tried to create the image from tmp directory but it was not working. From hackthebox forum i get to know why and you can read more here
https://www.the-art-of-web.com/php/where-is-tmp/
I copied the file to ash home directory and ran the below command
lxc image import ./alpine-v3.12-x86_64-20201106_2001.tar.gz --alias myimage
data:image/s3,"s3://crabby-images/45684/45684e96cb91a3ba710f6bea11d1d5861926bf44" alt=""
lxc init myimage ehackify -c security.privileged=true
lxc config device add ehackify mydevice disk source=/ path=/mnt/root recursive=true
lxc start ehackify
lxc exec ehackify /bin/sh
data:image/s3,"s3://crabby-images/66a63/66a632ad95cd8407934aa2857810bdd5f0218f1d" alt=""
If you find this useful you can respect me on Hackthebox
https://www.hackthebox.eu/profile/240146
data:image/s3,"s3://crabby-images/47ef5/47ef5892b4ee1f9456771f3e5d9ecde9ef51d95d" alt="Image for post"
You can connect me on
LinkedIn: Derick N
Twitter: Derick N
Ehackify
Ehackify is a Cyber Security Training company based in South India devoted to providing best-in-class ethical hacking and cyber security trainings to beginners as well as professionals looking for a step-up. Here at eHackify primarily focus our efforts to provide real-time simulating hands on practical trainings to help better understand industry scenarios and latest trends in cybersecurity.