| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203 | 
							- <?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();
 
-     }
 
- }
 
 
  |