aboutsummaryrefslogtreecommitdiff
path: root/middleware/dnstap/setup.go
blob: 5c74bd3463c362939e9c6cc56d039b57388d7c67 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
package dnstap

import (
	"fmt"
	"log"

	"github.com/coredns/coredns/core/dnsserver"
	"github.com/coredns/coredns/middleware"
	"github.com/coredns/coredns/middleware/dnstap/out"

	"github.com/mholt/caddy"
	"github.com/mholt/caddy/caddyfile"
)

func init() {
	caddy.RegisterPlugin("dnstap", caddy.Plugin{
		ServerType: "dns",
		Action:     wrapSetup,
	})
}

func wrapSetup(c *caddy.Controller) error {
	if err := setup(c); err != nil {
		return middleware.Error("dnstap", err)
	}
	return nil
}

func parseConfig(c *caddyfile.Dispenser) (path string, full bool, err error) {
	c.Next() // directive name

	if !c.Args(&path) {
		err = c.ArgErr()
		return
	}

	full = c.NextArg() && c.Val() == "full"

	return
}

func setup(c *caddy.Controller) error {
	path, full, err := parseConfig(&c.Dispenser)
	if err != nil {
		return err
	}

	dnstap := Dnstap{Pack: full}

	o, err := out.NewSocket(path)
	if err != nil {
		log.Printf("[WARN] Can't connect to %s at the moment", path)
	}
	dnstap.Out = o

	c.OnShutdown(func() error {
		if err := o.Close(); err != nil {
			return fmt.Errorf("output: %s", err)
		}
		return nil
	})

	dnsserver.GetConfig(c).AddMiddleware(
		func(next middleware.Handler) middleware.Handler {
			dnstap.Next = next
			return dnstap
		})

	return nil
}