File: //home/marketing.cfbon.ru/public_html/app/Http/Requests/AdminUsers/UpdateRequest.php
<?php
namespace App\Http\Requests\AdminUsers;
use App\Enums\UserRole;
use Illuminate\Foundation\Http\FormRequest;
use Illuminate\Validation\Rule;
class UpdateRequest 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<mixed>|string>
     */
    public function rules(): array
    {
        $currentUserId = $this->route('admin_user');
        return [
            'name' => ['required', 'string', Rule::unique('users')->ignore($currentUserId)->whereNull('deleted_at')],
            'email' => ['required', 'string', 'email', Rule::unique('users')->ignore($currentUserId)],
            'role' => ['required', Rule::enum(UserRole::class)],
        ];
    }
    public function messages()
    {
        return [
            'name.required' => 'Это поле необходимо для заполнения',
            'name.string' => 'Имя пользователя должна быть строкой',
            'name.unique' => 'Пользователь с таким логином уже существует',
            'email.required' => 'Это поле необходимо для заполнения',
            'email.string' => 'Почта должна быть строкой',
            'email.email' => 'Ваша почта должна соответсвовать формату test@test.ru',
            'email.unique' => 'Пользователь с таким email уже существует',
            'role.enum' => 'Выбрана недопустимая роль',
        ];
    }
}