disableCsrfValidation(); } protected function checkInput() { $fields = [ 'group_rights' => 'required|array', 'new_group_right' => 'required|array' ]; $ret = $this->validateInput($fields); if ($ret) { $new_group_right = $this->getInput('new_group_right') + ['groupids' => []]; if (!$new_group_right['groupids']) { error(_s('Incorrect value for field "%1$s": %2$s.', _('Host groups'), _('cannot be empty'))); $ret = false; } } if (!$ret) { $this->setResponse((new CControllerResponseData([ 'main_block' => json_encode(['messages' => getMessages()->toString()]) ]))->disableView()); } return $ret; } protected function checkPermissions() { return $this->checkAccess(CRoleHelper::UI_ADMINISTRATION_USER_GROUPS); } protected function doAction() { $new_group_right = $this->getInput('new_group_right') + [ 'groupids' => [], 'permission' => PERM_NONE, 'include_subgroups' => '0' ]; [$groupids, $subgroupids] = $new_group_right['include_subgroups'] ? [[], $new_group_right['groupids']] : [$new_group_right['groupids'], []]; $this->setResponse(new CControllerResponseData([ 'group_rights' => collapseGroupRights(applyHostGroupRights( $this->getInput('group_rights'), $groupids, $subgroupids, $new_group_right['permission'] )), 'user' => [ 'debug_mode' => $this->getDebugMode() ] ])); } }