2018-06-20 05:06:27 +00:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
namespace Webkul\User\Http\Controllers;
|
|
|
|
|
|
|
|
|
|
use Illuminate\Http\Request;
|
|
|
|
|
use Illuminate\Http\Response;
|
2018-08-31 06:03:11 +00:00
|
|
|
use Auth;
|
2018-06-20 05:06:27 +00:00
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Admin user session controller
|
|
|
|
|
*
|
|
|
|
|
* @author Jitendra Singh <jitendra@webkul.com>
|
|
|
|
|
* @copyright 2018 Webkul Software Pvt Ltd (http://www.webkul.com)
|
|
|
|
|
*/
|
2018-07-05 07:58:26 +00:00
|
|
|
class SessionController extends Controller
|
2018-06-20 05:06:27 +00:00
|
|
|
{
|
2018-07-05 07:58:26 +00:00
|
|
|
/**
|
|
|
|
|
* Contains route related configuration
|
|
|
|
|
*
|
|
|
|
|
* @var array
|
|
|
|
|
*/
|
2018-06-20 05:06:27 +00:00
|
|
|
protected $_config;
|
|
|
|
|
|
2018-07-05 07:58:26 +00:00
|
|
|
/**
|
|
|
|
|
* Create a new controller instance.
|
|
|
|
|
*
|
|
|
|
|
* @return void
|
|
|
|
|
*/
|
2018-06-20 05:06:27 +00:00
|
|
|
public function __construct()
|
|
|
|
|
{
|
2018-08-31 06:03:11 +00:00
|
|
|
$this->middleware('admin')->except(['create','store']);
|
|
|
|
|
|
2018-06-20 05:06:27 +00:00
|
|
|
$this->_config = request('_config');
|
|
|
|
|
|
|
|
|
|
$this->middleware('guest', ['except' => 'destroy']);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Show the form for creating a new resource.
|
|
|
|
|
*
|
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
|
*/
|
|
|
|
|
public function create()
|
|
|
|
|
{
|
2018-08-31 06:03:11 +00:00
|
|
|
if (auth()->guard('admin')->check()) {
|
|
|
|
|
return redirect()->route('admin.dashboard.index');
|
|
|
|
|
} else {
|
|
|
|
|
return view($this->_config['view']);
|
|
|
|
|
}
|
|
|
|
|
|
2018-06-20 05:06:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Store a newly created resource in storage.
|
|
|
|
|
*
|
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
|
*/
|
|
|
|
|
public function store()
|
|
|
|
|
{
|
2018-07-05 07:58:26 +00:00
|
|
|
$this->validate(request(), [
|
|
|
|
|
'email' => 'required|email',
|
|
|
|
|
'password' => 'required'
|
|
|
|
|
]);
|
|
|
|
|
|
|
|
|
|
$remember = request('remember');
|
2018-12-18 10:44:21 +00:00
|
|
|
|
|
|
|
|
if (!auth()->guard('admin')->attempt(request(['email', 'password']), $remember)) {
|
2018-07-05 07:58:26 +00:00
|
|
|
session()->flash('error', 'Please check your credentials and try again.');
|
|
|
|
|
|
|
|
|
|
return back();
|
2018-06-20 05:06:27 +00:00
|
|
|
}
|
|
|
|
|
|
2018-12-18 10:44:21 +00:00
|
|
|
if (auth()->guard('admin')->user()->status == 0) {
|
|
|
|
|
session()->flash('warning', 'Your account is yet to be activated, please contact administrator.');
|
|
|
|
|
|
|
|
|
|
auth()->guard('admin')->logout();
|
|
|
|
|
|
|
|
|
|
return redirect()->route('admin.session.create');
|
|
|
|
|
}
|
|
|
|
|
|
2018-08-31 06:03:11 +00:00
|
|
|
return redirect()->intended(route($this->_config['redirect']));
|
2018-06-20 05:06:27 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* Remove the specified resource from storage.
|
|
|
|
|
*
|
|
|
|
|
* @param int $id
|
|
|
|
|
* @return \Illuminate\Http\Response
|
|
|
|
|
*/
|
|
|
|
|
public function destroy($id)
|
|
|
|
|
{
|
|
|
|
|
auth()->guard('admin')->logout();
|
|
|
|
|
|
2018-07-05 07:58:26 +00:00
|
|
|
return redirect()->route($this->_config['redirect']);
|
2018-06-20 05:06:27 +00:00
|
|
|
}
|
2018-07-24 14:42:36 +00:00
|
|
|
}
|