Проверка уникального поля Laravel - PullRequest
0 голосов
/ 20 октября 2018

У меня есть модель продукта с полем ввода текста для номера продукта.В моем приложении Laravel я проверяю это поле как уникальное для этого конкретного пользователя.Таким образом, два пользователя могут иметь один и тот же номер продукта, но один пользователь не может иметь дубликат.До сих пор правила проверки работали при добавлении новых продуктов:

'product_no' => 'nullable|unique:products,product_no,NULL,id,user_id,' . auth()->user()->id

Однако при редактировании того же продукта проверка не проходит.Вероятно, потому что это уже существует.Я не уверен, как исключить существующий идентификатор в проверке.Есть идеи?

1 Ответ

0 голосов
/ 22 октября 2018

Пример по запросу

namespace App\Http\Requests;

use Illuminate\Foundation\Http\FormRequest;

class Request1 extends FormRequest
{
    private $rules;

    /**
     * Determine if the user is authorized to make this request.
     *
     * @return bool
     */
    public function authorize()
    {
        return true;
    }

    public function __construct()
    {
         parent::__construct();
         $this->rules = [
            'password' => [
                'nullable',
            ]
        ];
    }

    /**
     * Get the validation rules that apply to the request.
     *
     * @return array
     */
    public function rules()
    {
        return $this->rules;
    }
}

А тот, у которого уникальность, выглядит так

namespace App\Http\Requests;

use Illuminate\Foundation\Http\FormRequest;

class Request2 extends Request1
{

    public function __construct()
    {
         parent::__construct();
         $this->rules[] = 'unique:products,product_no,NULL,id,user_id,' . auth()->user()->id';  
    }

    /**
     * Get the validation rules that apply to the request.
     *
     * @return array
     */
    public function rules()
    {
        return $this->rules;
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...