Log.class.php 2.01 KB
<?php
/**
 * 记录日志的插件
 * 
 * @name Lib_Plugin_Log
 * @package lib/plugin
 * @copyright yoho.inc
 * @version 5.0 (2014-2-14 10:48:39)
 * @author fei.hong <fei.hong@yoho.cn>
 */
class Lib_Plugin_Log extends Framework_YPlugin
{
    /**
     * 覆盖父类的构造函数
     */
    protected function __construct() {}
    
    /**
     * 是否开启该插件
     *
     * @return boolean
     */
    public function _open()
    {
        return true;
    }
    
    /**
     * 在调用动作之后执行的事件
     * 
     * 备注:此方法用于记录接口的调用
     * 
     * @param array $params  参数项
     * @return void
     */
    public function afterAction($params)
    {
        if (isset($params['req']))
        {
            $request = $params['req'];
            $actionName = $request->controller_name . ':' . $request->action_name;
            if (in_array($actionName, self::$allowsAction))
            {
                $query = $request->query();
                if (isset($query['password']))
                {
                    // 为了安全,清空密码
                    $query['password'] = '';
                }
                $key = isset($query['key']) ? $query['key'] : null;
                $input = json_encode($query);
                $output = isset($params['res']) ? (string) $params['res'] : '';
                
                $query = array();

                Facade_Log::add($key, $actionName, $input, $output);
            }
        }
    }
    
    /**
     * 定义允许记录的操作
     * 
     * @var array 
     */
    protected static $allowsAction = array(
        // 注册
        'register:back',
        'register:callbackregister',
        
        // 用户账号
        'userinfo:update',
        'userinfo:setauth',
        'userinfo:delauth',
        'userinfo:changepwd',
        
        // 第三方
        'associate:index',
        'associate:callbacklogin',
        'associate:bind',
        
        // 订阅
        'subscribe:index',
    );
    
}