Fix: SW-Update Dauerschleife — controllerchange nicht auf Reload-Seiten registrieren (SW by-v888)

clients.claim() feuert asynchron nach Seitenstart → controllerchange auf
der neu geladenen Seite → Reload → clients.claim() → loop.
Fix: controllerchange nur registrieren wenn _t= NICHT im URL steht.
This commit is contained in:
rene 2026-05-12 19:35:42 +02:00
parent b8f70eb2cd
commit 7257c9e04f
4 changed files with 14 additions and 11 deletions

View file

@ -406,7 +406,7 @@ async def serve_media(path: str, request: _Request):
raise _HE(404, "Nicht gefunden.") raise _HE(404, "Nicht gefunden.")
return _media_response(filepath) return _media_response(filepath)
APP_VER = "887" # muss mit APP_VER in app.js übereinstimmen APP_VER = "888" # 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

@ -660,14 +660,17 @@
}); });
// Backup: controllerchange (falls updatefound nicht feuert) // Backup: controllerchange (falls updatefound nicht feuert)
// Konsumiert auch den by_skip_sw_reload-Flag (statechange prüft ihn nur) // NICHT registrieren wenn diese Seite selbst durch einen SW-Reload entstand (_t= im URL)
navigator.serviceWorker.addEventListener('controllerchange', () => { // — verhindert Dauerschleife wenn clients.claim() erst nach Seitenstart feuert
if (sessionStorage.getItem('by_skip_sw_reload')) { if (!location.search.includes('_t=')) {
sessionStorage.removeItem('by_skip_sw_reload'); navigator.serviceWorker.addEventListener('controllerchange', () => {
return; if (sessionStorage.getItem('by_skip_sw_reload')) {
} sessionStorage.removeItem('by_skip_sw_reload');
window.location.replace('/?_t=' + Date.now()); return;
}); }
window.location.replace('/?_t=' + Date.now());
});
}
navigator.serviceWorker.addEventListener('message', e => { navigator.serviceWorker.addEventListener('message', e => {
if (e.data?.type === 'QUEUE_PROCESSED') { if (e.data?.type === 'QUEUE_PROCESSED') {

View file

@ -3,7 +3,7 @@
Router, State-Management, Navigation, Initialisierung. Router, State-Management, Navigation, Initialisierung.
============================================================ */ ============================================================ */
const APP_VER = '887'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen const APP_VER = '888'; // ← bei jedem Deploy mit Frontend-Änderungen erhöhen
const APP_VERSION = '1.5.1'; // ← semantische Version, wird bei make release gesetzt const APP_VERSION = '1.5.1'; // ← 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

@ -3,7 +3,7 @@
Offline-Cache + Push Notifications + Tile-Cache Offline-Cache + Push Notifications + Tile-Cache
============================================================ */ ============================================================ */
const CACHE_VERSION = 'by-v887'; const CACHE_VERSION = 'by-v888';
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