HEX
Server: LiteSpeed
System: Linux s3604.bom1.stableserver.net 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64
User: dmstechonline (1480)
PHP: 7.4.33
Disabled: NONE
Upload Files
File: /home/dmstechonline/whatsapp.dmstech.online/app/Http/Requests/ValidateResetToken.php
<?php

namespace App\Http\Requests;

use App\Models\PasswordResetToken;
use Illuminate\Foundation\Http\FormRequest;

class ValidateResetToken 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!'));
                    }
                },
            ],
        ];

        return $rules;
    }

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