2.6 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	RustyDHCP
A simple and zero-dependency DHCP server written in Rust, with credit to Richard Warburton for contributions to parts of the code.
Features
- Lightweight and minimalistic DHCP server.
- Zero external dependencies; just Rust!
- Easy to use and configure.
- Based on reliable networking libraries.
- Fast and efficient.
- Cross-platform support and cross-compilation.
Table of Contents
Installation
- 
Make sure you have Rust installed. If not, install it from https://www.rust-lang.org/. 
- 
Clone this repository: git clone https://github.com/pj1234678/RustyDHCP.git
- 
Build the server: cd rusty-dhcp cargo build --release
Usage
- 
Start the DHCP server: sudo ./target/release/rusty-dhcpThe server will listen on the default DHCP ports (67 and 68) and start serving DHCP requests. 
- 
Make DHCP requests from clients, and the server will respond with IP addresses and other configuration details. 
Configuration
To configure the server, edit the following fields in the examples/server.rs file:
// Server configuration
const SERVER_IP: Ipv4Addr = Ipv4Addr::new(192, 168, 2, 1);
const IP_START: [u8; 4] = [192, 168, 2, 2];
const SUBNET_MASK: Ipv4Addr = Ipv4Addr::new(255, 255, 255, 0);
const DNS_IPS: [Ipv4Addr; 1] = [
    // Google DNS servers
    Ipv4Addr::new(8, 8, 8, 8),
];
const ROUTER_IP: Ipv4Addr = Ipv4Addr::new(192, 168, 2, 1);
const BROADCAST_IP: Ipv4Addr = Ipv4Addr::new(192, 168, 2, 255);
const LEASE_DURATION_SECS: u32 = 86400;
const LEASE_NUM: u32 = 252;
You can customize these configuration parameters according to your network requirements.
Contributions
This DHCP server has been made possible with contributions from the open-source community, including valuable code from Richard Warburton. Feel free to contribute to this project and make it even better!
If you find a bug or have a feature request, please open an issue on the GitHub repository.
License
This project is licensed under the MIT License - see the LICENSE file for details.
Note: Remember to use this DHCP server responsibly and comply with local network regulations and security practices.