Honeypots
Project Objectives
In this individual project, you will both use an existing off-the-shelf honeypot and create your own.
Part 1 Requirements - Off the Shelf Honeypot
For the first part of the project, you are going to deploy an existing honeypot, expose it on the Internet in a controlled manner, and use it to collect information.
First, pick a freely available honeypot. Examples include.
- Dionaea - Malware Trap
- Cowrie - SSH Honeypot (also see http://www.micheloosterhof.com/cowrie/)
- Anything on the Awesome Honeypots list
- Anything available via TPot, a universal installer that includes dockerized containers of many Linux honeypots.
- Anything available via HoneyDrive, a Linux distribution with pre-installed honeypots.
Second, install your chosen honeypot on a local virtual machine, either directly, or via TPot, HoneyDrive, or some other wrapper. Learn how to configure and use your honeypot.
Third, decide on how you wish to deploy this honeypot. Questions to consider include:
- Hosting: Do you want to run it on the VMware host in the lab or in the cloud via Amazon Web Services?
- Networking:
- What ports does your honeypot need to be exposed to the Internet on?
- What specific communication pattern does the firewall need to permit? (assuming deny all other communication)
- If we lock down the honeypot server completely, how will you obtain your results?
- Do you want a public IP for your honeypot, or port forwarding from some other IP? What are the implications for the IP address of hosting a honeypot there?
Fourth, run your honeypot for at least a week! Write a short report that includes the following information:
- The name of the honeypot you used
- What features the honeypot provides
- How you configured your specific installation (honeypot features, network configuration, etc)
- The data that your honeypot has collected, including an explanation of what the results mean in plain English. (i.e. don't just copy and paste the output file, put your name up top, and call it a day).
Part 2 Requirements - Honeypot Implementation
For the second part of the project, you are going to implement a honeypot yourself.
Requirements
There are three high-level requirements of your new honeypot:
- For a dumb/lazy/excessively automated attacker, your honeypot needs to appear to be a viable target system.
- The attacker needs to be able to do something to or with your honeypot, such that the attacker has revealed malicious intent beyond background internet port scanning
- Your honeypot needs to have a “marketing use case” whereby running the honeypot and examining its results could yield some benefit to a defender.
Project Proposal Requirements
Write a short proposal (less than 1 page) describing the honeypot you intend to build. In it, answer the following questions:
- What are you modeling? A software daemon? (Database, SMB file share, NTP server, etc…) An Internet of Things (IOT) appliance?
- What level of interaction will your honeypot permit with the attacker? (Low-to-medium, presumably)
- What level of emulation fidelity will your honeypot support? Or, in other words, how hard will the attacker have to work to identify the honeypot as not a real device?
- In your development, how are you going to compare your system against the real thing?
- How would an attacker identify what they have connected to? (Is the attacker looking for something in particular? Or casting a wide net?)
- What is the attacker going to do to or with your honeypot?
- What will you learn from your honeypot about the attacker?
Project Deliverables
- Project proposal document (< 1 page)
- The code
- Documentation for installation + configuration + interpreting results
- Documentation providing a technical comparison between real system and honeypot
- Port scan
- Services provided
- Interactions possible with the services
- Documentation covering detailed use case scenarios
- What is the attacker going to do to or with your honeypot?
- What will you learn from your honeypot about the attack?
Grading
This is an individual project. The grading breakdown is:
- Off-the-shelf honeypot installation and report - 40%
- Your custom honeypot implementation and documentation - 60%
Schedule
Your goal should be to have the off-the-shelf honeypot installed and collecting data in week "1", develop your own honeypot in weeks "2-3", and write up both sets of results at the end.
Submission
Submit all files to the Canvas CMS site.
Make sure that your submission includes all of the following project deliverables:
- Your report on the off-the-shelf honeypot usage and results
- Your report on your own custom honeypot usage and results
- Your source code and usage documentation for your custom honeypot