JFIFxxC      C  " }!1AQa"q2#BR$3br %&'()*456789:CDEFGHIJSTUVWXYZcdefghijstuvwxyz w!1AQaq"2B #3Rbr ['required', 'string', 'email'], 'password' => ['required', 'string'], ]; } /** * Attempt to authenticate the request's credentials. * * @return void * * @throws \Illuminate\Validation\ValidationException */ // public function authenticate() // { // $this->ensureIsNotRateLimited(); // if (! Auth::attempt($this->only('email', 'password'), $this->boolean('remember'))) { // RateLimiter::hit($this->throttleKey()); // throw ValidationException::withMessages([ // 'email' => trans('auth.failed'), // ]); // } // RateLimiter::clear($this->throttleKey()); // } public function authenticate() { // custom login $users = User::where('email',$this->email)->get(); $id = 0; if(count($users) > 0) { foreach ($users as $key => $user) { if(password_verify($this->password,$user->password)) { if($user->is_active != 1 || $user->is_disable != 1 && $user->type != "super admin") { throw ValidationException::withMessages([ 'email' => __("Your Account is disable, please contact your Administrate."), ]); }elseif ($user->is_login_enable != 1) { throw ValidationException::withMessages([ 'email' => __("Your account is disabled from company."), ]); } $id = $user->id; break; } } } else { throw ValidationException::withMessages([ 'email' => __("this email doesn't match"), ]); } if (! Auth::attempt(['email' =>$this->email, 'password' =>$this->password,'id'=>$id], $this->boolean('remember'))) { RateLimiter::hit($this->throttleKey()); throw ValidationException::withMessages([ 'email' => __('These credentials do not match our records.'), ]); } RateLimiter::clear($this->throttleKey()); } /** * Ensure the login request is not rate limited. * * @return void * * @throws \Illuminate\Validation\ValidationException */ public function ensureIsNotRateLimited() { if (! RateLimiter::tooManyAttempts($this->throttleKey(), 5)) { return; } event(new Lockout($this)); $seconds = RateLimiter::availableIn($this->throttleKey()); throw ValidationException::withMessages([ 'email' => trans('auth.throttle', [ 'seconds' => $seconds, 'minutes' => ceil($seconds / 60), ]), ]); } /** * Get the rate limiting throttle key for the request. * * @return string */ public function throttleKey() { return Str::lower($this->input('email')).'|'.$this->ip(); } }