nameserver_local.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. package dns
  2. import (
  3. "context"
  4. "strings"
  5. "time"
  6. "github.com/xtls/xray-core/common/log"
  7. "github.com/xtls/xray-core/common/net"
  8. "github.com/xtls/xray-core/features/dns"
  9. "github.com/xtls/xray-core/features/dns/localdns"
  10. )
  11. // LocalNameServer is an wrapper over local DNS feature.
  12. type LocalNameServer struct {
  13. client *localdns.Client
  14. }
  15. const errEmptyResponse = "No address associated with hostname"
  16. // QueryIP implements Server.
  17. func (s *LocalNameServer) QueryIP(_ context.Context, domain string, _ net.IP, option dns.IPOption, _ bool) (ips []net.IP, err error) {
  18. start := time.Now()
  19. ips, err = s.client.LookupIP(domain, option)
  20. if err != nil && strings.HasSuffix(err.Error(), errEmptyResponse) {
  21. err = dns.ErrEmptyResponse
  22. }
  23. if len(ips) > 0 {
  24. newError("Localhost got answer: ", domain, " -> ", ips).AtInfo().WriteToLog()
  25. log.Record(&log.DNSLog{Server: s.Name(), Domain: domain, Result: ips, Status: log.DNSQueried, Elapsed: time.Since(start), Error: err})
  26. }
  27. return
  28. }
  29. // Name implements Server.
  30. func (s *LocalNameServer) Name() string {
  31. return "localhost"
  32. }
  33. // NewLocalNameServer creates localdns server object for directly lookup in system DNS.
  34. func NewLocalNameServer() *LocalNameServer {
  35. newError("DNS: created localhost client").AtInfo().WriteToLog()
  36. return &LocalNameServer{
  37. client: localdns.New(),
  38. }
  39. }
  40. // NewLocalDNSClient creates localdns client object for directly lookup in system DNS.
  41. func NewLocalDNSClient() *Client {
  42. return &Client{server: NewLocalNameServer()}
  43. }