nameserver_fakedns.go 1.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. package dns
  2. import (
  3. "context"
  4. "github.com/xtls/xray-core/common/errors"
  5. "github.com/xtls/xray-core/common/net"
  6. "github.com/xtls/xray-core/features/dns"
  7. )
  8. type FakeDNSServer struct {
  9. fakeDNSEngine dns.FakeDNSEngine
  10. }
  11. func NewFakeDNSServer(fd dns.FakeDNSEngine) *FakeDNSServer {
  12. return &FakeDNSServer{fakeDNSEngine: fd}
  13. }
  14. func (FakeDNSServer) Name() string {
  15. return "FakeDNS"
  16. }
  17. // IsDisableCache implements Server.
  18. func (s *FakeDNSServer) IsDisableCache() bool {
  19. return true
  20. }
  21. func (f *FakeDNSServer) QueryIP(ctx context.Context, domain string, opt dns.IPOption) ([]net.IP, uint32, error) {
  22. if f.fakeDNSEngine == nil {
  23. return nil, 0, errors.New("Unable to locate a fake DNS Engine").AtError()
  24. }
  25. var ips []net.Address
  26. if fkr0, ok := f.fakeDNSEngine.(dns.FakeDNSEngineRev0); ok {
  27. ips = fkr0.GetFakeIPForDomain3(domain, opt.IPv4Enable, opt.IPv6Enable)
  28. } else {
  29. ips = f.fakeDNSEngine.GetFakeIPForDomain(domain)
  30. }
  31. netIP, err := toNetIP(ips)
  32. if err != nil {
  33. return nil, 0, errors.New("Unable to convert IP to net ip").Base(err).AtError()
  34. }
  35. errors.LogInfo(ctx, f.Name(), " got answer: ", domain, " -> ", ips)
  36. if len(netIP) > 0 {
  37. return netIP, 1, nil // fakeIP ttl is 1
  38. }
  39. return nil, 0, dns.ErrEmptyResponse
  40. }