Log.php 2.02 KB
Newer Older
Mark committed
1
<?php
2 3 4 5 6
/**
 * @link http://www.yiiframework.com/
 * @copyright Copyright (c) 2008 Yii Software LLC
 * @license http://www.yiiframework.com/license/
 */
Mark committed
7 8 9 10 11 12 13

namespace yii\debug\models\search;

use yii\data\ArrayDataProvider;
use yii\debug\components\search\Filter;

/**
14 15 16 17 18
 * Search model for current request log.
 *
 * @author Qiang Xue <qiang.xue@gmail.com>
 * @author Mark Jebri <mark.github@yandex.ru>
 * @since 2.0
Mark committed
19 20 21
 */
class Log extends Base
{
22 23 24 25 26 27 28 29 30 31 32 33
    /**
     * @var string ip attribute input search value
     */
    public $level;
    /**
     * @var string method attribute input search value
     */
    public $category;
    /**
     * @var integer message attribute input search value
     */
    public $message;
Mark committed
34

35

36 37 38 39 40 41 42 43 44
    /**
     * @inheritdoc
     */
    public function rules()
    {
        return [
            [['level', 'message', 'category'], 'safe'],
        ];
    }
Mark committed
45

46 47 48 49 50 51 52 53 54 55 56
    /**
     * @inheritdoc
     */
    public function attributeLabels()
    {
        return [
            'level' => 'Level',
            'category' => 'Category',
            'message' => 'Message',
        ];
    }
Mark committed
57

58 59 60
    /**
     * Returns data provider with filled models. Filter applied if needed.
     *
61 62
     * @param array $params an array of parameter values indexed by parameter names
     * @param array $models data to return provider for
63 64 65 66 67 68 69 70 71 72 73
     * @return \yii\data\ArrayDataProvider
     */
    public function search($params, $models)
    {
        $dataProvider = new ArrayDataProvider([
            'allModels' => $models,
            'pagination' => false,
            'sort' => [
                'attributes' => ['time', 'level', 'category', 'message'],
            ],
        ]);
Mark committed
74

75 76 77
        if (!($this->load($params) && $this->validate())) {
            return $dataProvider;
        }
Mark committed
78

79 80 81 82 83
        $filter = new Filter();
        $this->addCondition($filter, 'level');
        $this->addCondition($filter, 'category', true);
        $this->addCondition($filter, 'message', true);
        $dataProvider->allModels = $filter->filter($models);
Mark committed
84

85 86
        return $dataProvider;
    }
Mark committed
87
}