mirror of
https://github.com/snipe/snipe-it.git
synced 2025-01-03 18:07:41 -08:00
59 lines
1.5 KiB
PHP
59 lines
1.5 KiB
PHP
<?php
|
|
namespace App\Models;
|
|
|
|
use Illuminate\Database\Eloquent\Model;
|
|
use Gate;
|
|
use Watson\Validating\ValidatingTrait;
|
|
|
|
class CustomFieldset extends Model
|
|
{
|
|
protected $guarded=["id"];
|
|
|
|
public $rules=[
|
|
"name" => "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 boolean
|
|
*/
|
|
protected $injectUniqueIdentifier = true;
|
|
use ValidatingTrait;
|
|
|
|
|
|
public function fields()
|
|
{
|
|
return $this->belongsToMany('\App\Models\CustomField')->withPivot(["required","order"])->orderBy("pivot_order");
|
|
}
|
|
|
|
public function models()
|
|
{
|
|
return $this->hasMany('\App\Models\AssetModel', "fieldset_id");
|
|
}
|
|
|
|
public function user()
|
|
{
|
|
return $this->belongsTo('\App\Models\User'); //WARNING - not all CustomFieldsets have a User!!
|
|
}
|
|
|
|
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";
|
|
}
|
|
|
|
array_push($rule, $field->attributes['format']);
|
|
$rules[$field->db_column_name()]=$rule;
|
|
}
|
|
return $rules;
|
|
}
|
|
}
|