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.c65
1 files changed, 48 insertions, 17 deletions
diff --git a/mail/mail-ops.c b/mail/mail-ops.c
index 59a6e0cde3..99feb2059f 100644
--- a/mail/mail-ops.c
+++ b/mail/mail-ops.c
@@ -99,7 +99,8 @@ mail_load_evolution_rule_context ()
}
static void
-mail_op_report_status(FilterDriver *driver, enum filter_status_t status, const char *desc, CamelMimeMessage *msg, void *data)
+mail_op_report_status (FilterDriver *driver, enum filter_status_t status, const char *desc,
+ CamelMimeMessage *msg, void *data)
{
printf("reporting status: %s\n", desc);
@@ -351,24 +352,24 @@ do_filter_ondemand (gpointer in_data, gpointer op_data, CamelException *ex)
filter_driver_set_status_func(driver, mail_op_report_status, logfile);
/* build the uid list - all uid's not deleted already */
uids = camel_folder_get_uids (input->source);
- new_uids = g_ptr_array_new();
- for (i=0;i<uids->len;i++) {
+ new_uids = g_ptr_array_new ();
+ for (i = 0; i < uids->len; i++) {
const CamelMessageInfo *info = camel_folder_get_message_info(input->source, uids->pdata[i]);
if (info && (info->flags & CAMEL_MESSAGE_DELETED) == 0) {
g_ptr_array_add(new_uids, uids->pdata[i]);
}
}
-
+
/* run the filter */
- filter_driver_filter_folder(driver, input->source, FILTER_SOURCE_DEMAND, new_uids, TRUE, ex);
-
+ filter_driver_filter_folder (driver, input->source, FILTER_SOURCE_DEMAND, new_uids, TRUE, ex);
+
camel_folder_free_uids (input->source, uids);
g_ptr_array_free(new_uids, TRUE);
-
+
if (logfile)
- fclose(logfile);
-
- gtk_object_unref((GtkObject *)driver);
+ fclose (logfile);
+
+ gtk_object_unref (GTK_OBJECT (driver));
mail_tool_camel_lock_down ();
}
@@ -471,12 +472,13 @@ do_send_mail (gpointer in_data, gpointer op_data, CamelException *ex)
{
send_mail_input_t *input = (send_mail_input_t *) in_data;
extern CamelFolder *sent_folder;
+ CamelMessageInfo *info;
CamelTransport *xport;
- char *x_mailer;
+ FilterContext *context;
+ char *x_mailer, *user, *system;
mail_tool_camel_lock_up ();
- x_mailer = g_strdup_printf ("Evolution %s (Developer Preview)",
- VERSION);
+ x_mailer = g_strdup_printf ("Evolution %s (Developer Preview)", VERSION);
camel_medium_add_header (CAMEL_MEDIUM (input->message), "X-Mailer",
x_mailer);
g_free (x_mailer);
@@ -508,14 +510,43 @@ do_send_mail (gpointer in_data, gpointer op_data, CamelException *ex)
mail_tool_camel_lock_down ();
}
+ /* now lets run it through the outgoing filters */
+
+ info = g_new0 (CamelMessageInfo, 1);
+ info->flags = CAMEL_MESSAGE_SEEN;
+
+ /* setup filter driver */
+ context = filter_context_new ();
+ user = g_strdup_printf ("%s/filters.xml", evolution_dir);
+ system = g_strdup_printf ("%s/evolution/filtertypes.xml", EVOLUTION_DATADIR);
+ rule_context_load ((RuleContext *)context, system, user);
+ g_free (user);
+ g_free (system);
+
+ if (!((RuleContext *)context)->error) {
+ FilterDriver *driver;
+ FILE *logfile;
+
+ driver = filter_driver_new (context, mail_tool_filter_get_folder_func, NULL);
+
+ if (TRUE /* perform_logging */) {
+ char *filename;
+
+ filename = g_strdup_printf ("%s/evolution-filter-log", evolution_dir);
+ logfile = fopen (filename, "a+");
+ g_free (filename);
+ }
+
+ filter_driver_filter_message (driver, input->message, info, "", FILTER_SOURCE_OUTGOING, ex);
+
+ if (logfile)
+ fclose (logfile);
+ }
+
/* now to save the message in Sent */
if (sent_folder) {
- CamelMessageInfo *info;
-
mail_tool_camel_lock_up ();
- info = g_new0 (CamelMessageInfo, 1);
- info->flags = CAMEL_MESSAGE_SEEN;
camel_folder_append_message (sent_folder, input->message, info, ex);
g_free (info);