mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-25 01:14:26 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			604 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			604 lines
		
	
	
		
			17 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| // {{{ICINGA_LICENSE_HEADER}}}
 | |
| // {{{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($this->escape($command));
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the given command string with escaped newlines
 | |
|      *
 | |
|      * @param   string  $command    The command string to escape
 | |
|      *
 | |
|      * @return  string              The escaped command string
 | |
|      */
 | |
|     public function escape($command)
 | |
|     {
 | |
|         return str_replace(array("\r", "\n"), array('\r', '\n'), $command);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Send a command to the icinga pipe
 | |
|      *
 | |
|      * @param Command   $command
 | |
|      * @param array     $objects
 | |
|      */
 | |
|     public function sendCommand(Command $command, array $objects = array())
 | |
|     {
 | |
|         if ($command->provideGlobalCommand() === true) {
 | |
|             $this->send($command->getGlobalCommand());
 | |
|         } else {
 | |
|             foreach ($objects as $object) {
 | |
|                 $objectType = $this->getObjectType($object);
 | |
|                 if ($objectType === self::TYPE_SERVICE) {
 | |
|                     $this->send($command->getServiceCommand($object->host_name, $object->service_description));
 | |
|                 } else {
 | |
|                     $this->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;
 | |
|     }
 | |
| }
 |