Remove the unique constraint on the 'cif' field in the debitures table and refactor the `UniqueCifExceptZero` validation rule to handle the uniqueness check more robustly. Also, add an unused import statement for `UniqueExcept` in `DebitureRequest`.
33 lines
908 B
PHP
33 lines
908 B
PHP
<?php
|
|
|
|
namespace Modules\Lpj\Rules;
|
|
|
|
use Closure;
|
|
use Illuminate\Contracts\Validation\ValidationRule;
|
|
use Modules\Lpj\Models\Debiture;
|
|
|
|
class UniqueCifExceptZero implements ValidationRule
|
|
{
|
|
protected $id;
|
|
|
|
public function __construct($id = null)
|
|
{
|
|
$this->id = $id;
|
|
}
|
|
|
|
/**
|
|
* Run the validation rule.
|
|
*/
|
|
public function validate(string $attribute, mixed $value, Closure $fail)
|
|
: void {
|
|
if ($value !== '0000000000' && $value !== null && Debiture::query()->where($attribute, $value)->when(
|
|
$this->id,
|
|
function ($query) {
|
|
$query->where('id', '!=', $this->id);
|
|
},
|
|
)->exists()) {
|
|
$fail('The :attribute field must be unique.');
|
|
}
|
|
}
|
|
}
|