From 46f7b7096450939fe03c95aa81ce06ae4bfca89d Mon Sep 17 00:00:00 2001 From: Aleksander Machniak <alec@alec.pl> Date: Mon, 28 Mar 2016 06:51:43 -0400 Subject: [PATCH] Enable reply/reply-all/forward buttons also in preview frame of message/rfc822 --- program/lib/Roundcube/rcube_ldap.php | 126 ++++++++++++++++++++++------------------- 1 files changed, 67 insertions(+), 59 deletions(-) diff --git a/program/lib/Roundcube/rcube_ldap.php b/program/lib/Roundcube/rcube_ldap.php index dc7b3c0..b08ee7b 100644 --- a/program/lib/Roundcube/rcube_ldap.php +++ b/program/lib/Roundcube/rcube_ldap.php @@ -1,6 +1,6 @@ <?php -/* +/** +-----------------------------------------------------------------------+ | This file is part of the Roundcube Webmail client | | Copyright (C) 2006-2013, The Roundcube Dev Team | @@ -38,6 +38,7 @@ // private properties protected $ldap; + protected $formats = array(); protected $prop = array(); protected $fieldmap = array(); protected $filter = ''; @@ -45,7 +46,7 @@ protected $result; protected $ldap_result; protected $mail_domain = ''; - protected $debug = false; + protected $debug = false; /** * Group objectclass (lowercase) to member attribute mapping @@ -119,22 +120,38 @@ if (is_array($p['fieldmap'])) { $p['fieldmap'] = array_filter($p['fieldmap']); foreach ($p['fieldmap'] as $rf => $lf) - $this->fieldmap[$rf] = $this->_attr_name(strtolower($lf)); + $this->fieldmap[$rf] = $this->_attr_name($lf); } else if (!empty($p)) { // read deprecated *_field properties to remain backwards compatible foreach ($p as $prop => $value) if (!empty($value) && preg_match('/^(.+)_field$/', $prop, $matches)) - $this->fieldmap[$matches[1]] = $this->_attr_name(strtolower($value)); + $this->fieldmap[$matches[1]] = $this->_attr_name($value); } // use fieldmap to advertise supported coltypes to the application foreach ($this->fieldmap as $colv => $lfv) { list($col, $type) = explode(':', $colv); - list($lf, $limit, $delim) = explode(':', $lfv); + $params = explode(':', $lfv); - if ($limit == '*') $limit = null; - else $limit = max(1, intval($limit)); + $lf = array_shift($params); + $limit = 1; + + foreach ($params as $idx => $param) { + // field format specification + if (preg_match('/^(date)\[(.+)\]$/i', $param, $m)) { + $this->formats[$lf] = array('type' => strtolower($m[1]), 'format' => $m[2]); + } + // first argument is a limit + else if ($idx === 0) { + if ($param == '*') $limit = null; + else $limit = max(1, intval($param)); + } + // second is a composite field separator + else if ($idx === 1 && $param) { + $this->coltypes[$col]['serialized'][$type] = $param; + } + } if (!is_array($this->coltypes[$col])) { $subtypes = $type ? array($type) : null; @@ -146,10 +163,7 @@ $this->coltypes[$col]['limit'] += $limit; } - if ($delim) - $this->coltypes[$col]['serialized'][$type] = $delim; - - $this->fieldmap[$colv] = $lf; + $this->fieldmap[$colv] = $lf; } // support for composite address @@ -195,7 +209,7 @@ } foreach ($this->prop['required_fields'] as $key => $val) { - $this->prop['required_fields'][$key] = $this->_attr_name(strtolower($val)); + $this->prop['required_fields'][$key] = $this->_attr_name($val); } // Build sub_fields filter @@ -239,10 +253,9 @@ $this->_connect(); } - /** - * Establish a connection to the LDAP server - */ + * Establish a connection to the LDAP server + */ private function _connect() { $rcube = rcube::get_instance(); @@ -272,8 +285,7 @@ $bind_dn = $this->prop['bind_dn']; $this->base_dn = $this->prop['base_dn']; - $this->groups_base_dn = ($this->prop['groups']['base_dn']) ? - $this->prop['groups']['base_dn'] : $this->base_dn; + $this->groups_base_dn = $this->prop['groups']['base_dn'] ?: $this->base_dn; // User specific access, generate the proper values to use. if ($this->prop['user_specific']) { @@ -439,7 +451,6 @@ return $this->ready; } - /** * Close connection to LDAP server */ @@ -450,7 +461,6 @@ } } - /** * Returns address book name * @@ -460,7 +470,6 @@ { return $this->prop['name']; } - /** * Set internal list page @@ -484,7 +493,6 @@ $this->ldap->set_vlv_page($this->list_page, $this->page_size); } - /** * Set internal sort settings * @@ -497,7 +505,6 @@ $this->sort_col = $this->coltypes[$sort_col]['attributes'][0]; } - /** * Save a search string for future listings * @@ -507,7 +514,6 @@ { $this->filter = $filter; } - /** * Getter for saved search properties @@ -519,7 +525,6 @@ return $this->filter; } - /** * Reset all saved results and search parameters */ @@ -530,14 +535,13 @@ $this->filter = ''; } - /** * List the current set of contact records * - * @param array List of cols to show - * @param int Only return this number of records + * @param array List of cols to show + * @param int Only return this number of records * - * @return array Indexed list of contact records, each a hash array + * @return array Indexed list of contact records, each a hash array */ function list_records($cols=null, $subset=0) { @@ -672,7 +676,7 @@ $attrib = array_merge($attrib, array_values($this->group_types)); $attrib[] = 'memberURL'; - $filter = $this->prop['groups']['member_filter'] ? $this->prop['groups']['member_filter'] : '(objectclass=*)'; + $filter = $this->prop['groups']['member_filter'] ?: '(objectclass=*)'; for ($i=0; $i < $entry[$attr]['count']; $i++) { if (empty($entry[$attr][$i])) @@ -735,7 +739,6 @@ { return strcmp($a[$this->sort_col][0], $b[$this->sort_col][0]); } - /** * Search contacts @@ -843,13 +846,12 @@ } else { // map address book fields into ldap attributes - $me = $this; $attributes = array(); - array_walk($fields, function($field) use ($me, &$attributes) { - if ($me->coltypes[$field] && ($attrs = (array)$me->coltypes[$field]['attributes'])) { - $attributes = array_merge($attributes, $attrs); + foreach ((array) $fields as $field) { + if ($this->coltypes[$field] && ($attrs = $this->coltypes[$field]['attributes'])) { + $attributes = array_merge($attributes, (array) $attrs); } - }); + } } // compose a full-text-like search filter @@ -892,7 +894,6 @@ return $this->result; } - /** * Count number of available contacts in database * @@ -920,7 +921,6 @@ return new rcube_result_set($count, ($this->list_page-1) * $this->page_size); } - /** * Return the last result set @@ -989,7 +989,6 @@ return $err; } - /** * Check the given data before saving. @@ -1062,15 +1061,17 @@ return true; } - /** * Create a new contact record * - * @param array Hash array with save data + * @param array Associative array with save data + * Keys: Field name with optional section in the form FIELD:SECTION + * Values: Field value. Can be either a string or an array of strings for multiple values + * @param boolean True to check for duplicates first * - * @return encoded record ID on success, False on error + * @return mixed The created record ID on success, False on error */ - function insert($save_cols) + function insert($save_cols, $check = false) { // Map out the column names to their LDAP ones to build the new entry. $newentry = $this->_map_data($save_cols); @@ -1131,7 +1132,6 @@ return $dn; } - /** * Update a specific contact record @@ -1311,9 +1311,8 @@ } } - return $newdn ? $newdn : true; + return $newdn ?: true; } - /** * Mark one or more contact records as deleted @@ -1364,7 +1363,6 @@ return count($ids); } - /** * Remove all contact records * @@ -1373,7 +1371,7 @@ function delete_all($with_groups = false) { // searching for contact entries - $dn_list = $this->ldap->list_entries($this->base_dn, $this->prop['filter'] ? $this->prop['filter'] : '(objectclass=*)'); + $dn_list = $this->ldap->list_entries($this->base_dn, $this->prop['filter'] ?: '(objectclass=*)'); if (!empty($dn_list)) { foreach ($dn_list as $idx => $entry) { @@ -1433,7 +1431,6 @@ } } - /** * Converts LDAP entry into an array */ @@ -1449,7 +1446,7 @@ if ($this->is_group_entry($rec)) { $out['_type'] = 'group'; $out['readonly'] = true; - $fieldmap['name'] = $this->group_data['name_attr'] ? $this->group_data['name_attr'] : $this->prop['groups']['name_attr']; + $fieldmap['name'] = $this->group_data['name_attr'] ?: $this->prop['groups']['name_attr']; } // assign object type from object class mapping @@ -1474,7 +1471,7 @@ if ($col == 'email' && $this->mail_domain && !strpos($value, '@')) $out[$rf][] = sprintf('%s@%s', $value, $this->mail_domain); else if (in_array($col, array('street','zipcode','locality','country','region'))) - $out['address'.($subtype?':':'').$subtype][$i][$col] = $value; + $out['address' . ($subtype ? ':' : '') . $subtype][$i][$col] = $value; else if ($col == 'address' && strpos($value, '$') !== false) // address data is represented as string separated with $ list($out[$rf][$i]['street'], $out[$rf][$i]['locality'], $out[$rf][$i]['zipcode'], $out[$rf][$i]['country']) = explode('$', $value); else if ($rec[$lf]['count'] > 1) @@ -1492,7 +1489,6 @@ return $out; } - /** * Return LDAP attribute(s) for the given field */ @@ -1500,7 +1496,6 @@ { return (array)$this->coltypes[$field]['attributes']; } - /** * Convert a record data set into LDAP field attributes @@ -1554,6 +1549,20 @@ } } + foreach ($this->formats as $fld => $format) { + if (empty($ldap_data[$fld])) { + continue; + } + + switch ($format['type']) { + case 'date': + if ($dt = rcube_utils::anytodatetime($ldap_data[$fld])) { + $ldap_data[$fld] = $dt->format($format['format']); + } + break; + } + } + return $ldap_data; } @@ -1573,6 +1582,7 @@ list($name, $limit) = explode(':', $namev, 2); $suffix = $limit ? ':'.$limit : ''; + $name = strtolower($name); return (isset($aliases[$name]) ? $aliases[$name] : $name) . $suffix; } @@ -1690,7 +1700,7 @@ $filter = $this->prop['groups']['filter']; $scope = $this->prop['groups']['scope']; $name_attr = $this->prop['groups']['name_attr']; - $email_attr = $this->prop['groups']['email_attr'] ? $this->prop['groups']['email_attr'] : 'mail'; + $email_attr = $this->prop['groups']['email_attr'] ?: 'mail'; $sort_attrs = $this->prop['groups']['sort'] ? (array)$this->prop['groups']['sort'] : array($name_attr); $sort_attr = $sort_attrs[0]; @@ -1838,11 +1848,11 @@ $new_dn = 'cn=' . rcube_ldap_generic::quote_string($group_name, true) . ',' . $this->groups_base_dn; $new_gid = self::dn_encode($new_dn); $member_attr = $this->get_group_member_attr(); - $name_attr = $this->prop['groups']['name_attr'] ? $this->prop['groups']['name_attr'] : 'cn'; + $name_attr = $this->prop['groups']['name_attr'] ?: 'cn'; $new_entry = array( 'objectClass' => $this->prop['groups']['object_classes'], - $name_attr => $group_name, - $member_attr => '', + $name_attr => $group_name, + $member_attr => '', ); if (!$this->ldap->add_entry($new_dn, $new_entry)) { @@ -1994,7 +2004,7 @@ $base_dn = $this->groups_base_dn; $contact_dn = self::dn_decode($contact_id); - $name_attr = $this->prop['groups']['name_attr'] ? $this->prop['groups']['name_attr'] : 'cn'; + $name_attr = $this->prop['groups']['name_attr'] ?: 'cn'; $member_attr = $this->get_group_member_attr(); $add_filter = ''; @@ -2043,7 +2053,6 @@ return $default; } - /** * HTML-safe DN string encoding * @@ -2070,5 +2079,4 @@ $str = str_pad(strtr($str, '-_', '+/'), strlen($str) % 4, '=', STR_PAD_RIGHT); return base64_decode($str); } - } -- Gitblit v1.9.1