mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-09 07:28:43 +01:00
"fixed not working limited result and sorting for type 'both', caused by an (now disabled) optimisation, which only works for type 'accounts'"
This commit is contained in:
parent
9284452553
commit
6aebe8485b
@ -693,6 +693,8 @@ class accounts_ldap
|
|||||||
$filter = str_replace(array('%user','%domain'),array('*',$GLOBALS['egw_info']['user']['domain']),$filter);
|
$filter = str_replace(array('%user','%domain'),array('*',$GLOBALS['egw_info']['user']['domain']),$filter);
|
||||||
$filter .= ')';
|
$filter .= ')';
|
||||||
|
|
||||||
|
if ($param['type'] != 'both')
|
||||||
|
{
|
||||||
// folw:
|
// folw:
|
||||||
// - first query only few attributes for sorting and throwing away not needed results
|
// - first query only few attributes for sorting and throwing away not needed results
|
||||||
// - throw away & sort
|
// - throw away & sort
|
||||||
@ -703,9 +705,11 @@ class accounts_ldap
|
|||||||
'account_lid' => 'uid',
|
'account_lid' => 'uid',
|
||||||
'account_firstname' => 'givenname',
|
'account_firstname' => 'givenname',
|
||||||
'account_lastname' => 'sn',
|
'account_lastname' => 'sn',
|
||||||
'account_email' => 'email'
|
'account_email' => 'email',
|
||||||
|
'account_fullname' => 'cn',
|
||||||
);
|
);
|
||||||
$order = $propertyMap[$param['order']] ? $propertyMap[$param['order']] : 'uid';
|
$orders = explode(',',$param['order']);
|
||||||
|
$order = isset($propertyMap[$orders[0]]) ? $propertyMap[$orders[0]] : 'uid';
|
||||||
$sri = ldap_search($this->ds, $this->user_context, $filter,array('uid', $order));
|
$sri = ldap_search($this->ds, $this->user_context, $filter,array('uid', $order));
|
||||||
$fullSet = array();
|
$fullSet = array();
|
||||||
foreach ((array)ldap_get_entries($this->ds, $sri) as $key => $entry)
|
foreach ((array)ldap_get_entries($this->ds, $sri) as $key => $entry)
|
||||||
@ -729,33 +733,20 @@ class accounts_ldap
|
|||||||
$sortFn = $param['sort'] == 'DESC' ? 'arsort' : 'asort';
|
$sortFn = $param['sort'] == 'DESC' ? 'arsort' : 'asort';
|
||||||
$sortFn($fullSet);
|
$sortFn($fullSet);
|
||||||
$relevantAccounts = is_numeric($start) ? array_slice(array_keys($fullSet), $start, $offset) : array_keys($fullSet);
|
$relevantAccounts = is_numeric($start) ? array_slice(array_keys($fullSet), $start, $offset) : array_keys($fullSet);
|
||||||
// if we do not have a start, or want the members of a certain group, we want all, that way we dont want to or the uids
|
$filter = '(&(objectclass=posixaccount)(|(uid='.implode(')(uid=',$relevantAccounts).'))' . $this->account_filter.')';
|
||||||
// since if we have a whole lot of members, it slows the query down
|
|
||||||
// if you work with very big groups, it may present a problem
|
|
||||||
if (is_numeric($start) || is_numeric($param['type']))
|
|
||||||
{
|
|
||||||
$filter = "(" . "&(objectclass=posixaccount)" . '(|(uid='.implode(')(uid=',$relevantAccounts).'))' . $this->account_filter . ")";
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$filter = "(" . "&(objectclass=posixaccount)" . $this->account_filter . ")";
|
|
||||||
}
|
|
||||||
|
|
||||||
$filter = "(" . "&(objectclass=posixaccount)" . '(|(uid='.implode(')(uid=',$relevantAccounts).'))' . $this->account_filter . ")";
|
|
||||||
$filter = str_replace(array('%user','%domain'),array('*',$GLOBALS['egw_info']['user']['domain']),$filter);
|
$filter = str_replace(array('%user','%domain'),array('*',$GLOBALS['egw_info']['user']['domain']),$filter);
|
||||||
|
}
|
||||||
$sri = ldap_search($this->ds, $this->user_context, $filter,array('uid','uidNumber','givenname','sn','mail','shadowExpire','createtimestamp','modifytimestamp'));
|
$sri = ldap_search($this->ds, $this->user_context, $filter,array('uid','uidNumber','givenname','sn','mail','shadowExpire','createtimestamp','modifytimestamp'));
|
||||||
//echo "<p>ldap_search(,$this->user_context,'$filter',) ".($sri ? '' : ldap_error($this->ds)).microtime()."</p>\n";
|
//echo "<p>ldap_search(,$this->user_context,'$filter',) ".($sri ? '' : ldap_error($this->ds)).microtime()."</p>\n";
|
||||||
$allValues = ldap_get_entries($this->ds, $sri);
|
|
||||||
|
|
||||||
$utc_diff = date('Z');
|
$utc_diff = date('Z');
|
||||||
while (list($null,$allVals) = @each($allValues))
|
foreach(ldap_get_entries($this->ds, $sri) as $allVals)
|
||||||
{
|
{
|
||||||
settype($allVals,'array');
|
settype($allVals,'array');
|
||||||
$test = @$allVals['uid'][0];
|
$test = @$allVals['uid'][0];
|
||||||
if (!$this->frontend->config['global_denied_users'][$test] && $allVals['uid'][0])
|
if (!$this->frontend->config['global_denied_users'][$test] && $allVals['uid'][0])
|
||||||
{
|
{
|
||||||
$accounts[$allVals['uidnumber'][0]] = Array(
|
$account = Array(
|
||||||
'account_id' => $allVals['uidnumber'][0],
|
'account_id' => $allVals['uidnumber'][0],
|
||||||
'account_lid' => translation::convert($allVals['uid'][0],'utf-8'),
|
'account_lid' => translation::convert($allVals['uid'][0],'utf-8'),
|
||||||
'account_type' => 'u',
|
'account_type' => 'u',
|
||||||
@ -765,8 +756,9 @@ class accounts_ldap
|
|||||||
'account_email' => $allVals['mail'][0],
|
'account_email' => $allVals['mail'][0],
|
||||||
'account_created' => isset($allVals['createtimestamp'][0]) ? self::accounts_ldap2ts($allVals['createtimestamp'][0]) : null,
|
'account_created' => isset($allVals['createtimestamp'][0]) ? self::accounts_ldap2ts($allVals['createtimestamp'][0]) : null,
|
||||||
'account_modified' => isset($allVals['modifytimestamp'][0]) ? self::accounts_ldap2ts($allVals['modifytimestamp'][0]) : null,
|
'account_modified' => isset($allVals['modifytimestamp'][0]) ? self::accounts_ldap2ts($allVals['modifytimestamp'][0]) : null,
|
||||||
|
|
||||||
);
|
);
|
||||||
|
$account['account_fullname'] = common::display_fullname($account['account_lid'],$account['account_firstname'],$account['account_lastname']);
|
||||||
|
$accounts[$account['account_id']] = $account;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -793,8 +785,7 @@ class accounts_ldap
|
|||||||
$filter = "(&(objectclass=posixgroup)(cn=$query))";
|
$filter = "(&(objectclass=posixgroup)(cn=$query))";
|
||||||
}
|
}
|
||||||
$sri = ldap_search($this->ds, $this->group_context, $filter,array('cn','gidNumber'));
|
$sri = ldap_search($this->ds, $this->group_context, $filter,array('cn','gidNumber'));
|
||||||
$allValues = ldap_get_entries($this->ds, $sri);
|
foreach((array)ldap_get_entries($this->ds, $sri) as $allVals)
|
||||||
while (list($null,$allVals) = @each($allValues))
|
|
||||||
{
|
{
|
||||||
settype($allVals,'array');
|
settype($allVals,'array');
|
||||||
$test = $allVals['cn'][0];
|
$test = $allVals['cn'][0];
|
||||||
@ -807,7 +798,9 @@ class accounts_ldap
|
|||||||
'account_firstname' => translation::convert($allVals['cn'][0],'utf-8'),
|
'account_firstname' => translation::convert($allVals['cn'][0],'utf-8'),
|
||||||
'account_lastname' => lang('Group'),
|
'account_lastname' => lang('Group'),
|
||||||
'account_status' => 'A',
|
'account_status' => 'A',
|
||||||
|
'account_fullname' => translation::convert($allVals['cn'][0],'utf-8'),
|
||||||
);
|
);
|
||||||
|
if (isset($totalcount)) ++$totalcount;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user