diff options
Diffstat (limited to 'program/lib')
| -rw-r--r-- | program/lib/Roundcube/rcube.php | 4 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_browser.php | 36 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_contacts.php | 8 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_csv2vcard.php | 10 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_db.php | 29 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_imap.php | 9 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_message.php | 14 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_plugin.php | 2 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_plugin_api.php | 5 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_session.php | 45 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_spellchecker.php | 8 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_user.php | 34 | ||||
| -rw-r--r-- | program/lib/Roundcube/rcube_vcard.php | 2 | 
13 files changed, 133 insertions, 73 deletions
| diff --git a/program/lib/Roundcube/rcube.php b/program/lib/Roundcube/rcube.php index 399f84fd8..e0fa22c3c 100644 --- a/program/lib/Roundcube/rcube.php +++ b/program/lib/Roundcube/rcube.php @@ -1537,6 +1537,10 @@ class rcube                      !empty($response) ? join('; ', $response) : ''));              }          } +        else { +            // allow plugins to catch sending errors with the same parameters as in 'message_before_send' +            $this->plugins->exec_hook('message_send_error', $plugin + array('error' => $error)); +        }          if (is_resource($msg_body)) {              fclose($msg_body); diff --git a/program/lib/Roundcube/rcube_browser.php b/program/lib/Roundcube/rcube_browser.php index 34128291b..e53e31200 100644 --- a/program/lib/Roundcube/rcube_browser.php +++ b/program/lib/Roundcube/rcube_browser.php @@ -28,32 +28,24 @@ class rcube_browser      {          $HTTP_USER_AGENT = strtolower($_SERVER['HTTP_USER_AGENT']); -        $this->ver = 0; -        $this->win = strpos($HTTP_USER_AGENT, 'win') != false; -        $this->mac = strpos($HTTP_USER_AGENT, 'mac') != false; +        $this->ver   = 0; +        $this->win   = strpos($HTTP_USER_AGENT, 'win') != false; +        $this->mac   = strpos($HTTP_USER_AGENT, 'mac') != false;          $this->linux = strpos($HTTP_USER_AGENT, 'linux') != false;          $this->unix  = strpos($HTTP_USER_AGENT, 'unix') != false; -        $this->opera = strpos($HTTP_USER_AGENT, 'opera') !== false; -        $this->ns4 = strpos($HTTP_USER_AGENT, 'mozilla/4') !== false && strpos($HTTP_USER_AGENT, 'msie') === false; -        $this->ns  = ($this->ns4 || strpos($HTTP_USER_AGENT, 'netscape') !== false); -        $this->ie  = !$this->opera && strpos($HTTP_USER_AGENT, 'compatible; msie') !== false; -        $this->khtml = strpos($HTTP_USER_AGENT, 'khtml') !== false; -        $this->mz  = !$this->ie && !$this->khtml && strpos($HTTP_USER_AGENT, 'mozilla/5') !== false; +        $this->opera  = strpos($HTTP_USER_AGENT, 'opera') !== false; +        $this->ns     = strpos($HTTP_USER_AGENT, 'netscape') !== false;          $this->chrome = strpos($HTTP_USER_AGENT, 'chrome') !== false; -        $this->safari = !$this->chrome && ($this->khtml || strpos($HTTP_USER_AGENT, 'safari') !== false); +        $this->ie     = !$this->opera && (strpos($HTTP_USER_AGENT, 'compatible; msie') !== false || strpos($HTTP_USER_AGENT, 'trident/') !== false); +        $this->safari = !$this->chrome && (strpos($HTTP_USER_AGENT, 'safari') !== false || strpos($HTTP_USER_AGENT, 'applewebkit') !== false); +        $this->mz     = !$this->ie && !$this->safari && !$this->chrome && !$this->ns && strpos($HTTP_USER_AGENT, 'mozilla') !== false; -        if ($this->ns || $this->chrome) { -            $test = preg_match('/(mozilla|chrome)\/([0-9.]+)/', $HTTP_USER_AGENT, $regs); -            $this->ver = $test ? (float)$regs[2] : 0; +        if (preg_match('/(chrome|msie|opera|version|khtml)(\s*|\/)([0-9.]+)/', $HTTP_USER_AGENT, $regs)) { +            $this->ver = (float) $regs[3];          } -        else if ($this->mz) { -            $test = preg_match('/rv:([0-9.]+)/', $HTTP_USER_AGENT, $regs); -            $this->ver = $test ? (float)$regs[1] : 0; -        } -        else if ($this->ie || $this->opera) { -            $test = preg_match('/(msie|opera) ([0-9.]+)/', $HTTP_USER_AGENT, $regs); -            $this->ver = $test ? (float)$regs[2] : 0; +        else if (preg_match('/rv:([0-9.]+)/', $HTTP_USER_AGENT, $regs)) { +            $this->ver = (float) $regs[1];          }          if (preg_match('/ ([a-z]{2})-([a-z]{2})/', $HTTP_USER_AGENT, $regs)) @@ -61,10 +53,10 @@ class rcube_browser          else              $this->lang =  'en'; -        $this->dom = ($this->mz || $this->safari || ($this->ie && $this->ver>=5) || ($this->opera && $this->ver>=7)); +        $this->dom      = $this->mz || $this->safari || ($this->ie && $this->ver>=5) || ($this->opera && $this->ver>=7);          $this->pngalpha = $this->mz || $this->safari || ($this->ie && $this->ver>=5.5) ||              ($this->ie && $this->ver>=5 && $this->mac) || ($this->opera && $this->ver>=7) ? true : false; -        $this->imgdata = !$this->ie; +        $this->imgdata  = !$this->ie;      }  } diff --git a/program/lib/Roundcube/rcube_contacts.php b/program/lib/Roundcube/rcube_contacts.php index 5c9e5ab39..2e03352bf 100644 --- a/program/lib/Roundcube/rcube_contacts.php +++ b/program/lib/Roundcube/rcube_contacts.php @@ -350,7 +350,7 @@ class rcube_contacts extends rcube_addressbook                  if (in_array($col, $this->table_cols)) {                      switch ($mode) {                      case 1: // strict -                        $where[] = '(' . $this->db->quoteIdentifier($col) . ' = ' . $this->db->quote($val) +                        $where[] = '(' . $this->db->quote_identifier($col) . ' = ' . $this->db->quote($val)                              . ' OR ' . $this->db->ilike($col, $val . $AS . '%')                              . ' OR ' . $this->db->ilike($col, '%' . $AS . $val . $AS . '%')                              . ' OR ' . $this->db->ilike($col, '%' . $AS . $val) . ')'; @@ -390,7 +390,7 @@ class rcube_contacts extends rcube_addressbook          }          foreach (array_intersect($required, $this->table_cols) as $col) { -            $and_where[] = $this->db->quoteIdentifier($col).' <> '.$this->db->quote(''); +            $and_where[] = $this->db->quote_identifier($col).' <> '.$this->db->quote('');          }          if (!empty($where)) { @@ -630,7 +630,7 @@ class rcube_contacts extends rcube_addressbook          $a_insert_cols = $a_insert_values = array();          foreach ($save_data as $col => $value) { -            $a_insert_cols[]   = $this->db->quoteIdentifier($col); +            $a_insert_cols[]   = $this->db->quote_identifier($col);              $a_insert_values[] = $this->db->quote($value);          } @@ -665,7 +665,7 @@ class rcube_contacts extends rcube_addressbook          $save_cols = $this->convert_save_data($save_cols, $record);          foreach ($save_cols as $col => $value) { -            $write_sql[] = sprintf("%s=%s", $this->db->quoteIdentifier($col), $this->db->quote($value)); +            $write_sql[] = sprintf("%s=%s", $this->db->quote_identifier($col), $this->db->quote($value));          }          if (!empty($write_sql)) { diff --git a/program/lib/Roundcube/rcube_csv2vcard.php b/program/lib/Roundcube/rcube_csv2vcard.php index 00e6d4e20..aa385dce4 100644 --- a/program/lib/Roundcube/rcube_csv2vcard.php +++ b/program/lib/Roundcube/rcube_csv2vcard.php @@ -47,7 +47,7 @@ class rcube_csv2vcard          //'business_street_2'     => '',          //'business_street_3'     => '',          'car_phone'             => 'phone:car', -        'categories'            => 'categories', +        'categories'            => 'groups',          //'children'              => '',          'company'               => 'organization',          //'company_main_phone'    => '', @@ -146,6 +146,9 @@ class rcube_csv2vcard          'work_title'            => 'jobtitle',          'work_zip'              => 'zipcode:work',          'group'                 => 'groups', + +        // GMail +        'groups'                => 'groups',      );      /** @@ -427,6 +430,11 @@ class rcube_csv2vcard              $contact['birthday'] = $contact['birthday-y'] .'-' .$contact['birthday-m'] . '-' . $contact['birthday-d'];          } +        // categories/groups separator in vCard is ',' not ';' +        if (!empty($contact['groups'])) { +            $contact['groups'] = str_replace(';', ',', $contact['groups']); +        } +          // Empty dates, e.g. "0/0/00", "0000-00-00 00:00:00"          foreach (array('birthday', 'anniversary') as $key) {              if (!empty($contact[$key])) { diff --git a/program/lib/Roundcube/rcube_db.php b/program/lib/Roundcube/rcube_db.php index aaba28172..2828f26ee 100644 --- a/program/lib/Roundcube/rcube_db.php +++ b/program/lib/Roundcube/rcube_db.php @@ -392,7 +392,7 @@ class rcube_db       */      protected function _query($query, $offset, $numrows, $params)      { -        $query = trim($query); +        $query = ltrim($query);          $this->db_connect($this->dsn_select($query), true); @@ -405,27 +405,28 @@ class rcube_db              $query = $this->set_limit($query, $numrows, $offset);          } -        $params = (array) $params; -          // Because in Roundcube we mostly use queries that are          // executed only once, we will not use prepared queries          $pos = 0;          $idx = 0; -        while ($pos = strpos($query, '?', $pos)) { -            if ($query[$pos+1] == '?') {  // skip escaped ? -                $pos += 2; -            } -            else { -                $val = $this->quote($params[$idx++]); -                unset($params[$idx-1]); -                $query = substr_replace($query, $val, $pos, 1); -                $pos += strlen($val); +        if (count($params)) { +            while ($pos = strpos($query, '?', $pos)) { +                if ($query[$pos+1] == '?') {  // skip escaped '?' +                    $pos += 2; +                } +                else { +                    $val = $this->quote($params[$idx++]); +                    unset($params[$idx-1]); +                    $query = substr_replace($query, $val, $pos, 1); +                    $pos += strlen($val); +                }              }          } -        // replace escaped ? back to normal -        $query = rtrim(strtr($query, array('??' => '?')), ';'); +        // replace escaped '?' back to normal, see self::quote() +        $query = str_replace('??', '?', $query); +        $query = rtrim($query, " \t\n\r\0\x0B;");          $this->debug($query); diff --git a/program/lib/Roundcube/rcube_imap.php b/program/lib/Roundcube/rcube_imap.php index 9faf1bbc6..fdda1d4b2 100644 --- a/program/lib/Roundcube/rcube_imap.php +++ b/program/lib/Roundcube/rcube_imap.php @@ -3848,9 +3848,12 @@ class rcube_imap extends rcube_storage      /**       * Sort folders first by default folders and then in alphabethical order       * -     * @param array $a_folders Folders list +     * @param array $a_folders    Folders list +     * @param bool  $skip_default Skip default folders handling +     * +     * @return array Sorted list       */ -    protected function sort_folder_list($a_folders) +    public function sort_folder_list($a_folders, $skip_default = false)      {          $a_out = $a_defaults = $folders = array(); @@ -3862,7 +3865,7 @@ class rcube_imap extends rcube_storage                  continue;              } -            if (($p = array_search($folder, $this->default_folders)) !== false && !$a_defaults[$p]) { +            if (!$skip_default && ($p = array_search($folder, $this->default_folders)) !== false && !$a_defaults[$p]) {                  $a_defaults[$p] = $folder;              }              else { diff --git a/program/lib/Roundcube/rcube_message.php b/program/lib/Roundcube/rcube_message.php index 9b662a286..f24ec3ed8 100644 --- a/program/lib/Roundcube/rcube_message.php +++ b/program/lib/Roundcube/rcube_message.php @@ -211,16 +211,19 @@ class rcube_message                  }                  $level = explode('.', $part->mime_id); +                $depth = count($level);                  // Check if the part belongs to higher-level's multipart part -                // this can be alternative/related/signed/encrypted, but not mixed +                // this can be alternative/related/signed/encrypted or mixed                  while (array_pop($level) !== null) { -                    if (!count($level)) { +                    $parent_depth = count($level); +                    if (!$parent_depth) {                          return true;                      }                      $parent = $this->mime_parts[join('.', $level)]; -                    if (!preg_match('/^multipart\/(alternative|related|signed|encrypted)$/', $parent->mimetype)) { +                    if (!preg_match('/^multipart\/(alternative|related|signed|encrypted|mixed)$/', $parent->mimetype) +                        || ($parent->mimetype == 'multipart/mixed' && $parent_depth < $depth - 1)) {                          continue 2;                      }                  } @@ -529,8 +532,9 @@ class rcube_message                      $part_mimetype = $mail_part->real_mimetype;                      list($primary_type, $secondary_type) = explode('/', $part_mimetype);                  } -                else -                    $part_mimetype = $mail_part->mimetype; +                else { +                    $part_mimetype = $part_orig_mimetype = $mail_part->mimetype; +                  }                  // multipart/alternative                  if ($primary_type == 'multipart') { diff --git a/program/lib/Roundcube/rcube_plugin.php b/program/lib/Roundcube/rcube_plugin.php index 3153a8410..aa6d8376e 100644 --- a/program/lib/Roundcube/rcube_plugin.php +++ b/program/lib/Roundcube/rcube_plugin.php @@ -109,7 +109,7 @@ abstract class rcube_plugin       */      public function require_plugin($plugin_name)      { -        return $this->api->load_plugin($plugin_name); +        return $this->api->load_plugin($plugin_name, true);      }      /** diff --git a/program/lib/Roundcube/rcube_plugin_api.php b/program/lib/Roundcube/rcube_plugin_api.php index 2258f1486..ad012552d 100644 --- a/program/lib/Roundcube/rcube_plugin_api.php +++ b/program/lib/Roundcube/rcube_plugin_api.php @@ -168,10 +168,11 @@ class rcube_plugin_api       * Load the specified plugin       *       * @param string Plugin name +     * @param boolean Force loading of the plugin even if it doesn't match the filter       *       * @return boolean True on success, false if not loaded or failure       */ -    public function load_plugin($plugin_name) +    public function load_plugin($plugin_name, $force = false)      {          static $plugins_dir; @@ -197,7 +198,7 @@ class rcube_plugin_api                  // check inheritance...                  if (is_subclass_of($plugin, 'rcube_plugin')) {                      // ... task, request type and framed mode -                    if ((!$plugin->task || preg_match('/^('.$plugin->task.')$/i', $this->task)) +                    if (($force || !$plugin->task || preg_match('/^('.$plugin->task.')$/i', $this->task))                          && (!$plugin->noajax || (is_object($this->output) && $this->output->type == 'html'))                          && (!$plugin->noframe || empty($_REQUEST['_framed']))                      ) { diff --git a/program/lib/Roundcube/rcube_session.php b/program/lib/Roundcube/rcube_session.php index 67072df41..caca262c6 100644 --- a/program/lib/Roundcube/rcube_session.php +++ b/program/lib/Roundcube/rcube_session.php @@ -34,6 +34,7 @@ class rcube_session      private $changed;      private $time_diff = 0;      private $reloaded = false; +    private $appends = array();      private $unsets = array();      private $gc_handlers = array();      private $cookiename = 'roundcube_sessauth'; @@ -441,8 +442,19 @@ class rcube_session          $node = &$this->get_node(explode('.', $path), $_SESSION); -        if ($key !== null) $node[$key] = $value; -        else               $node[] = $value; +        if ($key !== null) { +            $node[$key] = $value; +            $path .= '.' . $key; +        } +        else { +            $node[] = $value; +        } + +        $this->appends[] = $path; + +        // when overwriting a previously unset variable +        if ($this->unsets[$path]) +            unset($this->unsets[$path]);      } @@ -491,13 +503,40 @@ class rcube_session       */      public function reload()      { +        // collect updated data from previous appends +        $merge_data = array(); +        foreach ((array)$this->appends as $var) { +            $path = explode('.', $var); +            $value = $this->get_node($path, $_SESSION); +            $k = array_pop($path); +            $node = &$this->get_node($path, $merge_data); +            $node[$k] = $value; +        } +          if ($this->key && $this->memcache)              $data = $this->mc_read($this->key);          else if ($this->key)              $data = $this->db_read($this->key); -        if ($data) +        if ($data) {              session_decode($data); + +            // apply appends and unsets to reloaded data +            $_SESSION = array_merge_recursive($_SESSION, $merge_data); + +            foreach ((array)$this->unsets as $var) { +                if (isset($_SESSION[$var])) { +                    unset($_SESSION[$var]); +                } +                else { +                    $path = explode('.', $var); +                    $k = array_pop($path); +                    $node = &$this->get_node($path, $_SESSION); +                    unset($node[$k]); +                } +            } +        } +      }      /** diff --git a/program/lib/Roundcube/rcube_spellchecker.php b/program/lib/Roundcube/rcube_spellchecker.php index 3182ff378..5b77bda02 100644 --- a/program/lib/Roundcube/rcube_spellchecker.php +++ b/program/lib/Roundcube/rcube_spellchecker.php @@ -352,7 +352,7 @@ class rcube_spellchecker                      "UPDATE ".$this->rc->db->table_name('dictionary')                      ." SET data = ?"                      ." WHERE user_id " . ($plugin['userid'] ? "= ".$this->rc->db->quote($plugin['userid']) : "IS NULL") -                        ." AND " . $this->rc->db->quoteIdentifier('language') . " = ?", +                        ." AND " . $this->rc->db->quote_identifier('language') . " = ?",                      implode(' ', $plugin['dictionary']), $plugin['language']);              }              // don't store empty dict @@ -360,14 +360,14 @@ class rcube_spellchecker                  $this->rc->db->query(                      "DELETE FROM " . $this->rc->db->table_name('dictionary')                      ." WHERE user_id " . ($plugin['userid'] ? "= ".$this->rc->db->quote($plugin['userid']) : "IS NULL") -                        ." AND " . $this->rc->db->quoteIdentifier('language') . " = ?", +                        ." AND " . $this->rc->db->quote_identifier('language') . " = ?",                      $plugin['language']);              }          }          else if (!empty($this->dict)) {              $this->rc->db->query(                  "INSERT INTO " .$this->rc->db->table_name('dictionary') -                ." (user_id, " . $this->rc->db->quoteIdentifier('language') . ", data) VALUES (?, ?, ?)", +                ." (user_id, " . $this->rc->db->quote_identifier('language') . ", data) VALUES (?, ?, ?)",                  $plugin['userid'], $plugin['language'], implode(' ', $plugin['dictionary']));          }      } @@ -394,7 +394,7 @@ class rcube_spellchecker              $sql_result = $this->rc->db->query(                  "SELECT data FROM ".$this->rc->db->table_name('dictionary')                  ." WHERE user_id ". ($plugin['userid'] ? "= ".$this->rc->db->quote($plugin['userid']) : "IS NULL") -                    ." AND " . $this->rc->db->quoteIdentifier('language') . " = ?", +                    ." AND " . $this->rc->db->quote_identifier('language') . " = ?",                  $plugin['language']);              if ($sql_arr = $this->rc->db->fetch_assoc($sql_result)) { diff --git a/program/lib/Roundcube/rcube_user.php b/program/lib/Roundcube/rcube_user.php index 57f63361d..1d5a90577 100644 --- a/program/lib/Roundcube/rcube_user.php +++ b/program/lib/Roundcube/rcube_user.php @@ -221,6 +221,14 @@ class rcube_user          return false;      } +    /** +     * Generate a unique hash to identify this user which +     */ +    function get_hash() +    { +        $key = substr($this->rc->config->get('des_key'), 1, 4); +        return md5($this->data['user_id'] . $key . $this->data['username'] . '@' . $this->data['mail_host']); +    }      /**       * Get default identity of this user @@ -257,7 +265,7 @@ class rcube_user              "SELECT * FROM ".$this->db->table_name('identities').              " WHERE del <> 1 AND user_id = ?".              ($sql_add ? " ".$sql_add : ""). -            " ORDER BY ".$this->db->quoteIdentifier('standard')." DESC, name ASC, identity_id ASC", +            " ORDER BY ".$this->db->quote_identifier('standard')." DESC, name ASC, identity_id ASC",              $this->ID);          while ($sql_arr = $this->db->fetch_assoc($sql_result)) { @@ -292,7 +300,7 @@ class rcube_user          $query_cols = $query_params = array();          foreach ((array)$data as $col => $value) { -            $query_cols[]   = $this->db->quoteIdentifier($col) . ' = ?'; +            $query_cols[]   = $this->db->quote_identifier($col) . ' = ?';              $query_params[] = $value;          }          $query_params[] = $iid; @@ -328,7 +336,7 @@ class rcube_user          $insert_cols = $insert_values = array();          foreach ((array)$data as $col => $value) { -            $insert_cols[]   = $this->db->quoteIdentifier($col); +            $insert_cols[]   = $this->db->quote_identifier($col);              $insert_values[] = $value;          }          $insert_cols[]   = 'user_id'; @@ -393,7 +401,7 @@ class rcube_user          if ($this->ID && $iid) {              $this->db->query(                  "UPDATE ".$this->db->table_name('identities'). -                " SET ".$this->db->quoteIdentifier('standard')." = '0'". +                " SET ".$this->db->quote_identifier('standard')." = '0'".                  " WHERE user_id = ?".                      " AND identity_id <> ?".                      " AND del <> 1", @@ -633,11 +641,11 @@ class rcube_user          $result = array();          $sql_result = $this->db->query( -            "SELECT search_id AS id, ".$this->db->quoteIdentifier('name') +            "SELECT search_id AS id, ".$this->db->quote_identifier('name')              ." FROM ".$this->db->table_name('searches')              ." WHERE user_id = ?" -                ." AND ".$this->db->quoteIdentifier('type')." = ?" -            ." ORDER BY ".$this->db->quoteIdentifier('name'), +                ." AND ".$this->db->quote_identifier('type')." = ?" +            ." ORDER BY ".$this->db->quote_identifier('name'),              (int) $this->ID, (int) $type);          while ($sql_arr = $this->db->fetch_assoc($sql_result)) { @@ -665,9 +673,9 @@ class rcube_user          }          $sql_result = $this->db->query( -            "SELECT ".$this->db->quoteIdentifier('name') -                .", ".$this->db->quoteIdentifier('data') -                .", ".$this->db->quoteIdentifier('type') +            "SELECT ".$this->db->quote_identifier('name') +                .", ".$this->db->quote_identifier('data') +                .", ".$this->db->quote_identifier('type')              ." FROM ".$this->db->table_name('searches')              ." WHERE user_id = ?"                  ." AND search_id = ?", @@ -722,11 +730,11 @@ class rcube_user          $insert_cols[]   = 'user_id';          $insert_values[] = (int) $this->ID; -        $insert_cols[]   = $this->db->quoteIdentifier('type'); +        $insert_cols[]   = $this->db->quote_identifier('type');          $insert_values[] = (int) $data['type']; -        $insert_cols[]   = $this->db->quoteIdentifier('name'); +        $insert_cols[]   = $this->db->quote_identifier('name');          $insert_values[] = $data['name']; -        $insert_cols[]   = $this->db->quoteIdentifier('data'); +        $insert_cols[]   = $this->db->quote_identifier('data');          $insert_values[] = serialize($data['data']);          $sql = "INSERT INTO ".$this->db->table_name('searches') diff --git a/program/lib/Roundcube/rcube_vcard.php b/program/lib/Roundcube/rcube_vcard.php index 5f74ccbd4..a54ee7e11 100644 --- a/program/lib/Roundcube/rcube_vcard.php +++ b/program/lib/Roundcube/rcube_vcard.php @@ -378,7 +378,7 @@ class rcube_vcard          default:              if ($field == 'phone' && $this->phonetypemap[$type_uc]) {                  $type = $this->phonetypemap[$type_uc]; -             } +            }              if (($tag = self::$fieldmap[$field]) && (is_array($value) || strlen($value))) {                  $index = count($this->raw[$tag]); | 
