aboutsummaryrefslogtreecommitdiff
path: root/middleware/reverse/reverse.go
diff options
context:
space:
mode:
Diffstat (limited to 'middleware/reverse/reverse.go')
-rw-r--r--middleware/reverse/reverse.go47
1 files changed, 21 insertions, 26 deletions
diff --git a/middleware/reverse/reverse.go b/middleware/reverse/reverse.go
index 9cf7d751a..3e019affd 100644
--- a/middleware/reverse/reverse.go
+++ b/middleware/reverse/reverse.go
@@ -3,31 +3,33 @@ package reverse
import (
"net"
- "github.com/miekg/coredns/request"
"github.com/miekg/coredns/middleware"
"github.com/miekg/coredns/middleware/pkg/dnsutil"
+ "github.com/miekg/coredns/request"
"github.com/miekg/dns"
"golang.org/x/net/context"
)
-// Reverse provides dynamic reverse dns and the related forward rr
+// Reverse provides dynamic reverse DNS and the related forward RR.
type Reverse struct {
Next middleware.Handler
Networks networks
}
// ServeDNS implements the middleware.Handler interface.
-func (reverse Reverse) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
- var rr dns.RR
- nextHandler := true
+func (re Reverse) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (int, error) {
+ var (
+ rr dns.RR
+ fallThrough bool
+ )
state := request.Request{W: w, Req: r}
m := new(dns.Msg)
m.SetReply(r)
m.Authoritative, m.RecursionAvailable, m.Compress = true, true, true
- switch state.QType(){
+ switch state.QType() {
case dns.TypePTR:
address := dnsutil.ExtractAddressFromReverse(state.Name())
@@ -38,11 +40,11 @@ func (reverse Reverse) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dn
ip := net.ParseIP(address)
// loop through the configured networks
- for _, n := range reverse.Networks {
- if (n.IPnet.Contains(ip)) {
- nextHandler = n.Fallthrough
+ for _, n := range re.Networks {
+ if n.IPnet.Contains(ip) {
+ fallThrough = n.Fallthrough
rr = &dns.PTR{
- Hdr: dns.RR_Header{Name: state.QName(), Rrtype: dns.TypePTR, Class: dns.ClassINET, Ttl: n.TTL},
+ Hdr: dns.RR_Header{Name: state.QName(), Rrtype: dns.TypePTR, Class: dns.ClassINET, Ttl: n.TTL},
Ptr: n.ipToHostname(ip),
}
break
@@ -50,9 +52,9 @@ func (reverse Reverse) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dn
}
case dns.TypeA:
- for _, n := range reverse.Networks {
+ for _, n := range re.Networks {
if dns.IsSubDomain(n.Zone, state.Name()) {
- nextHandler = n.Fallthrough
+ fallThrough = n.Fallthrough
// skip if requesting an v4 address and network is not v4
if n.IPnet.IP.To4() == nil {
@@ -62,8 +64,8 @@ func (reverse Reverse) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dn
result := n.hostnameToIP(state.Name())
if result != nil {
rr = &dns.A{
- Hdr: dns.RR_Header{Name: state.QName(), Rrtype: dns.TypeA, Class: dns.ClassINET, Ttl: n.TTL},
- A: result,
+ Hdr: dns.RR_Header{Name: state.QName(), Rrtype: dns.TypeA, Class: dns.ClassINET, Ttl: n.TTL},
+ A: result,
}
break
}
@@ -71,9 +73,9 @@ func (reverse Reverse) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dn
}
case dns.TypeAAAA:
- for _, n := range reverse.Networks {
+ for _, n := range re.Networks {
if dns.IsSubDomain(n.Zone, state.Name()) {
- nextHandler = n.Fallthrough
+ fallThrough = n.Fallthrough
// Do not use To16 which tries to make v4 in v6
if n.IPnet.IP.To4() != nil {
@@ -93,13 +95,8 @@ func (reverse Reverse) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dn
}
- if rr == nil {
- if reverse.Next == nil || !nextHandler {
- // could not resolv
- w.WriteMsg(m)
- return dns.RcodeNameError, nil
- }
- return reverse.Next.ServeDNS(ctx, w, r)
+ if rr == nil && !fallThrough {
+ return middleware.NextOrFailure(re.Name(), re.Next, ctx, w, r)
}
m.Answer = append(m.Answer, rr)
@@ -109,6 +106,4 @@ func (reverse Reverse) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dn
}
// Name implements the Handler interface.
-func (reverse Reverse) Name() string {
- return "reverse"
-}
+func (re Reverse) Name() string { return "reverse" }