From 5ced9ca0756ca20e67d6a2ffdb4c1b6ca4192192 Mon Sep 17 00:00:00 2001
From: alecpl <alec@alec.pl>
Date: Fri, 06 Aug 2010 09:14:26 -0400
Subject: [PATCH] - Replace message_part_encrypted hook with more generic message_part_structure
---
program/include/rcube_message.php | 38 +++++++++++++++-----------------------
1 files changed, 15 insertions(+), 23 deletions(-)
diff --git a/program/include/rcube_message.php b/program/include/rcube_message.php
index fac7fe8..124120b 100644
--- a/program/include/rcube_message.php
+++ b/program/include/rcube_message.php
@@ -247,17 +247,11 @@
*/
private function parse_structure($structure, $recursive = false)
{
- $message_ctype_primary = $structure->ctype_primary;
- $message_ctype_secondary = $structure->ctype_secondary;
- $mimetype = $structure->mimetype;
-
// real content-type of message/rfc822 part
- if ($mimetype == 'message/rfc822') {
- if ($structure->real_mimetype) {
- $mimetype = $structure->real_mimetype;
- list($message_ctype_primary, $message_ctype_secondary) = explode('/', $mimetype);
- }
- }
+ if ($mimetype == 'message/rfc822' && $structure->real_mimetype)
+ $mimetype = $structure->real_mimetype;
+ else
+ $mimetype = $structure->mimetype;
// show message headers
if ($recursive && is_array($structure->headers) && isset($structure->headers['subject'])) {
@@ -266,6 +260,17 @@
$c->headers = &$structure->headers;
$this->parts[] = $c;
}
+
+ // Allow plugins to handle message parts
+ $plugin = $this->app->plugins->exec_hook('message_part_structure',
+ array('object' => $this, 'structure' => $structure,
+ 'mimetype' => $mimetype, 'recursive' => $recursive));
+
+ if ($plugin['abort'])
+ return;
+
+ $structure = $plugin['structure'];
+ list($message_ctype_primary, $message_ctype_secondary) = explode('/', $plugin['mimetype']);
// print body if message doesn't have multiple parts
if ($message_ctype_primary == 'text' && !$recursive) {
@@ -278,8 +283,6 @@
$this->mime_parts[$uupart->mime_id] = $uupart;
$this->attachments[] = $uupart;
}
-
- // @TODO: plugin hook?
}
// the same for pgp signed messages
else if ($mimetype == 'application/pgp' && !$recursive) {
@@ -360,17 +363,6 @@
$p->ctype_secondary = 'plain';
$p->body = rcube_label('encryptedmessage');
$p->size = strlen($p->body);
-
- // maybe some plugins are able to decode this encrypted message part
- $data = $this->app->plugins->exec_hook('message_part_encrypted',
- array('object' => $this, 'struct' => $structure, 'part' => $p));
-
- if (is_array($data['parts'])) {
- $this->parts = array_merge($this->parts, $data['parts']);
- }
- else if ($data['part']) {
- $this->parts[] = $p;
- }
}
// message contains multiple parts
else if (is_array($structure->parts) && !empty($structure->parts)) {
--
Gitblit v1.9.1