204 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			204 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			PHP
		
	
	
<?php
 | 
						|
 | 
						|
namespace Illuminate\Foundation\Auth;
 | 
						|
 | 
						|
use Illuminate\Http\JsonResponse;
 | 
						|
use Illuminate\Http\Request;
 | 
						|
use Illuminate\Support\Facades\Auth;
 | 
						|
use Illuminate\Validation\ValidationException;
 | 
						|
 | 
						|
trait AuthenticatesUsers
 | 
						|
{
 | 
						|
    use RedirectsUsers, ThrottlesLogins;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Show the application's login form.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\View\View
 | 
						|
     */
 | 
						|
    public function showLoginForm()
 | 
						|
    {
 | 
						|
        return view('auth.login');
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Handle a login request to the application.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @return \Illuminate\Http\RedirectResponse|\Illuminate\Http\Response|\Illuminate\Http\JsonResponse
 | 
						|
     *
 | 
						|
     * @throws \Illuminate\Validation\ValidationException
 | 
						|
     */
 | 
						|
    public function login(Request $request)
 | 
						|
    {
 | 
						|
        $this->validateLogin($request);
 | 
						|
 | 
						|
        // If the class is using the ThrottlesLogins trait, we can automatically throttle
 | 
						|
        // the login attempts for this application. We'll key this by the username and
 | 
						|
        // the IP address of the client making these requests into this application.
 | 
						|
        if (method_exists($this, 'hasTooManyLoginAttempts') &&
 | 
						|
            $this->hasTooManyLoginAttempts($request)) {
 | 
						|
            $this->fireLockoutEvent($request);
 | 
						|
 | 
						|
            return $this->sendLockoutResponse($request);
 | 
						|
        }
 | 
						|
 | 
						|
        if ($this->attemptLogin($request)) {
 | 
						|
            if ($request->hasSession()) {
 | 
						|
                $request->session()->put('auth.password_confirmed_at', time());
 | 
						|
            }
 | 
						|
 | 
						|
            return $this->sendLoginResponse($request);
 | 
						|
        }
 | 
						|
 | 
						|
        // If the login attempt was unsuccessful we will increment the number of attempts
 | 
						|
        // to login and redirect the user back to the login form. Of course, when this
 | 
						|
        // user surpasses their maximum number of attempts they will get locked out.
 | 
						|
        $this->incrementLoginAttempts($request);
 | 
						|
 | 
						|
        return $this->sendFailedLoginResponse($request);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Validate the user login request.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @return void
 | 
						|
     *
 | 
						|
     * @throws \Illuminate\Validation\ValidationException
 | 
						|
     */
 | 
						|
    protected function validateLogin(Request $request)
 | 
						|
    {
 | 
						|
        $request->validate([
 | 
						|
            $this->username() => 'required|string',
 | 
						|
            'password' => 'required|string',
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Attempt to log the user into the application.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @return bool
 | 
						|
     */
 | 
						|
    protected function attemptLogin(Request $request)
 | 
						|
    {
 | 
						|
        return $this->guard()->attempt(
 | 
						|
            $this->credentials($request), $request->boolean('remember')
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Get the needed authorization credentials from the request.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @return array
 | 
						|
     */
 | 
						|
    protected function credentials(Request $request)
 | 
						|
    {
 | 
						|
        return $request->only($this->username(), 'password');
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Send the response after the user was authenticated.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @return \Illuminate\Http\RedirectResponse|\Illuminate\Http\JsonResponse
 | 
						|
     */
 | 
						|
    protected function sendLoginResponse(Request $request)
 | 
						|
    {
 | 
						|
        $request->session()->regenerate();
 | 
						|
 | 
						|
        $this->clearLoginAttempts($request);
 | 
						|
 | 
						|
        if ($response = $this->authenticated($request, $this->guard()->user())) {
 | 
						|
            return $response;
 | 
						|
        }
 | 
						|
 | 
						|
        return $request->wantsJson()
 | 
						|
                    ? new JsonResponse([], 204)
 | 
						|
                    : redirect()->intended($this->redirectPath());
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * The user has been authenticated.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @param  mixed  $user
 | 
						|
     * @return mixed
 | 
						|
     */
 | 
						|
    protected function authenticated(Request $request, $user)
 | 
						|
    {
 | 
						|
        //
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 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([
 | 
						|
            $this->username() => [trans('auth.failed')],
 | 
						|
        ]);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Get the login username to be used by the controller.
 | 
						|
     *
 | 
						|
     * @return string
 | 
						|
     */
 | 
						|
    public function username()
 | 
						|
    {
 | 
						|
        return 'email';
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Log the user out of the application.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @return \Illuminate\Http\RedirectResponse|\Illuminate\Http\JsonResponse
 | 
						|
     */
 | 
						|
    public function logout(Request $request)
 | 
						|
    {
 | 
						|
        $this->guard()->logout();
 | 
						|
 | 
						|
        $request->session()->invalidate();
 | 
						|
 | 
						|
        $request->session()->regenerateToken();
 | 
						|
 | 
						|
        if ($response = $this->loggedOut($request)) {
 | 
						|
            return $response;
 | 
						|
        }
 | 
						|
 | 
						|
        return $request->wantsJson()
 | 
						|
            ? new JsonResponse([], 204)
 | 
						|
            : redirect('/');
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * The user has logged out of the application.
 | 
						|
     *
 | 
						|
     * @param  \Illuminate\Http\Request  $request
 | 
						|
     * @return mixed
 | 
						|
     */
 | 
						|
    protected function loggedOut(Request $request)
 | 
						|
    {
 | 
						|
        //
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Get the guard to be used during authentication.
 | 
						|
     *
 | 
						|
     * @return \Illuminate\Contracts\Auth\StatefulGuard
 | 
						|
     */
 | 
						|
    protected function guard()
 | 
						|
    {
 | 
						|
        return Auth::guard();
 | 
						|
    }
 | 
						|
}
 |