Skip to content

Commit

Permalink
NET-7813 - DNS : SERVFAIL when resolving PTR records
Browse files Browse the repository at this point in the history
  • Loading branch information
jmurret committed Feb 20, 2024
1 parent 53afd8f commit 324e829
Show file tree
Hide file tree
Showing 6 changed files with 490 additions and 428 deletions.
3 changes: 3 additions & 0 deletions .changelog/20679.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
```release-note:bug
dns: SERVFAIL when resolving not found PTR records.
```
4 changes: 4 additions & 0 deletions agent/discovery/query_fetcher_v1.go
Original file line number Diff line number Diff line change
Expand Up @@ -250,6 +250,10 @@ func (f *V1DataFetcher) FetchRecordsByIp(reqCtx Context, ip net.IP) ([]*Result,

var sout structs.IndexedServiceNodes
if err := f.rpcFunc(context.Background(), "Catalog.ServiceNodes", &sargs, &sout); err == nil {
if len(sout.ServiceNodes) == 0 {
return nil, ErrNotFound
}

for _, n := range sout.ServiceNodes {
if n.ServiceAddress == targetIP {
results = append(results, &Result{
Expand Down
13 changes: 10 additions & 3 deletions agent/dns.go
Original file line number Diff line number Diff line change
Expand Up @@ -413,7 +413,9 @@ func (d *DNSServer) handlePtr(resp dns.ResponseWriter, req *dns.Msg) {
m.SetReply(req)
m.Compress = !cfg.DisableCompression
m.Authoritative = true
m.RecursionAvailable = (len(cfg.Recursors) > 0)
recursorsEnabled := atomic.LoadUint32(&(d.recursorEnabled)) != 1
recursionAvailable := recursorsEnabled && len(cfg.Recursors) > 0
m.RecursionAvailable = recursionAvailable

// Only add the SOA if requested
if req.Question[0].Qtype == dns.TypeSOA {
Expand Down Expand Up @@ -492,8 +494,13 @@ func (d *DNSServer) handlePtr(resp dns.ResponseWriter, req *dns.Msg) {

// nothing found locally, recurse
if len(m.Answer) == 0 {
d.handleRecurse(resp, req)
return
if recursionAvailable {
d.handleRecurse(resp, req)
return
} else {
m.SetRcode(req, dns.RcodeNameError)
d.addSOAToMessage(cfg, m, q.Name)
}
}

// ptr record responses are globally valid
Expand Down
Loading

0 comments on commit 324e829

Please sign in to comment.