2014-09-29 12:28:12 +02:00
|
|
|
<?php
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
2014-11-14 11:01:16 +01:00
|
|
|
namespace Icinga\Module\Setup\Forms;
|
2014-09-29 12:28:12 +02:00
|
|
|
|
2014-11-11 12:11:14 +01:00
|
|
|
use Icinga\Application\Config;
|
2014-09-29 12:28:12 +02:00
|
|
|
use Icinga\Web\Form;
|
2014-11-14 10:57:14 +01:00
|
|
|
use Icinga\Forms\Config\Authentication\DbBackendForm;
|
|
|
|
use Icinga\Forms\Config\Authentication\LdapBackendForm;
|
|
|
|
use Icinga\Forms\Config\Authentication\AutologinBackendForm;
|
2014-09-29 12:28:12 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Wizard page to define authentication backend specific details
|
|
|
|
*/
|
|
|
|
class AuthBackendPage extends Form
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The resource configuration to use
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $config;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize this page
|
|
|
|
*/
|
|
|
|
public function init()
|
|
|
|
{
|
|
|
|
$this->setName('setup_authentication_backend');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the resource configuration to use
|
|
|
|
*
|
|
|
|
* @param array $config
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function setResourceConfig(array $config)
|
|
|
|
{
|
|
|
|
$this->config = $config;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-11-11 12:11:14 +01:00
|
|
|
* Return the resource configuration as Config object
|
2014-09-29 12:28:12 +02:00
|
|
|
*
|
2014-11-11 12:11:14 +01:00
|
|
|
* @return Config
|
2014-09-29 12:28:12 +02:00
|
|
|
*/
|
|
|
|
public function getResourceConfig()
|
|
|
|
{
|
2014-11-11 12:11:14 +01:00
|
|
|
return new Config($this->config);
|
2014-09-29 12:28:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @see Form::createElements()
|
|
|
|
*/
|
|
|
|
public function createElements(array $formData)
|
|
|
|
{
|
2014-11-11 15:27:14 +01:00
|
|
|
$this->addElement(
|
2014-11-14 10:15:11 +01:00
|
|
|
'note',
|
|
|
|
'title',
|
|
|
|
array(
|
|
|
|
'value' => mt('setup', 'Authentication Backend', 'setup.page.title'),
|
|
|
|
'decorators' => array(
|
|
|
|
'ViewHelper',
|
|
|
|
array('HtmlTag', array('tag' => 'h2'))
|
2014-11-11 15:27:14 +01:00
|
|
|
)
|
|
|
|
)
|
|
|
|
);
|
|
|
|
|
2014-10-21 16:15:04 +02:00
|
|
|
if ($this->config['type'] === 'db') {
|
2014-11-11 09:24:53 +01:00
|
|
|
$note = mt(
|
|
|
|
'setup',
|
2014-10-21 16:15:04 +02:00
|
|
|
'As you\'ve chosen to use a database for authentication all you need '
|
|
|
|
. 'to do now is defining a name for your first authentication backend.'
|
|
|
|
);
|
|
|
|
} elseif ($this->config['type'] === 'ldap') {
|
2014-11-11 09:24:53 +01:00
|
|
|
$note = mt(
|
|
|
|
'setup',
|
2014-10-21 16:15:04 +02:00
|
|
|
'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.'
|
|
|
|
);
|
|
|
|
} else { // if ($this->config['type'] === 'autologin'
|
2014-11-11 09:24:53 +01:00
|
|
|
$note = mt(
|
|
|
|
'setup',
|
2014-10-21 16:15:04 +02:00
|
|
|
'You\'ve chosen to authenticate using a web server\'s mechanism so it may be necessary'
|
|
|
|
. ' to adjust usernames before any permissions, restrictions, etc. are being applied.'
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2014-09-29 12:28:12 +02:00
|
|
|
$this->addElement(
|
2014-11-14 10:15:11 +01:00
|
|
|
'note',
|
|
|
|
'description',
|
|
|
|
array('value' => $note)
|
2014-09-29 12:28:12 +02:00
|
|
|
);
|
|
|
|
|
|
|
|
if (isset($formData['skip_validation']) && $formData['skip_validation']) {
|
|
|
|
$this->addSkipValidationCheckbox();
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->config['type'] === 'db') {
|
|
|
|
$backendForm = new DbBackendForm();
|
|
|
|
$backendForm->createElements($formData)->removeElement('resource');
|
|
|
|
} elseif ($this->config['type'] === 'ldap') {
|
|
|
|
$backendForm = new LdapBackendForm();
|
|
|
|
$backendForm->createElements($formData)->removeElement('resource');
|
|
|
|
} else { // $this->config['type'] === 'autologin'
|
|
|
|
$backendForm = new AutologinBackendForm();
|
|
|
|
$backendForm->createElements($formData);
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->addElements($backendForm->getElements());
|
2014-11-11 12:41:02 +01:00
|
|
|
$this->getElement('name')->setValue('icingaweb');
|
2014-09-29 12:28:12 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Validate the given form data and check whether it's possible to authenticate using the configured backend
|
|
|
|
*
|
|
|
|
* @param array $data The data to validate
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isValid($data)
|
|
|
|
{
|
|
|
|
if (false === parent::isValid($data)) {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (false === isset($data['skip_validation']) || $data['skip_validation'] == 0) {
|
|
|
|
if ($this->config['type'] === 'ldap' && false === LdapBackendForm::isValidAuthenticationBackend($this)) {
|
|
|
|
$this->addSkipValidationCheckbox();
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a checkbox to this form by which the user can skip the authentication validation
|
|
|
|
*/
|
|
|
|
protected function addSkipValidationCheckbox()
|
|
|
|
{
|
|
|
|
$this->addElement(
|
|
|
|
'checkbox',
|
|
|
|
'skip_validation',
|
|
|
|
array(
|
2014-11-11 15:27:14 +01:00
|
|
|
'order' => 2,
|
2014-09-29 12:28:12 +02:00
|
|
|
'ignore' => true,
|
|
|
|
'required' => true,
|
2014-11-11 09:24:53 +01:00
|
|
|
'label' => mt('setup', 'Skip Validation'),
|
|
|
|
'description' => mt('setup', 'Check this to not to validate authentication using this backend')
|
2014-09-29 12:28:12 +02:00
|
|
|
)
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|