mirror of
https://github.com/MetaCubeX/mihomo.git
synced 2025-12-20 00:50:06 +08:00
chore: cleanup dns client code
This commit is contained in:
parent
6786705212
commit
40b2cde2b2
@ -16,53 +16,49 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type client struct {
|
type client struct {
|
||||||
*D.Client
|
port string
|
||||||
port string
|
host string
|
||||||
host string
|
dialer *dnsDialer
|
||||||
dialer *dnsDialer
|
schema string
|
||||||
addr string
|
skipCertVerify bool
|
||||||
}
|
}
|
||||||
|
|
||||||
var _ dnsClient = (*client)(nil)
|
var _ dnsClient = (*client)(nil)
|
||||||
|
|
||||||
// Address implements dnsClient
|
// Address implements dnsClient
|
||||||
func (c *client) Address() string {
|
func (c *client) Address() string {
|
||||||
if len(c.addr) != 0 {
|
return fmt.Sprintf("%s://%s", c.schema, net.JoinHostPort(c.host, c.port))
|
||||||
return c.addr
|
|
||||||
}
|
|
||||||
schema := "udp"
|
|
||||||
if strings.HasPrefix(c.Client.Net, "tcp") {
|
|
||||||
schema = "tcp"
|
|
||||||
if strings.HasSuffix(c.Client.Net, "tls") {
|
|
||||||
schema = "tls"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
c.addr = fmt.Sprintf("%s://%s", schema, net.JoinHostPort(c.host, c.port))
|
|
||||||
return c.addr
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *client) ExchangeContext(ctx context.Context, m *D.Msg) (*D.Msg, error) {
|
func (c *client) ExchangeContext(ctx context.Context, m *D.Msg) (*D.Msg, error) {
|
||||||
network := "udp"
|
network := "udp"
|
||||||
if strings.HasPrefix(c.Client.Net, "tcp") {
|
if c.schema != "udp" {
|
||||||
network = "tcp"
|
network = "tcp"
|
||||||
}
|
}
|
||||||
|
|
||||||
tlsConfig, err := ca.GetTLSConfig(ca.Option{
|
|
||||||
TLSConfig: c.Client.TLSConfig,
|
|
||||||
})
|
|
||||||
if err != nil {
|
|
||||||
return nil, err
|
|
||||||
}
|
|
||||||
|
|
||||||
addr := net.JoinHostPort(c.host, c.port)
|
addr := net.JoinHostPort(c.host, c.port)
|
||||||
conn, err := c.dialer.DialContext(ctx, network, addr)
|
conn, err := c.dialer.DialContext(ctx, network, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
defer func() {
|
defer conn.Close()
|
||||||
_ = conn.Close()
|
|
||||||
}()
|
if c.schema == "tls" {
|
||||||
|
tlsConfig, err := ca.GetTLSConfig(ca.Option{
|
||||||
|
TLSConfig: &tls.Config{
|
||||||
|
ServerName: c.host,
|
||||||
|
InsecureSkipVerify: c.skipCertVerify,
|
||||||
|
},
|
||||||
|
})
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
tlsConn := tls.Client(conn, tlsConfig)
|
||||||
|
if err := tlsConn.HandshakeContext(ctx); err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
conn = tlsConn
|
||||||
|
}
|
||||||
|
|
||||||
// miekg/dns ExchangeContext doesn't respond to context cancel.
|
// miekg/dns ExchangeContext doesn't respond to context cancel.
|
||||||
// this is a workaround
|
// this is a workaround
|
||||||
@ -72,34 +68,30 @@ func (c *client) ExchangeContext(ctx context.Context, m *D.Msg) (*D.Msg, error)
|
|||||||
}
|
}
|
||||||
ch := make(chan result, 1)
|
ch := make(chan result, 1)
|
||||||
go func() {
|
go func() {
|
||||||
if strings.HasSuffix(c.Client.Net, "tls") {
|
dClient := &D.Client{
|
||||||
conn = tls.Client(conn, tlsConfig)
|
UDPSize: 4096,
|
||||||
|
Timeout: 5 * time.Second,
|
||||||
}
|
}
|
||||||
|
|
||||||
dConn := &D.Conn{
|
dConn := &D.Conn{
|
||||||
Conn: conn,
|
Conn: conn,
|
||||||
UDPSize: c.Client.UDPSize,
|
UDPSize: dClient.UDPSize,
|
||||||
TsigSecret: c.Client.TsigSecret,
|
|
||||||
TsigProvider: c.Client.TsigProvider,
|
|
||||||
}
|
}
|
||||||
|
|
||||||
msg, _, err := c.Client.ExchangeWithConn(m, dConn)
|
msg, _, err := dClient.ExchangeWithConn(m, dConn)
|
||||||
|
|
||||||
// Resolvers MUST resend queries over TCP if they receive a truncated UDP response (with TC=1 set)!
|
// Resolvers MUST resend queries over TCP if they receive a truncated UDP response (with TC=1 set)!
|
||||||
if msg != nil && msg.Truncated && network == "udp" {
|
if msg != nil && msg.Truncated && network == "udp" {
|
||||||
tcpClient := *c.Client // copy a client
|
|
||||||
tcpClient.Net = "tcp"
|
|
||||||
network = "tcp"
|
network = "tcp"
|
||||||
log.Debugln("[DNS] Truncated reply from %s:%s for %s over UDP, retrying over TCP", c.host, c.port, m.Question[0].String())
|
log.Debugln("[DNS] Truncated reply from %s:%s for %s over UDP, retrying over TCP", c.host, c.port, m.Question[0].String())
|
||||||
dConn.Conn, err = c.dialer.DialContext(ctx, network, addr)
|
var tcpConn net.Conn
|
||||||
|
tcpConn, err = c.dialer.DialContext(ctx, network, addr)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
ch <- result{msg, err}
|
ch <- result{msg, err}
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
defer func() {
|
defer tcpConn.Close()
|
||||||
_ = conn.Close()
|
dConn.Conn = tcpConn
|
||||||
}()
|
msg, _, err = dClient.ExchangeWithConn(m, dConn)
|
||||||
msg, _, err = tcpClient.ExchangeWithConn(m, dConn)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ch <- result{msg, err}
|
ch <- result{msg, err}
|
||||||
@ -118,20 +110,19 @@ func (c *client) ResetConnection() {}
|
|||||||
func newClient(addr string, resolver *Resolver, netType string, params map[string]string, proxyAdapter C.ProxyAdapter, proxyName string) *client {
|
func newClient(addr string, resolver *Resolver, netType string, params map[string]string, proxyAdapter C.ProxyAdapter, proxyName string) *client {
|
||||||
host, port, _ := net.SplitHostPort(addr)
|
host, port, _ := net.SplitHostPort(addr)
|
||||||
c := &client{
|
c := &client{
|
||||||
Client: &D.Client{
|
|
||||||
Net: netType,
|
|
||||||
TLSConfig: &tls.Config{
|
|
||||||
ServerName: host,
|
|
||||||
},
|
|
||||||
UDPSize: 4096,
|
|
||||||
Timeout: 5 * time.Second,
|
|
||||||
},
|
|
||||||
port: port,
|
port: port,
|
||||||
host: host,
|
host: host,
|
||||||
dialer: newDNSDialer(resolver, proxyAdapter, proxyName),
|
dialer: newDNSDialer(resolver, proxyAdapter, proxyName),
|
||||||
|
schema: "udp",
|
||||||
|
}
|
||||||
|
if strings.HasPrefix(netType, "tcp") {
|
||||||
|
c.schema = "tcp"
|
||||||
|
if strings.HasSuffix(netType, "tls") {
|
||||||
|
c.schema = "tls"
|
||||||
|
}
|
||||||
}
|
}
|
||||||
if params["skip-cert-verify"] == "true" {
|
if params["skip-cert-verify"] == "true" {
|
||||||
c.TLSConfig.InsecureSkipVerify = true
|
c.skipCertVerify = true
|
||||||
}
|
}
|
||||||
return c
|
return c
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user