parent
52159c2627
commit
e6903b3834
modules/monitoring/library/Monitoring
|
@ -0,0 +1,46 @@
|
|||
<?php
|
||||
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
||||
|
||||
namespace Icinga\Module\Monitoring\Hook;
|
||||
|
||||
use Icinga\Module\Monitoring\Object\Host;
|
||||
|
||||
/**
|
||||
* Base class for host action hooks
|
||||
*/
|
||||
abstract class HostActionsHook
|
||||
{
|
||||
/**
|
||||
* Implementors of this method should return an array containing
|
||||
* additional action links for a specific host. You get a full Host
|
||||
* object, which allows you to return specific links only for nodes
|
||||
* with specific properties.
|
||||
*
|
||||
* The result array should be in the form title => url, where title will
|
||||
* be used as link caption. Url should be an Icinga\Web\Url object when
|
||||
* the link should point to an Icinga Web url - otherwise a string would
|
||||
* be fine.
|
||||
*
|
||||
* Mixed example:
|
||||
* <code>
|
||||
* return array(
|
||||
* 'Wiki' => 'http://my.wiki/host=' . rawurlencode($host->host_name),
|
||||
* 'Logstash' => Url::fromPath(
|
||||
* 'logstash/search/syslog',
|
||||
* array('host' => $host->host_name)
|
||||
* )
|
||||
* );
|
||||
* </code>
|
||||
*
|
||||
* One might also provide ssh:// or rdp:// urls if equipped with fitting
|
||||
* (safe) URL handlers for his browser(s).
|
||||
*
|
||||
* TODO: I'd love to see some kind of a Link/LinkSet object implemented
|
||||
* for this and similar hooks.
|
||||
*
|
||||
* @param Host $host Monitoring host object
|
||||
*
|
||||
* @return array An array containing a list of host action links
|
||||
*/
|
||||
abstract public function getActionsForHost(Host $host);
|
||||
}
|
|
@ -0,0 +1,46 @@
|
|||
<?php
|
||||
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
||||
|
||||
namespace Icinga\Module\Monitoring\Hook;
|
||||
|
||||
use Icinga\Module\Monitoring\Object\Service;
|
||||
|
||||
/**
|
||||
* Base class for host action hooks
|
||||
*/
|
||||
abstract class ServiceActionsHook
|
||||
{
|
||||
/**
|
||||
* Implementors of this method should return an array containing
|
||||
* additional action links for a specific host. You get a full Service
|
||||
* object, which allows you to return specific links only for nodes
|
||||
* with specific properties.
|
||||
*
|
||||
* The result array should be in the form title => url, where title will
|
||||
* be used as link caption. Url should be an Icinga\Web\Url object when
|
||||
* the link should point to an Icinga Web url - otherwise a string would
|
||||
* be fine.
|
||||
*
|
||||
* Mixed example:
|
||||
* <code>
|
||||
* return array(
|
||||
* 'Wiki' => 'http://my.wiki/host=' . rawurlencode($service->service_name),
|
||||
* 'Logstash' => Url::fromPath(
|
||||
* 'logstash/search/syslog',
|
||||
* array('service' => $service->host_name)
|
||||
* )
|
||||
* );
|
||||
* </code>
|
||||
*
|
||||
* One might also provide ssh:// or rdp:// urls if equipped with fitting
|
||||
* (safe) URL handlers for his browser(s).
|
||||
*
|
||||
* TODO: I'd love to see some kind of a Link/LinkSet object implemented
|
||||
* for this and similar hooks.
|
||||
*
|
||||
* @param Service $service Monitoring service object
|
||||
*
|
||||
* @return array An array containing a list of service action links
|
||||
*/
|
||||
abstract public function getActionsForService(Service $service);
|
||||
}
|
|
@ -0,0 +1,37 @@
|
|||
<?php
|
||||
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
||||
|
||||
namespace Icinga\Module\Monitoring\Hook;
|
||||
|
||||
use Icinga\Module\Monitoring\Timeline\TimeRange;
|
||||
|
||||
/**
|
||||
* Base class for TimeLine providers
|
||||
*/
|
||||
abstract class TimelineProviderHook
|
||||
{
|
||||
/**
|
||||
* Return the names by which to group entries
|
||||
*
|
||||
* @return array An array with the names as keys and their attribute-lists as values
|
||||
*/
|
||||
abstract public function getIdentifiers();
|
||||
|
||||
/**
|
||||
* Return the visible entries supposed to be shown on the timeline
|
||||
*
|
||||
* @param TimeRange $range The range of time for which to fetch entries
|
||||
*
|
||||
* @return array The entries to display on the timeline
|
||||
*/
|
||||
abstract public function fetchEntries(TimeRange $range);
|
||||
|
||||
/**
|
||||
* Return the entries supposed to be used to calculate forecasts
|
||||
*
|
||||
* @param TimeRange $range The range of time for which to fetch forecasts
|
||||
*
|
||||
* @return array The entries to calculate forecasts with
|
||||
*/
|
||||
abstract public function fetchForecasts(TimeRange $range);
|
||||
}
|
|
@ -3,44 +3,11 @@
|
|||
|
||||
namespace Icinga\Module\Monitoring\Web\Hook;
|
||||
|
||||
use Icinga\Module\Monitoring\Object\Host;
|
||||
use Icinga\Module\Monitoring\Hook\HostActionsHook as BaseHook;
|
||||
|
||||
/**
|
||||
* Base class for host action hooks
|
||||
* Compat only
|
||||
*
|
||||
* Please implement hooks in our Hook direcory
|
||||
*/
|
||||
abstract class HostActionsHook
|
||||
{
|
||||
/**
|
||||
* Implementors of this method should return an array containing
|
||||
* additional action links for a specific host. You get a full Host
|
||||
* object, which allows you to return specific links only for nodes
|
||||
* with specific properties.
|
||||
*
|
||||
* The result array should be in the form title => url, where title will
|
||||
* be used as link caption. Url should be an Icinga\Web\Url object when
|
||||
* the link should point to an Icinga Web url - otherwise a string would
|
||||
* be fine.
|
||||
*
|
||||
* Mixed example:
|
||||
* <code>
|
||||
* return array(
|
||||
* 'Wiki' => 'http://my.wiki/host=' . rawurlencode($host->host_name),
|
||||
* 'Logstash' => Url::fromPath(
|
||||
* 'logstash/search/syslog',
|
||||
* array('host' => $host->host_name)
|
||||
* )
|
||||
* );
|
||||
* </code>
|
||||
*
|
||||
* One might also provide ssh:// or rdp:// urls if equipped with fitting
|
||||
* (safe) URL handlers for his browser(s).
|
||||
*
|
||||
* TODO: I'd love to see some kind of a Link/LinkSet object implemented
|
||||
* for this and similar hooks.
|
||||
*
|
||||
* @param Host $host Monitoring host object
|
||||
*
|
||||
* @return array An array containing a list of host action links
|
||||
*/
|
||||
abstract public function getActionsForHost(Host $host);
|
||||
}
|
||||
abstract class HostActionsHook extends BaseHook {}
|
||||
|
|
|
@ -3,44 +3,11 @@
|
|||
|
||||
namespace Icinga\Module\Monitoring\Web\Hook;
|
||||
|
||||
use Icinga\Module\Monitoring\Object\Service;
|
||||
use Icinga\Module\Monitoring\Hook\HostActionsHook as BaseHook;
|
||||
|
||||
/**
|
||||
* Base class for host action hooks
|
||||
* Compat only
|
||||
*
|
||||
* Please implement hooks in our Hook direcory
|
||||
*/
|
||||
abstract class ServiceActionsHook
|
||||
{
|
||||
/**
|
||||
* Implementors of this method should return an array containing
|
||||
* additional action links for a specific host. You get a full Service
|
||||
* object, which allows you to return specific links only for nodes
|
||||
* with specific properties.
|
||||
*
|
||||
* The result array should be in the form title => url, where title will
|
||||
* be used as link caption. Url should be an Icinga\Web\Url object when
|
||||
* the link should point to an Icinga Web url - otherwise a string would
|
||||
* be fine.
|
||||
*
|
||||
* Mixed example:
|
||||
* <code>
|
||||
* return array(
|
||||
* 'Wiki' => 'http://my.wiki/host=' . rawurlencode($service->service_name),
|
||||
* 'Logstash' => Url::fromPath(
|
||||
* 'logstash/search/syslog',
|
||||
* array('service' => $service->host_name)
|
||||
* )
|
||||
* );
|
||||
* </code>
|
||||
*
|
||||
* One might also provide ssh:// or rdp:// urls if equipped with fitting
|
||||
* (safe) URL handlers for his browser(s).
|
||||
*
|
||||
* TODO: I'd love to see some kind of a Link/LinkSet object implemented
|
||||
* for this and similar hooks.
|
||||
*
|
||||
* @param Service $service Monitoring service object
|
||||
*
|
||||
* @return array An array containing a list of service action links
|
||||
*/
|
||||
abstract public function getActionsForService(Service $service);
|
||||
}
|
||||
abstract class ServiceActionsHook extends BaseHook {}
|
||||
|
|
|
@ -3,35 +3,11 @@
|
|||
|
||||
namespace Icinga\Module\Monitoring\Web\Hook;
|
||||
|
||||
use Icinga\Module\Monitoring\Timeline\TimeRange;
|
||||
use Icinga\Module\Monitoring\Hook\HostActionsHook as BaseHook;
|
||||
|
||||
/**
|
||||
* Base class for TimeLine providers
|
||||
* Compat only
|
||||
*
|
||||
* Please implement hooks in our Hook direcory
|
||||
*/
|
||||
abstract class TimelineProviderHook
|
||||
{
|
||||
/**
|
||||
* Return the names by which to group entries
|
||||
*
|
||||
* @return array An array with the names as keys and their attribute-lists as values
|
||||
*/
|
||||
abstract public function getIdentifiers();
|
||||
|
||||
/**
|
||||
* Return the visible entries supposed to be shown on the timeline
|
||||
*
|
||||
* @param TimeRange $range The range of time for which to fetch entries
|
||||
*
|
||||
* @return array The entries to display on the timeline
|
||||
*/
|
||||
abstract public function fetchEntries(TimeRange $range);
|
||||
|
||||
/**
|
||||
* Return the entries supposed to be used to calculate forecasts
|
||||
*
|
||||
* @param TimeRange $range The range of time for which to fetch forecasts
|
||||
*
|
||||
* @return array The entries to calculate forecasts with
|
||||
*/
|
||||
abstract public function fetchForecasts(TimeRange $range);
|
||||
}
|
||||
abstract class TimelineProviderHook extends BaseHook {}
|
||||
|
|
Loading…
Reference in New Issue