mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-18 18:46:17 +00:00
Making ModelBehavior beforeX callbacks default to returning true. Returning null or false from a Behavior::before method will abort the operation. It felt illogical to have null continue, but false stop.
This commit is contained in:
parent
48879f8264
commit
3c69d9b138
2 changed files with 19 additions and 11 deletions
|
@ -1322,7 +1322,7 @@ class Model extends Object {
|
|||
|
||||
if ($options['callbacks'] === true || $options['callbacks'] === 'before') {
|
||||
$result = $this->Behaviors->trigger('beforeSave', array(&$this, $options), array(
|
||||
'break' => true, 'breakOn' => false
|
||||
'break' => true, 'breakOn' => array(false, null)
|
||||
));
|
||||
if (!$result || !$this->beforeSave($options)) {
|
||||
$this->whitelist = $_whitelist;
|
||||
|
@ -1854,7 +1854,7 @@ class Model extends Object {
|
|||
$filters = $this->Behaviors->trigger(
|
||||
'beforeDelete',
|
||||
array(&$this, $cascade),
|
||||
array('break' => true, 'breakOn' => false)
|
||||
array('break' => true, 'breakOn' => array(false, null))
|
||||
);
|
||||
if (!$filters || !$this->exists()) {
|
||||
return false;
|
||||
|
@ -1876,7 +1876,7 @@ class Model extends Object {
|
|||
if (!empty($this->belongsTo)) {
|
||||
$this->updateCounterCache($keys[$this->alias]);
|
||||
}
|
||||
$this->Behaviors->trigger($this, 'afterDelete');
|
||||
$this->Behaviors->trigger('afterDelete', array(&$this));
|
||||
$this->afterDelete();
|
||||
$this->_clearCache();
|
||||
$this->id = false;
|
||||
|
@ -2142,8 +2142,8 @@ class Model extends Object {
|
|||
if ($query['callbacks'] === true || $query['callbacks'] === 'before') {
|
||||
$return = $this->Behaviors->trigger(
|
||||
'beforeFind',
|
||||
array(&$this, $query),
|
||||
array('break' => true, 'breakOn' => false, 'modParams' => 1)
|
||||
array(&$this, $query),
|
||||
array('break' => true, 'breakOn' => array(false, null), 'modParams' => 1)
|
||||
);
|
||||
|
||||
$query = (is_array($return)) ? $return : $query;
|
||||
|
|
|
@ -80,7 +80,7 @@ class ModelBehavior extends Object {
|
|||
*
|
||||
* @param object $model Model using this behavior
|
||||
* @param array $queryData Data used to execute this query, i.e. conditions, order, etc.
|
||||
* @return mixed False if the operation should abort. An array will replace the value of $query.
|
||||
* @return mixed False or null will abort the operation. You should array will replace the value of $query.
|
||||
* @access public
|
||||
*/
|
||||
public function beforeFind($model, $query) { }
|
||||
|
@ -100,10 +100,12 @@ class ModelBehavior extends Object {
|
|||
* Before validate callback
|
||||
*
|
||||
* @param object $model Model using this behavior
|
||||
* @return mixed False if the operation should abort. Any other result will continue.
|
||||
* @return mixed False or null will abort the operation. Any other result will continue.
|
||||
* @access public
|
||||
*/
|
||||
public function beforeValidate($model) { }
|
||||
public function beforeValidate($model) {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Before save callback
|
||||
|
@ -112,7 +114,9 @@ class ModelBehavior extends Object {
|
|||
* @return mixed False if the operation should abort. Any other result will continue.
|
||||
* @access public
|
||||
*/
|
||||
public function beforeSave($model) { }
|
||||
public function beforeSave($model) {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* After save callback
|
||||
|
@ -120,7 +124,9 @@ class ModelBehavior extends Object {
|
|||
* @param object $model Model using this behavior
|
||||
* @param boolean $created True if this save created a new record
|
||||
*/
|
||||
public function afterSave($model, $created) { }
|
||||
public function afterSave($model, $created) {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* Before delete callback
|
||||
|
@ -130,7 +136,9 @@ class ModelBehavior extends Object {
|
|||
* @return mixed False if the operation should abort. Any other result will continue.
|
||||
* @access public
|
||||
*/
|
||||
public function beforeDelete($model, $cascade = true) { }
|
||||
public function beforeDelete($model, $cascade = true) {
|
||||
return true;
|
||||
}
|
||||
|
||||
/**
|
||||
* After delete callback
|
||||
|
|
Loading…
Add table
Reference in a new issue