관리-도구
편집 파일: PermissionMiddleware.php
<?php namespace Spatie\Permission\Middleware; use Closure; use Illuminate\Support\Facades\Auth; use Spatie\Permission\Exceptions\UnauthorizedException; use Spatie\Permission\Guard; class PermissionMiddleware { public function handle($request, Closure $next, $permission, $guard = null) { $authGuard = Auth::guard($guard); $user = $authGuard->user(); // For machine-to-machine Passport clients if (! $user && $request->bearerToken() && config('permission.use_passport_client_credentials')) { $user = Guard::getPassportClient($guard); } if (! $user) { throw UnauthorizedException::notLoggedIn(); } if (! method_exists($user, 'hasAnyPermission')) { throw UnauthorizedException::missingTraitHasRoles($user); } $permissions = is_array($permission) ? $permission : explode('|', $permission); if (! $user->canAny($permissions)) { throw UnauthorizedException::forPermissions($permissions); } return $next($request); } /** * Specify the permission and guard for the middleware. * * @param array|string $permission * @param string|null $guard * @return string */ public static function using($permission, $guard = null) { $permissionString = is_string($permission) ? $permission : implode('|', $permission); $args = is_null($guard) ? $permissionString : "$permissionString,$guard"; return static::class.':'.$args; } }