doggo/pkg/resolvers/udp.go

64 lines
1.3 KiB
Go
Raw Normal View History

2020-12-11 12:18:54 +01:00
package resolvers
2020-12-10 10:39:05 +01:00
import (
"time"
2020-12-10 10:39:05 +01:00
"github.com/miekg/dns"
)
// UDPResolver represents the config options for setting up a Resolver.
type UDPResolver struct {
2020-12-16 14:08:34 +01:00
client *dns.Client
server string
2020-12-10 10:39:05 +01:00
}
// UDPResolverOpts holds options for setting up a Classic resolver.
type UDPResolverOpts struct {
IPv4Only bool
IPv6Only bool
Timeout time.Duration
2020-12-12 07:46:54 +01:00
}
// NewUDPResolver accepts a list of nameservers and configures a DNS resolver.
2020-12-16 14:08:34 +01:00
func NewUDPResolver(server string, opts UDPResolverOpts) (Resolver, error) {
client := &dns.Client{
Timeout: opts.Timeout,
}
2020-12-13 08:15:45 +01:00
2020-12-12 07:46:54 +01:00
client.Net = "udp"
if opts.IPv4Only {
2020-12-12 07:46:54 +01:00
client.Net = "udp4"
}
if opts.IPv6Only {
2020-12-12 07:46:54 +01:00
client.Net = "udp6"
}
return &UDPResolver{
2020-12-16 14:08:34 +01:00
client: client,
server: server,
2020-12-12 07:16:13 +01:00
}, nil
2020-12-10 10:39:05 +01:00
}
2020-12-10 17:14:04 +01:00
// Lookup prepare a list of DNS messages to be sent to the server.
// It's possible to send multiple question in one message
// but some nameservers are not able to
2020-12-16 14:08:34 +01:00
func (r *UDPResolver) Lookup(questions []dns.Question) ([]Response, error) {
2020-12-12 11:57:13 +01:00
var (
messages = prepareMessages(questions)
responses []Response
)
2020-12-12 07:46:54 +01:00
2020-12-10 10:39:05 +01:00
for _, msg := range messages {
2020-12-16 14:08:34 +01:00
in, rtt, err := r.client.Exchange(&msg, r.server)
if err != nil {
return nil, err
}
rsp := Response{
Message: *in,
RTT: rtt,
Nameserver: r.server,
2020-12-10 10:39:05 +01:00
}
2020-12-16 14:08:34 +01:00
responses = append(responses, rsp)
2020-12-10 10:39:05 +01:00
}
2020-12-12 11:57:13 +01:00
return responses, nil
2020-12-10 10:39:05 +01:00
}