File manager - Edit - /var/www/payraty/hris/app/Http/Requests/Auth/LoginRequest.php
Back
<?php namespace App\Http\Requests\Auth; use App\Models\User; use Illuminate\Auth\Events\Lockout; use Illuminate\Foundation\Http\FormRequest; use Illuminate\Support\Facades\Auth; use Illuminate\Support\Facades\RateLimiter; use Illuminate\Support\Str; use Illuminate\Validation\ValidationException; class LoginRequest extends FormRequest { /** * Determine if the user is authorized to make this request. * * @return bool */ public function authorize() { return true; } /** * Get the validation rules that apply to the request. * * @return array */ public function rules() { return [ 'email' => ['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_enable_login != 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(); } }
| ver. 1.4 |
Github
|
.
| PHP 8.3.30 | Generation time: 0 |
proxy
|
phpinfo
|
Settings