в моем веб-приложении у меня есть панель администратора, и я пытаюсь сделать доступ к пользователям, которые имеют роль администратора, с помощью этого кода:
namespace App\Http\Middleware;
use Closure;
class CheckUserAdminRole
{
public function handle($request, Closure $next)
{
if (auth()->check()) {
if (auth()->check() && !auth()->user()->hasRole('admin')) {
auth()->logout();
return redirect(route('system.messages','userIsNotAdmin'));
}
}
return $next($request);
}
}
и в моих маршрутах у меня есть эта группа маршрутов:
Route::group(['namespace' => 'Dashboard', 'middleware' => ['auth:web'], 'prefix' => 'dashboard'], function () {
$this->group(['prefix' => 'administrator'], function () {
$this->get('panel', 'AdminController@index');
});
мое ядро:
protected $middleware = [
\Illuminate\Foundation\Http\Middleware\CheckForMaintenanceMode::class,
\Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,
...
\App\Http\Middleware\CheckUserAdminRole::class,
];
теперь, когда я добавляю свое промежуточное ПО как CheckUserAdminRole
в группу маршрутизации, как с этим кодом:
Route::group(['namespace' => 'Dashboard', 'middleware' => ['auth:web','CheckUserAdminRole'], 'prefix' => 'dashboard'], function () {
я получаю этоошибка:
Class CheckUserAdminRole does not exist
этот код не может решить мою проблему:
php artisan route:clear
php artisan cache:clear
php artisan config:clear
composer dump-autoload