<?php declare(strict_types = 0);
class CControllerUsergroupEdit extends CController {
private $user_group = [];
protected function init() {
$this->disableCsrfValidation();
protected function checkInput() {
'usrgrpid' => 'db usrgrp.usrgrpid',
'name' => 'db usrgrp.name',
'userids' => 'array_db users.userid',
'gui_access' => 'db usrgrp.gui_access|in '.implode(',', [GROUP_GUI_ACCESS_SYSTEM, GROUP_GUI_ACCESS_INTERNAL, GROUP_GUI_ACCESS_LDAP, GROUP_GUI_ACCESS_DISABLED]),
'users_status' => 'db usrgrp.users_status|in '.GROUP_STATUS_ENABLED.','.GROUP_STATUS_DISABLED,
'debug_mode' => 'db usrgrp.debug_mode|in '.GROUP_DEBUG_MODE_ENABLED.','.GROUP_DEBUG_MODE_DISABLED,
'ms_hostgroup_right' => 'array',
'hostgroup_right' => 'array',
'ms_templategroup_right' => 'array',
'templategroup_right' => 'array',
'tag_filters' => 'array',
'form_refresh' => 'int32'
$ret = $this->validateInput($fields);
$this->setResponse(new CControllerResponseFatal());
protected function checkPermissions() {
if (!$this->checkAccess(CRoleHelper::UI_ADMINISTRATION_USER_GROUPS)) {
if ($this->hasInput('usrgrpid')) {
$user_groups = API::UserGroup()->get([
'output' => ['name', 'gui_access', 'users_status', 'debug_mode', 'userdirectoryid', 'mfa_status',
'selectTagFilters' => ['groupid', 'tag', 'value'],
'usrgrpids' => $this->getInput('usrgrpid'),
$this->user_group = $user_groups[0];
protected function doAction() {
$db_defaults = DB::getDefaults('usrgrp');
$mfa_config_status = CAuthenticationHelper::get(CAuthenticationHelper::MFA_STATUS);
'name' => $db_defaults['name'],
'gui_access' => $db_defaults['gui_access'],
'users_status' => $db_defaults['users_status'],
'debug_mode' => $db_defaults['debug_mode'],
'group_mfa_status' => $mfa_config_status ? GROUP_MFA_ENABLED : GROUP_MFA_DISABLED,