Release 1.0.0

This commit is contained in:
2026-03-12 20:01:54 +01:00
parent 7bdf11184e
commit 52a438c331
4 changed files with 137 additions and 2 deletions

1
.gitattributes vendored Normal file
View File

@@ -0,0 +1 @@
* text=auto eol=lf

7
02-immich-whitelist.yaml Normal file
View File

@@ -0,0 +1,7 @@
name: crowdsecurity/immich-whitelists
description: "Whitelist false positive from Immich-api"
filter: "evt.Meta.http_path != ''"
whitelist:
reason: "Whitelist false positive from Immich-api"
expression:
- evt.Meta.http_verb == 'GET' && evt.Meta.http_path matches '/api/assets/[a-f0-9-]+/thumbnail'

View File

@@ -1,11 +1,35 @@
# template_repository
# CrowdSec Parser-Whitelist für Immich
Eine Parser-Whitelist für [CrowdSec](https://www.crowdsec.net/), die legitime Immich-API-Anfragen in NPMplus-Logs vom Parsen ausschließt.
Damit wird verhindert, dass Thumbnail-Requests fälschlicherweise als verdächtig eingestuft werden.
## Überblick
| Pfad-Pattern | Beschreibung |
|---|---|
| `/api/assets/<uuid>/thumbnail` | Immich Asset-Thumbnails (GET) |
Wichtig: Link für Lizenz anpassen.
## Schnellstart
1. Datei kopieren:
```bash
cp 02-immich-whitelist.yaml /etc/crowdsec/parsers/s02-enrich/02-immich-whitelist.yaml
```
2. CrowdSec neu starten:
```bash
docker restart crowdsec
```
3. Funktion prüfen:
```bash
docker exec crowdsec cscli metrics
```
Detaillierte Anleitung: [docs/installation.md](docs/installation.md)
<p align="center">
<img src="https://assets.techniverse.net/f1/git/graphics/gray0-catonline.svg" alt="">

103
docs/installation.md Normal file
View File

@@ -0,0 +1,103 @@
# Installation & Konfiguration
## Voraussetzungen
- CrowdSec (als Docker-Container oder nativ installiert)
- NPMplus als Reverse Proxy mit aktiviertem Logging
- Immich (Docker-Setup)
## Installation
### 1. Whitelist-Datei kopieren
Die YAML-Datei muss in das CrowdSec Parser-Verzeichnis `s02-enrich` kopiert werden:
```bash
cp s02-enrich/immich-whitelist.yaml /etc/crowdsec/parsers/s02-enrich/immich-whitelist.yaml
```
> **Hinweis:** Bei einer Docker-Installation liegt das Verzeichnis im gemappten Volume, z. B.
> `./data/crowdsec/config/parsers/s02-enrich/`
### 2. CrowdSec neu starten
Damit die Whitelist geladen wird, muss CrowdSec neu gestartet werden:
```bash
docker restart crowdsec
```
## Überprüfung
### Parser testen
Mit `cscli explain` kann geprüft werden, ob die Whitelist auf eine echte Log-Zeile greift:
```bash
grep '/api/assets/' /home/docker-projekte/npmplus/data/npmplus/nginx/logs/access.log \
| tail -n 1 \
| docker exec -i crowdsec cscli explain -f- --type npmplus
```
In der Ausgabe sollte die Whitelist als Treffer erscheinen, z. B.:
```
├ s02-enrich
| ├ ☑ crowdsecurity/whitelists
| ├ ☑ crowdsecurity/immich-whitelists ✅ (whitelisted)
```
### Metriken prüfen
Die Wirkung ist in den CrowdSec-Metriken sichtbar:
```bash
docker exec crowdsec cscli metrics
```
Beispielausgabe:
```
+--------------------------------------------------------------------------------------------+
| Whitelist Metrics |
+------------------------------------+----------------------------------+------+-------------+
| Whitelist | Reason | Hits | Whitelisted |
+------------------------------------+----------------------------------+------+-------------+
| crowdsecurity/immich-whitelists | Whitelist false positive from | 312 | 298 |
| | Immich-api | | |
+------------------------------------+----------------------------------+------+-------------+
```
Die Spalte **Whitelisted** zeigt an, wie viele Log-Zeilen durch die Whitelist herausgefiltert wurden.
## Funktionsweise
Die Whitelist arbeitet als CrowdSec-Parser in der Stufe `s02-enrich`. Sie prüft eingehende Log-Events anhand folgender Kriterien:
**Filter:** Die Whitelist verwendet `evt.Meta.http_path != ''` als Filter und greift damit auf alle Events mit geparsten HTTP-Daten. Die eigentliche Filterung erfolgt über die Whitelist-Expressions.
**Whitelist-Regeln:** GET-Anfragen auf Thumbnail-Endpunkte der Immich-API werden als legitim eingestuft:
| Pfad-Pattern | Beschreibung |
|---|---|
| `/api/assets/<uuid>/thumbnail` | Immich Asset-Thumbnails (UUID-basiert) |
## Anpassung
### Weitere Pfade hinzufügen
Die Datei kann bei Bedarf um weitere Immich-API-Pfade erweitert werden. Dazu einfach weitere Einträge unter `expression` hinzufügen:
```yaml
whitelist:
reason: "Whitelist false positive from Immich-api"
expression:
- evt.Meta.http_verb == 'GET' && evt.Meta.http_path matches '/api/assets/[a-f0-9-]+/thumbnail'
- evt.Meta.http_verb == 'GET' && evt.Meta.http_path startsWith '/api/assets'
```
Nach jeder Änderung muss CrowdSec neu gestartet werden:
```bash
docker restart crowdsec
```