Documentation ¶
Overview ¶
Package dhcp provides building blocks for DHCP clients and servers.
Index ¶
- Constants
- Variables
- func GetOptIP(ip net.IP) []byte
- func GetOptIPs(ips []net.IP) []byte
- func GetOptTime(d time.Duration) []byte
- func GetOptUint16(val uint16) []byte
- func IsPXERequest(pkt Packet) bool
- func IsUEFIPxeArch(arch uint16) bool
- func NewDHCPServer2(iface string, dhcpServerPort, dhcpRelayPort uint16) (*DHCPServer, *Conn, error)
- type Conn
- func (c *Conn) Close() error
- func (c *Conn) RecvDHCP() (Packet, *net.UDPAddr, net.HardwareAddr, *net.Interface, error)
- func (c *Conn) SendDHCP(pkt Packet, addr *net.UDPAddr, mac net.HardwareAddr, intf *net.Interface) error
- func (c *Conn) SetReadDeadline(t time.Time) error
- func (c *Conn) SetWriteDeadline(t time.Time) error
- type DHCPHandler
- type DHCPServer
- type MessageType
- type OpCode
- type Option
- type OptionCode
- type Options
- func (o Options) Byte(n OptionCode) (byte, error)
- func (o Options) Bytes(code OptionCode) ([]byte, error)
- func (o Options) IP(n OptionCode) (net.IP, error)
- func (o Options) IPMask(n OptionCode) (net.IPMask, error)
- func (o Options) IPs(n OptionCode) ([]net.IP, error)
- func (o Options) String(n OptionCode) (string, error)
- func (o Options) Uint16(n OptionCode) (uint16, error)
- func (o Options) Uint32(n OptionCode) (uint32, error)
- type Packet
- func MakeReplyPacket(pkt Packet, conf *ResponseConfig) (Packet, error)
- func NewPacket(opCode OpCode) Packet
- func ReplyPacket(req Packet, mt MessageType, serverId, yIAddr net.IP, ...) Packet
- func RequestPacket(mt MessageType, chAddr net.HardwareAddr, cIAddr net.IP, xId []byte, ...) Packet
- func Unmarshal(b []byte) Packet
- func (p *Packet) AddOption(o OptionCode, value []byte)
- func (p Packet) Broadcast() bool
- func (p Packet) CHAddr() net.HardwareAddr
- func (p Packet) CIAddr() net.IP
- func (p Packet) Cookie() []byte
- func (p Packet) File() []byte
- func (p Packet) Flags() []byte
- func (p Packet) GIAddr() net.IP
- func (p Packet) GetOptionValue(code OptionCode) []byte
- func (p Packet) HLen() byte
- func (p Packet) HType() byte
- func (p Packet) Hops() byte
- func (p Packet) Marshal() []byte
- func (p Packet) OpCode() OpCode
- func (p Packet) Options() []byte
- func (p *Packet) PadToMinSize()
- func (p Packet) ParseOptions() Options
- func (p Packet) RelayAddr() net.IP
- func (p Packet) SIAddr() net.IP
- func (p Packet) SName() []byte
- func (p Packet) Secs() []byte
- func (p Packet) SetBroadcast(broadcast bool)
- func (p Packet) SetCHAddr(a net.HardwareAddr)
- func (p Packet) SetCIAddr(ip net.IP)
- func (p Packet) SetCookie(cookie []byte)
- func (p Packet) SetFile(file []byte)
- func (p Packet) SetFlags(flags []byte)
- func (p Packet) SetGIAddr(ip net.IP)
- func (p Packet) SetHType(hType byte)
- func (p Packet) SetHops(hops byte)
- func (p Packet) SetOpCode(c OpCode)
- func (p Packet) SetSIAddr(ip net.IP)
- func (p Packet) SetSName(sName []byte)
- func (p Packet) SetSecs(secs []byte)
- func (p Packet) SetXId(xId []byte)
- func (p Packet) SetYIAddr(ip net.IP)
- func (p *Packet) StripOptions()
- func (p Packet) TransactionID() string
- func (p Packet) Type() MessageType
- func (p Packet) XId() []byte
- func (p Packet) YIAddr() net.IP
- type ResponseConfig
Constants ¶
const ( // DHCP client architecture values // - https://datatracker.ietf.org/doc/html/rfc4578#section-2.1 // - https://github.com/ipxe/ipxe/blob/236299baa32452c79a59138c44eca5fcf4a918f9/src/include/ipxe/dhcp.h#L275-L305 // 0. Intel x86 PC CLIENT_ARCH_INTEL_X86PC = iota // 1. NEC/PC98 CLIENT_ARCH_NEC_PC98 // 2. EFI Itenium CLIENT_ARCH_EFI_ITANIUM // 3. DEC alpha CLIENT_ARCH_DEC_ALPHA // 4. Arc x86 CLIENT_ARCH_ARC_X86 // 5. Intel Lean Client CLIENT_ARCH_INTEL_LEAN_CLIENT // 6. EFI IA32 CLIENT_ARCH_EFI_IA32 // 7. EFI BC CLIENT_ARCH_EFI_BC // 8. EFI Xscale CLIENT_ARCH_EFI_XSCALE // 9. EFI x86_64 CLIENT_ARCH_EFI_X86_64 // 10. EFI 32-bit ARM CLIENT_ARCH_EFI_ARM32 // 11. EFI 64-bit ARM CLIENT_ARCH_EFI_ARM64 )
Variables ¶
var (
ErrOptionWrongSize = errors.New("option value is the wrong size")
)
Functions ¶
func GetOptTime ¶
func GetOptUint16 ¶
func IsPXERequest ¶
func IsUEFIPxeArch ¶
func NewDHCPServer2 ¶
func NewDHCPServer2(iface string, dhcpServerPort, dhcpRelayPort uint16) (*DHCPServer, *Conn, error)
raw socket
Types ¶
type Conn ¶
type Conn struct {
// contains filtered or unexported fields
}
Conn is a DHCP-oriented packet socket.
Multiple goroutines may invoke methods on a Conn simultaneously.
func NewRawSocketConn ¶
func NewSnooperConn ¶
NewSnooperConn creates a Conn that listens on the given UDP ip:port.
Unlike NewConn, NewSnooperConn does not bind to the ip:port, enabling the Conn to coexist with other services on the machine.
func (*Conn) Close ¶
Close closes the DHCP socket. Any blocked Read or Write operations will be unblocked and return errors.
func (*Conn) RecvDHCP ¶
RecvDHCP reads a Packet from the connection. It returns the packet and the interface it was received on.
func (*Conn) SendDHCP ¶
func (c *Conn) SendDHCP(pkt Packet, addr *net.UDPAddr, mac net.HardwareAddr, intf *net.Interface) error
SendDHCP sends pkt. The precise transmission mechanism depends on pkt.txType(). intf should be the net.Interface returned by RecvDHCP if responding to a DHCP client, or the interface for which configuration is desired if acting as a client.
func (*Conn) SetReadDeadline ¶
SetReadDeadline sets the deadline for future Read calls. If the deadline is reached, Read will fail with a timeout (see net.Error) instead of blocking. A zero value for t means Read will not time out.
type DHCPHandler ¶
type DHCPServer ¶
func NewDHCPServer ¶
func NewDHCPServer(address string, port int) (*DHCPServer, error)
net.ListenPacket
func (*DHCPServer) GetConn ¶
func (s *DHCPServer) GetConn() *Conn
func (*DHCPServer) ListenAndServe ¶
func (s *DHCPServer) ListenAndServe(handler DHCPHandler) error
type MessageType ¶
type MessageType byte // Option 53
const ( Discover MessageType = 1 // Broadcast Packet From Client - Can I have an IP? Offer MessageType = 2 // Broadcast From Server - Here's an IP Request MessageType = 3 // Broadcast From Client - I'll take that IP (Also start for renewals) Decline MessageType = 4 // Broadcast From Client - Sorry I can't use that IP ACK MessageType = 5 // From Server, Yes you can have that IP NAK MessageType = 6 // From Server, No you cannot have that IP Release MessageType = 7 // From Client, I don't need that IP anymore Inform MessageType = 8 // From Client, I have this IP and there's nothing you can do about it )
DHCP Message Type 53
type OptionCode ¶
type OptionCode byte
const ( PXECLIENT = "PXEClient" OptClasslessRouteLin OptionCode = OptionClasslessRouteFormat //Classless Static Route Option OptClasslessRouteWin OptionCode = 249 )
const ( End OptionCode = 255 Pad OptionCode = 0 OptionSubnetMask OptionCode = 1 OptionTimeOffset OptionCode = 2 OptionRouter OptionCode = 3 OptionTimeServer OptionCode = 4 OptionNameServer OptionCode = 5 OptionDomainNameServer OptionCode = 6 OptionLogServer OptionCode = 7 OptionCookieServer OptionCode = 8 OptionLPRServer OptionCode = 9 OptionImpressServer OptionCode = 10 OptionResourceLocationServer OptionCode = 11 OptionHostName OptionCode = 12 OptionBootFileSize OptionCode = 13 OptionMeritDumpFile OptionCode = 14 OptionDomainName OptionCode = 15 OptionSwapServer OptionCode = 16 OptionRootPath OptionCode = 17 OptionExtensionsPath OptionCode = 18 // IP Layer Parameters per Host OptionIPForwardingEnableDisable OptionCode = 19 OptionNonLocalSourceRoutingEnableDisable OptionCode = 20 OptionPolicyFilter OptionCode = 21 OptionMaximumDatagramReassemblySize OptionCode = 22 OptionDefaultIPTimeToLive OptionCode = 23 OptionPathMTUAgingTimeout OptionCode = 24 OptionPathMTUPlateauTable OptionCode = 25 // IP Layer Parameters per Interface OptionInterfaceMTU OptionCode = 26 OptionAllSubnetsAreLocal OptionCode = 27 OptionBroadcastAddress OptionCode = 28 OptionPerformMaskDiscovery OptionCode = 29 OptionMaskSupplier OptionCode = 30 OptionPerformRouterDiscovery OptionCode = 31 OptionRouterSolicitationAddress OptionCode = 32 OptionStaticRoute OptionCode = 33 // Link Layer Parameters per Interface OptionTrailerEncapsulation OptionCode = 34 OptionARPCacheTimeout OptionCode = 35 OptionEthernetEncapsulation OptionCode = 36 // TCP Parameters OptionTCPDefaultTTL OptionCode = 37 OptionTCPKeepaliveInterval OptionCode = 38 OptionTCPKeepaliveGarbage OptionCode = 39 // Application and Service Parameters OptionNetworkInformationServiceDomain OptionCode = 40 OptionNetworkInformationServers OptionCode = 41 OptionNetworkTimeProtocolServers OptionCode = 42 OptionVendorSpecificInformation OptionCode = 43 OptionNetBIOSOverTCPIPNameServer OptionCode = 44 OptionNetBIOSOverTCPIPDatagramDistributionServer OptionCode = 45 OptionNetBIOSOverTCPIPNodeType OptionCode = 46 OptionNetBIOSOverTCPIPScope OptionCode = 47 OptionXWindowSystemFontServer OptionCode = 48 OptionXWindowSystemDisplayManager OptionCode = 49 OptionNetworkInformationServicePlusDomain OptionCode = 64 OptionNetworkInformationServicePlusServers OptionCode = 65 OptionMobileIPHomeAgent OptionCode = 68 OptionSimpleMailTransportProtocol OptionCode = 69 OptionPostOfficeProtocolServer OptionCode = 70 OptionNetworkNewsTransportProtocol OptionCode = 71 OptionDefaultWorldWideWebServer OptionCode = 72 OptionDefaultFingerServer OptionCode = 73 OptionDefaultInternetRelayChatServer OptionCode = 74 OptionStreetTalkServer OptionCode = 75 OptionStreetTalkDirectoryAssistance OptionCode = 76 OptionRelayAgentInformation OptionCode = 82 // DHCP Extensions OptionRequestedIPAddress OptionCode = 50 OptionIPAddressLeaseTime OptionCode = 51 OptionOverload OptionCode = 52 OptionDHCPMessageType OptionCode = 53 OptionServerIdentifier OptionCode = 54 OptionParameterRequestList OptionCode = 55 OptionMessage OptionCode = 56 OptionMaximumDHCPMessageSize OptionCode = 57 OptionRenewalTimeValue OptionCode = 58 OptionRebindingTimeValue OptionCode = 59 OptionVendorClassIdentifier OptionCode = 60 OptionClientIdentifier OptionCode = 61 OptionTFTPServerName OptionCode = 66 OptionBootFileName OptionCode = 67 OptionUserClass OptionCode = 77 OptionClientArchitecture OptionCode = 93 OptionClientNetworkInterfaceIdentifier OptionCode = 94 OptionClientMachineIdentifier OptionCode = 97 OptionTZPOSIXString OptionCode = 100 OptionTZDatabaseString OptionCode = 101 OptionDomainSearch OptionCode = 119 OptionClasslessRouteFormat OptionCode = 121 // From RFC3942 - Options Used by PXELINUX OptionPxelinuxMagic OptionCode = 208 OptionPxelinuxConfigfile OptionCode = 209 OptionPxelinuxPathprefix OptionCode = 210 OptionPxelinuxReboottime OptionCode = 211 )
DHCP Options
type Packet ¶
type Packet []byte
A DHCP packet
func MakeReplyPacket ¶
func MakeReplyPacket(pkt Packet, conf *ResponseConfig) (Packet, error)
func ReplyPacket ¶
func ReplyPacket(req Packet, mt MessageType, serverId, yIAddr net.IP, leaseDuration time.Duration, options []Option) Packet
ReplyPacket creates a reply packet that a Server would send to a client. It uses the req Packet param to copy across common/necessary fields to associate the reply the request.
func RequestPacket ¶
func RequestPacket(mt MessageType, chAddr net.HardwareAddr, cIAddr net.IP, xId []byte, broadcast bool, options []Option) Packet
Creates a request packet that a Client would send to a server.
func (*Packet) AddOption ¶
func (p *Packet) AddOption(o OptionCode, value []byte)
Appends a DHCP option to the end of a packet
func (Packet) CHAddr ¶
func (p Packet) CHAddr() net.HardwareAddr
func (Packet) GetOptionValue ¶
func (p Packet) GetOptionValue(code OptionCode) []byte
func (*Packet) PadToMinSize ¶
func (p *Packet) PadToMinSize()
func (Packet) ParseOptions ¶
Parses the packet's options into an Options map
func (Packet) SetBroadcast ¶
func (Packet) SetCHAddr ¶
func (p Packet) SetCHAddr(a net.HardwareAddr)
func (Packet) TransactionID ¶
func (Packet) Type ¶
func (p Packet) Type() MessageType
type ResponseConfig ¶
type ResponseConfig struct { OsName string ServerIP net.IP // OptServerIdentifier 54 ClientIP net.IP Gateway net.IP // OptRouters 3 Domain string // OptDomainName 15 LeaseTime time.Duration // OptLeaseTime 51 RenewalTime time.Duration // OptRenewalTime 58 BroadcastAddr net.IP // OptBroadcastAddr 28 Hostname string // OptHostname 12 SubnetMask net.IP // OptSubnetMask 1 DNSServers []net.IP // OptDNSServers Routes [][]string // TODO: 249 for windows, 121 for linux NTPServers []net.IP // OptNTPServers 42 MTU uint16 // OptMTU 26 // Relay Info https://datatracker.ietf.org/doc/html/rfc3046 RelayInfo []byte // TFTP config BootServer string BootFile string BootBlock uint16 }
http://www.networksorcery.com/enp/rfc/rfc2132.txt
func (ResponseConfig) GetHostname ¶
func (conf ResponseConfig) GetHostname() string