Commit d6743531 authored by Chris O'Haver's avatar Chris O'Haver Committed by GitHub

fix healthy proxy error case (#5168)

Signed-off-by: default avatarChris O'Haver <cohaver@infoblox.com>
parent 4064430f
......@@ -37,10 +37,10 @@ func (g *GRPC) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (
}
var (
span, child ot.Span
ret *dns.Msg
upstreamErr, err error
i int
span, child ot.Span
ret *dns.Msg
err error
i int
)
span = ot.SpanFromContext(ctx)
list := g.list()
......@@ -74,8 +74,6 @@ func (g *GRPC) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (
child.Finish()
}
upstreamErr = err
// Check if the reply is correct; if not return FormErr.
if !state.Match(ret) {
debug.Hexdumpf(ret, "Wrong reply for id: %d, %s %d", ret.Id, state.QName(), state.QType())
......@@ -90,8 +88,10 @@ func (g *GRPC) ServeDNS(ctx context.Context, w dns.ResponseWriter, r *dns.Msg) (
return 0, nil
}
if upstreamErr != nil {
return dns.RcodeServerFailure, upstreamErr
// SERVFAIL if all healthy proxys returned errors.
if err != nil {
// just return the last error received
return dns.RcodeServerFailure, err
}
return dns.RcodeServerFailure, ErrNoHealthy
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment