我编写了一个自定义规则方法,用于在添加新记录之前验证数据库中是否存在记录。我将该方法放入行为中,以便可以与其他模型共享它,但我遇到了先有鸡还是先有蛋的情况。
为了知道某个类别是否已经具有特定的组名称,我需要有类别 ID 和组名称。因此,我使用自定义规则(category_id 和 name)传递这些键。但是,这是行不通的,因为如果我没有错误地选择category_id,那么查询将仅在名称上发生,所以我用几行修补了它,但如果是这种情况,需要返回 true 并继续下去Category_id 验证无效。
有没有更好的方法来实现这种验证?这不是我想象的那么糟糕吗?或者只是不要打扰,在我的控制器中将 hasAny() 放在我对 validates() 的调用下(如果它通过了)。
MODEL:
public $validate = [
'category_id' => [
'rule' => 'notEmpty',
'message' => 'Category is required.'
],
'name' => [
'notEmpty' => [
'rule' => 'notEmpty',
'message' => 'Team is required.'
],
'recordExists' => [
'rule' => [ 'recordExists', [ 'category_id', 'name' ] ],
'message' => 'Group already exists.'
]
]
];
// BEHAVIOR:
public function recordExists( Model $Model, $conditions, $requireKeys )
{
// Overrite conditions to
$conditions = $Model->data[ $Model->name ];
// Trim all array elements and filter out any empty indexes
$conditions = array_map( 'trim', $conditions );
$conditions = array_filter( $conditions );
// Get the remaining non-empty keys
$conditionKeys = array_keys( $conditions );
// Only query for record if all required keys are in conditions
if (empty( array_diff( $requireKeys, $conditionKeys ) )) {
return !$Model->hasAny( $conditions );
}
// NOTE: seems wrong to return true based on the assumption the category_id validation has probably failed
return true;
}
使用模型的 beforeValidate() 回调来检查字段是否存在以及是否为空。如果它们为空,只需 unset() 模型验证属性中的
recordExists
验证规则。如果您想在当前操作后将它们设置回来,请将它们复制到临时变量或属性中。
并使用
$Model->alias
,如果通过具有不同名称的关联使用模型,name
将会中断。
$conditions = $Model->data[ $Model->name ];