Merge pull request #3671 from Icinga/bugfix/getrestriction

Monitoring\Controller#getRestriction(): return filters matching all, not none
This commit is contained in:
Johannes Meyer 2019-04-16 08:06:55 +02:00 committed by GitHub
commit 1cce44453c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -97,7 +97,7 @@ class Controller extends IcingaWebController
* *
* @param string $name Name of the restriction * @param string $name Name of the restriction
* *
* @return Filter|null Filter object or null if the authenticated user is not restricted * @return Filter Filter object
* @throws ConfigurationError If the restriction contains invalid filter columns * @throws ConfigurationError If the restriction contains invalid filter columns
*/ */
protected function getRestriction($name) protected function getRestriction($name)
@ -115,7 +115,7 @@ class Controller extends IcingaWebController
)); ));
foreach ($this->getRestrictions($name) as $filter) { foreach ($this->getRestrictions($name) as $filter) {
if ($filter === '*') { if ($filter === '*') {
return Filter::matchAny(); return Filter::matchAll();
} }
try { try {
$restriction->addFilter(Filter::fromQueryString($filter)); $restriction->addFilter(Filter::fromQueryString($filter));
@ -138,6 +138,11 @@ class Controller extends IcingaWebController
); );
} }
} }
if ($restriction->isEmpty()) {
return Filter::matchAll();
}
return $restriction; return $restriction;
} }
} }