aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--mail/ChangeLog3
-rw-r--r--mail/mail-format.c12
2 files changed, 14 insertions, 1 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index c9e8568717..6de7d5b813 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,5 +1,8 @@
2002-10-01 Jeffrey Stedfast <fejj@ximian.com>
+ * mail-format.c (mail_get_message_body): Handle a
+ multipart/encrypted part. Fixes bug #31547.
+
* upgrade-mailer.c: Shut up some compiler warnings.
* importers/evolution-mbox-importer.c (process_item_fn): Use the
diff --git a/mail/mail-format.c b/mail/mail-format.c
index 12cd41dc90..dc63788b66 100644
--- a/mail/mail-format.c
+++ b/mail/mail-format.c
@@ -2324,6 +2324,7 @@ mail_get_message_body (CamelDataWrapper *data, gboolean want_plain, gboolean cit
{
char *subtext, *old, *div, *text = NULL;
CamelContentType *mime_type;
+ CamelCipherContext *cipher;
GByteArray *bytes = NULL;
CamelMimePart *subpart;
CamelMultipart *mp;
@@ -2373,7 +2374,16 @@ mail_get_message_body (CamelDataWrapper *data, gboolean want_plain, gboolean cit
mp = CAMEL_MULTIPART (data);
- if (header_content_type_is (mime_type, "multipart", "alternative")) {
+ if (CAMEL_IS_MULTIPART_ENCRYPTED (mp)) {
+ cipher = camel_gpg_context_new (session, mail_config_get_pgp_path ());
+ subpart = camel_multipart_encrypted_decrypt (CAMEL_MULTIPART_ENCRYPTED (mp),
+ cipher, NULL);
+ if (!subpart)
+ return NULL;
+
+ data = camel_medium_get_content_object (CAMEL_MEDIUM (subpart));
+ return mail_get_message_body (data, want_plain, cite);
+ } else if (header_content_type_is (mime_type, "multipart", "alternative")) {
/* Pick our favorite alternative and reply to it. */
subpart = find_preferred_alternative (mp, want_plain);