mailwolt/app/Http/Middleware/RequireRole.php

23 lines
466 B
PHP

<?php
namespace App\Http\Middleware;
use App\Enums\Role;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class RequireRole
{
public function handle(Request $request, Closure $next, string ...$roles): Response
{
$user = $request->user();
if (!$user || !in_array($user->role?->value, $roles, true)) {
abort(403, 'Keine Berechtigung.');
}
return $next($request);
}
}