From bb3db9be47f970d1f24fc52681eec593c3dae189 Mon Sep 17 00:00:00 2001 From: m5r Date: Sat, 29 Oct 2022 00:13:04 +0200 Subject: [PATCH] return NXDOMAIN when ip can't be parsed --- xip/xip.go | 12 +++++++----- 1 file changed, 7 insertions(+), 5 deletions(-) diff --git a/xip/xip.go b/xip/xip.go index e96a880..12a0d2d 100644 --- a/xip/xip.go +++ b/xip/xip.go @@ -24,7 +24,7 @@ var ( dashedIpV4Regex = regexp.MustCompile(`(?:^|(?:[\w\d])+\.)(((25[0-5]|(2[0-4]|1\d|[1-9]|)\d)\-?\b){4})($|[.-])`) ) -func (xip *Xip) handleA(question dns.Question, response *dns.Msg) *dns.A { +func (xip *Xip) handleA(question dns.Question) *dns.A { fqdn := question.Name for _, ipV4RE := range []*regexp.Regexp{dashedIpV4Regex, dottedIpV4Regex} { @@ -83,12 +83,14 @@ func (xip *Xip) handleQuery(message *dns.Msg) { for _, question := range message.Question { switch question.Qtype { case dns.TypeA: - record := xip.handleA(question, message) - if record != nil { - message.Answer = append(message.Answer, record) - } else { + record := xip.handleA(question) + if record == nil { + message.Rcode = dns.RcodeNameError message.Ns = append(message.Ns, xip.SOARecord(question)) + return } + + message.Answer = append(message.Answer, record) } } }