Franske ITC 2900 SP20 Possible Projects
Possible Projects
Power Monitoring
Research, explore, and demonstrate the use of the NUT UPS power monitoring software to manage large numbers of uninterruptible power supplies on the ITC network. Specifically, research the use of NUT and develop/implement a plan to connect a Raspberry Pi running Raspbian Lite and running NUT to every UPS in the ITC labs and connect them with static IPs to the ITC network. If time allows provide centralized status reporting via MQTT.
Resources
- Lots of Raspberry Pis
- UPSs
Deliverables
- Working NUT servers on every UPS
- Documentation on setup and configuration
- Prepare a whitepaper and presentation detailing your research, testing process, and results
Network Automation
Research, explore, and demonstrate the use of network automation, the ability to configure and program network devices with software code. It's expected that you would build a small demonstration network and then install one or two network automation software packages to manage and make changes to the network.
Resources
- Cisco Routers & Switches
- 3Com/HP Switches
- Network Automation Software (Ansible, Chef, Puppet, etc.)
Deliverables
- Working network automation system
- Documentation on setup and configuration
- Prepare a whitepaper and presentation detailing your research, testing process, and results
DNS and Web Deep Dive
Introduction
Explore the operation of DNS servers, Web servers, and related services by modeling how the Internet DNS system works. Includes deploying at least a root nameserver, a few TLD nameservers, some nameservers for particular domains, delegated nameservers, as well as a root Certificate Authority, experimenting with DNSSEC and DANE, and setting up demo webservers for sample domains (utilizing the DNS infrastructure, DNSSEC, DANE, SSL/TLS certificated, etc.)
Resources
- Lots of Linux server VMs
- BIND DNS Server (and/or Unbound DNS server)
- nginx web server
Deliverables
- Public Key Infrastructure setup (certificate creation, signing, etc.)
- DNS Server hierarchy with working DNSSEC/DANE access to webservers/sample domains
- Prepare a whitepaper and presentation detailing your research, testing process, and results
Comparison of File Synchronization Servers
Introduction
Install, configure and test a variety of self-hosted services for file synchronization. These could include rsync based software, Goggle's Upspin, Syncthing, OwnCloud/NextCloud, SparkleShare, etc.
Resources
- Virtual machines
Deliverables
- Working file synchronization systems
- Comparison and documentation for various file sync systems
- Prepare a whitepaper and presentation detailing your research, testing process, and results
VMware Virtual Machine Automation and Permissions
Introduction
The ITC department utilizes VMware based virtual machines for a variety of classes. There is currently a manual process to create many virtual machines for each class (including virtual networks, etc.), modify them during the semester (such as wiping the virtual hard drive, etc.), and assign students permissions to them, etc. In addition there have been challenges in identifying the minimum set of permissions which students need access to in order to use the VMs in a class but not have access to interfere with other VMs running for other classes or for departmental services. Your goal is to automate as much of the deployment, configuration, maintenance, etc. as possible as well as to determine the appropriate permissions for students so they do not encounter permissions errors when completing course tasks but do not have overly broad permissions.
Resources
- VMware ESXi Servers
- VMware vCenter Server
- Test VMs
- Python programming
Deliverables
- Permissions recommendations for VMware
- VMware Automation Scripts
- Prepare a whitepaper and presentation detailing your research, testing process, and results
Asterisk PRI Integration
Introduction
The ITC department currently has a "PSTN Simulator" running Cisco IOS and CUCME (Cisco Unified Communications Manager Express) but the configuration is complex and difficult to manage. Your goal is to implement the same functionality of the PSTN Simulator using the open-source Asterisk PBX. This will require some experimentation with the Asterisk VoIP PBX software as well as experimentation surrounding integrating it with the T1 ports on the Cisco hardware.
Resources
- Cisco Routers with T1 cards
- Asterisk PBX Software
Deliverables
- Design, implement and test configurations which replicate PSTN Simulator functionality using Asterisk
- Document all configurations
- Prepare a written whitepaper and oral presentation detailing the process, criteria, results, and configurations
Network Access Control
Introduction
The Inver Hills ITC department has an academic, demonstration, and research network ("ITCnet") which uses network devices from Cisco and HP and supports a number of virtual machines, hosts, and devices including Windows, Linux, Android, iPhone, and more. Network ports are not physically securable but it may be possible to improve security on this network by implementing some type of Network Access Control (NAC) which restricts access to network resources until a user authenticates to the network. Users on our network are stored in an Active Directory system which is also accessible through LDAP and RADIUS methods. It has been determined in previous groups that PacketFence is a reasonable option for NAC but test implementations with switches and wireless APs have not been completed. You task would be to setup and test PacketFence with the Cisco and HP/3Com switches we use as well as with the Ubiquiti UniFi APs (running OpenWrt) and to document your results.
Resources
- Cisco Switches
- HP/3Com Switches
- Wireless APs and Controllers
- Windows Server / Active Directory
- PacketFence Open Source NAC
Deliverables
- Design and implement a test network environment
- Determine, test, and document configurations which will meet the 802.1x and captive portal requirements
- Prepare a written whitepaper and oral presentation detailing the process, criteria, results, and configurations