f7a1063
#!/bin/bash
f7a1063
#
f7a1063
# nsd           Starts the NSD Name Server Daemon
f7a1063
#
f7a1063
# chkconfig:    - 23 87
f7a1063
# description:  NSD is a complete implementation of an authoritative \
f7a1063
#               DNS name server.
f7a1063
#
f7a1063
### BEGIN INIT INFO
f7a1063
# Provides: nsd
f7a1063
# Required-Start: $local_fs $network $syslog
f7a1063
# Required-Stop: $local_fs $network $syslog
f7a1063
# Default-Start:
f7a1063
# Default-Stop: 0 1 2 3 4 5 6
f7a1063
# Short-Description: The NSD Name Server Daemon
f7a1063
# Description: NSD is a complete implementation of an authoritative
f7a1063
#              DNS name server.
f7a1063
### END INIT INFO
f7a1063
f7a1063
# Init script default settings
f7a1063
NSD_CONF="/etc/nsd/nsd.conf"
f7a1063
NSD_PROG="/usr/sbin/nsd"
f7a1063
NSD_PIDFILE="/var/run/nsd/nsd.pid"
f7a1063
NSD_XFRDFILE="/var/lib/nsd/xfrd.state"
f7a1063
NSDC_PROG="/usr/sbin/nsd-control"
f7a1063
NSD_USER="nsd"
f7a1063
NSD_PIDDIR="$(dirname ${NSD_PIDFILE})"
f7a1063
NSD_EXTRA_OPTS=""
f7a1063
f7a1063
# Source function library.
f7a1063
. /etc/rc.d/init.d/functions
f7a1063
f7a1063
[ -r /etc/sysconfig/nsd ] && . /etc/sysconfig/nsd
f7a1063
f7a1063
# Check that networking is configured.
f7a1063
[ "${NETWORKING}" = "no" ] && exit 0
f7a1063
f7a1063
# avoid AVC, see rhbz#989218
f7a1063
cd /etc/nsd
f7a1063
f7a1063
start() {
f7a1063
    # Source networking configuration.
f7a1063
    [ -r /etc/sysconfig/network ] && . /etc/sysconfig/network
f7a1063
f7a1063
    # Check that networking is up
f7a1063
    [ "${NETWORKING}" = "no" ] && exit 1
f7a1063
f7a1063
    # Sanity checks.
f7a1063
    [ -f ${NSD_CONF} ] || exit 5
f7a1063
    [ -x ${NSD_PROG} ] || exit 5
f7a1063
    # /var/run could (and should) be tmpfs
f7a1063
    [ -d ${NSD_PIDDIR} ] || {
f7a1063
	mkdir -p ${NSD_PIDDIR}
f7a1063
	chown ${NSD_USER}: ${NSD_PIDDIR}
f7a1063
    }
f7a1063
f7a1063
    if [ ! -f /etc/nsd/nsd_control.key ]; then
f7a1063
	echo -n $"Generating nsd control key and certificate: "
f7a1063
	/usr/sbin/nsd-control-setup -d /etc/nsd/ > /dev/null 2> /dev/null
f7a1063
	chgrp nsd /etc/nsd/nsd_*key /etc/nsd/nsd_*pem
f7a1063
	[ -x /usr/sbin/selinuxenabled ] && /usr/sbin/selinuxenabled && \
f7a1063
	    [ -x /sbin/restorecon ] && /sbin/restorecon /etc/nsd/*
f7a1063
	echo
f7a1063
    fi
f7a1063
f7a1063
    echo -n $"Starting nsd:"
f7a1063
    daemon \
f7a1063
	--pidfile=${NSD_PIDFILE} \
f7a1063
	${NSD_PROG} -c ${NSD_CONF} \
f7a1063
	${NSD_EXTRA_OPTS}
f7a1063
    RETVAL=$?
f7a1063
    [ $RETVAL -eq 0 ] && touch /var/lock/subsys/nsd
f7a1063
    echo
f7a1063
}
f7a1063
f7a1063
stop() {
f7a1063
    echo -n $"Stopping nsd: "
f7a1063
    # save state to zonefiles
f7a1063
    ${NSDC_PROG} -c ${NSD_CONF} write > /dev/null 2>&1
f7a1063
    killproc -p ${NSD_PIDFILE} ${NSD_PROG}
f7a1063
    RETVAL=$?
f7a1063
    if [ $RETVAL -eq 0 ] ; then
f7a1063
	rm -f /var/lock/subsys/nsd
f7a1063
	# ensure notifies are sent at startup
f7a1063
	rm -f ${NSD_XFRDFILE}
f7a1063
	success
f7a1063
    else
f7a1063
	failure
f7a1063
    fi
f7a1063
    echo
f7a1063
    return $RETVAL
f7a1063
}
f7a1063
f7a1063
restart() {
f7a1063
    stop
f7a1063
    start
f7a1063
}
f7a1063
f7a1063
RETVAL=0
f7a1063
f7a1063
# See how we were called.
f7a1063
case "$1" in
f7a1063
    start)
f7a1063
	start
f7a1063
	;;
f7a1063
    stop)
f7a1063
	stop
f7a1063
	;;
f7a1063
    restart)
f7a1063
	restart
f7a1063
	;;
f7a1063
    condrestart|try-restart)
f7a1063
	[ -f /var/lock/subsys/nsd ] && restart || :
f7a1063
	;;
f7a1063
    status)
f7a1063
	status -p ${NSD_PIDFILE} ${NSD_PROG}
f7a1063
	RETVAL=$?
f7a1063
	;;
f7a1063
    reload)
f7a1063
	echo -n $"Reloading nsd:"
f7a1063
	killproc -p ${NSD_PIDFILE} ${NSD_PROG} -HUP
f7a1063
	RETVAL=$?
f7a1063
	${NSDC_PROG} -c ${NSD_CONF} notify >/dev/null 2>&1 
f7a1063
	if [ $RETVAL -eq 0 ] ; then
f7a1063
	    success
f7a1063
	else
f7a1063
	    failure
f7a1063
	fi
f7a1063
	echo
f7a1063
	;;
f7a1063
    *)
f7a1063
	echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload}"
f7a1063
	exit 2
f7a1063
esac
f7a1063
f7a1063
exit $RETVAL