innoweb/silverstripe-fail2ban

Logs failed logins into a separate log file to be consumed by Fail2ban to block IPs with failed logins.

Installs: 18

Dependents: 0

Suggesters: 0

Security: 0

Stars: 0

Watchers: 2

Forks: 0

Open Issues: 0

Type:silverstripe-vendormodule

1.0.0 2024-10-14 22:50 UTC

This package is auto-updated.

Last update: 2025-01-12 22:18:51 UTC


README

Version License

Overview

Logs failed logins into a separate log file to be consumed by Fail2ban to block IPs with failed logins

Requirements

  • Silverstripe Framework 5.x

Installation

Install the module using composer:

composer require innoweb/silverstripe-fail2ban

Then run dev/build.

configure Silverstripe log file location

By default, the login attempts are logged to silverstripe-login.log in the base folder of your project.

You can change the log file location by adding the following Silverstripe config:

Innoweb\SilverstripeFail2Ban\Extensions\LoginAttemptExtension:
  login_logfile: 'your/path/to/silverstripe-login.log'

Alternatively, you can set the log file location in your .env file:

FAIL2BAN_LOGIN_LOGFILE=your/path/to/silverstripe-login.log

configure Fail2ban jail

Add the Fail2ban filter to /etc/fail2ban/filter.d/silverstripe-login.conf:

# Fail2Ban filter for silverstripe logins

[INCLUDES]

before = common.conf

[Definition]

datepattern = \[%%Y-%%m-%%dT%%H:%%M:%%S.%%f%%z\]

failregex = ^ ss-fail2ban\.INFO: Login Failure - host: <HOST> \[\] \[\]$

ignoreregex = 

# DEV Notes:
#
# pattern :     [2024-10-14T11:47:16.259637+11:00] ss-fail2ban.INFO: Login Failure - host: 127.0.0.1 [] []
#               [2024-10-14T11:47:16.259637+11:00] ss-fail2ban.INFO: Login Failure - host: 127.0.0.1 [] []

Add the following to your /etc/fail2ban/jail.local to enable the filter:

[silverstripe-login]
enabled	= true
logpath = /your/path/to/silverstripe-login.log

License

BSD 3-Clause License, see License