FarisaRahmaSari_E31222327/app/Http/Middleware/RoleMiddleware.php

33 lines
711 B
PHP

<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
class RoleMiddleware
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
* @return mixed
*/
public function handle($request, Closure $next)
{
if (auth()->user() === null) {
abort(403, 'Unauthorized action.');
}
$actions = $request->route()->getAction();
$roles = isset($actions['roles']) ? $actions['roles'] : null;
if ($roles !== null && auth()->user()->hasAnyRole($roles)) {
return $next($request);
}
abort(403, 'Unauthorized action.');
}
}