mirror of
https://github.com/qdm12/gluetun.git
synced 2026-05-07 12:30:11 +02:00
405a6f699d
- start DNS server before healthcheck - do not fallback to plaintext anymore - allow to use plain addresses with a port different than 53, system-wide - do not wait for the DNS server and rely on healtcheck only
48 lines
1.3 KiB
Go
48 lines
1.3 KiB
Go
package dns
|
|
|
|
import (
|
|
"context"
|
|
"fmt"
|
|
|
|
"github.com/qdm12/dns/v2/pkg/middlewares/filter/update"
|
|
"github.com/qdm12/dns/v2/pkg/nameserver"
|
|
"github.com/qdm12/dns/v2/pkg/server"
|
|
"github.com/qdm12/gluetun/internal/configuration/settings"
|
|
)
|
|
|
|
func (l *Loop) setupServer(ctx context.Context, settings settings.DNS) (runError <-chan error, err error) {
|
|
var updateSettings update.Settings
|
|
updateSettings.SetRebindingProtectionExempt(settings.Blacklist.RebindingProtectionExemptHostnames)
|
|
err = l.filter.Update(updateSettings)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("updating filter for rebinding protection: %w", err)
|
|
}
|
|
|
|
serverSettings, err := buildServerSettings(settings, l.filter, l.localResolvers, l.localSubnets, l.logger)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("building server settings: %w", err)
|
|
}
|
|
|
|
server, err := server.New(serverSettings)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("creating server: %w", err)
|
|
}
|
|
|
|
runError, err = server.Start(ctx)
|
|
if err != nil {
|
|
return nil, fmt.Errorf("starting server: %w", err)
|
|
}
|
|
l.server = server
|
|
|
|
// use internal DNS server
|
|
nameserver.UseDNSInternally(nameserver.SettingsInternalDNS{})
|
|
err = nameserver.UseDNSSystemWide(nameserver.SettingsSystemDNS{
|
|
ResolvPath: l.resolvConf,
|
|
})
|
|
if err != nil {
|
|
l.logger.Error(err.Error())
|
|
}
|
|
|
|
return runError, nil
|
|
}
|