diff options
author | Thomas Bruederli <thomas@roundcube.net> | 2013-06-19 16:22:51 +0200 |
---|---|---|
committer | Thomas Bruederli <thomas@roundcube.net> | 2013-06-19 16:22:51 +0200 |
commit | 8862f67513bac25b1a835ed9ae31bff1bf218ad4 (patch) | |
tree | e21c2d39e40a3d3bd79d24ba1dc896894cc5698f | |
parent | 5a6c3a169bed84d29a17c6c6f87896c42565bf9d (diff) |
Use the right attribute to display group names
-rw-r--r-- | program/lib/Roundcube/rcube_ldap.php | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/program/lib/Roundcube/rcube_ldap.php b/program/lib/Roundcube/rcube_ldap.php index 334cb2465..d286c2da3 100644 --- a/program/lib/Roundcube/rcube_ldap.php +++ b/program/lib/Roundcube/rcube_ldap.php @@ -85,8 +85,13 @@ class rcube_ldap extends rcube_addressbook // add group name attrib to the list of attributes to be fetched $fetch_attributes[] = $this->prop['groups']['name_attr']; } - else if (is_array($p['group_filters']) && count($p['group_filters'])) { + if (is_array($p['group_filters']) && count($p['group_filters'])) { $this->groups = true; + + foreach ($p['group_filters'] as $group_filter) { + if ($group_filter['name_attr']) + $fetch_attributes[] = $group_filter['name_attr']; + } } // fieldmap property is given @@ -198,8 +203,8 @@ class rcube_ldap extends rcube_addressbook $this->cache = $rcube->get_cache($cache_name, $cache_type, $cache_ttl); // determine which attributes to fetch + $this->prop['list_attributes'] = array_unique($fetch_attributes); $this->prop['attributes'] = array_merge(array_values($this->fieldmap), $fetch_attributes); - $this->prop['list_attributes'] = $fetch_attributes; foreach ($rcube->config->get('contactlist_fields') as $col) { $this->prop['list_attributes'] = array_merge($this->prop['list_attributes'], $this->_map_field($col)); } @@ -1334,7 +1339,7 @@ class rcube_ldap extends rcube_addressbook if (self::is_group_entry($rec)) { $out['_type'] = 'group'; $out['readonly'] = true; - $fieldmap['name'] = $this->prop['groups']['name_attr']; + $fieldmap['name'] = $this->group_data['name_attr'] ? $this->group_data['name_attr'] : $this->prop['groups']['name_attr']; } foreach ($fieldmap as $rf => $lf) |