Skip to main content

Shows geolocation of the IPs of the failed attempts recorded by fail2ban

Project description

fail2bangeolocation

Shows geolocation of failed attempts registered by fail2ban.
It's useful to know from which locations you are being attacked the most.
You can group locations by country or by country and by city.

GitHub repo file count GitHub code size in bytes GitHub repo size

PyPI PyPI - Python Version PyPI - Implementation PyPI - Wheel PyPI - Downloads

GitHub issues GitHub closed issues GitHub pull requests GitHub closed pull requests GitHub all releases

GitHub

Screenshots

  • Grouped by country
Output grouped by country
  • Grouped by country and city
Output grouped by country and city

reallyfreegeoip.org

IP geolocation is done through reallyfreegeoip.org. This means you will need an active internet connection in order to geolocate the IPs.

Installation

You can install fail2bangeolocation via pipx:

Installation as user

$ pipx install fail2bangeolocation

Installation as root

$ sudo su
# pipx install fail2bangeolocation

Usage

  • You can run fail2bangeolocation directly from the command line interface:

    fail2bangeolocation [-h] [-c] {fail2ban,log,server}
    
  • fail2bangeolocation arguments

    usage: fail2bangeolocation.py [-h] [-c] {fail2ban,log,server} ...
    
    Shows geolocation of failed attempts registered by fail2ban
    
    positional arguments:
      {fail2ban,log,server}
                            These options are mutually exclusive
        fail2ban            analyze all banned IPs by fail2ban (from fail2ban output)
        log                 analyze a fail2ban log file. Use "log -h" to see more options
        server              analyze all banned IPs by fail2ban (e.g. "server sshd")
    
    optional arguments:
      -h, --help            show this help message and exit
      -c, --show-city       group IPs by country and city 
    
  • Analyze all IPs registered by fail2ban

    :warning: Requires root privileges

    Run fail2bangeolocation using the fail2ban argument:

    $ sudo su
    # fail2bangeolocation fail2ban
    
  • Analyze all IPs registered by fail2ban for a given jailed server/service, e.g. sshd

    :warning: Requires root privileges
    Run fail2bangeolocation with the server argument and the jailed server name:

    $sudo su
    # fail2bangeolocation server sshd
    
  • Analyze a log file

    :warning: May require root privileges depending on the file to be analyzed
    Run fail2bangeolocation with the log argument and the path to the log file:

    fail2bangeolocation log /var/log/fai2ban.log
    

    You can also geolocate the unbanned IPs contained in the log adding the -u argument:

    fail2bangeolocation log -u /var/log/fai2ban.log
    
  • Group the output by country and city

    Run fail2bangeolocation with "-c" as first argument:

    fail2bangeolocation -c {fail2ban,log,server}
    

Troubleshooting

In case of any problem, you create an issue.

Discussions

If you want ask (or answer) a question, leave an opinion or have an open-ended conversation you can create (or join) a discussion.

Support

If you find this application useful you can star this repo.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

fail2bangeolocation-2.0.9.tar.gz (57.5 kB view details)

Uploaded Source

Built Distribution

fail2bangeolocation-2.0.9-py3-none-any.whl (38.8 kB view details)

Uploaded Python 3

File details

Details for the file fail2bangeolocation-2.0.9.tar.gz.

File metadata

  • Download URL: fail2bangeolocation-2.0.9.tar.gz
  • Upload date:
  • Size: 57.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/5.1.1 CPython/3.12.7

File hashes

Hashes for fail2bangeolocation-2.0.9.tar.gz
Algorithm Hash digest
SHA256 cee5c7cb59e6b6906b817417b2e5d74c506af3f752e70cadb3d8996b5d9ff021
MD5 be795f27ae51242b4fffd5316a161c26
BLAKE2b-256 b5a166a456a9c2070d19e4f44cb65634d2748dd9e60c4d679fb1a17368fb2848

See more details on using hashes here.

Provenance

The following attestation bundles were made for fail2bangeolocation-2.0.9.tar.gz:

Publisher: publish.yml on rubenhortas/fail2bangeolocation

Attestations:

File details

Details for the file fail2bangeolocation-2.0.9-py3-none-any.whl.

File metadata

File hashes

Hashes for fail2bangeolocation-2.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 ab184aaaa6ef532eb6723056573e8d895ddc5e2b695caaf9e9ec888e57196f7d
MD5 0623ec9b729ad7dcd24272a300e08eea
BLAKE2b-256 af253e1ad0f2ca998a3647e1a6e8b44d103f1695426710c4ea07f56f43ec3542

See more details on using hashes here.

Provenance

The following attestation bundles were made for fail2bangeolocation-2.0.9-py3-none-any.whl:

Publisher: publish.yml on rubenhortas/fail2bangeolocation

Attestations:

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page