| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177 |
- <?php
- namespace App\Http\Controllers\AdminAuth;
- use App\Http\Controllers\Controller;
- use Illuminate\Foundation\Auth\AuthenticatesUsers;
- use Illuminate\Support\Facades\Auth;
- use Hesto\MultiAuth\Traits\LogsoutGuard;
- use Illuminate\Http\Request;
- use App\Models\Admin;
- use App\Models\LoginRecords;
- use Session;
- class LoginController extends Controller
- {
- /*
- |--------------------------------------------------------------------------
- | Login Controller
- |--------------------------------------------------------------------------
- |
- | This controller handles authenticating users for the application and
- | redirecting them to your home screen. The controller uses a trait
- | to conveniently provide its functionality to your applications.
- |
- */
- use AuthenticatesUsers, LogsoutGuard {
- LogsoutGuard::logout insteadof AuthenticatesUsers;
- }
- /**
- * Where to redirect users after login / registration.
- *
- * @var string
- */
- public $redirectTo = '/admin/dashboard';
- /**
- * Create a new controller instance.
- *
- * @return void
- */
- public function __construct()
- {
- $this->middleware('admin.guest', ['except' => 'logout']);
- }
- /**
- * Show the application's login form.
- *
- * @return \Illuminate\Http\Response
- */
- public function showLoginForm()
- {
- return view('admin.auth.login');
- }
- public function login(Request $request)
- {
- $admin = Admin::where('email',$request->email)->first();
- if(!$admin){
- return redirect('/')->with('error','Unknown Email address!');
- }else{
- if($admin->status == '0'){
- return redirect('/')->with('error','Account Status is not Activated!');
- }else{
- if($admin->type==5)
- return redirect('https://sales.samscrm.co.uk')->with('success','Please login here!');
-
- $credentials = [
- 'email' => $request->email,
- 'password' => $request->password,
- 'status' => '1'
- ];
- if (Auth::guard('admin')->attempt($credentials)) {
- $time = date('y-m-d h:i:s',time());
- $ip = $request->ip();
- $records = new LoginRecords;
- $records->auth_type = 'admins';
- $records->auth_id = $admin->id;
- $records->ip_address = $ip;
- $records->start_time = $time;
- $records->save();
- $admin->active_status=1;
- $admin->last_logged_timezone=$request->last_logged_timezone;
- $admin->api_token=make_api_token('admins');
- $admin->update();
- $previous_session = $admin->session_id;
- if($previous_session) {
- Session::getHandler()->destroy($previous_session);
- }
- Session::put('session_start', $time);
- Session::put('login_record', $records->id);
- Session::put('admin_type', 'admins');
- $admin->session_id = Session::getId();
- $admin->update();
- return redirect('admin/dashboard');
- }else{
- return redirect('/')->with('error','Wrong Email/Password combination');
- }
- }
- }
- }
- /**
- * Get the guard to be used during authentication.
- *
- * @return \Illuminate\Contracts\Auth\StatefulGuard
- */
- protected function guard()
- {
- return Auth::guard('admin');
- }
- public function logout(){
- $auth_user=Auth::guard('admin')->user();
- if($auth_user){
- $auth_user->update([
- 'active_status'=>0,
- 'api_token'=>NULL
- ]);
-
- }
- if(Session::get('login_record')){
- $record_id = Session::get('login_record');
- $time = date('y-m-d h:i:s',time());
- $records = LoginRecords::find($record_id);
- if($records){
- $records->end_time = $time;
- $records->update();
- if($records->login_source){
- $source = $records->loginSource->source;
- }
- }
- }
- $previous_session = Auth::guard('admin')->session_id;
- if($previous_session) {
- Session::getHandler()->destroy($previous_session);
- }
- Auth::guard('admin')->logout();
- if(!isset($source)){
- return redirect('/');
- }else{
- return redirect($source);
- }
- //return redirect('/admin');
- }
- public function showRegisterForm()
- {
- return view('admin.auth.register');
- }
-
- }
|