SICKOS 1.2
- Layout for this exercise:
data:image/s3,"s3://crabby-images/be407/be4075ac493e5ce48eb6e9851c5723422cf636c9" alt=""
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine SickOS 1.2:
data:image/s3,"s3://crabby-images/7c97d/7c97d3179c8457bd9ba95e93004f7c2fa87c05f7" alt=""
- SickOS 1.2 can be downloaded from here:
https://www.vulnhub.com/entry/sickos-12,144/
- Once downloaded and extracted with WMware:
data:image/s3,"s3://crabby-images/f826c/f826cdc2822b0adb65fa9fba1cfca6faa5738829" alt=""
2 - ENUMERATION
- Using netdiscover let's notice that the only IP address in the local network working with WMware is 192.168.1.16, so it should correspond to the vulnerable machine SickOS 1.2:
data:image/s3,"s3://crabby-images/e92db/e92dbdf6e51d52ebe9e43f76dac16a17fb5520e0" alt=""
data:image/s3,"s3://crabby-images/54157/54157219eaaa985aad3250390f4f5f29e65a2344" alt=""
- Scanning with Nmap:
data:image/s3,"s3://crabby-images/03c68/03c6848114a95dd66af1e628ad0a4d8f9e171288" alt=""
- Connecting to the web service:
data:image/s3,"s3://crabby-images/ce5b8/ce5b83817b1c847d6a50500c5d830937129e972b" alt=""
- Viewing the source there is nothing interesting:
data:image/s3,"s3://crabby-images/64f65/64f65b9509371a3a36bd5be97cb97e3e88e65a56" alt=""
- Scanning the web content with dirb:
data:image/s3,"s3://crabby-images/da7ce/da7cea96d3eced91842e8b366bcf085c87a9443f" alt=""
- Going to the /test folder:
data:image/s3,"s3://crabby-images/00ba0/00ba05bfd023946f5fde7356d87da384857c7268" alt=""
- curl shows that the PUT method is allowed, meaning that we can create a resource at the web folder /test:
data:image/s3,"s3://crabby-images/be9af/be9af040edad589aaa2419d2ebd4994103479306" alt=""
3 - EXPLOITATION
- Using the -X option and the method PUT let's try to create a simple text file and upload it to the the web folder /test:
data:image/s3,"s3://crabby-images/26f3d/26f3db604ee737540c536cbe23be45e25c5d11bd" alt=""
data:image/s3,"s3://crabby-images/a2319/a23191b83282fc182c20ce3d997d8f6fd8cf9090" alt=""
data:image/s3,"s3://crabby-images/f752b/f752b71254dcedb4a21cb0360a22ac09d22bc36d" alt=""
data:image/s3,"s3://crabby-images/92480/924802dfc454312e49e0b472693d2390e7304dbb" alt=""
- Once we see that the upload is successful let's try some more tricky uploads, for instance creating a cmd.php file useful to execute php scripts:
data:image/s3,"s3://crabby-images/96105/96105002f5786a6c79d65941ea79792b0e188c62" alt=""
- Listing with ls -la:
data:image/s3,"s3://crabby-images/c1d89/c1d891e5444a9cf05286431c27b02066590fd30d" alt=""
- Opening /etc/passwd with cat:
data:image/s3,"s3://crabby-images/66492/664925a4c5e3b65a0cd7a17edfbffeb00beef3d7" alt=""
- Using which let's discover whether netcat is available at the victim machine:
data:image/s3,"s3://crabby-images/77a80/77a80fe1a7bbd8db5cc18c3508f752ce310696e9" alt=""
3.1 - Exploiting with curl and netcat
- Taking advantage of this Python reverse shell, and encoding it with the percent-encoding:
http://pentestmonkey.net/cheat-sheet/shells/reverse-shell-cheat-sheet
https://en.wikipedia.org/wiki/Percent-encoding
data:image/s3,"s3://crabby-images/5a5a5/5a5a59e7aaa63f848398211b80f15151c88dd4df" alt=""
- Setting a listening session on port 443:
data:image/s3,"s3://crabby-images/24f62/24f62db409e43b570f08b15c5313070409bf676e" alt=""
- Running the reverse shell with curl:
data:image/s3,"s3://crabby-images/b7bc0/b7bc0a8df34dd8a3bb18e503d29f2c352c34196c" alt=""
- A limited shell is achieved:
data:image/s3,"s3://crabby-images/f2125/f2125d49735b21316c9a9385428f87576bf199b6" alt=""
3.2 - Exploiting with Command Injection
- Another alternative would be injecting directly the Pyhon script via the browser.
- First, setting a listening session on port 443:
data:image/s3,"s3://crabby-images/24f62/24f62db409e43b570f08b15c5313070409bf676e" alt=""
- Passing the Python script directly via the browser:
data:image/s3,"s3://crabby-images/f4c68/f4c683f52b2f3d59bead1bc211cd6be4c95ff822" alt=""
- The limited shell is again achieved:
data:image/s3,"s3://crabby-images/69430/69430a9b597e710b7e6336336b24190f059012b6" alt=""
3.3 - Exploiting with Metasploit
- Setting a Metasploit handler session on port 443:
data:image/s3,"s3://crabby-images/ae159/ae159596f5b6ba768c2fb571b43d7e4e60ec3425" alt=""
data:image/s3,"s3://crabby-images/a6c93/a6c937c8faed9fe2fb33b788c5417b6ee9693fe4" alt=""
- Executing the reverse shell script via curl:
data:image/s3,"s3://crabby-images/d9d0d/d9d0d3ecf2defbfae1a729dbd021dbd6cdff8401" alt=""
- A limited shell is achieved:
data:image/s3,"s3://crabby-images/9b0ba/9b0baddd806e2bcb5ad0c6a009fba33e26137ad6" alt=""
- Now, before starting the Privilege Escalation process let's background this Metasploit session for later use:
data:image/s3,"s3://crabby-images/1927a/1927a8560833133e0232dbd5e127953fc9e3572e" alt=""
4 - PRIVILEGE ESCALATION
- Following these directions for Privilege Escalation at a Linux machine:
https://blog.g0tmi1k.com/2011/08/basic-linux-privilege-escalation/
- Searching for cron.daily:
data:image/s3,"s3://crabby-images/c06e7/c06e72750109b30222a19c6e74f1626b56fc1925" alt=""
data:image/s3,"s3://crabby-images/c7760/c776063e7864c93a90173cd9ad433e5101cb2fcf" alt=""
data:image/s3,"s3://crabby-images/e6c0e/e6c0e43b9d61d0b8afc267ba8e43b1b6844aa835" alt=""
- cron.daily uses an outdated version of chkrootkit:
data:image/s3,"s3://crabby-images/eb3f9/eb3f9947d24a08feddddde7b2f04d801f96c90a0" alt=""
data:image/s3,"s3://crabby-images/2390b/2390b76bc430a39da9cbe05a6e7304aac05408cd" alt=""
- Looking for related vulnerabilities:
data:image/s3,"s3://crabby-images/79613/796132978547ae27ca3a68d756af70e54ced82b5" alt=""
data:image/s3,"s3://crabby-images/ac348/ac348ba9decd0ee9f91bb12d291ae00a26f6e776" alt=""
- Searching with Metasploit we find an exploit:
data:image/s3,"s3://crabby-images/d82c8/d82c86ff0dc200d54c9e38ce0720f99a0e7447db" alt=""
data:image/s3,"s3://crabby-images/6ae80/6ae8071e415abdb5ef04577d0137def6c825d4bd" alt=""
- Setting options for the exploit:
data:image/s3,"s3://crabby-images/80254/80254a12e902af7580ce1be2a33e9fc41ddbd8ae" alt=""
- One of the require options is a session, what corresponds to the session 1 backgrounded at point 3.2 of this exercise:
data:image/s3,"s3://crabby-images/4ff2f/4ff2f421e76e2324cf3ead713f04b25e876a181c" alt=""
- Running the exploit, the Privilege Escalation is successful because a root shell is achieved:
data:image/s3,"s3://crabby-images/d092f/d092fdcc772265c8ed63680c7154e2f3287399bc" alt=""
5 - CAPTURING THE FLAG
- Going to the /root folder:
data:image/s3,"s3://crabby-images/39c7e/39c7e8d092da6eefbbcec0e4d2fdc09c923a83e2" alt=""
data:image/s3,"s3://crabby-images/354d6/354d69641a7c47015cff488ed47d5f8dc62ab0b2" alt=""