coredns-ldap/example.go

43 lines
1.3 KiB
Go
Raw Normal View History

// The example middleware prints example to stdout on every packet received.
package example
import (
"fmt"
2017-09-15 20:29:47 +00:00
"github.com/coredns/coredns/plugin"
"github.com/miekg/dns"
"golang.org/x/net/context"
)
// Example is an example middleware to ...
type Example struct {
2017-09-15 20:29:47 +00:00
Next plugin.Handler
}
// ServeDNS implements the middleware.Handler interface.
func (e Example) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
2017-07-29 09:48:27 +00:00
// Somewhat convoluted, as we could have printed "example" here and just call
// the next middleware - but as an example, show how to wrap a ResponseWriter might be
// educational.
pw := NewResponsePrinter(w)
2017-09-15 20:29:47 +00:00
return plugin.NextOrFailure(e.Name(), e.Next, ctx, pw, r)
}
// Name implements the Handler interface.
func (e Example) Name() string { return "example" }
type ResponsePrinter struct {
dns.ResponseWriter
}
// NewResponsePrinter returns a dns.Msg modifier that print example when a query is received.
func NewResponsePrinter(w dns.ResponseWriter) *ResponsePrinter {
return &ResponsePrinter{ResponseWriter: w}
}
// WriteMsg records the status code and calls the underlying ResponseWriter's WriteMsg method.
func (r *ResponsePrinter) WriteMsg(res *dns.Msg) error {
fmt.Println("example")
return r.ResponseWriter.WriteMsg(res)
}