You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gentoo-overlay/net-dns/opendnssec/files/opendnssec.initd

86 lines
1.8 KiB

#!/sbin/openrc-run
# Copyright 1999-2014 Gentoo Foundation
# Distributed under the terms of the GNU General Public License v2
description="An open-source turn-key solution for DNSSEC"
depend() {
use logger
}
checkconfig() {
if [ -x "${CHECKCONFIG_BIN}" ]; then
output=$(${CHECKCONFIG_BIN} 2>&1| grep -v -E "^/etc/opendnssec/(conf|kasp).xml validates")
if [ -n "$output" ]; then
echo $output
fi
errors=$(echo $output | grep ERROR | wc -l)
if [ $errors -gt 0 ]; then
ewarn "$errors error(s) found in OpenDNSSEC configuration."
fi
return $errors
fi
eerror "Unable to execute ${CHECKCONFIG_BIN:-config binary}"
# can't validate config, just die
return 1
}
start_enforcer() {
if [ -n "${ENFORCER_BIN}" ] && [ -x "${ENFORCER_BIN}" ]; then
ebegin "Starting OpenDNSSEC Enforcer"
${CONTROL_BIN} enforcer start > /dev/null
eend $?
else
if [ -n "${ENFORCER_BIN}" ]; then
eerror "OpenDNSSEC Enforcer binary not executable"
return 1
fi
einfo "OpenDNSSEC Enforcer not used."
fi
}
stop_enforcer() {
if [ -x "${ENFORCER_BIN}" ]; then
ebegin "Stopping OpenDNSSEC Enforcer"
${CONTROL_BIN} enforcer stop > /dev/null
eend $?
fi
}
start_signer() {
if [ -n "${SIGNER_BIN}" ] && [ -x "${SIGNER_BIN}" ]; then
ebegin "Starting OpenDNSSEC Signer"
${CONTROL_BIN} signer start > /dev/null 2>&1
eend $?
else
if [ -n "${SIGNER_BIN}" ]; then
eerror "OpenDNSSEC Signer binary not executable"
return 1
fi
einfo "OpenDNSSEC Signer not used."
fi
}
stop_signer() {
if [ -x "${SIGNER_BIN}" ]; then
ebegin "Stopping OpenDNSSEC Signer"
${CONTROL_BIN} signer stop > /dev/null 2>&1
eend $?
fi
}
start() {
checkconfig || return $?
checkpath -d -m 0755 -o opendnssec:opendnssec /run/opendnssec
start_enforcer || return $?
start_signer || return $?
}
stop() {
stop_signer
stop_enforcer
sleep 5
}