You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
50 lines
1.5 KiB
50 lines
1.5 KiB
3 months ago
|
<?php
|
||
|
/**
|
||
|
* Plugin to integrate Roundcube into Mailcow-Dockerizeds' Fail2Ban
|
||
|
*
|
||
|
* @version 1.0
|
||
|
* @author Snep <snep@diskcat.com>
|
||
|
* @license MIT
|
||
|
* @url https://git.diskcat.com/Resneptacle/roundcube-mailcow-dockerized-fail2ban
|
||
|
*
|
||
|
* Inspired by https://github.com/mattrude/rc-plugin-fail2ban
|
||
|
*/
|
||
|
|
||
|
|
||
|
class mailcow_f2b extends rcube_plugin {
|
||
|
|
||
|
function init () {
|
||
|
$this -> add_hook ('login_failed', [ $this, 'log_failed_attempt' ]);
|
||
|
}
|
||
|
|
||
|
function log_failed_attempt ($args) {
|
||
|
// Try to get Redis connection data from Roundcube config
|
||
|
$redis_host = rcmail::get_instance () -> config -> get ('mailcow_f2b_redis_host');
|
||
|
$redis_port = rcmail::get_instance () -> config -> get ('mailcow_f2b_redis_port');
|
||
|
|
||
|
// Use MailCow defaults for Redis connection if not set in Roundcube config
|
||
|
if (is_null ($redis_host)) $redis_host = "redis-mailcow";
|
||
|
if (is_null ($redis_port)) $redis_port = 6379;
|
||
|
|
||
|
$log_entry = "roundcube: failed login from {$_SERVER['REMOTE_ADDR']} for user {$args['user']}";
|
||
|
|
||
|
// Write log entry to PHP error log
|
||
|
error_log ("{$log_entry}\n");
|
||
|
|
||
|
// Open Redis connection
|
||
|
$redis = new Redis ();
|
||
|
try {
|
||
|
$redis -> connect ($redis_host, $redis_port);
|
||
|
} catch (Exception $e) {
|
||
|
error_log ("roundcube: failed to connect to redis database at {$redis_host}:{$redis_port} because " . $e -> getMessage () . "\n");
|
||
|
}
|
||
|
|
||
|
// Write log entry to Redis DB
|
||
|
$redis -> publish ("F2B_CHANNEL", $log_entry);
|
||
|
|
||
|
// Close Redis connection
|
||
|
$redis -> close ();
|
||
|
}
|
||
|
|
||
|
}
|