FreeBSD: separate rc script into xrdp and xrdp-sesman

to improve fscd(8)[1] compatibility. fscd(8) monitors daemons and
restarts after daemons crashed. We usually want to start, stop, and
restart xrdp and xrdp-sesman separately because restarting xrdp-sesman
means losing existing sessions. This change will enable fscd(8) not to
restart xrdp-sesman together when only xrdp daemon crashes.

Now rc.d/xrdp mainly has following commands:

* start      - starts xrdp
* stop       - stops xrdp
* restart    - stops xrdp, then starts it again
* allstart   - starts both xrdp and xrdp-sesman
* allstop    - stops both
* allrestart - stops both, then start them again
* status     - returns status of xrdp

rc.d/xrdp-sesman doesn't have all- prefixed commands.

[1] https://www.freshports.org/sysutils/fsc/
This commit is contained in:
Koichiro IWAO 2018-05-29 00:30:22 +09:00
parent 57015aa088
commit 72b5088449
No known key found for this signature in database
GPG Key ID: 9F72CDBC01BF10EB
4 changed files with 85 additions and 38 deletions

View File

@ -97,5 +97,6 @@ endif
if FREEBSD if FREEBSD
# must be tab below # must be tab below
install-data-hook: install-data-hook:
sed -i '' 's|%%PREFIX%%|$(prefix)|g' $(DESTDIR)$(sysconfdir)/rc.d/xrdp sed -i '' 's|%%PREFIX%%|$(prefix)|g' $(DESTDIR)$(sysconfdir)/rc.d/xrdp \
$(DESTDIR)$(sysconfdir)/rc.d/xrdp-sesman
endif endif

View File

@ -1,2 +1,2 @@
startscriptdir = $(sysconfdir)/rc.d startscriptdir = $(sysconfdir)/rc.d
dist_startscript_SCRIPTS = xrdp dist_startscript_SCRIPTS = xrdp xrdp-sesman

View File

@ -1,6 +1,7 @@
#!/bin/sh #!/bin/sh
# #
# Copyright (c) 1992-2015 The FreeBSD Project. All rights reserved. # Copyright (c) 1992-2018 The FreeBSD Project. All rights reserved.
# Copyright (c) 2015-2018 Koichiro Iwao <meta@FreeBSD.org>
# #
# Redistribution and use in source and binary forms, with or without # Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions # modification, are permitted provided that the following conditions
@ -26,55 +27,56 @@
# $FreeBSD$ # $FreeBSD$
# #
# REQUIRE: DAEMON # REQUIRE: DAEMON
# PROVIDE: xrdp xrdp_sesman # PROVIDE: xrdp
# #
# Add the following line to /etc/rc.conf to enable xrdp:
#
# xrdp_enable="YES"
# xrdp_sesman_enable="YES"
. /etc/rc.subr . /etc/rc.subr
name="xrdp" name="xrdp"
rcvar=xrdp_enable rcvar="xrdp_enable"
xrdp_daemons="xrdp"
# Read settings and set default values.
load_rc_config "$name" load_rc_config "$name"
: ${xrdp_enable="NO"} : ${xrdp_enable="NO"}
# Enable/disable dependent daemon. extra_commands="status allstart allstop allrestart"
if [ -n "${rcvar}" ] && checkyesno "xrdp_sesman_enable"; then command="%%PREFIX%%/sbin/xrdp"
xrdp_daemons="xrdp xrdp_sesman"
fi
# Commands. allstart_cmd="xrdp_allstart"
extra_commands="reload status" allstop_cmd="xrdp_allstop"
start_cmd="xrdp_cmd" allrestart_cmd="xrdp_allrestart"
stop_cmd="xrdp_cmd"
status_cmd="xrdp_cmd"
reload_cmd="xrdp_cmd"
rcvar_cmd="xrdp_cmd"
# Command wrapper to call each of them per daemon. xrdp_allstart()
xrdp_cmd() { {
local name rcvar command pidfile xrdp_daemons run_rc_command "start"
# Prevent recursive calling.
unset "${rc_arg}_cmd" if checkyesno "xrdp_sesman_enable" && \
# Stop processes in the reverse to order. ! %%PREFIX%%/etc/rc.d/xrdp-sesman forcestatus 1>/dev/null 2>&1; then
if [ "${rc_arg}" = "stop" ] ; then %%PREFIX%%/etc/rc.d/xrdp-sesman start || return 1
xrdp_daemons=$(reverse_list ${xrdp_daemons}) fi
}
xrdp_allstop()
{
if checkyesno "xrdp_sesman_enable" && \
%%PREFIX%%/etc/rc.d/xrdp-sesman forcestatus 1>/dev/null 2>&1; then
%%PREFIX%%/etc/rc.d/xrdp-sesman stop || return 1
fi fi
# Apply to all the daemons. run_rc_command "stop"
for name in ${xrdp_daemons}; do }
rcvar=${name}_enable
if [ "${name}" = "xrdp_sesman" ]; then xrdp_allrestart()
command="%%PREFIX%%/sbin/xrdp-sesman" {
pidfile="/var/run/xrdp-sesman.pid" if checkyesno "xrdp_sesman_enable" && \
else %%PREFIX%%/etc/rc.d/xrdp-sesman forcestatus 1>/dev/null 2>&1; then
command="%%PREFIX%%/sbin/${name}" %%PREFIX%%/etc/rc.d/xrdp-sesman restart || return 1
pidfile="/var/run/${name}.pid"
fi fi
run_rc_command "${_rc_prefix}${rc_arg}" ${rc_extra_args} run_rc_command "restart"
done
} }
run_rc_command "$1" run_rc_command "$1"

View File

@ -0,0 +1,44 @@
#!/bin/sh
#
# Copyright (c) 1992-2015 The FreeBSD Project. All rights reserved.
# Copyright (c) 2015-2018 Koichiro Iwao <meta@FreeBSD.org>
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions
# are met:
# 1. Redistributions of source code must retain the above copyright
# notice, this list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright
# notice, this list of conditions and the following disclaimer in the
# documentation and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
# SUCH DAMAGE.
#
# $FreeBSD$
#
# REQUIRE: LOGIN
# PROVIDE: xrdp_sesman
#
. /etc/rc.subr
name="xrdp_sesman"
rcvar="xrdp_sesman_enable"
load_rc_config "$name"
: ${xrdp_sesman_enable="NO"}
extra_commands="status"
command="%%PREFIX%%/sbin/xrdp-sesman"
run_rc_command "$1"