1
0
Fork 0

Merge pull request #2 from gaopenghigh/dev

bugfix: do proxy if no AAAA records found, e.g. only CNAME records
pull/4/head
Ambrose Chua 2018-07-02 08:38:24 +08:00 committed by GitHub
commit a7bcde07e8
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 56 additions and 6 deletions

View File

@ -3,7 +3,6 @@ package dns64
import ( import (
"errors" "errors"
"log"
"net" "net"
"time" "time"
@ -56,13 +55,15 @@ func (r *ResponseWriter) WriteMsg(res *dns.Msg) error {
// do not modify if there are AAAA records or NameError. continue if NoData or any other error. // do not modify if there are AAAA records or NameError. continue if NoData or any other error.
ty, _ := response.Typify(res, time.Now().UTC()) ty, _ := response.Typify(res, time.Now().UTC())
if ty == response.NoError || ty == response.NameError { if ty == response.NoError || ty == response.NameError {
return r.ResponseWriter.WriteMsg(res) if hasAAAA(res) {
return r.ResponseWriter.WriteMsg(res)
}
} }
// perform request to upstream. // perform request to upstream.
res2, err := r.Proxy.Lookup(state, state.Name(), dns.TypeA) res2, err := r.Proxy.Lookup(state, state.Name(), dns.TypeA)
if err != nil { if err != nil {
log.Printf("[WARNING] Unable to query upstream DNS: %v", err) log.Warningf("[WARNING] Unable to query upstream DNS: %v", err)
res.MsgHdr.Rcode = dns.RcodeServerFailure res.MsgHdr.Rcode = dns.RcodeServerFailure
return r.ResponseWriter.WriteMsg(res) return r.ResponseWriter.WriteMsg(res)
} }
@ -103,7 +104,7 @@ func (r *ResponseWriter) WriteMsg(res *dns.Msg) error {
// Write implements the dns.ResponseWriter interface. // Write implements the dns.ResponseWriter interface.
func (r *ResponseWriter) Write(buf []byte) (int, error) { func (r *ResponseWriter) Write(buf []byte) (int, error) {
log.Printf("[WARNING] DNS64 called with Write: not performing DNS64") log.Warning("[WARNING] DNS64 called with Write: not performing DNS64")
n, err := r.ResponseWriter.Write(buf) n, err := r.ResponseWriter.Write(buf)
return n, err return n, err
} }
@ -141,3 +142,13 @@ func To6(prefix *net.IPNet, addr net.IP) (net.IP, error) {
return v6, nil return v6, nil
} }
// hasAAAA checks if AAAA records exists in dns.Msg
func hasAAAA(res *dns.Msg) bool {
for _, a := range res.Answer {
if a.Header().Rrtype == dns.TypeAAAA {
return true
}
}
return false
}

View File

@ -6,11 +6,14 @@ import (
"github.com/coredns/coredns/core/dnsserver" "github.com/coredns/coredns/core/dnsserver"
"github.com/coredns/coredns/plugin" "github.com/coredns/coredns/plugin"
"github.com/coredns/coredns/plugin/pkg/dnsutil" "github.com/coredns/coredns/plugin/pkg/dnsutil"
clog "github.com/coredns/coredns/plugin/pkg/log"
"github.com/coredns/coredns/plugin/proxy" "github.com/coredns/coredns/plugin/proxy"
"github.com/mholt/caddy" "github.com/mholt/caddy"
) )
var log = clog.NewWithPlugin("dns64")
func init() { func init() {
caddy.RegisterPlugin("dns64", caddy.Plugin{ caddy.RegisterPlugin("dns64", caddy.Plugin{
ServerType: "dns", ServerType: "dns",
@ -57,7 +60,8 @@ func dns64Parse(c *caddy.Controller) (proxy.Proxy, *net.IPNet, error) {
if !c.NextArg() { if !c.NextArg() {
return prxy, pref, c.ArgErr() return prxy, pref, c.ArgErr()
} }
_, pref, err := net.ParseCIDR(c.Val()) var err error
_, pref, err = net.ParseCIDR(c.Val())
// test for valid prefix // test for valid prefix
n, total := pref.Mask.Size() n, total := pref.Mask.Size()

View File

@ -10,58 +10,68 @@ func TestSetupDns64(t *testing.T) {
tests := []struct { tests := []struct {
inputUpstreams string inputUpstreams string
shouldErr bool shouldErr bool
prefix string
}{ }{
{ {
`dns64`, `dns64`,
false, false,
"64:ff9b::/96",
}, },
{ {
`dns64 { `dns64 {
upstream 8.8.8.8 upstream 8.8.8.8
}`, }`,
false, false,
"64:ff9b::/96",
}, },
{ {
`dns64 { `dns64 {
prefix 64:ff9b::/96 prefix 64:ff9b::/96
}`, }`,
false, false,
"64:ff9b::/96",
}, },
{ {
`dns64 { `dns64 {
prefix 64:ff9b::/32 prefix 64:ff9b::/32
}`, }`,
false, false,
"64:ff9b::/32",
}, },
{ {
`dns64 { `dns64 {
prefix 64:ff9b::/52 prefix 64:ff9b::/52
}`, }`,
true, true,
"64:ff9b::/52",
}, },
{ {
`dns64 { `dns64 {
prefix 64:ff9b::/104 prefix 64:ff9b::/104
}`, }`,
true, true,
"64:ff9b::/104",
}, },
{ {
`dns64 { `dns64 {
prefix 8.8.8.8/24 prefix 8.8.8.8/24
}`, }`,
true, true,
"8.8.9.9/24",
}, },
{ {
`dns64 { `dns64 {
upstream 8.8.8.8 8.8.4.4 upstream 8.8.8.8 8.8.4.4
}`, }`,
false, false,
"64:ff9b::/96",
}, },
{ {
`dns64 { `dns64 {
upstream some_not_useable_domain upstream some_not_useable_domain
}`, }`,
true, true,
"64:ff9b::/96",
}, },
{ {
`dns64 { `dns64 {
@ -69,6 +79,23 @@ func TestSetupDns64(t *testing.T) {
upstream 8.8.8.8 upstream 8.8.8.8
}`, }`,
false, false,
"64:ff9b::/96",
},
{
`dns64 {
prefix 2002:ac12:b083::/96
upstream 8.8.8.8
}`,
false,
"2002:ac12:b083::/96",
},
{
`dns64 {
prefix 2002:c0a8:a88a::/48
upstream 8.8.8.8
}`,
false,
"2002:c0a8:a88a::/48",
}, },
{ {
`dns64 foobar { `dns64 foobar {
@ -76,24 +103,32 @@ func TestSetupDns64(t *testing.T) {
upstream 8.8.8.8 upstream 8.8.8.8
}`, }`,
true, true,
"64:ff9b::/96",
}, },
{ {
`dns64 foobar`, `dns64 foobar`,
true, true,
"64:ff9b::/96",
}, },
{ {
`dns64 { `dns64 {
foobar foobar
}`, }`,
true, true,
"64:ff9b::/96",
}, },
} }
for i, test := range tests { for i, test := range tests {
c := caddy.NewTestController("dns", test.inputUpstreams) c := caddy.NewTestController("dns", test.inputUpstreams)
_, _, err := dns64Parse(c) _, pref, err := dns64Parse(c)
if (err != nil) != test.shouldErr { if (err != nil) != test.shouldErr {
t.Errorf("Test %d expected %v error, got %v for %s", i+1, test.shouldErr, err, test.inputUpstreams) t.Errorf("Test %d expected %v error, got %v for %s", i+1, test.shouldErr, err, test.inputUpstreams)
} }
if err == nil {
if pref.String() != test.prefix {
t.Errorf("Test %d expected prefix %s, got %v", i+1, test.prefix, pref.String())
}
}
} }
} }