doggo/pkg/resolvers/resolver.go

62 lines
1.5 KiB
Go
Raw Normal View History

2020-12-11 12:18:54 +01:00
package resolvers
2020-12-12 11:57:13 +01:00
import (
"time"
"github.com/miekg/dns"
2020-12-24 17:25:20 +01:00
"github.com/sirupsen/logrus"
2020-12-12 11:57:13 +01:00
)
2020-12-11 12:18:54 +01:00
2020-12-24 17:25:20 +01:00
// Options represent a set of common options
// to configure a Resolver.
type Options struct {
SearchList []string
Ndots int
Timeout time.Duration
Logger *logrus.Logger
}
2020-12-12 07:16:13 +01:00
// Resolver implements the configuration for a DNS
// Client. Different types of providers can load
// a DNS Resolver satisfying this interface.
2020-12-11 12:18:54 +01:00
type Resolver interface {
2020-12-24 17:25:20 +01:00
Lookup(dns.Question) (Response, error)
2020-12-12 11:57:13 +01:00
}
// Response represents a custom output format
// for DNS queries. It wraps metadata about the DNS query
2020-12-12 11:57:13 +01:00
// and the DNS Answer as well.
type Response struct {
2020-12-24 17:25:20 +01:00
Answers []Answer `json:"answers"`
Authorities []Authority `json:"authorities"`
Questions []Question `json:"questions"`
}
type Question struct {
Name string `json:"name"`
Type string `json:"type"`
Class string `json:"class"`
}
type Answer struct {
Name string `json:"name"`
Type string `json:"type"`
Class string `json:"class"`
TTL string `json:"ttl"`
Address string `json:"address"`
Status string `json:"status"`
RTT string `json:"rtt"`
Nameserver string `json:"nameserver"`
}
type Authority struct {
Name string `json:"name"`
Type string `json:"type"`
Class string `json:"class"`
TTL string `json:"ttl"`
MName string `json:"mname"`
Status string `json:"status"`
RTT string `json:"rtt"`
Nameserver string `json:"nameserver"`
2020-12-11 12:18:54 +01:00
}