if (in_array($filter['tag_source'], [ZBX_SERVICE_FILTER_TAGS_ANY, ZBX_SERVICE_FILTER_TAGS_SERVICE])) {
<?php declare(strict_types = 0);
abstract class CControllerServiceListGeneral extends CController {
protected const WITHOUT_PARENTS_SERVICEID = 0;
protected const FILTER_DEFAULT_NAME = '';
protected const FILTER_DEFAULT_STATUS = SERVICE_STATUS_ANY;
protected const FILTER_DEFAULT_WITHOUT_CHILDREN = false;
protected const FILTER_DEFAULT_WITHOUT_PROBLEM_TAGS = false;
protected const FILTER_DEFAULT_TAG_SOURCE = ZBX_SERVICE_FILTER_TAGS_SERVICE;
protected const FILTER_DEFAULT_EVALTYPE = TAG_EVAL_TYPE_AND_OR;
protected function checkPermissions(): bool {
if ($this->hasInput('serviceid')) {
$db_service = API::Service()->get([
'output' => ['serviceid', 'name', 'status', 'readonly'],
'serviceids' => $this->getInput('serviceid'),
'selectParents' => ['serviceid'],
'selectTags' => ['tag', 'value']
$this->service = $db_service[0];
protected function canEdit(): bool {
$db_roles = API::Role()->get([
'selectRules' => ['services.write.mode', 'services.write.list', 'services.write.tag'],
'roleids' => CWebUser::$data['roleid']
return ($db_roles[0]['rules']['services.write.mode'] == ZBX_ROLE_RULE_SERVICES_ACCESS_ALL
|| $db_roles[0]['rules']['services.write.list']
|| $db_roles[0]['rules']['services.write.tag']['tag'] !== '');
protected function doAction(): void {
if ($this->service !== null) {
$this->service['tags'] = makeTags([$this->service], true, 'serviceid');
$this->service['parents'] = API::Service()->get([
'output' => ['serviceid', 'name'],
'serviceids' => array_column($this->service['parents'], 'serviceid'),