forked from extern/shorewall_code
0925636995
On 7 Jun 2016 at 8:21, Tom Eastep wrote: > On 06/07/2016 06:40 AM, Matt Darfeuille wrote: > > On 5 Jun 2016 at 12:53, Tom Eastep wrote: > > > >> On 06/05/2016 12:33 PM, Matt Darfeuille wrote: > >>> On 5 Jun 2016 at 7:57, Tom Eastep wrote: > >>> > >>>> On 05/29/2016 02:00 AM, Matt Darfeuille wrote: > >>>> > >>>> Hi 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> > >>>>> --- > >>>>> Shorewall-core/lib.common | 2 +- > >>>>> 1 file changed, 1 insertion(+), 1 deletion(-) > >>>>> > >>>>> diff --git a/Shorewall-core/lib.common b/Shorewall-core/lib.common > >>>>> index 03ecb2a..fcb02ee 100644 > >>>>> --- a/Shorewall-core/lib.common > >>>>> +++ b/Shorewall-core/lib.common > >>>>> @@ -776,7 +776,7 @@ mutex_on() > >>>>> error_message "WARNING: Stale lockfile ${lockf} removed" > >>>>> elif [ $lockpid -eq $$ ]; then > >>>>> return 0 > >>>>> - elif ! qt ps p ${lockpid}; then > >>>>> + elif ! qt ps | grep -v grep | grep ${lockpid}; then > >>>> > >>>> I don't see how this can work -- 'qt ps' will produce no output yet the > >>>> code pipes into tandem greps. > >>>> > >>>> Do you really want this instead? > >>>> > >>>> elif ! ps | grep -v grep | qt grep ${lockpid}; then > >>>> > >>> > >>> Oops sorry Tom, that's what I meant(do you want the corrected > >>> patch?)! > >> > >> Yes, please. > >> > > > > Tom, along with correcting this faulty commit I realize, after some > > more testing, that I've also sent unnecessary commits. > > > > Should I revert these 3 commits(git revert ...): > > Set proper permissions for the LOCKFILE on openwrt > > 2ded346cb557212389212fd5adcd4c6800edbb62 > > Create lockfile before using openwrt's lock utility > > 08e8796ff1abc3b24b8bbd40bf5e0a2b36464d61 > > Emulate 'ps -p' using grep to work on openwrt > > 6ff651108df33ab8be4562caef03a8582e9eac5e > > > > or should I simply create new commits that will correct these faulty > > commits? > > > > In other words what's the best way to correct submited commits. > > > > Matt, > > Either way is fine. > Hopefully these 3 commits will do it(code-fixes.patch): Patch 1 will correct the error you have point out! On OpenWRT the lock utility doesn't allow to append the pid of the currently running script to the LOCKFILE that's why I've simply deleted that line(patch 2). I've also reordered the permissions line to be added after the line that will lock the file specified by the LOCKFILE variable(patch 3). and two other patches: While installing shorewall-init using the DESTDIR variable on debian, 'mkdir' would complain if the directory ${DESTDIR}/${etc}/default already exist; corrected using 'mkdir -p ...'(patch 4). The last patch will correct a typo in the blacklisting_support article. -Matt -------------- Enclosure number 1 ---------------- >From 1a2ff15c8dc994030e819d2882570d188b99c501 Mon Sep 17 00:00:00 2001 From: Matt Darfeuille <matdarf@gmail.com> Date: Wed, 8 Jun 2016 09:09:46 +0200 Subject: [PATCH 1/5] Correct pid detection mutex_on() Signed-off-by: Matt Darfeuille <matdarf@gmail.com> Signed-off-by: Tom Eastep <teastep@shorewall.net>
633 lines
15 KiB
Bash
Executable File
633 lines
15 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# Script to install Shoreline Firewall Init
|
|
#
|
|
# (c) 2000-2016 - Tom Eastep (teastep@shorewall.net)
|
|
# (c) 2010 - Roberto C. Sanchez (roberto@connexer.com)
|
|
#
|
|
# 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/>.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software
|
|
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
|
|
#
|
|
|
|
VERSION=xxx #The Build script inserts the actual version.
|
|
PRODUCT=shorewall-init
|
|
Product="Shorewall Init"
|
|
|
|
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
|
|
return 0
|
|
fi
|
|
done
|
|
|
|
return 2
|
|
}
|
|
|
|
cant_autostart()
|
|
{
|
|
echo
|
|
echo "WARNING: Unable to configure shorewall init to start automatically at boot" >&2
|
|
}
|
|
|
|
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 0755 $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)"
|
|
|
|
#
|
|
# 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 "Shorewall-init 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
|
|
#
|
|
# Load packager's settings if any
|
|
#
|
|
if [ -f ./shorewallrc ]; then
|
|
. ./shorewallrc || exit 1
|
|
file=~/.shorewallrc
|
|
elif [ -f ~/.shorewallrc ]; then
|
|
. ~/.shorewallrc || exit 1
|
|
file=./.shorewallrc
|
|
else
|
|
fatal_error "No configuration file specified and ~/.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 "$SANDBOX" ] && configure=0
|
|
|
|
PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/bin:/usr/local/sbin
|
|
|
|
[ $configure -eq 1 ] && ETC=/etc || ETC="${CONFDIR}"
|
|
|
|
if [ -z "$BUILD" ]; then
|
|
case $(uname) in
|
|
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|ubuntu)
|
|
BUILD=debian
|
|
;;
|
|
opensuse)
|
|
BUILD=suse
|
|
;;
|
|
*)
|
|
BUILD="$ID"
|
|
;;
|
|
esac
|
|
elif [ -f /etc/debian_version ]; then
|
|
BUILD=debian
|
|
elif [ -f /etc/ubuntu_version ]; then
|
|
BUILD=debian
|
|
elif [ -f /etc/gentoo-release ]; then
|
|
BUILD=gentoo
|
|
elif [ -f /etc/redhat-release ]; then
|
|
BUILD=redhat
|
|
elif [ -f /etc/SuSE-release ]; then
|
|
BUILD=suse
|
|
elif [ -f /etc/slackware-version ] ; then
|
|
BUILD=slackware
|
|
elif [ -f /etc/arch-release ] ; then
|
|
BUILD=archlinux
|
|
elif [ -f ${CONFDIR}/openwrt_release ]; then
|
|
BUILD=openwrt
|
|
else
|
|
BUILD=linux
|
|
fi
|
|
;;
|
|
esac
|
|
fi
|
|
|
|
case $BUILD in
|
|
apple)
|
|
[ -z "$OWNER" ] && OWNER=root
|
|
[ -z "$GROUP" ] && GROUP=wheel
|
|
;;
|
|
cygwin*|CYGWIN*)
|
|
OWNER=$(id -un)
|
|
GROUP=$(id -gn)
|
|
;;
|
|
*)
|
|
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
|
|
debian)
|
|
echo "Installing Debian-specific configuration..."
|
|
;;
|
|
gentoo)
|
|
echo "Installing Gentoo-specific configuration..."
|
|
;;
|
|
redhat)
|
|
echo "Installing Redhat/Fedora-specific configuration..."
|
|
;;
|
|
slackware)
|
|
echo "Shorewall-init is currently not supported on Slackware" >&2
|
|
exit 1
|
|
;;
|
|
archlinux)
|
|
echo "Shorewall-init is currently not supported on Arch Linux" >&2
|
|
exit 1
|
|
;;
|
|
suse)
|
|
echo "Installing SuSE-specific configuration..."
|
|
;;
|
|
openwrt)
|
|
echo "Installing Openwrt-specific configuration..."
|
|
;;
|
|
linux)
|
|
echo "ERROR: Shorewall-init is not supported on this system" >&2
|
|
exit 1
|
|
;;
|
|
*)
|
|
echo "ERROR: Unsupported HOST distribution: \"$HOST\"" >&2
|
|
exit 1;
|
|
;;
|
|
esac
|
|
|
|
[ -z "$TARGET" ] && TARGET=$HOST
|
|
|
|
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}${INITDIR} 0755
|
|
fi
|
|
|
|
echo "Installing Shorewall Init Version $VERSION"
|
|
|
|
#
|
|
# Check for /usr/share/shorewall-init/version
|
|
#
|
|
if [ -f ${DESTDIR}${SHAREDIR}/shorewall-init/version ]; then
|
|
first_install=""
|
|
else
|
|
first_install="Yes"
|
|
fi
|
|
|
|
if [ -n "$DESTDIR" ]; then
|
|
mkdir -p ${DESTDIR}${CONFDIR}/logrotate.d
|
|
chmod 0755 ${DESTDIR}${CONFDIR}/logrotate.d
|
|
fi
|
|
|
|
#
|
|
# Install the Firewall Script
|
|
#
|
|
if [ -n "$INITFILE" ]; then
|
|
mkdir -p ${DESTDIR}${INITDIR}
|
|
install_file $INITSOURCE ${DESTDIR}${INITDIR}/$INITFILE 0544
|
|
[ "${SHAREDIR}" = /usr/share ] || eval sed -i \'s\|/usr/share/\|${SHAREDIR}/\|\' ${DESTDIR}${INITDIR}/$INITFILE
|
|
|
|
if [ -n "${AUXINITSOURCE}" ]; then
|
|
install_file $INITSOURCE ${DESTDIR}${INITDIR}/$AUXINITFILE 0544
|
|
fi
|
|
|
|
echo "SysV init script $INITSOURCE installed in ${DESTDIR}${INITDIR}/$INITFILE"
|
|
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 0644
|
|
[ ${SBINDIR} != /sbin ] && eval sed -i \'s\|/sbin/\|${SBINDIR}/\|\' ${DESTDIR}${SERVICEDIR}/$PRODUCT.service
|
|
echo "Service file $SERVICEFILE installed as ${DESTDIR}${SERVICEDIR}/$PRODUCT.service"
|
|
if [ -n "$DESTDIR" -o $configure -eq 0 ]; then
|
|
mkdir -p ${DESTDIR}${SBINDIR}
|
|
chmod 0755 ${DESTDIR}${SBINDIR}
|
|
fi
|
|
install_file shorewall-init ${DESTDIR}${SBINDIR}/shorewall-init 0700
|
|
[ "${SHAREDIR}" = /usr/share ] || eval sed -i \'s\|/usr/share/\|${SHAREDIR}/\|\' ${DESTDIR}${SBINDIR}/shorewall-init
|
|
echo "CLI installed as ${DESTDIR}${SBINDIR}/shorewall-init"
|
|
fi
|
|
|
|
#
|
|
# Create /usr/share/shorewall-init if needed
|
|
#
|
|
mkdir -p ${DESTDIR}${SHAREDIR}/shorewall-init
|
|
chmod 0755 ${DESTDIR}${SHAREDIR}/shorewall-init
|
|
|
|
#
|
|
# Install logrotate file
|
|
#
|
|
if [ -d ${DESTDIR}${CONFDIR}/logrotate.d ]; then
|
|
install_file logrotate ${DESTDIR}${CONFDIR}/logrotate.d/$PRODUCT 0644
|
|
echo "Logrotate file installed as ${DESTDIR}${CONFDIR}/logrotate.d/$PRODUCT"
|
|
fi
|
|
|
|
#
|
|
# Create the version file
|
|
#
|
|
echo "$VERSION" > ${DESTDIR}/${SHAREDIR}/shorewall-init/version
|
|
chmod 0644 ${DESTDIR}${SHAREDIR}/shorewall-init/version
|
|
|
|
#
|
|
# Remove and create the symbolic link to the init script
|
|
#
|
|
if [ -z "$DESTDIR" ]; then
|
|
rm -f ${SHAREDIR}/shorewall-init/init
|
|
ln -s ${INITDIR}/${INITFILE} ${SHAREDIR}/shorewall-init/init
|
|
fi
|
|
|
|
if [ $HOST = debian ]; then
|
|
if [ -n "${DESTDIR}" ]; then
|
|
mkdir -p ${DESTDIR}${ETC}/network/if-up.d/
|
|
mkdir -p ${DESTDIR}${ETC}/network/if-down.d/
|
|
mkdir -p ${DESTDIR}${ETC}/network/if-post-down.d/
|
|
elif [ $configure -eq 0 ]; then
|
|
mkdir -p ${DESTDIR}${CONFDIR}/network/if-up.d/
|
|
mkdir -p ${DESTDIR}${CONFDIR}/network/if-down.d/
|
|
mkdir -p ${DESTDIR}${CONFDIR}/network/if-post-down.d/
|
|
fi
|
|
|
|
if [ ! -f ${DESTDIR}${CONFDIR}/default/shorewall-init ]; then
|
|
if [ -n "${DESTDIR}" ]; then
|
|
mkdir -p ${DESTDIR}${ETC}/default
|
|
fi
|
|
|
|
[ $configure -eq 1 ] || mkdir -p ${DESTDIR}${CONFDIR}/default
|
|
install_file sysconfig ${DESTDIR}${ETC}/default/shorewall-init 0644
|
|
echo "sysconfig file installed in ${DESTDIR}${SYSCONFDIR}/${PRODUCT}"
|
|
fi
|
|
|
|
IFUPDOWN=ifupdown.debian.sh
|
|
else
|
|
if [ -n "$DESTDIR" ]; then
|
|
mkdir -p ${DESTDIR}${SYSCONFDIR}
|
|
|
|
if [ -z "$RPM" ]; then
|
|
if [ $HOST = suse ]; then
|
|
mkdir -p ${DESTDIR}${ETC}/sysconfig/network/if-up.d
|
|
mkdir -p ${DESTDIR}${ETC}/sysconfig/network/if-down.d
|
|
elif [ $HOST = gentoo ]; then
|
|
# Gentoo does not support if-{up,down}.d
|
|
/bin/true
|
|
elif [ $HOST = openwrt ]; then
|
|
# Not implemented on openwrt
|
|
/bin/true
|
|
else
|
|
mkdir -p ${DESTDIR}/${ETC}/NetworkManager/dispatcher.d
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
if [ -n "$SYSCONFFILE" -a ! -f ${DESTDIR}${SYSCONFDIR}/${PRODUCT} ]; then
|
|
install_file ${SYSCONFFILE} ${DESTDIR}${SYSCONFDIR}/$PRODUCT 0644
|
|
echo "${SYSCONFFILE} file installed in ${DESTDIR}${SYSCONFDIR}/${PRODUCT}"
|
|
fi
|
|
|
|
[ $HOST = suse ] && IFUPDOWN=ifupdown.suse.sh || IFUPDOWN=ifupdown.fedora.sh
|
|
fi
|
|
|
|
#
|
|
# Install the ifupdown script
|
|
#
|
|
|
|
if [ $HOST != openwrt ]; then
|
|
cp $IFUPDOWN ifupdown
|
|
|
|
[ "${SHAREDIR}" = /usr/share ] || eval sed -i \'s\|/usr/share/\|${SHAREDIR}/\|\' ifupdown
|
|
|
|
mkdir -p ${DESTDIR}${LIBEXECDIR}/shorewall-init
|
|
|
|
install_file ifupdown ${DESTDIR}${LIBEXECDIR}/shorewall-init/ifupdown 0544
|
|
fi
|
|
|
|
if [ -d ${DESTDIR}/etc/NetworkManager ]; then
|
|
[ $configure -eq 1 ] || mkdir -p ${DESTDIR}${CONFDIR}/NetworkManager/dispatcher.d/
|
|
install_file ifupdown ${DESTDIR}${ETC}/NetworkManager/dispatcher.d/01-shorewall 0544
|
|
fi
|
|
|
|
case $HOST in
|
|
debian)
|
|
if [ $configure -eq 1 ]; then
|
|
install_file ifupdown ${DESTDIR}/etc/network/if-up.d/shorewall 0544
|
|
install_file ifupdown ${DESTDIR}/etc/network/if-down.d/shorewall 0544
|
|
install_file ifupdown ${DESTDIR}/etc/network/if-post-down.d/shorewall 0544
|
|
else
|
|
install_file ifupdown ${DESTDIR}${CONFDIR}/network/if-up.d/shorewall 0544
|
|
install_file ifupdown ${DESTDIR}${CONFDIR}/network/if-down.d/shorewall 0544
|
|
install_file ifupdown ${DESTDIR}${CONFDIR}/network/if-post-down.d/shorewall 0544
|
|
fi
|
|
;;
|
|
suse)
|
|
if [ -z "$RPM" ]; then
|
|
if [ $configure -eq 0 ]; then
|
|
mkdir -p ${DESTDIR}${SYSCONFDIR}/network/if-up.d/
|
|
mkdir -p ${DESTDIR}${SYSCONFDIR}/network/if-down.d/
|
|
fi
|
|
|
|
install_file ifupdown ${DESTDIR}${SYSCONFDIR}/network/if-up.d/shorewall 0544
|
|
install_file ifupdown ${DESTDIR}${SYSCONFDIR}/network/if-down.d/shorewall 0544
|
|
fi
|
|
;;
|
|
redhat)
|
|
if [ -z "$DESTDIR" ]; then
|
|
install_local=
|
|
|
|
if [ -f ${SBINDIR}/ifup-local -o -f ${SBINDIR}/ifdown-local ]; then
|
|
if ! grep -qF Shorewall-based ${SBINDIR}/ifup-local || ! grep -qF Shorewall-based ${SBINDIR}/ifdown-local; then
|
|
echo "WARNING: ${SBINDIR}/ifup-local and/or ${SBINDIR}/ifdown-local already exist; up/down events will not be handled"
|
|
else
|
|
install_local=Yes
|
|
fi
|
|
else
|
|
install_local=Yes
|
|
fi
|
|
|
|
if [ -n "$install_local" ]; then
|
|
install_file ifupdown ${DESTDIR}${SBINDIR}/ifup-local 0544
|
|
install_file ifupdown ${DESTDIR}${SBINDIR}/ifdown-local 0544
|
|
fi
|
|
fi
|
|
;;
|
|
esac
|
|
|
|
if [ -z "$DESTDIR" ]; then
|
|
if [ $configure -eq 1 -a -n "first_install" ]; then
|
|
if [ $HOST = debian ]; then
|
|
if [ -n "$SERVICEDIR" ]; then
|
|
if systemctl enable ${PRODUCT}.service; then
|
|
echo "Shorewall Init will start automatically at boot"
|
|
fi
|
|
elif mywhich insserv; then
|
|
if insserv ${INITDIR}/shorewall-init; then
|
|
echo "Shorewall Init will start automatically at boot"
|
|
else
|
|
cant_autostart
|
|
fi
|
|
elif mywhich update-rc.d ; then
|
|
if update-rc.d $PRODUCT enable; then
|
|
echo "$PRODUCT will start automatically at boot"
|
|
echo "Set startup=1 in ${CONFDIR}/default/$PRODUCT to enable"
|
|
else
|
|
cant_autostart
|
|
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 [ $HOST = gentoo ]; then
|
|
# On Gentoo, a service must be enabled manually by the user,
|
|
# not by the installer
|
|
/bin/true
|
|
else
|
|
if [ -n "$SERVICEDIR" ]; then
|
|
if systemctl enable shorewall-init.service; then
|
|
echo "Shorewall Init will start automatically at boot"
|
|
fi
|
|
elif [ -x ${SBINDIR}/insserv -o -x /usr${SBINDIR}/insserv ]; then
|
|
if insserv ${INITDIR}/shorewall-init ; then
|
|
echo "Shorewall Init will start automatically at boot"
|
|
else
|
|
cant_autostart
|
|
fi
|
|
elif [ -x ${SBINDIR}/chkconfig -o -x /usr${SBINDIR}/chkconfig ]; then
|
|
if chkconfig --add shorewall-init ; then
|
|
echo "Shorewall Init will start automatically in run levels as follows:"
|
|
chkconfig --list shorewall-init
|
|
else
|
|
cant_autostart
|
|
fi
|
|
elif [ -x ${SBINDIR}/rc-update ]; then
|
|
if rc-update add shorewall-init default; then
|
|
echo "Shorewall Init will start automatically at boot"
|
|
else
|
|
cant_autostart
|
|
fi
|
|
elif [ $HOST = openwrt -a -f ${CONFDIR}/rc.common ]; then
|
|
/etc/init.d/$PRODUCT enable
|
|
if /etc/init.d/shorewall-init enabled; then
|
|
echo "$Product will start automatically at boot"
|
|
else
|
|
cant_autostart
|
|
fi
|
|
else
|
|
cant_autostart
|
|
fi
|
|
fi
|
|
fi
|
|
else
|
|
if [ $configure -eq 1 -a -n "$first_install" ]; then
|
|
if [ $HOST = debian ]; then
|
|
if [ -n "${DESTDIR}" ]; then
|
|
mkdir -p ${DESTDIR}/etc/rcS.d
|
|
fi
|
|
|
|
ln -sf ../init.d/shorewall-init ${DESTDIR}${CONFDIR}/rcS.d/S38shorewall-init
|
|
echo "Shorewall Init will start automatically at boot"
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
[ -z "${DESTDIR}" ] && [ ! -f ~/.shorewallrc ] && cp ${SHAREDIR}/shorewall/shorewallrc .
|
|
|
|
if [ -d ${DESTDIR}/etc/ppp ]; then
|
|
case $HOST in
|
|
debian|suse)
|
|
for directory in ip-up.d ip-down.d ipv6-up.d ipv6-down.d; do
|
|
mkdir -p ${DESTDIR}/etc/ppp/$directory #SuSE doesn't create the IPv6 directories
|
|
cp -fp ${DESTDIR}${LIBEXECDIR}/shorewall-init/ifupdown ${DESTDIR}${CONFDIR}/ppp/$directory/shorewall
|
|
done
|
|
;;
|
|
redhat)
|
|
#
|
|
# Must use the dreaded ip_xxx.local file
|
|
#
|
|
for file in ip-up.local ip-down.local; do
|
|
FILE=${DESTDIR}/etc/ppp/$file
|
|
if [ -f $FILE ]; then
|
|
if grep -qF Shorewall-based $FILE ; then
|
|
cp -fp ${DESTDIR}${LIBEXECDIR}/shorewall-init/ifupdown $FILE
|
|
else
|
|
echo "$FILE already exists -- ppp devices will not be handled"
|
|
break
|
|
fi
|
|
else
|
|
cp -fp ${DESTDIR}${LIBEXECDIR}/shorewall-init/ifupdown $FILE
|
|
fi
|
|
done
|
|
;;
|
|
esac
|
|
fi
|
|
#
|
|
# Report Success
|
|
#
|
|
echo "shorewall Init Version $VERSION Installed"
|