| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- package dns
- import (
- "errors"
- "net"
- "github.com/coredhcp/coredhcp/handler"
- "github.com/coredhcp/coredhcp/logger"
- "github.com/coredhcp/coredhcp/plugins"
- "github.com/insomniacslk/dhcp/dhcpv4"
- "github.com/insomniacslk/dhcp/dhcpv6"
- )
- var log = logger.GetLogger()
- func init() {
- plugins.RegisterPlugin("dns", setupDNS6, setupDNS4)
- }
- var (
- dnsServers []net.IP
- )
- func setupDNS6(args ...string) (handler.Handler6, error) {
- // TODO setup function for IPv6
- log.Warning("plugins/dns: not implemented for IPv6")
- return Handler6, nil
- }
- func setupDNS4(args ...string) (handler.Handler4, error) {
- log.Printf("plugins/dns: loaded plugin for DHCPv4.")
- if len(args) < 1 {
- return nil, errors.New("need at least one DNS server")
- }
- for _, arg := range args {
- DNSServer := net.ParseIP(arg)
- if DNSServer.To4() == nil {
- return Handler4, errors.New("expected an DNS server address, got: " + arg)
- }
- dnsServers = append(dnsServers, DNSServer)
- }
- log.Infof("plugins/dns: loaded %d DNS servers.", len(dnsServers))
- return Handler4, nil
- }
- // Handler6 not implemented only IPv4
- func Handler6(req, resp dhcpv6.DHCPv6) (dhcpv6.DHCPv6, bool) {
- // TODO add DNS servers for v6 to the response
- return resp, false
- }
- //Handler4 handles DHCPv4 packets for the dns plugin
- func Handler4(req, resp *dhcpv4.DHCPv4) (*dhcpv4.DHCPv4, bool) {
- resp.Options.Update(dhcpv4.OptDNS(dnsServers...))
- return resp, false
- }
|