disableSIDValidation(); } protected function checkInput() { $fields = [ 'dashboardid' => 'required|db dashboard.dashboardid' ]; $ret = $this->validateInput($fields); if (!$ret) { $this->setResponse( (new CControllerResponseData(['main_block' => json_encode([ 'error' => [ 'messages' => array_column(get_and_clear_messages(), 'message') ] ])]))->disableView() ); } return $ret; } protected function checkPermissions() { return $this->checkAccess(CRoleHelper::UI_REPORTS_SCHEDULED_REPORTS); } protected function doAction() { $data = [ 'title' => _('Related reports'), 'allowed_edit' => $this->checkAccess(CRoleHelper::ACTIONS_MANAGE_SCHEDULED_REPORTS), 'user' => [ 'debug_mode' => $this->getDebugMode() ], 'reports' => API::Report()->get([ 'output' => ['reportid', 'userid', 'name', 'status', 'period', 'cycle', 'active_till', 'state', 'lastsent', 'info' ], 'filter' => ['dashboardid' => $this->getInput('dashboardid')] ]) ]; if ($data['reports']) { CArrayHelper::sort($data['reports'], ['name']); $users = API::User()->get([ 'output' => ['userid', 'username', 'name', 'surname'], 'userids' => array_column($data['reports'], 'userid'), 'preservekeys' => true ]); foreach ($data['reports'] as &$report) { $report['owner'] = array_key_exists($report['userid'], $users) ? getUserFullname($users[$report['userid']]) : _('Inaccessible user'); } unset($report); } $this->setResponse(new CControllerResponseData($data)); } }