From b8de4580da41201a341b4d112fa30c83469d8ef8 Mon Sep 17 00:00:00 2001 From: Johannes Meyer Date: Tue, 19 Jul 2022 16:20:56 +0200 Subject: [PATCH] Add detail integration for Icinga DB Web --- .../Icingadb/ServiceDetailExtension.php | 77 +++++++++++++++++++ run.php | 1 + 2 files changed, 78 insertions(+) create mode 100644 library/Businessprocess/ProvidedHook/Icingadb/ServiceDetailExtension.php diff --git a/library/Businessprocess/ProvidedHook/Icingadb/ServiceDetailExtension.php b/library/Businessprocess/ProvidedHook/Icingadb/ServiceDetailExtension.php new file mode 100644 index 0000000..ca6bc19 --- /dev/null +++ b/library/Businessprocess/ProvidedHook/Icingadb/ServiceDetailExtension.php @@ -0,0 +1,77 @@ +setSection(self::GRAPH_SECTION); + + try { + $this->storage = LegacyStorage::getInstance(); + $this->commandName = $this->getModule()->getConfig()->get( + 'DetailviewExtension', + 'checkcommand_name', + 'icingacli-businessprocess' + ); + } catch (\Exception $e) { + // Ignore and don't display anything + } + } + + public function getHtmlForObject(Service $service): ValidHtml + { + if (! isset($this->storage) + || $service->checkcommand_name !== $this->commandName + ) { + return HtmlString::create(''); + } + + $bpName = $service->customvars['businessprocess_config'] ?? null; + if (! $bpName) { + return HtmlString::create(''); + } + + $nodeName = $service->customvars['businessprocess_process'] ?? null; + if (! $nodeName) { + return HtmlString::create(''); + } + + $bp = $this->storage->loadProcess($bpName); + $node = $bp->getBpNode($nodeName); + + IcingaDbState::apply($bp); + + if ($service->customvars['businessprocess_as_tree'] ?? false) { + $renderer = new TreeRenderer($bp, $node); + $tag = 'ul'; + } else { + $renderer = new TileRenderer($bp, $node); + $tag = 'div'; + } + + $renderer->setUrl(Url::fromPath('businessprocess/process/show?config=' . $bpName . '&node=' . $nodeName)); + $renderer->ensureAssembled()->getFirst($tag)->setAttribute('data-base-target', '_next'); + + return (new HtmlDocument())->addHtml(Html::tag('h2', 'Business Process'), $renderer); + } +} diff --git a/run.php b/run.php index dbe38fb..6cb81f8 100644 --- a/run.php +++ b/run.php @@ -6,4 +6,5 @@ $this->provideHook('monitoring/DetailviewExtension'); $this->provideHook('icingadb/HostActions'); $this->provideHook('icingadb/ServiceActions'); $this->provideHook('icingadb/icingadbSupport'); +$this->provideHook('icingadb/ServiceDetailExtension'); //$this->provideHook('director/shipConfigFiles');