diff options
author | 2016-08-05 18:19:51 -0700 | |
---|---|---|
committer | 2016-08-05 18:19:51 -0700 | |
commit | 6d90b745e0faf5b73472e918cd72965dc0d93348 (patch) | |
tree | 9b86325e955a9fe5759c78f90dbe20eadbf5093d /middleware/kubernetes/handler.go | |
parent | 604d2a3730fb0ce0939f19f8ec545e7719226f67 (diff) | |
download | coredns-6d90b745e0faf5b73472e918cd72965dc0d93348.tar.gz coredns-6d90b745e0faf5b73472e918cd72965dc0d93348.tar.zst coredns-6d90b745e0faf5b73472e918cd72965dc0d93348.zip |
Switch over to k8s notification API (#202)
* Merge notification code by @aledbf and update for recent changes.
* Fix travis environment to correctly build with k8s.io and forked repositories.
* Refactored kubernetes Corefile parser
* Added lots of Corefile parsing tests
Diffstat (limited to 'middleware/kubernetes/handler.go')
-rw-r--r-- | middleware/kubernetes/handler.go | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/middleware/kubernetes/handler.go b/middleware/kubernetes/handler.go index a78873426..05dfba934 100644 --- a/middleware/kubernetes/handler.go +++ b/middleware/kubernetes/handler.go @@ -3,6 +3,7 @@ package kubernetes import ( "fmt" "log" + "strings" "github.com/miekg/coredns/middleware" @@ -18,6 +19,26 @@ func (k Kubernetes) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.M return dns.RcodeServerFailure, fmt.Errorf("can only deal with ClassINET") } + m := new(dns.Msg) + m.SetReply(r) + m.Authoritative, m.RecursionAvailable, m.Compress = true, true, true + + // TODO: find an alternative to this block + if strings.HasSuffix(state.Name(), arpaSuffix) { + ip, _ := extractIP(state.Name()) + records := k.getServiceRecordForIP(ip, state.Name()) + if len(records) > 0 { + srvPTR := &records[0] + m.Answer = append(m.Answer, srvPTR.NewPTR(state.QName(), ip)) + + m = dedup(m) + state.SizeAndDo(m) + m, _ = state.Scrub(m) + w.WriteMsg(m) + return dns.RcodeSuccess, nil + } + } + // Check that query matches one of the zones served by this middleware, // otherwise delegate to the next in the pipeline. zone := middleware.Zones(k.Zones).Matches(state.Name()) @@ -28,10 +49,6 @@ func (k Kubernetes) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.M return k.Next.ServeDNS(ctx, w, r) } - m := new(dns.Msg) - m.SetReply(r) - m.Authoritative, m.RecursionAvailable, m.Compress = true, true, true - var ( records, extra []dns.RR err error |