30 lines
659 B
PHP
30 lines
659 B
PHP
<?php
|
|
|
|
namespace Spatie\Permission\Middlewares;
|
|
|
|
use Closure;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Spatie\Permission\Exceptions\UnauthorizedException;
|
|
|
|
class RoleMiddleware
|
|
{
|
|
public function handle($request, Closure $next, $role, $guard = null)
|
|
{
|
|
$authGuard = Auth::guard($guard);
|
|
|
|
if ($authGuard->guest()) {
|
|
throw UnauthorizedException::notLoggedIn();
|
|
}
|
|
|
|
$roles = is_array($role)
|
|
? $role
|
|
: explode('|', $role);
|
|
|
|
if (! $authGuard->user()->hasAnyRole($roles)) {
|
|
throw UnauthorizedException::forRoles($roles);
|
|
}
|
|
|
|
return $next($request);
|
|
}
|
|
}
|