VULNOS 1
- Layout for this exercise:
data:image/s3,"s3://crabby-images/2c21e/2c21e40f44da8a876cd36d39fbe798d6a21e9f22" alt=""
1 - INTRODUCTION
- The purpose of this exercise is the study of the hacking process for the vulnerable machine VulnOS 1.
- VulnOS 1 can be downloaded from here:
https://www.vulnhub.com/entry/vulnos-1,60/
- Once VulnOS 1 downloaded and extracted with VirtualBox:
data:image/s3,"s3://crabby-images/72f25/72f258b911d1ee15f4a24cb1d138152242f47709" alt=""
- In this vulnerable machine it happens that the number of potential vulnerabilities is very large, because there are many open ports and the corresponding associated services running.
- According to the author's suggestion all the vulnerabilities should be found.
- However, in this exercise we have limited ourselves to the search of a root shell and eventually the capture of the flag, just by exploiting the mininum amount of essential vulnerabilities to achieve our goal.
2 - ENUMERATION
- Discovering the IP with netdiscover, we learn that VulnOS 1 is assigned with 192.168.1.11:
data:image/s3,"s3://crabby-images/54d3c/54d3ccf3f0d090ba93a865dcbc763462d7682a01" alt=""
data:image/s3,"s3://crabby-images/eb538/eb53855ead1dcd20d65c39627587ffc83d083890" alt=""
- Scanning with Nmap the great amount of services running:
data:image/s3,"s3://crabby-images/19a82/19a8204264470c382570659535653212192e32d5" alt=""
- Browsing the web:
data:image/s3,"s3://crabby-images/b6b56/b6b563c49d897a2466f2da4b52b4b2a303e94f69" alt=""
data:image/s3,"s3://crabby-images/857a4/857a41f488c13ce590a83d1a12c1f3a2e7daf327" alt=""
- dirb helps to discover some of the available folders:
data:image/s3,"s3://crabby-images/29acd/29acd59cc9f2cd8184c69be6cb8f146b55862843" alt=""
data:image/s3,"s3://crabby-images/7681e/7681ec79fe96f642d445ea63f5e53efc4326af43" alt=""
3 - PHPMYADMIN
- Let's go first with phpmyadmin, which default login is root plus blank password.
- However these credentials don't work in our case, probably because of the configuration:
data:image/s3,"s3://crabby-images/9b1d0/9b1d0fd47f4a3d6295a7949382226da9dcad9e57" alt=""
- Using Medusa to find a valid password for username root:
data:image/s3,"s3://crabby-images/3c6bc/3c6bc2854828d2b2acf11f505a3b36beec84c62e" alt=""
data:image/s3,"s3://crabby-images/e30bf/e30bf24a960497dc0eb2dd0fd63bae4b092f8550" alt=""
- Medusa discovers root:toor, let's check whether it is correct:
data:image/s3,"s3://crabby-images/5ab4b/5ab4bcbd916812376adec313c89467536d180e9f" alt=""
- Yes, Medusa was right:
data:image/s3,"s3://crabby-images/aef54/aef54182e566ea7e96998411fbc9b5949d185be5" alt=""
- Now, the first thing to notice is the great amount of available databases, each one with its corresponding list of usernames and password hashes.
- Let's go with the main databases one bye one.
- dolibarr:
data:image/s3,"s3://crabby-images/398b6/398b680b01ca0e21ad6cddbfea44a444ed26e13f" alt=""
- drupal6:
data:image/s3,"s3://crabby-images/70e56/70e566136bcf93be4eb86a34190174aa85a70f01" alt=""
- dvwa (interesting):
data:image/s3,"s3://crabby-images/c0e10/c0e10f3b734a28dccf55abe192ea26ff0780e45a" alt=""
- mysql:
data:image/s3,"s3://crabby-images/62ed0/62ed0d4934ce19ffd35702f088f2f1a18b019318" alt=""
- nowasp:
data:image/s3,"s3://crabby-images/c41f6/c41f6434b8d1558f9ad1b7d7d20ff529d9e1c12a" alt=""
- weberp:
data:image/s3,"s3://crabby-images/da5ab/da5abd3d5c27b7ac2aaf8e4c127a79e595907b34" alt=""
- CrackStation helps to decrypt most of the hashes:
https://crackstation.net/
data:image/s3,"s3://crabby-images/b57c2/b57c2aeb4a573f975e218599ac0bf3959305e4c6" alt=""
data:image/s3,"s3://crabby-images/4e330/4e33002bb269a3c3721f1bdf7f366d16ff3b7df3" alt=""
data:image/s3,"s3://crabby-images/7c05f/7c05f3e70efe3917fa064c8e2e5586e9548e5499" alt=""
data:image/s3,"s3://crabby-images/40dff/40dffc932a859f77d79ed6810ce8f38b601248b4" alt=""
- Gathering all these credentials we create two text files:
- users.txt: containing all the usernames and logins
- passwords.txt: containing all the decrypted passwords
4 - EXPLOITING WEBADMIN
- Now, let's focus our attention on port 10000:
data:image/s3,"s3://crabby-images/b1195/b1195c9f5658ee9d5d85d864cd53ade351f3af4e" alt=""
- MiniServ 0.01 has got some exploits associated, for instance this Perl script that allows File Disclosure:
data:image/s3,"s3://crabby-images/ae8a0/ae8a001db2506c68437354a90295a52898d642d6" alt=""
- Locating exploit 2017 at Kali:
data:image/s3,"s3://crabby-images/069e2/069e2f9b67727040b73059cb54212c0133d1b300" alt=""
- As expected, it is an executable Perl script:
data:image/s3,"s3://crabby-images/8471c/8471c743c299eb2620bb534f9d48cd515ec698ef" alt=""
- Opening the script there is an usage example line:
data:image/s3,"s3://crabby-images/a9d60/a9d600245119bc8fc070bde1419727b19bb0de95" alt=""
data:image/s3,"s3://crabby-images/1cb4e/1cb4e9d8914afaa0da6980dccca795e7bb696c0e" alt=""
- Also, running the script without arguments we can learn how to use it:
data:image/s3,"s3://crabby-images/16d39/16d39948773a1ab57df2ca0f0b8ed847d76800de" alt=""
- For instance let's use the script 2017.pl to read remotely /etc/sudoers available at VulnOS 1:
data:image/s3,"s3://crabby-images/d6b0a/d6b0a3b911cf54dc27db171f798cf9f7f0ab7b89" alt=""
- Later (point 6.2 of this exercise) this Perl script will be used for achieving essential information about passwords for relevant users.
5 - EXPLOITING DVWA
- DVWA is the well-known Damn Vulnerable Web Application, basically a web application that is vulnerable on purpose:
http://www.dvwa.co.uk/
data:image/s3,"s3://crabby-images/86b0c/86b0cc006d84aee8dc2cd5e06a4eba3d4054a5de" alt=""
- The fact that DVWA is present at VulnOS 1 is an unvaluable gift, because it provides us with a lot of potential ways for exploitating the vulnerable machine.
- As seen before the valid credentials for DVWA are admin:password:
data:image/s3,"s3://crabby-images/24c9b/24c9bcbd48739b3451ada5dc5cb9b04eda5d38c7" alt=""
data:image/s3,"s3://crabby-images/e4d9f/e4d9fbafdc42662b3ab18dd9bbb57b9243cd96b1" alt=""
- Some of the recently released versions of DVWA are 1.9, 1.0.8, 1.0.7, etc ...
- Trying all of them, finally we have access to the DVWA web server:
data:image/s3,"s3://crabby-images/1d5d0/1d5d0d3e6e7dab3e8cb71ee29e27f6bc2cab9ab2" alt=""
data:image/s3,"s3://crabby-images/4f1e1/4f1e15e701f0f68de0400a32bbccaeedc5dd61d9" alt=""
- Let's notice that the default Security Level is set to high:
data:image/s3,"s3://crabby-images/f037c/f037c385864cad404710c00c19de56c789226f4f" alt=""
- Levering down to low:
data:image/s3,"s3://crabby-images/75fd3/75fd37334eb4a45a52d679a8aa39437744db8ada" alt=""
data:image/s3,"s3://crabby-images/0b4e8/0b4e885f53bd23e35b0d394fcbae5af4b60f832e" alt=""
data:image/s3,"s3://crabby-images/4b69c/4b69cc97f73000a43254593b1d68714f861487f7" alt=""
- Taking advantage of the Command Execution vulnerability let's try to submit this PHP script:
data:image/s3,"s3://crabby-images/badb2/badb27a80b26f1c448cd891a7391e6c298710603" alt=""
- Before that, don't forget to set a Netcat listener at port 4444:
data:image/s3,"s3://crabby-images/63724/6372447e66932e3d45cadc823cb4d3f2516ebb09" alt=""
- Now, submitting the script:
data:image/s3,"s3://crabby-images/9c5c8/9c5c8c35f2914e356eef4fc36fe91c0be1906988" alt=""
- As a consequence a low privilege shell is succesfully achieved:
data:image/s3,"s3://crabby-images/4e8d1/4e8d1e5c5a2beab1cc9e27d7f98fda45f383a737" alt=""
- Improving the shell:
data:image/s3,"s3://crabby-images/2314f/2314f4e98845c3cab2127d063659884b441c88df" alt=""
6 - PRIVILEGE ESCALATION
6.1 - HTPASSWD
- htpasswd is used to create and update the flat-files used to store usernames and password for basic authentication of HTTP users.
- Resources available from the Apache HTTP server can be restricted to just the users listed in the files created by htpasswd.
- htpasswd encrypts passwords using either bcrypt, a version of MD5 modified for Apache, SHA1, or the system's crypt() routine.
https://httpd.apache.org/docs/2.4/programs/htpasswd.html
- Let's try to find any htpasswd file across Vulnos 1:
data:image/s3,"s3://crabby-images/cc0ea/cc0ea45c8837431bf5c65e46c0502016c32a7420" alt=""
data:image/s3,"s3://crabby-images/08686/0868684ec29a24f85b4f3f10faf3f93fbc6f909e" alt=""
- Reading the file:
data:image/s3,"s3://crabby-images/8bee6/8bee6030ab6bbf8514da50c029bbe09b54ee740f" alt=""
- Also, looking for htpasswd.users:
data:image/s3,"s3://crabby-images/e871b/e871b3b765cf72a8144d54f3d138b221eab4e48d" alt=""
data:image/s3,"s3://crabby-images/a4e18/a4e18685bc39eecfb813b8c9e002d0609414f8b8" alt=""
data:image/s3,"s3://crabby-images/694f8/694f846dbf3347598d64e04218b52bb4357262d8" alt=""
- John The Ripper helps to decrypt the second password:
data:image/s3,"s3://crabby-images/200d6/200d679bc829339941bc3fbe01b9c1f2a5bd5692" alt=""
data:image/s3,"s3://crabby-images/eb0be/eb0bed9a11ce855051454d334a147eccc944548f" alt=""
data:image/s3,"s3://crabby-images/625a1/625a1a0aac96d9a5a1eb8d9e22ca1ad146c2fd5a" alt=""
- However this path does not lead us to anything, let's try another way.
6.2 - vulnosadmin
- Let's focus our attention on the interesting user vulnosadmin:
data:image/s3,"s3://crabby-images/b5f03/b5f03c42ba3b7ff8c9035809e0139f12673ebb63" alt=""
data:image/s3,"s3://crabby-images/dad8c/dad8cbd4f8fc693091738e635856a67d39423d92" alt=""
- Going to his home directory we find that vulnosadmin has been a successful sudoer in the past:
data:image/s3,"s3://crabby-images/3f1d9/3f1d9732484d57847eb9dc6ad5ebdfa14257370d" alt=""
- Now, taking advantage of the webmin exploit at port 10000 used at point 4 of this exercise, we can get both /etc/passwd and /etc/shadow for vulnosadmin:
data:image/s3,"s3://crabby-images/771ad/771ada4504b1aa84df4456ca902eabdac469d986" alt=""
- Copying output to files a and b:
data:image/s3,"s3://crabby-images/bb561/bb561f3a5799d7298ff08344d18497f77a41c7d7" alt=""
- Preparing the password hahes with unshadow command:
data:image/s3,"s3://crabby-images/6cf58/6cf58408c192038623ba334c50374f248eed3a26" alt=""
- Applying John The Ripper over file u:
data:image/s3,"s3://crabby-images/59d9c/59d9c8dee7c386ac8bbf678f7d99d24bb163d43a" alt=""
- Finally we have been able to decrypt vulnosadmin user's password.
6.3 - SSH
- Using our lists from point 3 users.txt and passwords.txt (where canuhackme has been added) Medusa finds the right credentials for SSH remote shell connection:
data:image/s3,"s3://crabby-images/8a167/8a1675cd49ecc8a19a5af0b6278cc5f047963191" alt=""
data:image/s3,"s3://crabby-images/a5c77/a5c779db8d789fdf2ed53496f431bb0165816947" alt=""
- Now, entering SSH credentials vulnosadmin:canuhackme let's connect to Vulnos 1:
data:image/s3,"s3://crabby-images/c2f72/c2f721f31892f949a4c3f1729f7469e75abf5507" alt=""
- The good news are that vulnosadmin is an (ALL)ALL sudoer:
data:image/s3,"s3://crabby-images/2e5f4/2e5f4d4b065a993c034ae16cd6240efb5cd8b370" alt=""
- Changing the password for user root:
data:image/s3,"s3://crabby-images/47519/47519ab897ad4f714a0ee947fb2b322a9dbbc6e3" alt=""
- Finally a root shell is succesfully achieved:
data:image/s3,"s3://crabby-images/cfbb7/cfbb7bf64bd861d5675d48b98ddada482e1c2c9e" alt=""
- Also this would be equally valid:
data:image/s3,"s3://crabby-images/5e13d/5e13d244c13a8fa866d396b52dca6243964678de" alt=""
7 - CAPTURING THE FLAG
- Reading hello.txt:
data:image/s3,"s3://crabby-images/756c8/756c815a1ccd367d49e307eb3542e6a834a3e607" alt=""