sarga/packages/Webkul/User/src/Http/Controllers/SessionController.php

95 lines
2.3 KiB
PHP
Executable File

<?php
namespace Webkul\User\Http\Controllers;
use Auth;
class SessionController extends Controller
{
/**
* Contains route related configuration
*
* @var array
*/
protected $_config;
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
$this->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']);
}
}