Penetration Test Project
Project Summary
In this project, you have been hired to conduct a penetration test on a server operated by "Tiger Enterprises, Inc", a small consulting company. Tiger Enterprises has been increasingly concerned about the state of their computer systems in recent months due to the spread of ransomware. Adding to their concern, their full-time system administrator left for a better job three years ago and has been replaced by an ever-changing cast of temporary employees or interns handling the "computer stuff" just to keep the lights on. Can you help them to identify their security weaknesses, and provide advice on remedial actions they could take?
Getting Started
For the purposes of this project, you have been provided one virtual machine: "U". Your contact at Tiger Enterprises has given you written permission to both scan and attempt to actively exploit this machine for the purposes of penetration testing, but wasn't able to provide much in the way of technical details, saying they were "not really a computer person".
Download the virtual machine and import it into VMware alongside your Kali VM.
The download link is available in the Canvas project assignment (and not publicly posted here).
Testing Requirements
For the purposes for this course project, you can consider your penetration test to be complete if you achieve the following goals:
"U" System:
- Run port/version scans using Nmap and vulnerability scans using OpenVAS and/or Nessus
- Discover at least two exploits that provide for remote command-line access.
- At least one method, either directly, or through privilege escalation, must allow you to gain full control over the machine, equivalent to the root, Administrator, or SYSTEM user.
- Discover at least one existing user account (username and password) that provides for remote command-line access to the system. The existing password must be provided in plaintext.
Notes:
(1) Attacks requiring physical machine access to be successful are outside the scope of this project. In this penetration test, you are only interacting with the Tiger Enterprise system over the network.
Documentation Requirements
Your deliverable for this penetration test should be a formal written report.
Note: Your report should be narrative in style, with human explanation and commentary. A "report" that is merely a collection of screenshots and data dumps will be graded poorly.
Your report should be structured as follows:
Section 1: Introduction / Purpose of Penetration Test
Section 2: Executive Summary of Results
What methods of access did you discover? What logins did you discover?
Section 3: Application Scanning Results
Document the applications running on the server. Provide a table summarizing the protocol (TCP/UDP), port number, application name, application version, and any other information you find relevant. In addition, describe how the results were obtained, i.e. your methodology.
Section 4, 5, 6, ... : Access via Exploit (EACH exploit gets its OWN section)
For each exploit or privilege escalation method that you personally verified (and not merely theorized from some automated scan tool), provide a section describing that method in detail. Include the following information:
- What network service or software component is vulnerable? Specify its name and version number.
- What port number does that service listen on? (if applicable)
- What is the CVE number of the vulnerability? (if applicable)
- What are the exact steps you took to discover the vulnerability?
- What are the exact steps you took to exploit the vulnerability?
- What level of access is granted by the vulnerability? (Commands run as a specific user? Does that user have full control?)
- How can you prove that you have the level of access you claim? Provide screenshots documenting your key accomplishments.
- How does the vulnerability function? (this may require external research on your part)
- What steps should a system administrator take to mitigate this vulnerability?
Section n: Access via User Logins
Document the user login(s) (usernames and passwords) that you discovered. Include the following information:
- Username and passwords for each login
- How did you discover and verify each of these logins?
- What steps should a system administrator take (or policies that should be enforced) to reduce the likelihood of attackers obtaining these logins through similar methods?
Conclusion
Appendix: Vulnerability Scan Results
As an appendix to your written report, submit the results of an automated vulnerability scan tool such as Nessus or OpenVAS. In this appendix, it is acceptable to have vulnerabilities listed that you have not personally had the time to verify in this project. This section should contain the complete scan results with all the vulnerability details, not just a summary. Export the scan results as a PDF, and concatenate it to your report PDF.
Resources
- All the class labs to-date! :)
- Exploit Proof-of-Concepts (POCs)
- Linux Post-Exploit Cheat Sheet
- Linux Enumeration Cheat Sheet
Grading
Checkpoint 1 (5 pts)
For the first checkpoint, submit a progress report of your penetration test to date. By this point, you should have conducted port and version scans of the target using Nmap, and vulnerability scans of the target using either OpenVAS or Nessus. The progress report must include the following elements:
- Application scanning results for server U. This should be a table summarizing the protocol (tcp/udp), port number, application name, application version, and any other information you find relevant.
- A discussion of how you obtained the application scanning results
- A discussion of at least three technical steps (tests, scans, exploit attempts, etc) that you intend to take next
- Appendix: OpenVAS scan or Nessus scan showing complete scan results with all vulnerability details
Checkpoint 2 (10 pts)
For the second checkpoint, submit a progress report of your penetration test to date. The progress report must include the following elements:
- Application scanning results for server U
- A summary of the vulnerabilities proven to exist. For full credit, you must have exploited at least one vulnerability. Include a screenshot of each successful exploit as "proof of work" in addition to the written commentary.
- A discussion of at least three technical steps (tests, scans, exploit attempts, etc) that you intend to take next
Penetration Test Report - Technical Content (40pts)
- 2+ exploits to gain shell access to the "U" system, including proof of access - 30pts
- 1+ logins to access the "U" system, including proof of access - 10pts
Penetration Test Report - Human Explanation of Technical Content (35 pts)
- Clear discussion of each step taken to obtain an exploit or login - 20 pts
- Clear discussion of how each exploit functions - 5 pts
- Clear discussion of steps that a system administrator should take to mitigate each vulnerability - 10 pts
Peer Review (10 pts)
- Completion of 2 peer reviews
Submission
Submit your report in PDF format to the Canvas CMS site.