You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
zabbix/ui/app/controllers/CControllerUserroleEditGene...

143 lines
4.4 KiB

<?php declare(strict_types = 0);
/*
** Zabbix
** Copyright (C) 2001-2023 Zabbix SIA
**
** This program is free software; you can redistribute it and/or modify
** it under the terms of the GNU General Public License as published by
** the Free Software Foundation; either version 2 of the License, or
** (at your option) any later version.
**
** This program is distributed in the hope that it will be useful,
** but WITHOUT ANY WARRANTY; without even the implied warranty of
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
** GNU General Public License for more details.
**
** You should have received a copy of the GNU General Public License
** along with this program; if not, write to the Free Software
** Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
**/
/**
* Class containing operations with userrole.
*/
abstract class CControllerUserroleEditGeneral extends CController {
/**
* @throws APIException
*/
protected function getRulesInput(int $user_type): array {
return array_merge(
$this->getUiSectionRules($user_type),
$this->getServiceSectionRules(),
$this->getModuleSectionRules(),
$this->getApiSectionRules(),
$this->getActionSectionRules($user_type)
);
}
private function getUiSectionRules(int $user_type): array {
return [
'ui' => array_map(
function (string $rule): array {
return [
'name' => str_replace('ui.', '', $rule),
'status' => $this->getInput(str_replace('.', '_', $rule))
];
},
CRoleHelper::getUiElementsByUserType($user_type)
),
'ui.default_access' => $this->getInput('ui_default_access')
];
}
private function getServiceSectionRules(): array {
$read_access = $this->getInput('service_read_access', CRoleHelper::SERVICES_ACCESS_NONE);
$write_access = $this->getInput('service_write_access', CRoleHelper::SERVICES_ACCESS_NONE);
return [
'services.read.mode' => $read_access == CRoleHelper::SERVICES_ACCESS_ALL
? ZBX_ROLE_RULE_SERVICES_ACCESS_ALL
: ZBX_ROLE_RULE_SERVICES_ACCESS_CUSTOM,
'services.read.list' => $read_access == CRoleHelper::SERVICES_ACCESS_LIST
? array_map(
static function (string $serviceid): array {
return ['serviceid' => $serviceid];
},
$this->getInput('service_read_list', []))
: [],
'services.read.tag' => $read_access == CRoleHelper::SERVICES_ACCESS_LIST
? [
'tag' => trim($this->getInput('service_read_tag_tag', '')),
'value' => trim($this->getInput('service_read_tag_value', ''))
]
: ['tag' => '', 'value' => ''],
'services.write.mode' => $write_access == CRoleHelper::SERVICES_ACCESS_ALL
? ZBX_ROLE_RULE_SERVICES_ACCESS_ALL
: ZBX_ROLE_RULE_SERVICES_ACCESS_CUSTOM,
'services.write.list' => $write_access == CRoleHelper::SERVICES_ACCESS_LIST
? array_map(
static function (string $serviceid): array {
return ['serviceid' => $serviceid];
},
$this->getInput('service_write_list', []))
: [],
'services.write.tag' => $write_access == CRoleHelper::SERVICES_ACCESS_LIST
? [
'tag' => trim($this->getInput('service_write_tag_tag', '')),
'value' => trim($this->getInput('service_write_tag_value', ''))
]
: ['tag' => '', 'value' => '']
];
}
/**
* @throws APIException
*/
private function getModuleSectionRules(): array {
$db_modules = API::Module()->get([
'output' => [],
'preservekeys' => true
]);
$modules = $this->getInput('modules', []);
return [
'modules' => array_map(
static function (string $moduleid) use ($modules): array {
return [
'moduleid' => $moduleid,
'status' => $modules[$moduleid]
];
},
array_keys($db_modules)
),
'modules.default_access' => $this->getInput('modules_default_access')
];
}
private function getApiSectionRules() : array {
return [
'api' => $this->getInput('api_methods', []),
'api.access' => $this->getInput('api_access'),
'api.mode' => $this->getInput('api_mode', ZBX_ROLE_RULE_API_MODE_DENY)
];
}
private function getActionSectionRules(int $user_type): array {
return [
'actions' => array_map(
function (string $rule): array {
return [
'name' => str_replace('actions.', '', $rule),
'status' => $this->getInput(str_replace('.', '_', $rule))
];
},
CRoleHelper::getActionsByUserType($user_type)
),
'actions.default_access' => $this->getInput('actions_default_access')
];
}
}