2008-02-27 20:29:32 +00:00
|
|
|
#!@SHELL@
|
2007-04-05 11:18:42 +00:00
|
|
|
# Shell wrapper for runscript
|
2007-11-14 15:22:04 +00:00
|
|
|
|
2009-05-01 15:11:40 +01:00
|
|
|
# Copyright (c) 2007-2009 Roy Marples <roy@marples.name>
|
2011-06-29 19:46:31 -04:00
|
|
|
# Released under the 2-clause BSD license.
|
2007-11-14 15:22:04 +00:00
|
|
|
|
2012-03-03 09:16:27 -06:00
|
|
|
verify_boot()
|
|
|
|
{
|
|
|
|
if [ ! -e ${RC_SVCDIR}/softlevel ]; then
|
|
|
|
eerror "You are attempting to run an openrc service on a"
|
|
|
|
eerror "system which openrc did not boot."
|
|
|
|
eerror "You may be inside a chroot or you may have used"
|
|
|
|
eerror "another initialization system to boot this system."
|
|
|
|
eerror "In this situation, you will get unpredictable results!"
|
|
|
|
eerror
|
|
|
|
eerror "If you really want to do this, issue the following command:"
|
|
|
|
eerror "touch ${RC_SVCDIR}/softlevel"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2011-01-08 14:25:32 -06:00
|
|
|
sourcex()
|
|
|
|
{
|
|
|
|
if [ "$1" = "-e" ]; then
|
|
|
|
shift
|
|
|
|
[ -e "$1" ] || return 1
|
|
|
|
fi
|
|
|
|
if ! . "$1"; then
|
|
|
|
eerror "$RC_SVCNAME: error loading $1"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2012-04-26 12:56:44 -05:00
|
|
|
sourcex "@LIBEXECDIR@/sh/functions.sh"
|
2011-11-02 08:16:52 -05:00
|
|
|
sourcex "@LIBEXECDIR@/sh/rc-functions.sh"
|
2013-02-03 16:01:16 -06:00
|
|
|
[ "$RC_SYS" != "PREFIX" ] && sourcex -e "@LIBEXECDIR@/sh/rc-cgroup.sh"
|
2011-11-02 08:16:52 -05:00
|
|
|
|
|
|
|
# Support LiveCD foo
|
|
|
|
if sourcex -e "/sbin/livecd-functions.sh"; then
|
|
|
|
livecd_read_commandline
|
|
|
|
fi
|
|
|
|
|
2007-11-20 10:24:40 +00:00
|
|
|
if [ -z "$1" -o -z "$2" ]; then
|
2009-04-26 21:13:26 +00:00
|
|
|
eerror "$RC_SVCNAME: not enough arguments"
|
2007-04-05 11:18:42 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
2008-03-11 15:00:16 +00:00
|
|
|
# So daemons know where to recall us if needed
|
2012-11-07 00:22:33 +00:00
|
|
|
RC_SERVICE="$1" ; export RC_SERVICE
|
2008-04-26 19:32:28 +00:00
|
|
|
shift
|
2008-03-11 15:00:16 +00:00
|
|
|
|
2008-03-19 19:57:24 +00:00
|
|
|
# Compat
|
2012-11-07 00:22:33 +00:00
|
|
|
SVCNAME=$RC_SVCNAME ; export SVCNAME
|
2008-03-19 19:57:24 +00:00
|
|
|
|
2009-09-04 16:00:08 +01:00
|
|
|
# Dependency function
|
|
|
|
config() {
|
|
|
|
[ -n "$*" ] && echo "config $*"
|
|
|
|
}
|
|
|
|
need() {
|
|
|
|
[ -n "$*" ] && echo "need $*"
|
|
|
|
}
|
|
|
|
use() {
|
|
|
|
[ -n "$*" ] && echo "use $*"
|
|
|
|
}
|
|
|
|
before() {
|
|
|
|
[ -n "$*" ] && echo "before $*"
|
|
|
|
}
|
|
|
|
after() {
|
|
|
|
[ -n "$*" ] && echo "after $*"
|
|
|
|
}
|
|
|
|
provide() {
|
|
|
|
[ -n "$*" ] && echo "provide $*"
|
|
|
|
}
|
|
|
|
keyword() {
|
|
|
|
[ -n "$*" ] && echo "keyword $*"
|
|
|
|
}
|
|
|
|
|
2011-10-16 19:02:21 -04:00
|
|
|
# Describe the init script to the user
|
2008-01-11 12:13:46 +00:00
|
|
|
describe()
|
|
|
|
{
|
2009-04-26 21:13:26 +00:00
|
|
|
if [ -n "$description" ]; then
|
|
|
|
einfo "$description"
|
2007-07-10 19:09:41 +00:00
|
|
|
else
|
2009-04-26 21:13:26 +00:00
|
|
|
ewarn "No description for $RC_SVCNAME"
|
2007-07-10 19:09:41 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
local svc= desc=
|
2011-10-17 13:47:45 -05:00
|
|
|
for svc in ${extra_commands:-$opts} $extra_started_commands \
|
|
|
|
$extra_stopped_commands; do
|
2009-04-26 21:13:26 +00:00
|
|
|
eval desc=\$description_$svc
|
|
|
|
if [ -n "$desc" ]; then
|
|
|
|
einfo "$HILITE$svc$NORMAL: $desc"
|
2007-07-10 19:09:41 +00:00
|
|
|
else
|
2009-04-26 21:13:26 +00:00
|
|
|
ewarn "$HILITE$svc$NORMAL: no description"
|
2007-07-10 19:09:41 +00:00
|
|
|
fi
|
|
|
|
done
|
|
|
|
}
|
|
|
|
|
2009-04-18 00:09:03 +00:00
|
|
|
# Report status
|
2009-04-18 10:39:53 +00:00
|
|
|
_status()
|
2009-04-18 00:09:03 +00:00
|
|
|
{
|
|
|
|
if service_stopping; then
|
|
|
|
ewarn "status: stopping"
|
|
|
|
return 4
|
|
|
|
elif service_starting; then
|
|
|
|
ewarn "status: starting"
|
|
|
|
return 8
|
|
|
|
elif service_inactive; then
|
|
|
|
ewarn "status: inactive"
|
|
|
|
return 16
|
|
|
|
elif service_started; then
|
|
|
|
if service_crashed; then
|
|
|
|
eerror "status: crashed"
|
|
|
|
return 32
|
|
|
|
fi
|
|
|
|
einfo "status: started"
|
|
|
|
return 0
|
|
|
|
else
|
|
|
|
einfo "status: stopped"
|
2011-01-12 19:46:11 -06:00
|
|
|
return 3
|
2009-04-18 00:09:03 +00:00
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
2009-04-18 10:39:53 +00:00
|
|
|
# Template start / stop / status functions
|
2008-04-26 19:32:28 +00:00
|
|
|
start()
|
|
|
|
{
|
2009-04-26 21:13:26 +00:00
|
|
|
[ -n "$command" ] || return 0
|
2008-04-26 19:32:28 +00:00
|
|
|
local _background=
|
2009-04-26 21:13:26 +00:00
|
|
|
ebegin "Starting ${name:-$RC_SVCNAME}"
|
2011-01-17 04:49:07 -05:00
|
|
|
if yesno "${command_background}"; then
|
2012-01-17 18:23:56 +01:00
|
|
|
if [ -z "${pidfile}" ]; then
|
|
|
|
eend 1 "command_background option used but no pidfile specified"
|
|
|
|
return 1
|
|
|
|
fi
|
2012-01-17 12:04:20 -06:00
|
|
|
_background="--background --make-pidfile"
|
2008-04-26 19:32:28 +00:00
|
|
|
fi
|
2009-04-26 21:13:26 +00:00
|
|
|
if yesno "$start_inactive"; then
|
2008-04-26 19:32:28 +00:00
|
|
|
local _inactive=false
|
|
|
|
service_inactive && _inactive=true
|
|
|
|
mark_service_inactive
|
|
|
|
fi
|
2009-05-26 22:36:53 +01:00
|
|
|
eval start-stop-daemon --start \
|
2009-04-26 21:13:26 +00:00
|
|
|
--exec $command \
|
2014-10-19 19:36:57 -05:00
|
|
|
${chroot:+--chroot} $chroot \
|
2009-04-26 21:13:26 +00:00
|
|
|
${procname:+--name} $procname \
|
|
|
|
${pidfile:+--pidfile} $pidfile \
|
|
|
|
$_background $start_stop_daemon_args \
|
|
|
|
-- $command_args
|
2013-01-15 12:14:05 -06:00
|
|
|
if eend $? "Failed to start $RC_SVCNAME"; then
|
|
|
|
service_set_value "command" "${command}"
|
2014-10-19 19:36:57 -05:00
|
|
|
[ -n "${chroot}" ] && service_set_value "chroot" "${chroot}"
|
2013-01-15 12:14:05 -06:00
|
|
|
[ -n "${pidfile}" ] && service_set_value "pidfile" "${pidfile}"
|
|
|
|
[ -n "${procname}" ] && service_set_value "procname" "${procname}"
|
|
|
|
return 0
|
|
|
|
fi
|
2009-04-26 21:13:26 +00:00
|
|
|
if yesno "$start_inactive"; then
|
|
|
|
if ! $_inactive; then
|
2008-04-26 19:32:28 +00:00
|
|
|
mark_service_stopped
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
return 1
|
|
|
|
}
|
|
|
|
|
|
|
|
stop()
|
|
|
|
{
|
2013-01-15 12:36:12 -06:00
|
|
|
local startcommand="$(service_get_value "command")"
|
2014-10-19 19:36:57 -05:00
|
|
|
local startchroot="$(service_get_value "chroot")"
|
2013-01-15 12:36:12 -06:00
|
|
|
local startpidfile="$(service_get_value "pidfile")"
|
|
|
|
local startprocname="$(service_get_value "procname")"
|
2013-01-15 12:14:05 -06:00
|
|
|
command="${startcommand:-$command}"
|
2014-10-19 19:36:57 -05:00
|
|
|
chroot="${startchroot:-$chroot}"
|
2013-01-15 12:14:05 -06:00
|
|
|
pidfile="${startpidfile:-$pidfile}"
|
|
|
|
procname="${startprocname:-$procname}"
|
2009-04-26 21:13:26 +00:00
|
|
|
[ -n "$command" -o -n "$procname" -o -n "$pidfile" ] || return 0
|
|
|
|
ebegin "Stopping ${name:-$RC_SVCNAME}"
|
2008-04-26 19:32:28 +00:00
|
|
|
start-stop-daemon --stop \
|
2011-12-31 02:41:59 +01:00
|
|
|
${retry:+--retry} $retry \
|
2009-04-26 21:13:26 +00:00
|
|
|
${command:+--exec} $command \
|
|
|
|
${procname:+--name} $procname \
|
2014-10-19 19:36:57 -05:00
|
|
|
${pidfile:+--pidfile} $chroot$pidfile \
|
2009-04-27 13:32:13 +00:00
|
|
|
${stopsig:+--signal} $stopsig
|
2009-04-26 21:13:26 +00:00
|
|
|
eend $? "Failed to stop $RC_SVCNAME"
|
2008-04-26 19:32:28 +00:00
|
|
|
}
|
|
|
|
|
2009-04-18 10:39:53 +00:00
|
|
|
status()
|
|
|
|
{
|
|
|
|
_status
|
|
|
|
}
|
|
|
|
|
2009-04-26 21:13:26 +00:00
|
|
|
yesno $RC_DEBUG && set -x
|
2014-09-11 12:02:51 -05:00
|
|
|
if yesno "${rc_verbose:-$RC_VERBOSE}"; then
|
|
|
|
EINFO_VERBOSE=yes
|
|
|
|
export EINFO_VERBOSE
|
|
|
|
fi
|
2007-04-05 11:18:42 +00:00
|
|
|
|
2011-12-11 01:18:08 -06:00
|
|
|
_conf_d=${RC_SERVICE%/*}/../conf.d
|
|
|
|
# If we're net.eth0 or openvpn.work then load net or openvpn config
|
|
|
|
_c=${RC_SVCNAME%%.*}
|
|
|
|
if [ -n "$_c" -a "$_c" != "$RC_SVCNAME" ]; then
|
|
|
|
if ! sourcex -e "$_conf_d/$_c.$RC_RUNLEVEL"; then
|
|
|
|
sourcex -e "$_conf_d/$_c"
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
unset _c
|
|
|
|
|
|
|
|
# Overlay with our specific config
|
|
|
|
if ! sourcex -e "$_conf_d/$RC_SVCNAME.$RC_RUNLEVEL"; then
|
|
|
|
sourcex -e "$_conf_d/$RC_SVCNAME"
|
2007-04-05 11:18:42 +00:00
|
|
|
fi
|
2011-12-11 01:18:08 -06:00
|
|
|
unset _conf_d
|
2007-04-05 11:18:42 +00:00
|
|
|
|
|
|
|
# Load any system overrides
|
2011-01-08 14:25:32 -06:00
|
|
|
sourcex -e "@SYSCONFDIR@/rc.conf"
|
2007-04-05 11:18:42 +00:00
|
|
|
|
2014-09-11 13:26:58 -05:00
|
|
|
for _cmd; do
|
|
|
|
if [ "$_cmd" != status -a "$_cmd" != describe ]; then
|
|
|
|
# Apply any ulimit defined
|
|
|
|
[ -n "${rc_ulimit:-$RC_ULIMIT}" ] && \
|
|
|
|
ulimit ${rc_ulimit:-$RC_ULIMIT}
|
|
|
|
# Apply cgroups settings if defined
|
|
|
|
if [ "$(command -v cgroup_add_service)" = \
|
|
|
|
"cgroup_add_service" ]
|
|
|
|
then
|
|
|
|
if [ -d /sys/fs/cgroup -a ! -w /sys/fs/cgroup ]; then
|
|
|
|
eerror "No permission to apply cgroup settings"
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
cgroup_add_service /sys/fs/cgroup/openrc
|
|
|
|
cgroup_add_service /sys/fs/cgroup/systemd/system
|
|
|
|
fi
|
|
|
|
[ "$(command -v cgroup_set_limits)" = \
|
|
|
|
"cgroup_set_limits" ] && \
|
|
|
|
cgroup_set_limits
|
|
|
|
break
|
2014-07-10 05:18:00 -05:00
|
|
|
fi
|
2014-09-11 13:26:58 -05:00
|
|
|
done
|
|
|
|
|
2007-04-05 11:18:42 +00:00
|
|
|
# Load our script
|
2011-01-08 14:25:32 -06:00
|
|
|
sourcex "$RC_SERVICE"
|
2007-04-05 11:18:42 +00:00
|
|
|
|
2009-04-26 21:13:26 +00:00
|
|
|
for _d in $required_dirs; do
|
|
|
|
if [ ! -d $_d ]; then
|
|
|
|
eerror "$RC_SVCNAME: \`$_d' is not a directory"
|
2007-11-28 13:08:25 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
unset _d
|
|
|
|
|
2009-04-26 21:13:26 +00:00
|
|
|
for _f in $required_files; do
|
|
|
|
if [ ! -r $_f ]; then
|
|
|
|
eerror "$RC_SVCNAME: \`$_f' is not readable"
|
2007-11-28 13:08:25 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
unset _f
|
|
|
|
|
2011-07-26 12:19:59 -05:00
|
|
|
if [ -n "$opts" ]; then
|
|
|
|
ewarn "Use of the opts variable is deprecated and will be"
|
|
|
|
ewarn "removed in the future."
|
2011-10-17 13:47:45 -05:00
|
|
|
ewarn "Please use extra_commands, extra_started_commands or extra_stopped_commands."
|
2011-07-26 12:19:59 -05:00
|
|
|
fi
|
|
|
|
|
2007-11-20 10:24:40 +00:00
|
|
|
while [ -n "$1" ]; do
|
2011-10-16 19:02:21 -04:00
|
|
|
# Special case depend
|
2010-02-20 21:48:06 +00:00
|
|
|
if [ "$1" = depend ]; then
|
|
|
|
shift
|
2012-04-26 12:19:42 -05:00
|
|
|
|
|
|
|
# Enter the dir of the init script to fix the globbing
|
|
|
|
# bug 412677
|
|
|
|
cd ${RC_SERVICE%/*}
|
2010-02-20 21:48:06 +00:00
|
|
|
_depend
|
2012-04-26 12:19:42 -05:00
|
|
|
cd /
|
2010-02-20 21:48:06 +00:00
|
|
|
continue
|
|
|
|
fi
|
2007-04-05 11:18:42 +00:00
|
|
|
# See if we have the required function and run it
|
2010-02-20 21:48:06 +00:00
|
|
|
for _cmd in describe start stop status ${extra_commands:-$opts} \
|
2011-10-17 13:47:45 -05:00
|
|
|
$extra_started_commands $extra_stopped_commands
|
2009-04-26 21:13:26 +00:00
|
|
|
do
|
|
|
|
if [ "$_cmd" = "$1" ]; then
|
2008-04-21 17:32:17 +00:00
|
|
|
if [ "$(command -v "$1")" = "$1" ]; then
|
2008-01-11 12:13:46 +00:00
|
|
|
# If we're in the background, we may wish to
|
|
|
|
# fake some commands. We do this so we can
|
|
|
|
# "start" ourselves from inactive which then
|
2009-04-26 21:13:26 +00:00
|
|
|
# triggers other services to start which
|
|
|
|
# depend on us.
|
|
|
|
# A good example of this is openvpn.
|
|
|
|
if yesno $IN_BACKGROUND; then
|
|
|
|
for _cmd in $in_background_fake; do
|
|
|
|
if [ "$_cmd" = "$1" ]; then
|
2007-11-28 13:08:25 +00:00
|
|
|
shift
|
|
|
|
continue 3
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
fi
|
2008-01-11 12:13:46 +00:00
|
|
|
# Check to see if we need to be started before
|
|
|
|
# we can run this command
|
2009-04-26 21:13:26 +00:00
|
|
|
for _cmd in $extra_started_commands; do
|
|
|
|
if [ "$_cmd" = "$1" ]; then
|
2012-03-03 09:16:27 -06:00
|
|
|
if verify_boot && ! service_started; then
|
2009-04-26 21:13:26 +00:00
|
|
|
eerror "$RC_SVCNAME: cannot \`$1' as it has not been started"
|
2007-11-29 16:23:59 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
2011-10-17 13:47:45 -05:00
|
|
|
# Check to see if we need to be stopped before
|
|
|
|
# we can run this command
|
|
|
|
for _cmd in $extra_stopped_commands; do
|
|
|
|
if [ "$_cmd" = "$1" ]; then
|
2012-03-03 09:16:27 -06:00
|
|
|
if verify_boot && ! service_stopped; then
|
2011-10-17 13:47:45 -05:00
|
|
|
eerror "$RC_SVCNAME: cannot \`$1' as it has not been stopped"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
fi
|
|
|
|
done
|
2007-11-28 13:08:25 +00:00
|
|
|
unset _cmd
|
2012-03-03 09:16:27 -06:00
|
|
|
case $1 in
|
|
|
|
start|stop|status) verify_boot;;
|
|
|
|
esac
|
2009-04-26 21:13:26 +00:00
|
|
|
if [ "$(command -v "$1_pre")" = "$1_pre" ]
|
|
|
|
then
|
2007-11-20 10:24:40 +00:00
|
|
|
"$1"_pre || exit $?
|
|
|
|
fi
|
2007-04-05 11:18:42 +00:00
|
|
|
"$1" || exit $?
|
2009-04-26 21:13:26 +00:00
|
|
|
if [ "$(command -v "$1_post")" = "$1_post" ]
|
|
|
|
then
|
2007-11-20 10:24:40 +00:00
|
|
|
"$1"_post || exit $?
|
|
|
|
fi
|
2013-05-25 21:04:10 -05:00
|
|
|
[ "$(command -v cgroup_cleanup)" = "cgroup_cleanup" -a \
|
|
|
|
"$1" = "stop" ] && \
|
2013-09-25 20:05:41 -05:00
|
|
|
yesno "${rc_cgroup_cleanup}" && \
|
2013-04-16 09:52:33 +04:00
|
|
|
cgroup_cleanup
|
2007-04-05 11:18:42 +00:00
|
|
|
shift
|
|
|
|
continue 2
|
|
|
|
else
|
2009-04-26 21:13:26 +00:00
|
|
|
if [ "$_cmd" = "start" -o "$_cmd" = "stop" ]
|
|
|
|
then
|
2008-01-26 16:46:53 +00:00
|
|
|
shift
|
|
|
|
continue 2
|
2007-04-05 11:18:42 +00:00
|
|
|
else
|
2009-04-26 21:13:26 +00:00
|
|
|
eerror "$RC_SVCNAME: function \`$1' defined but does not exist"
|
2007-04-05 11:18:42 +00:00
|
|
|
exit 1
|
|
|
|
fi
|
2011-01-17 04:49:07 -05:00
|
|
|
fi
|
2007-04-05 11:18:42 +00:00
|
|
|
fi
|
|
|
|
done
|
2009-04-26 21:13:26 +00:00
|
|
|
eerror "$RC_SVCNAME: unknown function \`$1'"
|
2007-04-05 11:18:42 +00:00
|
|
|
exit 1
|
|
|
|
done
|
2011-11-12 22:19:55 +01:00
|
|
|
|
|
|
|
exit 0
|