mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 11:06:15 +00:00
Merge pull request #1708 from dereuromark/2.5-behavior-whitelist
Fix whitelist to be modifiable from behaviors to work with validate.
This commit is contained in:
commit
02acf636a7
2 changed files with 51 additions and 1 deletions
|
@ -249,7 +249,11 @@ class ModelValidator implements ArrayAccess, IteratorAggregate, Countable {
|
||||||
return $model->validationErrors;
|
return $model->validationErrors;
|
||||||
}
|
}
|
||||||
|
|
||||||
$fieldList = isset($options['fieldList']) ? $options['fieldList'] : array();
|
$fieldList = $model->whitelist;
|
||||||
|
if (empty($fieldList) && !empty($options['fieldList'])) {
|
||||||
|
$fieldList = $options['fieldList'];
|
||||||
|
}
|
||||||
|
|
||||||
$exists = $model->exists();
|
$exists = $model->exists();
|
||||||
$methods = $this->getMethods();
|
$methods = $this->getMethods();
|
||||||
$fields = $this->_validationList($fieldList);
|
$fields = $this->_validationList($fieldList);
|
||||||
|
|
|
@ -612,6 +612,34 @@ class ModelValidationTest extends BaseModelTest {
|
||||||
$this->assertEquals(0, $joinRecords, 'Records were saved on the join table. %s');
|
$this->assertEquals(0, $joinRecords, 'Records were saved on the join table. %s');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Test that if a behavior modifies the model's whitelist validation gets triggered
|
||||||
|
* properly for those fields.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function testValidateWithFieldListAndBehavior() {
|
||||||
|
$TestModel = new ValidationTest1();
|
||||||
|
$TestModel->validate = array(
|
||||||
|
'title' => array(
|
||||||
|
'rule' => 'notEmpty',
|
||||||
|
),
|
||||||
|
'name' => array(
|
||||||
|
'rule' => 'notEmpty',
|
||||||
|
));
|
||||||
|
$TestModel->Behaviors->attach('ValidationRule', array('fields' => array('name')));
|
||||||
|
|
||||||
|
$data = array(
|
||||||
|
'title' => '',
|
||||||
|
'name' => '',
|
||||||
|
);
|
||||||
|
$result = $TestModel->save($data, array('fieldList' => array('title')));
|
||||||
|
$this->assertFalse($result);
|
||||||
|
|
||||||
|
$expected = array('title' => array('This field cannot be left blank'), 'name' => array('This field cannot be left blank'));
|
||||||
|
$this->assertEquals($expected, $TestModel->validationErrors);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* test that saveAll and with models with validation interact well
|
* test that saveAll and with models with validation interact well
|
||||||
*
|
*
|
||||||
|
@ -2380,3 +2408,21 @@ class ModelValidationTest extends BaseModelTest {
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Behavior for testing validation rules.
|
||||||
|
*/
|
||||||
|
class ValidationRuleBehavior extends ModelBehavior {
|
||||||
|
|
||||||
|
public function setup(Model $Model, $config = array()) {
|
||||||
|
$this->settings[$Model->alias] = $config;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function beforeValidate(Model $Model, $options = array()) {
|
||||||
|
$fields = $this->settings[$Model->alias]['fields'];
|
||||||
|
foreach ($fields as $field) {
|
||||||
|
$Model->whitelist[] = $field;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue