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.
118 lines
3.3 KiB
118 lines
3.3 KiB
<?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)]));
|
|
}
|
|
}
|