mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-31 03:14:31 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			182 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			182 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| // {{{ICINGA_LICENSE_HEADER}}}
 | |
| /**
 | |
|  * This file is part of Icinga Web 2.
 | |
|  *
 | |
|  * Icinga Web 2 - 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\Module\Monitoring\Form\Command;
 | |
| 
 | |
| use Zend_Config;
 | |
| use Zend_Controller_Request_Abstract;
 | |
| use Zend_Form_Element_Hidden;
 | |
| use Icinga\Module\Monitoring\Command\AcknowledgeCommand;
 | |
| use Icinga\Web\Form;
 | |
| 
 | |
| /**
 | |
|  * Simple confirmation command
 | |
|  */
 | |
| abstract class CommandForm extends Form
 | |
| {
 | |
|     /**
 | |
|      * If the form is for a global command
 | |
|      *
 | |
|      * @var bool
 | |
|      */
 | |
|     protected $globalCommand = false;
 | |
| 
 | |
|     /**
 | |
|      * Set command program wide
 | |
|      *
 | |
|      * @param bool $flag
 | |
|      */
 | |
|     public function setProvideGlobalCommand($flag = true)
 | |
|     {
 | |
|         $this->globalCommand = (boolean) $flag;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Getter for globalCommand
 | |
|      *
 | |
|      * @return bool
 | |
|      */
 | |
|     public function provideGlobalCommand()
 | |
|     {
 | |
|         return (boolean) $this->globalCommand;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Create an instance name containing hidden field
 | |
|      *
 | |
|      * @return Zend_Form_Element_Hidden
 | |
|      */
 | |
|     private function createInstanceHiddenField()
 | |
|     {
 | |
|         $field = new Zend_Form_Element_Hidden('instance');
 | |
|         $value = $this->getRequest()->getParam($field->getName());
 | |
|         $field->setValue($value);
 | |
|         return $field;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add elements to this form (used by extending classes)
 | |
|      *
 | |
|      * @see Form::create
 | |
|      */
 | |
|     protected function create()
 | |
|     {
 | |
|         $this->addElement($this->createInstanceHiddenField());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get the author name
 | |
|      *
 | |
|      * @return string
 | |
|      */
 | |
|     protected function getAuthorName()
 | |
|     {
 | |
|         if (is_a($this->getRequest(), "Zend_Controller_Request_HttpTestCase")) {
 | |
|             return "Test user";
 | |
|         }
 | |
|         return $this->getRequest()->getUser()->getUsername();
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Creator for author field
 | |
|      *
 | |
|      * @return Zend_Form_Element_Hidden
 | |
|      */
 | |
|     protected function createAuthorField()
 | |
|     {
 | |
|         $authorName = $this->getAuthorName();
 | |
| 
 | |
|         $authorField = new Zend_Form_Element_Hidden(
 | |
|             array(
 | |
|                 'name'       => 'author',
 | |
|                 'label'      => t('Author (Your Name)'),
 | |
|                 'value'      => $authorName,
 | |
|                 'required'   => true
 | |
|             )
 | |
|         );
 | |
| 
 | |
|         $authorField->addDecorator(
 | |
|             'Callback',
 | |
|             array(
 | |
|                 'callback' => function () use ($authorName) {
 | |
|                     return sprintf('<strong>%s</strong>', $authorName);
 | |
|                 }
 | |
|             )
 | |
|         );
 | |
| 
 | |
|         return $authorField;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Get a list of valid datetime formats
 | |
|      *
 | |
|      * @return array
 | |
|      */
 | |
|     public function getValidDateTimeFormats()
 | |
|     {
 | |
|         $config = $this->getConfiguration();
 | |
|         $global = $config->global;
 | |
|         if ($global === null) {
 | |
|             $global = new Zend_Config(array());
 | |
|         }
 | |
|         $preferences = $this->getUserPreferences();
 | |
|         return array(
 | |
|             implode(
 | |
|                 ' ',
 | |
|                 array(
 | |
|                     $preferences->get('app.dateFormat', $global->get('dateFormat', 'd/m/Y')),
 | |
|                     $preferences->get('app.timeFormat', $global->get('timeFormat', 'g:i A'))
 | |
|                 )
 | |
|             )
 | |
|         );
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Sets the form to global if we have data in the request
 | |
|      *
 | |
|      * @param Zend_Controller_Request_Abstract $request
 | |
|      */
 | |
|     public function setRequest(Zend_Controller_Request_Abstract $request)
 | |
|     {
 | |
|         parent::setRequest($request);
 | |
| 
 | |
|         if ($request->getParam('global')) {
 | |
|             $this->setProvideGlobalCommand(true);
 | |
|         }
 | |
|     }
 | |
| 
 | |
| 
 | |
|     /**
 | |
|      * Create command object for CommandPipe protocol
 | |
|      *
 | |
|      * @return AcknowledgeCommand
 | |
|      */
 | |
|     abstract public function createCommand();
 | |
| }
 |