summaryrefslogtreecommitdiffstats
path: root/application/controllers/ReportController.php
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-14 13:28:59 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-14 13:28:59 +0000
commit978a1651bac3faf5e91ddba327bf39aeb6a4cb63 (patch)
treef0d1fee61877df200ccfb1c0af58a39cd551fb46 /application/controllers/ReportController.php
parentInitial commit. (diff)
downloadicingaweb2-module-reporting-978a1651bac3faf5e91ddba327bf39aeb6a4cb63.tar.xz
icingaweb2-module-reporting-978a1651bac3faf5e91ddba327bf39aeb6a4cb63.zip
Adding upstream version 0.10.0.upstream/0.10.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'application/controllers/ReportController.php')
-rw-r--r--application/controllers/ReportController.php208
1 files changed, 208 insertions, 0 deletions
diff --git a/application/controllers/ReportController.php b/application/controllers/ReportController.php
new file mode 100644
index 0000000..090c759
--- /dev/null
+++ b/application/controllers/ReportController.php
@@ -0,0 +1,208 @@
+<?php
+// Icinga Reporting | (c) 2018 Icinga GmbH | GPLv2
+
+namespace Icinga\Module\Reporting\Controllers;
+
+use GuzzleHttp\Psr7\ServerRequest;
+use Icinga\Application\Hook;
+use Icinga\Module\Pdfexport\ProvidedHook\Pdfexport;
+use Icinga\Module\Reporting\Database;
+use Icinga\Module\Reporting\Report;
+use Icinga\Module\Reporting\Web\Controller;
+use Icinga\Module\Reporting\Web\Forms\ReportForm;
+use Icinga\Module\Reporting\Web\Forms\ScheduleForm;
+use Icinga\Module\Reporting\Web\Forms\SendForm;
+use Icinga\Module\Reporting\Web\Widget\CompatDropdown;
+use ipl\Html\Error;
+use ipl\Web\Url;
+use ipl\Web\Widget\ActionBar;
+use Icinga\Util\Environment;
+
+class ReportController extends Controller
+{
+ use Database;
+
+ /** @var Report */
+ protected $report;
+
+ public function init()
+ {
+ $this->report = Report::fromDb($this->params->getRequired('id'));
+ }
+
+ public function indexAction()
+ {
+ $this->addTitleTab($this->report->getName());
+
+ $this->addControl($this->assembleActions());
+
+ Environment::raiseExecutionTime();
+ Environment::raiseMemoryLimit();
+
+ try {
+ $this->addContent($this->report->toHtml());
+ } catch (\Exception $e) {
+ $this->addContent(Error::show($e));
+ }
+ }
+
+ public function editAction()
+ {
+ $this->assertPermission('reporting/reports');
+ $this->addTitleTab('Edit Report');
+
+ $values = [
+ 'name' => $this->report->getName(),
+ // TODO(el): Must cast to string here because ipl/html does not
+ // support integer return values for attribute callbacks
+ 'timeframe' => (string) $this->report->getTimeframe()->getId(),
+ ];
+
+ $reportlet = $this->report->getReportlets()[0];
+
+ $values['reportlet'] = $reportlet->getClass();
+
+ foreach ($reportlet->getConfig() as $name => $value) {
+ $values[$name] = $value;
+ }
+
+ $form = new ReportForm();
+ $form->setId($this->report->getId());
+ $form->populate($values);
+ $form->handleRequest(ServerRequest::fromGlobals());
+
+ $this->redirectForm($form, 'reporting/reports');
+
+ $this->addContent($form);
+ }
+
+ public function sendAction()
+ {
+ $this->addTitleTab('Send Report');
+
+ Environment::raiseExecutionTime();
+ Environment::raiseMemoryLimit();
+
+ $form = new SendForm();
+ $form
+ ->setReport($this->report)
+ ->handleRequest(ServerRequest::fromGlobals());
+
+ $this->redirectForm($form, "reporting/report?id={$this->report->getId()}");
+
+ $this->addContent($form);
+ }
+
+ public function scheduleAction()
+ {
+ $this->assertPermission('reporting/schedules');
+ $this->addTitleTab('Schedule');
+
+ $form = new ScheduleForm();
+ $form
+ ->setReport($this->report)
+ ->handleRequest(ServerRequest::fromGlobals());
+
+ $this->redirectForm($form, "reporting/report?id={$this->report->getId()}");
+
+ $this->addContent($form);
+ }
+
+ public function downloadAction()
+ {
+ $type = $this->params->getRequired('type');
+
+ Environment::raiseExecutionTime();
+ Environment::raiseMemoryLimit();
+
+ $name = sprintf(
+ '%s (%s) %s',
+ $this->report->getName(),
+ $this->report->getTimeframe()->getName(),
+ date('Y-m-d H:i')
+ );
+
+ switch ($type) {
+ case 'pdf':
+ /** @var Hook\PdfexportHook */
+ Pdfexport::first()->streamPdfFromHtml($this->report->toPdf(), $name);
+ exit;
+ case 'csv':
+ $response = $this->getResponse();
+ $response
+ ->setHeader('Content-Type', 'text/csv')
+ ->setHeader('Cache-Control', 'no-store')
+ ->setHeader(
+ 'Content-Disposition',
+ 'attachment; filename=' . $name . '.csv'
+ )
+ ->appendBody($this->report->toCsv())
+ ->sendResponse();
+ exit;
+ case 'json':
+ $response = $this->getResponse();
+ $response
+ ->setHeader('Content-Type', 'application/json')
+ ->setHeader('Cache-Control', 'no-store')
+ ->setHeader(
+ 'Content-Disposition',
+ 'inline; filename=' . $name . '.json'
+ )
+ ->appendBody($this->report->toJson())
+ ->sendResponse();
+ exit;
+ }
+ }
+
+ protected function assembleActions()
+ {
+ $reportId = $this->report->getId();
+
+ $download = (new CompatDropdown('Download'))
+ ->addLink(
+ 'PDF',
+ Url::fromPath('reporting/report/download?type=pdf', ['id' => $reportId]),
+ null,
+ ['target' => '_blank']
+ );
+
+ if ($this->report->providesData()) {
+ $download->addLink(
+ 'CSV',
+ Url::fromPath('reporting/report/download?type=csv', ['id' => $reportId]),
+ null,
+ ['target' => '_blank']
+ );
+ $download->addLink(
+ 'JSON',
+ Url::fromPath('reporting/report/download?type=json', ['id' => $reportId]),
+ null,
+ ['target' => '_blank']
+ );
+ }
+
+ $actions = new ActionBar();
+
+ if ($this->hasPermission('reporting/reports')) {
+ $actions->addLink(
+ 'Modify',
+ Url::fromPath('reporting/report/edit', ['id' => $reportId]),
+ 'edit'
+ );
+ }
+
+ if ($this->hasPermission('reporting/schedules')) {
+ $actions->addLink(
+ 'Schedule',
+ Url::fromPath('reporting/report/schedule', ['id' => $reportId]),
+ 'calendar-empty'
+ );
+ }
+
+ $actions
+ ->add($download)
+ ->addLink('Send', Url::fromPath('reporting/report/send', ['id' => $reportId]), 'forward');
+
+ return $actions;
+ }
+}