asset); } public function prepareForValidation(): void { if ($this->filled('purchase_cost') && ! is_float($this->input('purchase_cost')) && preg_match('/^[\d.,]+$/', (string) $this->input('purchase_cost'))) { $this->merge(['purchase_cost' => Helper::ParseCurrency($this->input('purchase_cost'))]); } } /** * Get the validation rules that apply to the request. * * @return array */ public function rules() { $setting = Setting::getSettings(); $rules = array_merge( parent::rules(), (new Asset)->getRules(), // This overwrites the rulesets that are set at the model level (via Watson) but are not necessarily required at the request level when doing a PATCH update. // Confusingly, this skips the unique_undeleted validator at the model level (and therefore the UniqueUndeletedTrait), so we have to re-add those // rules here without the requiredness, since those values will already exist if you're updating an existing asset. [ 'model_id' => ['integer', 'exists:models,id,deleted_at,NULL', 'not_array'], 'status_id' => ['integer', 'exists:status_labels,id'], 'asset_tag' => [ 'min:1', 'max:255', 'not_array', Rule::unique('assets', 'asset_tag')->ignore($this->asset)->withoutTrashed(), ], 'serial' => [ 'string', 'max:255', 'not_array', $setting->unique_serial == '1' ? Rule::unique('assets', 'serial')->ignore($this->asset)->withoutTrashed() : 'nullable', ], ], ); return $rules; } }