#!@PREFIX@/sbin/runscript
# Copyright (c) 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.

command=/usr/sbin/named
command_args=$named_args
pidfile=@VARBASE@/run/named.pid
name="Domain Name server"
extra_started_commands="reload"

namedb=/etc/namedb
uid=named
case "$RC_UNAME" in
	FreeBSD)
		uid=bind
		pidfile=@VARBASE@/run/named/pid
		;;
	Linux)
		uid=bind
		;;
esac
: ${named_uid:=${uid}}

depend()
{
	provide dns
	need localmount
	after bootmisc
}

start_pre()
{
	if [ -n "$named_chroot" ]; then
		# Create (or update) the chroot directory structure
		if [ -r /etc/mtree/BIND.chroot.dist ]; then
			mtree -deU -f /etc/mtree/BIND.chroot.dist -p "$named_chroot"
		else
			ewarn "/etc/mtree/BIND.chroot.dist missing,"
			ewarn "chroot directory structure not updated"
		fi

		if [ ! -d "$named_chroot"/. ]; then
			eerror "chroot directory $named_chroot missing"
			exit 1
		fi

		# Create /etc/namedb symlink
		if [ ! -L "$namedb" ]; then
			if [ -d "$namedb" ]; then
				ewarn "named chroot: $namedb is a directory!"
			elif [ -e "$namedb" ]; then
				ewarn "named chroot: $namedb exists!"
			else
				ln -s "$named_chroot$namedb" "$namedb"
			fi
		else
			# Make sure it points to the right place.
			ln -shf "$named_chroot$namedb" "$namedb"
		fi

		case "$RC_UNAME" in
			*BSD|DragonFly)
				# Mount a devfs in the chroot directory if needed
				umount "$named_chroot"/dev 2>/dev/null
				mount -t devfs dev "$named_chroot"/dev
				devfs -m "$named_chroot"/dev \
					ruleset devfsrules_hide_all
				devfs -m "$named_chroot"/dev \
					rule apply path null unhide
				devfs -m "$named_chroot"/dev \
					rule apply path random unhide
				;;
		esac

		# Copy local timezone information if it is not up to date.
		if [ -r /etc/localtime ]; then
			cmp -s /etc/localtime "$named_chroot/etc/localtime" ||
			cp -p /etc/localtime "$named_chroot/etc/localtime"
		fi

		command_args="$command_args -t $named_chroot"

		ln -fs "$named_chroot$pidfile" "$pidfile"
	fi

	if [ ! -s "$named_chroot$namedb/rndc.conf" ]; then
		local confgen="${command%/named}/rndc-confgen -a -b256 -u $named_uid \
			-c $named_chrootdir/etc/namedb/rndc.key"
		if [ -s "$named_chroot$namedb/rndc.key" ]; then
			local getuser="stat -f%Su"
			[ "$RC_UNAME" = Linux ] && getuser="stat -c%U"
			case $(${getuser} "$named_chroot$namedb"/rndc.key) in
				root|"$named_uid");;
				*) $confgen;;
			esac
		else
			$confgen
		fi
	fi
}

reload()
{
	rndc reload
}

stop_post()
{
	if [ -n "$named_chroot" -a -c "$named_chroot"/dev/null ]; then
		umount "$named_chroot"/dev 2>/dev/null || true
	fi
}