example.go 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. // The example middleware prints example to stdout on every packet received.
  2. package example
  3. import (
  4. "fmt"
  5. "github.com/coredns/coredns/plugin"
  6. "github.com/miekg/dns"
  7. "golang.org/x/net/context"
  8. )
  9. // Example is an example middleware to ...
  10. type Example struct {
  11. Next plugin.Handler
  12. }
  13. // ServeDNS implements the middleware.Handler interface.
  14. func (e Example) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
  15. // Somewhat convoluted, as we could have printed "example" here and just call
  16. // the next middleware - but as an example, show how to wrap a ResponseWriter might be
  17. // educational.
  18. pw := NewResponsePrinter(w)
  19. return plugin.NextOrFailure(e.Name(), e.Next, ctx, pw, r)
  20. }
  21. // Name implements the Handler interface.
  22. func (e Example) Name() string { return "example" }
  23. type ResponsePrinter struct {
  24. dns.ResponseWriter
  25. }
  26. // NewResponsePrinter returns a dns.Msg modifier that print example when a query is received.
  27. func NewResponsePrinter(w dns.ResponseWriter) *ResponsePrinter {
  28. return &ResponsePrinter{ResponseWriter: w}
  29. }
  30. // WriteMsg records the status code and calls the underlying ResponseWriter's WriteMsg method.
  31. func (r *ResponsePrinter) WriteMsg(res *dns.Msg) error {
  32. fmt.Println("example")
  33. return r.ResponseWriter.WriteMsg(res)
  34. }