Allow to discover LDAP connections in the wizard as well

...
This commit is contained in:
Johannes Meyer 2015-07-29 09:26:53 +02:00
parent 1de1f119d6
commit 83aafe8cda
2 changed files with 13 additions and 25 deletions

View File

@ -164,12 +164,7 @@ class UserBackend
); );
} }
if ($backendConfig->resource instanceof ConfigObject) {
$resource = ResourceFactory::createResource($backendConfig->resource);
} else {
$resource = ResourceFactory::create($backendConfig->resource); $resource = ResourceFactory::create($backendConfig->resource);
}
switch ($backendType) { switch ($backendType) {
case 'db': case 'db':
$backend = new DbUserBackend($resource); $backend = new DbUserBackend($resource);

View File

@ -3,7 +3,8 @@
namespace Icinga\Module\Setup\Forms; namespace Icinga\Module\Setup\Forms;
use Icinga\Data\ConfigObject; use Icinga\Application\Config;
use Icinga\Data\ResourceFactory;
use Icinga\Forms\Config\UserBackendConfigForm; use Icinga\Forms\Config\UserBackendConfigForm;
use Icinga\Forms\Config\UserBackend\DbBackendForm; use Icinga\Forms\Config\UserBackend\DbBackendForm;
use Icinga\Forms\Config\UserBackend\LdapBackendForm; use Icinga\Forms\Config\UserBackend\LdapBackendForm;
@ -40,22 +41,18 @@ class AuthBackendPage extends Form
*/ */
public function setResourceConfig(array $config) public function setResourceConfig(array $config)
{ {
$resourceConfig = new Config();
$resourceConfig->setSection($config['name'], $config);
ResourceFactory::setConfig($resourceConfig);
$this->config = $config; $this->config = $config;
return $this; return $this;
} }
/** /**
* Return the resource configuration as Config object * Create and add elements to this form
* *
* @return ConfigObject * @param array $formData
*/
public function getResourceConfig()
{
return new ConfigObject($this->config);
}
/**
* @see Form::createElements()
*/ */
public function createElements(array $formData) public function createElements(array $formData)
{ {
@ -74,7 +71,9 @@ class AuthBackendPage extends Form
)); ));
} elseif ($this->config['type'] === 'ldap') { } elseif ($this->config['type'] === 'ldap') {
$backendForm = new LdapBackendForm(); $backendForm = new LdapBackendForm();
$backendForm->create($formData)->removeElement('resource'); $backendForm->setResources(array($this->config['name']));
$backendForm->create($formData);
$backendForm->getElement('resource')->setIgnore(true);
$this->addDescription($this->translate( $this->addDescription($this->translate(
'Before you are able to authenticate using the LDAP connection defined earlier you need to' 'Before you are able to authenticate using the LDAP connection defined earlier you need to'
. ' provide some more information so that Icinga Web 2 is able to locate account details.' . ' provide some more information so that Icinga Web 2 is able to locate account details.'
@ -139,13 +138,7 @@ class AuthBackendPage extends Form
if ($this->config['type'] === 'ldap' && (! isset($data['skip_validation']) || $data['skip_validation'] == 0)) { if ($this->config['type'] === 'ldap' && (! isset($data['skip_validation']) || $data['skip_validation'] == 0)) {
$self = clone $this; $self = clone $this;
$self->addElement( $self->getSubForm('backend_form')->getElement('resource')->setIgnore(false);
'text',
'resource',
array(
'value' => $this->getResourceConfig()
)
);
$inspection = UserBackendConfigForm::inspectUserBackend($self); $inspection = UserBackendConfigForm::inspectUserBackend($self);
if ($inspection && $inspection->hasError()) { if ($inspection && $inspection->hasError()) {
$this->error($inspection->getError()); $this->error($inspection->getError());