You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

38 lines
914 B
PHP

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
use Illuminate\Support\Facades\Auth;
class CheckRole
{
/**
* Handle an incoming request.
*/
public function handle(Request $request, Closure $next, ...$roles): Response
{
$user = Auth::user();
if (!$user) {
return response()->json([
'success' => false,
'message' => 'No autenticado'
], 401);
}
// Verificar si el usuario tiene alguno de los roles requeridos
foreach ($roles as $role) {
if ($user->hasRole($role)) {
return $next($request);
}
}
return response()->json([
'success' => false,
'message' => 'No autorizado para esta acción'
], 403);
}
}