You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
150 lines
4.4 KiB
150 lines
4.4 KiB
<?php |
|
/** |
|
* @copyright Copyright (c) 2016, ownCloud, Inc. |
|
* |
|
* @author Arthur Schiwon <blizzz@arthur-schiwon.de> |
|
* @author Joas Schilling <coding@schilljs.com> |
|
* @author Juan Pablo Villafáñez <jvillafanez@solidgear.es> |
|
* @author Lukas Reschke <lukas@statuscode.ch> |
|
* @author Morris Jobke <hey@morrisjobke.de> |
|
* @author Robin Appelman <robin@icewind.nl> |
|
* @author Roeland Jago Douma <roeland@famdouma.nl> |
|
* @author Roger Szabo <roger.szabo@web.de> |
|
* @author Thomas Müller <thomas.mueller@tmit.eu> |
|
* |
|
* @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/> |
|
* |
|
*/ |
|
|
|
// Check user and app status |
|
\OC_JSON::checkAdminUser(); |
|
\OC_JSON::checkAppEnabled('user_ldap'); |
|
\OC_JSON::callCheck(); |
|
|
|
$l = \OC::$server->getL10N('user_ldap'); |
|
|
|
if(!isset($_POST['action'])) { |
|
\OC_JSON::error(array('message' => $l->t('No action specified'))); |
|
} |
|
$action = (string)$_POST['action']; |
|
|
|
|
|
if(!isset($_POST['ldap_serverconfig_chooser'])) { |
|
\OC_JSON::error(array('message' => $l->t('No configuration specified'))); |
|
} |
|
$prefix = (string)$_POST['ldap_serverconfig_chooser']; |
|
|
|
$ldapWrapper = new \OCA\User_LDAP\LDAP(); |
|
$configuration = new \OCA\User_LDAP\Configuration($prefix); |
|
|
|
$con = new \OCA\User_LDAP\Connection($ldapWrapper, $prefix, null); |
|
$con->setConfiguration($configuration->getConfiguration()); |
|
$con->ldapConfigurationActive = true; |
|
$con->setIgnoreValidation(true); |
|
|
|
$userManager = new \OCA\User_LDAP\User\Manager( |
|
\OC::$server->getConfig(), |
|
new \OCA\User_LDAP\FilesystemHelper(), |
|
new \OCA\User_LDAP\LogWrapper(), |
|
\OC::$server->getAvatarManager(), |
|
new \OCP\Image(), |
|
\OC::$server->getDatabaseConnection(), |
|
\OC::$server->getUserManager(), |
|
\OC::$server->getNotificationManager()); |
|
|
|
$access = new \OCA\User_LDAP\Access( |
|
$con, |
|
$ldapWrapper, |
|
$userManager, |
|
new \OCA\User_LDAP\Helper(\OC::$server->getConfig()), |
|
\OC::$server->getConfig(), |
|
\OC::$server->getUserManager() |
|
); |
|
|
|
$wizard = new \OCA\User_LDAP\Wizard($configuration, $ldapWrapper, $access); |
|
|
|
switch($action) { |
|
case 'guessPortAndTLS': |
|
case 'guessBaseDN': |
|
case 'detectEmailAttribute': |
|
case 'detectUserDisplayNameAttribute': |
|
case 'determineGroupMemberAssoc': |
|
case 'determineUserObjectClasses': |
|
case 'determineGroupObjectClasses': |
|
case 'determineGroupsForUsers': |
|
case 'determineGroupsForGroups': |
|
case 'determineAttributes': |
|
case 'getUserListFilter': |
|
case 'getUserLoginFilter': |
|
case 'getGroupFilter': |
|
case 'countUsers': |
|
case 'countGroups': |
|
case 'countInBaseDN': |
|
try { |
|
$result = $wizard->$action(); |
|
if($result !== false) { |
|
\OC_JSON::success($result->getResultArray()); |
|
exit; |
|
} |
|
} catch (\Exception $e) { |
|
\OC_JSON::error(array('message' => $e->getMessage(), 'code' => $e->getCode())); |
|
exit; |
|
} |
|
\OC_JSON::error(); |
|
exit; |
|
break; |
|
|
|
case 'testLoginName': { |
|
try { |
|
$loginName = $_POST['ldap_test_loginname']; |
|
$result = $wizard->$action($loginName); |
|
if($result !== false) { |
|
\OC_JSON::success($result->getResultArray()); |
|
exit; |
|
} |
|
} catch (\Exception $e) { |
|
\OC_JSON::error(array('message' => $e->getMessage())); |
|
exit; |
|
} |
|
\OC_JSON::error(); |
|
exit; |
|
break; |
|
} |
|
|
|
case 'save': |
|
$key = isset($_POST['cfgkey']) ? $_POST['cfgkey'] : false; |
|
$val = isset($_POST['cfgval']) ? $_POST['cfgval'] : null; |
|
if($key === false || is_null($val)) { |
|
\OC_JSON::error(array('message' => $l->t('No data specified'))); |
|
exit; |
|
} |
|
$cfg = array($key => $val); |
|
$setParameters = array(); |
|
$configuration->setConfiguration($cfg, $setParameters); |
|
if(!in_array($key, $setParameters)) { |
|
\OC_JSON::error(array('message' => $l->t($key. |
|
' Could not set configuration %s', $setParameters[0]))); |
|
exit; |
|
} |
|
$configuration->saveConfiguration(); |
|
//clear the cache on save |
|
$connection = new \OCA\User_LDAP\Connection($ldapWrapper, $prefix); |
|
$connection->clearCache(); |
|
\OC_JSON::success(); |
|
break; |
|
default: |
|
\OC_JSON::error(array('message' => $l->t('Action does not exist'))); |
|
break; |
|
}
|
|
|