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

45 lines
1.1 KiB

<?php
namespace App\Http\Middleware;
use Closure;
/**
* Role Middleware.
*
* @author Nafies Luthfi <nafiesL@gmail.com>
*/
class Role
{
/**
* Handle an incoming request.
*
* @param \Illuminate\Http\Request $request
* @param \Closure $next
*
* @return mixed
*/
public function handle($request, Closure $next, $names)
{
$nameArray = explode('|', $names);
if (auth()->check() == false) {
return $request->expectsJson()
? response()->json(['message' => 'Forbidden.'], 403)
: redirect()->guest('login');
}
// Cek apakah grup user ada di dalam array $nameArray?
if (auth()->user()->hasRoles($nameArray) == false) {
if ($request->expectsJson()) {
return response()->json(['message' => 'Forbidden.'], 403);
}
flash(__('auth.unauthorized_access', ['url' => $request->path()]), 'danger');
return redirect()->route('home');
}
return $next($request);
}
}