| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175 |
- <?php
- namespace App\Http\Controllers\Auth;
- use Illuminate\Foundation\Auth\AuthenticatesUsers;
- use Illuminate\Validation\ValidationException;
- use Illuminate\Support\Facades\Auth;
- use Illuminate\Http\Request;
- use App\Http\Controllers\Controller;
- use App\Providers\RouteServiceProvider;
- use App\Models\LoginLog;
- use DateTime;
- 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 = RouteServiceProvider::HOME;
- /**
- * Create a new controller instance.
- *
- * @return void
- */
- public function __construct()
- {
- $this->middleware(['guest', 'front'])->except('logout');
- }
- /**
- * 로그인 시 uid 검증 사용
- */
- public function username()
- {
- return 'email';
- }
- /**
- * Show the application's login form.
- *
- * @return \Illuminate\View\View
- */
- public function showLoginForm()
- {
- $env = strtoupper(env('DEVELOPER_ENV'));
- $email = "";
- $password = "";
- if($env == 'LOCAL') {
- $email = 'playedcompany@gmail.com';
- $password = '12341234';
- }
- return view('auth.login', [
- 'email' => $email,
- 'password' => $password,
- ]);
- }
- /**
- * 로그인 창에서 처리 요청 시 처리 방식을 변경한다.
- */
- public function credentials(Request $request)
- {
- $inputParam = $request->only($this->username(), 'password');
- return [
- 'email' => $inputParam['email'],
- 'password' => $inputParam['password'],
- 'is_withdraw' => 0,
- 'deleted_at' => null
- ];
- }
- /**
- * 로그인 시 마지막 로그인 시간 기록
- */
- public function authenticated(Request $request, $user)
- {
- // 이메일 인증을 받았는지 확인
- if(!$user->hasVerifiedEmail()) {
- Auth::logout(); // 강제 로그아웃
- return view('auth.verify');
- }
- // 로그인 성공 기록
- (new LoginLog)->setSucceedLog($user->email, "로그인 성공");
- // 로그인 일시, IP 갱신
- $user->update([
- 'last_login_at' => now(),
- 'last_login_ip' => $request->getClientIp()
- ]);
- // 비밀번호 갱신 주기 확인
- $chgPwdDay = (int)config('change_password_day', 0);
- if($chgPwdDay > 0) {
- $diffDay = (int)((new DateTime($user->password_updated_at))->diff(new DateTime)->format("%r%a"));
- if($diffDay >= $chgPwdDay) {
- return redirect()->route('account.password.campaign');
- }
- }
- }
- /**
- * 로그인 실패 시 처리
- */
- protected function sendFailedLoginResponse(Request $request)
- {
- // 로그인 시도 제한 여부
- $msg = ($this->hasTooManyLoginAttempts($request) ? '로그인 시도 횟수 초과' : '로그인 실패, ID/PW 불일치');
- $email = $request->post('email');
- // 로그인 실패 기록
- (new LoginLog)->setFailedLog($email, $msg);
- // 로그인 실패 기록
- throw ValidationException::withMessages([
- $this->username() => [trans('auth.failed')],
- ]);
- }
- /**
- * 로그인 후 이동 주소
- */
- public function redirectTo()
- {
- return request()->post('callback') ?? DIRECTORY_SEPARATOR . config('url_after_login');
- }
- /**
- * 로그인 시도 제한 횟수
- */
- public function maxAttempts()
- {
- return intval(config('max_login_try_count', 6));
- }
- /**
- * 로그인 시도 제한 시간
- */
- public function decayMinutes()
- {
- return intval(config('max_login_try_limit_second', 60) / 60);
- }
- /**
- * 로그아웃 후 처리
- */
- protected function loggedOut(Request $request)
- {
- if($to = config('url_after_logout')) {
- return redirect($to)->call(function() {
- Auth::logout();
- });
- }
- }
- }
|