mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-10-25 17:34:03 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			190 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			190 lines
		
	
	
		
			5.5 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\Form\Config\Authentication;
 | |
| 
 | |
| use \Zend_Config;
 | |
| use \Zend_Form_Element_Checkbox;
 | |
| use Icinga\Web\Form;
 | |
| use Icinga\Data\ResourceFactory;
 | |
| use Icinga\Web\Form\Decorator\HelpText;
 | |
| 
 | |
| /**
 | |
|  * Base form for authentication backend forms
 | |
|  */
 | |
| abstract class BaseBackendForm extends Form
 | |
| {
 | |
|     /**
 | |
|      * The name of the backend currently displayed in this form
 | |
|      *
 | |
|      * Will be the section in the authentication.ini file
 | |
|      *
 | |
|      * @var string
 | |
|      */
 | |
|     protected $backendName = '';
 | |
| 
 | |
|     /**
 | |
|      * The backend configuration as a Zend_Config object
 | |
|      *
 | |
|      * @var Zend_Config
 | |
|      */
 | |
|     protected $backend;
 | |
| 
 | |
|     /**
 | |
|      * The resources to use instead of the factory provided ones (use for testing)
 | |
|      *
 | |
|      * @var Zend_Config
 | |
|      */
 | |
|     protected $resources;
 | |
| 
 | |
|     /**
 | |
|      * Set the name of the currently displayed backend
 | |
|      *
 | |
|      * @param   string  $name   The name to be stored as the section when persisting
 | |
|      */
 | |
|     public function setBackendName($name)
 | |
|     {
 | |
|         $this->backendName = $name;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the backend name of this form
 | |
|      *
 | |
|      * @return  string
 | |
|      */
 | |
|     public function getBackendName()
 | |
|     {
 | |
|         return $this->backendName;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return the backend configuration or a empty Zend_Config object if none is given
 | |
|      *
 | |
|      * @return  Zend_Config
 | |
|      */
 | |
|     public function getBackend()
 | |
|     {
 | |
|         return ($this->backend !== null) ? $this->backend : new Zend_Config(array());
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set the backend configuration for initial population
 | |
|      *
 | |
|      * @param   Zend_Config     $backend    The backend to display in this form
 | |
|      */
 | |
|     public function setBackend(Zend_Config $backend)
 | |
|     {
 | |
|         $this->backend = $backend;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Set an alternative array of resources that should be used instead of the DBFactory resource set
 | |
|      *
 | |
|      * @param   array   $resources      The resources to use for populating the db selection field
 | |
|      */
 | |
|     public function setResources(array $resources)
 | |
|     {
 | |
|         $this->resources = $resources;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return content of the resources.ini or previously set resources
 | |
|      *
 | |
|      * @return  array
 | |
|      */
 | |
|     public function getResources()
 | |
|     {
 | |
|         if ($this->resources === null) {
 | |
|             return ResourceFactory::getResourceConfigs()->toArray();
 | |
|         } else {
 | |
|             return $this->resources;
 | |
|         }
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Add checkbox at the beginning of the form which allows to skip logic connection validation
 | |
|      */
 | |
|     protected function addForceCreationCheckbox()
 | |
|     {
 | |
|         $checkbox = new Zend_Form_Element_Checkbox(
 | |
|             array(
 | |
|                 'name'      =>  'backend_force_creation',
 | |
|                 'label'     =>  t('Force Changes'),
 | |
|                 'helptext'  =>  t('Check this box to enforce changes without connectivity validation'),
 | |
|                 'order'     =>  0
 | |
|             )
 | |
|         );
 | |
|         $checkbox->addDecorator(new HelpText());
 | |
|         $this->addElement($checkbox);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Validate this form with the Zend validation mechanism and perform a logic validation of the connection.
 | |
|      *
 | |
|      * If logic validation fails, the 'backend_force_creation' checkbox is prepended to the form to allow users to
 | |
|      * skip the logic connection validation.
 | |
|      *
 | |
|      * @param   array   $data   The form input to validate
 | |
|      *
 | |
|      * @return  bool            Whether validation succeeded or not
 | |
|      */
 | |
|     public function isValid($data)
 | |
|     {
 | |
|         if (!parent::isValid($data)) {
 | |
|             return false;
 | |
|         }
 | |
|         if (isset($data['backend_force_creation']) && $data['backend_force_creation']) {
 | |
|             return true;
 | |
|         }
 | |
|         if (!$this->isValidAuthenticationBackend()) {
 | |
|             $this->addForceCreationCheckbox();
 | |
|             return false;
 | |
|         }
 | |
|         return true;
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Return an array containing all sections defined by this form as the key and all settings
 | |
|      * as an key-value sub-array
 | |
|      *
 | |
|      * @return  array
 | |
|      */
 | |
|     abstract public function getConfig();
 | |
| 
 | |
|     /**
 | |
|      * Validate the configuration state of this backend with the concrete authentication backend.
 | |
|      *
 | |
|      * An implementation should not throw any exception, but use the add/setErrorMessages method of
 | |
|      * Zend_Form. If the 'backend_force_creation' checkbox is set, this method won't be called.
 | |
|      *
 | |
|      * @return  bool    Whether validation succeeded or not
 | |
|      */
 | |
|     abstract public function isValidAuthenticationBackend();
 | |
| }
 |