setName('setup_authentication_backend'); $this->setTitle($this->translate('Authentication Backend', 'setup.page.title')); $this->setValidatePartial(true); } /** * Set the resource configuration to use * * @param array $config * * @return $this */ public function setResourceConfig(array $config) { $resourceConfig = new Config(); $resourceConfig->setSection($config['name'], $config); ResourceFactory::setConfig($resourceConfig); $this->config = $config; return $this; } /** * Create and add elements to this form * * @param array $formData */ public function createElements(array $formData) { if (isset($formData['skip_validation']) && $formData['skip_validation']) { $this->addSkipValidationCheckbox(); } $backendForm = null; if (! isset($this->config) || $this->config['type'] === 'external') { $backendForm = new ExternalBackendForm(); $backendForm->create($formData); $this->addDescription($this->translate( '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.' )); } elseif ($this->config['type'] === 'db') { $this->setRequiredCue(null); $backendForm = new DbBackendForm(); $backendForm->setRequiredCue(null); $backendForm->create($formData)->removeElement('resource'); $this->addDescription($this->translate( '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') { $type = null; if (! isset($formData['type'])) { if (isset($formData['backend'])) { $formData['type'] = $type = $formData['backend']; } elseif (isset($this->suggestions['backend'])) { $formData['type'] = $type = $this->suggestions['backend']; } } $backendForm = new LdapBackendForm(); $backendForm->setSuggestions($this->suggestions); $backendForm->setResources(array($this->config['name'])); $backendForm->create($formData); $backendForm->getElement('resource')->setIgnore(true); $this->addDescription($this->translate( '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.' )); $this->addElement( 'select', 'type', array( 'ignore' => true, 'required' => true, 'autosubmit' => true, 'label' => $this->translate('Backend Type'), 'description' => $this->translate( 'The type of the resource being used for this authenticaton provider' ), 'multiOptions' => array( 'ldap' => 'LDAP', 'msldap' => 'ActiveDirectory' ), 'value' => $type ) ); } $backendForm->getElement('name')->setValue('icingaweb2'); $this->addSubForm($backendForm, 'backend_form'); } /** * 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; } /** * 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 (! parent::isValid($data)) { return false; } if (isset($this->config)) { if ($this->config['type'] === 'ldap' && ( ! isset($data['skip_validation']) || $data['skip_validation'] == 0) ) { $self = clone $this; $self->getSubForm('backend_form')->getElement('resource')->setIgnore(false); $inspection = UserBackendConfigForm::inspectUserBackend($self); if ($inspection && $inspection->hasError()) { $this->error($inspection->getError()); $this->addSkipValidationCheckbox(); return false; } } } return true; } /** * Run the configured backend's inspection checks and show the result, if necessary * * This will only run any validation if the user pushed the 'backend_validation' button. * * @param array $formData * * @return bool */ public function isValidPartial(array $formData) { if (isset($formData['backend_validation']) && parent::isValid($formData)) { $self = clone $this; if (($resourceElement = $self->getSubForm('backend_form')->getElement('resource')) !== null) { $resourceElement->setIgnore(false); } $inspection = UserBackendConfigForm::inspectUserBackend($self); if ($inspection !== null) { $join = function ($e) use (&$join) { return is_string($e) ? $e : join("\n", array_map($join, $e)); }; $this->addElement( 'note', 'inspection_output', array( 'order' => 0, 'value' => '' . $this->translate('Validation Log') . "\n\n" . join("\n", array_map($join, $inspection->toArray())), 'decorators' => array( 'ViewHelper', array('HtmlTag', array('tag' => 'pre', 'class' => 'log-output')), ) ) ); if ($inspection->hasError()) { $this->warning(sprintf( $this->translate('Failed to successfully validate the configuration: %s'), $inspection->getError() )); return false; } } $this->info($this->translate('The configuration has been successfully validated.')); } elseif (isset($formData['discovery_btn']) || isset($formData['btn_discover_domain'])) { return parent::isValidPartial($formData); } elseif (! isset($formData['backend_validation'])) { // This is usually done by isValid(Partial), but as we're not calling any of these... $this->populate($formData); } 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( 'order' => 0, 'ignore' => true, 'required' => true, 'label' => $this->translate('Skip Validation'), 'description' => $this->translate('Check this to not to validate authentication using this backend') ) ); } /** * Get default values for the subform's elements suggested by a previous step * * @return string[] */ public function getSuggestions() { return $this->suggestions; } /** * Set default values for the subform's elements suggested by a previous step * * @param string[] $suggestions * * @return $this */ public function setSuggestions(array $suggestions) { $this->suggestions = $suggestions; return $this; } }