我写了一个自定义规则方法,用于在添加新记录之前验证数据库中是否存在记录。我把这个方法放在一个行为中,所以我可以和其他模特分享,但我遇到了鸡蛋和鸡蛋的情况。
为了知道某个类别是否具有特定的组名,我需要具有类别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;
}
答案 0 :(得分:2)
使用模型的beforeValidate()回调来检查字段是否存在以及它们是否为空。如果它们为空,则只需取消设置()模型验证属性中的recordExists
验证规则。如果要在当前操作后将它们设置回来,请将它们复制到临时变量或属性。
如果通过具有不同名称的关联使用模型,则使用$Model->alias
,name
将会中断。
$conditions = $Model->data[ $Model->name ];