mirror of
https://github.com/status-im/consul.git
synced 2025-01-09 21:35:52 +00:00
dns: small refactor to setEDNS to return early
Using a guard clause instead of a long nested if. The diff is best viewed with whitespace turned off.
This commit is contained in:
parent
4beff900d1
commit
b96c8195a5
56
agent/dns.go
56
agent/dns.go
@ -273,34 +273,36 @@ func (d *DNSServer) ReloadConfig(newCfg *config.RuntimeConfig) error {
|
|||||||
// possibly the ECS headers as well if they were present in the
|
// possibly the ECS headers as well if they were present in the
|
||||||
// original request
|
// original request
|
||||||
func setEDNS(request *dns.Msg, response *dns.Msg, ecsGlobal bool) {
|
func setEDNS(request *dns.Msg, response *dns.Msg, ecsGlobal bool) {
|
||||||
// Enable EDNS if enabled
|
edns := request.IsEdns0()
|
||||||
if edns := request.IsEdns0(); edns != nil {
|
if edns == nil {
|
||||||
// cannot just use the SetEdns0 function as we need to embed
|
return
|
||||||
// the ECS option as well
|
|
||||||
ednsResp := new(dns.OPT)
|
|
||||||
ednsResp.Hdr.Name = "."
|
|
||||||
ednsResp.Hdr.Rrtype = dns.TypeOPT
|
|
||||||
ednsResp.SetUDPSize(edns.UDPSize())
|
|
||||||
|
|
||||||
// Setup the ECS option if present
|
|
||||||
if subnet := ednsSubnetForRequest(request); subnet != nil {
|
|
||||||
subOp := new(dns.EDNS0_SUBNET)
|
|
||||||
subOp.Code = dns.EDNS0SUBNET
|
|
||||||
subOp.Family = subnet.Family
|
|
||||||
subOp.Address = subnet.Address
|
|
||||||
subOp.SourceNetmask = subnet.SourceNetmask
|
|
||||||
if c := response.Rcode; ecsGlobal || c == dns.RcodeNameError || c == dns.RcodeServerFailure || c == dns.RcodeRefused || c == dns.RcodeNotImplemented {
|
|
||||||
// reply is globally valid and should be cached accordingly
|
|
||||||
subOp.SourceScope = 0
|
|
||||||
} else {
|
|
||||||
// reply is only valid for the subnet it was queried with
|
|
||||||
subOp.SourceScope = subnet.SourceNetmask
|
|
||||||
}
|
|
||||||
ednsResp.Option = append(ednsResp.Option, subOp)
|
|
||||||
}
|
|
||||||
|
|
||||||
response.Extra = append(response.Extra, ednsResp)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// cannot just use the SetEdns0 function as we need to embed
|
||||||
|
// the ECS option as well
|
||||||
|
ednsResp := new(dns.OPT)
|
||||||
|
ednsResp.Hdr.Name = "."
|
||||||
|
ednsResp.Hdr.Rrtype = dns.TypeOPT
|
||||||
|
ednsResp.SetUDPSize(edns.UDPSize())
|
||||||
|
|
||||||
|
// Setup the ECS option if present
|
||||||
|
if subnet := ednsSubnetForRequest(request); subnet != nil {
|
||||||
|
subOp := new(dns.EDNS0_SUBNET)
|
||||||
|
subOp.Code = dns.EDNS0SUBNET
|
||||||
|
subOp.Family = subnet.Family
|
||||||
|
subOp.Address = subnet.Address
|
||||||
|
subOp.SourceNetmask = subnet.SourceNetmask
|
||||||
|
if c := response.Rcode; ecsGlobal || c == dns.RcodeNameError || c == dns.RcodeServerFailure || c == dns.RcodeRefused || c == dns.RcodeNotImplemented {
|
||||||
|
// reply is globally valid and should be cached accordingly
|
||||||
|
subOp.SourceScope = 0
|
||||||
|
} else {
|
||||||
|
// reply is only valid for the subnet it was queried with
|
||||||
|
subOp.SourceScope = subnet.SourceNetmask
|
||||||
|
}
|
||||||
|
ednsResp.Option = append(ednsResp.Option, subOp)
|
||||||
|
}
|
||||||
|
|
||||||
|
response.Extra = append(response.Extra, ednsResp)
|
||||||
}
|
}
|
||||||
|
|
||||||
// recursorAddr is used to add a port to the recursor if omitted.
|
// recursorAddr is used to add a port to the recursor if omitted.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user