You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 

33 lines
1.0 KiB

#!/usr/bin/env bash
set -euo pipefail
RESOLVED_SERVICE_NAME="systemd-resolved"
RESOLVED_CONF_FILE="/etc/systemd/resolved.conf"
# Check if the 'systemd-resolved' service is running
if ! systemctl is-active --quiet service "${RESOLVED_SERVICE_NAME}"; then
echo "Service '${RESOLVED_SERVICE_NAME}' is not running"
exit
fi
# Check if the DNS Stub Listener is running
if cat "${RESOLVED_CONF_FILE}" | grep --quiet "^DNSStubListener=no$"; then
echo "DNSStubListener already turned off"
exit
fi
echo "Turning off the DNS Stub Listener"
# Turn off DNSStubListener within config file
sed -r -i.orig 's/#?DNSStubListener=yes/DNSStubListener=no/g' "${RESOLVED_CONF_FILE}"
# Remove active resolv.conf which would have
# localhost (systemd-resolved's DNS listener) as the DNS resolver
rm -f /etc/resolv.conf
# Create a symlink between systemd-resolved's upstream resolv.conf
# and the OS's resolv.conf
ln -s /run/systemd/resolve/resolv.conf /etc/resolv.conf
echo "Restart service '${RESOLVED_SERVICE_NAME}'"
systemctl restart "${RESOLVED_SERVICE_NAME}"