#!/usr/bin/env python # This file is part of Fail2Ban. # # Fail2Ban 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. # # Fail2Ban 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 Fail2Ban; if not, write to the Free Software # Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA # Author: Cyril Jaquier # # $Revision$ __author__ = "Cyril Jaquier" __version__ = "$Revision$" __date__ = "$Date$" __copyright__ = "Copyright (c) 2004 Cyril Jaquier" __license__ = "GPL" from distutils.core import setup from version import version from os.path import isfile, join from sys import exit, argv longdesc = ''' Fail2Ban scans log files like /var/log/pwdfail or /var/log/apache/error_log and bans IP that makes too many password failures. It updates firewall rules to reject the IP address or executes user defined commands.''' setup( name = "fail2ban", version = version, description = "Ban IPs that make too many password failure", long_description = longdesc, author = "Cyril Jaquier", author_email = "lostcontrol@users.sourceforge.net", url = "http://fail2ban.sourceforge.net", license = "GPL", platforms = "Posix", scripts = [ 'fail2ban-client', 'fail2ban-server', 'fail2ban-regex' ], py_modules = ['version'], packages = [ 'client', 'server' ], data_files = [ ('/etc/fail2ban', [ 'config/fail2ban.conf', 'config/jail.conf' ] ), ('/etc/fail2ban/filter.d', [ 'config/filter.d/vsftpd.conf', 'config/filter.d/apache-auth.conf', 'config/filter.d/sshd.conf', 'config/filter.d/couriersmtp.conf', 'config/filter.d/postfix.conf', 'config/filter.d/qmail.conf' ] ), ('/etc/fail2ban/action.d', [ 'config/action.d/iptables.conf', 'config/action.d/mail-whois.conf', 'config/action.d/dummy.conf', 'config/action.d/mail.conf', 'config/action.d/hostsdeny.conf' ] ) ] ) # Do some checks after installation # Search for obsolete files. obsoleteFiles = [] elements = { "/etc/": [ "fail2ban.conf" ], "/usr/bin/": [ "fail2ban.py" ], "/usr/lib/fail2ban/firewall/": [ "iptables.py", "ipfwadm.py", "ipfw.py" ] } for dir in elements: for f in elements[dir]: path = join(dir, f) if isfile(path): obsoleteFiles.append(path) if obsoleteFiles: print print "Obsolete files from previous Fail2Ban versions were found on " \ "your system." print "Please delete them:" print for f in obsoleteFiles: print "\t" + f print # Update config file if argv[1] == "install": print print "Please do not forget to update your configuration files." print "They are in /etc/fail2ban/." print