mirror of
				https://github.com/Icinga/icingaweb2-module-director.git
				synced 2025-10-25 01:14:29 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace Icinga\Module\Director\Forms;
 | |
| 
 | |
| use Icinga\Module\Director\Web\Form\DirectorObjectForm;
 | |
| use Icinga\Authentication\Auth;
 | |
| 
 | |
| class DirectorDatalistForm extends DirectorObjectForm
 | |
| {
 | |
|     public function setup()
 | |
|     {
 | |
|         $this->addElement('text', 'list_name', array(
 | |
|             'label'       => $this->translate('List name'),
 | |
|             'description' => $this->translate(
 | |
|                 'Data lists are mainly used as data providers for custom variables'
 | |
|                 . ' presented as dropdown boxes boxes. You can manually manage'
 | |
|                 . ' their entries here in place, but you could also create dedicated'
 | |
|                 . ' sync rules after creating a new empty list. This would allow you'
 | |
|                 . ' to keep your available choices in sync with external data providers'
 | |
|             ),
 | |
|             'required'    => true,
 | |
|         ));
 | |
|         $this->addSimpleDisplayGroup(array('list_name'), 'list', array(
 | |
|             'legend' => $this->translate('Data list')
 | |
|         ));
 | |
| 
 | |
|         $this->setButtons();
 | |
|     }
 | |
| 
 | |
|     public function onSuccess()
 | |
|     {
 | |
|         $this->object()->set('owner', self::username());
 | |
|         parent::onSuccess();
 | |
|     }
 | |
| 
 | |
|     protected static function username()
 | |
|     {
 | |
|         $auth = Auth::getInstance();
 | |
|         if ($auth->isAuthenticated()) {
 | |
|             return $auth->getUser()->getUsername();
 | |
|         } else {
 | |
|             return '<unknown>';
 | |
|         }
 | |
|     }
 | |
| }
 |