diff options
Diffstat (limited to 'mail')
-rw-r--r-- | mail/ChangeLog | 8 | ||||
-rw-r--r-- | mail/mail-callbacks.c | 128 | ||||
-rw-r--r-- | mail/mail-format.c | 2 |
3 files changed, 72 insertions, 66 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog index 5b238f41c5..46caa2cb9b 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,3 +1,11 @@ +2002-06-03 Not Zed <NotZed@Ximian.com> + + * mail-callbacks.c (composer_get_message): Changed to check + everything from the composer before the message is requested. + Otherwise we could end up signing/encrypting it twice, etc. + + * mail-format.c (handle_multipart_signed): removed some dead wood. + 2002-06-03 Jeffrey Stedfast <fejj@ximian.com> * component-factory.c (request_quit): Prompt the user to see if he diff --git a/mail/mail-callbacks.c b/mail/mail-callbacks.c index 674877c442..5570430d1b 100644 --- a/mail/mail-callbacks.c +++ b/mail/mail-callbacks.c @@ -366,44 +366,51 @@ composer_sent_cb (char *uri, CamelMimeMessage *message, gboolean sent, void *dat static CamelMimeMessage * composer_get_message (EMsgComposer *composer) { - static char *recipient_type[] = { - CAMEL_RECIPIENT_TYPE_TO, - CAMEL_RECIPIENT_TYPE_CC, - CAMEL_RECIPIENT_TYPE_BCC - }; - const CamelInternetAddress *iaddr; const MailConfigAccount *account; - CamelMimeMessage *message; - EDestination **recipients; - const char *subject; - int num_addrs, i; - - message = e_msg_composer_get_message (composer); - if (message == NULL) - return NULL; - - /* Add info about the sending account */ - account = e_msg_composer_get_preferred_account (composer); - - if (account) { - camel_medium_set_header (CAMEL_MEDIUM (message), "X-Evolution-Account", account->name); - camel_medium_set_header (CAMEL_MEDIUM (message), "X-Evolution-Transport", account->transport->url); - camel_medium_set_header (CAMEL_MEDIUM (message), "X-Evolution-Fcc", account->sent_folder_uri); - if (account->id->organization) - camel_medium_set_header (CAMEL_MEDIUM (message), "Organization", account->id->organization); - } - + CamelMimeMessage *message = NULL; + EDestination **recipients, **recipients_bcc; + char *subject; + int i; + int hidden = 0, shown = 0; + int num = 0, num_bcc = 0; + + /* We should do all of the validity checks based on the composer, and not on + the created message, as extra interaction may occur when we get the message + (e.g. to get a passphrase to sign a message) */ + /* get the message recipients */ - recipients = e_msg_composer_get_recipients (composer); - - /* Check for recipients */ - for (num_addrs = 0, i = 0; i < 3; i++) { - iaddr = camel_mime_message_get_recipients (message, recipient_type[i]); - num_addrs += iaddr ? camel_address_length (CAMEL_ADDRESS (iaddr)) : 0; + recipients = e_msg_composer_get_recipients(composer); + + /* see which ones are visible/present, etc */ + if (recipients) { + for (i=0; recipients[i] != NULL;i++) { + const char *addr = e_destination_get_address(recipients[i]); + + if (addr && addr[0]) { + num++; + if (e_destination_is_evolution_list(recipients[i]) + && !e_destination_list_show_addresses(recipients[i])) { + hidden++; + } else { + shown++; + } + } + } } - + + recipients_bcc = e_msg_composer_get_bcc(composer); + if (recipients_bcc) { + for (i=0; recipients_bcc[i] != NULL;i++) { + const char *addr = e_destination_get_address(recipients_bcc[i]); + + if (addr && addr[0]) + num_bcc++; + } + e_destination_freev (recipients_bcc); + } + /* I'm sensing a lack of love, er, I mean recipients. */ - if (num_addrs == 0) { + if (num == 0) { GtkWidget *message_box; message_box = gnome_message_box_new (_("You must specify recipients in order to " @@ -413,33 +420,13 @@ composer_get_message (EMsgComposer *composer) NULL); gnome_dialog_run_and_close (GNOME_DIALOG (message_box)); - - camel_object_unref (CAMEL_OBJECT (message)); - message = NULL; goto finished; } - if (iaddr && num_addrs == camel_address_length (CAMEL_ADDRESS (iaddr))) { - /* this means that the only recipients are Bcc's */ - - /* OK, this is an abusive hack. If someone sends a mail with a - hidden contact list on the To: line and no other recipients, - they will unknowingly create a message with only bcc: recipients. - We try to detect this and pass a flag to ask_confirm_for_only_bcc, - so that it can present the user with a dialog whose text has been - modified to reflect this situation. */ - - const char *to_header = camel_medium_get_header (CAMEL_MEDIUM (message), CAMEL_RECIPIENT_TYPE_TO); - gboolean hidden_list_case = FALSE; - - if (to_header && !strcmp (to_header, "Undisclosed-Recipient:;")) - hidden_list_case = TRUE; - - if (!ask_confirm_for_only_bcc (composer, hidden_list_case)) { - camel_object_unref (CAMEL_OBJECT (message)); - message = NULL; + if (num == num_bcc || shown == 0) { + /* this means that the only recipients are Bcc's */ + if (!ask_confirm_for_only_bcc (composer, shown == 0)) goto finished; - } } /* Only show this warning if our default is to send html. If it isn't, we've @@ -456,23 +443,36 @@ composer_get_message (EMsgComposer *composer) if (html_problem) { html_problem = !ask_confirm_for_unwanted_html_mail (composer, recipients); - if (html_problem) { - camel_object_unref (CAMEL_OBJECT (message)); - message = NULL; + if (html_problem) goto finished; - } } } /* Check for no subject */ - subject = camel_mime_message_get_subject (message); + subject = e_msg_composer_get_subject(composer); if (subject == NULL || subject[0] == '\0') { if (!ask_confirm_for_empty_subject (composer)) { - camel_object_unref (CAMEL_OBJECT (message)); - message = NULL; + g_free(subject); goto finished; } } + g_free(subject); + + /* actually get the message now, this will sign/encrypt etc */ + message = e_msg_composer_get_message (composer); + if (message == NULL) + goto finished; + + /* Add info about the sending account */ + account = e_msg_composer_get_preferred_account (composer); + + if (account) { + camel_medium_set_header (CAMEL_MEDIUM (message), "X-Evolution-Account", account->name); + camel_medium_set_header (CAMEL_MEDIUM (message), "X-Evolution-Transport", account->transport->url); + camel_medium_set_header (CAMEL_MEDIUM (message), "X-Evolution-Fcc", account->sent_folder_uri); + if (account->id->organization) + camel_medium_set_header (CAMEL_MEDIUM (message), "Organization", account->id->organization); + } /* Get the message recipients and 'touch' them, boosting their use scores */ e_destination_touchv (recipients); diff --git a/mail/mail-format.c b/mail/mail-format.c index e7ca110766..03bd1991c5 100644 --- a/mail/mail-format.c +++ b/mail/mail-format.c @@ -1756,10 +1756,8 @@ handle_multipart_signed (CamelMimePart *part, const char *mime_type, { CamelMimePart *subpart; CamelDataWrapper *wrapper; - /*CamelMultipart *mp;*/ CamelMultipartSigned *mps; gboolean output = FALSE; - int nparts, i; wrapper = camel_medium_get_content_object (CAMEL_MEDIUM (part)); |