server/apps/user_ldap/settings.php
Arthur Schiwon 5355c285fc LDAP Wizard Overhaul
wizard refactor

reimplement save spinners and cursor

implement Port detector

introduced detector queue, added base dn detector

disable input fields when detectors are running

introduce spinners for fields that are being updated by detector

cache jq element objects

consolidate processing of detector results in generic / abstract base class

display notification if a detector discovered a problem

don't run base dn detector if a base is configured

reset detector queue on configuration switch

implement functionality check and update of status indicator

document ConfigModel

jsdoc for controller and main view

more documentation

implement the user filter tab view

so far the multiselects get initialized (not filled yet) and the mode can be switched.

mode is also restored.

reintroduce filter switch confirmation in admin XP mode

new detector for user object classes. so we also load user object classes if necessary and are able to save and show the setting.

multiselect trigger save actions now on close only

show spinners automatically, when a detector is running

20k limit for object classes preselection test

adjust wordings, fix grammar

add group (for users tab) detector

also includes wording fixes

error presentation moved from detectors to view, where it belongs

add info label to users page

missing wording changes

show effective LDAP filter in Assisted Mode

add user filter detector

implement count button for users and limit all count actions to 1001 for performance reasons

make port field a bit bigger. not perfect though.

do not detect port automatically

implement login filter tab view

only load features in assisted mode and don't enable assisted fields while in raw mode

add tooltips on login filter checkbox options for better understanding

permanently show filter on login tab

and also compile login filter in assisted mode

test/verify button on login attributes tab, with backend changes.

only run wizard requests if your an active tab. also run compile filter requests when switching to assisted mode

underline toggle filter links to stress that they are clickable

unity user and group tab functionality in common abstract class, add group filter tab view. only detectors and template adjustments left to have group tab implementation complete

add object class and group detector for groups as well as filter composer

show ldap filter permanently on groups tab

introduce input element that can deal better with many groups, will be used with > 40

fix disabling complex group chooser while detection is running

hide complex group chooser on config switch

fix few more issues with complex chooser

make complex group chooser available on Users tab as well

detect base dn improvements/changes:

- do not look for Base DN automatically, offer a button instead
- fix for alternative way to detect a base dn (if agent dn is not given)
- do not trigger filter composers on config switch

Changes with configuration chooser controls

- "New" was removed out of the configuration list
- and split into buttons "add" and "copy"
- delete button is also now an icon

add test button for Base DN

reimplement advanced tab. The save button is gone.

reimplement expert tab

remove unused methods

implement mail attribute detector

implement user display name attribute detection

implement member group association detector

replace text input with textarea for raw filter input

finish functionality check

auto-enable good configurations, as it was before

cleanup

move save confirmation handling to base class, reduces code duplication

enable tabs only if no running save processes are left.

move onConfigLoaded to base class, avoids code duplication

simplify, save LOCs

Test Configuration button to be dealt with in main view as it is a cross-tab element

require detectorQueue in constructor

cleanup

put bootstrap into a function and thus make it testable

get rid of old stuff
2015-04-09 09:47:49 +02:00

123 lines
No EOL
5.6 KiB
PHP

<?php
/**
* @author Arthur Schiwon <blizzz@owncloud.com>
* @author ben-denham <bend@catalyst.net.nz>
* @author Dominik Schmidt <dev@dominik-schmidt.de>
* @author Frank Karlitschek <frank@owncloud.org>
* @author Lukas Reschke <lukas@owncloud.com>
* @author Morris Jobke <hey@morrisjobke.de>
* @author Robin Appelman <icewind@owncloud.com>
* @author Robin McCorkell <rmccorkell@karoshi.org.uk>
* @author Volkan Gezer <volkangezer@gmail.com>
*
* @copyright Copyright (c) 2015, ownCloud, Inc.
* @license AGPL-3.0
*
* This code is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License, version 3,
* as published by the Free Software Foundation.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License, version 3,
* along with this program. If not, see <http://www.gnu.org/licenses/>
*
*/
OC_Util::checkAdminUser();
\OC_Util::addVendorScript('user_ldap', 'ui-multiselect/src/jquery.multiselect');
\OC_Util::addVendorStyle('user_ldap', 'ui-multiselect/jquery.multiselect');
\OCP\Util::addScript('user_ldap', 'wizard/controller');
\OCP\Util::addScript('user_ldap', 'wizard/configModel');
\OCP\Util::addScript('user_ldap', 'wizard/view');
\OCP\Util::addScript('user_ldap', 'wizard/wizardObject');
\OCP\Util::addScript('user_ldap', 'wizard/wizardTabGeneric');
\OCP\Util::addScript('user_ldap', 'wizard/wizardTabElementary');
\OCP\Util::addScript('user_ldap', 'wizard/wizardTabAbstractFilter');
\OCP\Util::addScript('user_ldap', 'wizard/wizardTabUserFilter');
\OCP\Util::addScript('user_ldap', 'wizard/wizardTabLoginFilter');
\OCP\Util::addScript('user_ldap', 'wizard/wizardTabGroupFilter');
\OCP\Util::addScript('user_ldap', 'wizard/wizardTabAdvanced');
\OCP\Util::addScript('user_ldap', 'wizard/wizardTabExpert');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorQueue');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorGeneric');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorPort');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorBaseDN');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorFeatureAbstract');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorUserObjectClasses');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorGroupObjectClasses');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorGroupsForUsers');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorGroupsForGroups');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorSimpleRequestAbstract');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorFilterUser');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorFilterLogin');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorFilterGroup');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorUserCount');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorGroupCount');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorEmailAttribute');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorUserDisplayNameAttribute');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorUserGroupAssociation');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorAvailableAttributes');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorTestAbstract');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorTestLoginName');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorTestBaseDN');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorTestConfiguration');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorClearUserMappings');
\OCP\Util::addScript('user_ldap', 'wizard/wizardDetectorClearGroupMappings');
\OCP\Util::addScript('user_ldap', 'wizard/wizardFilterOnType');
\OCP\Util::addScript('user_ldap', 'wizard/wizardFilterOnTypeFactory');
\OCP\Util::addScript('user_ldap', 'wizard/wizard');
OCP\Util::addStyle('user_ldap', 'settings');
// fill template
$tmpl = new OCP\Template('user_ldap', 'settings');
$helper = new \OCA\user_ldap\lib\Helper();
$prefixes = $helper->getServerConfigurationPrefixes();
$hosts = $helper->getServerConfigurationHosts();
$wizardHtml = '';
$toc = array();
$wControls = new OCP\Template('user_ldap', 'part.wizardcontrols');
$wControls = $wControls->fetchPage();
$sControls = new OCP\Template('user_ldap', 'part.settingcontrols');
$sControls = $sControls->fetchPage();
$l = \OC::$server->getL10N('user_ldap');
$wizTabs = array();
$wizTabs[] = array('tpl' => 'part.wizard-server', 'cap' => $l->t('Server'));
$wizTabs[] = array('tpl' => 'part.wizard-userfilter', 'cap' => $l->t('Users'));
$wizTabs[] = array('tpl' => 'part.wizard-loginfilter', 'cap' => $l->t('Login Attributes'));
$wizTabs[] = array('tpl' => 'part.wizard-groupfilter', 'cap' => $l->t('Groups'));
$wizTabsCount = count($wizTabs);
for($i = 0; $i < $wizTabsCount; $i++) {
$tab = new OCP\Template('user_ldap', $wizTabs[$i]['tpl']);
if($i === 0) {
$tab->assign('serverConfigurationPrefixes', $prefixes);
$tab->assign('serverConfigurationHosts', $hosts);
}
$tab->assign('wizardControls', $wControls);
$wizardHtml .= $tab->fetchPage();
$toc['#ldapWizard'.($i+1)] = $wizTabs[$i]['cap'];
}
$tmpl->assign('tabs', $wizardHtml);
$tmpl->assign('toc', $toc);
$tmpl->assign('settingControls', $sControls);
// assign default values
$config = new \OCA\user_ldap\lib\Configuration('', false);
$defaults = $config->getDefaults();
foreach($defaults as $key => $default) {
$tmpl->assign($key.'_default', $default);
}
return $tmpl->fetchPage();