mirror of https://github.com/fail2ban/fail2ban
- Removed user-defined time regex/pattern.
git-svn-id: https://fail2ban.svn.sourceforge.net/svnroot/fail2ban/branches/FAIL2BAN-0_8@639 a942ae1a-1317-0410-a47c-b1dcaea8d605_tent/ipv6_via_aInfo
parent
eae650fdfc
commit
adcc2ef386
|
@ -52,8 +52,6 @@ protocol = [
|
||||||
["set <JAIL> delignoreip <IP>", "removes <IP> from the ignore list of <JAIL>"],
|
["set <JAIL> delignoreip <IP>", "removes <IP> from the ignore list of <JAIL>"],
|
||||||
["set <JAIL> addlogpath <FILE>", "adds <FILE> to the monitoring list of <JAIL>"],
|
["set <JAIL> addlogpath <FILE>", "adds <FILE> to the monitoring list of <JAIL>"],
|
||||||
["set <JAIL> dellogpath <FILE>", "removes <FILE> to the monitoring list of <JAIL>"],
|
["set <JAIL> dellogpath <FILE>", "removes <FILE> to the monitoring list of <JAIL>"],
|
||||||
["set <JAIL> timeregex <REGEX>", "sets the regular expression <REGEX> to match the date format for <JAIL>. This will disable the autodetection feature."],
|
|
||||||
["set <JAIL> timepattern <PATTERN>", "sets the pattern <PATTERN> to match the date format for <JAIL>. This will disable the autodetection feature."],
|
|
||||||
["set <JAIL> addfailregex <REGEX>", "adds the regular expression <REGEX> which must match failures for <JAIL>"],
|
["set <JAIL> addfailregex <REGEX>", "adds the regular expression <REGEX> which must match failures for <JAIL>"],
|
||||||
["set <JAIL> delfailregex <INDEX>", "removes the regular expression at <INDEX> for failregex"],
|
["set <JAIL> delfailregex <INDEX>", "removes the regular expression at <INDEX> for failregex"],
|
||||||
["set <JAIL> addignoreregex <REGEX>", "adds the regular expression <REGEX> which should match pattern to exclude for <JAIL>"],
|
["set <JAIL> addignoreregex <REGEX>", "adds the regular expression <REGEX> which should match pattern to exclude for <JAIL>"],
|
||||||
|
|
|
@ -39,7 +39,6 @@ class DateDetector:
|
||||||
def __init__(self):
|
def __init__(self):
|
||||||
self.__lock = Lock()
|
self.__lock = Lock()
|
||||||
self.__templates = list()
|
self.__templates = list()
|
||||||
self.__defTemplate = DateStrptime()
|
|
||||||
|
|
||||||
def addDefaultTemplate(self):
|
def addDefaultTemplate(self):
|
||||||
try:
|
try:
|
||||||
|
@ -100,22 +99,7 @@ class DateDetector:
|
||||||
def getTemplates(self):
|
def getTemplates(self):
|
||||||
return self.__templates
|
return self.__templates
|
||||||
|
|
||||||
def setDefaultRegex(self, value):
|
|
||||||
self.__defTemplate.setRegex(value)
|
|
||||||
|
|
||||||
def getDefaultRegex(self):
|
|
||||||
return self.__defTemplate.getRegex()
|
|
||||||
|
|
||||||
def setDefaultPattern(self, value):
|
|
||||||
self.__defTemplate.setPattern(value)
|
|
||||||
|
|
||||||
def getDefaultPattern(self):
|
|
||||||
return self.__defTemplate.getPattern()
|
|
||||||
|
|
||||||
def matchTime(self, line):
|
def matchTime(self, line):
|
||||||
if self.__defTemplate.isValid():
|
|
||||||
return self.__defTemplate.matchDate(line)
|
|
||||||
else:
|
|
||||||
try:
|
try:
|
||||||
self.__lock.acquire()
|
self.__lock.acquire()
|
||||||
for template in self.__templates:
|
for template in self.__templates:
|
||||||
|
@ -127,13 +111,6 @@ class DateDetector:
|
||||||
self.__lock.release()
|
self.__lock.release()
|
||||||
|
|
||||||
def getTime(self, line):
|
def getTime(self, line):
|
||||||
if self.__defTemplate.isValid():
|
|
||||||
try:
|
|
||||||
date = self.__defTemplate.getDate(line)
|
|
||||||
return date
|
|
||||||
except ValueError:
|
|
||||||
return None
|
|
||||||
else:
|
|
||||||
try:
|
try:
|
||||||
self.__lock.acquire()
|
self.__lock.acquire()
|
||||||
for template in self.__templates:
|
for template in self.__templates:
|
||||||
|
@ -141,7 +118,6 @@ class DateDetector:
|
||||||
date = template.getDate(line)
|
date = template.getDate(line)
|
||||||
if date == None:
|
if date == None:
|
||||||
continue
|
continue
|
||||||
template.incHits()
|
|
||||||
return date
|
return date
|
||||||
except ValueError:
|
except ValueError:
|
||||||
pass
|
pass
|
||||||
|
|
|
@ -25,7 +25,7 @@ __copyright__ = "Copyright (c) 2004 Cyril Jaquier"
|
||||||
__license__ = "GPL"
|
__license__ = "GPL"
|
||||||
|
|
||||||
from failmanager import FailManager
|
from failmanager import FailManager
|
||||||
from failticket import FailTicket
|
from ticket import FailTicket
|
||||||
from jailthread import JailThread
|
from jailthread import JailThread
|
||||||
from datedetector import DateDetector
|
from datedetector import DateDetector
|
||||||
from mytime import MyTime
|
from mytime import MyTime
|
||||||
|
@ -122,40 +122,6 @@ class Filter(JailThread):
|
||||||
except ValueError:
|
except ValueError:
|
||||||
return False
|
return False
|
||||||
|
|
||||||
##
|
|
||||||
# Set the regular expression which matches the time.
|
|
||||||
#
|
|
||||||
# @param value the regular expression
|
|
||||||
|
|
||||||
def setTimeRegex(self, value):
|
|
||||||
self.dateDetector.setDefaultRegex(value)
|
|
||||||
logSys.info("Set default regex = %s" % value)
|
|
||||||
|
|
||||||
##
|
|
||||||
# Get the regular expression which matches the time.
|
|
||||||
#
|
|
||||||
# @return the regular expression
|
|
||||||
|
|
||||||
def getTimeRegex(self):
|
|
||||||
return self.dateDetector.getDefaultRegex()
|
|
||||||
|
|
||||||
##
|
|
||||||
# Set the time pattern.
|
|
||||||
#
|
|
||||||
# @param value the time pattern
|
|
||||||
|
|
||||||
def setTimePattern(self, value):
|
|
||||||
self.dateDetector.setDefaultPattern(value)
|
|
||||||
logSys.info("Set default pattern = %s" % value)
|
|
||||||
|
|
||||||
##
|
|
||||||
# Get the time pattern.
|
|
||||||
#
|
|
||||||
# @return the time pattern
|
|
||||||
|
|
||||||
def getTimePattern(self):
|
|
||||||
return self.dateDetector.getDefaultPattern()
|
|
||||||
|
|
||||||
##
|
##
|
||||||
# Add a regular expression which matches the failure.
|
# Add a regular expression which matches the failure.
|
||||||
#
|
#
|
||||||
|
|
|
@ -73,8 +73,8 @@ class Server:
|
||||||
logSys.debug("Starting communication")
|
logSys.debug("Starting communication")
|
||||||
try:
|
try:
|
||||||
self.__asyncServer.start(sock, force)
|
self.__asyncServer.start(sock, force)
|
||||||
except AsyncServerException:
|
except AsyncServerException, e:
|
||||||
logSys.error("Could not start server")
|
logSys.error("Could not start server: %s", e)
|
||||||
logSys.info("Exiting Fail2ban")
|
logSys.info("Exiting Fail2ban")
|
||||||
|
|
||||||
def quit(self):
|
def quit(self):
|
||||||
|
@ -148,18 +148,6 @@ class Server:
|
||||||
def getLogPath(self, name):
|
def getLogPath(self, name):
|
||||||
return self.__jails.getFilter(name).getLogPath()
|
return self.__jails.getFilter(name).getLogPath()
|
||||||
|
|
||||||
def setTimeRegex(self, name, value):
|
|
||||||
self.__jails.getFilter(name).setTimeRegex(value)
|
|
||||||
|
|
||||||
def getTimeRegex(self, name):
|
|
||||||
return self.__jails.getFilter(name).getTimeRegex()
|
|
||||||
|
|
||||||
def setTimePattern(self, name, value):
|
|
||||||
self.__jails.getFilter(name).setTimePattern(value)
|
|
||||||
|
|
||||||
def getTimePattern(self, name):
|
|
||||||
return self.__jails.getFilter(name).getTimePattern()
|
|
||||||
|
|
||||||
def setFindTime(self, name, value):
|
def setFindTime(self, name, value):
|
||||||
self.__jails.getFilter(name).setFindTime(value)
|
self.__jails.getFilter(name).setFindTime(value)
|
||||||
|
|
||||||
|
|
|
@ -135,14 +135,6 @@ class Transmitter:
|
||||||
value = command[2]
|
value = command[2]
|
||||||
self.__server.delLogPath(name, value)
|
self.__server.delLogPath(name, value)
|
||||||
return self.__server.getLogPath(name)
|
return self.__server.getLogPath(name)
|
||||||
elif command[1] == "timeregex":
|
|
||||||
value = command[2]
|
|
||||||
self.__server.setTimeRegex(name, value)
|
|
||||||
return self.__server.getTimeRegex(name)
|
|
||||||
elif command[1] == "timepattern":
|
|
||||||
value = command[2]
|
|
||||||
self.__server.setTimePattern(name, value)
|
|
||||||
return self.__server.getTimePattern(name)
|
|
||||||
elif command[1] == "addfailregex":
|
elif command[1] == "addfailregex":
|
||||||
value = command[2]
|
value = command[2]
|
||||||
self.__server.addFailRegex(name, value)
|
self.__server.addFailRegex(name, value)
|
||||||
|
@ -229,10 +221,6 @@ class Transmitter:
|
||||||
return self.__server.getLogPath(name)
|
return self.__server.getLogPath(name)
|
||||||
elif command[1] == "ignoreip":
|
elif command[1] == "ignoreip":
|
||||||
return self.__server.getIgnoreIP(name)
|
return self.__server.getIgnoreIP(name)
|
||||||
elif command[1] == "timeregex":
|
|
||||||
return self.__server.getTimeRegex(name)
|
|
||||||
elif command[1] == "timepattern":
|
|
||||||
return self.__server.getTimePattern(name)
|
|
||||||
elif command[1] == "failregex":
|
elif command[1] == "failregex":
|
||||||
return self.__server.getFailRegex(name)
|
return self.__server.getFailRegex(name)
|
||||||
elif command[1] == "ignoreregex":
|
elif command[1] == "ignoreregex":
|
||||||
|
|
Loading…
Reference in New Issue