mirror of
https://github.com/Icinga/icingaweb2-module-businessprocess.git
synced 2025-12-18 23:16:16 -05:00
Enhance DetailViewExtension
* The checkcommand name can now be configured * The variable names are shortened * The config and process variables are now separate
This commit is contained in:
parent
8e3b6689f1
commit
b2bc6b852e
1 changed files with 21 additions and 11 deletions
|
|
@ -13,19 +13,23 @@ use Icinga\Module\Monitoring\Object\Service;
|
|||
|
||||
class DetailviewExtension extends DetailviewExtensionHook
|
||||
{
|
||||
/**
|
||||
* @var $storage LegacyStorage
|
||||
*/
|
||||
/** @var LegacyStorage */
|
||||
private $storage;
|
||||
|
||||
/** @var string */
|
||||
private $commandName;
|
||||
|
||||
/**
|
||||
* Initialize storage
|
||||
*/
|
||||
public function init()
|
||||
{
|
||||
try {
|
||||
$this->storage = new LegacyStorage(
|
||||
$this->getModule()->getConfig()->getSection('global')
|
||||
$this->storage = LegacyStorage::getInstance();
|
||||
$this->commandName = $this->getModule()->getConfig()->get(
|
||||
'DetailviewExtension',
|
||||
'checkcommand_name',
|
||||
'icingacli-businessprocess'
|
||||
);
|
||||
} catch (\Exception $e) {
|
||||
// Ignore and don't display anything
|
||||
|
|
@ -43,29 +47,35 @@ class DetailviewExtension extends DetailviewExtensionHook
|
|||
{
|
||||
if (! isset($this->storage)
|
||||
|| ! $object instanceof Service
|
||||
|| $object->check_command !== 'icingacli-businessprocess'
|
||||
|| $object->check_command !== $this->commandName
|
||||
) {
|
||||
return '';
|
||||
}
|
||||
|
||||
$bpName = $object->_service_icingacli_businessprocess_process;
|
||||
$bpName = $object->_service_businessprocess_config;
|
||||
if (! $bpName) {
|
||||
return '';
|
||||
}
|
||||
|
||||
$nodeName = $object->_service_businessprocess_process;
|
||||
if (! $nodeName) {
|
||||
return '';
|
||||
}
|
||||
|
||||
$bp = $this->storage->loadProcess($bpName);
|
||||
$node = $bp->getBpNode($nodeName);
|
||||
|
||||
MonitoringState::apply($bp);
|
||||
|
||||
if (filter_var($object->_service_icingacli_businessprocess_grapher_tree, FILTER_VALIDATE_BOOLEAN)) {
|
||||
$renderer = new TreeRenderer($bp);
|
||||
if (filter_var($object->_service_businessprocess_as_tree, FILTER_VALIDATE_BOOLEAN)) {
|
||||
$renderer = new TreeRenderer($bp, $node);
|
||||
$tag = 'ul';
|
||||
} else {
|
||||
$renderer = new TileRenderer($bp);
|
||||
$renderer = new TileRenderer($bp, $node);
|
||||
$tag = 'div';
|
||||
}
|
||||
|
||||
$renderer->setUrl(Url::fromPath('businessprocess/process/show?config=' . $bpName . '&node=' . $bpName));
|
||||
$renderer->setUrl(Url::fromPath('businessprocess/process/show?config=' . $bpName . '&node=' . $nodeName));
|
||||
$renderer->ensureAssembled()->getFirst($tag)->setAttribute('data-base-target', '_next');
|
||||
|
||||
return '<h2>Business Process</h2>' . $renderer;
|
||||
|
|
|
|||
Loading…
Reference in a new issue