2022-01-06 06:40:23 -05:00
|
|
|
package env
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"fmt"
|
2023-05-20 19:58:18 +00:00
|
|
|
"net/netip"
|
2022-01-06 06:40:23 -05:00
|
|
|
|
|
|
|
|
"github.com/qdm12/gluetun/internal/configuration/settings"
|
|
|
|
|
)
|
|
|
|
|
|
2022-08-26 15:16:51 +00:00
|
|
|
func (s *Source) readDNS() (dns settings.DNS, err error) {
|
|
|
|
|
dns.ServerAddress, err = s.readDNSServerAddress()
|
2022-01-06 06:40:23 -05:00
|
|
|
if err != nil {
|
|
|
|
|
return dns, err
|
|
|
|
|
}
|
|
|
|
|
|
2023-06-01 08:22:55 +00:00
|
|
|
dns.KeepNameserver, err = s.env.BoolPtr("DNS_KEEP_NAMESERVER")
|
2022-01-06 06:40:23 -05:00
|
|
|
if err != nil {
|
2023-05-30 15:21:09 +00:00
|
|
|
return dns, err
|
2022-01-06 06:40:23 -05:00
|
|
|
}
|
|
|
|
|
|
2022-08-26 15:16:51 +00:00
|
|
|
dns.DoT, err = s.readDoT()
|
2022-01-06 06:40:23 -05:00
|
|
|
if err != nil {
|
2022-02-20 02:58:16 +00:00
|
|
|
return dns, fmt.Errorf("DoT settings: %w", err)
|
2022-01-06 06:40:23 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return dns, nil
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-20 19:58:18 +00:00
|
|
|
func (s *Source) readDNSServerAddress() (address netip.Addr, err error) {
|
2023-06-05 16:25:52 +00:00
|
|
|
const currentKey = "DNS_ADDRESS"
|
|
|
|
|
key := firstKeySet(s.env, "DNS_PLAINTEXT_ADDRESS", currentKey)
|
|
|
|
|
switch key {
|
|
|
|
|
case "":
|
2023-05-20 19:58:18 +00:00
|
|
|
return address, nil
|
2023-06-05 16:25:52 +00:00
|
|
|
case currentKey:
|
|
|
|
|
default: // Retro-compatibility
|
|
|
|
|
s.handleDeprecatedKey(key, currentKey)
|
2022-01-06 06:40:23 -05:00
|
|
|
}
|
|
|
|
|
|
2023-06-05 16:25:52 +00:00
|
|
|
address, err = s.env.NetipAddr(key)
|
2023-05-20 19:58:18 +00:00
|
|
|
if err != nil {
|
2023-06-05 16:25:52 +00:00
|
|
|
return address, err
|
2022-01-06 06:40:23 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
// TODO remove in v4
|
2023-05-20 19:58:18 +00:00
|
|
|
if address.Unmap().Compare(netip.AddrFrom4([4]byte{127, 0, 0, 1})) != 0 {
|
2023-06-05 16:25:52 +00:00
|
|
|
s.warner.Warn(key + " is set to " + address.String() +
|
2022-01-06 06:40:23 -05:00
|
|
|
" so the DNS over TLS (DoT) server will not be used." +
|
2022-08-26 15:16:51 +00:00
|
|
|
" The default value changed to 127.0.0.1 so it uses the internal DoT serves." +
|
2022-01-06 06:40:23 -05:00
|
|
|
" If the DoT server fails to start, the IPv4 address of the first plaintext DNS server" +
|
|
|
|
|
" corresponding to the first DoT provider chosen is used.")
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return address, nil
|
|
|
|
|
}
|