aboutsummaryrefslogtreecommitdiffstats
path: root/mail/mail-ops.c
diff options
context:
space:
mode:
Diffstat (limited to 'mail/mail-ops.c')
-rw-r--r--mail/mail-ops.c199
1 files changed, 177 insertions, 22 deletions
diff --git a/mail/mail-ops.c b/mail/mail-ops.c
index 5b7690ae7f..a856d30435 100644
--- a/mail/mail-ops.c
+++ b/mail/mail-ops.c
@@ -253,51 +253,50 @@ static void
setup_send_mail (gpointer in_data, gpointer op_data, CamelException *ex)
{
send_mail_input_t *input = (send_mail_input_t *) in_data;
-
+
if (!input->xport_uri) {
camel_exception_set (ex, CAMEL_EXCEPTION_INVALID_PARAM,
/* doesn't really need i18n */
"No transport URI specified for send_mail operation.");
return;
}
-
+
if (!CAMEL_IS_MIME_MESSAGE (input->message)) {
camel_exception_set (ex, CAMEL_EXCEPTION_INVALID_PARAM,
"No message specified for send_mail operation.");
return;
}
-
+
/* NOTE THE EARLY EXIT!! */
-
+
if (input->done_folder == NULL) {
camel_object_ref (CAMEL_OBJECT (input->message));
- gtk_object_ref (GTK_OBJECT (input->composer));
- gtk_widget_hide (GTK_WIDGET (input->composer));
+ if (input->composer) {
+ gtk_object_ref (GTK_OBJECT (input->composer));
+ gtk_widget_hide (GTK_WIDGET (input->composer));
+ }
return;
}
-
+
if (!CAMEL_IS_FOLDER (input->done_folder)) {
camel_exception_set (ex, CAMEL_EXCEPTION_INVALID_PARAM,
"Bad done_folder specified for send_mail operation.");
return;
}
-
+
if (input->done_uid == NULL) {
camel_exception_set (ex, CAMEL_EXCEPTION_INVALID_PARAM,
"No done_uid specified for send_mail operation.");
return;
}
-
- if (!GTK_IS_WIDGET (input->composer)) {
- camel_exception_set (ex, CAMEL_EXCEPTION_INVALID_PARAM,
- "No composer specified for send_mail operation.");
- return;
- }
-
+
camel_object_ref (CAMEL_OBJECT (input->message));
camel_object_ref (CAMEL_OBJECT (input->done_folder));
- gtk_object_ref (GTK_OBJECT (input->composer));
- gtk_widget_hide (GTK_WIDGET (input->composer));
+
+ if (input->composer) {
+ gtk_object_ref (GTK_OBJECT (input->composer));
+ gtk_widget_hide (GTK_WIDGET (input->composer));
+ }
}
static void
@@ -344,7 +343,7 @@ do_send_mail (gpointer in_data, gpointer op_data, CamelException *ex)
/* now to save the message in Sentbox */
if (sentbox_folder) {
CamelMessageInfo *info;
-
+
mail_tool_camel_lock_up ();
info = g_new0 (CamelMessageInfo, 1);
@@ -368,10 +367,12 @@ cleanup_send_mail (gpointer in_data, gpointer op_data, CamelException *ex)
g_free (input->xport_uri);
g_free (input->done_uid);
- if (!camel_exception_is_set (ex))
- gtk_widget_destroy (input->composer);
- else
- gtk_widget_show (input->composer);
+ if (input->composer) {
+ if (!camel_exception_is_set (ex))
+ gtk_widget_destroy (input->composer);
+ else
+ gtk_widget_show (input->composer);
+ }
}
static const mail_operation_spec op_send_mail = {
@@ -402,6 +403,160 @@ mail_do_send_mail (const char *xport_uri,
mail_operation_queue (&op_send_mail, input, TRUE);
}
+/* ** SEND MAIL QUEUE ***************************************************** */
+
+typedef struct send_queue_input_s
+{
+ CamelFolder *folder_queue;
+ gchar *xport_uri;
+}
+send_queue_input_t;
+
+static gchar *describe_send_queue (gpointer in_data, gboolean gerund);
+static void setup_send_queue (gpointer in_data, gpointer op_data,
+ CamelException *ex);
+static void do_send_queue (gpointer in_data, gpointer op_data,
+ CamelException *ex);
+static void cleanup_send_queue (gpointer in_data, gpointer op_data,
+ CamelException *ex);
+
+static gchar *
+describe_send_queue (gpointer in_data, gboolean gerund)
+{
+ /*send_queue_input_t *input = (send_queue_input_t *) in_data;*/
+
+ if (gerund) {
+ return g_strdup_printf (_("Sending queue"));
+ } else {
+ return g_strdup_printf (_("Send queue"));
+ }
+}
+
+static void
+setup_send_queue (gpointer in_data, gpointer op_data, CamelException *ex)
+{
+ send_queue_input_t *input = (send_queue_input_t *) in_data;
+
+ if (!input->xport_uri) {
+ camel_exception_set (ex, CAMEL_EXCEPTION_INVALID_PARAM,
+ /* doesn't really need i18n */
+ "No transport URI specified for send_queue operation.");
+ return;
+ }
+
+ if (!CAMEL_IS_FOLDER (input->folder_queue)) {
+ camel_exception_set (ex, CAMEL_EXCEPTION_INVALID_PARAM,
+ "No queue specified for send_queue operation.");
+ return;
+ }
+
+ camel_object_ref (CAMEL_OBJECT (input->folder_queue));
+}
+
+static void
+do_send_queue (gpointer in_data, gpointer op_data, CamelException *ex)
+{
+ send_queue_input_t *input = (send_queue_input_t *) in_data;
+ extern CamelFolder *sentbox_folder;
+ CamelTransport *xport;
+ GPtrArray *uids;
+ char *x_mailer;
+ guint32 set;
+ int i;
+
+ uids = camel_folder_get_uids (input->folder_queue);
+ if (!uids)
+ return;
+
+ x_mailer = g_strdup_printf ("Evolution %s (Developer Preview)",
+ VERSION);
+
+ for (i = 0; i < uids->len; i++) {
+ CamelMimeMessage *message;
+
+ mail_tool_camel_lock_up ();
+
+ message = camel_folder_get_message (input->folder_queue, uids->pdata[i], ex);
+ if (camel_exception_is_set (ex))
+ break;
+
+ camel_medium_add_header (CAMEL_MEDIUM (message), "X-Mailer", x_mailer);
+
+ camel_mime_message_set_date (message, CAMEL_MESSAGE_DATE_CURRENT, 0);
+
+ xport = camel_session_get_transport (session, input->xport_uri, ex);
+ mail_tool_camel_lock_down ();
+ if (camel_exception_is_set (ex))
+ break;
+
+ mail_tool_send_via_transport (xport, CAMEL_MEDIUM (message), ex);
+ camel_object_unref (CAMEL_OBJECT (xport));
+
+ if (camel_exception_is_set (ex))
+ break;
+
+ mail_tool_camel_lock_up ();
+ set = camel_folder_get_message_flags (input->folder_queue,
+ uids->pdata[i]);
+ camel_folder_set_message_flags (input->folder_queue,
+ uids->pdata[i],
+ CAMEL_MESSAGE_DELETED, ~set);
+ mail_tool_camel_lock_down ();
+
+ /* now to save the message in Sentbox */
+ if (sentbox_folder) {
+ CamelMessageInfo *info;
+
+ mail_tool_camel_lock_up ();
+
+ info = g_new0 (CamelMessageInfo, 1);
+ info->flags = 0;
+ camel_folder_append_message (sentbox_folder, message, info, ex);
+ g_free (info);
+
+ mail_tool_camel_lock_down ();
+ }
+ }
+
+ g_free (x_mailer);
+
+ for (i = 0; i < uids->len; i++)
+ g_free (uids->pdata[i]);
+ g_ptr_array_free (uids, TRUE);
+}
+
+static void
+cleanup_send_queue (gpointer in_data, gpointer op_data, CamelException *ex)
+{
+ send_queue_input_t *input = (send_queue_input_t *) in_data;
+
+ camel_object_unref (CAMEL_OBJECT (input->folder_queue));
+
+ g_free (input->xport_uri);
+}
+
+static const mail_operation_spec op_send_queue = {
+ describe_send_queue,
+ 0,
+ setup_send_queue,
+ do_send_queue,
+ cleanup_send_queue
+};
+
+void
+mail_do_send_queue (CamelFolder *folder_queue,
+ const char *xport_uri)
+{
+ send_queue_input_t *input;
+
+ input = g_new (send_queue_input_t, 1);
+ input->xport_uri = g_strdup (xport_uri);
+ input->folder_queue = folder_queue;
+
+ mail_operation_queue (&op_send_queue, input, TRUE);
+}
+
+
/* ** APPEND MESSAGE TO FOLDER ******************************************** */
typedef struct append_mail_input_s