#!/bin/sh
#
# $FreeBSD: branches/2018Q4/dns/knot2/files/knot.in 416499 2016-06-07 08:00:17Z pi $
#
# PROVIDE: knot
# REQUIRE: SERVERS cleanvar
# KEYWORD: shutdown
#
# Add the following lines to /etc/rc.conf to enable knot:
#
# knot_enable="YES":	Set to NO by default.
#			Set it to YES to enable knot.
# knot_config="":	Set to /usr/local/etc/knot/knot.conf
#			by default.
#
# -----------------------------------------------------------------------------
#
# This script supports running multiple instances of knot.
# To run additional instances link this script to something like
# % ln -s knot knot_foo
# and define additional knot_foo_* variables in one of
# /etc/rc.conf, /etc/rc.conf.local or /etc/rc.conf.d/knot_foo
#
# Below NAME should be substituted with the name of this script. By default
# it is knot, so read as knot_enable. If you linked the script to
# knot_foo, then read as knot_foo_enable etc.
#
# The following variables are supported (defaults are shown).
# You can place them in any of
# /etc/rc.conf, /etc/rc.conf.local or /etc/rc.conf.d/NAME
#
# NAME_enable="NO"	# set to YES to enable knot
#
# # optional:
# NAME_config="/usr/local/etc/knot/NAME.conf"  # (-c)onfig file
# NAME_diruser="knot"   # /var/db/NAME and /var/run/NAME are created if they
# NAME_dirgroup="knot"  # don't exist. These don't control the user/group knot
#                       # runs as, the config file has a setting for that.
#
# You also need to set the rundir directive in the server section of the
# config file to /var/run/NAME (if using a NAME other than the default)
# and you will want the storage directive(s) declared in the zone section
# to point to /var/db/NAME overriding the default of /var/db/knot.
#
# For further documentation, please see knot.conf(5).

. /etc/rc.subr

case "$0" in
/etc/rc*)
	# during boot (shutdown) $0 is /etc/rc (/etc/rc.shutdown),
	# so get the name of the script from $_file
	name="$_file"
	;;
*)
	name="$0"
	;;
esac

name="${name##*/}"
rcvar=${name}_enable

load_rc_config ${name}

eval ": \${${name}_enable:=\"NO\"}"
eval ": \${${name}_diruser:=\"knot\"}"
eval ": \${${name}_dirgroup:=\"knot\"}"
eval ": \${${name}_config:=\"/usr/local/etc/knot/${name}.conf\"}"

configfile="$(eval echo \${${name}_config})"
diruser="$(eval echo \${${name}_diruser})"
dirgroup="$(eval echo \${${name}_dirgroup})"

command=/usr/local/sbin/knotd
command_args="-c ${configfile} -d"
control=/usr/local/sbin/knotc
pidfile=/var/run/${name}/knot.pid

required_files=${configfile}

extra_commands=reload
reload_cmd="knot_reload"
start_precmd="knot_prestart"

knot_prestart()
{
	if [ ! -d /var/run/${name} ]; then
		install -d -o ${diruser} -g ${dirgroup} /var/run/${name}
	fi
	if [ ! -d /var/db/${name} ]; then
		install -d -o ${diruser} -g ${dirgroup} /var/db/${name}
	fi
	${control} -c ${configfile} conf-check
}

knot_reload()
{
	echo "Reloading ${name}."
	${control} -c ${configfile} reload
}

run_rc_command "$1"
