|
|
@ -550,7 +550,8 @@ class rcube_ldap extends rcube_addressbook |
|
|
|
|
|
|
|
// fetch group object
|
|
|
|
if (empty($entries)) { |
|
|
|
$entries = $this->ldap->read_entries($dn, '(objectClass=*)', array('dn','objectClass','member','uniqueMember','memberURL')); |
|
|
|
$attribs = array('dn','objectClass','member','uniqueMember','memberURL'); |
|
|
|
$entries = $this->ldap->read_entries($dn, '(objectClass=*)', $attribs); |
|
|
|
if ($entries === false) { |
|
|
|
return $group_members; |
|
|
|
} |
|
|
@ -558,29 +559,25 @@ class rcube_ldap extends rcube_addressbook |
|
|
|
|
|
|
|
for ($i=0; $i < $entries['count']; $i++) { |
|
|
|
$entry = $entries[$i]; |
|
|
|
|
|
|
|
if (empty($entry['objectclass'])) |
|
|
|
continue; |
|
|
|
$attrs = array(); |
|
|
|
|
|
|
|
foreach ((array)$entry['objectclass'] as $objectclass) { |
|
|
|
switch (strtolower($objectclass)) { |
|
|
|
case "group": |
|
|
|
case "groupofnames": |
|
|
|
case "kolabgroupofnames": |
|
|
|
$group_members = array_merge($group_members, $this->_list_group_members($dn, $entry, 'member', $count)); |
|
|
|
break; |
|
|
|
case "groupofuniquenames": |
|
|
|
case "kolabgroupofuniquenames": |
|
|
|
$group_members = array_merge($group_members, $this->_list_group_members($dn, $entry, 'uniquemember', $count)); |
|
|
|
break; |
|
|
|
case "groupofurls": |
|
|
|
$group_members = array_merge($group_members, $this->_list_group_memberurl($dn, $entry, $count)); |
|
|
|
break; |
|
|
|
if (strtolower($objectclass) == 'groupofurls') { |
|
|
|
$members = $this->_list_group_memberurl($dn, $entry, $count); |
|
|
|
$group_members = array_merge($group_members, $members); |
|
|
|
} |
|
|
|
else if (($member_attr = $this->get_group_member_attr(array($objectclass), '')) |
|
|
|
&& ($member_attr = strtolower($member_attr)) && !in_array($member_attr, $attrs) |
|
|
|
) { |
|
|
|
$members = $this->_list_group_members($dn, $entry, $member_attr, $count); |
|
|
|
$group_members = array_merge($group_members, $members); |
|
|
|
$attrs[] = $member_attr; |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if ($this->prop['sizelimit'] && count($group_members) > $this->prop['sizelimit']) |
|
|
|
break; |
|
|
|
if ($this->prop['sizelimit'] && count($group_members) > $this->prop['sizelimit']) { |
|
|
|
break 2; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
return array_filter($group_members); |
|
|
@ -599,8 +596,9 @@ class rcube_ldap extends rcube_addressbook |
|
|
|
// Use the member attributes to return an array of member ldap objects
|
|
|
|
// NOTE that the member attribute is supposed to contain a DN
|
|
|
|
$group_members = array(); |
|
|
|
if (empty($entry[$attr])) |
|
|
|
if (empty($entry[$attr])) { |
|
|
|
return $group_members; |
|
|
|
} |
|
|
|
|
|
|
|
// read these attributes for all members
|
|
|
|
$attrib = $count ? array('dn','objectClass') : $this->prop['list_attributes']; |
|
|
@ -1466,7 +1464,8 @@ class rcube_ldap extends rcube_addressbook |
|
|
|
private static function is_group_entry($entry) |
|
|
|
{ |
|
|
|
return array_intersect( |
|
|
|
array('group', 'groupofnames', 'kolabgroupofnames', 'groupofuniquenames','kolabgroupofuniquenames','groupofurls'), |
|
|
|
array('group', 'groupofnames', 'kolabgroupofnames', 'groupofuniquenames', |
|
|
|
'kolabgroupofuniquenames', 'groupofurls', 'univentiongroup'), |
|
|
|
array_map('strtolower', (array)$entry['objectclass']) |
|
|
|
); |
|
|
|
} |
|
|
@ -1888,37 +1887,33 @@ class rcube_ldap extends rcube_addressbook |
|
|
|
/** |
|
|
|
* Detects group member attribute name |
|
|
|
*/ |
|
|
|
private function get_group_member_attr($object_classes = array()) |
|
|
|
private function get_group_member_attr($object_classes = array(), $default = 'member') |
|
|
|
{ |
|
|
|
if (empty($object_classes)) { |
|
|
|
$object_classes = $this->prop['groups']['object_classes']; |
|
|
|
} |
|
|
|
|
|
|
|
if (!empty($object_classes)) { |
|
|
|
foreach ((array)$object_classes as $oc) { |
|
|
|
switch (strtolower($oc)) { |
|
|
|
case 'group': |
|
|
|
case 'groupofnames': |
|
|
|
case 'kolabgroupofnames': |
|
|
|
$member_attr = 'member'; |
|
|
|
break; |
|
|
|
return 'member'; |
|
|
|
|
|
|
|
case 'groupofuniquenames': |
|
|
|
case 'kolabgroupofuniquenames': |
|
|
|
$member_attr = 'uniqueMember'; |
|
|
|
break; |
|
|
|
case 'univentiongroup': |
|
|
|
return 'uniqueMember'; |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
if (!empty($member_attr)) { |
|
|
|
return $member_attr; |
|
|
|
} |
|
|
|
|
|
|
|
if (!empty($this->prop['groups']['member_attr'])) { |
|
|
|
return $this->prop['groups']['member_attr']; |
|
|
|
} |
|
|
|
|
|
|
|
return 'member'; |
|
|
|
return $default; |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|