nameserver_fakedns.go 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. package dns
  2. import (
  3. "context"
  4. "github.com/xtls/xray-core/common/net"
  5. "github.com/xtls/xray-core/core"
  6. "github.com/xtls/xray-core/features/dns"
  7. )
  8. type FakeDNSServer struct {
  9. fakeDNSEngine dns.FakeDNSEngine
  10. }
  11. func NewFakeDNSServer() *FakeDNSServer {
  12. return &FakeDNSServer{}
  13. }
  14. func (FakeDNSServer) Name() string {
  15. return "FakeDNS"
  16. }
  17. func (f *FakeDNSServer) QueryIP(ctx context.Context, domain string, _ net.IP, opt dns.IPOption, _ bool) ([]net.IP, error) {
  18. if f.fakeDNSEngine == nil {
  19. if err := core.RequireFeatures(ctx, func(fd dns.FakeDNSEngine) {
  20. f.fakeDNSEngine = fd
  21. }); err != nil {
  22. return nil, newError("Unable to locate a fake DNS Engine").Base(err).AtError()
  23. }
  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, newError("Unable to convert IP to net ip").Base(err).AtError()
  34. }
  35. newError(f.Name(), " got answer: ", domain, " -> ", ips).AtInfo().WriteToLog()
  36. if len(netIP) > 0 {
  37. return netIP, nil
  38. }
  39. return nil, dns.ErrEmptyResponse
  40. }