57 lines
1.3 KiB
Bash
Executable file
57 lines
1.3 KiB
Bash
Executable file
#!/bin/bash
|
|
#
|
|
# Parses DHCP options from openvpn to update resolv.conf
|
|
# To use set as 'up' and 'down' script in your openvpn *.conf:
|
|
# up /etc/openvpn/update-resolv-conf
|
|
# down /etc/openvpn/update-resolv-conf
|
|
#
|
|
# Used snippets of resolvconf script by Thomas Hood and Chris Hanson.
|
|
# Licensed under the GNU GPL. See /usr/share/common-licenses/GPL.
|
|
#
|
|
# Example envs set from openvpn:
|
|
#
|
|
# foreign_option_1='dhcp-option DNS 193.43.27.132'
|
|
# foreign_option_2='dhcp-option DNS 193.43.27.133'
|
|
# foreign_option_3='dhcp-option DOMAIN be.bnc.ch'
|
|
#
|
|
|
|
[ "$script_type" ] || exit 0
|
|
[ "$dev" ] || exit 0
|
|
|
|
split_into_parts()
|
|
{
|
|
part1="$1"
|
|
part2="$2"
|
|
part3="$3"
|
|
}
|
|
|
|
case "$script_type" in
|
|
up)
|
|
NMSRVRS=""
|
|
SRCHS=""
|
|
for optionvarname in ${!foreign_option_*} ; do
|
|
option="${!optionvarname}"
|
|
echo "$option"
|
|
split_into_parts $option
|
|
if [ "$part1" = "dhcp-option" ] ; then
|
|
if [ "$part2" = "DNS" ] ; then
|
|
NMSRVRS="${NMSRVRS:+$NMSRVRS }$part3"
|
|
elif [ "$part2" = "DOMAIN" ] ; then
|
|
SRCHS="${SRCHS:+$SRCHS }$part3"
|
|
fi
|
|
fi
|
|
done
|
|
R=""
|
|
for NS in $NMSRVRS ; do
|
|
R="${R}server=$NS@$dev\n"
|
|
done
|
|
echo -en "$R" > /etc/dnsmasq.d/forward
|
|
/usr/sbin/service dnsmasq restart
|
|
;;
|
|
down)
|
|
echo -n "" > /etc/dnsmasq.d/forward
|
|
/usr/sbin/service dnsmasq restart
|
|
;;
|
|
esac
|
|
|