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); } foreach ($user->roles as $role) { if ($role->hasPermissionTo($request->route()->getName())) { return $next($request); } } throw UnauthorizedException::forPermissions($user->getAllPermissions()->toArray()); } /** * 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; } }