Fail2ban Joomla

Stack Overflow for Teams – Collaborate and share knowledge with a private group. Create a free Team. Fail2ban is a python project that phrases logs through regular expressions (filters) and applies a configured action when it matches. Usually, those actions are firewall related actions. Fail2ban configuration is based on jails.

One of the biggest problems I have seen with Joomla is that the well-known administrator is public. You may protect it with some .htaccess configuration (I will publish some of that later), but the problem is that since most Joomla websites are hosted and residential Internet providers give you dynamic IP, protecting by IP is useless.

Fail2ban Joomla

On the bright side, remember when you are installing Joomla, the super admin username is not any more admin. You can select a different one, which it makes really difficult to guess it. However, there is still the thread of the DoS, many failed attempts may run out of resources your Web server, and this is why we need fail2ban.

Usually, this should not be a big deal, but since ISPConfig takes over many configurations it is important to take note of this. ISPConfig 3 will not log anything in the common log places (a.k.a /var/log/httpd), instead, it will store the logs related to your website into the /var/www/yourwebsite/logs/ directory. Because of that, using the classic fail2ban Joomla plugin will not work for a whole server; it could work if you are only interested on protecting one website and you hardcode the log path name.

The Syslog Joomla Plugin

I have found this plugin that it seems to work. It injects failed logging attempts into the syslog. As I am using CentOS and Syslog is forwarded to the journal system I am able to use fail2ban with the systemd backend.

The plugin name is Syslog AuthLog, but you will not be able to install from the Joomla Web Installer, the link is broken. You will need to go to the developer's Github page and install it manually.

Configuring Fail2ban to Block Failed Attempts

Assuming you already have your fail2ban up and running, the first step is adding a valid filter expression. Edit or create the file filter.d/joomla-admin.conf with the following content:

failregex = .* WARNING login UNKNOWN ADMIN .* from $

Later, edit your jail.local and add the following:

enabled = true
port = http,ftp
filter = joomla-admin
maxretry = 2
bantime = 84600
findtime = 21150
action = iptables-allports[name=joomla, protocol=all]
backend = systemd

Change this configurations to fit your needs. You are done, restart fail2ban.

Good luck!

Please enable JavaScript to view the comments powered by comments powered by Disqus

If you are managing a farm of clusters with a common mission, for example, a set VoIP cluster or a Web Hosting farm, One of the hardest things is the repetitive management work. In a 100-server cluster environment, when an attacker hits one node, eventually that attacker will get to another node and continue the attack. One of the biggest exposures here is that usually (not always), cluster's nodes share a common database. Hitting a winning vulnerability it is just a matter of time for the other peers.

With all this said, I will explain my approach that tries to fix this situation. At the end of this reading, you will understand how to have a proactive secured environment.

First, some security concepts.

What is Honeypot?

In the security field, a honeypot is a security concept that homologates to the image of a bear eating honey. The bear is so busy eating the honey that he doesn't pay attention to anything else. With this said, an attacker will keep his activity on a server that is designed to be unprotected.

Some authors instead of comparing against a bear, use files. Flies got stuck because of the honey thickness and they won't turn to the next server. Anyway, any of those analogies matches what a honeypot is for.

Honeypots are also used to gather intelligence about new attack techniques, but in this case, we are just using it for its very first purpose: keeping attackers busy and disclosing them.

What is Fail2ban and How Fail2ban works?

Fail2ban is a python project that phrases logs through regular expressions (filters) and applies a configured action when it matches. Usually, those actions are firewall related actions. Fail2ban configuration is based on jails. A jail is a set of parameters where you specify the filter, the source log, the action, the quarantine time and other parameters.

Fail2ban by itself operates at a reactive approach. The attacker needs to fail n times before getting blocked (usually 3). But if we build a fail2ban cluster, the reactiveness of fail2ban could be converted to proactiveness. And this is what we want to accomplish.

Fail2ban Joomla

Clustering Fail2ban for a Proactive Security Approach

In a given scenario, you have several servers. They could be part of the same cluster (such as VoIP or Web) or each one may have its own mission. You optionally have a honeypot server. An attacker will eventually find that honeypot (which is easier since it is unprotected on purpose) and any other production server with an open port to the Internet. Mp3 converter.

Each production server has a fail2ban daemon and a rsyslog daemon running on it, but what it makes this interesting is that they also report their actions to a central fail2ban cluster server. The mission of this server is to store all the information sent by the production servers' fail2ban and inform the others about a confirmed offending IP. Proactively, the other servers will block that attacker.

In this example, we have two attackers. One is kept in the honeypot server, the other is trying to hack through an email server. The honeypot server won't block the attacker; the mail server will eventually block the attacker. In both cases, the two servers will inform the fail2ban cluster server about the attempts.

In a matter of seconds, that central server will inform the rest of the servers to block that offending IP. When the attacker moves on from the mail server and it arrives at the next one (PBX server), that IP will be already blocked and any attempt of connectivity will just be dropped.

This proactive approach will keep safe your servers.

Why is it so Important these Days having a Proactive Security Approach?

These days VPS'es companies such as Digital Ocean or Vultr are very common to be the host of many companies' core servers. It is a win-win using them, they provide excellent service at a low price. However, have you realized that their autonomous system is well-known? Because of this, and the way the hacking scripts work if they start attacking IP and your server might have they will eventually get to your server. It is just a matter of time.

If you use one of these VPS providers to host the core of your business, for example, a VoIP cluster. Hacking one server usually means hacking them all. Cluster's usually share a common database. It is easier to try a winning username - password combination than a blind brute force.

So, let's just agree that having this is better than just reacting.

What are the Perfect Use Cases Scenarios for a fail2ban Cluster?

I can think about the following:

  • Websites that are balanced, such as a big Government website where it is very common the use of more than one node to host visitors
  • A VoIP Cluster, the nodes do not really know where the users are going to be registered, therefore they are ready to accept them on any node

I am pretty sure there are more scenarios.

How do I get a Distributed fail2ban Cluster in my Infrastructure?

The easiest way is by hiring me as your consultant. I will deal with the configurations to make this happens. However, if you have enough IT skills and you just need a guide, you just can visit the Bitbucket address in this article. I will be updating it.

The software has two components. A Rsyslogd configuration that reports the fail2ban.log activity to the central node and a script that sends commands to the nodes. Later, when I have finished all, I will publish an RPM for those CentOS fans out there.

Fail2ban Joomla Free

Good luck!

Please enable JavaScript to view the comments powered by comments powered by

Fail2ban Apache Joomla