239 lines
6.0 KiB
PHP
239 lines
6.0 KiB
PHP
<?php
|
|
// +----------------------------------------------------------------------
|
|
// | ThinkPHP [ WE CAN DO IT JUST THINK ]
|
|
// +----------------------------------------------------------------------
|
|
// | Copyright (c) 2006~2018 http://thinkphp.cn All rights reserved.
|
|
// +----------------------------------------------------------------------
|
|
// | Licensed ( http://www.apache.org/licenses/LICENSE-2.0 )
|
|
// +----------------------------------------------------------------------
|
|
// | Author: liu21st <liu21st@gmail.com>
|
|
// +----------------------------------------------------------------------
|
|
|
|
namespace think\model\concern;
|
|
|
|
use think\Container;
|
|
use think\Loader;
|
|
|
|
/**
|
|
* 模型事件处理
|
|
*/
|
|
trait ModelEvent
|
|
{
|
|
/**
|
|
* 模型回调
|
|
* @var array
|
|
*/
|
|
private static $event = [];
|
|
|
|
/**
|
|
* 模型事件观察
|
|
* @var array
|
|
*/
|
|
protected static $observe = ['before_write', 'after_write', 'before_insert', 'after_insert', 'before_update', 'after_update', 'before_delete', 'after_delete', 'before_restore', 'after_restore'];
|
|
|
|
/**
|
|
* 绑定模型事件观察者类
|
|
* @var array
|
|
*/
|
|
protected $observerClass;
|
|
|
|
/**
|
|
* 是否需要事件响应
|
|
* @var bool
|
|
*/
|
|
private $withEvent = true;
|
|
|
|
/**
|
|
* 注册回调方法
|
|
* @access public
|
|
* @param string $event 事件名
|
|
* @param callable $callback 回调方法
|
|
* @param bool $override 是否覆盖
|
|
* @return void
|
|
*/
|
|
public static function event($event, $callback, $override = false)
|
|
{
|
|
$class = static::class;
|
|
|
|
if ($override) {
|
|
self::$event[$class][$event] = [];
|
|
}
|
|
|
|
self::$event[$class][$event][] = $callback;
|
|
}
|
|
|
|
/**
|
|
* 清除回调方法
|
|
* @access public
|
|
* @return void
|
|
*/
|
|
public static function flushEvent()
|
|
{
|
|
self::$event[static::class] = [];
|
|
}
|
|
|
|
/**
|
|
* 注册一个模型观察者
|
|
*
|
|
* @param object|string $class
|
|
* @return void
|
|
*/
|
|
public static function observe($class)
|
|
{
|
|
self::flushEvent();
|
|
|
|
foreach (static::$observe as $event) {
|
|
$eventFuncName = Loader::parseName($event, 1, false);
|
|
|
|
if (method_exists($class, $eventFuncName)) {
|
|
static::event($event, [$class, $eventFuncName]);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 当前操作的事件响应
|
|
* @access protected
|
|
* @param bool $event 是否需要事件响应
|
|
* @return $this
|
|
*/
|
|
public function withEvent($event)
|
|
{
|
|
$this->withEvent = $event;
|
|
return $this;
|
|
}
|
|
|
|
/**
|
|
* 触发事件
|
|
* @access protected
|
|
* @param string $event 事件名
|
|
* @return bool
|
|
*/
|
|
protected function trigger($event)
|
|
{
|
|
$class = static::class;
|
|
|
|
if ($this->withEvent && isset(self::$event[$class][$event])) {
|
|
foreach (self::$event[$class][$event] as $callback) {
|
|
$result = Container::getInstance()->invoke($callback, [$this]);
|
|
|
|
if (false === $result) {
|
|
return false;
|
|
}
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
/**
|
|
* 模型before_insert事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function beforeInsert($callback, $override = false)
|
|
{
|
|
self::event('before_insert', $callback, $override);
|
|
}
|
|
|
|
/**
|
|
* 模型after_insert事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function afterInsert($callback, $override = false)
|
|
{
|
|
self::event('after_insert', $callback, $override);
|
|
}
|
|
|
|
/**
|
|
* 模型before_update事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function beforeUpdate($callback, $override = false)
|
|
{
|
|
self::event('before_update', $callback, $override);
|
|
}
|
|
|
|
/**
|
|
* 模型after_update事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function afterUpdate($callback, $override = false)
|
|
{
|
|
self::event('after_update', $callback, $override);
|
|
}
|
|
|
|
/**
|
|
* 模型before_write事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function beforeWrite($callback, $override = false)
|
|
{
|
|
self::event('before_write', $callback, $override);
|
|
}
|
|
|
|
/**
|
|
* 模型after_write事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function afterWrite($callback, $override = false)
|
|
{
|
|
self::event('after_write', $callback, $override);
|
|
}
|
|
|
|
/**
|
|
* 模型before_delete事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function beforeDelete($callback, $override = false)
|
|
{
|
|
self::event('before_delete', $callback, $override);
|
|
}
|
|
|
|
/**
|
|
* 模型after_delete事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function afterDelete($callback, $override = false)
|
|
{
|
|
self::event('after_delete', $callback, $override);
|
|
}
|
|
|
|
/**
|
|
* 模型before_restore事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function beforeRestore($callback, $override = false)
|
|
{
|
|
self::event('before_restore', $callback, $override);
|
|
}
|
|
|
|
/**
|
|
* 模型after_restore事件快捷方法
|
|
* @access protected
|
|
* @param callable $callback
|
|
* @param bool $override
|
|
*/
|
|
protected static function afterRestore($callback, $override = false)
|
|
{
|
|
self::event('after_restore', $callback, $override);
|
|
}
|
|
}
|