mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-25 09:24:02 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			178 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			178 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| // {{{ICINGA_LICENSE_HEADER}}}
 | |
| // {{{ICINGA_LICENSE_HEADER}}}
 | |
| 
 | |
| namespace Icinga\Module\Monitoring\Command\Object;
 | |
| 
 | |
| use InvalidArgumentException;
 | |
| use LogicException;
 | |
| 
 | |
| /**
 | |
|  * Submit a passive check result for a host or service
 | |
|  */
 | |
| class ProcessCheckResultCommand extends ObjectCommand
 | |
| {
 | |
|     /**
 | |
|      * (non-PHPDoc)
 | |
|      * @see \Icinga\Module\Monitoring\Command\Object\ObjectCommand::$allowedObjects For the property documentation.
 | |
|      */
 | |
|     protected $allowedObjects = array(
 | |
|         self::TYPE_HOST,
 | |
|         self::TYPE_SERVICE
 | |
|     );
 | |
| 
 | |
|     /**
 | |
|      * Host up
 | |
|      */
 | |
|     const HOST_UP = 0;
 | |
| 
 | |
|     /**
 | |
|      * Host down
 | |
|      */
 | |
|     const HOST_DOWN = 1;
 | |
| 
 | |
|     /**
 | |
|      * Host unreachable
 | |
|      */
 | |
|     const HOST_UNREACHABLE = 2; // TODO: Icinga 2.x does not support submitting results with this state, yet
 | |
| 
 | |
|     /**
 | |
|      * Service ok
 | |
|      */
 | |
|     const SERVICE_OK = 0;
 | |
| 
 | |
|     /**
 | |
|      * Service warning
 | |
|      */
 | |
|     const SERVICE_WARNING = 1;
 | |
| 
 | |
|     /**
 | |
|      * Service critical
 | |
|      */
 | |
|     const SERVICE_CRITICAL = 2;
 | |
| 
 | |
|     /**
 | |
|      * Service unknown
 | |
|      */
 | |
|     const SERVICE_UNKNOWN = 3;
 | |
| 
 | |
|     /**
 | |
|      * Possible status codes for passive host and service checks
 | |
|      *
 | |
|      * @var array
 | |
|      */
 | |
|     public static $statusCodes = array(
 | |
|         self::TYPE_HOST => array(
 | |
|             self::HOST_UP, self::HOST_DOWN, self::HOST_UNREACHABLE
 | |
|         ),
 | |
|         self::TYPE_SERVICE => array(
 | |
|             self::SERVICE_OK, self::SERVICE_WARNING, self::SERVICE_CRITICAL, self::SERVICE_UNKNOWN
 | |
|         )
 | |
|     );
 | |
| 
 | |
|     /**
 | |
|      * Status code of the host or service check result
 | |
|      *
 | |
|      * @var int
 | |
|      */
 | |
|     protected $status;
 | |
| 
 | |
|     /**
 | |
|      * Text output of the host or service check result
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     protected $output;
 | |
| 
 | |
|     /**
 | |
|      * Optional performance data of the host or service check result
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     protected $performanceData;
 | |
| 
 | |
| 
 | |
|     /**
 | |
|      * Set the status code of the host or service check result
 | |
|      *
 | |
|      * @param   int $status
 | |
|      *
 | |
|      * @return  $this
 | |
|      *
 | |
|      * @throws  LogicException              If the object is null
 | |
|      * @throws  InvalidArgumentException    If status is not one of the valid status codes for the object's type
 | |
|      */
 | |
|     public function setStatus($status)
 | |
|     {
 | |
|         if ($this->object === null) {
 | |
|             throw new LogicException('You\'re required to call setObject() before calling setStatus()');
 | |
|         }
 | |
|         $status = (int) $status;
 | |
|         if (! in_array($status, self::$statusCodes[$this->object->getType()])) {
 | |
|             throw new InvalidArgumentException(sprintf(
 | |
|                 'The status code %u you provided is not one of the valid status codes for type %s',
 | |
|                 $status,
 | |
|                 $this->object->getType()
 | |
|             ));
 | |
|         }
 | |
|         $this->status = $status;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the status code of the host or service check result
 | |
|      *
 | |
|      * @return int
 | |
|      */
 | |
|     public function getStatus()
 | |
|     {
 | |
|         return $this->status;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the text output of the host or service check result
 | |
|      *
 | |
|      * @param   string $output
 | |
|      *
 | |
|      * @return  $this
 | |
|      */
 | |
|     public function setOutput($output)
 | |
|     {
 | |
|         $this->output = (string) $output;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the text output of the host or service check result
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public function getOutput()
 | |
|     {
 | |
|         return $this->output;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the performance data of the host or service check result
 | |
|      *
 | |
|      * @param   string $performanceData
 | |
|      *
 | |
|      * @return  $this
 | |
|      */
 | |
|     public function setPerformanceData($performanceData)
 | |
|     {
 | |
|         $this->performanceData = (string) $performanceData;
 | |
|         return $this;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the performance data of the host or service check result
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     public function getPerformanceData()
 | |
|     {
 | |
|         return $this->performanceData;
 | |
|     }
 | |
| }
 |