Log.php 1.75 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 22 23 24 25 26 27 28 29 30 31 32
 */
class Log extends Base
{
	/**
	 * @var string ip attribute input search value
	 */
	public $level;

	/**
	 * @var string method attribute input search value
	 */
	public $category;

	/**
33
	 * @var integer message attribute input search value
Mark committed
34 35 36
	 */
	public $message;

37 38 39
	/**
	 * @inheritdoc
	 */
Mark committed
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60
	public function rules()
	{
		return [
			[['level', 'message', 'category'], 'safe'],
		];
	}

	/**
	 * @inheritdoc
	 */
	public function attributeLabels()
	{
		return [
			'level' => 'Level',
			'category' => 'Category',
			'message' => 'Message',
		];
	}

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

		if (!($this->load($params) && $this->validate())) {
			return $dataProvider;
		}

		$filter = new Filter();
		$this->addCondition($filter, 'level');
		$this->addCondition($filter, 'category', true);
		$this->addCondition($filter, 'message', true);
		$dataProvider->allModels = $filter->filter($models);

		return $dataProvider;
	}
}