if (preg_match("@multipart/([^;]+);@", $this->headers['content-type'], $mpart_type)) {
preg_match("/boundary=\"?([^ \"]+)\"?/", $this->headers['content-type'], $mpart_boundary);
- $this->split_multipart($mpart_type[1], $mpart_boundary[1]);
- }
-
- if (preg_match('!charset=([^;]*)\s*(;|$)!', $this->headers['content-type'], $matches)) {
- $this->body = iconv($matches[1], 'utf-8', $this->body);
+ $this->_split_multipart($mpart_type[1], $mpart_boundary[1]);
} else {
- $this->body = utf8_encode($this->body);
+ if (preg_match('!charset=([^;]*)\s*(;|$)!', $this->headers['content-type'], $matches)) {
+ $this->body = iconv($matches[1], 'utf-8', $this->body);
+ } else {
+ $this->body = utf8_encode($this->body);
+ }
}
}
* @param $type STRING multipart type description
* @param $boundary STRING multipart boundary identification string
*/
- function split_multipart($type, $boundary)
+ function _split_multipart($type, $boundary)
{
$parts = preg_split("/\n--$boundary(--|\n)/", $this->body);
foreach ($parts as $part) {
- $part = $this->get_part($part);
+ $part = $this->_get_part($part);
$local_header = $part['headers'];
$local_body = $part['body'];
if (isset($local_header['content-disposition']) && preg_match("/attachment/", $local_header['content-disposition'])) {
- $this->add_attachment($part);
+ $this->_add_attachment($part);
} else if (isset($local_header['content-type']) && preg_match("@text/([^;]+);@", $local_header['content-type'], $format)) {
array_push($this->messages, $part);
- }
- }
- if (count($this->messages) > 0) {
- $this->set_body_to_part(0);
+ }
}
+ $this->set_body_to_part(0);
}
/** extract new headers from the part
* @param $part STRING part of a multipart message
*/
- function get_part($part)
+ function _get_part($part)
{
global $banana;
/** add an attachment
*/
- function add_attachment($part)
+ function _add_attachment($part)
{
$local_header = $part['headers'];
$local_body = $part['body'];
return true;
}
+ /** return body in plain text (useful for messages without a text/plain part)
+ */
+ function get_body()
+ {
+ preg_match("@text/([^;]+);@", $this->headers['content-type'], $format);
+ if ($format[1] == 'plain') {
+ return $this->body;
+ }
+ if ($format[1] == 'richtext') {
+ return htmlToPlainText(richtextToHtml($this->body));
+ } else {
+ return htmlToPlainText($this->body);
+ }
+ }
+
/** decode an attachment
* @param pjid INT id of the attachment to decode
* @param action BOOL action to execute : true=view, false=download
return false;
} else {
$file = $this->pj[$pjid];
- header('Content-Type: '.$file['MIME']);
+ header('Content-Type: '.$file['MIME'].'; name="'.$file['filename'].'"');
if (!$action) {
header('Content-Disposition: attachment; filename="'.$file['filename'].'"');
- }
+ } else {
+ header('Content-Disposition: inline; filename="'.$file['filename'].'"');
+ }
if ($file['encoding'] == 'base64') {
echo base64_decode($file['data']);
} else {
$this->headers[$hdr] = $local_header[$hdr];
}
}
+
+ if (preg_match('!charset=([^;]*)\s*(;|$)!', $this->headers['content-type'], $matches)) {
+ $this->body = iconv($matches[1], 'utf-8', $this->body);
+ } else {
+ $this->body = utf8_encode($this->body);
+ }
return true;
}
/** convert message to html
* @param partid INT id of the multipart message that must be displaid
*/
- function to_html($partid = 0)
+ function to_html($partid = -1)
{
global $banana;
- if ($partid != 0) {
- $this->set_body_to_part($partid);
+ if (count($this->messages) > 1) {
+ if ($partid != -1) {
+ $this->set_body_to_part($partid);
+ } else {
+ // Select prefered text-format
+ foreach ($banana->body_mime as $mime) {
+ for ($id = 0 ; $id < count($this->messages) ; $id++) {
+ if (preg_match("@$mime@", $this->messages[$id]['headers']['content-type'])) {
+ $partid = $id;
+ $this->set_body_to_part($partid);
+ break;
+ }
+ }
+ if ($partid != -1) {
+ break;
+ }
+ }
+ if ($partid == -1) {
+ $partid = 0;
+ }
+ }
+ } else {
+ $partid = 0;
}
$res = '<table class="bicol banana_msg" cellpadding="0" cellspacing="0">';
preg_match("@text/([^;]+);@", $this->headers['content-type'], $format);
$format = $format[1];
- $res .= '<tr><td colspan="2">';
+ $res .= '<tr><td colspan="2"';
if ($format == 'html') {
- $res .= formatbody($this->body, $format);
+ if (preg_match('@<body[^>]*bgcolor="?([#0-9a-f]+)"?[^>]*>@i', $this->body, $bgcolor)) {
+ $res .= ' bgcolor="'.$bgcolor[1].'"';
+ }
+ $res .= '>'.formatbody($this->body, $format);
} else {
- $res .= '<pre>'.formatbody($this->body).'</pre>';
+ $res .= '><pre>'.formatbody($this->body).'</pre>';
}
$res .= '</td></tr>';
foreach ($this->pj as $file) {
$res .= $file['filename'].' ('.$file['MIME'].') : ';
$res .= '<a href="pj.php?group='.$banana->state['group'].'&artid='.$this->id.'&pj='.$i.'">télécharger</a>';
- if (preg_match("@(image|text)/@", $file['MIME'])) {
- $res .= ' . <a href="pj.php?group='.$banana->state['group'].'&artid='.$this->id.'&pj='.$i.'&action=view">aperçu</a>';
- }
+ $res .= ' . <a href="pj.php?group='.$banana->state['group'].'&artid='.$this->id.'&pj='.$i.'&action=view" target="_blank">aperçu</a>';
$res .= '<br/>';
$i++;
}
$res .= '</td></tr>';
}
- $res .= '<tr><th colspan="2">'._b_('apercu').'</th></tr>';
+ $res .= '<tr><th colspan="2">'._b_('Apercu').'</th></tr>';
$ndx = $banana->spool->getndx($this->id);
$res .= '<tr><td class="thrd" colspan="2">'.$banana->spool->to_html($ndx-$banana->tbefore, $ndx+$banana->tafter, $ndx).'</td></tr>';