commit - d4fb21f3542ee2a42aecdddc73a76a6ff41fcacd
commit + 75ef4e14e0a3e08eec9ec454a2749711ccaa6c2e
blob - 25e27872bd143d05bef96e4d169edc180d3c69df
blob + 561f765ca1d2000ad526c2c58d3d77bfdc8f207e
--- contrib/Debian/rules
+++ contrib/Debian/rules
$(CURDIR)/contrib/ngircd.logcheck \
$(CURDIR)/debian/ngircd/etc/logcheck/ignore.d.paranoid/ngircd
+# Install the fail2ban configuration.
+ install -o root -g root -m 0644 -D \
+ $(CURDIR)/contrib/ngircd-fail2ban.conf \
+ $(CURDIR)/debian/ngircd/etc/fail2ban/filter.d/ngircd.conf
+
# Make lintian happy :-)
rm $(CURDIR)/debian/ngircd/usr/share/doc/ngircd/COPYING
mv $(CURDIR)/debian/ngircd/usr/share/doc/ngircd/ChangeLog \
blob - f2d9901240b50c75e129a15cd75b524eff561261
blob + cd2eb05e85479f7a947544b7a52f7441e75d6929
--- contrib/Makefile.am
+++ contrib/Makefile.am
Dockerfile \
ngindent.sh \
ngircd-bsd.sh \
+ ngircd-fail2ban.conf \
ngIRCd-Logo.gif \
ngircd-redhat.init \
ngircd.logcheck \
blob - fdd46495c0ce6bb068ac97c29cd239686dcd28a8
blob + 5ab57690b3cac6218c720a094f45828ae77309fb
--- contrib/README.md
+++ contrib/README.md
- `ngircd-bsd.sh`: Start/stop script for FreeBSD.
+- `ngircd-fail2ban.conf`: fail2ban(1) filter configuration for ngIRCd.
+
- `ngircd-redhat.init`: Start/stop script for old(er) RedHat-based
distributions (like CentOS and Fedora), which did _not_ use systemd(8).
blob - /dev/null
blob + c9903e0c5e7da6ad84d8d40c6eb6ed69de3d941b (mode 644)
--- /dev/null
+++ contrib/ngircd-fail2ban.conf
+# Fail2ban filter for ngIRCd
+#
+# Put into /etc/fail2ban/filter.d/ngircd.conf and enable in your jail.local
+# configuration like this:
+#
+# [ngircd]
+# enabled = true
+# backend = systemd
+#
+
+[INCLUDES]
+
+before = common.conf
+
+[DEFAULT]
+
+_daemon = ngircd
+
+[Definition]
+
+failregex = ^%(__prefix_line)sRefused connection from <ADDR> on socket \d+:
+
+[Init]
+
+journalmatch = _SYSTEMD_UNIT=ngircd.service + _COMM=ngircd