Я хочу сделать систему входа администратора и систему входа пользователя. У обоих разные таблицы. Для аутентификации пользователя я использовал обычную аутентификацию, а для аутентификации администратора - Middleware. Мой код ниже, скажите, пожалуйста, в чем ошибка в этом коде
// RedirectIfNotAdmin
public function handle($request, Closure $next, $guard = 'admin')
{
if (!Auth::guard($guard)->check()) {
return redirect('/admin');
}
return $next($request);
}
Маршрут
Route::group(['middleware' => ['web']], function () {
Route::get('admin/login', array('as' => 'login.index', 'uses' => 'Admin\LoginController@showLoginForm'));
Route::post('admin/login', array('as' => 'login.entry', 'uses' => 'Admin\LoginController@login'));
Route::get('/admin/logout','Admin\LoginController@logout');
Route::get('admin/register', 'Admin\RegisterController@showRegistrationForm');
Route::post('admin/register', 'Admin\RegisterController@register');
Route::get('/admin', 'AdminController@index');
});
Kernel
protected $routeMiddleware = [
'auth' => \Illuminate\Auth\Middleware\Authenticate::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'bindings' => \Illuminate\Routing\Middleware\SubstituteBindings::class,
'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class,
'can' => \Illuminate\Auth\Middleware\Authorize::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
'signed' => \Illuminate\Routing\Middleware\ValidateSignature::class,
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
'admin' => \App\Http\Middleware\RedirectIfNotAdmin::class,
];
Контроллер администратора
class AdminController extends Controller{
public function __construct(){
$this->middleware('admin');
}
public function index(){
return view('home');
}}
Контроллер входа
protected $redirectTo = '/admin';
public $guard = 'admin';
public function showLoginForm()
{
if (view()->exists('admin.auth.authenticate')) {
return view('admin.auth.authenticate');
}
return view('admin.auth.login');
}
public function showRegistrationForm()
{
return view('admin.auth.register');
}