2020-07-03 15:20:01 +00:00
|
|
|
package dhcpd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"net"
|
|
|
|
"time"
|
|
|
|
)
|
|
|
|
|
|
|
|
// DHCPServer - DHCP server interface
|
|
|
|
type DHCPServer interface {
|
2021-06-16 13:48:46 +00:00
|
|
|
// ResetLeases resets leases.
|
|
|
|
ResetLeases(leases []*Lease) (err error)
|
|
|
|
// GetLeases returns deep clones of the current leases.
|
|
|
|
GetLeases(flags GetLeasesFlags) (leases []*Lease)
|
2020-07-03 15:20:01 +00:00
|
|
|
// AddStaticLease - add a static lease
|
2021-06-16 13:48:46 +00:00
|
|
|
AddStaticLease(l *Lease) (err error)
|
2020-07-03 15:20:01 +00:00
|
|
|
// RemoveStaticLease - remove a static lease
|
2021-06-16 13:48:46 +00:00
|
|
|
RemoveStaticLease(l *Lease) (err error)
|
2020-07-03 15:20:01 +00:00
|
|
|
// FindMACbyIP - find a MAC address by IP address in the currently active DHCP leases
|
|
|
|
FindMACbyIP(ip net.IP) net.HardwareAddr
|
|
|
|
|
|
|
|
// WriteDiskConfig4 - copy disk configuration
|
|
|
|
WriteDiskConfig4(c *V4ServerConf)
|
|
|
|
// WriteDiskConfig6 - copy disk configuration
|
|
|
|
WriteDiskConfig6(c *V6ServerConf)
|
|
|
|
|
|
|
|
// Start - start server
|
2021-06-16 13:48:46 +00:00
|
|
|
Start() (err error)
|
2020-07-03 15:20:01 +00:00
|
|
|
// Stop - stop server
|
2021-06-16 13:48:46 +00:00
|
|
|
Stop() (err error)
|
2021-03-18 14:07:13 +00:00
|
|
|
|
|
|
|
getLeasesRef() []*Lease
|
2020-07-03 15:20:01 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// V4ServerConf - server configuration
|
|
|
|
type V4ServerConf struct {
|
2021-01-20 12:59:24 +00:00
|
|
|
Enabled bool `yaml:"-" json:"-"`
|
|
|
|
InterfaceName string `yaml:"-" json:"-"`
|
2020-07-03 15:20:01 +00:00
|
|
|
|
2021-01-20 12:59:24 +00:00
|
|
|
GatewayIP net.IP `yaml:"gateway_ip" json:"gateway_ip"`
|
|
|
|
SubnetMask net.IP `yaml:"subnet_mask" json:"subnet_mask"`
|
2021-07-30 12:27:24 +00:00
|
|
|
// broadcastIP is the broadcasting address pre-calculated from the
|
|
|
|
// configured gateway IP and subnet mask.
|
|
|
|
broadcastIP net.IP
|
2020-07-03 15:20:01 +00:00
|
|
|
|
|
|
|
// The first & the last IP address for dynamic leases
|
|
|
|
// Bytes [0..2] of the last allowed IP address must match the first IP
|
2021-01-20 12:59:24 +00:00
|
|
|
RangeStart net.IP `yaml:"range_start" json:"range_start"`
|
|
|
|
RangeEnd net.IP `yaml:"range_end" json:"range_end"`
|
2020-07-03 15:20:01 +00:00
|
|
|
|
2021-01-20 12:59:24 +00:00
|
|
|
LeaseDuration uint32 `yaml:"lease_duration" json:"lease_duration"` // in seconds
|
2020-07-03 15:20:01 +00:00
|
|
|
|
|
|
|
// IP conflict detector: time (ms) to wait for ICMP reply
|
|
|
|
// 0: disable
|
2021-01-20 12:59:24 +00:00
|
|
|
ICMPTimeout uint32 `yaml:"icmp_timeout_msec" json:"-"`
|
2020-07-03 15:20:01 +00:00
|
|
|
|
2020-08-25 11:07:11 +00:00
|
|
|
// Custom Options.
|
|
|
|
//
|
|
|
|
// Option with arbitrary hexadecimal data:
|
|
|
|
// DEC_CODE hex HEX_DATA
|
|
|
|
// where DEC_CODE is a decimal DHCPv4 option code in range [1..255]
|
|
|
|
//
|
|
|
|
// Option with IP data (only 1 IP is supported):
|
|
|
|
// DEC_CODE ip IP_ADDR
|
2021-01-20 12:59:24 +00:00
|
|
|
Options []string `yaml:"options" json:"-"`
|
2020-08-25 11:07:11 +00:00
|
|
|
|
2021-03-16 16:11:32 +00:00
|
|
|
ipRange *ipRange
|
|
|
|
|
2020-07-03 15:20:01 +00:00
|
|
|
leaseTime time.Duration // the time during which a dynamic lease is considered valid
|
|
|
|
dnsIPAddrs []net.IP // IPv4 addresses to return to DHCP clients as DNS server addresses
|
2021-04-20 12:07:57 +00:00
|
|
|
|
|
|
|
// subnet contains the DHCP server's subnet. The IP is the IP of the
|
|
|
|
// gateway.
|
|
|
|
subnet *net.IPNet
|
|
|
|
|
|
|
|
options []dhcpOption
|
2020-07-03 15:20:01 +00:00
|
|
|
|
2021-03-18 14:07:13 +00:00
|
|
|
// notify is a way to signal to other components that leases have
|
|
|
|
// change. notify must be called outside of locked sections, since the
|
|
|
|
// clients might want to get the new data.
|
|
|
|
//
|
|
|
|
// TODO(a.garipov): This is utter madness and must be refactored. It
|
|
|
|
// just begs for deadlock bugs and other nastiness.
|
2020-07-03 15:20:01 +00:00
|
|
|
notify func(uint32)
|
|
|
|
}
|
|
|
|
|
|
|
|
// V6ServerConf - server configuration
|
|
|
|
type V6ServerConf struct {
|
2021-01-20 12:59:24 +00:00
|
|
|
Enabled bool `yaml:"-" json:"-"`
|
|
|
|
InterfaceName string `yaml:"-" json:"-"`
|
2020-07-03 15:20:01 +00:00
|
|
|
|
|
|
|
// The first IP address for dynamic leases
|
|
|
|
// The last allowed IP address ends with 0xff byte
|
2021-02-15 10:32:16 +00:00
|
|
|
RangeStart net.IP `yaml:"range_start" json:"range_start"`
|
2020-07-03 15:20:01 +00:00
|
|
|
|
2021-01-20 12:59:24 +00:00
|
|
|
LeaseDuration uint32 `yaml:"lease_duration" json:"lease_duration"` // in seconds
|
2020-07-03 15:20:01 +00:00
|
|
|
|
2021-02-11 17:49:03 +00:00
|
|
|
RASLAACOnly bool `yaml:"ra_slaac_only" json:"-"` // send ICMPv6.RA packets without MO flags
|
|
|
|
RAAllowSLAAC bool `yaml:"ra_allow_slaac" json:"-"` // send ICMPv6.RA packets with MO flags
|
2020-09-24 15:33:11 +00:00
|
|
|
|
2020-07-03 15:20:01 +00:00
|
|
|
ipStart net.IP // starting IP address for dynamic leases
|
|
|
|
leaseTime time.Duration // the time during which a dynamic lease is considered valid
|
|
|
|
dnsIPAddrs []net.IP // IPv6 addresses to return to DHCP clients as DNS server addresses
|
|
|
|
|
|
|
|
// Server calls this function when leases data changes
|
|
|
|
notify func(uint32)
|
|
|
|
}
|
2020-08-25 11:07:11 +00:00
|
|
|
|
|
|
|
type dhcpOption struct {
|
|
|
|
code uint8
|
2021-03-15 16:24:26 +00:00
|
|
|
data []byte
|
2020-08-25 11:07:11 +00:00
|
|
|
}
|