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/CControllerDashboardShareUp...

118 lines
3.3 KiB

1 year ago
<?php
/*
** 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.
**/
/**
* Controller to update dashboard
*/
class CControllerDashboardShareUpdate extends CController {
public const EMPTY_USER = 'empty_user';
public const EMPTY_GROUP = 'empty_group';
protected function init() {
$this->setPostContentType(self::POST_CONTENT_TYPE_JSON);
}
protected function checkInput() {
$fields = [
'dashboardid' => 'required|db dashboard.dashboardid',
'private' => 'db dashboard.private|in 0,1',
'users' => 'array',
'userGroups' => 'array'
];
$ret = $this->validateInput($fields);
if (!$ret) {
$this->setResponse(
new CControllerResponseData(['main_block' => json_encode([
'error' => [
'messages' => array_column(get_and_clear_messages(), 'message')
]
])])
);
}
return $ret;
}
protected function checkPermissions() {
return $this->checkAccess(CRoleHelper::UI_MONITORING_DASHBOARD)
&& $this->checkAccess(CRoleHelper::ACTIONS_EDIT_DASHBOARDS);
}
protected function doAction() {
$editable_dashboard = (bool) API::Dashboard()->get([
'output' => [],
'dashboardids' => [$this->getInput('dashboardid')],
'editable' => true
]);
if ($editable_dashboard) {
$dashboard = ['dashboardid' => $this->getInput('dashboardid')];
if ($this->hasInput('private')) {
$dashboard['private'] = $this->getInput('private');
}
if ($this->hasInput('users')) {
$users = $this->getInput('users');
/**
* Empty user needed to always POST the 'users' parameter.
* If 'users' parameter is empty array (excluding empty user) then API deletes all users.
*/
unset($users[self::EMPTY_USER]);
$dashboard['users'] = $users;
}
if ($this->hasInput('userGroups')) {
$groups = $this->getInput('userGroups');
/**
* Empty user group always needs POST the 'userGroups' parameter.
* If 'userGroups' is empty array (excluding empty group) the API deletes all user groups.
*/
unset($groups[self::EMPTY_GROUP]);
$dashboard['userGroups'] = $groups;
}
$result = (bool) API::Dashboard()->update($dashboard);
}
else {
error(_('No permissions to referred object or it does not exist!'));
$result = false;
}
if ($result) {
$output['success']['title'] = _('Dashboard updated');
if ($messages = get_and_clear_messages()) {
$output['success']['messages'] = array_column($messages, 'message');
}
}
else {
$output['error'] = [
'title' => _('Failed to update dashboard sharing.'),
'messages' => array_column(get_and_clear_messages(), 'message')
];
}
$this->setResponse(new CControllerResponseData(['main_block' => json_encode($output)]));
}
}