mirror of https://github.com/v2ray/v2ray-core
test case for edns0_subnet
parent
d013e8069d
commit
afc613f8f3
|
@ -27,10 +27,28 @@ type staticHandler struct {
|
||||||
func (*staticHandler) ServeDNS(w dns.ResponseWriter, r *dns.Msg) {
|
func (*staticHandler) ServeDNS(w dns.ResponseWriter, r *dns.Msg) {
|
||||||
ans := new(dns.Msg)
|
ans := new(dns.Msg)
|
||||||
ans.Id = r.Id
|
ans.Id = r.Id
|
||||||
|
|
||||||
|
var clientIP net.IP
|
||||||
|
|
||||||
|
opt := r.IsEdns0()
|
||||||
|
if opt != nil {
|
||||||
|
for _, o := range opt.Option {
|
||||||
|
if o.Option() == dns.EDNS0SUBNET {
|
||||||
|
subnet := o.(*dns.EDNS0_SUBNET)
|
||||||
|
clientIP = subnet.Address
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
for _, q := range r.Question {
|
for _, q := range r.Question {
|
||||||
if q.Name == "google.com." && q.Qtype == dns.TypeA {
|
if q.Name == "google.com." && q.Qtype == dns.TypeA {
|
||||||
rr, _ := dns.NewRR("google.com. IN A 8.8.8.8")
|
if clientIP == nil {
|
||||||
ans.Answer = append(ans.Answer, rr)
|
rr, _ := dns.NewRR("google.com. IN A 8.8.8.8")
|
||||||
|
ans.Answer = append(ans.Answer, rr)
|
||||||
|
} else {
|
||||||
|
rr, _ := dns.NewRR("google.com. IN A 8.8.4.4")
|
||||||
|
ans.Answer = append(ans.Answer, rr)
|
||||||
|
}
|
||||||
} else if q.Name == "facebook.com." && q.Qtype == dns.TypeA {
|
} else if q.Name == "facebook.com." && q.Qtype == dns.TypeA {
|
||||||
rr, _ := dns.NewRR("facebook.com. IN A 9.9.9.9")
|
rr, _ := dns.NewRR("facebook.com. IN A 9.9.9.9")
|
||||||
ans.Answer = append(ans.Answer, rr)
|
ans.Answer = append(ans.Answer, rr)
|
||||||
|
@ -39,6 +57,62 @@ func (*staticHandler) ServeDNS(w dns.ResponseWriter, r *dns.Msg) {
|
||||||
w.WriteMsg(ans)
|
w.WriteMsg(ans)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestUDPServerSubnet(t *testing.T) {
|
||||||
|
if runtime.GOOS == "windows" {
|
||||||
|
t.Skip("doesn't work on Windows due to miekg/dns changes.")
|
||||||
|
}
|
||||||
|
assert := With(t)
|
||||||
|
|
||||||
|
port := udp.PickPort()
|
||||||
|
|
||||||
|
dnsServer := dns.Server{
|
||||||
|
Addr: "127.0.0.1:" + port.String(),
|
||||||
|
Net: "udp",
|
||||||
|
Handler: &staticHandler{},
|
||||||
|
UDPSize: 1200,
|
||||||
|
}
|
||||||
|
|
||||||
|
go dnsServer.ListenAndServe()
|
||||||
|
time.Sleep(time.Second)
|
||||||
|
|
||||||
|
config := &core.Config{
|
||||||
|
App: []*serial.TypedMessage{
|
||||||
|
serial.ToTypedMessage(&Config{
|
||||||
|
NameServers: []*net.Endpoint{
|
||||||
|
{
|
||||||
|
Network: net.Network_UDP,
|
||||||
|
Address: &net.IPOrDomain{
|
||||||
|
Address: &net.IPOrDomain_Ip{
|
||||||
|
Ip: []byte{127, 0, 0, 1},
|
||||||
|
},
|
||||||
|
},
|
||||||
|
Port: uint32(port),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
ClientIp: []byte{7, 8, 9, 10},
|
||||||
|
}),
|
||||||
|
serial.ToTypedMessage(&dispatcher.Config{}),
|
||||||
|
serial.ToTypedMessage(&proxyman.OutboundConfig{}),
|
||||||
|
serial.ToTypedMessage(&policy.Config{}),
|
||||||
|
},
|
||||||
|
Outbound: []*core.OutboundHandlerConfig{
|
||||||
|
{
|
||||||
|
ProxySettings: serial.ToTypedMessage(&freedom.Config{}),
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
v, err := core.New(config)
|
||||||
|
assert(err, IsNil)
|
||||||
|
|
||||||
|
client := v.GetFeature(feature_dns.ClientType()).(feature_dns.Client)
|
||||||
|
|
||||||
|
ips, err := client.LookupIP("google.com")
|
||||||
|
assert(err, IsNil)
|
||||||
|
assert(len(ips), Equals, 1)
|
||||||
|
assert([]byte(ips[0]), Equals, []byte{8, 8, 4, 4})
|
||||||
|
}
|
||||||
|
|
||||||
func TestUDPServer(t *testing.T) {
|
func TestUDPServer(t *testing.T) {
|
||||||
if runtime.GOOS == "windows" {
|
if runtime.GOOS == "windows" {
|
||||||
t.Skip("doesn't work on Windows due to miekg/dns changes.")
|
t.Skip("doesn't work on Windows due to miekg/dns changes.")
|
||||||
|
|
|
@ -104,7 +104,10 @@ func (s *ClassicNameServer) HandleResponse(ctx context.Context, payload *buf.Buf
|
||||||
newError("failed to parse DNS response").Base(err).AtWarning().WriteToLog()
|
newError("failed to parse DNS response").Base(err).AtWarning().WriteToLog()
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
parser.SkipAllQuestions()
|
if err := parser.SkipAllQuestions(); err != nil {
|
||||||
|
newError("failed to skip questions in DNS response").Base(err).AtWarning().WriteToLog()
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
id := header.ID
|
id := header.ID
|
||||||
s.Lock()
|
s.Lock()
|
||||||
|
|
Loading…
Reference in New Issue