Использование расширения проверки работало бы:
// register the rule in AppServiceProvider.php
Validator::extend('custom_rule', function ($attribute, $value, $parameters, $validator) {
// field1 is accessible in $parameters. Add your custom validation logic here, for example:
return $value < $parameters[0];
});
Затем передайте значение field1
правилу в качестве параметра:
public function rules()
{
$rules = [
'array' => ['array'],
'array.*.field1' => [
'required',
'integer',
'min:1',
'distinct',
]
];
foreach ($this->array as $idx => $val) {
$rules['array.' . $idx . '.field2'] = [
'required',
'integer',
'min:1',
'custom_rule:' . $val['field1'],
];
}
return $rules;
}
Использование объекта правила:
class CustomRule implements Rule
{
public $field1;
public function __construct($field1)
{
$this->field1 = $field1;
}
/**
* Determine if the validation rule passes.
*
* @param string $attribute
* @param mixed $value
* @return bool
*/
public function passes($attribute, $value)
{
return $value < $this->field1;
}
/**
* Get the validation error message.
*
* @return string
*/
public function message()
{
return 'The :attribute must be less than field1.';
}
}
// loop the array elements
foreach ($this->array as $idx => $val) {
$rules['array.' . $idx . '.field2'] = [
'required',
'integer',
'min:1',
new CustomRule($val['field1']),
];
}