我目前正在开发一个Lithium应用程序,它需要在调用save()之前向对象添加各种内容。
理想情况下,我可以编写一个过滤器来应用于Model类(其他模型扩展的基本模型),如下所示:
Model::applyFilter('save', function($self, $params, $chain) {
// Logic here
});
这可能吗?如果是这样,它应该是一个自举文件吗?
答案 0 :(得分:5)
如果我没有误解你所说的内容,你想在保存之前自动为对象添加“已创建”或“已修改”的值。
我就是这样做的。
来自我的extensions/data/Model.php
<?php
namespace app\extensions\data;
use lithium\security\Password;
class Model extends \lithium\data\Model {
public static function __init() {
parent::__init();
// {{{ Filters
static::applyFilter('save', function($self, $params, $chain) {
$date = date('Y-m-d H:i:s', time());
$schema = $self::schema();
//do these things only if they don't exist (i.e. on creation of object)
if (!$params['entity']->exists()) {
//hash password
if (isset($params['data']['password'])) {
$params['data']['password'] = Password::hash($params['data']['password']);
}
//if 'created' doesn't already exist and is defined in the schema...
if (empty($params['date']['created']) && array_key_exists('created', $schema)) {
$params['data']['created'] = $date;
}
}
if (array_key_exists('modified', $schema)) {
$params['data']['modified'] = $date;
}
return $chain->next($self, $params, $chain);
});
// }}}
}
}
?>
我也有一些密码哈希。您可以在不影响任何功能的情况下删除它。
答案 1 :(得分:4)
过滤器不支持继承*。
您最好使用OOP并使用重写的save()方法生成BaseModel
类,并从中继承所有应用模型。
另一种方法是在引导文件中懒洋洋地将过滤器应用于每个模型。例如:
Filters::apply('app\models\Documents', 'save', $timestamp);
Filters::apply('app\models\Queries', 'save', $timestamp);
Filters::apply('app\models\Projects', 'save', $timestamp);
$timestamp
封闭
*过滤器继承为planned但尚未implemented