89 lines
2.2 KiB
PHP
89 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Shop\Auth;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use Illuminate\Foundation\Auth\AuthenticatesUsers;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Illuminate\Http\Request;
|
|
|
|
use App\Repositories\Layout;
|
|
use App\Repositories\Languages;
|
|
use App\Repositories\Shop\Customers;
|
|
|
|
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;
|
|
|
|
/**
|
|
* Where to redirect users after login.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $redirectTo = '/';
|
|
|
|
/**
|
|
* Create a new controller instance.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function __construct()
|
|
{
|
|
$this->middleware('customer')->except('logout');
|
|
}
|
|
|
|
public function showLoginForm()
|
|
{
|
|
$data['url'] = route('Shop.Auth.login.post');
|
|
return view('Shop.Auth.login', $data);
|
|
}
|
|
|
|
protected function guard()
|
|
{
|
|
return Auth::guard('customer');
|
|
}
|
|
|
|
public function login(Request $request)
|
|
{
|
|
$this->validate($request, [
|
|
'username' => 'required|email',
|
|
'password' => 'required|min:6'
|
|
]);
|
|
|
|
if (Auth::guard('customer')->attempt(['username' => $request->username, 'password' => $request->password], $request->get('remember'))) {
|
|
return redirect()->intended(route('Conferencing.event'));
|
|
}
|
|
return back()->withInput($request->only('username', 'remember'));
|
|
}
|
|
|
|
public function logout(Request $request)
|
|
{
|
|
|
|
// Get the session key for this user
|
|
$sessionKey = $this->guard()->getName();
|
|
|
|
$this->guard()->logout();
|
|
|
|
// Delete single session key (just for this user)
|
|
$request->session()->forget($sessionKey);
|
|
|
|
return redirect()->route('home');
|
|
}
|
|
|
|
public function username()
|
|
{
|
|
return 'username';
|
|
}
|
|
}
|