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.
313 lines
11 KiB
313 lines
11 KiB
1 year ago
|
<?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 CControllerScheduledReportEdit extends CController {
|
||
|
|
||
|
protected $report = [];
|
||
|
|
||
|
protected function init() {
|
||
|
$this->disableCsrfValidation();
|
||
|
}
|
||
|
|
||
|
protected function checkInput() {
|
||
|
$fields = [
|
||
|
'reportid' => 'db report.reportid',
|
||
|
'userid' => 'db report.userid',
|
||
|
'name' => 'db report.name',
|
||
|
'dashboardid' => 'db report.dashboardid',
|
||
|
'old_dashboardid' => 'db report.dashboardid',
|
||
|
'period' => 'db report.period|in '.implode(',', [ZBX_REPORT_PERIOD_DAY, ZBX_REPORT_PERIOD_WEEK, ZBX_REPORT_PERIOD_MONTH, ZBX_REPORT_PERIOD_YEAR]),
|
||
|
'cycle' => 'db report.cycle|in '.implode(',', [ZBX_REPORT_CYCLE_DAILY, ZBX_REPORT_CYCLE_WEEKLY, ZBX_REPORT_CYCLE_MONTHLY, ZBX_REPORT_CYCLE_YEARLY]),
|
||
|
'weekdays' => 'array',
|
||
|
'hours' => 'int32',
|
||
|
'minutes' => 'int32',
|
||
|
'active_since' => 'string',
|
||
|
'active_till' => 'string',
|
||
|
'subject' => 'string',
|
||
|
'message' => 'string',
|
||
|
'subscriptions' => 'array',
|
||
|
'description' => 'db report.description',
|
||
|
'status' => 'db report.status|in '.ZBX_REPORT_STATUS_DISABLED.','.ZBX_REPORT_STATUS_ENABLED,
|
||
|
'form_refresh' => 'int32'
|
||
|
];
|
||
|
|
||
|
$ret = $this->validateInput($fields);
|
||
|
|
||
|
if (!$ret) {
|
||
|
$this->setResponse(new CControllerResponseFatal());
|
||
|
}
|
||
|
|
||
|
return $ret;
|
||
|
}
|
||
|
|
||
|
protected function checkPermissions() {
|
||
|
if (!$this->checkAccess(CRoleHelper::UI_REPORTS_SCHEDULED_REPORTS)
|
||
|
|| (!$this->hasInput('reportid')
|
||
|
&& !$this->checkAccess(CRoleHelper::ACTIONS_MANAGE_SCHEDULED_REPORTS))) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
if ($this->hasInput('reportid') && !$this->hasInput('form_refresh')) {
|
||
|
if (!$this->getInput('reportid', 0)) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
$reports = API::Report()->get([
|
||
|
'output' => ['reportid', 'userid', 'name', 'description', 'status', 'dashboardid', 'period', 'cycle',
|
||
|
'weekdays', 'start_time', 'active_since', 'active_till', 'subject', 'message'
|
||
|
],
|
||
|
'selectUsers' => ['userid', 'access_userid', 'exclude'],
|
||
|
'selectUserGroups' => ['usrgrpid', 'access_userid'],
|
||
|
'reportids' => $this->getInput('reportid')
|
||
|
]);
|
||
|
|
||
|
if (!$reports) {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
$this->report = $reports[0];
|
||
|
}
|
||
|
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
protected function doAction() {
|
||
|
$db_defaults = DB::getDefaults('report');
|
||
|
$current_user_name = getUserFullname(CWebUser::$data);
|
||
|
$data = [
|
||
|
'reportid' => 0,
|
||
|
'userid' => CWebUser::$data['userid'],
|
||
|
'name' => $db_defaults['name'],
|
||
|
'dashboardid' => 0,
|
||
|
'old_dashboardid' => 0,
|
||
|
'period' => $db_defaults['period'],
|
||
|
'cycle' => $db_defaults['cycle'],
|
||
|
'hours' => '00',
|
||
|
'minutes' => '00',
|
||
|
'weekdays' => 127,
|
||
|
'active_since' => '',
|
||
|
'active_till' => '',
|
||
|
'subject' => '',
|
||
|
'message' => '',
|
||
|
'subscriptions' => [[
|
||
|
'recipientid' => CWebUser::$data['userid'],
|
||
|
'recipient_type' => ZBX_REPORT_RECIPIENT_TYPE_USER,
|
||
|
'recipient_name' => $current_user_name,
|
||
|
'recipient_inaccessible' => 0,
|
||
|
'creatorid' => CWebUser::$data['userid'],
|
||
|
'creator_type' => ZBX_REPORT_CREATOR_TYPE_USER,
|
||
|
'creator_name' => $current_user_name,
|
||
|
'creator_inaccessible' => 0,
|
||
|
'exclude' => ZBX_REPORT_EXCLUDE_USER_FALSE
|
||
|
]],
|
||
|
'ms_user' => [['id' => CWebUser::$data['userid'], 'name' => $current_user_name]],
|
||
|
'ms_dashboard' => [],
|
||
|
'description' => $db_defaults['description'],
|
||
|
'status' => $db_defaults['status'],
|
||
|
'form_refresh' => 0,
|
||
|
'allowed_edit' => $this->checkAccess(CRoleHelper::ACTIONS_MANAGE_SCHEDULED_REPORTS)
|
||
|
];
|
||
|
|
||
|
if ($this->hasInput('reportid') && !$this->hasInput('form_refresh')) {
|
||
|
$data['reportid'] = $this->report['reportid'];
|
||
|
$data['userid'] = $this->report['userid'];
|
||
|
$data['name'] = $this->report['name'];
|
||
|
$data['dashboardid'] = $this->report['dashboardid'];
|
||
|
$data['old_dashboardid'] = $this->report['dashboardid'];
|
||
|
$data['period'] = $this->report['period'];
|
||
|
$data['cycle'] = $this->report['cycle'];
|
||
|
$data['hours'] = sprintf("%02d", floor($this->report['start_time'] / SEC_PER_HOUR));
|
||
|
$data['minutes'] = sprintf("%02d", floor(($this->report['start_time'] % SEC_PER_HOUR) / SEC_PER_MIN));
|
||
|
$data['weekdays'] = ($this->report['cycle'] == ZBX_REPORT_CYCLE_WEEKLY) ? $this->report['weekdays'] : 127;
|
||
|
$data['active_since'] = $this->report['active_since'];
|
||
|
$data['active_till'] = $this->report['active_till'];
|
||
|
$data['subject'] = $this->report['subject'];
|
||
|
$data['message'] = $this->report['message'];
|
||
|
$data['description'] = $this->report['description'];
|
||
|
$data['status'] = $this->report['status'];
|
||
|
$data['subscriptions'] = [];
|
||
|
|
||
|
$userids = [$data['userid'] => true];
|
||
|
$usrgrpids = [];
|
||
|
|
||
|
foreach ($this->report['users'] as $user) {
|
||
|
$userids[$user['userid']] = true;
|
||
|
$userids[$user['access_userid']] = true;
|
||
|
}
|
||
|
|
||
|
foreach ($this->report['user_groups'] as $usrgrp) {
|
||
|
$usrgrpids[$usrgrp['usrgrpid']] = true;
|
||
|
$userids[$usrgrp['access_userid']] = true;
|
||
|
}
|
||
|
|
||
|
unset($userids[CWebUser::$data['userid']]);
|
||
|
|
||
|
$db_users = $userids
|
||
|
? API::User()->get([
|
||
|
'output' => ['username', 'name', 'surname'],
|
||
|
'userids' => array_keys($userids),
|
||
|
'preservekeys' => true
|
||
|
])
|
||
|
: [];
|
||
|
|
||
|
foreach ($this->report['users'] as $user) {
|
||
|
$subscription = [
|
||
|
'recipientid' => $user['userid'],
|
||
|
'recipient_type' => ZBX_REPORT_RECIPIENT_TYPE_USER,
|
||
|
'recipient_name' => _('Inaccessible user'),
|
||
|
'recipient_inaccessible' => 1,
|
||
|
'creatorid' => $user['access_userid'],
|
||
|
'creator_type' => ZBX_REPORT_CREATOR_TYPE_USER,
|
||
|
'creator_name' => _('Inaccessible user'),
|
||
|
'creator_inaccessible' => 1,
|
||
|
'exclude' => $user['exclude']
|
||
|
];
|
||
|
|
||
|
if ($user['userid'] == CWebUser::$data['userid']) {
|
||
|
$subscription['recipient_name'] = $current_user_name;
|
||
|
$subscription['recipient_inaccessible'] = 0;
|
||
|
}
|
||
|
elseif (array_key_exists($user['userid'], $db_users)) {
|
||
|
$subscription['recipient_name'] = getUserFullname($db_users[$user['userid']]);
|
||
|
$subscription['recipient_inaccessible'] = 0;
|
||
|
}
|
||
|
|
||
|
if ($user['access_userid'] == 0) {
|
||
|
$subscription['creator_type'] = ZBX_REPORT_CREATOR_TYPE_RECIPIENT;
|
||
|
$subscription['creator_name'] = _('Recipient');
|
||
|
$subscription['creator_inaccessible'] = $subscription['recipient_inaccessible'];
|
||
|
}
|
||
|
elseif ($user['access_userid'] == CWebUser::$data['userid']) {
|
||
|
$subscription['creator_name'] = $current_user_name;
|
||
|
$subscription['creator_inaccessible'] = 0;
|
||
|
}
|
||
|
elseif (array_key_exists($user['access_userid'], $db_users)) {
|
||
|
$subscription['creator_name'] = getUserFullname($db_users[$user['access_userid']]);
|
||
|
$subscription['creator_inaccessible'] = 0;
|
||
|
}
|
||
|
|
||
|
$data['subscriptions'][] = $subscription;
|
||
|
}
|
||
|
|
||
|
if ($data['userid'] != CWebUser::$data['userid']) {
|
||
|
$data['ms_user'] = [[
|
||
|
'id' => $data['userid'],
|
||
|
'name' => array_key_exists($data['userid'], $db_users)
|
||
|
? getUserFullname($db_users[$data['userid']])
|
||
|
: _('Inaccessible user')
|
||
|
]];
|
||
|
}
|
||
|
|
||
|
$db_usrgrps = $usrgrpids
|
||
|
? API::UserGroup()->get([
|
||
|
'output' => ['name'],
|
||
|
'usrgrpids' => array_keys($usrgrpids),
|
||
|
'preservekeys' => true
|
||
|
])
|
||
|
: [];
|
||
|
|
||
|
foreach ($this->report['user_groups'] as $usrgrp) {
|
||
|
$subscription = [
|
||
|
'recipientid' => $usrgrp['usrgrpid'],
|
||
|
'recipient_type' => ZBX_REPORT_RECIPIENT_TYPE_USER_GROUP,
|
||
|
'recipient_name' => _('Inaccessible user group'),
|
||
|
'recipient_inaccessible' => 1,
|
||
|
'creatorid' => $usrgrp['access_userid'],
|
||
|
'creator_type' => ZBX_REPORT_CREATOR_TYPE_USER,
|
||
|
'creator_name' => _('Inaccessible user'),
|
||
|
'creator_inaccessible' => 1
|
||
|
];
|
||
|
|
||
|
if (array_key_exists($usrgrp['usrgrpid'], $db_usrgrps)) {
|
||
|
$subscription['recipient_name'] = $db_usrgrps[$usrgrp['usrgrpid']]['name'];
|
||
|
$subscription['recipient_inaccessible'] = 0;
|
||
|
}
|
||
|
|
||
|
if ($usrgrp['access_userid'] == 0) {
|
||
|
$subscription['creator_type'] = ZBX_REPORT_CREATOR_TYPE_RECIPIENT;
|
||
|
$subscription['creator_name'] = _('Recipient');
|
||
|
$subscription['creator_inaccessible'] = $subscription['recipient_inaccessible'];
|
||
|
}
|
||
|
elseif ($usrgrp['access_userid'] == CWebUser::$data['userid']) {
|
||
|
$subscription['creator_name'] = $current_user_name;
|
||
|
$subscription['creator_inaccessible'] = 0;
|
||
|
}
|
||
|
elseif (array_key_exists($usrgrp['access_userid'], $db_users)) {
|
||
|
$subscription['creator_name'] = getUserFullname($db_users[$usrgrp['access_userid']]);
|
||
|
$subscription['creator_inaccessible'] = 0;
|
||
|
}
|
||
|
|
||
|
$data['subscriptions'][] = $subscription;
|
||
|
}
|
||
|
|
||
|
CArrayHelper::sort($data['subscriptions'], ['recipient_name']);
|
||
|
}
|
||
|
|
||
|
$this->getInputs($data, ['reportid', 'name', 'dashboardid', 'old_dashboardid', 'period', 'cycle', 'hours',
|
||
|
'minutes', 'active_since', 'active_till', 'subject', 'message', 'description', 'status', 'form_refresh'
|
||
|
]);
|
||
|
|
||
|
if ($data['form_refresh'] != 0) {
|
||
|
$data['userid'] = $this->getInput('userid', 0);
|
||
|
$data['weekdays'] = array_sum($this->getInput('weekdays', []));
|
||
|
$data['subscriptions'] = $this->getInput('subscriptions', []);
|
||
|
$data['ms_user'] = [];
|
||
|
|
||
|
if ($data['userid'] != 0) {
|
||
|
if (CWebUser::$data['userid'] != $data['userid']) {
|
||
|
$users = API::User()->get([
|
||
|
'output' => ['username', 'name', 'surname'],
|
||
|
'userids' => $data['userid']
|
||
|
]);
|
||
|
|
||
|
$user_name = $users ? getUserFullname($users[0]) : _('Inaccessible user');
|
||
|
}
|
||
|
else {
|
||
|
$user_name = $current_user_name;
|
||
|
}
|
||
|
|
||
|
$data['ms_user'] = [['id' => $data['userid'], 'name' => $user_name]];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$data['dashboard_inaccessible'] = false;
|
||
|
|
||
|
if ($data['dashboardid'] != 0) {
|
||
|
$dashboards = API::Dashboard()->get([
|
||
|
'output' => ['name'],
|
||
|
'dashboardids' => $data['dashboardid']
|
||
|
]);
|
||
|
|
||
|
if ($dashboards) {
|
||
|
$data['ms_dashboard'] = [['id' => $data['dashboardid'], 'name' => $dashboards[0]['name']]];
|
||
|
}
|
||
|
else {
|
||
|
$data['ms_dashboard'] = [['id' => $data['dashboardid'], 'name' => _('Inaccessible dashboard')]];
|
||
|
$data['dashboard_inaccessible'] = true;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
$response = new CControllerResponseData($data);
|
||
|
$response->setTitle(_('Scheduled reports'));
|
||
|
$this->setResponse($response);
|
||
|
}
|
||
|
}
|