netgescon-master/_BACKUP_OLD_netgescon-laravel_INACTIVE/app/Http/Middleware/SecureRoutingMiddleware.php

39 lines
885 B
PHP

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Auth;
class SecureRoutingMiddleware
{
/**
* Handle an incoming request.
*/
public function handle(Request $request, Closure $next, ...$roles)
{
$user = Auth::user();
if (!$user) {
return redirect()->route('login');
}
// Verifica che l'utente abbia almeno uno dei ruoli richiesti
$hasRole = false;
foreach ($roles as $role) {
if ($user->hasRole($role)) {
$hasRole = true;
break;
}
}
if (!$hasRole) {
// Redirect alla dashboard appropriata senza rivelare il ruolo
return redirect()->route('secure.dashboard');
}
return $next($request);
}
}