disableCsrfValidation(); } protected function checkInput() { $fields = [ 'templategroup_rights' => 'required|array', 'new_templategroup_right' => 'required|array' ]; $ret = $this->validateInput($fields); if ($ret) { $new_templategroup_right = $this->getInput('new_templategroup_right') + ['groupids' => []]; if (!$new_templategroup_right['groupids']) { error(_s('Incorrect value for field "%1$s": %2$s.', _('Template 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_templategroup_right = $this->getInput('new_templategroup_right') + [ 'groupids' => [], 'permission' => PERM_NONE, 'include_subgroups' => '0' ]; [$templategroup_groupids, $templategroup_subgroupids] = $new_templategroup_right['include_subgroups'] ? [[], $new_templategroup_right['groupids']] : [$new_templategroup_right['groupids'], []]; $this->setResponse(new CControllerResponseData([ 'templategroup_rights' => collapseGroupRights(applyTemplateGroupRights( $this->getInput('templategroup_rights'), $templategroup_groupids, $templategroup_subgroupids, $new_templategroup_right['permission'] )), 'user' => [ 'debug_mode' => $this->getDebugMode() ] ])); } }