193 lines
5.1 KiB
PHP
193 lines
5.1 KiB
PHP
<?php
|
|
|
|
namespace App\Http\Controllers\Auth;
|
|
|
|
use App\Http\Controllers\Controller;
|
|
use Carbon\Carbon;
|
|
use Illuminate\Foundation\Auth\AuthenticatesUsers;
|
|
use Illuminate\Http\Request;
|
|
use Illuminate\Http\Response;
|
|
use Illuminate\Support\Facades\Auth;
|
|
use Illuminate\Validation\ValidationException;
|
|
|
|
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 = '/dashboard';
|
|
|
|
/**
|
|
* Login username to be used by the controller.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $username;
|
|
|
|
/**
|
|
* Create a new controller instance.
|
|
*
|
|
* @return void
|
|
*/
|
|
public function __construct()
|
|
{
|
|
$this->middleware('guest')->except('logout');
|
|
$this->username = $this->findUsername();
|
|
}
|
|
|
|
public function login(Request $request)
|
|
{
|
|
$user = null;
|
|
|
|
if (!$user) {
|
|
$msg = 'Authenticating user (' . $request->username . ') against database.';
|
|
activityLogIt(__CLASS__, __FUNCTION__, 'info', $msg, 'authentication');
|
|
|
|
$this->validateLogin($request); // replaced $this->validateLogin in AuthenticatesUsers.php with private version in this class
|
|
|
|
if ($this->hasTooManyLoginAttempts($request)) {
|
|
$this->fireLockoutEvent($request);
|
|
|
|
return $this->sendLockoutResponse($request);
|
|
}
|
|
|
|
if ($this->attemptLogin($request)) {
|
|
if ($user = Auth::user()) {
|
|
$msg = 'Local authentication for user ' . $user->email;
|
|
activityLogIt(__CLASS__, __FUNCTION__, 'info', $msg, 'authentication');
|
|
|
|
$user->last_login = Carbon::now();
|
|
$user->save();
|
|
|
|
return redirect('/dashboard');
|
|
}
|
|
|
|
return $this->sendLoginResponse($request);
|
|
}
|
|
|
|
$this->incrementLoginAttempts($request);
|
|
$msg = 'Local authentication failed.';
|
|
activityLogIt(__CLASS__, __FUNCTION__, 'error', $msg, 'authentication');
|
|
|
|
return $this->sendFailedLoginResponse($request);
|
|
}
|
|
}
|
|
|
|
public function showLoginForm()
|
|
{
|
|
$banner = \App\Models\Banner::select('login_banner')->get();
|
|
$login_banner = $banner[0]->login_banner;
|
|
|
|
return view('auth.login', compact('login_banner'));
|
|
}
|
|
|
|
public function showLoggedOut()
|
|
{
|
|
// assume we're logged out at this point
|
|
return view('auth.logged-out');
|
|
}
|
|
|
|
public function logout(Request $request)
|
|
{
|
|
$this->guard()->logout();
|
|
$request->session()->flush();
|
|
$request->session()->regenerate();
|
|
|
|
return redirect('/login');
|
|
}
|
|
|
|
/**
|
|
* Get the login username to be used by the controller.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function findUsername()
|
|
{
|
|
$login = request()->input('username');
|
|
|
|
$fieldType = filter_var($login, FILTER_VALIDATE_EMAIL) ? 'email' : 'username';
|
|
|
|
request()->merge([$fieldType => $login]);
|
|
|
|
return $fieldType;
|
|
}
|
|
|
|
/**
|
|
* Get username property.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function username()
|
|
{
|
|
return $this->username;
|
|
}
|
|
|
|
/**
|
|
* Validate the user login request.
|
|
*
|
|
* @param \Illuminate\Http\Request $request
|
|
* @return void
|
|
*
|
|
* @throws \Illuminate\Validation\ValidationException
|
|
*/
|
|
private function validateLogin(Request $request)
|
|
{
|
|
$request->validate([
|
|
'username' => 'required|string',
|
|
'password' => 'required|string',
|
|
]);
|
|
}
|
|
|
|
/**
|
|
* Redirect the user after determining they are locked out.
|
|
*
|
|
* @param \Illuminate\Http\Request $request
|
|
* @return \Symfony\Component\HttpFoundation\Response
|
|
*
|
|
* @throws \Illuminate\Validation\ValidationException
|
|
*/
|
|
private function sendLockoutResponse(Request $request)
|
|
{
|
|
$seconds = $this->limiter()->availableIn(
|
|
$this->throttleKey($request)
|
|
);
|
|
|
|
throw ValidationException::withMessages([
|
|
'username' => [trans('auth.throttle', [
|
|
'seconds' => $seconds,
|
|
'minutes' => ceil($seconds / 60),
|
|
])],
|
|
])->status(Response::HTTP_TOO_MANY_REQUESTS);
|
|
}
|
|
|
|
/**
|
|
* Get the failed login response instance.
|
|
*
|
|
* @param \Illuminate\Http\Request $request
|
|
* @return \Symfony\Component\HttpFoundation\Response
|
|
*
|
|
* @throws \Illuminate\Validation\ValidationException
|
|
*/
|
|
protected function sendFailedLoginResponse(Request $request)
|
|
{
|
|
throw ValidationException::withMessages([
|
|
'username' => [trans('auth.failed')],
|
|
]);
|
|
}
|
|
}
|