summaryrefslogtreecommitdiffstats
path: root/apps
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@owncloud.com>2015-05-12 14:45:32 +0200
committerThomas Müller <thomas.mueller@tmit.eu>2015-05-18 18:14:05 +0200
commitcdb068933414657d2e9316cd030279d3529bbd9b (patch)
treef480d42b12325b9cdee783646fd8245e88084dc1 /apps
parent5a563936579110bfa7d333ae8f32121cbc36cc7d (diff)
downloadnextcloud-server-cdb068933414657d2e9316cd030279d3529bbd9b.tar.gz
nextcloud-server-cdb068933414657d2e9316cd030279d3529bbd9b.zip
handle unallowed auth exception on port detection
Diffstat (limited to 'apps')
-rw-r--r--apps/user_ldap/lib/ldap.php2
-rw-r--r--apps/user_ldap/lib/wizard.php24
2 files changed, 20 insertions, 6 deletions
diff --git a/apps/user_ldap/lib/ldap.php b/apps/user_ldap/lib/ldap.php
index 8d2c493a4dc..4d45db2e155 100644
--- a/apps/user_ldap/lib/ldap.php
+++ b/apps/user_ldap/lib/ldap.php
@@ -288,7 +288,7 @@ class LDAP implements ILDAPWrapper {
} else if ($errorCode === -1) {
throw new ServerNotAvailableException('Lost connection to LDAP server.');
} else if ($errorCode === 48) {
- throw new \Exception('LDAP authentication method rejected');
+ throw new \Exception('LDAP authentication method rejected', $errorCode);
} else if ($errorCode === 1) {
throw new \Exception('LDAP Operations error', $errorCode);
} else {
diff --git a/apps/user_ldap/lib/wizard.php b/apps/user_ldap/lib/wizard.php
index 824923eecbf..6c39f406e83 100644
--- a/apps/user_ldap/lib/wizard.php
+++ b/apps/user_ldap/lib/wizard.php
@@ -657,12 +657,26 @@ class Wizard extends LDAPUtility {
\OCP\Util::writeLog('user_ldap', 'Wiz: trying port '. $p . ', TLS '. $t, \OCP\Util::DEBUG);
//connectAndBind may throw Exception, it needs to be catched by the
//callee of this method
- if($this->connectAndBind($p, $t) === true) {
- $config = array('ldapPort' => $p,
- 'ldapTLS' => intval($t)
- );
+
+ // unallowed anonymous bind throws 48. But if it throws 48, we
+ // detected port and TLS, i.e. it is successful.
+ try {
+ $settingsFound = $this->connectAndBind($p, $t);
+ } catch (\Exception $e) {
+ if($e->getCode() === 48) {
+ $settingsFound = true;
+ } else {
+ throw $e;
+ }
+ }
+
+ if ($settingsFound === true) {
+ $config = array(
+ 'ldapPort' => $p,
+ 'ldapTLS' => intval($t)
+ );
$this->configuration->setConfiguration($config);
- \OCP\Util::writeLog('user_ldap', 'Wiz: detected Port '. $p, \OCP\Util::DEBUG);
+ \OCP\Util::writeLog('user_ldap', 'Wiz: detected Port ' . $p, \OCP\Util::DEBUG);
$this->result->addChange('ldap_port', $p);
return $this->result;
}