mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-11-03 20:54:27 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			612 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			612 lines
		
	
	
		
			18 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
// {{{ICINGA_LICENSE_HEADER}}}
 | 
						|
/**
 | 
						|
 * This file is part of Icinga 2 Web.
 | 
						|
 *
 | 
						|
 * Icinga 2 Web - Head for multiple monitoring backends.
 | 
						|
 * Copyright (C) 2013 Icinga Development Team
 | 
						|
 *
 | 
						|
 * This program is free software; you can redistribute it and/or
 | 
						|
 * modify it under the terms of the GNU General Public License
 | 
						|
 * as published by the Free Software Foundation; either version 2
 | 
						|
 * of the License, or (at your option) any later version.
 | 
						|
 *
 | 
						|
 * This program is distributed in the hope that it will be useful,
 | 
						|
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
						|
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
						|
 * GNU General Public License for more details.
 | 
						|
 *
 | 
						|
 * You should have received a copy of the GNU General Public License
 | 
						|
 * along with this program; if not, write to the Free Software
 | 
						|
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 | 
						|
 *
 | 
						|
 * @copyright 2013 Icinga Development Team <info@icinga.org>
 | 
						|
 * @license   http://www.gnu.org/licenses/gpl-2.0.txt GPL, version 2
 | 
						|
 * @author    Icinga Development Team <info@icinga.org>
 | 
						|
 */
 | 
						|
// {{{ICINGA_LICENSE_HEADER}}}
 | 
						|
 | 
						|
namespace Icinga\Protocol\Commandpipe;
 | 
						|
 | 
						|
use Icinga\Protocol\Commandpipe\Transport\Transport;
 | 
						|
use Icinga\Protocol\Commandpipe\Transport\LocalPipe;
 | 
						|
use Icinga\Protocol\Commandpipe\Transport\SecureShell;
 | 
						|
 | 
						|
/**
 | 
						|
 * Class to the access icinga CommandPipe via a @see Icinga\Protocol\Commandpipe\Transport.php
 | 
						|
 *
 | 
						|
 * Will be configured using the instances.ini
 | 
						|
 */
 | 
						|
class CommandPipe
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * The name of this class as defined in the instances.ini
 | 
						|
     *
 | 
						|
     * @var string
 | 
						|
     */
 | 
						|
    private $name = "";
 | 
						|
 | 
						|
    /**
 | 
						|
     * The underlying @see Icinga\Protocol\Commandpipe\Transport.php class handling communication with icinga
 | 
						|
     *
 | 
						|
     * @var Icinga\Protocol\Commandpipe\Transport
 | 
						|
     */
 | 
						|
    private $transport = null;
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Constant identifying a monitoring object as host
 | 
						|
     */
 | 
						|
    const TYPE_HOST = "HOST";
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Constant identifying a monitoring object as service
 | 
						|
     */
 | 
						|
    const TYPE_SERVICE = "SVC";
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Constant identifying a monitoring object as hostgroup
 | 
						|
     */
 | 
						|
    const TYPE_HOSTGROUP = "HOSTGROUP";
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Constant identifying a monitoring object as servicegroups
 | 
						|
     */
 | 
						|
    const TYPE_SERVICEGROUP = "SERVICEGROUP";
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Notification option (use logical OR for combination)
 | 
						|
     *
 | 
						|
     *  Broadcast (send notification to all normal and all escalated contacts for the service)
 | 
						|
     */
 | 
						|
    const NOTIFY_BROADCAST  = 1;
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Notification option (use logical OR for combination)
 | 
						|
     *
 | 
						|
     *  notification is sent out regardless of current time, whether or not notifications are enabled, etc.
 | 
						|
     */
 | 
						|
    const NOTIFY_FORCED     = 2;
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Notification option (use logical OR for combination)
 | 
						|
     *
 | 
						|
     *  Increment current notification # for the service(this is not done by default for custom notifications)
 | 
						|
     */
 | 
						|
    const NOTIFY_INCREMENT  = 4;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Create a new CommandPipe class which accesses the icinga.cmd pipe as defined in $config
 | 
						|
     *
 | 
						|
     * @param \Zend_Config $config
 | 
						|
     */
 | 
						|
    public function __construct(\Zend_Config $config)
 | 
						|
    {
 | 
						|
        $this->getTransportForConfiguration($config);
 | 
						|
        $this->name = $config->name;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Setup the @see Icinga\Protocol\Commandpipe\Transport.php class that will be used for accessing the command pipe
 | 
						|
     *
 | 
						|
     * Currently this method uses SecureShell when a host is given, otherwise it assumes the pipe is accessible
 | 
						|
     * via the machines filesystem
 | 
						|
     *
 | 
						|
     * @param \Zend_Config $config          The configuration as defined in the instances.ini
 | 
						|
     */
 | 
						|
    private function getTransportForConfiguration(\Zend_Config $config)
 | 
						|
    {
 | 
						|
        if (isset($config->host)) {
 | 
						|
            $this->transport = new SecureShell();
 | 
						|
            $this->transport->setEndpoint($config);
 | 
						|
        } else {
 | 
						|
            $this->transport = new LocalPipe();
 | 
						|
            $this->transport->setEndpoint($config);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Send the command string $command to the icinga pipe
 | 
						|
     *
 | 
						|
     * This method just delegates the send command to the underlying transport
 | 
						|
     *
 | 
						|
     * @param String $command       The command string to send, without the timestamp
 | 
						|
     */
 | 
						|
    public function send($command)
 | 
						|
    {
 | 
						|
        $this->transport->send($command);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Send a command to the icinga pipe
 | 
						|
     *
 | 
						|
     * @param Command   $command
 | 
						|
     * @param array     $objects
 | 
						|
     */
 | 
						|
    public function sendCommand(BaseCommand $command, array $objects)
 | 
						|
    {
 | 
						|
        foreach ($objects as $object) {
 | 
						|
            $objectType = $this->getObjectType($object);
 | 
						|
            if ($objectType === self::TYPE_SERVICE) {
 | 
						|
                $this->transport->send($command->getServiceCommand($object->host_name, $object->service_description));
 | 
						|
            } else {
 | 
						|
                $this->transport->send($command->getHostCommand($object->host_name));
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Remove the acknowledgements of the provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array of mixed service and host objects whose acknowledgments will be removed
 | 
						|
     */
 | 
						|
    public function removeAcknowledge($objects)
 | 
						|
    {
 | 
						|
        foreach ($objects as $object) {
 | 
						|
            if (isset($object->service_description)) {
 | 
						|
                $this->send("REMOVE_SVC_ACKNOWLEDGEMENT;$object->host_name;$object->service_description");
 | 
						|
            } else {
 | 
						|
                $this->send("REMOVE_HOST_ACKNOWLEDGEMENT;$object->host_name");
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Removes the submitted comments
 | 
						|
     *
 | 
						|
     * @param array $objectsOrComments      An array of hosts and services (to remove all their comments)
 | 
						|
     *                                      or single comment objects to remove
 | 
						|
     */
 | 
						|
    public function removeComment($objectsOrComments)
 | 
						|
    {
 | 
						|
        foreach ($objectsOrComments as $object) {
 | 
						|
            if (isset($object->comment_id)) {
 | 
						|
                if (isset($object->service_description)) {
 | 
						|
                    $type = "SERVICE_COMMENT";
 | 
						|
                } else {
 | 
						|
                    $type = "HOST_COMMENT";
 | 
						|
                }
 | 
						|
                $this->send("DEL_{$type};" . intval($object->comment_id));
 | 
						|
            } else {
 | 
						|
                if (isset($object->service_description)) {
 | 
						|
                    $type = "SERVICE_COMMENT";
 | 
						|
                } else {
 | 
						|
                    $type = "HOST_COMMENT";
 | 
						|
                }
 | 
						|
                $cmd = "DEL_ALL_{$type}S;" . $object->host_name;
 | 
						|
                if ($type == "SERVICE_COMMENT") {
 | 
						|
                    $cmd .= ";" . $object->service_description;
 | 
						|
                }
 | 
						|
                $this->send($cmd);
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Globally enable notifications for this instance
 | 
						|
     *
 | 
						|
     */
 | 
						|
    public function enableGlobalNotifications()
 | 
						|
    {
 | 
						|
        $this->send("ENABLE_NOTIFICATIONS");
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Globally disable notifications for this instance
 | 
						|
     *
 | 
						|
     */
 | 
						|
    public function disableGlobalNotifications()
 | 
						|
    {
 | 
						|
        $this->send("DISABLE_NOTIFICATIONS");
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Return the object type of the provided object (TYPE_SERVICE or TYPE_HOST)
 | 
						|
     *
 | 
						|
     * @param $object           The object to identify
 | 
						|
     * @return string           TYPE_SERVICE or TYPE_HOST
 | 
						|
     */
 | 
						|
    private function getObjectType($object)
 | 
						|
    {
 | 
						|
        //@TODO: This must be refactored once more commands are supported
 | 
						|
        if (isset($object->service_description)) {
 | 
						|
            return self::TYPE_SERVICE;
 | 
						|
        }
 | 
						|
        return self::TYPE_HOST;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Remove downtimes for objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array containing hosts, service or downtime objects
 | 
						|
     * @param int $starttime        An optional starttime to use for the DEL_DOWNTIME_BY_HOST_NAME command
 | 
						|
     */
 | 
						|
    public function removeDowntime($objects, $starttime = 0)
 | 
						|
    {
 | 
						|
        foreach ($objects as $object) {
 | 
						|
            $type = $this->getObjectType($object);
 | 
						|
            if (isset($object->downtime_id)) {
 | 
						|
                $this->send("DEL_" . $type . "_DOWNTIME;" . $object->downtime_id);
 | 
						|
                continue;
 | 
						|
            }
 | 
						|
            $cmd = "DEL_DOWNTIME_BY_HOST_NAME;" . $object->host_name;
 | 
						|
            if ($type == self::TYPE_SERVICE) {
 | 
						|
                $cmd .= ";" . $object->service_description;
 | 
						|
            }
 | 
						|
            if ($starttime != 0) {
 | 
						|
                $cmd .= ";" . $starttime;
 | 
						|
            }
 | 
						|
            $this->send($cmd);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     *  Restart the icinga instance
 | 
						|
     *
 | 
						|
     */
 | 
						|
    public function restartIcinga()
 | 
						|
    {
 | 
						|
        $this->send("RESTART_PROCESS");
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Modify monitoring flags for the provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects            An arry of service and/or host objects to modify
 | 
						|
     * @param PropertyModifier $flags   The Monitoring attributes to modify
 | 
						|
     */
 | 
						|
    public function setMonitoringProperties($objects, PropertyModifier $flags)
 | 
						|
    {
 | 
						|
        foreach ($objects as $object) {
 | 
						|
            $type = $this->getObjectType($object);
 | 
						|
            $formatArray = $flags->getFormatString($type);
 | 
						|
            foreach ($formatArray as $format) {
 | 
						|
                $format .= ";"
 | 
						|
                    . $object->host_name
 | 
						|
                    . ($type == self::TYPE_SERVICE ? ";" . $object->service_description : "");
 | 
						|
                $this->send($format);
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable active checks for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array containing services and hosts to enable active checks for
 | 
						|
     */
 | 
						|
    public function enableActiveChecks($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::ACTIVE => PropertyModifier::STATE_ENABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disable active checks for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array containing services and hosts to disable active checks
 | 
						|
     */
 | 
						|
    public function disableActiveChecks($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::ACTIVE => PropertyModifier::STATE_DISABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable passive checks for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array containing services and hosts to enable passive checks for
 | 
						|
     */
 | 
						|
    public function enablePassiveChecks($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::PASSIVE => PropertyModifier::STATE_ENABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable passive checks for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array containing services and hosts to enable passive checks for
 | 
						|
     */
 | 
						|
    public function disablePassiveChecks($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::PASSIVE => PropertyModifier::STATE_DISABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable flap detection for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array containing services and hosts to enable flap detection
 | 
						|
     *
 | 
						|
     */
 | 
						|
    public function enableFlappingDetection($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::FLAPPING => PropertyModifier::STATE_ENABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disable flap detection for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array containing services and hosts to disable flap detection
 | 
						|
     *
 | 
						|
     */
 | 
						|
    public function disableFlappingDetection($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::FLAPPING => PropertyModifier::STATE_DISABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable notifications for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array containing services and hosts to enable notification
 | 
						|
     *
 | 
						|
     */
 | 
						|
    public function enableNotifications($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::NOTIFICATIONS => PropertyModifier::STATE_ENABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disable flap detection for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects        An array containing services and hosts to disable notifications
 | 
						|
     *
 | 
						|
     */
 | 
						|
    public function disableNotifications($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::NOTIFICATIONS => PropertyModifier::STATE_DISABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable freshness checks for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts and/or services
 | 
						|
     */
 | 
						|
    public function enableFreshnessChecks($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::FRESHNESS => PropertyModifier::STATE_ENABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disable freshness checks for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts and/or services
 | 
						|
     */
 | 
						|
    public function disableFreshnessChecks($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::FRESHNESS => PropertyModifier::STATE_DISABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable event handler for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts and/or services
 | 
						|
     */
 | 
						|
    public function enableEventHandler($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::EVENTHANDLER => PropertyModifier::STATE_ENABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disable event handler for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts and/or services
 | 
						|
     */
 | 
						|
    public function disableEventHandler($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::EVENTHANDLER => PropertyModifier::STATE_DISABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable performance data parsing for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts and/or services
 | 
						|
     */
 | 
						|
    public function enablePerfdata($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::PERFDATA => PropertyModifier::STATE_ENABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disable performance data parsing for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts and/or services
 | 
						|
     */
 | 
						|
    public function disablePerfdata($objects)
 | 
						|
    {
 | 
						|
        $this->setMonitoringProperties(
 | 
						|
            $objects,
 | 
						|
            new PropertyModifier(
 | 
						|
                array(
 | 
						|
                    PropertyModifier::PERFDATA => PropertyModifier::STATE_DISABLE
 | 
						|
                )
 | 
						|
            )
 | 
						|
        );
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disable notifications for all services of the provided hosts
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts
 | 
						|
     */
 | 
						|
    public function disableNotificationsForServices($objects)
 | 
						|
    {
 | 
						|
        foreach ($objects as $host) {
 | 
						|
            $msg = 'DISABLE_HOST_SVC_NOTIFICATIONS;'.$host->host_name;
 | 
						|
            $this->send($msg);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable notifications for all services of the provided hosts
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts
 | 
						|
     */
 | 
						|
    public function enableNotificationsForServices($objects)
 | 
						|
    {
 | 
						|
        foreach ($objects as $host) {
 | 
						|
            $msg = 'ENABLE_HOST_SVC_NOTIFICATIONS;'.$host->host_name;
 | 
						|
            $this->send($msg);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Disable active checks for all services of the provided hosts
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts
 | 
						|
     */
 | 
						|
    public function disableActiveChecksWithChildren($objects)
 | 
						|
    {
 | 
						|
        foreach ($objects as $host) {
 | 
						|
            $msg = 'DISABLE_HOST_SVC_CHECKS;'.$host->host_name;
 | 
						|
            $this->send($msg);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Enable active checks for all services of the provided hosts
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts
 | 
						|
     */
 | 
						|
    public function enableActiveChecksWithChildren($objects)
 | 
						|
    {
 | 
						|
        foreach ($objects as $host) {
 | 
						|
            $msg = 'ENABLE_HOST_SVC_CHECKS;'.$host->host_name;
 | 
						|
            $this->send($msg);
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Reset modified attributes for all provided objects
 | 
						|
     *
 | 
						|
     * @param array $objects    An array of hosts and services
 | 
						|
     */
 | 
						|
    public function resetAttributes($objects)
 | 
						|
    {
 | 
						|
        foreach ($objects as $object) {
 | 
						|
            $type = $this->getObjectType($object);
 | 
						|
            if ($type === self::TYPE_SERVICE) {
 | 
						|
                $this->send('CHANGE_SVC_MODATTR;'.$object->host_name.';'.$object->service_description.';0');
 | 
						|
            } else {
 | 
						|
                $this->send('CHANGE_HOST_MODATTR;'.$object->host_name.';0');
 | 
						|
            }
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Return the transport handler that handles actual sending of commands
 | 
						|
     *
 | 
						|
     * @return Transport
 | 
						|
     */
 | 
						|
    public function getTransport()
 | 
						|
    {
 | 
						|
        return $this->transport;
 | 
						|
    }
 | 
						|
}
 |