Class yii\debug\models\search\Log
Inheritance | yii\debug\models\search\Log » yii\debug\models\search\Base » yii\base\Model |
---|---|
Available since extension's version | 2.0 |
Source Code | https://github.com/yiisoft/yii2-debug/blob/master/src/models/search/Log.php |
Search model for current request log.
Public Properties
Property | Type | Description | Defined By |
---|---|---|---|
$category | string | Method attribute input search value | yii\debug\models\search\Log |
$level | string | Ip attribute input search value | yii\debug\models\search\Log |
$message | integer | Message attribute input search value | yii\debug\models\search\Log |
Public Methods
Method | Description | Defined By |
---|---|---|
addCondition() | Adds filtering condition for a given attribute | yii\debug\models\search\Base |
attributeLabels() | yii\debug\models\search\Log | |
rules() | yii\debug\models\search\Log | |
search() | Returns data provider with filled models. Filter applied if needed. | yii\debug\models\search\Log |
Property Details
Method Details
Defined in: yii\debug\models\search\Base::addCondition()
Adds filtering condition for a given attribute
public void addCondition ( yii\debug\components\search\Filter $filter, $attribute, $partial = false ) | ||
$filter | yii\debug\components\search\Filter |
Filter instance |
$attribute | string |
Attribute to filter |
$partial | boolean |
If partial match should be used |
public function addCondition(Filter $filter, $attribute, $partial = false)
{
$value = (string)$this->$attribute;
if (mb_strpos($value, '>') !== false) {
$value = (int)str_replace('>', '', $value);
$filter->addMatcher($attribute, new matchers\GreaterThan(['value' => $value]));
} elseif (mb_strpos($value, '<') !== false) {
$value = (int)str_replace('<', '', $value);
$filter->addMatcher($attribute, new matchers\LowerThan(['value' => $value]));
} else {
$filter->addMatcher($attribute, new matchers\SameAs(['value' => $value, 'partial' => $partial]));
}
}
public void attributeLabels ( ) |
public function attributeLabels()
{
return [
'level' => 'Level',
'category' => 'Category',
'message' => 'Message',
'time_since_previous' => 'Since previous',
];
}
public void rules ( ) |
public function rules()
{
return [
[['level', 'message', 'category'], 'safe'],
];
}
Returns data provider with filled models. Filter applied if needed.
public \yii\data\ArrayDataProvider search ( $params, $models ) | ||
$params | array |
An array of parameter values indexed by parameter names |
$models | array |
Data to return provider for |
public function search($params, $models)
{
$dataProvider = new ArrayDataProvider([
'allModels' => $models,
'pagination' => false,
'sort' => [
'attributes' => [
'time',
'time_since_previous' => [
'default' => SORT_DESC,
],
'level',
'category',
'message'
],
'defaultOrder' => [
'time' => SORT_ASC,
],
],
]);
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;
}