| | |
| | | |
| | | // part body not fetched yet... save in memory if it's small enough |
| | | if ($part->body === null && is_numeric($mime_id) && $part->size < self::BODY_MAX_SIZE) { |
| | | $this->storage->set_folder($this->folder); |
| | | // Warning: body here should be always unformatted |
| | | $part->body = $this->storage->get_message_part($this->uid, $mime_id, $part, |
| | | null, null, true, 0, false); |
| | |
| | | $this->storage->set_folder($this->folder); |
| | | |
| | | $body = $this->storage->get_message_part($this->uid, $mime_id, $part, |
| | | $mode === -1, is_resource($mode) ? $mode : null, !$formatted, $max_bytes, $formatted); |
| | | |
| | | if (!$mode && $body && $formatted) { |
| | | $body = self::format_part_body($body, $part, $this->headers->charset); |
| | | } |
| | | $mode === -1, is_resource($mode) ? $mode : null, |
| | | !($mode && $formatted), $max_bytes, $mode && $formatted); |
| | | |
| | | if (is_resource($mode)) { |
| | | rewind($mode); |
| | | return $body !== false; |
| | | } |
| | | |
| | | if (!$mode && $body && $formatted) { |
| | | $body = self::format_part_body($body, $part, $this->headers->charset); |
| | | } |
| | | |
| | | return $body; |
| | |
| | | else if ($mimetype == 'multipart/alternative' |
| | | && is_array($structure->parts) && count($structure->parts) > 1 |
| | | ) { |
| | | $plain_part = null; |
| | | $html_part = null; |
| | | $print_part = null; |
| | | $related_part = null; |
| | | $attach_part = null; |
| | | |
| | | // get html/plaintext parts, other add to attachments list |
| | | foreach ($structure->parts as $p => $sub_part) { |
| | | $sub_mimetype = $sub_part->mimetype; |
| | |
| | | { |
| | | // @TODO: attachment may be huge, handle body via file |
| | | $body = $this->get_part_body($part->mime_id); |
| | | $tnef = new tnef_decoder; |
| | | $tnef = new rcube_tnef_decoder; |
| | | $tnef_arr = $tnef->decompress($body); |
| | | $parts = array(); |
| | | |
| | |
| | | foreach ($tnef_arr as $pid => $winatt) { |
| | | $tpart = new rcube_message_part; |
| | | |
| | | $tpart->filename = trim($winatt['name']); |
| | | $tpart->filename = $this->fix_attachment_name(trim($winatt['name']), $part); |
| | | $tpart->encoding = 'stream'; |
| | | $tpart->ctype_primary = trim(strtolower($winatt['type'])); |
| | | $tpart->ctype_secondary = trim(strtolower($winatt['subtype'])); |
| | |
| | | return $parts; |
| | | } |
| | | |
| | | /** |
| | | * Fix attachment name encoding if needed/possible |
| | | */ |
| | | protected function fix_attachment_name($name, $part) |
| | | { |
| | | if ($name == rcube_charset::clean($name)) { |
| | | return $name; |
| | | } |
| | | |
| | | // find charset from part or its parent(s) |
| | | if ($part->charset) { |
| | | $charsets[] = $part->charset; |
| | | } |
| | | else { |
| | | // check first part (common case) |
| | | $n = strpos($part->mime_id, '.') ? preg_replace('/\.[0-9]+$/', '', $part->mime_id) . '.1' : 1; |
| | | if (($_part = $this->mime_parts[$n]) && $_part->charset) { |
| | | $charsets[] = $_part->charset; |
| | | } |
| | | |
| | | // check parents' charset |
| | | $items = explode('.', $part->mime_id); |
| | | for ($i = count($items)-1; $i > 0; $i--) { |
| | | $last = array_pop($items); |
| | | $parent = $this->mime_parts[join('.', $items)]; |
| | | |
| | | if ($parent && $parent->charset) { |
| | | $charsets[] = $parent->charset; |
| | | } |
| | | } |
| | | } |
| | | |
| | | if ($this->headers->charset) { |
| | | $charsets[] = $this->headers->charset; |
| | | } |
| | | |
| | | if (empty($charsets)) { |
| | | $rcube = rcube::get_instance(); |
| | | $charsets[] = rcube_charset::detect($name, $rcube->config->get('default_charset', RCUBE_CHARSET)); |
| | | } |
| | | |
| | | foreach (array_unique($charsets) as $charset) { |
| | | $_name = rcube_charset::convert($name, $charset); |
| | | |
| | | if ($_name == rcube_charset::clean($_name)) { |
| | | if (!$part->charset) { |
| | | $part->charset = $charset; |
| | | } |
| | | |
| | | return $_name; |
| | | } |
| | | } |
| | | |
| | | return $name; |
| | | } |
| | | |
| | | /** |
| | | * Deprecated methods (to be removed) |