Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/giovannibaccichet/ant-net
Infrastructure as Code (IaC) for Advanced Network Technologies (ANT) Educational Lab
https://github.com/giovannibaccichet/ant-net
coap-server education infrastructure-as-code mqtt terraform vpn wi-fi wireguard-vpn
Last synced: about 2 months ago
JSON representation
Infrastructure as Code (IaC) for Advanced Network Technologies (ANT) Educational Lab
- Host: GitHub
- URL: https://github.com/giovannibaccichet/ant-net
- Owner: GiovanniBaccichet
- License: gpl-3.0
- Created: 2024-09-24T13:58:52.000Z (4 months ago)
- Default Branch: main
- Last Pushed: 2024-11-21T13:31:22.000Z (about 2 months ago)
- Last Synced: 2024-11-21T14:28:47.295Z (about 2 months ago)
- Topics: coap-server, education, infrastructure-as-code, mqtt, terraform, vpn, wi-fi, wireguard-vpn
- Language: HCL
- Homepage:
- Size: 689 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
ANT Net
Infrastructure as Code (IaC) for Advanced Network Technologies (ANT) Educational Lab
ANT Lab Website »
## About The Project
ANT-Net is a self deployable virtual infrastructure that hosts different services that are used in different courses at Politecnico di Milano. In particular it hosts:
- **VPN Gateway**: [Wireguard](https://www.wireguard.com/) server w/ web interface for managing users and remote access to the infrastructure
- **MQTT Broker**: [EMQX](https://www.emqx.com/en) server with web interface for managing topics and clients
- **CoAP Server**: Python-based CoAP server
- **File Server + Sensor Network**: a RPi network sending wireless data to a centralized file management serviceThe diagram below shows the logical organization of the virtual infrastructure, and in particular how the network is segmented to prevent users from communicating with machines on the outside of the virtual lab network.
![ANT-Net Infrastructure](images/proxmox-infra.png)
### Built With
The project is build around [Proxmox](https://www.proxmox.com/en/). The deployment of VMs is performed through [Hashicorp Terraform](https://www.terraform.io/), using the [Terraform Provider for Proxmox](https://github.com/bpg/terraform-provider-proxmox). Despite being very well documented, said provider lacks some features regarding Proxmox templating and networking, and for that reason I added the scripts in `scripts/`. Additionally, the VM configuration is performed with the scripts in `scripts/vm_configuration`, this since every configuration is very simple, and it would have been totally overkill to use a tool like Ansible.
## Getting Started
The main goal of this project being a reproducible and easy-to-deploy setup, most of the configurations are automatic and require little to none user interaction.
### Prerequisites
To successfully deploy the infrastructure, ensure you meet the following requirements:
1. **Proxmox Server**
- A computer running [Proxmox Virtual Environment](https://www.proxmox.com/) (tested on version 8.2).
- Ensure that the server is connected to the internet and has at least one separate Network Interface Card (NIC).2. **Network Interface Configuration**
- **Motherboard NIC**: Reserved for internet access and Proxmox management - will be `vmbr0`.
- **PCIe NIC**: Dedicated to the *VPN-Gateway* virtual machine. This NIC should be configured to be passed through to the VM and exposed publicly for VPN access.3. **Additional Requirements**
- Sufficient resources (CPU, RAM, and storage) to run the Proxmox environment and the planned virtual machines - in the base config, at least 8 CPU cores and 16 GB RAM.
- Access to a computer or device with Terraform installed ( [Terraform installation guide](https://developer.hashicorp.com/terraform/tutorials)).
- SSH keys configured for secure access to Proxmox and other virtual machines.4. **Terraform Environment**
- Terraform (version 1.9.8 or later, tested with version 1.9.8).
- The Terraform Proxmox provider configured. Install it via `terraform init` using the provided `proxmox` provider in this repo's `main.tf`.### Proxmox Authentication
The Terraform Proxmox provider uses API Token Key authentication. Before starting we need to create a user and generate an API token for that user (more info [here](https://registry.terraform.io/providers/bpg/proxmox/latest/docs)). For this project, user creation, permissions, API Token generation and SSH keys are managed using `scripts/ssh_api_token_setup.sh`.
**It is mandatory to execute that script** - or generate manually a user, assign the correct permissions and generate an API Token - **before proceeding**. It will output the SSH keys, both public and private, in `ssh`, and will output in CLI the Proxmox API Token, which must be copied and will be used by Terraform as authentication.
Inside `terraform/terraform.tfvars` put the output of the script, it should be something like:
```json
api_token = "terraform@pve!provider=xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx"
```### Network
Install guest agents on cloud image:
```bash
virt-customize -a noble-server-cloudimg-amd64.img --install qemu-guest-agent
```The Proxmox Terraform provider we are using, despite being the one with the most features wrt API support, does not fully support the newly introduced SDN functionality of Proxmox (>= 8.0). For this reason we are using a bash script that leverages the `pvesh` command, a shell interface for the Proxmox VE API, more on that [here](https://pve.proxmox.com/pve-docs/pvesh.1.html).
The script can be found in `scripts/network_setup.sh`, but here is a short comment to better understand what it does:
1. Create a **simple zone**:
```bash
pvesh create /cluster/sdn/zones --type simple --zone "labnet" --dhcp "dnsmasq" --ipam "pve"
```
2. Create a **Virtual Network** within the previously created zone:
```bash
pvesh create /cluster/sdn/vnets --vnet "labvnet" --zone "labnet"
```
3. Create a **subnet** for that Virtual Network:
```bash
pvesh create /cluster/sdn/vnets/labvnet/subnets --subnet "10.10.10.0/24" --type "subnet" --gateway "10.10.10.1" --snat true --dhcp-range start-address=10.10.10.10,end-address=10.10.10.254
```
4. Apply SDN controller changes and reload:
```bash
pvesh set /cluster/sdn
```Simple Zones are explained into detail [here](https://pve.proxmox.com/wiki/Setup_Simple_Zone_With_SNAT_and_DHCP).
### Installation
External NIC to VPN Gateway:
`qm set 111 -hostpci0 0000:04:00.0`
Install EMQX:
```bash
curl -s https://assets.emqx.com/scripts/install-emqx-deb.sh | sudo bash && sudo apt-get install emqx && sudo systemctl start emqx && sudo emqx start
```Routes for VPN gateway:
`sudo ip route add 10.10.10.0/24 dev eth0`
Interface for VPN gateway:
`sudo sed -i '/eth0:/a\ ens16f0:\n dhcp4: true' /etc/netplan/50-cloud-init.yaml && sudo netplan apply`
## Usage
Use this space to show useful examples of how a project can be used. Additional screenshots, code examples and demos work well in this space. You may also link to more resources.
_For more examples, please refer to the [Documentation](https://example.com)_
## Roadmap
- [x] Automatically configure networking
- [x] Automatically generate API Token
- [x] Download and patch Ubuntu Cloud image w/ `qemu-guest-agent`
- [x] Deploy VMs
- [x] Deploy firewall rules
- [ ] Provision VMs
- [ ] VPN Gateway
- [x] MQTT Broker
- [ ] CoAP Server
- [ ] File Server
- [ ] Stress test the infrastructureSee the [open issues](https://github.com/GiovanniBaccichet/ANT-net/issues) for a full list of proposed features (and known issues).
## Contributing
Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**.
If you have a suggestion that would make this better, please fork the repo and create a pull request. You can also simply open an issue with the tag "enhancement".
Don't forget to give the project a star! Thanks again!1. Fork the Project
2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`)
3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`)
4. Push to the Branch (`git push origin feature/AmazingFeature`)
5. Open a Pull Request## License
Distributed under the GPLv3 License. See `LICENSE` for more information.
## Contact
Giovanni Baccichet - [email protected]
Project Link: [https://github.com/GiovanniBaccichet/ANT-Net](https://github.com/GiovanniBaccichet/ANT-Net)
## Acknowledgments
- Proxmox