mirror of
https://gitlab.com/shorewall/code.git
synced 2025-01-03 12:09:14 +01:00
cd4e9654d8
------- Forwarded message follows ------- From: istvan@istvan.org To: shorewall-users@lists.sourceforge.net Date sent: Thu, 19 May 2016 09:10:21 +0200 Subject: [Shorewall-users] Shorewall-lite on OpenWRT Send reply to: Shorewall Users <shorewall-users@lists.sourceforge.net> <mailto:shorewall-users-request@lists.sourceforge.net?subject=unsubscribe> <mailto:shorewall-users-request@lists.sourceforge.net?subject=subscribe> Hi there, I use Shorewall on an OpenWRT distribution and I experience 2 problems. I have solved them myself and report them here to help others with it. Shorewall version: shorewall[6]-lite 5.0.4 OpenWRT version: Chaos Calmer 15.05, r46767 Problem 1: Shorewall uses the lock utility from openwrt. I believe it is used in the wrong way. File lib.common line 775 First it passes arguments which the utility doesn't use/know. The util accepts them dumbly and continues to create a lockfile. It has no time-out functionality. I do not know the meaning of the r1 argument. Second the mutex_off simply deletes the lockfile by using the utility rm. This way a stale lock process keeps running. After a while the router is running a high number of stale processes which has impact on the load of the router. The correct way is to use "lock -u /lib/shorewall-lite/lock". This way the lockfile will be removed and the process will be terminated accordingly. To make it work for me, I no more let shorewall use the lock utility by using an ugly hack. Problem 2: An fgrep on the output of the type utility is wrongly coded. The output of the type command probably has been changed. File lib.cli line 4343 It is coded: "if type $1 2> /dev/null | fgrep -q 'is a function'; then" To make it work for me, it should be coded: "if type $1 2> /dev/null | fgrep -q 'is a shell function'; then" With regards, Stefan ------- End of forwarded message ------- Tom, attached as code.patch, are the patches that I believe will correct those issues In addition to those patches I've also added 3 patches: - Patch 1 will emulate the -p flag of the ps utility which is not available on openwrt. - The last two patches will add "file" to the progress message of SYSCONFFILE to make it more consistent among the installers. In shorewall-init/install.sh the else clause between the line 586 and 597 will only work for a sysvinit script. Should I make it also work for a systemd service script or can't we simply remove that else clause? In the compiled firewall script the comments before and after the functions imported from lib.common have two slashes in the path: $ grep -H lib.common firewall firewall:# Functions imported from /usr/share/shorewall//lib.common firewall:# End of imports from /usr/share/shorewall//lib.common -Matt -------------- Enclosure number 1 ---------------- >From 6ff651108df33ab8be4562caef03a8582e9eac5e Mon Sep 17 00:00:00 2001 From: Matt Darfeuille <matdarf@gmail.com> Date: Tue, 24 May 2016 13:10:28 +0200 Subject: [PATCH 1/8] Emulate 'ps -p' using grep to work on openwrt Signed-off-by: Matt Darfeuille <matdarf@gmail.com> Signed-off-by: Tom Eastep <teastep@shorewall.net>
622 lines
15 KiB
Bash
Executable File
622 lines
15 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# Script to install Shoreline Firewall Lite
|
|
#
|
|
# (c) 2000-2016 - Tom Eastep (teastep@shorewall.net)
|
|
#
|
|
# Shorewall documentation is available at http://shorewall.net
|
|
#
|
|
# This program is part of Shorewall.
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of the GNU General Public License as published by the
|
|
# Free Software Foundation, either version 2 of the license or, at your
|
|
# option, any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
|
|
VERSION=xxx #The Build script inserts the actual version
|
|
|
|
usage() # $1 = exit status
|
|
{
|
|
ME=$(basename $0)
|
|
echo "usage: $ME [ <configuration-file> ]"
|
|
echo " $ME -v"
|
|
echo " $ME -h"
|
|
echo " $ME -n"
|
|
exit $1
|
|
}
|
|
|
|
fatal_error()
|
|
{
|
|
echo " ERROR: $@" >&2
|
|
exit 1
|
|
}
|
|
|
|
split() {
|
|
local ifs
|
|
ifs=$IFS
|
|
IFS=:
|
|
set -- $1
|
|
echo $*
|
|
IFS=$ifs
|
|
}
|
|
|
|
qt()
|
|
{
|
|
"$@" >/dev/null 2>&1
|
|
}
|
|
|
|
mywhich() {
|
|
local dir
|
|
|
|
for dir in $(split $PATH); do
|
|
if [ -x $dir/$1 ]; then
|
|
echo $dir/$1
|
|
return 0
|
|
fi
|
|
done
|
|
|
|
return 2
|
|
}
|
|
|
|
cant_autostart()
|
|
{
|
|
echo
|
|
echo "WARNING: Unable to configure $Product to start automatically at boot" >&2
|
|
}
|
|
|
|
delete_file() # $1 = file to delete
|
|
{
|
|
rm -f $1
|
|
}
|
|
|
|
install_file() # $1 = source $2 = target $3 = mode
|
|
{
|
|
if cp -f $1 $2; then
|
|
if chmod $3 $2; then
|
|
if [ -n "$OWNER" ]; then
|
|
if chown $OWNER:$GROUP $2; then
|
|
return
|
|
fi
|
|
else
|
|
return 0
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
echo "ERROR: Failed to install $2" >&2
|
|
exit 1
|
|
}
|
|
|
|
make_directory() # $1 = directory , $2 = mode
|
|
{
|
|
mkdir -p $1
|
|
chmod 755 $1
|
|
[ -n "$OWNERSHIP" ] && chown $OWNERSHIP $1
|
|
|
|
}
|
|
|
|
require()
|
|
{
|
|
eval [ -n "\$$1" ] || fatal_error "Required option $1 not set"
|
|
}
|
|
|
|
#
|
|
# Change to the directory containing this script
|
|
#
|
|
cd "$(dirname $0)"
|
|
|
|
if [ -f shorewall-lite ]; then
|
|
PRODUCT=shorewall-lite
|
|
Product="Shorewall Lite"
|
|
else
|
|
PRODUCT=shorewall6-lite
|
|
Product="Shorewall6 Lite"
|
|
fi
|
|
|
|
#
|
|
# Parse the run line
|
|
#
|
|
finished=0
|
|
configure=1
|
|
|
|
while [ $finished -eq 0 ] ; do
|
|
|
|
option=$1
|
|
|
|
case "$option" in
|
|
-*)
|
|
option=${option#-}
|
|
|
|
while [ -n "$option" ]; do
|
|
case $option in
|
|
h)
|
|
usage 0
|
|
;;
|
|
v)
|
|
echo "$Product Firewall Installer Version $VERSION"
|
|
exit 0
|
|
;;
|
|
n*)
|
|
configure=0
|
|
option=${option#n}
|
|
;;
|
|
*)
|
|
usage 1
|
|
;;
|
|
esac
|
|
done
|
|
|
|
shift
|
|
;;
|
|
*)
|
|
finished=1
|
|
;;
|
|
esac
|
|
done
|
|
|
|
#
|
|
# Read the RC file
|
|
#
|
|
if [ $# -eq 0 ]; then
|
|
if [ -f ./shorewallrc ]; then
|
|
. ./shorewallrc || exit 1
|
|
file=./shorewallrc
|
|
elif [ -f ~/.shorewallrc ]; then
|
|
. ~/.shorewallrc
|
|
elif [ -f /usr/share/shorewall/shorewallrc ]; then
|
|
. /usr/share/shorewall/shorewallrc
|
|
else
|
|
fatal_error "No configuration file specified and /usr/share/shorewall/shorewallrc not found"
|
|
fi
|
|
elif [ $# -eq 1 ]; then
|
|
file=$1
|
|
case $file in
|
|
/*|.*)
|
|
;;
|
|
*)
|
|
file=./$file
|
|
;;
|
|
esac
|
|
|
|
. $file
|
|
else
|
|
usage 1
|
|
fi
|
|
|
|
if [ -z "${VARLIB}" ]; then
|
|
VARLIB=${VARDIR}
|
|
VARDIR=${VARLIB}/${PRODUCT}
|
|
elif [ -z "${VARDIR}" ]; then
|
|
VARDIR=${VARLIB}/${PRODUCT}
|
|
fi
|
|
|
|
for var in SHAREDIR LIBEXECDIR CONFDIR SBINDIR VARLIB VARDIR; do
|
|
require $var
|
|
done
|
|
|
|
[ -n "${INITFILE}" ] && require INITSOURCE && require INITDIR
|
|
|
|
PATH=${SBINDIR}:/bin:/usr${SBINDIR}:/usr/bin:/usr/local/bin:/usr/local${SBINDIR}
|
|
|
|
[ -n "$SANDBOX" ] && configure=0
|
|
|
|
#
|
|
# Determine where to install the firewall script
|
|
#
|
|
cygwin=
|
|
|
|
if [ -z "$BUILD" ]; then
|
|
case $(uname) in
|
|
cygwin*|CYGWIN*)
|
|
BUILD=cygwin
|
|
;;
|
|
Darwin)
|
|
BUILD=apple
|
|
;;
|
|
*)
|
|
if [ -f /etc/os-release ]; then
|
|
eval $(cat /etc/os-release | grep ^ID)
|
|
|
|
case $ID in
|
|
fedora|rhel|centos|foobar)
|
|
BUILD=redhat
|
|
;;
|
|
debian)
|
|
BUILD=debian
|
|
;;
|
|
gentoo)
|
|
BUILD=gentoo
|
|
;;
|
|
opensuse)
|
|
BUILD=suse
|
|
;;
|
|
*)
|
|
BUILD="$ID"
|
|
;;
|
|
esac
|
|
elif [ -f ${CONFDIR}/debian_version ]; then
|
|
BUILD=debian
|
|
elif [ -f /etc/gentoo-release ]; then
|
|
BUILD=gentoo
|
|
elif [ -f ${CONFDIR}/redhat-release ]; then
|
|
BUILD=redhat
|
|
elif [ -f ${CONFDIR}/SuSE-release ]; then
|
|
BUILD=suse
|
|
elif [ -f ${CONFDIR}/slackware-version ] ; then
|
|
BUILD=slackware
|
|
elif [ -f ${CONFDIR}/arch-release ] ; then
|
|
BUILD=archlinux
|
|
elif [ -f ${CONFDIR}/openwrt_release ]; then
|
|
BUILD=openwrt
|
|
else
|
|
BUILD=linux
|
|
fi
|
|
;;
|
|
esac
|
|
fi
|
|
|
|
case $BUILD in
|
|
cygwin*|CYGWIN*)
|
|
OWNER=$(id -un)
|
|
GROUP=$(id -gn)
|
|
;;
|
|
apple)
|
|
[ -z "$OWNER" ] && OWNER=root
|
|
[ -z "$GROUP" ] && GROUP=wheel
|
|
;;
|
|
*)
|
|
if [ $(id -u) -eq 0 ]; then
|
|
[ -z "$OWNER" ] && OWNER=root
|
|
[ -z "$GROUP" ] && GROUP=root
|
|
fi
|
|
;;
|
|
esac
|
|
|
|
[ -n "$OWNER" ] && OWNERSHIP="$OWNER:$GROUP"
|
|
|
|
[ -n "$HOST" ] || HOST=$BUILD
|
|
|
|
case "$HOST" in
|
|
cygwin)
|
|
echo "$PRODUCT is not supported on Cygwin" >&2
|
|
exit 1
|
|
;;
|
|
apple)
|
|
echo "$PRODUCT is not supported on OS X" >&2
|
|
exit 1
|
|
;;
|
|
debian)
|
|
echo "Installing Debian-specific configuration..."
|
|
;;
|
|
gentoo)
|
|
echo "Installing Gentoo-specific configuration..."
|
|
;;
|
|
redhat)
|
|
echo "Installing Redhat/Fedora-specific configuration..."
|
|
;;
|
|
slackware)
|
|
echo "Installing Slackware-specific configuration..."
|
|
;;
|
|
archlinux)
|
|
echo "Installing ArchLinux-specific configuration..."
|
|
;;
|
|
suse)
|
|
echo "Installing Suse-specific configuration..."
|
|
;;
|
|
openwrt)
|
|
echo "Installing OpenWRT-specific configuration..."
|
|
;;
|
|
linux)
|
|
;;
|
|
*)
|
|
echo "ERROR: Unknown HOST \"$HOST\"" >&2
|
|
exit 1;
|
|
;;
|
|
esac
|
|
|
|
[ -z "$INITDIR" ] && INITDIR="${CONFDIR}/init.d"
|
|
|
|
if [ -n "$DESTDIR" ]; then
|
|
if [ `id -u` != 0 ] ; then
|
|
echo "Not setting file owner/group permissions, not running as root."
|
|
OWNERSHIP=""
|
|
fi
|
|
|
|
make_directory ${DESTDIR}${SBINDIR} 755
|
|
make_directory ${DESTDIR}${INITDIR} 755
|
|
|
|
else
|
|
if [ ! -f ${SHAREDIR}/shorewall/coreversion ]; then
|
|
echo "$PRODUCT $VERSION requires Shorewall Core which does not appear to be installed" >&2
|
|
exit 1
|
|
fi
|
|
fi
|
|
|
|
echo "Installing $Product Version $VERSION"
|
|
|
|
#
|
|
# Check for ${CONFDIR}/$PRODUCT
|
|
#
|
|
if [ -z "$DESTDIR" -a -d ${CONFDIR}/$PRODUCT ]; then
|
|
if [ ! -f ${SHAREDIR}/shorewall/coreversion ]; then
|
|
echo "$PRODUCT $VERSION requires Shorewall Core which does not appear to be installed" >&2
|
|
exit 1
|
|
fi
|
|
|
|
[ -f ${CONFDIR}/$PRODUCT/shorewall.conf ] && \
|
|
mv -f ${CONFDIR}/$PRODUCT/shorewall.conf ${CONFDIR}/$PRODUCT/$PRODUCT.conf
|
|
else
|
|
rm -rf ${DESTDIR}${CONFDIR}/$PRODUCT
|
|
rm -rf ${DESTDIR}${SHAREDIR}/$PRODUCT
|
|
rm -rf ${DESTDIR}${VARDIR}
|
|
[ "$LIBEXECDIR" = /usr/share ] || rm -rf ${DESTDIR}/usr/share/$PRODUCT/wait4ifup ${DESTDIR}/usr/share/$PRODUCT/shorecap
|
|
fi
|
|
|
|
#
|
|
# Check for ${SBINDIR}/$PRODUCT
|
|
#
|
|
if [ -f ${DESTDIR}${SBINDIR}/$PRODUCT ]; then
|
|
first_install=""
|
|
else
|
|
first_install="Yes"
|
|
fi
|
|
|
|
delete_file ${DESTDIR}/usr/share/$PRODUCT/xmodules
|
|
|
|
install_file $PRODUCT ${DESTDIR}${SBINDIR}/$PRODUCT 0544
|
|
[ -n "${INITFILE}" ] && make_directory ${DESTDIR}${INITDIR} 755
|
|
|
|
echo "$Product control program installed in ${DESTDIR}${SBINDIR}/$PRODUCT"
|
|
|
|
#
|
|
# Create ${CONFDIR}/$PRODUCT, /usr/share/$PRODUCT and /var/lib/$PRODUCT if needed
|
|
#
|
|
mkdir -p ${DESTDIR}${CONFDIR}/$PRODUCT
|
|
mkdir -p ${DESTDIR}${SHAREDIR}/$PRODUCT
|
|
mkdir -p ${DESTDIR}${LIBEXECDIR}/$PRODUCT
|
|
mkdir -p ${DESTDIR}${VARDIR}
|
|
|
|
chmod 755 ${DESTDIR}${CONFDIR}/$PRODUCT
|
|
chmod 755 ${DESTDIR}${SHAREDIR}/$PRODUCT
|
|
|
|
if [ -n "$DESTDIR" ]; then
|
|
mkdir -p ${DESTDIR}${CONFDIR}/logrotate.d
|
|
chmod 755 ${DESTDIR}${CONFDIR}/logrotate.d
|
|
mkdir -p ${DESTDIR}${INITDIR}
|
|
chmod 755 ${DESTDIR}${INITDIR}
|
|
fi
|
|
|
|
if [ -n "$INITFILE" ]; then
|
|
if [ -f "${INITSOURCE}" ]; then
|
|
initfile="${DESTDIR}${INITDIR}/${INITFILE}"
|
|
install_file ${INITSOURCE} "$initfile" 0544
|
|
|
|
[ "${SHAREDIR}" = /usr/share ] || eval sed -i \'s\|/usr/share/\|${SHAREDIR}/\|\' "$initfile"
|
|
|
|
echo "SysV init script $INITSOURCE installed in $initfile"
|
|
fi
|
|
fi
|
|
#
|
|
# Install the .service file
|
|
#
|
|
if [ -z "${SERVICEDIR}" ]; then
|
|
SERVICEDIR="$SYSTEMD"
|
|
fi
|
|
|
|
if [ -n "$SERVICEDIR" ]; then
|
|
mkdir -p ${DESTDIR}${SERVICEDIR}
|
|
[ -z "$SERVICEFILE" ] && SERVICEFILE=$PRODUCT.service
|
|
install_file $SERVICEFILE ${DESTDIR}${SERVICEDIR}/$PRODUCT.service 644
|
|
[ ${SBINDIR} != /sbin ] && eval sed -i \'s\|/sbin/\|${SBINDIR}/\|\' ${DESTDIR}${SERVICEDIR}/$PRODUCT.service
|
|
echo "Service file $SERVICEFILE installed as ${DESTDIR}${SERVICEDIR}/$PRODUCT.service"
|
|
fi
|
|
#
|
|
# Install the config file
|
|
#
|
|
if [ ! -f ${DESTDIR}${CONFDIR}/$PRODUCT/$PRODUCT.conf ]; then
|
|
install_file $PRODUCT.conf ${DESTDIR}${CONFDIR}/$PRODUCT/$PRODUCT.conf 0744
|
|
echo "Config file installed as ${DESTDIR}${CONFDIR}/$PRODUCT/$PRODUCT.conf"
|
|
fi
|
|
|
|
if [ $HOST = archlinux ] ; then
|
|
sed -e 's!LOGFILE=/var/log/messages!LOGFILE=/var/log/messages.log!' -i ${DESTDIR}${CONFDIR}/$PRODUCT/$PRODUCT.conf
|
|
elif [ $HOST = gentoo ]; then
|
|
# Adjust SUBSYSLOCK path (see https://bugs.gentoo.org/show_bug.cgi?id=459316)
|
|
perl -p -w -i -e "s|^SUBSYSLOCK=.*|SUBSYSLOCK=/run/lock/$PRODUCT|;" ${DESTDIR}${CONFDIR}/$PRODUCT/$PRODUCT.conf
|
|
fi
|
|
|
|
#
|
|
# Install the Makefile
|
|
#
|
|
install_file Makefile ${DESTDIR}${CONFDIR}/$PRODUCT/Makefile 0600
|
|
[ $SHAREDIR = /usr/share ] || eval sed -i \'s\|/usr/share/\|${SHAREDIR}/\|\' ${DESTDIR}${CONFDIR}/$PRODUCT/Makefile
|
|
[ $SBINDIR = /sbin ] || eval sed -i \'s\|/sbin/\|${SBINDIR}/\|\' ${DESTDIR}${CONFDIR}/$PRODUCT/Makefile
|
|
echo "Makefile installed as ${DESTDIR}${CONFDIR}/$PRODUCT/Makefile"
|
|
|
|
#
|
|
# Install the default config path file
|
|
#
|
|
install_file configpath ${DESTDIR}${SHAREDIR}/$PRODUCT/configpath 0644
|
|
echo "Default config path file installed as ${DESTDIR}${SHAREDIR}/$PRODUCT/configpath"
|
|
|
|
#
|
|
# Install the libraries
|
|
#
|
|
for f in lib.* ; do
|
|
if [ -f $f ]; then
|
|
install_file $f ${DESTDIR}${SHAREDIR}/$PRODUCT/$f 0644
|
|
echo "Library ${f#*.} file installed as ${DESTDIR}${SHAREDIR}/$PRODUCT/$f"
|
|
fi
|
|
done
|
|
|
|
ln -sf lib.base ${DESTDIR}${SHAREDIR}/$PRODUCT/functions
|
|
|
|
echo "Common functions linked through ${DESTDIR}${SHAREDIR}/$PRODUCT/functions"
|
|
|
|
#
|
|
# Install Shorecap
|
|
#
|
|
|
|
install_file shorecap ${DESTDIR}${LIBEXECDIR}/$PRODUCT/shorecap 0755
|
|
[ $SHAREDIR = /usr/share ] || eval sed -i \'s\|/usr/share/\|${SHAREDIR}/\|\' ${DESTDIR}${LIBEXECDIR}/$PRODUCT/shorecap
|
|
|
|
echo
|
|
echo "Capability file builder installed in ${DESTDIR}${LIBEXECDIR}/$PRODUCT/shorecap"
|
|
|
|
#
|
|
# Install the Modules files
|
|
#
|
|
|
|
if [ -f modules ]; then
|
|
install_file modules ${DESTDIR}${SHAREDIR}/$PRODUCT/modules 0600
|
|
echo "Modules file installed as ${DESTDIR}${SHAREDIR}/$PRODUCT/modules"
|
|
fi
|
|
|
|
if [ -f helpers ]; then
|
|
install_file helpers ${DESTDIR}${SHAREDIR}/$PRODUCT/helpers 600
|
|
echo "Helper modules file installed as ${DESTDIR}${SHAREDIR}/$PRODUCT/helpers"
|
|
fi
|
|
|
|
for f in modules.*; do
|
|
install_file $f ${DESTDIR}${SHAREDIR}/$PRODUCT/$f 644
|
|
echo "Module file $f installed as ${DESTDIR}${SHAREDIR}/$PRODUCT/$f"
|
|
done
|
|
|
|
#
|
|
# Install the Man Pages
|
|
#
|
|
|
|
if [ -d manpages -a -n "$MANDIR" ]; then
|
|
cd manpages
|
|
|
|
mkdir -p ${DESTDIR}${MANDIR}/man5/ ${DESTDIR}${MANDIR}/man8/
|
|
|
|
for f in *.5; do
|
|
gzip -c $f > $f.gz
|
|
install_file $f.gz ${DESTDIR}${MANDIR}/man5/$f.gz 644
|
|
echo "Man page $f.gz installed to ${DESTDIR}${MANDIR}/man5/$f.gz"
|
|
done
|
|
|
|
for f in *.8; do
|
|
gzip -c $f > $f.gz
|
|
install_file $f.gz ${DESTDIR}${MANDIR}/man8/$f.gz 644
|
|
echo "Man page $f.gz installed to ${DESTDIR}${MANDIR}/man8/$f.gz"
|
|
done
|
|
|
|
cd ..
|
|
|
|
echo "Man Pages Installed"
|
|
fi
|
|
|
|
if [ -d ${DESTDIR}${CONFDIR}/logrotate.d ]; then
|
|
install_file logrotate ${DESTDIR}${CONFDIR}/logrotate.d/$PRODUCT 644
|
|
echo "Logrotate file installed as ${DESTDIR}${CONFDIR}/logrotate.d/$PRODUCT"
|
|
fi
|
|
|
|
#
|
|
# Create the version file
|
|
#
|
|
echo "$VERSION" > ${DESTDIR}${SHAREDIR}/$PRODUCT/version
|
|
chmod 644 ${DESTDIR}${SHAREDIR}/$PRODUCT/version
|
|
#
|
|
# Remove and create the symbolic link to the init script
|
|
#
|
|
|
|
if [ -z "${DESTDIR}" -a -n "${INITFILE}" ]; then
|
|
rm -f ${SHAREDIR}/$PRODUCT/init
|
|
ln -s ${INITDIR}/${INITFILE} ${SHAREDIR}/$PRODUCT/init
|
|
fi
|
|
|
|
delete_file ${DESTDIR}${SHAREDIR}/$PRODUCT/lib.common
|
|
delete_file ${DESTDIR}${SHAREDIR}/$PRODUCT/lib.cli
|
|
delete_file ${DESTDIR}${SHAREDIR}/$PRODUCT/wait4ifup
|
|
|
|
#
|
|
# Note -- not all packages will have the SYSCONFFILE so we need to check for its existance here
|
|
#
|
|
if [ -n "$SYSCONFFILE" -a -f "$SYSCONFFILE" -a ! -f ${DESTDIR}${SYSCONFDIR}/${PRODUCT} ]; then
|
|
if [ ${DESTDIR} ]; then
|
|
mkdir -p ${DESTDIR}${SYSCONFDIR}
|
|
chmod 755 ${DESTDIR}${SYSCONFDIR}
|
|
fi
|
|
|
|
install_file ${SYSCONFFILE} ${DESTDIR}${SYSCONFDIR}/${PRODUCT} 0640
|
|
echo "$SYSCONFFILE file installed in ${DESTDIR}${SYSCONFDIR}/${PRODUCT}"
|
|
fi
|
|
|
|
if [ ${SHAREDIR} != /usr/share ]; then
|
|
eval sed -i \'s\|/usr/share/\|${SHAREDIR}/\|\' ${DESTDIR}${SHAREDIR}/${PRODUCT}/lib.base
|
|
eval sed -i \'s\|/usr/share/\|${SHAREDIR}/\|\' ${DESTDIR}${SBINDIR}/$PRODUCT
|
|
fi
|
|
|
|
if [ $configure -eq 1 -a -z "$DESTDIR" -a -n "$first_install" -a -z "${cygwin}${mac}" ]; then
|
|
if [ -n "$SERVICEDIR" ]; then
|
|
if systemctl enable ${PRODUCT}.service; then
|
|
echo "$Product will start automatically at boot"
|
|
fi
|
|
elif mywhich insserv; then
|
|
if insserv ${INITDIR}/${INITFILE} ; then
|
|
echo "$PRODUCT will start automatically at boot"
|
|
if [ $HOST = debian ]; then
|
|
echo "Set startup=1 in ${CONFDIR}/default/$PRODUCT to enable"
|
|
touch /var/log/$PRODUCT-init.log
|
|
perl -p -w -i -e 's/^STARTUP_ENABLED=No/STARTUP_ENABLED=Yes/;s/^IP_FORWARDING=On/IP_FORWARDING=Keep/;s/^SUBSYSLOCK=.*/SUBSYSLOCK=/;' ${CONFDIR}/$PRODUCT/$PRODUCT.conf
|
|
else
|
|
echo "Set STARTUP_ENABLED=Yes in ${CONFDIR}/$PRODUCT/$PRODUCT.conf to enable"
|
|
fi
|
|
else
|
|
cant_autostart
|
|
fi
|
|
elif mywhich chkconfig; then
|
|
if chkconfig --add $PRODUCT ; then
|
|
echo "$PRODUCT will start automatically in run levels as follows:"
|
|
echo "Set STARTUP_ENABLED=Yes in ${CONFDIR}/$PRODUCT/${PRODUCT}.conf to enable"
|
|
chkconfig --list $PRODUCT
|
|
else
|
|
cant_autostart
|
|
fi
|
|
elif mywhich update-rc.d ; then
|
|
echo "$PRODUCT will start automatically at boot"
|
|
echo "Set startup=1 in ${CONFDIR}/default/$PRODUCT to enable"
|
|
touch /var/log/$PRODUCT-init.log
|
|
perl -p -w -i -e 's/^STARTUP_ENABLED=No/STARTUP_ENABLED=Yes/;s/^IP_FORWARDING=On/IP_FORWARDING=Keep/;s/^SUBSYSLOCK=.*/SUBSYSLOCK=/;' ${CONFDIR}/$PRODUCT/$PRODUCT.conf
|
|
update-rc.d $PRODUCT enable
|
|
elif mywhich rc-update ; then
|
|
if rc-update add $PRODUCT default; then
|
|
echo "$PRODUCT will start automatically at boot"
|
|
if [ $HOST = debian ]; then
|
|
echo "Set startup=1 in ${CONFDIR}/default/$PRODUCT to enable"
|
|
touch /var/log/$PRODUCT-init.log
|
|
perl -p -w -i -e 's/^STARTUP_ENABLED=No/STARTUP_ENABLED=Yes/;s/^IP_FORWARDING=On/IP_FORWARDING=Keep/;s/^SUBSYSLOCK=.*/SUBSYSLOCK=/;' ${CONFDIR}/$PRODUCT/$PRODUCT.conf
|
|
else
|
|
echo "Set STARTUP_ENABLED=Yes in ${CONFDIR}/$PRODUCT/$PRODUCT.conf to enable"
|
|
fi
|
|
else
|
|
cant_autostart
|
|
fi
|
|
elif [ $HOST = openwrt -a -f ${CONFDIR}/rc.common ]; then
|
|
/etc/init.d/$PRODUCT enable
|
|
if /etc/init.d/$PRODUCT enabled; then
|
|
echo "$PRODUCT will start automatically at boot"
|
|
else
|
|
cant_autostart
|
|
fi
|
|
elif [ "$INITFILE" != rc.${PRODUCT} ]; then #Slackware starts this automatically
|
|
cant_autostart
|
|
fi
|
|
fi
|
|
|
|
#
|
|
# Report Success
|
|
#
|
|
echo "$Product Version $VERSION Installed"
|