disableCsrfValidation(); } protected function checkInput(): bool { $fields = [ 'groupid' => 'db hstgrp.groupid', 'name' => 'string', 'subgroups' => 'in 0,1' ]; $ret = $this->validateInput($fields); if (!$ret) { $this->setResponse(new CControllerResponseFatal()); } return $ret; } protected function checkPermissions(): bool { if (!$this->checkAccess(CRoleHelper::UI_CONFIGURATION_HOST_GROUPS)) { return false; } if ($this->getInput('groupid', 0)) { return (bool) API::HostGroup()->get([ 'output' => [], 'groupids' => $this->getInput('groupid'), 'editable' => true ]); } return true; } protected function doAction(): void { $data = [ 'groupid' => null, 'name' => '', 'subgroups' => 0 ]; if ($this->getInput('groupid', 0)) { $data['groupid'] = $this->getInput('groupid'); $groups = API::HostGroup()->get([ 'output' => ['name', 'flags'], 'selectHosts' => ['hostid'], 'selectDiscoveryRule' => ['itemid', 'name'], 'selectHostPrototype' => ['hostid'], 'groupids' => $data['groupid'] ]); $data = array_merge($data, $groups[0]); $data['is_discovery_rule_editable'] = $data['discoveryRule'] && API::DiscoveryRule()->get([ 'output' => [], 'itemids' => $data['discoveryRule']['itemid'], 'editable' => true ]); $data['allowed_ui_conf_hosts'] = CWebUser::checkAccess(CRoleHelper::UI_CONFIGURATION_HOSTS); } // For clone action. if ($this->hasInput('name')) { $data['name'] = $this->getInput('name'); } $data['user'] = ['debug_mode' => $this->getDebugMode()]; $response = new CControllerResponseData($data); $response->setTitle(_('Configuration of host group')); $this->setResponse($response); } }