2021-07-23 18:55:53 +00:00
|
|
|
package dns
|
|
|
|
|
|
2022-01-06 06:40:23 -05:00
|
|
|
import (
|
2023-05-20 19:58:18 +00:00
|
|
|
"net/netip"
|
2024-08-21 14:35:41 +02:00
|
|
|
"time"
|
2022-01-06 06:40:23 -05:00
|
|
|
|
2024-08-21 14:35:41 +02:00
|
|
|
"github.com/qdm12/dns/v2/pkg/nameserver"
|
2022-01-06 06:40:23 -05:00
|
|
|
)
|
2021-07-23 18:55:53 +00:00
|
|
|
|
2021-07-23 18:57:29 +00:00
|
|
|
func (l *Loop) useUnencryptedDNS(fallback bool) {
|
2021-07-23 18:55:53 +00:00
|
|
|
settings := l.GetSettings()
|
|
|
|
|
|
|
|
|
|
// Try with user provided plaintext ip address
|
2024-08-21 14:35:41 +02:00
|
|
|
// if it's not 127.0.0.1 (default for DoT), otherwise
|
|
|
|
|
// use the first DoT provider ipv4 address found.
|
|
|
|
|
var targetIP netip.Addr
|
|
|
|
|
if settings.ServerAddress.Compare(netip.AddrFrom4([4]byte{127, 0, 0, 1})) != 0 {
|
|
|
|
|
targetIP = settings.ServerAddress
|
|
|
|
|
} else {
|
|
|
|
|
targetIP = settings.DoT.GetFirstPlaintextIPv4()
|
2022-01-06 06:40:23 -05:00
|
|
|
}
|
|
|
|
|
|
2021-07-23 18:55:53 +00:00
|
|
|
if fallback {
|
|
|
|
|
l.logger.Info("falling back on plaintext DNS at address " + targetIP.String())
|
|
|
|
|
} else {
|
|
|
|
|
l.logger.Info("using plaintext DNS at address " + targetIP.String())
|
|
|
|
|
}
|
2024-08-21 14:35:41 +02:00
|
|
|
|
|
|
|
|
const dialTimeout = 3 * time.Second
|
|
|
|
|
settingsInternalDNS := nameserver.SettingsInternalDNS{
|
|
|
|
|
IP: targetIP,
|
|
|
|
|
Timeout: dialTimeout,
|
|
|
|
|
}
|
|
|
|
|
nameserver.UseDNSInternally(settingsInternalDNS)
|
|
|
|
|
|
|
|
|
|
settingsSystemWide := nameserver.SettingsSystemDNS{
|
|
|
|
|
IP: targetIP,
|
|
|
|
|
ResolvPath: l.resolvConf,
|
|
|
|
|
}
|
|
|
|
|
err := nameserver.UseDNSSystemWide(settingsSystemWide)
|
2021-07-23 18:55:53 +00:00
|
|
|
if err != nil {
|
|
|
|
|
l.logger.Error(err.Error())
|
|
|
|
|
}
|
|
|
|
|
}
|