mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-25 09:24:02 +02:00 
			
		
		
		
	Filter::matchAny() without any subfilters matches none, Filter::matchAll() without any subfilters matches all.
		
			
				
	
	
		
			149 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			149 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| /* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
 | |
| 
 | |
| namespace Icinga\Module\Monitoring;
 | |
| 
 | |
| use Icinga\Exception\ConfigurationError;
 | |
| use Icinga\Exception\QueryException;
 | |
| use Icinga\Data\Filter\Filter;
 | |
| use Icinga\Data\Filterable;
 | |
| use Icinga\File\Csv;
 | |
| use Icinga\Util\Json;
 | |
| use Icinga\Web\Controller as IcingaWebController;
 | |
| use Icinga\Web\Url;
 | |
| 
 | |
| /**
 | |
|  * Base class for all monitoring action controller
 | |
|  */
 | |
| class Controller extends IcingaWebController
 | |
| {
 | |
|     /**
 | |
|      * The backend used for this controller
 | |
|      *
 | |
|      * @var Backend
 | |
|      */
 | |
|     protected $backend;
 | |
| 
 | |
|     protected function moduleInit()
 | |
|     {
 | |
|         $this->backend = Backend::createBackend($this->_getParam('backend'));
 | |
|         $this->view->url = Url::fromRequest();
 | |
|     }
 | |
| 
 | |
|     protected function handleFormatRequest($query)
 | |
|     {
 | |
|         $desiredContentType = $this->getRequest()->getHeader('Accept');
 | |
|         if ($desiredContentType === 'application/json') {
 | |
|             $desiredFormat = 'json';
 | |
|         } elseif ($desiredContentType === 'text/csv') {
 | |
|             $desiredFormat = 'csv';
 | |
|         } else {
 | |
|             $desiredFormat = strtolower($this->params->get('format', 'html'));
 | |
|         }
 | |
| 
 | |
|         if ($desiredFormat !== 'html' && ! $this->params->has('limit')) {
 | |
|             $query->limit();  // Resets any default limit and offset
 | |
|         }
 | |
| 
 | |
|         switch ($desiredFormat) {
 | |
|             case 'sql':
 | |
|                 echo '<pre>'
 | |
|                     . htmlspecialchars(wordwrap($query->dump()))
 | |
|                     . '</pre>';
 | |
|                 exit;
 | |
|             case 'json':
 | |
|                 $response = $this->getResponse();
 | |
|                 $response
 | |
|                     ->setHeader('Content-Type', 'application/json')
 | |
|                     ->setHeader('Cache-Control', 'no-store')
 | |
|                     ->setHeader(
 | |
|                         'Content-Disposition',
 | |
|                         'inline; filename=' . $this->getRequest()->getActionName() . '.json'
 | |
|                     )
 | |
|                     ->appendBody(Json::sanitize($query->fetchAll()))
 | |
|                     ->sendResponse();
 | |
|                 exit;
 | |
|             case 'csv':
 | |
|                 $response = $this->getResponse();
 | |
|                 $response
 | |
|                     ->setHeader('Content-Type', 'text/csv')
 | |
|                     ->setHeader('Cache-Control', 'no-store')
 | |
|                     ->setHeader(
 | |
|                         'Content-Disposition',
 | |
|                         'attachment; filename=' . $this->getRequest()->getActionName() . '.csv'
 | |
|                     )
 | |
|                     ->appendBody((string) Csv::fromQuery($query))
 | |
|                     ->sendResponse();
 | |
|                 exit;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Apply a restriction of the authenticated on the given filterable
 | |
|      *
 | |
|      * @param   string      $name       Name of the restriction
 | |
|      * @param   Filterable  $filterable Filterable to restrict
 | |
|      *
 | |
|      * @return  Filterable  The filterable having the restriction applied
 | |
|      */
 | |
|     protected function applyRestriction($name, Filterable $filterable)
 | |
|     {
 | |
|         $filterable->applyFilter($this->getRestriction($name));
 | |
|         return $filterable;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get a restriction of the authenticated
 | |
|      *
 | |
|      * @param   string $name        Name of the restriction
 | |
|      *
 | |
|      * @return  Filter              Filter object
 | |
|      * @throws  ConfigurationError  If the restriction contains invalid filter columns
 | |
|      */
 | |
|     protected function getRestriction($name)
 | |
|     {
 | |
|         $restriction = Filter::matchAny();
 | |
|         $restriction->setAllowedFilterColumns(array(
 | |
|             'host_name',
 | |
|             'hostgroup_name',
 | |
|             'instance_name',
 | |
|             'service_description',
 | |
|             'servicegroup_name',
 | |
|             function ($c) {
 | |
|                 return preg_match('/^_(?:host|service)_/i', $c);
 | |
|             }
 | |
|         ));
 | |
|         foreach ($this->getRestrictions($name) as $filter) {
 | |
|             if ($filter === '*') {
 | |
|                 return Filter::matchAll();
 | |
|             }
 | |
|             try {
 | |
|                 $restriction->addFilter(Filter::fromQueryString($filter));
 | |
|             } catch (QueryException $e) {
 | |
|                 throw new ConfigurationError(
 | |
|                     $this->translate(
 | |
|                         'Cannot apply restriction %s using the filter %s. You can only use the following columns: %s'
 | |
|                     ),
 | |
|                     $name,
 | |
|                     $filter,
 | |
|                     implode(', ', array(
 | |
|                         'instance_name',
 | |
|                         'host_name',
 | |
|                         'hostgroup_name',
 | |
|                         'service_description',
 | |
|                         'servicegroup_name',
 | |
|                         '_(host|service)_<customvar-name>'
 | |
|                     )),
 | |
|                     $e
 | |
|                 );
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         if ($restriction->isEmpty()) {
 | |
|             return Filter::matchAll();
 | |
|         }
 | |
| 
 | |
|         return $restriction;
 | |
|     }
 | |
| }
 |