MR-ROBOT
- Layout for this exercise:
1 - INTRODUCTION
- The goal of this exercise is the study of the hacking process for the vulnerable machine Mr-Robot.
- According to the description provided by the authors of Mr-Robot there are 3 keys or flags to be found:
- Mr-Robot can be downloaded from here:
- Once downloaded and extracted with VirtualBox:
2 - ENUMERATION
- Using netdiscover to find the IP that corresponds to the vulnerable machine Mr-Robot:
- Scanning with Nmap:
- Scanning with nikto we find a lot of information:
data:image/s3,"s3://crabby-images/a54b9/a54b9e6754bd8a2a2d6d17d52cb14ee78a598483" alt=""
- After reading nikto output we learn that a WordPress page is running with a login PHP script, and also some other pages interesting to be studied.
- Connecting to the website:
- Checking the wp-login.php page:
- When trying to connect to the admin page it hangs up:
- Visiting wp-links-opml.php we learn that the website is running the version WordPress/4.3.16, what is outdated:
3 - EXPLOITATION
3.1 - robots.txt
- Also, robots.txt gives us key information to start the exploitation process:
data:image/s3,"s3://crabby-images/bf074/bf07433b39c3a03570566aa81073dbdb9923a2d8" alt=""
- Opening key-1-of-3.txt we find the 1st key:
3.1 - robots.txt
- Also, robots.txt gives us key information to start the exploitation process:
data:image/s3,"s3://crabby-images/bf074/bf07433b39c3a03570566aa81073dbdb9923a2d8" alt=""
- Opening key-1-of-3.txt we find the 1st key:
3.2 - Dictionary fsocity.dic
- Opening with cat we find a very long file text composed of a lot of lines what seem part of a dictionary:
......
- Counting the lines there are 858160, so no doubt this is a very complex file to be handled:
- How many of the 858160 lines are unique? Just 11451, so removing the repeated lines would make it easier to deal with the file:
data:image/s3,"s3://crabby-images/2ca5d/2ca5db9f17f102904f93209099d5994edfb3a5b0" alt=""
data:image/s3,"s3://crabby-images/2ca5d/2ca5db9f17f102904f93209099d5994edfb3a5b0" alt=""
- Let's create a new file ufsocity.dic that contains only the non repeated lines of the original text file:
data:image/s3,"s3://crabby-images/3ba7a/3ba7ad40dc3dc4ac40b398b9bd930a5688478f7c" alt=""
- Now, the file ufsocity.dic can be used for exploitation purposes as a brute force dictionary or wordlist.
3.3 - Dictionary attack with Hydra
- Hydra and ufsocity.dic help to perform a dictionary attack against the login page.
- Before launching the attack let's see what type of error message uses the login page, for instance using non valid admin:admin as credentials:
data:image/s3,"s3://crabby-images/e6611/e6611e19f21c8a91b644b143aca50ace1d4632b4" alt=""
- As expected there is an error message Invalid username:
data:image/s3,"s3://crabby-images/0dc86/0dc86504da28ceeff045038aeb0c1d8af9f6582b" alt=""
- Before launching the attack let's see what type of error message uses the login page, for instance using non valid admin:admin as credentials:
data:image/s3,"s3://crabby-images/e6611/e6611e19f21c8a91b644b143aca50ace1d4632b4" alt=""
- As expected there is an error message Invalid username:
data:image/s3,"s3://crabby-images/0dc86/0dc86504da28ceeff045038aeb0c1d8af9f6582b" alt=""
- Using this information (F=Invalid username) let's find a username without caring for the password (-p wedontcare):
- The error message confirms that elliot is correct as a username:
- Launching again Hydra, now passing the user elliot (-l elliot), we discover a password ER28-0652:
3.4 - Reverse shell with Metasploit
- Taking advantage of the fact we have valid credentials we can try finding a reverse shell with Metasploit:
data:image/s3,"s3://crabby-images/115e5/115e55df87835c370cad3c3a8ea762bfb94e10ad" alt=""
- Taking advantage of the fact we have valid credentials we can try finding a reverse shell with Metasploit:
data:image/s3,"s3://crabby-images/115e5/115e55df87835c370cad3c3a8ea762bfb94e10ad" alt=""
- Runnig the exploit it fails, giving this error message: "The target does not appear to be using WordPress":
data:image/s3,"s3://crabby-images/c2362/c23620044c694107bcc0b10a19be53cac4c36eba" alt=""
- Locating the exploit into Kali's file system:
- Once modified and reloaded, the exploit is successful:
- Getting a shell from the meterpreter session we find that a limited user is running:
data:image/s3,"s3://crabby-images/dd45b/dd45b10db1aaec1c92bf705f4c972c1f6a1ffb3a" alt=""
3.5 - Finding the second key
- Opening /home:
- At the robot user's home folder there is the 2nd key, but we cannot open it at this moment:
- Trying to run the user robot with the previous password, it works:
- There is a vulnerability associated to Nmap being run with special privileges like SUID root:
- Due to the presence of the SUID, using Nmap interactive mode we are able to run commands with root privileges: