2016-02-01 12:42:58 -06:00
|
|
|
# start / stop / status functions for supervise-daemon
|
|
|
|
|
|
|
|
# Copyright (c) 2016 The OpenRC Authors.
|
|
|
|
# See the Authors file at the top-level directory of this distribution and
|
|
|
|
# https://github.com/OpenRC/openrc/blob/master/AUTHORS
|
|
|
|
#
|
|
|
|
# This file is part of OpenRC. It is subject to the license terms in
|
|
|
|
# the LICENSE file found in the top-level directory of this
|
|
|
|
# distribution and at https://github.com/OpenRC/openrc/blob/master/LICENSE
|
|
|
|
# This file may not be copied, modified, propagated, or distributed
|
|
|
|
# except according to the terms contained in the LICENSE file.
|
|
|
|
|
|
|
|
supervise_start()
|
|
|
|
{
|
|
|
|
if [ -z "$command" ]; then
|
|
|
|
ewarn "The command variable is undefined."
|
|
|
|
ewarn "There is nothing for ${name:-$RC_SVCNAME} to start."
|
|
|
|
return 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
ebegin "Starting ${name:-$RC_SVCNAME}"
|
2016-09-20 11:23:46 -05:00
|
|
|
# The eval call is necessary for cases like:
|
|
|
|
# command_args="this \"is a\" test"
|
|
|
|
# to work properly.
|
2017-10-27 19:22:09 -05:00
|
|
|
eval supervise-daemon "${RC_SVCNAME}" --start \
|
2017-09-06 13:22:30 -05:00
|
|
|
${retry:+--retry} $retry \
|
2016-05-19 17:59:40 -05:00
|
|
|
${chroot:+--chroot} $chroot \
|
2016-02-01 12:42:58 -06:00
|
|
|
${pidfile:+--pidfile} $pidfile \
|
2017-05-10 18:01:10 -05:00
|
|
|
${respawn_delay:+--respawn-delay} $respawn_delay \
|
|
|
|
${respawn_max:+--respawn-max} $respawn_max \
|
|
|
|
${respawn_period:+--respawn-period} $respawn_period \
|
2016-02-01 12:42:58 -06:00
|
|
|
${command_user+--user} $command_user \
|
|
|
|
$supervise_daemon_args \
|
|
|
|
$command \
|
|
|
|
-- $command_args $command_args_foreground
|
|
|
|
rc=$?
|
2016-05-19 17:59:40 -05:00
|
|
|
if [ $rc = 0 ]; then
|
|
|
|
[ -n "${chroot}" ] && service_set_value "chroot" "${chroot}"
|
|
|
|
[ -n "${pidfile}" ] && service_set_value "pidfile" "${pidfile}"
|
|
|
|
fi
|
2016-09-13 12:27:08 -05:00
|
|
|
eend $rc "failed to start ${name:-$RC_SVCNAME}"
|
2016-02-01 12:42:58 -06:00
|
|
|
}
|
|
|
|
|
|
|
|
supervise_stop()
|
|
|
|
{
|
2016-05-19 17:59:40 -05:00
|
|
|
local startchroot="$(service_get_value "chroot")"
|
2016-02-01 12:42:58 -06:00
|
|
|
local startpidfile="$(service_get_value "pidfile")"
|
2016-05-19 17:59:40 -05:00
|
|
|
chroot="${startchroot:-$chroot}"
|
2016-02-01 12:42:58 -06:00
|
|
|
pidfile="${startpidfile:-$pidfile}"
|
|
|
|
[ -n "$pidfile" ] || return 0
|
|
|
|
ebegin "Stopping ${name:-$RC_SVCNAME}"
|
2017-10-27 19:22:09 -05:00
|
|
|
supervise-daemon "${RC_SVCNAME}" --stop \
|
2016-05-19 17:59:40 -05:00
|
|
|
${pidfile:+--pidfile} $chroot$pidfile \
|
2016-02-01 12:42:58 -06:00
|
|
|
${stopsig:+--signal} $stopsig
|
|
|
|
|
2016-09-13 12:27:08 -05:00
|
|
|
eend $? "Failed to stop ${name:-$RC_SVCNAME}"
|
2016-02-01 12:42:58 -06:00
|
|
|
}
|
|
|
|
|
2017-10-25 15:07:19 -05:00
|
|
|
_check_supervised()
|
|
|
|
{
|
2017-10-26 13:11:12 -05:00
|
|
|
local child_pid start_time
|
|
|
|
child_pid="$(service_get_value "child_pid")"
|
|
|
|
start_time="$(service_get_value "start_time")"
|
|
|
|
if [ -n "${child_pid}" ] && [ -n "${start_time}" ]; then
|
|
|
|
return 1
|
2017-10-25 15:07:19 -05:00
|
|
|
fi
|
|
|
|
return 0
|
|
|
|
}
|
|
|
|
|
2016-02-01 12:42:58 -06:00
|
|
|
supervise_status()
|
|
|
|
{
|
2017-10-25 15:07:19 -05: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
|
|
|
|
if ! _check_supervised; then
|
|
|
|
eerror "status: unsupervised"
|
|
|
|
return 64
|
|
|
|
fi
|
|
|
|
eerror "status: crashed"
|
|
|
|
return 32
|
|
|
|
fi
|
|
|
|
einfo "status: started"
|
|
|
|
return 0
|
|
|
|
else
|
|
|
|
einfo "status: stopped"
|
|
|
|
return 3
|
|
|
|
fi
|
2016-02-01 12:42:58 -06:00
|
|
|
}
|