Skip to content

Commit

Permalink
Handle glibc version issue
Browse files Browse the repository at this point in the history
  • Loading branch information
olarriga committed Dec 27, 2022
1 parent eb2a2ec commit 2bc8329
Show file tree
Hide file tree
Showing 4 changed files with 59 additions and 44 deletions.
19 changes: 19 additions & 0 deletions Dockerfile
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
FROM golang:1.19-buster
LABEL os=linux
LABEL arch=amd64

ENV CGO_ENABLED=1

# install build & runtime dependencies
RUN apt update \
&& apt install -y --no-install-recommends \
libsystemd-dev \
&& rm -rf /var/lib/apt/lists/*

# install Taskfile
RUN sh -c "$(curl --location https://taskfile.dev/install.sh)" -- -d -b /usr/local/bin

# exception for dubious ownership
RUN git config --global --add safe.directory /go/src

WORKDIR /go/src
71 changes: 29 additions & 42 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@

The Banisher watches in real time your systemd journal and bans, via iptables, hosts who match on yours rules.

Currently hosts (IP) are banished for 3 hours (configurable in config.yml).
Currently hosts (IP) are banished for 1 hour (configurable in config.yml).

The Banisher keeps states of banished IPs in a key-value store ([badger](https://github.com/dgraph-io/badger))

Expand All @@ -17,18 +17,20 @@ __WARNING The Banisher works only with logs handled by systemd journal and is cu

### Installing

Just download the lastest binary from the [releases section](https://github.com/toorop/banisher/releases).

### Config

#### Without debian package

In the same directory than The Banisher binary, create a [YAML](https://en.wikipedia.org/wiki/YAML) file named `config.yml`.

1. Download the lastest binary from the [releases section](https://github.com/olarriga/banisher/releases).
2. Set the exec flag (`chmod +x banisher`).
3. Create a [YAML](https://en.wikipedia.org/wiki/YAML) file named `config.yml` in the same directory than The Banisher binary to define the configuration.
4. Start The Banisher (`./banisher`).

#### With the debian package

Modify the /etc/banisher.yml file according to your needs
1. Download the lastest debian package from the [releases section](https://github.com/olarriga/banisher/releases).
2. Modify the /etc/banisher.yml file to define the configuration according to your needs
3. Restart The Banisher (`systemctl restart banisher.service`).

### Config

Here is a sample:

Expand Down Expand Up @@ -92,7 +94,6 @@ Log line for [Dovecot](https://www.dovecot.org/) authentification failure looks
```text
imap-login: Disconnected (auth failed, 1 attempts in 3 secs): user=<[email protected]>, method=PLAIN, rip=XXX.XXX.XXX.XXX, lip=YYY.YYY.YYY.YYY, TLS: Disconnected, session=<n48ImrmGRP6xth/K>

```
Here is the corresponding rule:
Expand All @@ -107,9 +108,9 @@ Yes i know, it seems to too easy to be real.
#### Multiple rules ?
Of course you can have multiple rules in your rules.ym, you just have to not forget the `-` prepending the `name` property for each rule.
Of course you can have multiple rules in your config file, you just have to not forget the `-` prepending the `name` property for each rule.

For example if you want those two rules, your `rules.yml` will be:
For example if you want those two rules, your config file will be:

```yaml
- name: ssh
Expand All @@ -121,46 +122,32 @@ For example if you want those two rules, your `rules.yml` will be:
IPpos: 0
```

### Launch

You have downloaded the Banisher binary ?
You have set the exec flag (`chmod +x banisher`) ?
You have set up your rules ?

Let's go !
## And what can i do if something goes wrong !!!

Just run:

```bash
./banisher
2019/04/17 16:19:12 dovecot: 183.82.32.153 banned
2019/04/17 16:19:12 ssh: 104.236.246.16 banned
2019/04/17 16:19:13 dovecot: 178.150.194.243 banned
2019/04/17 16:19:15 ssh: 51.77.213.181 banned
2019/04/17 16:19:20 ssh: 193.169.39.254 banned
2019/04/17 16:19:20 ssh: 82.200.65.218 banned
2019/04/17 16:19:21 ssh: 178.128.84.246 banned
2019/04/17 16:19:21 ssh: 190.145.55.89 banned
2019/04/17 16:19:21 ssh: 211.21.154.4 banned
```

Of course you can configure systemd to handle The Banisher binary (doc is coming)

### And what can i do if something goes wrong !!!

An iptables rules will be automaticaly removed after 3 hours.
An iptables rules will be automaticaly removed after defaultBanishmentDuration (defined in your config file).

If you made a mistake, just:

- stop The Banisher
- remove badger files, the db.bdg folder.
- flush iptables `ìptables -F`
- flush iptables INPUT chain `iptables -F INPUT`
- add your own iptables rules (if needed)

### Build dependencies
## Build

### Prerequisite

- [Task](https://taskfile.dev/) is used for compilation with a Docker image to handle glibc version issue to keep The Banisher compatible with debian buster (debian 10).
- To compile without the Docker image, the libsystemd0 library is needed (for debian like: `sudo apt install libsystemd-dev`).
- The Banisher is dynamically linked with the glibc.

### Build commands

The libsystemd0 library is needed to compile.
- Compile The Banisher without Docker image : `task build`
- Generate the docker image to compile The Banisher : `task generate-docker-image`
- Compile The Banisher with Docker image : `task build-with-docker`
- Generate debian package : `task package`

For debian like : sudo apt install libsystemd-dev
The binaries will be in the "dist" folder.


12 changes: 10 additions & 2 deletions Taskfile.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,17 @@ tasks:
cmds:
- go build -ldflags "-w -s -X main.appVersion={{.GIT_VERSION}}" -o dist/banisher

build-with-docker:
cmds:
- docker run --rm -v $PWD:/go/src banisher-compile:latest /bin/sh -c 'task build'

run:
deps: [build]
cmds:
- dist/banisher

package:
deps: [build]
deps: [build-with-docker]
vars:
PACKAGE_BUILD_DATE:
sh: date +%s
Expand All @@ -33,7 +37,11 @@ tasks:
- cp dist/banisher dist/packages/debian/usr/sbin/.
- mkdir -p dist/packages/debian/etc
- cp dist/config.yml dist/packages/debian/etc/banisher.yml
- dpkg-deb --build dist/packages/debian dist/banisher_{{.GIT_VERSION}}-{{.PACKAGE_BUILD_DATE}}_amd64.deb
- dpkg-deb --root-owner-group -Zxz --build dist/packages/debian dist/banisher_{{.GIT_VERSION}}-{{.PACKAGE_BUILD_DATE}}_amd64.deb

generate-docker-image:
cmds:
- docker build --tag banisher-compile .

clean:
cmds:
Expand Down
1 change: 1 addition & 0 deletions debian/control
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ Version: #version#
Section: net
Priority: optional
Architecture: amd64
Depends: libc6 (>= 2.28)
Essential: no
Maintainer: Olivier LARRIGAUDIERE
Description: Watches your systemd journal and bans, with no delay, abusers.

0 comments on commit 2bc8329

Please sign in to comment.