aboutsummaryrefslogtreecommitdiffstats
path: root/dns
diff options
context:
space:
mode:
authorlev <lev@FreeBSD.org>2016-08-17 21:22:27 +0800
committerlev <lev@FreeBSD.org>2016-08-17 21:22:27 +0800
commit6c3645253c21661e26681757190b9c7f039acfb5 (patch)
tree0e3e988bf0bf6bdf1ab789c96fc10cbb4d683d57 /dns
parentc1d7aec75268f3fb489d85065db09f10cd056a23 (diff)
downloadfreebsd-ports-gnome-6c3645253c21661e26681757190b9c7f039acfb5.tar.gz
freebsd-ports-gnome-6c3645253c21661e26681757190b9c7f039acfb5.tar.zst
freebsd-ports-gnome-6c3645253c21661e26681757190b9c7f039acfb5.zip
Add profiles to nsd init script.
PR: 211883 Submitted by: lev Approved by: jaap@NLnetLabs.nl
Diffstat (limited to 'dns')
-rw-r--r--dns/nsd/files/nsd.in87
1 files changed, 80 insertions, 7 deletions
diff --git a/dns/nsd/files/nsd.in b/dns/nsd/files/nsd.in
index c0c6e5fb5c1a..9c78e3fd354d 100644
--- a/dns/nsd/files/nsd.in
+++ b/dns/nsd/files/nsd.in
@@ -11,6 +11,18 @@
#
# nsd_enable="YES"
#
+# You could set alternative config with
+#
+# nsd_config="/path/to/config"
+#
+# Multiple profiles are supported with
+#
+# nsd_profiles="name1 name2"
+# nsd_name1_enable="YES"
+# nsd_name1_config="/path/to/config1"
+# nsd_name2_enable="YES"
+# nsd_name2_config="/path/to/config2"
+#
. /etc/rc.subr
@@ -19,16 +31,77 @@ rcvar=nsd_enable
# read settings, set default values
load_rc_config "${name}"
-: ${nsd_enable="NO"}
+: ${nsd_enable:="NO"}
+: ${nsd_config:=%%ETCDIR%%/nsd.conf}
-config=${nsd_config:=%%ETCDIR%%/nsd.conf}
-required_files=${config}
-pidfile=`%%PREFIX%%/sbin/nsd-checkconf -f -o pidfile ${config}`
+# Set PID file
+_pidprefix=/var/run/${name}
+_cfgpidfile=$(%%PREFIX%%/sbin/nsd-checkconf -f -o pidfile ${nsd_config})
+pidfile=${_cfgpidfile:-${_pidprefix}.pid}
+
+required_files=${nsd_config}
command="%%PREFIX%%/sbin/${name}"
-command_args="-c ${required_files}"
+command_args="-c ${nsd_config} -P ${pidfile}"
extra_commands="reload"
-load_rc_config $name
+load_rc_config "${name}"
+
+if [ -n "$2" ]; then
+ profile="$2"
+ if [ "x${nsd_profiles}" != "x" ]; then
+ eval nsd_config="\${nsd_${profile}_config:-%%ETCDIR%%/nsd-${profile}.conf}"
+ if [ "x${nsd_config}" = "x" ]; then
+ echo "You must define a configuration file (nsd_${profile}_config)"
+ exit 1
+ fi
+ _cfgpidfile=$(%%PREFIX%%/sbin/nsd-checkconf -f -o pidfile ${nsd_config})
+ _defaultpidfile=$(%%PREFIX%%/sbin/nsd-checkconf -f -o pidfile /dev/null)
+ # Replace empty or default value with profile-based
+ if [ "x${_cfgpidfile}" = "x" -o "x${_cfgpidfile}" = "x${_defaultpidfile}" ] ; then
+ pidfile=${_pidprefix}-${profile}.pid
+ else
+ pidfile=${_cfgpidfile}
+ fi
+ required_files="${nsd_config}"
+ eval nsd_enable="\${nsd_${profile}_enable:-${nsd_enable}}"
+ command_args="-c ${nsd_config} -P ${pidfile}"
+ else
+ echo "$0: extra argument ignored"
+ fi
+else
+ if [ "x${nsd_profiles}" != "x" -a "x$1" != "x" ]; then
+ for profile in ${nsd_profiles}; do
+ eval _enable="\${nsd_${profile}_enable}"
+ case "x${_enable:-${nsd_enable}}" in
+ x|x[Nn][Oo]|x[Nn][Oo][Nn][Ee])
+ continue
+ ;;
+ x[Yy][Ee][Ss])
+ ;;
+ *)
+ if test -z "$_enable"; then
+ _var=nsd_enable
+ else
+ _var=nsd_"${profile}"_enable
+ fi
+ echo "Bad value" \
+ "'${_enable:-${nsd_enable}}'" \
+ "for ${_var}. " \
+ "Profile ${profile} skipped."
+ continue
+ ;;
+ esac
+ echo "===> nsd profile: ${profile}"
+ %%PREFIX%%/etc/rc.d/nsd $1 ${profile}
+ retcode="$?"
+ if [ "0${retcode}" -ne 0 ]; then
+ failed="${profile} (${retcode}) ${failed:-}"
+ else
+ success="${profile} ${success:-}"
+ fi
+ done
+ exit 0
+ fi
+fi
run_rc_command "$1"
-