forked from extern/shorewall_code
b66929a65e
1) Elimination of the "shorewall monitor" command. 2) The /etc/shorewall/ipsec and /etc/shorewall/zones file are combined into a single /etc/shorewall/zones file. This is done in an upwardly-compatible way so that current users can continue to use their existing files. 3) Support has been added for the arp_ignore interface option. 4) DROPINVALID has been removed from shorewall.conf. Behavior is as if DROPINVALID=No was specified. 5) The 'nobogons' option and BOGON_LOG_LEVEL are removed. 6) Error and warning messages have been made easier to spot by using capitalization (e.g., ERROR: and WARNING:). 7) The /etc/shorewall/policy file now contains a new connection policy and a policy for ESTABLISHED packets. Useful for users of snort-inline who want to pass all packets to the QUEUE target. 8) A new 'critical' option has been added to /etc/shorewall/routestopped. Shorewall insures communication between the firewall and 'critical' hosts throughout start, restart, stop and clear. Useful for diskless firewall's with NFS-mounted file systems, LDAP servers, Crossbow, etc. 9) Macros. Macros are very similar to actions but are easier to use, allow parameter substitution and are more efficient. Almost all of the standard actions have been converted to macros in the EXPERIMENTAL branch. 10) The default value of ADD_IP_ALIASES in shorewall.conf is changed to No. 11) If you have 'make' installed on your firewall, then when you use the '-f' option to 'shorewall start' (as happens when you reboot), if your /etc/shorewall/ directory contains files that were modified after Shorewall was last restarted then Shorewall is started using the config files rather than using the saved configuration. git-svn-id: https://shorewall.svn.sourceforge.net/svnroot/shorewall/trunk@2409 fbd18981-670d-0410-9b5c-8dc0c1a9a2bb
110 lines
2.7 KiB
Bash
Executable File
110 lines
2.7 KiB
Bash
Executable File
#!/bin/sh
|
|
#
|
|
# Script to back uninstall Shoreline Firewall
|
|
#
|
|
# This program is under GPL [http://www.gnu.org/copyleft/gpl.htm]
|
|
#
|
|
# (c) 2000,2001,2002,2003,2004,2005 - Tom Eastep (teastep@shorewall.net)
|
|
#
|
|
# Shorewall documentation is available at http://shorewall.sourceforge.net
|
|
#
|
|
# This program is free software; you can redistribute it and/or modify
|
|
# it under the terms of Version 2 of the GNU General Public License
|
|
# as published by the Free Software Foundation.
|
|
#
|
|
# 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, write to the Free Software
|
|
# Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA
|
|
#
|
|
# Usage:
|
|
#
|
|
# You may only use this script to uninstall the version
|
|
# shown below. Simply run this script to remove Shorewall Firewall
|
|
|
|
VERSION=2.5.0
|
|
|
|
usage() # $1 = exit status
|
|
{
|
|
ME=$(basename $0)
|
|
echo "usage: $ME"
|
|
exit $1
|
|
}
|
|
|
|
qt()
|
|
{
|
|
"$@" >/dev/null 2>&1
|
|
}
|
|
|
|
restore_file() # $1 = file to restore
|
|
{
|
|
if [ -f ${1}-shorewall.bkout ]; then
|
|
if (mv -f ${1}-shorewall.bkout $1); then
|
|
echo
|
|
echo "$1 restored"
|
|
else
|
|
exit 1
|
|
fi
|
|
fi
|
|
}
|
|
|
|
remove_file() # $1 = file to restore
|
|
{
|
|
if [ -f $1 -o -L $1 ] ; then
|
|
rm -f $1
|
|
echo "$1 Removed"
|
|
fi
|
|
}
|
|
|
|
if [ -f /usr/share/shorewall/version ]; then
|
|
INSTALLED_VERSION="$(cat /usr/share/shorewall/version)"
|
|
if [ "$INSTALLED_VERSION" != "$VERSION" ]; then
|
|
echo "WARNING: Shorewall Version $INSTALLED_VERSION is installed"
|
|
echo " and this is the $VERSION uninstaller."
|
|
VERSION="$INSTALLED_VERSION"
|
|
fi
|
|
else
|
|
echo "WARNING: Shorewall Version $VERSION is not installed"
|
|
VERSION=""
|
|
fi
|
|
|
|
echo "Uninstalling shorewall $VERSION"
|
|
|
|
if qt iptables -L shorewall -n; then
|
|
/sbin/shorewall clear
|
|
fi
|
|
|
|
if [ -L /usr/share/shorewall/init ]; then
|
|
FIREWALL=$(ls -l /usr/share/shorewall/init | sed 's/^.*> //')
|
|
else
|
|
FIREWALL=/etc/init.d/shorewall
|
|
fi
|
|
|
|
if [ -n "$FIREWALL" ]; then
|
|
if [ -x /sbin/insserv -o -x /usr/sbin/insserv ]; then
|
|
insserv -r $FIREWALL
|
|
elif [ -x /sbin/chkconfig -o -x /usr/sbin/chkconfig ]; then
|
|
chkconfig --del $(basename $FIREWALL)
|
|
else
|
|
rm -f /etc/rc*.d/*$(basename $FIREWALL)
|
|
fi
|
|
|
|
remove_file $FIREWALL
|
|
rm -f ${FIREWALL}-*.bkout
|
|
fi
|
|
|
|
rm -f /sbin/shorewall
|
|
rm -f /sbin/shorewall-*.bkout
|
|
|
|
rm -rf /etc/shorewall
|
|
rm -rf /var/lib/shorewall
|
|
rm -rf /usr/share/shorewall
|
|
|
|
echo "Shorewall Uninstalled"
|
|
|
|
|