'required|unique:custom_fieldsets', ]; /** * Whether the model should inject it's identifier to the unique * validation rules before attempting validation. If this property * is not set in the model it will default to true. * * @var bool */ protected $injectUniqueIdentifier = true; /** * Establishes the fieldset -> field relationship * * @author [Brady Wetherington] [] * @since [v3.0] * @return \Illuminate\Database\Eloquent\Relations\Relation */ public function fields() { return $this->belongsToMany(\App\Models\CustomField::class)->withPivot(['required', 'order'])->orderBy('pivot_order'); } /** * Establishes the fieldset -> models relationship * * @author [Brady Wetherington] [] * @since [v3.0] * @return \Illuminate\Database\Eloquent\Relations\Relation */ public function models() { return $this->hasMany(\App\Models\AssetModel::class, 'fieldset_id'); } /** * Establishes the fieldset -> admin user relationship * * @author [Brady Wetherington] [] * @since [v3.0] * @return \Illuminate\Database\Eloquent\Relations\Relation */ public function user() { return $this->belongsTo(\App\Models\User::class); //WARNING - not all CustomFieldsets have a User!! } /** * Determine the validation rules we should apply based on the * custom field format * * @author [A. Gianotto] [] * @since [v3.0] * @return array */ public function validation_rules() { $rules = []; foreach ($this->fields as $field) { $rule = []; if (($field->field_encrypted != '1') || (($field->field_encrypted == '1') && (Gate::allows('admin')))) { $rule[] = ($field->pivot->required == '1') ? 'required' : 'nullable'; } if ($field->is_unique == '1') { $rule[] = 'unique_undeleted'; } array_push($rule, $field->attributes['format']); $rules[$field->db_column_name()] = $rule; // these are to replace the standard 'numeric' and 'alpha' rules if the custom field is also encrypted. // the values need to be decrypted first, because encrypted strings are alphanumeric if ($field->format === 'NUMERIC' && $field->field_encrypted) { $numericKey = array_search('numeric', $rules[$field->db_column_name()]); $rules[$field->db_column_name()][$numericKey] = new NumericEncrypted; } if ($field->format === 'ALPHA' && $field->field_encrypted) { $alphaKey = array_search('alpha', $rules[$field->db_column_name()]); $rules[$field->db_column_name()][$alphaKey] = new AlphaEncrypted; } // add not_array to rules for all fields but checkboxes if ($field->element != 'checkbox') { $rules[$field->db_column_name()][] = 'not_array'; } if ($field->element == 'checkbox') { $rules[$field->db_column_name()][] = 'checkboxes'; } if ($field->element == 'radio') { $rules[$field->db_column_name()][] = 'radio_buttons'; } } return $rules; } }