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
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);
|
|
}
|
|
} |