disableCsrfValidation(); } protected function checkInput(): bool { $fields = [ 'eventid' => 'required|db events.eventid' ]; $ret = $this->validateInput($fields); if ($ret) { $events = API::Event()->get([ 'output' => ['eventid', 'r_eventid', 'clock'], 'selectAcknowledges' => ['userid', 'action', 'message', 'clock', 'new_severity', 'old_severity', 'suppress_until' ], 'eventids' => (array) $this->getInput('eventid') ]); if (!$events) { error(_('No permissions to referred object or it does not exist!')); $ret = false; } else { $this->event = $events[0]; } } 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(): bool { return ($this->getUserType() >= USER_TYPE_ZABBIX_USER); } protected function doAction(): void { $actions = getEventDetailsActions($this->event); $users = $actions['userids'] ? API::User()->get([ 'output' => ['username', 'name', 'surname'], 'userids' => array_keys($actions['userids']), 'preservekeys' => true ]) : []; $mediatypes = $actions['mediatypeids'] ? API::MediaType()->get([ 'output' => ['name', 'maxattempts'], 'mediatypeids' => array_keys($actions['mediatypeids']), 'preservekeys' => true ]) : []; $this->setResponse(new CControllerResponseData([ 'actions' => $actions['actions'], 'users' => $users, 'mediatypes' => $mediatypes, 'foot_note' => ($actions['count'] > ZBX_WIDGET_ROWS) ? _s('Displaying %1$s of %2$s found', ZBX_WIDGET_ROWS, $actions['count']) : null ])); } }