Fix: Welten-Config — Sicherheitsnetz entfernt (Rolle-Chips ausblendbar), Duplikat-Schutz (SW by-v778)

This commit is contained in:
rene 2026-05-08 15:27:03 +02:00
parent 9fd146440f
commit 5664616a2a
5 changed files with 12 additions and 16 deletions

View file

@ -327,7 +327,7 @@ MEDIA_DIR = os.getenv("MEDIA_DIR", "/data/media")
os.makedirs(MEDIA_DIR, exist_ok=True) os.makedirs(MEDIA_DIR, exist_ok=True)
app.mount("/media", StaticFiles(directory=MEDIA_DIR), name="media") app.mount("/media", StaticFiles(directory=MEDIA_DIR), name="media")
APP_VER = "777" # muss mit APP_VER in app.js übereinstimmen APP_VER = "778" # muss mit APP_VER in app.js übereinstimmen
@app.get("/.well-known/assetlinks.json") @app.get("/.well-known/assetlinks.json")
async def assetlinks(): async def assetlinks():

View file

@ -578,7 +578,7 @@
<script src="/js/api.js?v=94"></script> <script src="/js/api.js?v=94"></script>
<script src="/js/ui.js?v=94"></script> <script src="/js/ui.js?v=94"></script>
<script src="/js/app.js?v=94"></script> <script src="/js/app.js?v=94"></script>
<script src="/js/worlds.js?v=777"></script> <script src="/js/worlds.js?v=778"></script>
<!-- Feature-Seiten werden lazy geladen --> <!-- Feature-Seiten werden lazy geladen -->

View file

@ -3,7 +3,7 @@
Router, State-Management, Navigation, Initialisierung. Router, State-Management, Navigation, Initialisierung.
============================================================ */ ============================================================ */
const APP_VER = '777'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen const APP_VER = '778'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VERSION = '1.5.0'; // ← semantische Version, wird bei make release gesetzt const APP_VERSION = '1.5.0'; // ← semantische Version, wird bei make release gesetzt
const IS_STAGING = location.hostname === 'staging.banyaro.app'; const IS_STAGING = location.hostname === 'staging.banyaro.app';
// Cache-Bust-Parameter nach Update-Reload sofort entfernen // Cache-Bust-Parameter nach Update-Reload sofort entfernen

View file

@ -640,18 +640,14 @@ window.Worlds = (() => {
} }
function _chipsForWorld(world) { function _chipsForWorld(world) {
const pages = _getConfig()[world] || _DEFAULT_CONFIG[world]; const cfg = _getConfig();
// Alle Chips filtern — _chipAllowed entscheidet ob angezeigt const pages = cfg[world] || _DEFAULT_CONFIG[world];
const chips = pages.map(_chipMeta).filter(c => c && _chipAllowed(c)); // Deduplizieren + filtern — _chipAllowed entscheidet ob angezeigt
// Sicherheitsnetz: Rolle-gebundene Chips aus Default einfügen wenn berechtigt const seen = new Set();
// (aber noch nicht in persönlicher Config) — _chipAllowed() entscheidet für alle const chips = pages
const alreadyIn = new Set(chips.map(c => c.page)); .filter(p => { if (seen.has(p)) return false; seen.add(p); return true; })
for (const page of (_DEFAULT_CONFIG[world] || [])) { .map(_chipMeta)
if (alreadyIn.has(page)) continue; .filter(c => c && _chipAllowed(c));
const meta = _chipMeta(page);
if (!meta?.role) continue; // nur role-gebundene Chips
if (_chipAllowed(meta)) { chips.push(meta); alreadyIn.add(page); }
}
return chips; return chips;
} }

View file

@ -3,7 +3,7 @@
Offline-Cache + Push Notifications + Tile-Cache Offline-Cache + Push Notifications + Tile-Cache
============================================================ */ ============================================================ */
const CACHE_VERSION = 'by-v777'; const CACHE_VERSION = 'by-v778';
const CACHE_STATIC = `${CACHE_VERSION}-static`; const CACHE_STATIC = `${CACHE_VERSION}-static`;
const CACHE_TILES = 'ban-yaro-tiles-v1'; // bleibt über SW-Updates erhalten const CACHE_TILES = 'ban-yaro-tiles-v1'; // bleibt über SW-Updates erhalten
const CACHE_API = 'ban-yaro-api-v1'; // API-Response-Cache const CACHE_API = 'ban-yaro-api-v1'; // API-Response-Cache