Nirodan 7f9c5c874a Add 6 new tools: Hasher, Base64, JWT Decoder, Password Gen, Timestamp, Text Diff
- backend/tools/hasher.py: POST /api/hash/sha256 and /api/hash/bcrypt (bcrypt added to requirements)
- backend/tools/base64tool.py: POST /api/base64/encode and /api/base64/decode
- backend/tools/jwtdecoder.py: POST /api/jwt/decode (signature verification disabled)
- backend/tools/passwordgen.py: POST /api/password/generate with charset and length options
- backend/tools/timestamp.py: POST /api/timestamp/convert (unix<->date, ISO 8601 + German format)
- backend/tools/textdiff.py: POST /api/text/diff returning structured added/removed/unchanged lines
- All blueprints registered in app.py and tools/__init__.py
- React components with copy button, dark/light mode support via CSS variables
- ToolOverview rebuilt as card grid; App.jsx routes added for all tools

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
2026-04-24 14:28:18 +02:00
2026-01-22 15:35:38 +01:00
2026-01-22 12:18:27 +01:00
2025-06-16 10:10:59 +02:00
2025-06-14 12:18:26 +02:00

Docker-Webplattform: React + Flask + externe MariaDB

Vollständig dockerisierte Webanwendung mit React-Frontend und Flask-Backend in einem einzigen Container. Verbindet sich mit einer externen MariaDB-Datenbank und bietet Setup-System, Login, Rollenverwaltung und modulare Tools.


Screenshot

Admin-Dashboard


Setup-Anleitung

Voraussetzungen

  • Docker & Docker Compose installiert
  • Externe MariaDB/MySQL-Datenbank erreichbar (z.B. auf Unraid, NAS oder anderem Server)

1. Repository klonen

git clone https://github.com/Nirodan/Tools.git
cd Tools

2. Umgebungsvariablen konfigurieren

cp .env.example .env

Dann .env öffnen und SECRET_KEY durch einen sicheren zufälligen Wert ersetzen:

# Sicheren Key generieren:
python -c "import secrets; print(secrets.token_hex(32))"

3. Container starten

docker compose -f docker-compose.dev.yml up -d

4. Datenbank einrichten (Erststart)

Beim ersten Start öffnet sich automatisch die Setup-Seite unter http://localhost:5050/setup.

Dort die MariaDB-Verbindungsdaten eintragen:

Feld Beispiel
Host 192.168.1.100
Port 3306
User tools_user
Password geheimes_pw
Database tools_db

Nach dem Speichern wird automatisch ein Admin-Account angelegt:

  • Benutzername: admin
  • Passwort: admin (bitte sofort im Admin-Dashboard ändern)

5. Anwendung aufrufen

http://localhost:5050

Was der Container macht

  • Startet automatisch Flask + React in einer Umgebung
  • Bei Erststart: Setup-Webseite zum Eintragen der DB-Verbindung
  • Speichert die Konfiguration in einem Docker-Volume (config/db_config.json)
  • Verbindet sich mit der externen MariaDB-Datenbank
  • Erstellt automatisch ein admin-Benutzerkonto
  • Liefert das React-Frontend direkt über Flask aus (keine extra Node-Instanz)

Projektstruktur

Tools/
├── backend/
│   ├── app.py              # Flask-Einstiegspunkt
│   ├── admin.py            # Admin-API (Nutzer- und Websitenverwaltung)
│   ├── auth/               # Login, Logout, Token-Verifikation
│   ├── tools/              # Modulare Tools (MD5 etc.)
│   └── util/               # DB-Pool, Konfiguration, Logger, Rate-Limiter
├── frontend/
│   └── src/
│       ├── App.jsx
│       ├── components/     # React-Komponenten
│       └── services/api.js # Axios-Instanz mit Auth-Interceptor
├── docker-compose.dev.yml
├── Dockerfile
├── .env.example            # Vorlage für Umgebungsvariablen
└── README.md

Sicherheitshinweise

  • SECRET_KEY niemals im Klartext in der Versionskontrolle speichern immer .env verwenden
  • Standard-Admin-Passwort (admin) nach dem Erststart sofort ändern
  • MD5 ist kryptografisch unsicher nicht für Passwort-Hashing verwenden

Lizenz

Dieses Projekt steht unter der Creative Commons BY-NC 4.0 Lizenz. Du darfst es verwenden, verändern und teilen aber nicht kommerziell nutzen. Volltext: https://creativecommons.org/licenses/by-nc/4.0

Author: Nirodan https://github.com/Nirodan

S
Description
No description provided
Readme 355 KiB
2026-05-22 09:31:47 +02:00
Languages
JavaScript 50.9%
Python 40.2%
CSS 6.9%
HTML 0.8%
Dockerfile 0.7%
Other 0.5%