summaryrefslogtreecommitdiffstats
path: root/apps/user_ldap
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@arthur-schiwon.de>2018-11-05 18:35:50 +0100
committerArthur Schiwon <blizzz@arthur-schiwon.de>2018-11-07 13:15:55 +0100
commitdeec5a70a00ac930d67c439c99a1a3fbf09af9ac (patch)
treefc6c794c1fe4f262823ccd0c75a4508db29c06bf /apps/user_ldap
parent9ea65734162191b3222ea9f6e265380ea5175f3a (diff)
downloadnextcloud-server-deec5a70a00ac930d67c439c99a1a3fbf09af9ac.tar.gz
nextcloud-server-deec5a70a00ac930d67c439c99a1a3fbf09af9ac.zip
avoid logging of "Partial search results returned: Sizelimit exceeded at"
LDAP servers respond with that even if a limit was passed with the request. Having this statement logged causes a lot of confusion. Signed-off-by: Arthur Schiwon <blizzz@arthur-schiwon.de>
Diffstat (limited to 'apps/user_ldap')
-rw-r--r--apps/user_ldap/lib/LDAP.php18
-rw-r--r--apps/user_ldap/tests/LDAPTest.php40
2 files changed, 57 insertions, 1 deletions
diff --git a/apps/user_ldap/lib/LDAP.php b/apps/user_ldap/lib/LDAP.php
index 2411b8d3438..e6039c77d12 100644
--- a/apps/user_ldap/lib/LDAP.php
+++ b/apps/user_ldap/lib/LDAP.php
@@ -189,9 +189,24 @@ class LDAP implements ILDAPWrapper {
* @param int $attrsOnly
* @param int $limit
* @return mixed
+ * @throws \Exception
*/
public function search($link, $baseDN, $filter, $attr, $attrsOnly = 0, $limit = 0) {
- return $this->invokeLDAPMethod('search', $link, $baseDN, $filter, $attr, $attrsOnly, $limit);
+ $oldHandler = set_error_handler(function($no, $message, $file, $line) use (&$oldHandler) {
+ if(strpos($message, 'Partial search results returned: Sizelimit exceeded') !== false) {
+ return true;
+ }
+ $oldHandler($no, $message, $file, $line);
+ return true;
+ });
+ try {
+ $result = $this->invokeLDAPMethod('search', $link, $baseDN, $filter, $attr, $attrsOnly, $limit);
+ restore_error_handler();
+ return $result;
+ } catch (\Exception $e) {
+ restore_error_handler();
+ throw $e;
+ }
}
/**
@@ -342,6 +357,7 @@ class LDAP implements ILDAPWrapper {
/**
* Called after an ldap method is run to act on LDAP error if necessary
+ * @throw \Exception
*/
private function postFunctionCall() {
if($this->isResource($this->curArgs[0])) {
diff --git a/apps/user_ldap/tests/LDAPTest.php b/apps/user_ldap/tests/LDAPTest.php
index 8e181741b50..3e754dbd272 100644
--- a/apps/user_ldap/tests/LDAPTest.php
+++ b/apps/user_ldap/tests/LDAPTest.php
@@ -37,6 +37,46 @@ class LDAPTest extends TestCase {
->getMock();
}
+ public function errorProvider() {
+ return [
+ [
+ 'ldap_search(): Partial search results returned: Sizelimit exceeded at /srv/http/nextcloud/master/apps/user_ldap/lib/LDAP.php#292',
+ false
+ ],
+ [
+ 'Some other error', true
+ ]
+ ];
+ }
+
+ /**
+ * @param string $errorMessage
+ * @param bool $passThrough
+ * @dataProvider errorProvider
+ */
+ public function testSearchWithErrorHandler(string $errorMessage, bool $passThrough) {
+
+ $wasErrorHandlerCalled = false;
+ $errorHandler = function($number, $message, $file, $line) use (&$wasErrorHandlerCalled) {
+ $wasErrorHandlerCalled = true;
+ };
+
+ set_error_handler($errorHandler);
+
+ $this->ldap
+ ->expects($this->once())
+ ->method('invokeLDAPMethod')
+ ->with('search', $this->anything(), $this->anything(), $this->anything(), $this->anything(), $this->anything())
+ ->willReturnCallback(function() use($errorMessage) {
+ trigger_error($errorMessage);
+ });
+
+ $this->ldap->search('pseudo-resource', 'base', 'filter', []);
+ $this->assertSame($wasErrorHandlerCalled, $passThrough);
+
+ restore_error_handler();
+ }
+
public function testModReplace() {
$link = $this->createMock(LDAP::class);
$userDN = 'CN=user';