Fix startup script issue with a wrapper script obtained from www/gatling.
This wrapper tries to emulate part of the functionality usually supplied by software like daemontools or runit. It is used to start socat which does not daemonize itself and logs to stdout/stderr. It redirects stdout and stderr to logger(1) via a fifo. While here also remove if-statement around PORTDOCS based on NOPORTDOCS since it's redundant with checks in ports/Mk/bsd.ports.mk. PR: 166947 Submitted by: Mark Felder <feld@feld.me>
This commit is contained in:
parent
418d775723
commit
5bfdda4b31
Notes:
svn2git
2021-03-31 03:12:20 +00:00
svn path=/head/; revision=294820
3 changed files with 106 additions and 12 deletions
|
@ -7,6 +7,7 @@
|
|||
|
||||
PORTNAME= socat
|
||||
PORTVERSION= 1.7.2.0
|
||||
PORTREVISION= 1
|
||||
CATEGORIES= net ipv6
|
||||
MASTER_SITES= http://www.dest-unreach.org/socat/download/ \
|
||||
CRITICAL
|
||||
|
@ -25,18 +26,18 @@ MAKE_JOBS_SAFE= yes
|
|||
PORTSCOUT= skipv:2.0.0-b2
|
||||
|
||||
MAN1= socat.1
|
||||
PLIST_FILES= bin/filan bin/procan bin/socat
|
||||
|
||||
.include <bsd.port.pre.mk>
|
||||
|
||||
.if !defined(NOPORTDOCS)
|
||||
PLIST_FILES= bin/filan bin/procan bin/socat sbin/socat_wrapper
|
||||
PORTDOCS= EXAMPLES README SECURITY FAQ
|
||||
.endif
|
||||
|
||||
post-install:
|
||||
do-install:
|
||||
.for f in filan procan socat
|
||||
${INSTALL_PROGRAM} ${WRKSRC}/${f} ${PREFIX}/bin
|
||||
.endfor
|
||||
${INSTALL_SCRIPT} ${FILESDIR}/socat_wrapper ${PREFIX}/sbin
|
||||
${INSTALL_MAN} ${WRKSRC}/doc/${MAN1} ${MAN1PREFIX}/man/man1
|
||||
.if !defined(NOPORTDOCS)
|
||||
@${MKDIR} ${DOCSDIR}
|
||||
${MKDIR} ${DOCSDIR}
|
||||
cd ${WRKSRC} && ${INSTALL_DATA} ${PORTDOCS} ${DOCSDIR}
|
||||
.endif
|
||||
|
||||
.include <bsd.port.post.mk>
|
||||
.include <bsd.port.mk>
|
||||
|
|
|
@ -18,11 +18,13 @@
|
|||
name="socat"
|
||||
rcvar=socat_enable
|
||||
|
||||
command=%%PREFIX%%/bin/${name}
|
||||
command_args="&"
|
||||
|
||||
load_rc_config $name
|
||||
|
||||
: ${socat_enable="NO"}
|
||||
|
||||
socat_flags="%%PREFIX%%/bin/socat ${socat_flags} &"
|
||||
command="%%PREFIX%%/sbin/socat_wrapper"
|
||||
command_interpreter="/bin/sh -T"
|
||||
pidfile=/var/run/socat_wrapper.pid
|
||||
|
||||
run_rc_command "$1"
|
||||
|
|
91
net/socat/files/socat_wrapper
Normal file
91
net/socat/files/socat_wrapper
Normal file
|
@ -0,0 +1,91 @@
|
|||
#!/bin/sh -T
|
||||
#
|
||||
#-
|
||||
# Copyright 2009 Thomas-Martin Seck. All rights reserved.
|
||||
#
|
||||
# Redistribution and use in source and binary forms, with or without
|
||||
# modification, are permitted providing 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 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 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$
|
||||
#
|
||||
# socat_wrapper socat [options]
|
||||
#
|
||||
# A simple wrapper script for socat (or any other program that does not
|
||||
# daemonize itself and logs to stdout).
|
||||
#
|
||||
# This wrapper tries to emulate part of the functionality usually supplied by
|
||||
# software like daemontools or runit. It can be used by a FreeBSD port rc.d
|
||||
# script to start a program that does not daemonize itself and logs to
|
||||
# stdout/stderr. It redirects stdout and stderr to logger(1) via a fifo.
|
||||
#
|
||||
# Note: We need a shell that can offer us asynchronous trap handling in order
|
||||
# to be able to abort the infinite loop from outside. FreeBSD's /bin/sh offers
|
||||
# the "-T" switch for this purpose.
|
||||
#
|
||||
# TODO: send fd 2 output to never-never land to get rid of "Terminated" when we
|
||||
# kill this script but provide a way for errx() to communicate with the outside
|
||||
# world via stderr.
|
||||
#
|
||||
|
||||
errx() {
|
||||
echo "${me}: $@" >&2
|
||||
exit 1
|
||||
}
|
||||
|
||||
cleanup() {
|
||||
rm -rf ${tmpdir}
|
||||
rm -f ${pidfile}
|
||||
}
|
||||
|
||||
PATH=/bin:/sbin:/usr/bin:/usr/sbin
|
||||
|
||||
me=${0##*/}
|
||||
logger=/usr/bin/logger
|
||||
daemon_log_facility=daemon.notice
|
||||
self_log_facility=daemon.notice
|
||||
pidfile=/var/run/${me}.pid
|
||||
daemon_name=socat
|
||||
daemon_program="$1"
|
||||
shift
|
||||
|
||||
test -x "${daemon_program}" || errx "cannot execute ${daemon_program}!"
|
||||
test -x ${logger} || errx "cannot execute ${logger}!"
|
||||
test -f ${pidfile} && errx "${pidfile} is already present -- is another instance of ${me} running?"
|
||||
echo $$ >${pidfile} || errx "cannot write to ${pidfile}!"
|
||||
tmpdir=`mktemp -d /tmp/${me}.XXXXXXXXXX` || errx "cannot generate tmpdir!"
|
||||
|
||||
logfifo=${tmpdir}/fifo
|
||||
mkfifo -m 0600 ${logfifo} || errx "cannot generate fifo!"
|
||||
|
||||
while true; do
|
||||
trap 'break' 1 2 3 6 9 15
|
||||
${logger} -i -p ${daemon_log_facility} -t ${daemon_name} <${logfifo} &
|
||||
log_pid=$!
|
||||
"${daemon_program}" $@ >${logfifo} 2>&1 &
|
||||
daemon_pid=$!
|
||||
wait ${daemon_pid}
|
||||
${logger} -i -p ${self_log_facility} -t ${me} "${daemon_program} died -- restarting..."
|
||||
sleep 2
|
||||
done
|
||||
|
||||
kill -TERM ${daemon_pid} 2>/dev/null
|
||||
wait
|
||||
cleanup
|
Loading…
Reference in a new issue