2016-01-11 17:03:46 +01:00
|
|
|
<?php
|
2016-02-08 15:41:00 +01:00
|
|
|
/* Icinga Web 2 | (c) 2016 Icinga Development Team | GPLv2+ */
|
2016-01-11 17:03:46 +01:00
|
|
|
|
|
|
|
namespace Icinga\Module\Monitoring\Hook;
|
|
|
|
|
|
|
|
use Icinga\Web\Navigation\Navigation;
|
|
|
|
use Icinga\Module\Monitoring\Object\MonitoredObject;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Base class for object action hooks
|
|
|
|
*/
|
|
|
|
abstract class ObjectActionsHook
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Return the action navigation for the given object
|
|
|
|
*
|
|
|
|
* @return Navigation
|
|
|
|
*/
|
|
|
|
public function getNavigation(MonitoredObject $object)
|
|
|
|
{
|
2016-01-12 12:27:21 +01:00
|
|
|
$urls = $this->getActionsForObject($object);
|
2016-01-11 17:03:46 +01:00
|
|
|
if (is_array($urls)) {
|
|
|
|
$navigation = new Navigation();
|
|
|
|
foreach ($urls as $label => $url) {
|
|
|
|
$navigation->addItem($label, array('url' => $url));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$navigation = $urls;
|
|
|
|
}
|
|
|
|
|
|
|
|
return $navigation;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create and return a new Navigation object
|
|
|
|
*
|
|
|
|
* @param array $actions Optional array of actions to add to the returned object
|
|
|
|
*
|
|
|
|
* @return Navigation
|
|
|
|
*/
|
|
|
|
protected function createNavigation(array $actions = null)
|
|
|
|
{
|
|
|
|
return empty($actions) ? new Navigation() : Navigation::fromArray($actions);
|
|
|
|
}
|
2016-01-12 12:27:21 +01:00
|
|
|
|
|
|
|
abstract function getActionsForObject(MonitoredObject $object);
|
2016-01-11 17:03:46 +01:00
|
|
|
}
|