4 |
- |
1 |
# Fail2Ban fitler for the Proftpd FTP daemon
|
|
|
2 |
#
|
5 |
- |
3 |
# Set "UseReverseDNS off" in proftpd.conf to avoid the need for DNS.
|
|
|
4 |
# See: http://www.proftpd.org/docs/howto/DNS.html
|
39 |
- |
5 |
# When the default locale for your system is not en_US.UTF-8
|
|
|
6 |
# on Debian-based systems be sure to add this to /etc/default/proftpd
|
|
|
7 |
# export LC_TIME="en_US.UTF-8"
|
4 |
- |
8 |
|
|
|
9 |
[INCLUDES]
|
|
|
10 |
|
|
|
11 |
before = common.conf
|
|
|
12 |
|
|
|
13 |
[Definition]
|
|
|
14 |
|
|
|
15 |
_daemon = proftpd
|
|
|
16 |
|
|
|
17 |
__suffix_failed_login = (User not authorized for login|No such user found|Incorrect password|Password expired|Account disabled|Invalid shell: '\S+'|User in \S+|Limit (access|configuration) denies login|Not a UserAlias|maximum login length exceeded).?
|
|
|
18 |
|
|
|
19 |
failregex = ^%(__prefix_line)s%(__hostname)s \(\S+\[<HOST>\]\)[: -]+ USER .*: no such user found from \S+ \[\S+\] to \S+:\S+ *$
|
|
|
20 |
^%(__prefix_line)s%(__hostname)s \(\S+\[<HOST>\]\)[: -]+ USER .* \(Login failed\): %(__suffix_failed_login)s\s*$
|
|
|
21 |
^%(__prefix_line)s%(__hostname)s \(\S+\[<HOST>\]\)[: -]+ SECURITY VIOLATION: .* login attempted\. *$
|
|
|
22 |
^%(__prefix_line)s%(__hostname)s \(\S+\[<HOST>\]\)[: -]+ Maximum login attempts \(\d+\) exceeded *$
|
|
|
23 |
|
|
|
24 |
ignoreregex =
|
|
|
25 |
|
|
|
26 |
# Author: Yaroslav Halchenko
|
|
|
27 |
# Daniel Black - hardening of regex
|