2015-05-29 16:34:34 +02:00
|
|
|
<?php
|
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
|
|
|
|
|
|
|
namespace Icinga\Forms\Config\UserGroup;
|
|
|
|
|
|
|
|
use InvalidArgumentException;
|
|
|
|
use Icinga\Exception\IcingaException;
|
|
|
|
use Icinga\Exception\NotFoundError;
|
|
|
|
use Icinga\Forms\ConfigForm;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Form for managing user group backends
|
|
|
|
*/
|
|
|
|
class UserGroupBackendForm extends ConfigForm
|
|
|
|
{
|
2015-06-05 13:07:16 +02:00
|
|
|
/**
|
|
|
|
* The backend to load when displaying the form for the first time
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $backendToLoad;
|
|
|
|
|
2015-05-29 16:34:34 +02:00
|
|
|
/**
|
|
|
|
* Initialize this form
|
|
|
|
*/
|
|
|
|
public function init()
|
|
|
|
{
|
|
|
|
$this->setName('form_config_usergroupbackend');
|
|
|
|
$this->setSubmitLabel($this->translate('Save Changes'));
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return a form object for the given backend type
|
|
|
|
*
|
2015-06-29 11:11:06 +02:00
|
|
|
* @param string $type The backend type for which to return a form
|
2015-05-29 16:34:34 +02:00
|
|
|
*
|
|
|
|
* @return Form
|
2015-06-29 11:11:06 +02:00
|
|
|
*
|
|
|
|
* @throws InvalidArgumentException In case the given backend type is invalid
|
2015-05-29 16:34:34 +02:00
|
|
|
*/
|
|
|
|
public function getBackendForm($type)
|
|
|
|
{
|
2015-06-05 14:53:29 +02:00
|
|
|
switch ($type)
|
|
|
|
{
|
|
|
|
case 'db':
|
|
|
|
return new DbUserGroupBackendForm();
|
|
|
|
case 'ldap':
|
|
|
|
case 'msldap':
|
|
|
|
return new LdapUserGroupBackendForm();
|
|
|
|
default:
|
|
|
|
throw new InvalidArgumentException(
|
|
|
|
sprintf($this->translate('Invalid backend type "%s" provided'), $type)
|
|
|
|
);
|
2015-05-29 16:34:34 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Populate the form with the given backend's config
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*
|
|
|
|
* @throws NotFoundError In case no backend with the given name is found
|
|
|
|
*/
|
|
|
|
public function load($name)
|
|
|
|
{
|
|
|
|
if (! $this->config->hasSection($name)) {
|
|
|
|
throw new NotFoundError('No user group backend called "%s" found', $name);
|
|
|
|
}
|
|
|
|
|
2015-06-05 13:07:16 +02:00
|
|
|
$this->backendToLoad = $name;
|
2015-05-29 16:34:34 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a new user group backend
|
|
|
|
*
|
2015-06-29 11:11:06 +02:00
|
|
|
* The backend to add is identified by the array-key `name'.
|
|
|
|
*
|
2015-05-29 16:34:34 +02:00
|
|
|
* @param array $data
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*
|
|
|
|
* @throws InvalidArgumentException In case $data does not contain a backend name
|
|
|
|
* @throws IcingaException In case a backend with the same name already exists
|
|
|
|
*/
|
|
|
|
public function add(array $data)
|
|
|
|
{
|
|
|
|
if (! isset($data['name'])) {
|
|
|
|
throw new InvalidArgumentException('Key \'name\' missing');
|
|
|
|
}
|
|
|
|
|
|
|
|
$backendName = $data['name'];
|
|
|
|
if ($this->config->hasSection($backendName)) {
|
|
|
|
throw new IcingaException('A user group backend with the name "%s" does already exist', $backendName);
|
|
|
|
}
|
|
|
|
|
|
|
|
unset($data['name']);
|
|
|
|
$this->config->setSection($backendName, $data);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Edit a user group backend
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
* @param array $data
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*
|
|
|
|
* @throws NotFoundError In case no backend with the given name is found
|
|
|
|
*/
|
|
|
|
public function edit($name, array $data)
|
|
|
|
{
|
|
|
|
if (! $this->config->hasSection($name)) {
|
|
|
|
throw new NotFoundError('No user group backend called "%s" found', $name);
|
|
|
|
}
|
|
|
|
|
|
|
|
$backendConfig = $this->config->getSection($name);
|
2015-06-05 15:41:24 +02:00
|
|
|
if (isset($data['name'])) {
|
|
|
|
if ($data['name'] !== $name) {
|
|
|
|
$this->config->removeSection($name);
|
|
|
|
$name = $data['name'];
|
|
|
|
}
|
|
|
|
|
2015-05-29 16:34:34 +02:00
|
|
|
unset($data['name']);
|
|
|
|
}
|
|
|
|
|
2015-06-05 15:45:33 +02:00
|
|
|
$backendConfig->merge($data);
|
|
|
|
foreach ($backendConfig->toArray() as $k => $v) {
|
|
|
|
if ($v === null) {
|
|
|
|
unset($backendConfig->$k);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->config->setSection($name, $backendConfig);
|
2015-05-29 16:34:34 +02:00
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remove a user group backend
|
|
|
|
*
|
|
|
|
* @param string $name
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function delete($name)
|
|
|
|
{
|
|
|
|
$this->config->removeSection($name);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create and add elements to this form
|
|
|
|
*
|
|
|
|
* @param array $formData
|
|
|
|
*/
|
|
|
|
public function createElements(array $formData)
|
|
|
|
{
|
|
|
|
$this->addElement(
|
|
|
|
'text',
|
|
|
|
'name',
|
|
|
|
array(
|
|
|
|
'required' => true,
|
|
|
|
'label' => $this->translate('Backend Name'),
|
|
|
|
'description' => $this->translate(
|
|
|
|
'The name of this user group backend that is used to differentiate it from others'
|
|
|
|
),
|
|
|
|
'validators' => array(
|
|
|
|
array(
|
|
|
|
'Regex',
|
|
|
|
false,
|
|
|
|
array(
|
|
|
|
'pattern' => '/^[^\\[\\]:]+$/',
|
|
|
|
'messages' => array(
|
|
|
|
'regexNotMatch' => $this->translate(
|
2015-06-29 11:11:06 +02:00
|
|
|
'The name cannot contain \'[\', \']\' or \':\'.'
|
2015-05-29 16:34:34 +02:00
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
// TODO(jom): We did not think about how to configure custom group backends yet!
|
|
|
|
$backendTypes = array(
|
2015-06-05 14:53:29 +02:00
|
|
|
'db' => $this->translate('Database'),
|
2015-06-05 16:40:17 +02:00
|
|
|
'ldap' => 'LDAP',
|
|
|
|
'msldap' => 'ActiveDirectory'
|
2015-05-29 16:34:34 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
$backendType = isset($formData['type']) ? $formData['type'] : null;
|
|
|
|
if ($backendType === null) {
|
|
|
|
$backendType = key($backendTypes);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->addElement(
|
|
|
|
'hidden',
|
|
|
|
'backend',
|
|
|
|
array(
|
|
|
|
'disabled' => true, // Prevents the element from being submitted, see #7717
|
|
|
|
'value' => $backendType
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
|
|
|
$this->addElement(
|
|
|
|
'select',
|
|
|
|
'type',
|
|
|
|
array(
|
|
|
|
'ignore' => true,
|
|
|
|
'required' => true,
|
|
|
|
'autosubmit' => true,
|
|
|
|
'label' => $this->translate('Backend Type'),
|
|
|
|
'description' => $this->translate('The type of this user group backend'),
|
2015-06-05 14:53:29 +02:00
|
|
|
'multiOptions' => $backendTypes
|
2015-05-29 16:34:34 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2015-06-05 14:53:29 +02:00
|
|
|
$this->addSubForm($this->getBackendForm($backendType)->create($formData), 'backend_form');
|
2015-05-29 16:34:34 +02:00
|
|
|
}
|
2015-06-05 13:07:16 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Populate the configuration of the backend to load
|
|
|
|
*/
|
|
|
|
public function onRequest()
|
|
|
|
{
|
|
|
|
if ($this->backendToLoad) {
|
|
|
|
$data = $this->config->getSection($this->backendToLoad)->toArray();
|
|
|
|
$data['type'] = $data['backend'];
|
|
|
|
$data['name'] = $this->backendToLoad;
|
|
|
|
$this->populate($data);
|
|
|
|
}
|
|
|
|
}
|
2015-06-05 14:53:29 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve all form element values
|
|
|
|
*
|
|
|
|
* @param bool $suppressArrayNotation Ignored
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getValues($suppressArrayNotation = false)
|
|
|
|
{
|
|
|
|
$values = parent::getValues();
|
|
|
|
$values = array_merge($values, $values['backend_form']);
|
|
|
|
unset($values['backend_form']);
|
|
|
|
return $values;
|
|
|
|
}
|
2015-05-29 16:34:34 +02:00
|
|
|
}
|