aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorblizzz <blizzz@owncloud.com>2015-03-13 13:16:33 +0100
committerblizzz <blizzz@owncloud.com>2015-03-13 13:16:33 +0100
commitd5e884d6295800d27e046289d713bc27242ecfbb (patch)
tree59b8ed7a4154e8b12d3c904b80a3968f02cba6e8
parentc546f0bf46a51dc297be15aa1acbca5ed9a84de9 (diff)
parentf28f7754aef3c221232dce783daa1a5d061e0cf6 (diff)
downloadnextcloud-server-d5e884d6295800d27e046289d713bc27242ecfbb.tar.gz
nextcloud-server-d5e884d6295800d27e046289d713bc27242ecfbb.zip
Merge pull request #14849 from owncloud/fix-11292
support paged results against 389ds.
-rw-r--r--apps/user_ldap/lib/access.php9
1 files changed, 6 insertions, 3 deletions
diff --git a/apps/user_ldap/lib/access.php b/apps/user_ldap/lib/access.php
index c1b6ebaf1ca..03c667a6a0c 100644
--- a/apps/user_ldap/lib/access.php
+++ b/apps/user_ldap/lib/access.php
@@ -1372,7 +1372,8 @@ class Access extends LDAPUtility implements user\IUserTools {
* @return void
*/
private function setPagedResultCookie($base, $filter, $limit, $offset, $cookie) {
- if(!empty($cookie)) {
+ // allow '0' for 389ds
+ if(!empty($cookie) || $cookie === '0') {
$cacheKey = 'lc' . crc32($base) . '-' . crc32($filter) . '-' .intval($limit) . '-' . intval($offset);
$this->cookies[$cacheKey] = $cookie;
$this->lastCookie = $cookie;
@@ -1410,11 +1411,12 @@ class Access extends LDAPUtility implements user\IUserTools {
foreach($bases as $base) {
$cookie = $this->getPagedResultCookie($base, $filter, $limit, $offset);
- if(empty($cookie) && ($offset > 0)) {
+ if(empty($cookie) && $cookie !== "0" && ($offset > 0)) {
// no cookie known, although the offset is not 0. Maybe cache run out. We need
// to start all over *sigh* (btw, Dear Reader, did you know LDAP paged
// searching was designed by MSFT?)
// Lukas: No, but thanks to reading that source I finally know!
+ // '0' is valid, because 389ds
$reOffset = ($offset - $limit) < 0 ? 0 : $offset - $limit;
//a bit recursive, $offset of 0 is the exit
\OCP\Util::writeLog('user_ldap', 'Looking for cookie L/O '.$limit.'/'.$reOffset, \OCP\Util::INFO);
@@ -1422,7 +1424,8 @@ class Access extends LDAPUtility implements user\IUserTools {
$cookie = $this->getPagedResultCookie($base, $filter, $limit, $offset);
//still no cookie? obviously, the server does not like us. Let's skip paging efforts.
//TODO: remember this, probably does not change in the next request...
- if(empty($cookie)) {
+ if(empty($cookie) && $cookie !== '0') {
+ // '0' is valid, because 389ds
$cookie = null;
}
}