mirror of
https://github.com/coredhcp/coredhcp.git
synced 2025-10-30 15:41:05 +01:00
This is useful to automatically provide context about what component of the framework is emitting a log line. Example output: ``` $ go build && sudo ./coredhcp [2019-08-25T21:39:26+01:00] INFO plugins: Registering plugin "dns" [2019-08-25T21:39:26+01:00] INFO plugins: Registering plugin "file" [2019-08-25T21:39:26+01:00] INFO plugins: Registering plugin "netmask" [2019-08-25T21:39:26+01:00] INFO plugins: Registering plugin "range" [2019-08-25T21:39:26+01:00] INFO plugins: Registering plugin "router" [2019-08-25T21:39:26+01:00] INFO plugins: Registering plugin "server_id" [2019-08-25T21:39:26+01:00] INFO config: Loading configuration [2019-08-25T21:39:26+01:00] INFO config: DHCPv4: found plugin `server_id` with 1 args: [10.10.10.1] [2019-08-25T21:39:26+01:00] INFO config: DHCPv4: found plugin `dns` with 2 args: [8.8.8.8 8.8.4.4] [2019-08-25T21:39:26+01:00] INFO config: DHCPv4: found plugin `router` with 1 args: [10.10.10.1] [2019-08-25T21:39:26+01:00] INFO config: DHCPv4: found plugin `netmask` with 1 args: [255.255.255.0] [2019-08-25T21:39:26+01:00] INFO config: DHCPv4: found plugin `range` with 4 args: [leases.txt 10.10.10.100 10.10.10.200 60s] [2019-08-25T21:39:26+01:00] INFO coredhcp: Loading plugins... [2019-08-25T21:39:26+01:00] INFO coredhcp: DHCPv4: loading plugin `server_id` [2019-08-25T21:39:26+01:00] INFO plugins/server_id: plugins/server_id: loading `server_id` plugin for DHCPv4 [2019-08-25T21:39:26+01:00] INFO coredhcp: DHCPv4: loading plugin `dns` [2019-08-25T21:39:26+01:00] INFO plugins/dns: loaded plugin for DHCPv4. [2019-08-25T21:39:26+01:00] INFO plugins/dns: loaded 2 DNS servers. [2019-08-25T21:39:26+01:00] INFO coredhcp: DHCPv4: loading plugin `router` [2019-08-25T21:39:26+01:00] INFO plugins/router: plugins/router: loaded plugin for DHCPv4. [2019-08-25T21:39:26+01:00] INFO plugins/router: plugins/router: loaded 1 router IP addresses. [2019-08-25T21:39:26+01:00] INFO coredhcp: DHCPv4: loading plugin `netmask` [2019-08-25T21:39:26+01:00] INFO plugins/netmask: plugins/netmask: loaded plugin for DHCPv4. [2019-08-25T21:39:26+01:00] INFO plugins/netmask: plugins/netmask: loaded client netmask [2019-08-25T21:39:26+01:00] INFO coredhcp: DHCPv4: loading plugin `range` [2019-08-25T21:39:26+01:00] INFO plugins/range: plugins/range: reading leases from leases.txt [2019-08-25T21:39:26+01:00] INFO plugins/range: plugins/range: loaded 1 leases from leases.txt [2019-08-25T21:39:26+01:00] INFO coredhcp: Starting DHCPv4 listener on 0.0.0.0:67 [2019-08-25T21:39:26+01:00] INFO coredhcp: Waiting ``` Signed-off-by: Andrea Barberio <insomniac@slackware.it>
57 lines
1.4 KiB
Go
57 lines
1.4 KiB
Go
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("plugins/dns")
|
|
|
|
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("not implemented for IPv6")
|
|
return Handler6, nil
|
|
}
|
|
|
|
func setupDNS4(args ...string) (handler.Handler4, error) {
|
|
log.Printf("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("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
|
|
}
|