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/SignupRequest.php
<?php

namespace App\Http\Requests;

use App\Models\Addon;
use App\Models\Setting;
use App\Rules\Recaptcha;
use App\Rules\UniqueEmail;
use Illuminate\Foundation\Http\FormRequest;

class SignupRequest 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
    {
        $rules = [
            'first_name' => 'required',
            'last_name' => 'required',
        ];

        if ($this->isMethod('put')) {
            $rules['email'] = ['required', 'email', new UniqueEmail($this->route('user'))];
        } else {
            $rules['email'] = ['required', 'email', new UniqueEmail];

            if ($this->has('organization_name')) {
                $rules['organization_name'] = 'required';
            }

            if ($this->has('phone')) {
                $rules['phone'] = [
                    'required',
                    'string',
                    'max:255',
                    'phone:AUTO',
                ];
            }
        }

        // Only require password if it exists in the request
        if ($this->has('password')) {
            $rules['password'] = 'required|confirmed';
        }

        // Check if recaptcha_active is 1, then add recaptcha_response rule
        if (Addon::where('name', 'Google Recaptcha')->first()->is_active === '1') {
            $rules['recaptcha_response'] = ['required', new Recaptcha];
        }

        return $rules;
    }
}