Your IP : 216.73.217.77


Current Path : /home/users/unlimited/www/whatsapp-crm/app/Http/Requests/
Upload File :
Current File : /home/users/unlimited/www/whatsapp-crm/app/Http/Requests/PasswordValidateResetRequest.php

<?php

namespace App\Http\Requests;

use App\Models\PasswordResetToken;
use App\Models\Setting;
use App\Models\User;
use App\Rules\Recaptcha;
use Illuminate\Foundation\Http\FormRequest;

class PasswordValidateResetRequest extends FormRequest
{
    /**
     * Determine if the user is authorized to make this request.
     */
    public function authorize(): bool
    {
        return true;
    }

    /**
     * Get the validation rules that apply to the request.
     *
     * @return array<string, \Illuminate\Contracts\Validation\ValidationRule|array|string>
     */
    public function rules(): array
    {
        $code = $this->input('token');
        
        $rules = [
            'password' => [
                'required',
                'confirmed',
                function ($attribute, $value, $fail) use ($code) {
                    if (!$this->isTokenValid($code)) {
                        $fail(__('Your token is invalid!'));
                    }
                },
            ],
        ];

        // Check if recaptcha_active is 1, then add recaptcha_response rule
        if (Setting::getValueByKey('recaptcha_active') === '1') {
            $rules['recaptcha_response'] = ['required', new Recaptcha];
        }

        return $rules;
    }

    private function isTokenValid(string $token): bool
    {
       return !PasswordResetToken::where('token', $token)->exists();
    }
}