mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-18 20:08:34 +01:00
fix not generally not working display multiple groups in status and also not displayed avatar pictures in that case
This commit is contained in:
parent
f313f07cdb
commit
28f9f15d0d
@ -374,6 +374,10 @@ class admin_ui
|
|||||||
$params['query'] = $query['search'];
|
$params['query'] = $query['search'];
|
||||||
$params['query_type'] = 'all';
|
$params['query_type'] = 'all';
|
||||||
}
|
}
|
||||||
|
if (!empty($query['account_id']))
|
||||||
|
{
|
||||||
|
$params['account_id'] = (array)$query['account_id'];
|
||||||
|
}
|
||||||
|
|
||||||
$rows = array_values(self::$accounts->search($params));
|
$rows = array_values(self::$accounts->search($params));
|
||||||
//error_log(__METHOD__."() accounts->search(".array2string($params).") total=".self::$accounts->total);
|
//error_log(__METHOD__."() accounts->search(".array2string($params).") total=".self::$accounts->total);
|
||||||
|
@ -187,6 +187,7 @@ class Accounts
|
|||||||
{
|
{
|
||||||
// normalize our cache-key by not storing anything, plus adding default the default sort (if none requested)
|
// normalize our cache-key by not storing anything, plus adding default the default sort (if none requested)
|
||||||
$keys = array_filter($params)+['order' => 'account_lid', 'sort' => 'ASC'];
|
$keys = array_filter($params)+['order' => 'account_lid', 'sort' => 'ASC'];
|
||||||
|
if (isset($keys['account_id'])) $keys['account_id'] = md5(json_encode($keys['account_id']));
|
||||||
// sort keys
|
// sort keys
|
||||||
ksort($keys);
|
ksort($keys);
|
||||||
$key = json_encode($keys);
|
$key = json_encode($keys);
|
||||||
@ -221,6 +222,7 @@ class Accounts
|
|||||||
* 'lid','firstname','lastname','email' - query only the given field for containing $param[query]
|
* 'lid','firstname','lastname','email' - query only the given field for containing $param[query]
|
||||||
* @param $param['app'] string with an app-name, to limit result on accounts with run-right for that app
|
* @param $param['app'] string with an app-name, to limit result on accounts with run-right for that app
|
||||||
* @param $param['active']=true boolean - true: return only acctive accounts, false: return expired or deactivated too
|
* @param $param['active']=true boolean - true: return only acctive accounts, false: return expired or deactivated too
|
||||||
|
* @param $param['account_id'] int[] return only given account_id's
|
||||||
* @return array with account_id => data pairs, data is an array with account_id, account_lid, account_firstname,
|
* @return array with account_id => data pairs, data is an array with account_id, account_lid, account_firstname,
|
||||||
* account_lastname, person_id (id of the linked addressbook entry), account_status, account_expires, account_primary_group
|
* account_lastname, person_id (id of the linked addressbook entry), account_status, account_expires, account_primary_group
|
||||||
*/
|
*/
|
||||||
|
@ -918,6 +918,7 @@ class Ads
|
|||||||
* @param $param['objectclass'] boolean return objectclass(es) under key 'objectclass' in each account
|
* @param $param['objectclass'] boolean return objectclass(es) under key 'objectclass' in each account
|
||||||
* @param $param['active'] boolean true: only return active / not expired accounts
|
* @param $param['active'] boolean true: only return active / not expired accounts
|
||||||
* @param $param['modified'] int if given minimum modification time
|
* @param $param['modified'] int if given minimum modification time
|
||||||
|
* @param $param['account_id'] int[] return only given account_id's
|
||||||
* @return array with account_id => data pairs, data is an array with account_id, account_lid, account_firstname,
|
* @return array with account_id => data pairs, data is an array with account_id, account_lid, account_firstname,
|
||||||
* account_lastname, person_id (id of the linked addressbook entry), account_status, account_expires, account_primary_group
|
* account_lastname, person_id (id of the linked addressbook entry), account_status, account_expires, account_primary_group
|
||||||
*/
|
*/
|
||||||
@ -967,6 +968,11 @@ class Ads
|
|||||||
$membership_filter = '(|(memberOf='.$this->id2name((int)$param['type'], 'account_dn').')(PrimaryGroupId='.abs($param['type']).'))';
|
$membership_filter = '(|(memberOf='.$this->id2name((int)$param['type'], 'account_dn').')(PrimaryGroupId='.abs($param['type']).'))';
|
||||||
$filter = $filter ? "(&$membership_filter$filter)" : $membership_filter;
|
$filter = $filter ? "(&$membership_filter$filter)" : $membership_filter;
|
||||||
}
|
}
|
||||||
|
if (!empty($param['account_id']))
|
||||||
|
{
|
||||||
|
$account_ids_filter = '(|(objectsid='.implode(')(objectsid=', array_map([$this, 'get_sid'], $param['account_id'])).')';
|
||||||
|
$filter = $filter ? "(&$filter$account_ids_filter)" : $account_ids_filter;
|
||||||
|
}
|
||||||
if (!empty($param['modified']))
|
if (!empty($param['modified']))
|
||||||
{
|
{
|
||||||
$filter = "(&(whenChanged>=".gmdate('YmdHis', $param['modified']).".0Z)$filter)";
|
$filter = "(&(whenChanged>=".gmdate('YmdHis', $param['modified']).".0Z)$filter)";
|
||||||
|
@ -731,6 +731,7 @@ class Ldap
|
|||||||
* @param $param['offset'] int - number of matches to return if start given, default use the value in the prefs
|
* @param $param['offset'] int - number of matches to return if start given, default use the value in the prefs
|
||||||
* @param $param['objectclass'] boolean return objectclass(es) under key 'objectclass' in each account
|
* @param $param['objectclass'] boolean return objectclass(es) under key 'objectclass' in each account
|
||||||
* @param $param['modified'] int if given minimum modification time
|
* @param $param['modified'] int if given minimum modification time
|
||||||
|
* @param $param['account_id'] int[] return only given account_id's
|
||||||
* @return array with account_id => data pairs, data is an array with account_id, account_lid, account_firstname,
|
* @return array with account_id => data pairs, data is an array with account_id, account_lid, account_firstname,
|
||||||
* account_lastname, person_id (id of the linked addressbook entry), account_status, account_expires, account_primary_group
|
* account_lastname, person_id (id of the linked addressbook entry), account_status, account_expires, account_primary_group
|
||||||
*/
|
*/
|
||||||
@ -812,6 +813,11 @@ class Ldap
|
|||||||
$filter .= '(uidNumber=0)'; // to NOT find any user
|
$filter .= '(uidNumber=0)'; // to NOT find any user
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// only return given account_id's
|
||||||
|
if (!empty($param['account_id']))
|
||||||
|
{
|
||||||
|
$filter .= '(|(uidNumber=' . implode(')(uidNumber=', $param['account_id']) . '))';
|
||||||
|
}
|
||||||
if (!empty($param['modified']))
|
if (!empty($param['modified']))
|
||||||
{
|
{
|
||||||
$filter .= "(modifytimestamp>=".gmdate('YmdHis', $param['modified']).".0Z)";
|
$filter .= "(modifytimestamp>=".gmdate('YmdHis', $param['modified']).".0Z)";
|
||||||
|
@ -424,6 +424,7 @@ class Sql
|
|||||||
* 'lid','firstname','lastname','email' - query only the given field for containing $param[query]
|
* 'lid','firstname','lastname','email' - query only the given field for containing $param[query]
|
||||||
* @param $param['offset'] int - number of matches to return if start given, default use the value in the prefs
|
* @param $param['offset'] int - number of matches to return if start given, default use the value in the prefs
|
||||||
* @param $param['objectclass'] boolean return objectclass(es) under key 'objectclass' in each account
|
* @param $param['objectclass'] boolean return objectclass(es) under key 'objectclass' in each account
|
||||||
|
* @param $param['account_id'] int[] return only given account_id's
|
||||||
* @return array with account_id => data pairs, data is an array with account_id, account_lid, account_firstname,
|
* @return array with account_id => data pairs, data is an array with account_id, account_lid, account_firstname,
|
||||||
* account_lastname, person_id (id of the linked addressbook entry), account_status, account_expires, account_primary_group
|
* account_lastname, person_id (id of the linked addressbook entry), account_status, account_expires, account_primary_group
|
||||||
*/
|
*/
|
||||||
@ -443,7 +444,7 @@ class Sql
|
|||||||
}
|
}
|
||||||
$order = str_replace(array_keys($order2contact),array_values($order2contact),$param['order'] ?? '');
|
$order = str_replace(array_keys($order2contact),array_values($order2contact),$param['order'] ?? '');
|
||||||
|
|
||||||
// allways add 'account_lid'
|
// always add 'account_lid'
|
||||||
if (strpos($order, 'account_lid') === false)
|
if (strpos($order, 'account_lid') === false)
|
||||||
{
|
{
|
||||||
$order .= ($order?',':'').'account_lid';
|
$order .= ($order?',':'').'account_lid';
|
||||||
@ -465,7 +466,7 @@ class Sql
|
|||||||
$join .= ' LEFT JOIN '.Api\Mail\Smtp\Sql::TABLE.' ON '.$this->table.'.account_id=-'.Api\Mail\Smtp\Sql::TABLE.'.account_id AND mail_type='.Api\Mail\Smtp\Sql::TYPE_ALIAS;
|
$join .= ' LEFT JOIN '.Api\Mail\Smtp\Sql::TABLE.' ON '.$this->table.'.account_id=-'.Api\Mail\Smtp\Sql::TABLE.'.account_id AND mail_type='.Api\Mail\Smtp\Sql::TYPE_ALIAS;
|
||||||
}
|
}
|
||||||
|
|
||||||
$filter = array();
|
$filter = empty($param['account_id']) ? [] : ['account_id' => (array)$param['account_id']];
|
||||||
switch($param['type'])
|
switch($param['type'])
|
||||||
{
|
{
|
||||||
case 'accounts':
|
case 'accounts':
|
||||||
@ -487,7 +488,7 @@ class Sql
|
|||||||
$members = array_unique(array_merge($members, array_keys((array)$this->members($grp))));
|
$members = array_unique(array_merge($members, array_keys((array)$this->members($grp))));
|
||||||
if ($param['type'] == 'groupmembers+memberships') $members[] = abs($grp);
|
if ($param['type'] == 'groupmembers+memberships') $members[] = abs($grp);
|
||||||
}
|
}
|
||||||
$filter['account_id'] = $members;
|
$filter['account_id'] = empty($filter['account_id']) ? $members : array_merge($members, $filter['account_id']);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (is_numeric($param['type']))
|
if (is_numeric($param['type']))
|
||||||
|
Loading…
Reference in New Issue
Block a user