setName('form_config_ldapusergroupbackend'); } /** * 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' ) ) ); $resourceNames = $this->getLdapResourceNames(); $this->addElement( 'select', 'resource', array( 'required' => true, 'autosubmit' => true, 'label' => $this->translate('LDAP Connection'), 'description' => $this->translate('The LDAP connection to use for this backend.'), 'multiOptions' => array_combine($resourceNames, $resourceNames) ) ); $resource = ResourceFactory::create( isset($formData['resource']) && in_array($formData['resource'], $resourceNames) ? $formData['resource'] : $resourceNames[0] ); $userBackendNames = $this->getLdapUserBackendNames($resource); if (! empty($userBackendNames)) { $userBackends = array_combine($userBackendNames, $userBackendNames); $userBackends['none'] = $this->translate('None', 'usergroupbackend.ldap.user_backend'); } else { $userBackends = array('none' => $this->translate('None', 'usergroupbackend.ldap.user_backend')); } $this->addElement( 'select', 'user_backend', array( 'required' => true, 'autosubmit' => true, 'label' => $this->translate('User Backend'), 'description' => $this->translate('The user backend to link with this user group backend.'), 'multiOptions' => $userBackends ) ); $groupBackend = new LdapUserGroupBackend($resource); if ($formData['type'] === 'ldap') { $defaults = $groupBackend->getOpenLdapDefaults(); $groupConfigDisabled = $userConfigDisabled = null; // MUST BE null, do NOT change this to false! } else { // $formData['type'] === 'msldap' $defaults = $groupBackend->getActiveDirectoryDefaults(); $groupConfigDisabled = $userConfigDisabled = true; } $this->createGroupConfigElements($defaults, $groupConfigDisabled); if (count($userBackends) === 1 || (isset($formData['user_backend']) && $formData['user_backend'] === 'none')) { $this->createUserConfigElements($defaults, $userConfigDisabled); } else { $this->createHiddenUserConfigElements(); } $this->addElement( 'hidden', 'backend', array( 'disabled' => true, // Prevents the element from being submitted, see #7717 'value' => $formData['type'] ) ); } /** * Create and add all elements to this form required for the group configuration * * @param ConfigObject $defaults * @param null|bool $disabled */ protected function createGroupConfigElements(ConfigObject $defaults, $disabled) { $this->addElement( 'text', 'group_class', array( 'preserveDefault' => true, 'ignore' => $disabled, 'disabled' => $disabled, 'label' => $this->translate('LDAP Group Object Class'), 'description' => $this->translate('The object class used for storing groups on the LDAP server.'), 'value' => $defaults->group_class ) ); $this->addElement( 'text', 'group_filter', array( 'preserveDefault' => true, 'allowEmpty' => true, 'label' => $this->translate('LDAP Group Filter'), 'description' => $this->translate( 'An additional filter to use when looking up groups using the specified connection. ' . 'Leave empty to not to use any additional filter rules.' ), 'requirement' => $this->translate( 'The filter needs to be expressed as standard LDAP expression, without' . ' outer parentheses. (e.g. &(foo=bar)(bar=foo) or foo=bar)' ), 'validators' => array( array( 'Callback', false, array( 'callback' => function ($v) { return strpos($v, '(') !== 0; }, 'messages' => array( 'callbackValue' => $this->translate('The filter must not be wrapped in parantheses.') ) ) ) ), 'value' => $defaults->group_filter ) ); $this->addElement( 'text', 'group_name_attribute', array( 'preserveDefault' => true, 'ignore' => $disabled, 'disabled' => $disabled, 'label' => $this->translate('LDAP Group Name Attribute'), 'description' => $this->translate( 'The attribute name used for storing a group\'s name on the LDAP server.' ), 'value' => $defaults->group_name_attribute ) ); $this->addElement( 'text', 'group_member_attribute', array( 'preserveDefault' => true, 'ignore' => $disabled, 'disabled' => $disabled, 'label' => $this->translate('LDAP Group Member Attribute'), 'description' => $this->translate('The attribute name used for storing a group\'s members.'), 'value' => $defaults->group_member_attribute ) ); $this->addElement( 'text', 'base_dn', array( 'preserveDefault' => true, 'label' => $this->translate('LDAP Group Base DN'), 'description' => $this->translate( 'The path where groups can be found on the LDAP server. Leave ' . 'empty to select all users available using the specified connection.' ), 'value' => $defaults->base_dn ) ); } /** * Create and add all elements to this form required for the user configuration * * @param ConfigObject $defaults * @param null|bool $disabled */ protected function createUserConfigElements(ConfigObject $defaults, $disabled) { $this->addElement( 'text', 'user_class', array( 'preserveDefault' => true, 'ignore' => $disabled, 'disabled' => $disabled, 'label' => $this->translate('LDAP User Object Class'), 'description' => $this->translate('The object class used for storing users on the LDAP server.'), 'value' => $defaults->user_class ) ); $this->addElement( 'text', 'user_filter', array( 'preserveDefault' => true, 'allowEmpty' => true, 'label' => $this->translate('LDAP User Filter'), 'description' => $this->translate( 'An additional filter to use when looking up users using the specified connection. ' . 'Leave empty to not to use any additional filter rules.' ), 'requirement' => $this->translate( 'The filter needs to be expressed as standard LDAP expression, without' . ' outer parentheses. (e.g. &(foo=bar)(bar=foo) or foo=bar)' ), 'validators' => array( array( 'Callback', false, array( 'callback' => function ($v) { return strpos($v, '(') !== 0; }, 'messages' => array( 'callbackValue' => $this->translate('The filter must not be wrapped in parantheses.') ) ) ) ), 'value' => $defaults->user_filter ) ); $this->addElement( 'text', 'user_name_attribute', array( 'preserveDefault' => true, 'ignore' => $disabled, 'disabled' => $disabled, 'label' => $this->translate('LDAP User Name Attribute'), 'description' => $this->translate( 'The attribute name used for storing a user\'s name on the LDAP server.' ), 'value' => $defaults->user_name_attribute ) ); $this->addElement( 'text', 'user_base_dn', array( 'preserveDefault' => true, 'label' => $this->translate('LDAP User Base DN'), 'description' => $this->translate( 'The path where users can be found on the LDAP server. Leave ' . 'empty to select all users available using the specified connection.' ), 'value' => $defaults->user_base_dn ) ); } /** * Create and add all elements for the user configuration as hidden inputs * * This is required to purge already present options when unlinking a group backend with a user backend. */ protected function createHiddenUserConfigElements() { $this->addElement('hidden', 'user_class', array('disabled' => true)); $this->addElement('hidden', 'user_filter', array('disabled' => true)); $this->addElement('hidden', 'user_name_attribute', array('disabled' => true)); $this->addElement('hidden', 'user_base_dn', array('disabled' => true)); } /** * Return the names of all configured LDAP resources * * @return array */ protected function getLdapResourceNames() { $names = array(); foreach (ResourceFactory::getResourceConfigs() as $name => $config) { if (in_array(strtolower($config->type), array('ldap', 'msldap'))) { $names[] = $name; } } if (empty($names)) { Notification::error( $this->translate('No LDAP resources available. Please configure an LDAP resource first.') ); $this->getResponse()->redirectAndExit('config/createresource'); } return $names; } /** * Return the names of all configured LDAP user backends * * @param LdapConnection $resource * * @return array */ protected function getLdapUserBackendNames(LdapConnection $resource) { $names = array(); foreach (UserBackend::getBackendConfigs() as $name => $config) { if (in_array(strtolower($config->backend), array('ldap', 'msldap'))) { $backendResource = ResourceFactory::create($config->resource); if ( $backendResource->getHostname() === $resource->getHostname() && $backendResource->getPort() === $resource->getPort() ) { $names[] = $name; } } } return $names; } }