LoginController.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. <?php
  2. namespace App\Http\Controllers\Auth;
  3. use Illuminate\Foundation\Auth\AuthenticatesUsers;
  4. use Illuminate\Validation\ValidationException;
  5. use Illuminate\Support\Facades\Auth;
  6. use Illuminate\Http\Request;
  7. use App\Http\Controllers\Controller;
  8. use App\Providers\RouteServiceProvider;
  9. use App\Models\LoginLog;
  10. use DateTime;
  11. class LoginController extends Controller
  12. {
  13. /*
  14. |--------------------------------------------------------------------------
  15. | Login Controller
  16. |--------------------------------------------------------------------------
  17. |
  18. | This controller handles authenticating users for the application and
  19. | redirecting them to your home screen. The controller uses a trait
  20. | to conveniently provide its functionality to your applications.
  21. |
  22. */
  23. use AuthenticatesUsers;
  24. /**
  25. * Where to redirect users after login.
  26. *
  27. * @var string
  28. */
  29. protected $redirectTo = RouteServiceProvider::HOME;
  30. /**
  31. * Create a new controller instance.
  32. *
  33. * @return void
  34. */
  35. public function __construct()
  36. {
  37. $this->middleware(['guest', 'front'])->except('logout');
  38. }
  39. /**
  40. * 로그인 시 uid 검증 사용
  41. */
  42. public function username()
  43. {
  44. return 'email';
  45. }
  46. /**
  47. * Show the application's login form.
  48. *
  49. * @return \Illuminate\View\View
  50. */
  51. public function showLoginForm()
  52. {
  53. $env = strtoupper(env('DEVELOPER_ENV'));
  54. $email = "";
  55. $password = "";
  56. if($env == 'LOCAL') {
  57. $email = 'playedcompany@gmail.com';
  58. $password = '12341234';
  59. }
  60. return view('auth.login', [
  61. 'email' => $email,
  62. 'password' => $password,
  63. ]);
  64. }
  65. /**
  66. * 로그인 창에서 처리 요청 시 처리 방식을 변경한다.
  67. */
  68. public function credentials(Request $request)
  69. {
  70. $inputParam = $request->only($this->username(), 'password');
  71. return [
  72. 'email' => $inputParam['email'],
  73. 'password' => $inputParam['password'],
  74. 'is_withdraw' => 0,
  75. 'deleted_at' => null
  76. ];
  77. }
  78. /**
  79. * 로그인 시 마지막 로그인 시간 기록
  80. */
  81. public function authenticated(Request $request, $user)
  82. {
  83. // 이메일 인증을 받았는지 확인
  84. if(!$user->hasVerifiedEmail()) {
  85. Auth::logout(); // 강제 로그아웃
  86. return view('auth.verify');
  87. }
  88. // 로그인 성공 기록
  89. (new LoginLog)->setSucceedLog($user->email, "로그인 성공");
  90. // 로그인 일시, IP 갱신
  91. $user->update([
  92. 'last_login_at' => now(),
  93. 'last_login_ip' => $request->getClientIp()
  94. ]);
  95. // 비밀번호 갱신 주기 확인
  96. $chgPwdDay = (int)config('change_password_day', 0);
  97. if($chgPwdDay > 0) {
  98. $diffDay = (int)((new DateTime($user->password_updated_at))->diff(new DateTime)->format("%r%a"));
  99. if($diffDay >= $chgPwdDay) {
  100. return redirect()->route('account.password.campaign');
  101. }
  102. }
  103. }
  104. /**
  105. * 로그인 실패 시 처리
  106. */
  107. protected function sendFailedLoginResponse(Request $request)
  108. {
  109. // 로그인 시도 제한 여부
  110. $msg = ($this->hasTooManyLoginAttempts($request) ? '로그인 시도 횟수 초과' : '로그인 실패, ID/PW 불일치');
  111. $email = $request->post('email');
  112. // 로그인 실패 기록
  113. (new LoginLog)->setFailedLog($email, $msg);
  114. // 로그인 실패 기록
  115. throw ValidationException::withMessages([
  116. $this->username() => [trans('auth.failed')],
  117. ]);
  118. }
  119. /**
  120. * 로그인 후 이동 주소
  121. */
  122. public function redirectTo()
  123. {
  124. return request()->post('callback') ?? DIRECTORY_SEPARATOR . config('url_after_login');
  125. }
  126. /**
  127. * 로그인 시도 제한 횟수
  128. */
  129. public function maxAttempts()
  130. {
  131. return intval(config('max_login_try_count', 6));
  132. }
  133. /**
  134. * 로그인 시도 제한 시간
  135. */
  136. public function decayMinutes()
  137. {
  138. return intval(config('max_login_try_limit_second', 60) / 60);
  139. }
  140. /**
  141. * 로그아웃 후 처리
  142. */
  143. protected function loggedOut(Request $request)
  144. {
  145. if($to = config('url_after_logout')) {
  146. return redirect($to)->call(function() {
  147. Auth::logout();
  148. });
  149. }
  150. }
  151. }