WS-2: Magic-Link für Firmen & Pressekontakte vereinheitlicht + Schreibzugriff
Magic-Link und Pressekontakt-Zugang zu einer Seite (/anmeldelink) zusammengeführt; altes Login-Modal entfernt, /pressekontakt-zugang leitet weiter. - ContactAccessService deckt jetzt Firmen-E-Mail UND Pressekontakt-E-Mail ab, portalübergreifend (ohne PortalScope). Eine E-Mail mehrfach hinterlegt → genau ein Account, dem alle Firmen + Kontakte zugeordnet werden. - Zugeordnete Firmen erhalten Pivot-Rolle 'responsible' (Schreibzugriff auf Stammdaten, Kontakte, Pressemitteilungen) statt nur 'member'; bestehende Lese-Pivots werden hochgestuft, Owner bleiben unangetastet. - Neuer Login-Listener (SyncCompanyMembershipsOnLogin) frischt die Zuordnungen bei JEDEM Login (Magic-Link, Passwort, Google) auf – auch nachträglich (API) hinzugekommene Firmen/Kontakte mit gleicher E-Mail greifen. - Auth-Bereich erzwingt Hellmodus: aus dem Portal übernommene .dark-Klasse wird am <html> entfernt (Login war im Dark Mode hängengeblieben). - Tests: Firmen-E-Mail-Login, Multi-Firmen-Aggregation, Schreibzugriff/Upgrade, Per-Login-Re-Sync, Auth-Hellmodus. Sicherheits-Doku aktualisiert. Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
This commit is contained in:
parent
068a5a4b49
commit
6c6b9e0f26
12 changed files with 587 additions and 327 deletions
|
|
@ -18,10 +18,14 @@ Route::group(['middleware' => config('fortify.middleware', ['web'])], function (
|
|||
->middleware(['guest:'.config('fortify.guard')])
|
||||
->name('magic-links.consume');
|
||||
|
||||
// Magic-Link-Zugang für Pressekontakte ohne Account (WS-2)
|
||||
Volt::route('/pressekontakt-zugang', 'auth.contact-access')
|
||||
// Anmeldung per E-Mail-Link (Magic-Link): zusammengeführte Seite für
|
||||
// Bestandskonten UND hinterlegte Pressekontakte ohne Account (WS-2).
|
||||
Volt::route('/anmeldelink', 'auth.magic-link')
|
||||
->middleware(['guest:'.config('fortify.guard')])
|
||||
->name('contact-access.request');
|
||||
->name('magic-link.request');
|
||||
|
||||
// Alte Pressekontakt-URL weiterleiten (Bestandslinks/Lesezeichen).
|
||||
Route::redirect('/pressekontakt-zugang', '/anmeldelink');
|
||||
|
||||
// Google-Login (WS-6)
|
||||
Route::get('/auth/google/redirect', [GoogleController::class, 'redirect'])
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue