2013-07-12 14:33:17 +02:00
|
|
|
<?php
|
2015-02-04 10:46:36 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
2013-07-12 14:33:17 +02:00
|
|
|
|
2013-08-20 15:32:25 +02:00
|
|
|
namespace Icinga\Module\Monitoring\Object;
|
2013-07-12 14:33:17 +02:00
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
use InvalidArgumentException;
|
2014-08-19 18:46:37 +02:00
|
|
|
use Icinga\Application\Config;
|
2015-01-27 14:54:21 +01:00
|
|
|
use Icinga\Data\Filter\Filter;
|
|
|
|
use Icinga\Data\Filterable;
|
2015-09-03 13:47:51 +02:00
|
|
|
use Icinga\Exception\InvalidPropertyException;
|
2015-09-17 10:40:00 +02:00
|
|
|
use Icinga\Exception\ProgrammingError;
|
2014-11-11 16:29:07 +01:00
|
|
|
use Icinga\Module\Monitoring\Backend\MonitoringBackend;
|
2014-09-24 07:17:22 +02:00
|
|
|
use Icinga\Web\UrlParams;
|
2014-06-17 15:10:54 +02:00
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
|
|
|
* A monitored Icinga object, i.e. host or service
|
|
|
|
*/
|
2015-01-27 14:54:21 +01:00
|
|
|
abstract class MonitoredObject implements Filterable
|
2013-07-12 14:33:17 +02:00
|
|
|
{
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
|
|
|
* Type host
|
|
|
|
*/
|
|
|
|
const TYPE_HOST = 'host';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Type service
|
|
|
|
*/
|
|
|
|
const TYPE_SERVICE = 'service';
|
|
|
|
|
2015-09-03 16:38:46 +02:00
|
|
|
/**
|
|
|
|
* Acknowledgement of the host or service if any
|
|
|
|
*
|
|
|
|
* @var object
|
|
|
|
*/
|
|
|
|
protected $acknowledgement;
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
|
|
|
* Backend to fetch object information from
|
|
|
|
*
|
2014-11-11 16:29:07 +01:00
|
|
|
* @var MonitoringBackend
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
|
|
|
protected $backend;
|
|
|
|
|
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Comments
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var array
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $comments;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
|
|
|
/**
|
2015-10-05 11:57:31 +02:00
|
|
|
* This object's obfuscated custom variables
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var array
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $customvars;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
2015-10-05 11:57:31 +02:00
|
|
|
/**
|
|
|
|
* The host custom variables
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $hostVariables;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The service custom variables
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $serviceVariables;
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Contact groups
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var array
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $contactgroups;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Contacts
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $contacts;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Downtimes
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $downtimes;
|
|
|
|
|
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Event history
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var \Icinga\Module\Monitoring\DataView\EventHistory
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $eventhistory;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Filter
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var Filter
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $filter;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Host groups
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $hostgroups;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Prefix of the Icinga object, i.e. 'host_' or 'service_'
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var string
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $prefix;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Properties
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var object
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $properties;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Service groups
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var array
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $servicegroups;
|
2014-09-12 10:16:31 +02:00
|
|
|
|
2014-09-24 07:17:22 +02:00
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Type of the Icinga object, i.e. 'host' or 'service'
|
2014-09-24 07:17:22 +02:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var string
|
2014-09-24 07:17:22 +02:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $type;
|
2014-09-24 07:17:22 +02:00
|
|
|
|
2015-01-27 14:54:21 +01:00
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Stats
|
2015-01-27 14:54:21 +01:00
|
|
|
*
|
2015-09-03 14:07:38 +02:00
|
|
|
* @var object
|
2015-01-27 14:54:21 +01:00
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
protected $stats;
|
2015-01-27 14:54:21 +01:00
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
|
|
|
* Create a monitored object, i.e. host or service
|
|
|
|
*
|
2014-11-11 16:29:07 +01:00
|
|
|
* @param MonitoringBackend $backend Backend to fetch object information from
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2014-11-11 16:29:07 +01:00
|
|
|
public function __construct(MonitoringBackend $backend)
|
2014-09-12 10:16:31 +02:00
|
|
|
{
|
|
|
|
$this->backend = $backend;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the object's data view
|
|
|
|
*
|
|
|
|
* @return \Icinga\Module\Monitoring\DataView\DataView
|
|
|
|
*/
|
|
|
|
abstract protected function getDataView();
|
|
|
|
|
2015-09-03 14:07:38 +02:00
|
|
|
/**
|
|
|
|
* Get the notes for this monitored object
|
|
|
|
*
|
|
|
|
* @return string The notes as a string
|
|
|
|
*/
|
|
|
|
public abstract function getNotes();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get all note urls configured for this monitored object
|
|
|
|
*
|
|
|
|
* @return array All note urls as a string
|
|
|
|
*/
|
|
|
|
public abstract function getNotesUrls();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function addFilter(Filter $filter)
|
2015-01-27 14:54:21 +01:00
|
|
|
{
|
2015-09-03 14:07:38 +02:00
|
|
|
// Left out on purpose. Interface is deprecated.
|
2015-01-27 14:54:21 +01:00
|
|
|
}
|
|
|
|
|
2015-09-03 14:07:38 +02:00
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function applyFilter(Filter $filter)
|
2015-01-27 14:54:21 +01:00
|
|
|
{
|
2015-09-03 14:07:38 +02:00
|
|
|
$this->getFilter()->addFilter($filter);
|
|
|
|
|
|
|
|
return $this;
|
2015-01-27 14:54:21 +01:00
|
|
|
}
|
|
|
|
|
2015-09-03 14:07:38 +02:00
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2015-01-27 14:54:21 +01:00
|
|
|
public function getFilter()
|
|
|
|
{
|
|
|
|
if ($this->filter === null) {
|
2015-06-16 17:44:29 +02:00
|
|
|
$this->filter = Filter::matchAll();
|
2015-01-27 14:54:21 +01:00
|
|
|
}
|
2015-09-03 14:07:38 +02:00
|
|
|
|
2015-01-27 14:54:21 +01:00
|
|
|
return $this->filter;
|
|
|
|
}
|
|
|
|
|
2015-09-03 14:07:38 +02:00
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function setFilter(Filter $filter)
|
2015-01-27 14:54:21 +01:00
|
|
|
{
|
|
|
|
// Left out on purpose. Interface is deprecated.
|
|
|
|
}
|
|
|
|
|
2015-09-03 14:07:38 +02:00
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
2015-01-27 14:54:21 +01:00
|
|
|
public function where($condition, $value = null)
|
|
|
|
{
|
|
|
|
// Left out on purpose. Interface is deprecated.
|
|
|
|
}
|
|
|
|
|
2015-09-17 10:40:00 +02:00
|
|
|
/**
|
|
|
|
* Return whether this object matches the given filter
|
|
|
|
*
|
|
|
|
* @param Filter $filter
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*
|
|
|
|
* @throws ProgrammingError In case the object cannot be found
|
2015-10-05 14:04:40 +02:00
|
|
|
*
|
|
|
|
* @deprecated Use $filter->matches($object) instead
|
2015-09-17 10:40:00 +02:00
|
|
|
*/
|
|
|
|
public function matches(Filter $filter)
|
|
|
|
{
|
|
|
|
if ($this->properties === null && $this->fetch() === false) {
|
|
|
|
throw new ProgrammingError(
|
|
|
|
'Unable to apply filter. Object %s of type %s not found.',
|
|
|
|
$this->getName(),
|
|
|
|
$this->getType()
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-10-05 14:04:40 +02:00
|
|
|
return $filter->matches($this);
|
2015-09-17 10:40:00 +02:00
|
|
|
}
|
|
|
|
|
2015-09-03 14:07:38 +02:00
|
|
|
/**
|
|
|
|
* Require the object's type to be one of the given types
|
|
|
|
*
|
|
|
|
* @param array $oneOf
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
* @throws InvalidArgumentException If the object's type is not one of the given types.
|
|
|
|
*/
|
|
|
|
public function assertOneOf(array $oneOf)
|
|
|
|
{
|
|
|
|
if (! in_array($this->type, $oneOf)) {
|
|
|
|
throw new InvalidArgumentException;
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
|
|
|
* Fetch the object's properties
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function fetch()
|
2013-07-12 14:33:17 +02:00
|
|
|
{
|
2015-09-03 16:38:46 +02:00
|
|
|
$properties = $this->getDataView()->applyFilter($this->getFilter())->getQuery()->fetchRow();
|
|
|
|
|
|
|
|
if ($properties === false) {
|
2014-11-16 19:28:08 +01:00
|
|
|
return false;
|
|
|
|
}
|
2015-09-03 16:38:46 +02:00
|
|
|
|
|
|
|
if (isset($properties->host_contacts)) {
|
2014-11-16 19:28:08 +01:00
|
|
|
$this->contacts = array();
|
2015-09-03 16:38:46 +02:00
|
|
|
foreach (preg_split('~,~', $properties->host_contacts) as $contact) {
|
2014-11-16 19:28:08 +01:00
|
|
|
$this->contacts[] = (object) array(
|
2015-04-10 12:23:35 +02:00
|
|
|
'contact_name' => $contact,
|
|
|
|
'contact_alias' => $contact,
|
|
|
|
'contact_email' => null,
|
|
|
|
'contact_pager' => null,
|
2014-11-16 19:28:08 +01:00
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
2015-09-03 16:38:46 +02:00
|
|
|
|
|
|
|
$this->properties = $properties;
|
|
|
|
|
2014-11-16 19:28:08 +01:00
|
|
|
return true;
|
2013-07-12 14:33:17 +02:00
|
|
|
}
|
|
|
|
|
2015-09-03 16:38:46 +02:00
|
|
|
/**
|
|
|
|
* Fetch the object's acknowledgement
|
|
|
|
*/
|
|
|
|
public function fetchAcknowledgement()
|
|
|
|
{
|
|
|
|
if ($this->comments === null) {
|
|
|
|
$this->fetchComments();
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
|
|
|
* Fetch the object's comments
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
2013-10-15 19:56:33 +02:00
|
|
|
public function fetchComments()
|
2013-07-12 14:33:17 +02:00
|
|
|
{
|
2014-11-16 19:24:37 +01:00
|
|
|
if ($this->backend->is('livestatus')) {
|
|
|
|
$this->comments = array();
|
|
|
|
return $this;
|
|
|
|
}
|
2015-09-03 16:38:46 +02:00
|
|
|
|
|
|
|
$commentsView = $this->backend->select()->from('comment', array(
|
|
|
|
'author' => 'comment_author_name',
|
|
|
|
'comment' => 'comment_data',
|
|
|
|
'expiration' => 'comment_expiration',
|
|
|
|
'id' => 'comment_internal_id',
|
|
|
|
'timestamp' => 'comment_timestamp',
|
|
|
|
'type' => 'comment_type'
|
|
|
|
));
|
2014-09-12 10:16:31 +02:00
|
|
|
if ($this->type === self::TYPE_SERVICE) {
|
2015-09-03 16:38:46 +02:00
|
|
|
$commentsView
|
2015-03-12 16:39:20 +01:00
|
|
|
->where('service_host_name', $this->host_name)
|
|
|
|
->where('service_description', $this->service_description);
|
|
|
|
} else {
|
2015-09-03 16:38:46 +02:00
|
|
|
$commentsView->where('host_name', $this->host_name);
|
|
|
|
}
|
|
|
|
$commentsView
|
|
|
|
->where('comment_type', array('ack', 'comment'))
|
|
|
|
->where('object_type', $this->type);
|
|
|
|
|
|
|
|
$comments = $commentsView->fetchAll();
|
|
|
|
|
|
|
|
if ((bool) $this->properties->{$this->prefix . 'acknowledged'}) {
|
|
|
|
$ackCommentIdx = null;
|
|
|
|
|
|
|
|
foreach ($comments as $i => $comment) {
|
|
|
|
if ($comment->type === 'ack') {
|
|
|
|
$this->acknowledgement = new Acknowledgement(array(
|
|
|
|
'author' => $comment->author,
|
|
|
|
'comment' => $comment->comment,
|
|
|
|
'entry_time' => $comment->timestamp,
|
|
|
|
'expiration_time' => $comment->expiration,
|
|
|
|
'sticky' => (int) $this->properties->{$this->prefix . 'acknowledgement_type'} === 2
|
|
|
|
));
|
|
|
|
$ackCommentIdx = $i;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($ackCommentIdx !== null) {
|
|
|
|
unset($comments[$ackCommentIdx]);
|
|
|
|
}
|
2014-03-09 19:29:23 +01:00
|
|
|
}
|
2015-09-03 16:38:46 +02:00
|
|
|
|
|
|
|
$this->comments = $comments;
|
|
|
|
|
2014-03-04 13:59:26 +01:00
|
|
|
return $this;
|
2013-07-12 14:33:17 +02:00
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Fetch the object's contact groups
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
public function fetchContactgroups()
|
2013-07-12 14:33:17 +02:00
|
|
|
{
|
2015-09-03 14:07:38 +02:00
|
|
|
if ($this->backend->is('livestatus')) {
|
|
|
|
$this->contactgroups = array();
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
$contactsGroups = $this->backend->select()->from('contactgroup', array(
|
|
|
|
'contactgroup_name',
|
|
|
|
'contactgroup_alias'
|
|
|
|
));
|
2014-09-12 10:16:31 +02:00
|
|
|
if ($this->type === self::TYPE_SERVICE) {
|
2015-09-03 14:07:38 +02:00
|
|
|
$contactsGroups
|
2015-03-06 13:14:20 +01:00
|
|
|
->where('service_host_name', $this->host_name)
|
|
|
|
->where('service_description', $this->service_description);
|
|
|
|
} else {
|
2015-09-03 14:07:38 +02:00
|
|
|
$contactsGroups->where('host_name', $this->host_name);
|
2014-03-09 21:58:01 +01:00
|
|
|
}
|
2015-09-03 14:07:38 +02:00
|
|
|
$this->contactgroups = $contactsGroups->applyFilter($this->getFilter())->getQuery()->fetchAll();
|
2013-07-12 14:33:17 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Fetch the object's contacts
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
public function fetchContacts()
|
2013-07-12 14:33:17 +02:00
|
|
|
{
|
2015-09-03 14:07:38 +02:00
|
|
|
if ($this->backend->is('livestatus')) {
|
|
|
|
$this->contacts = array();
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
$contacts = $this->backend->select()->from('contact', array(
|
|
|
|
'contact_name',
|
|
|
|
'contact_alias',
|
|
|
|
'contact_email',
|
|
|
|
'contact_pager',
|
|
|
|
));
|
|
|
|
if ($this->type === self::TYPE_SERVICE) {
|
|
|
|
$contacts
|
|
|
|
->where('service_host_name', $this->host_name)
|
|
|
|
->where('service_description', $this->service_description);
|
|
|
|
} else {
|
|
|
|
$contacts->where('host_name', $this->host_name);
|
|
|
|
}
|
|
|
|
$this->contacts = $contacts->applyFilter($this->getFilter())->getQuery()->fetchAll();
|
2013-07-12 14:33:17 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
2015-10-05 11:57:31 +02:00
|
|
|
* Fetch this object's obfuscated custom variables
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
2015-10-05 11:57:31 +02:00
|
|
|
* @return $this
|
2014-09-12 10:16:31 +02:00
|
|
|
*/
|
2014-01-30 16:34:23 +01:00
|
|
|
public function fetchCustomvars()
|
|
|
|
{
|
2014-11-16 19:24:37 +01:00
|
|
|
if ($this->backend->is('livestatus')) {
|
|
|
|
$this->customvars = array();
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-08-20 13:36:03 +02:00
|
|
|
$blacklist = array();
|
2014-09-12 10:16:31 +02:00
|
|
|
$blacklistPattern = '/^(.*pw.*|.*pass.*|community)$/i';
|
2014-08-20 13:36:03 +02:00
|
|
|
|
2014-11-18 13:11:52 +01:00
|
|
|
if (($blacklistConfig = Config::module('monitoring')->get('security', 'protected_customvars', '')) !== '') {
|
2014-08-20 13:36:03 +02:00
|
|
|
foreach (explode(',', $blacklistConfig) as $customvar) {
|
|
|
|
$nonWildcards = array();
|
|
|
|
foreach (explode('*', $customvar) as $nonWildcard) {
|
|
|
|
$nonWildcards[] = preg_quote($nonWildcard, '/');
|
|
|
|
}
|
|
|
|
$blacklist[] = implode('.*', $nonWildcards);
|
2014-08-19 18:46:37 +02:00
|
|
|
}
|
2014-08-20 13:36:03 +02:00
|
|
|
$blacklistPattern = '/^(' . implode('|', $blacklist) . ')$/i';
|
2014-08-19 18:46:37 +02:00
|
|
|
}
|
|
|
|
|
2015-10-05 11:57:31 +02:00
|
|
|
if ($this->type === self::TYPE_SERVICE) {
|
|
|
|
$this->fetchServiceVariables();
|
|
|
|
$customvars = $this->serviceVariables;
|
|
|
|
} else {
|
|
|
|
$this->fetchHostVariables();
|
|
|
|
$customvars = $this->hostVariables;
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->customvars = array();
|
|
|
|
foreach ($customvars as $name => $value) {
|
|
|
|
if ($blacklistPattern && preg_match($blacklistPattern, $name)) {
|
|
|
|
$this->customvars[$name] = '***';
|
|
|
|
} else {
|
|
|
|
$this->customvars[$name] = $value;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch the host custom variables related to this object
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function fetchHostVariables()
|
|
|
|
{
|
2014-09-12 10:16:31 +02:00
|
|
|
$query = $this->backend->select()->from('customvar', array(
|
|
|
|
'varname',
|
2014-11-06 16:15:16 +01:00
|
|
|
'varvalue',
|
|
|
|
'is_json'
|
2014-09-12 10:16:31 +02:00
|
|
|
))
|
2015-10-05 12:54:30 +02:00
|
|
|
->where('object_type', static::TYPE_HOST)
|
2014-09-16 18:38:03 +02:00
|
|
|
->where('host_name', $this->host_name);
|
2015-10-05 11:57:31 +02:00
|
|
|
|
|
|
|
$this->hostVariables = array();
|
|
|
|
foreach ($query as $row) {
|
|
|
|
if ($row->is_json) {
|
|
|
|
$this->hostVariables[strtolower($row->varname)] = json_decode($row->varvalue);
|
|
|
|
} else {
|
|
|
|
$this->hostVariables[strtolower($row->varname)] = $row->varvalue;
|
|
|
|
}
|
2014-01-30 16:34:23 +01:00
|
|
|
}
|
|
|
|
|
2015-10-05 11:57:31 +02:00
|
|
|
return $this;
|
|
|
|
}
|
2014-09-12 10:16:31 +02:00
|
|
|
|
2015-10-05 11:57:31 +02:00
|
|
|
/**
|
|
|
|
* Fetch the service custom variables related to this object
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*
|
|
|
|
* @throws ProgrammingError In case this object is not a service
|
|
|
|
*/
|
|
|
|
public function fetchServiceVariables()
|
|
|
|
{
|
|
|
|
if ($this->type !== static::TYPE_SERVICE) {
|
|
|
|
throw new ProgrammingError('Cannot fetch service custom variables for non-service objects');
|
|
|
|
}
|
|
|
|
|
|
|
|
$query = $this->backend->select()->from('customvar', array(
|
|
|
|
'varname',
|
|
|
|
'varvalue',
|
|
|
|
'is_json'
|
|
|
|
))
|
|
|
|
->where('object_type', static::TYPE_SERVICE)
|
|
|
|
->where('host_name', $this->host_name)
|
|
|
|
->where('service_description', $this->service_description);
|
|
|
|
|
|
|
|
$this->serviceVariables = array();
|
|
|
|
foreach ($query as $row) {
|
|
|
|
if ($row->is_json) {
|
|
|
|
$this->serviceVariables[strtolower($row->varname)] = json_decode($row->varvalue);
|
2014-11-06 16:15:16 +01:00
|
|
|
} else {
|
2015-10-05 11:57:31 +02:00
|
|
|
$this->serviceVariables[strtolower($row->varname)] = $row->varvalue;
|
2014-08-19 18:46:37 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-01-30 16:34:23 +01:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
2015-09-03 14:07:38 +02:00
|
|
|
* Fetch the object's downtimes
|
2014-09-12 10:16:31 +02:00
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
2015-09-03 14:07:38 +02:00
|
|
|
public function fetchDowntimes()
|
2013-07-12 14:33:17 +02:00
|
|
|
{
|
2015-09-03 14:07:38 +02:00
|
|
|
$downtimes = $this->backend->select()->from('downtime', array(
|
|
|
|
'id' => 'downtime_internal_id',
|
|
|
|
'objecttype' => 'object_type',
|
|
|
|
'comment' => 'downtime_comment',
|
|
|
|
'author_name' => 'downtime_author_name',
|
|
|
|
'start' => 'downtime_start',
|
|
|
|
'scheduled_start' => 'downtime_scheduled_start',
|
|
|
|
'scheduled_end' => 'downtime_scheduled_end',
|
|
|
|
'end' => 'downtime_end',
|
|
|
|
'duration' => 'downtime_duration',
|
|
|
|
'is_flexible' => 'downtime_is_flexible',
|
|
|
|
'is_fixed' => 'downtime_is_fixed',
|
|
|
|
'is_in_effect' => 'downtime_is_in_effect',
|
|
|
|
'entry_time' => 'downtime_entry_time'
|
|
|
|
))
|
|
|
|
->where('object_type', $this->type)
|
|
|
|
->order('downtime_is_in_effect', 'DESC')
|
|
|
|
->order('downtime_scheduled_start', 'ASC');
|
2014-09-12 10:16:31 +02:00
|
|
|
if ($this->type === self::TYPE_SERVICE) {
|
2015-09-03 14:07:38 +02:00
|
|
|
$downtimes
|
2015-03-12 16:39:20 +01:00
|
|
|
->where('service_host_name', $this->host_name)
|
|
|
|
->where('service_description', $this->service_description);
|
2015-03-06 10:02:20 +01:00
|
|
|
} else {
|
2015-09-03 14:07:38 +02:00
|
|
|
$downtimes
|
|
|
|
->where('host_name', $this->host_name);
|
2014-04-17 18:41:10 +02:00
|
|
|
}
|
2015-09-03 14:07:38 +02:00
|
|
|
$this->downtimes = $downtimes->getQuery()->fetchAll();
|
2013-07-12 14:33:17 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
|
|
|
* Fetch the object's event history
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function fetchEventhistory()
|
2013-07-12 14:33:17 +02:00
|
|
|
{
|
2015-08-19 11:53:00 +02:00
|
|
|
$eventHistory = $this->backend
|
|
|
|
->select()
|
|
|
|
->from(
|
|
|
|
'eventhistory',
|
|
|
|
array(
|
|
|
|
'object_type',
|
|
|
|
'host_name',
|
|
|
|
'host_display_name',
|
|
|
|
'service_description',
|
|
|
|
'service_display_name',
|
|
|
|
'timestamp',
|
|
|
|
'state',
|
|
|
|
'output',
|
|
|
|
'type'
|
|
|
|
)
|
|
|
|
)
|
|
|
|
->where('object_type', $this->type)
|
2014-09-16 18:38:03 +02:00
|
|
|
->where('host_name', $this->host_name);
|
2015-08-19 11:53:00 +02:00
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
if ($this->type === self::TYPE_SERVICE) {
|
2014-09-16 18:38:03 +02:00
|
|
|
$eventHistory->where('service_description', $this->service_description);
|
2014-06-06 09:09:15 +02:00
|
|
|
}
|
2015-08-19 11:53:00 +02:00
|
|
|
|
2015-06-16 17:44:29 +02:00
|
|
|
$this->eventhistory = $eventHistory->applyFilter($this->getFilter());
|
2013-07-12 14:33:17 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-09-03 14:07:38 +02:00
|
|
|
/**
|
|
|
|
* Fetch the object's host groups
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function fetchHostgroups()
|
|
|
|
{
|
|
|
|
$this->hostgroups = $this->backend->select()
|
|
|
|
->from('hostgroup', array('hostgroup_name', 'hostgroup_alias'))
|
|
|
|
->where('host_name', $this->host_name)
|
|
|
|
->applyFilter($this->getFilter())
|
|
|
|
->fetchPairs();
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch the object's service groups
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function fetchServicegroups()
|
|
|
|
{
|
2015-09-23 13:02:43 +02:00
|
|
|
$query = $this->backend->select()
|
2015-09-03 14:07:38 +02:00
|
|
|
->from('servicegroup', array('servicegroup_name', 'servicegroup_alias'))
|
2015-09-23 13:02:43 +02:00
|
|
|
->where('host_name', $this->host_name);
|
|
|
|
|
|
|
|
if ($this->type === self::TYPE_SERVICE) {
|
|
|
|
$query->where('service_description', $this->service_description);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->servicegroups = $query->applyFilter($this->getFilter())->fetchPairs();
|
2015-09-03 14:07:38 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2014-09-24 07:17:22 +02:00
|
|
|
/**
|
|
|
|
* Fetch stats
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function fetchStats()
|
|
|
|
{
|
2015-06-05 14:14:22 +02:00
|
|
|
$this->stats = $this->backend->select()->from('servicestatussummary', array(
|
2014-09-24 07:17:22 +02:00
|
|
|
'services_total',
|
|
|
|
'services_ok',
|
|
|
|
'services_critical',
|
|
|
|
'services_critical_unhandled',
|
|
|
|
'services_critical_handled',
|
|
|
|
'services_warning',
|
|
|
|
'services_warning_unhandled',
|
|
|
|
'services_warning_handled',
|
|
|
|
'services_unknown',
|
|
|
|
'services_unknown_unhandled',
|
|
|
|
'services_unknown_handled',
|
|
|
|
'services_pending',
|
|
|
|
))
|
|
|
|
->where('service_host_name', $this->host_name)
|
2015-06-05 14:14:22 +02:00
|
|
|
->applyFilter($this->getFilter())
|
2014-09-24 07:17:22 +02:00
|
|
|
->fetchRow();
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-09-03 14:07:38 +02:00
|
|
|
/**
|
|
|
|
* Get all action urls configured for this monitored object
|
|
|
|
*
|
|
|
|
* @return array All note urls as a string
|
|
|
|
*/
|
|
|
|
public function getActionUrls()
|
|
|
|
{
|
|
|
|
return $this->resolveAllStrings(
|
|
|
|
MonitoredObject::parseAttributeUrls($this->action_url)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the type of the object
|
|
|
|
*
|
2015-09-04 13:01:49 +02:00
|
|
|
* @param bool $translate
|
|
|
|
*
|
|
|
|
* @return string
|
2015-09-03 14:07:38 +02:00
|
|
|
*/
|
2015-09-04 13:01:49 +02:00
|
|
|
public function getType($translate = false)
|
2015-09-03 14:07:38 +02:00
|
|
|
{
|
2015-09-04 13:01:49 +02:00
|
|
|
if ($translate !== false) {
|
|
|
|
switch ($this->type) {
|
|
|
|
case self::TYPE_HOST:
|
|
|
|
$type = mt('montiroing', 'host');
|
|
|
|
break;
|
|
|
|
case self::TYPE_SERVICE:
|
|
|
|
$type = mt('monitoring', 'service');
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
throw new InvalidArgumentException('Invalid type ' . $this->type);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$type = $this->type;
|
|
|
|
}
|
|
|
|
return $type;
|
2015-09-03 14:07:38 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Parse the content of the action_url or notes_url attributes
|
|
|
|
*
|
|
|
|
* Find all occurences of http links, separated by whitespaces and quoted
|
|
|
|
* by single or double-ticks.
|
|
|
|
*
|
|
|
|
* @link http://docs.icinga.org/latest/de/objectdefinitions.html
|
|
|
|
*
|
|
|
|
* @param string $urlString A string containing one or more urls
|
|
|
|
* @return array Array of urls as strings
|
|
|
|
*/
|
|
|
|
public static function parseAttributeUrls($urlString)
|
|
|
|
{
|
|
|
|
if (empty($urlString)) {
|
|
|
|
return array();
|
|
|
|
}
|
2015-09-03 14:09:16 +02:00
|
|
|
$links = array();
|
2015-09-03 14:07:38 +02:00
|
|
|
if (strpos($urlString, "' ") === false) {
|
|
|
|
$links[] = $urlString;
|
|
|
|
} else {
|
|
|
|
// parse notes-url format
|
|
|
|
foreach (explode("' ", $urlString) as $url) {
|
|
|
|
$url = strpos($url, "'") === 0 ? substr($url, 1) : $url;
|
|
|
|
$url = strrpos($url, "'") === strlen($url) - 1 ? substr($url, 0, strlen($url) - 1) : $url;
|
|
|
|
$links[] = $url;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $links;
|
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
/**
|
|
|
|
* Fetch all available data of the object
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function populate()
|
2013-07-12 14:33:17 +02:00
|
|
|
{
|
2014-09-12 10:16:31 +02:00
|
|
|
$this
|
|
|
|
->fetchComments()
|
|
|
|
->fetchContactgroups()
|
2015-09-03 16:38:46 +02:00
|
|
|
->fetchContacts()
|
2014-09-12 10:16:31 +02:00
|
|
|
->fetchCustomvars()
|
|
|
|
->fetchDowntimes();
|
2015-09-03 13:47:51 +02:00
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
// Call fetchHostgroups or fetchServicegroups depending on the object's type
|
|
|
|
$fetchGroups = 'fetch' . ucfirst($this->type) . 'groups';
|
|
|
|
$this->$fetchGroups();
|
2015-09-03 13:47:51 +02:00
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
return $this;
|
2013-07-12 14:33:17 +02:00
|
|
|
}
|
2013-09-26 16:29:48 +02:00
|
|
|
|
2015-09-03 14:07:38 +02:00
|
|
|
/**
|
|
|
|
* Resolve macros in all given strings in the current object context
|
|
|
|
*
|
|
|
|
* @param array $strs An array of urls as string
|
2015-09-03 14:08:43 +02:00
|
|
|
*
|
|
|
|
* @return array
|
2015-09-03 14:07:38 +02:00
|
|
|
*/
|
|
|
|
protected function resolveAllStrings(array $strs)
|
|
|
|
{
|
|
|
|
foreach ($strs as $i => $str) {
|
|
|
|
$strs[$i] = Macro::resolveMacros($str, $this);
|
|
|
|
}
|
|
|
|
return $strs;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the object's properties
|
|
|
|
*
|
|
|
|
* @param object $properties
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function setProperties($properties)
|
|
|
|
{
|
|
|
|
$this->properties = (object) $properties;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function __isset($name)
|
|
|
|
{
|
|
|
|
if (property_exists($this->properties, $name)) {
|
|
|
|
return isset($this->properties->$name);
|
|
|
|
} elseif (property_exists($this, $name)) {
|
|
|
|
return isset($this->$name);
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
public function __get($name)
|
2013-10-14 18:17:58 +02:00
|
|
|
{
|
2014-09-12 10:16:31 +02:00
|
|
|
if (property_exists($this->properties, $name)) {
|
|
|
|
return $this->properties->$name;
|
|
|
|
} elseif (property_exists($this, $name)) {
|
2015-10-05 13:16:41 +02:00
|
|
|
if ($this->$name === null) {
|
|
|
|
$fetchMethod = 'fetch' . ucfirst($name);
|
|
|
|
$this->$fetchMethod();
|
|
|
|
}
|
|
|
|
|
2014-09-12 10:16:31 +02:00
|
|
|
return $this->$name;
|
2015-10-05 13:16:41 +02:00
|
|
|
} elseif (preg_match('/^_(host|service)_(.+)/i', $name, $matches)) {
|
|
|
|
if (strtolower($matches[1]) === static::TYPE_HOST) {
|
|
|
|
if ($this->hostVariables === null) {
|
|
|
|
$this->fetchHostVariables();
|
|
|
|
}
|
|
|
|
|
|
|
|
$customvars = $this->hostVariables;
|
|
|
|
} else {
|
|
|
|
if ($this->serviceVariables === null) {
|
|
|
|
$this->fetchServiceVariables();
|
|
|
|
}
|
|
|
|
|
|
|
|
$customvars = $this->serviceVariables;
|
|
|
|
}
|
|
|
|
|
|
|
|
$variableName = strtolower($matches[2]);
|
|
|
|
if (isset($customvars[$variableName])) {
|
|
|
|
return $customvars[$variableName];
|
|
|
|
}
|
|
|
|
|
|
|
|
return null; // Unknown custom variables MUST NOT throw an error
|
2015-10-05 13:59:57 +02:00
|
|
|
} elseif (in_array($name, array('contact_name', 'contactgroup_name', 'hostgroup_name', 'servicegroup_name'))) {
|
|
|
|
if ($name === 'contact_name') {
|
|
|
|
if ($this->contacts === null) {
|
|
|
|
$this->fetchContacts();
|
|
|
|
}
|
|
|
|
|
|
|
|
return array_map(function ($el) { return $el->contact_name; }, $this->contacts);
|
|
|
|
} elseif ($name === 'contactgroup_name') {
|
|
|
|
if ($this->contactgroups === null) {
|
|
|
|
$this->fetchContactgroups();
|
|
|
|
}
|
|
|
|
|
|
|
|
return array_map(function ($el) { return $el->contactgroup_name; }, $this->contactgroups);
|
|
|
|
} elseif ($name === 'hostgroup_name') {
|
|
|
|
if ($this->hostgroups === null) {
|
|
|
|
$this->fetchHostgroups();
|
|
|
|
}
|
|
|
|
|
|
|
|
return array_keys($this->hostgroups);
|
|
|
|
} else { // $name === 'servicegroup_name'
|
|
|
|
if ($this->servicegroups === null) {
|
|
|
|
$this->fetchServicegroups();
|
|
|
|
}
|
|
|
|
|
|
|
|
return array_keys($this->servicegroups);
|
|
|
|
}
|
2015-10-05 13:16:41 +02:00
|
|
|
} elseif (strpos($name, $this->prefix) !== 0) {
|
|
|
|
$propertyName = strtolower($name);
|
|
|
|
$prefixedName = $this->prefix . $propertyName;
|
2014-09-16 18:38:03 +02:00
|
|
|
if (property_exists($this->properties, $prefixedName)) {
|
|
|
|
return $this->properties->$prefixedName;
|
|
|
|
}
|
2015-10-05 13:16:41 +02:00
|
|
|
|
|
|
|
if ($this->type === static::TYPE_HOST) {
|
|
|
|
if ($this->hostVariables === null) {
|
|
|
|
$this->fetchHostVariables();
|
|
|
|
}
|
|
|
|
|
|
|
|
$customvars = $this->hostVariables;
|
|
|
|
} else { // $this->type === static::TYPE_SERVICE
|
|
|
|
if ($this->serviceVariables === null) {
|
|
|
|
$this->fetchServiceVariables();
|
|
|
|
}
|
|
|
|
|
|
|
|
$customvars = $this->serviceVariables;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (isset($customvars[$propertyName])) {
|
|
|
|
return $customvars[$propertyName];
|
|
|
|
}
|
2014-09-12 10:16:31 +02:00
|
|
|
}
|
2015-10-05 13:16:41 +02:00
|
|
|
|
2014-09-16 18:38:03 +02:00
|
|
|
throw new InvalidPropertyException('Can\'t access property \'%s\'. Property does not exist.', $name);
|
2013-10-14 18:17:58 +02:00
|
|
|
}
|
2014-09-24 07:17:22 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @deprecated
|
|
|
|
*/
|
|
|
|
public static function fromParams(UrlParams $params)
|
|
|
|
{
|
2015-04-20 16:11:22 +02:00
|
|
|
if ($params->has('service') && $params->has('host')) {
|
|
|
|
return new Service(MonitoringBackend::instance(), $params->get('host'), $params->get('service'));
|
|
|
|
} elseif ($params->has('host')) {
|
|
|
|
return new Host(MonitoringBackend::instance(), $params->get('host'));
|
2014-09-24 07:17:22 +02:00
|
|
|
}
|
2015-04-20 16:09:14 +02:00
|
|
|
return null;
|
2014-09-24 07:17:22 +02:00
|
|
|
}
|
2013-07-12 14:33:17 +02:00
|
|
|
}
|