icingaweb2-module-director/library/Director/Resolver/CommandUsage.php

105 lines
3.1 KiB
PHP

<?php
namespace Icinga\Module\Director\Resolver;
use gipfl\IcingaWeb2\Link;
use gipfl\Translation\TranslationHelper;
use Icinga\Module\Director\Objects\IcingaCommand;
use InvalidArgumentException;
class CommandUsage
{
use TranslationHelper;
/** @var IcingaCommand */
protected $command;
/** @var \Zend_Db_Adapter_Abstract */
protected $db;
/**
* CommandUsageTable constructor.
* @param IcingaCommand $command
*/
public function __construct(IcingaCommand $command)
{
if ($command->isTemplate()) {
throw new InvalidArgumentException(
'CommandUsageTable expects object or external_object, got a template'
);
}
$this->command = $command;
$this->db = $command->getDb();
}
/**
* @return array
*/
public function getLinks()
{
$name = $this->command->getObjectName();
$links = [];
$map = [
'host' => ['check_command', 'event_command'],
'service' => ['check_command', 'event_command'],
'notification' => ['command'],
];
$types = [
'host' => [
'object' => $this->translate('%d Host(s)'),
'template' => $this->translate('%d Host Template(s)'),
],
'service' => [
'object' => $this->translate('%d Service(s)'),
'template' => $this->translate('%d Service Template(s)'),
'apply' => $this->translate('%d Service Apply Rule(s)'),
],
'notification' => [
'object' => $this->translate('%d Notification(s)'),
'template' => $this->translate('%d Notification Template(s)'),
'apply' => $this->translate('%d Notification Apply Rule(s)'),
],
];
$urlSuffix = [
'object' => '',
'template' => '/templates',
'apply' => '/applyrules',
];
foreach ($map as $type => $relations) {
$res = $this->fetchFor($type, $relations, array_keys($types[$type]));
foreach ($types[$type] as $objectType => $caption) {
if ($res->$objectType > 0) {
$suffix = $urlSuffix[$objectType];
$links[] = Link::create(
sprintf($caption, $res->$objectType),
"director/${type}s$suffix",
['command' => $name]
);
}
}
}
return $links;
}
protected function fetchFor($table, $rels, $objectTypes)
{
$id = $this->command->getAutoincId();
$columns = [];
foreach ($objectTypes as $type) {
$columns[$type] = "COALESCE(SUM(CASE WHEN object_type = '$type' THEN 1 ELSE 0 END), 0)";
}
$query = $this->db->select()->from("icinga_$table", $columns);
foreach ($rels as $rel) {
$query->orWhere("${rel}_id = ?", $id);
}
return $this->db->fetchRow($query);
}
}