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