middleware('admin')->except(['create','store']); $this->_config = request('_config'); $this->middleware('guest', ['except' => 'destroy']); } /** * Show the form for creating a new resource. * * @return \Illuminate\View\View */ public function create() { if (auth()->guard('admin')->check()) { return redirect()->route('admin.dashboard.index'); } else { if (strpos(url()->previous(), 'admin') !== false) { $intendedUrl = url()->previous(); } else { $intendedUrl = route('admin.dashboard.index'); } session()->put('url.intended', $intendedUrl); return view($this->_config['view']); } } /** * Store a newly created resource in storage. * * @return \Illuminate\Http\Response */ public function store() { $this->validate(request(), [ 'email' => 'required|email', 'password' => 'required', ]); $remember = request('remember'); if (! auth()->guard('admin')->attempt(request(['email', 'password']), $remember)) { session()->flash('error', trans('admin::app.users.users.login-error')); return redirect()->back(); } if (auth()->guard('admin')->user()->status == 0) { session()->flash('warning', trans('admin::app.users.users.activate-warning')); auth()->guard('admin')->logout(); return redirect()->route('admin.session.create'); } return redirect()->intended(route($this->_config['redirect'])); } /** * Remove the specified resource from storage. * * @param int $id * @return \Illuminate\Http\Response */ public function destroy($id) { auth()->guard('admin')->logout(); return redirect()->route($this->_config['redirect']); } }