cvsdist 2f7f4bd
#!/bin/bash
cvsdist 2f7f4bd
#
cvsdist 2f7f4bd
# named           This shell script takes care of starting and stopping
cvsdist 2f7f4bd
#                 named (BIND DNS server).
cvsdist 2f7f4bd
#
jvdias 3c357dd
# chkconfig: - 13 87
cvsdist 2f7f4bd
# description: named (BIND) is a Domain Name Server (DNS) \
cvsdist 2f7f4bd
# that is used to resolve host names to IP addresses.
cvsdist 2f7f4bd
# probe: true
cvsdist 2f7f4bd
Adam Tkac 969b1cb
### BEGIN INIT INFO
Adam Tkac 969b1cb
# Provides: $named
Adam Tkac 969b1cb
# Required-Start: $local_fs $network $syslog
Adam Tkac 969b1cb
# Required-Stop: $local_fs $network $syslog
Adam Tkac fe4c11e
# Default-Start:
Adam Tkac fe4c11e
# Default-Stop: 0 1 2 3 4 5 6
Adam Tkac 969b1cb
# Short-Description: start|stop|status|restart|try-restart|reload|force-reload DNS server
Adam Tkac 969b1cb
# Description: control ISC BIND implementation of DNS server
Adam Tkac 969b1cb
### END INIT INFO
Adam Tkac e51da31
cvsdist 2f7f4bd
# Source function library.
cvsdist 2f7f4bd
. /etc/rc.d/init.d/functions
cvsdist 2f7f4bd
cvsdist 78e1f2e
[ -r /etc/sysconfig/named ] && . /etc/sysconfig/named
cvsdist 2f7f4bd
Adam Tkac e51da31
RETVAL=0
Adam Tkac fb5bf17
export KRB5_KTNAME=${KEYTAB_FILE:-/etc/named.keytab}
Adam Tkac e51da31
Adam Tkac 15c5cd7
named='named'
Adam Tkac 15c5cd7
if [ -x /usr/sbin/named-sdb ]; then
Adam Tkac 15c5cd7
	named='named-sdb'
Adam Tkac 15c5cd7
fi
Adam Tkac 15c5cd7
28242bb
# Don't kill named during clean-up
Adam Tkac 72f5cc8
NAMED_SHUTDOWN_TIMEOUT=${NAMED_SHUTDOWN_TIMEOUT:-25}
2e702b3
jvdias 0cd02aa
if [ -n "$ROOTDIR" ]; then
jvdias 0cd02aa
   ROOTDIR=`echo $ROOTDIR | sed 's#//*#/#g;s#/$##'`;
jvdias 0cd02aa
   rdl=`/usr/bin/readlink $ROOTDIR`;
jvdias 0cd02aa
   if [ -n "$rdl" ]; then
jvdias 0cd02aa
      ROOTDIR="$rdl";
jvdias 0cd02aa
   fi;
jvdias 0cd02aa
fi
jvdias 38a73ea
Adam Tkac 91895cf
ROOTDIR_MOUNT='/etc/named /etc/pki/dnssec-keys /var/named /etc/named.conf
Adam Tkac 583a06b
/etc/named.dnssec.keys /etc/named.rfc1912.zones /etc/rndc.conf /etc/rndc.key
Adam Tkac 34adbeb
/usr/lib64/bind /usr/lib/bind /etc/named.iscdlv.key'
Adam Tkac 91895cf
Adam Tkac 91895cf
mount_chroot_conf()
Adam Tkac 91895cf
{
Adam Tkac 91895cf
  if [ -n "$ROOTDIR" ]; then
Adam Tkac 91895cf
    for all in $ROOTDIR_MOUNT; do
Adam Tkac 91895cf
      # Skip nonexistant files
Adam Tkac 91895cf
      [ -e "$all" ] || continue
Adam Tkac 91895cf
Adam Tkac 91895cf
      # If mount source is a file
Adam Tkac 91895cf
      if ! [ -d "$all" ]; then
Adam Tkac 91895cf
        # mount it only if it is not present in chroot or it is empty
Adam Tkac b70aaad
        if ! [ -e "$ROOTDIR$all" ] || [ `stat -c'%s' "$ROOTDIR$all"` -eq 0 ]; then
Adam Tkac 91895cf
          touch "$ROOTDIR$all"
Adam Tkac 91895cf
          mount --bind "$all" "$ROOTDIR$all"
Adam Tkac 91895cf
        fi
Adam Tkac 91895cf
      else
Adam Tkac 91895cf
        # Mount source is a directory. Mount it only if directory in chroot is
Adam Tkac 91895cf
        # empty.
Adam Tkac 583a06b
	if [ -e "$all" ] && [ `ls -1A $ROOTDIR$all | wc -l` -eq 0 ]; then
Adam Tkac 91895cf
          mount --bind "$all" "$ROOTDIR$all"
Adam Tkac 583a06b
	fi
Adam Tkac 91895cf
      fi
Adam Tkac 91895cf
    done
Adam Tkac 91895cf
  fi
Adam Tkac 91895cf
}
Adam Tkac 91895cf
Adam Tkac 91895cf
umount_chroot_conf()
Adam Tkac 91895cf
{
Adam Tkac 91895cf
  for all in $ROOTDIR_MOUNT; do
Adam Tkac 91895cf
    # Check if file is mount target. Do not use /proc/mounts because detecting
Adam Tkac 91895cf
    # of modified mounted files can fail.
Adam Tkac 91895cf
    if mount | grep -q '.* on '"$ROOTDIR$all"' .*'; then
Adam Tkac 91895cf
      umount "$ROOTDIR$all"
Adam Tkac 91895cf
      # Remove temporary created files
Adam Tkac 91895cf
      [ -f "$all" ] && rm -f "$ROOTDIR$all"
Adam Tkac 91895cf
    fi
Adam Tkac 91895cf
  done
Adam Tkac 91895cf
}
Adam Tkac 91895cf
Adam Tkac e51da31
# Check if all what named needs running
Adam Tkac e51da31
start()
Adam Tkac e51da31
{
Adam Tkac 13e55cd
  [ "$EUID" != "0" ] && exit 4
Adam Tkac 13e55cd
Adam Tkac e51da31
  # Source networking configuration.
Adam Tkac e51da31
  [ -r /etc/sysconfig/network ] && . /etc/sysconfig/network
jvdias 0cd02aa
Adam Tkac e51da31
  # Check that networking is up
Adam Tkac e51da31
  [ "${NETWORKING}" = "no" ] && exit 1
jvdias 0cd02aa
jvdias 4206716
Adam Tkac 15c5cd7
  [ -x /usr/sbin/"$named" ] || exit 5
Adam Tkac e51da31
Adam Tkac e51da31
  # Handle -c option
Adam Tkac e51da31
  previous_option='unspecified';
Adam Tkac e51da31
  for a in $OPTIONS; do
Adam Tkac e51da31
    if [ $previous_option = '-c' ]; then
Adam Tkac e51da31
      named_conf=$a;
jvdias bc0ace6
    fi;
Adam Tkac e51da31
    previous_option=$a;
Adam Tkac e51da31
  done;
jvdias bc0ace6
Adam Tkac e51da31
  named_conf=${named_conf:-/etc/named.conf};
Adam Tkac e51da31
Adam Tkac 91895cf
  mount_chroot_conf
Adam Tkac 91895cf
Adam Tkac 0388640
  if [ ! -r $ROOTDIR$named_conf ]; then
Adam Tkac e51da31
    echo 'Cannot find configuration file. You could create it by system-config-bind'
Adam Tkac e51da31
    exit 6;
Adam Tkac e51da31
  fi;
Adam Tkac e51da31
Adam Tkac e51da31
  # all pre-start is done, lets start named
Adam Tkac 2be0bc6
  echo -n $"Starting named: "
Adam Tkac 15c5cd7
  if [ -n "`/sbin/pidof -o %PPID "$named"`" ]; then
Adam Tkac 2be0bc6
    echo -n $"named: already running"
Adam Tkac 13e55cd
    success
Adam Tkac e51da31
    echo
Adam Tkac 13e55cd
    exit 0;
Adam Tkac e51da31
  fi;
Adam Tkac e51da31
Adam Tkac e51da31
  ckcf_options='-z'; # enable named-checkzone for each zone (9.3.1+) !
Adam Tkac e51da31
  if [ -n "${ROOTDIR}" -a "x${ROOTDIR}" != "x/" ]; then
Adam Tkac e51da31
    OPTIONS="${OPTIONS} -t ${ROOTDIR}"
Adam Tkac e51da31
    ckcf_options="$ckcf_options -t ${ROOTDIR}";
Adam Tkac e51da31
    [ -s /etc/localtime ] && cp -fp /etc/localtime ${ROOTDIR}/etc/localtime;
Adam Tkac e51da31
  fi
jvdias bc0ace6
Adam Tkac e51da31
  RETVAL=0
Adam Tkac e51da31
  # check if configuration is correct
Adam Tkac e51da31
  if [ -x /usr/sbin/named-checkconf ] && [ -x /usr/sbin/named-checkzone ] && /usr/sbin/named-checkconf $ckcf_options ${named_conf} >/dev/null 2>&1; then
Adam Tkac 7fdb7fd
Adam Tkac 15c5cd7
    daemon /usr/sbin/"$named" -u named ${OPTIONS};
Adam Tkac e51da31
    RETVAL=$?
Adam Tkac e51da31
    if [ $RETVAL -eq 0 ]; then
Adam Tkac 15c5cd7
      rm -f /var/run/{named,named-sdb}.pid;
Adam Tkac 15c5cd7
      ln -s $ROOTDIR/var/run/named/"$named".pid /var/run/"$named".pid;
Adam Tkac e51da31
    fi;
Adam Tkac e51da31
Adam Tkac 15c5cd7
    if [ -n "`/sbin/pidof -o %PPID "$named"`" ]; then
Adam Tkac e51da31
      # Verify that named actually started (JM 2006-10-04)
Adam Tkac 15c5cd7
      if [ ! -e $ROOTDIR/var/run/named/"$named".pid ]; then
Adam Tkac e51da31
      # If there is not a file containing the PID of the now running named daemon then create it (JM 2006-10-04)
Adam Tkac 15c5cd7
        echo `/sbin/pidof -o %PPID "$named"` > $ROOTDIR/var/run/named/"$named".pid;
Adam Tkac e51da31
      fi;
Adam Tkac e51da31
    fi;
Adam Tkac e51da31
  else
Adam Tkac e51da31
    named_err="`/usr/sbin/named-checkconf $ckcf_options $named_conf 2>&1`";	   
Adam Tkac e51da31
    echo
Adam Tkac e51da31
    echo "Error in named configuration:";
Adam Tkac e51da31
    echo "$named_err";
Adam Tkac e51da31
    failure
Adam Tkac e51da31
    echo
Adam Tkac e51da31
    [ -x /usr/bin/logger ] && echo "$named_err" | /usr/bin/logger -pdaemon.error -tnamed;
Adam Tkac 91895cf
    umount_chroot_conf
Adam Tkac e51da31
    exit 2;
Adam Tkac e51da31
  fi;
Adam Tkac 1c28622
  echo
Adam Tkac e51da31
  if [ $RETVAL -eq 0 ]; then
Adam Tkac e51da31
    touch /var/lock/subsys/named;
Adam Tkac e51da31
  else
Adam Tkac 91895cf
    umount_chroot_conf
Adam Tkac e51da31
    exit 7;
Adam Tkac e51da31
  fi
Adam Tkac e51da31
  return 0;
cvsdist 2f7f4bd
}
Adam Tkac e51da31
cvsdist 2f7f4bd
stop() {
Adam Tkac 13e55cd
  [ "$EUID" != "0" ] && exit 4
Adam Tkac 13e55cd
Adam Tkac e51da31
  # Stop daemons.
Adam Tkac 2be0bc6
  echo -n $"Stopping named: "
Adam Tkac e51da31
  [ -x /usr/sbin/rndc ] && /usr/sbin/rndc stop >/dev/null 2>&1;
Adam Tkac e51da31
  RETVAL=$?
Adam Tkac 72f5cc8
  # was rndc successful?
Adam Tkac 72f5cc8
  [ "$RETVAL" -eq 0 ] || killproc "$named" -TERM >/dev/null 2>&1
Adam Tkac 72f5cc8
Adam Tkac 72f5cc8
  timeout=0
Adam Tkac 72f5cc8
  RETVAL=0
Adam Tkac dd1c37e
  while /sbin/pidof -o %PPID "$named" >/dev/null; do
Adam Tkac 72f5cc8
    if [ $timeout -ge $NAMED_SHUTDOWN_TIMEOUT ]; then
Adam Tkac 72f5cc8
      RETVAL=1
Adam Tkac 72f5cc8
      break
Adam Tkac 72f5cc8
    else
Adam Tkac 72f5cc8
      sleep 2 && echo -n "."
Adam Tkac 72f5cc8
      timeout=$((timeout+2))
Adam Tkac 72f5cc8
    fi;
Adam Tkac 72f5cc8
  done
Adam Tkac e51da31
Adam Tkac 91895cf
  umount_chroot_conf
Adam Tkac 91895cf
Adam Tkac e51da31
  # remove pid files
Adam Tkac e51da31
  if [ $RETVAL -eq 0 ]; then
Adam Tkac e51da31
    rm -f /var/lock/subsys/named
Adam Tkac 15c5cd7
    rm -f /var/run/{named,named-sdb}.pid
Adam Tkac e51da31
  fi;
Adam Tkac e51da31
Adam Tkac e51da31
  if [ $RETVAL -eq 0 ]; then
Adam Tkac e51da31
    success
Adam Tkac e51da31
  else
Adam Tkac e51da31
    failure
Adam Tkac e51da31
    RETVAL=1
Adam Tkac e51da31
  fi;
Adam Tkac e51da31
  echo
Adam Tkac e51da31
  return $RETVAL
cvsdist 2f7f4bd
}
Adam Tkac e51da31
Adam Tkac e51da31
cvsdist 2f7f4bd
rhstatus() {
Adam Tkac e51da31
  [ -x /usr/sbin/rndc ] && /usr/sbin/rndc status;
Adam Tkac 15c5cd7
  status /usr/sbin/"$named";
Adam Tkac e51da31
  return $?
cvsdist 2f7f4bd
}	
cvsdist 2f7f4bd
restart() {
cvsdist 2f7f4bd
	stop
cvsdist 2f7f4bd
	start
cvsdist 2f7f4bd
}	
cvsdist 2f7f4bd
reload() {
Adam Tkac 13e55cd
        [ "$EUID" != "0" ] && exit 
Adam Tkac 13e55cd
Adam Tkac 15c5cd7
        echo -n $"Reloading "$named": "
Adam Tkac 15c5cd7
	p=`/sbin/pidof -o %PPID "$named"`
cvsdist d69ee3d
	RETVAL=$?
cvsdist d69ee3d
	if [ "$RETVAL" -eq 0 ]; then 
jvdias aad9089
	    /usr/sbin/rndc reload >/dev/null 2>&1 || /bin/kill -HUP $p;
cvsdist d69ee3d
	    RETVAL=$?
cvsdist d69ee3d
        fi
Adam Tkac 15c5cd7
	[ "$RETVAL" -eq 0 ] && success $"$named reload" || failure $"$named reload"
cvsdist 78e1f2e
        echo
Adam Tkac e51da31
	return $RETVAL
jvdias b7b41ad
}
cvsdist 2f7f4bd
cvsdist 2f7f4bd
# See how we were called.
cvsdist 2f7f4bd
case "$1" in
cvsdist 2f7f4bd
	start)
cvsdist 2f7f4bd
		start
cvsdist 2f7f4bd
		;;
cvsdist 2f7f4bd
	stop)
cvsdist 2f7f4bd
		stop
cvsdist 2f7f4bd
		;;
cvsdist 2f7f4bd
	status)
Adam Tkac e51da31
		rhstatus;
Adam Tkac e51da31
		RETVAL=$?
cvsdist 2f7f4bd
		;;
cvsdist 2f7f4bd
	restart)
cvsdist 2f7f4bd
		restart
cvsdist 2f7f4bd
		;;
Adam Tkac 13e55cd
	condrestart|try-restart)
Adam Tkac 969b1cb
		if [ -e /var/lock/subsys/named ]; then restart; fi
Adam Tkac 969b1cb
                ;;
cvsdist 2f7f4bd
	reload)
cvsdist 2f7f4bd
		reload
cvsdist 2f7f4bd
		;;
Adam Tkac 969b1cb
	force-reload)
Adam Tkac 969b1cb
		if ! reload; then restart; fi
Adam Tkac 969b1cb
		;;
cvsdist 2f7f4bd
	*)
Adam Tkac 969b1cb
        	echo $"Usage: $0 {start|stop|status|restart|try-restart|reload|force-reload}"
Adam Tkac 13e55cd
		[ "x$1" = "x" ] && exit 0
Adam Tkac 311ac6e
		exit 2
cvsdist 2f7f4bd
esac
cvsdist 2f7f4bd
Adam Tkac e51da31
exit $RETVAL
cvsdist 2f7f4bd