Session 2026-04-20: Medien-Konvertierung, Umami Analytics, Username/Privacy
- HEIC→JPEG, MOV/AVI→MP4 Konvertierung bei allen Upload-Endpoints (media_utils.py) - ffmpeg im Docker-Image, Video-Thumbnails (extract_video_thumb, poster-Attribut) - Google Analytics entfernt, Umami self-hosted eingebunden (index.html, datenschutz.js) - Admin-Panel Analytics-Tab: Stat-Cards, Sparkline 7 Tage, Top-Seiten (Umami-API-Proxy) - Admin-Panel Tab-Icons korrigiert (aus vorhandenem Phosphor-Sprite) - users.real_name Spalte: Username öffentlich, echter Name privat und optional - Registrierung: Label "Benutzername", Leerzeichen verboten, Profanity-Blockliste - Datenschutzerklärung: GA-Abschnitt durch Umami-Text ersetzt
This commit is contained in:
parent
9a78121a3e
commit
5141ba9969
20 changed files with 524 additions and 143 deletions
|
|
@ -897,3 +897,16 @@ def _migrate(conn_factory):
|
|||
CREATE INDEX IF NOT EXISTS idx_user_badges_user ON user_badges(user_id);
|
||||
""")
|
||||
logger.info("Migration: user_badges Tabelle bereit.")
|
||||
|
||||
# Username / Real-Name Trennung
|
||||
try:
|
||||
conn.execute("ALTER TABLE users ADD COLUMN real_name TEXT")
|
||||
# Bestehende User: Leerzeichen im name → name enthält echten Namen → in real_name verschieben
|
||||
rows = conn.execute("SELECT id, name FROM users WHERE name LIKE '% %'").fetchall()
|
||||
for r in rows:
|
||||
first_word = r['name'].split()[0]
|
||||
conn.execute("UPDATE users SET real_name=?, name=? WHERE id=?",
|
||||
(r['name'], first_word, r['id']))
|
||||
logger.info("Migration: real_name Spalte hinzugefügt, %d User migriert.", len(rows))
|
||||
except Exception:
|
||||
pass
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue