From 30b6cddec93a0702e4b36858980450af3af62f47 Mon Sep 17 00:00:00 2001 From: Radek Doulik Date: Thu, 13 Nov 2003 11:09:08 +0000 Subject: new helper function, use it before any call to spamassassin, spamc and 2003-11-13 Radek Doulik * em-junk-filter.c (em_junk_sa_is_available): new helper function, use it before any call to spamassassin, spamc and sa-learn (em_junk_sa_test_spamd): first test if spamassassin is available svn path=/trunk/; revision=23317 --- mail/ChangeLog | 4 ++++ mail/em-junk-filter.c | 46 ++++++++++++++++++++++++++++++++++++---------- 2 files changed, 40 insertions(+), 10 deletions(-) (limited to 'mail') diff --git a/mail/ChangeLog b/mail/ChangeLog index ebb38b242a..3487a5a251 100644 --- a/mail/ChangeLog +++ b/mail/ChangeLog @@ -1,5 +1,9 @@ 2003-11-13 Radek Doulik + * em-junk-filter.c (em_junk_sa_is_available): new helper function, + use it before any call to spamassassin, spamc and sa-learn + (em_junk_sa_test_spamd): first test if spamassassin is available + * mail-folder-cache.c (folder_changed): don't call CAMEL_IS_VJUNK_FOLDER, it was added by mistake diff --git a/mail/em-junk-filter.c b/mail/em-junk-filter.c index 04bbadc2ba..cb0a53557e 100644 --- a/mail/em-junk-filter.c +++ b/mail/em-junk-filter.c @@ -61,6 +61,7 @@ static EMJunkPlugin spam_assassin_plugin = static gboolean em_junk_sa_spamd_tested = FALSE; static gboolean em_junk_sa_use_spamc = FALSE; +static gboolean em_junk_sa_available = FALSE; static gint em_junk_sa_spamd_port = -1; #define d(x) x @@ -78,6 +79,8 @@ pipe_to_sa (CamelMimeMessage *msg, gchar *in, int argc, gchar **argv) int result, status; int in_fds[2]; pid_t pid; + + d(printf ("pipe_to_sa %s, %s, %s, %s\n", argc > 0 ? argv [0] : "N/A", argc > 1 ? argv [1] : "N/A", argc > 2 ? argv [2] : "N/A", argc > 3 ? argv [3] : "N/A")); if (argc < 1 || argv[0] == '\0') return 0; @@ -111,7 +114,7 @@ pipe_to_sa (CamelMimeMessage *msg, gchar *in, int argc, gchar **argv) } execvp (argv [0], argv); - + d(printf ("Could not execute %s: %s\n", argv [0], g_strerror (errno))); _exit (255); } else if (pid < 0) { @@ -183,6 +186,17 @@ static void em_junk_sa_test_spamd () { gint i, port = 7830; + static gchar *args [3] = { + "/bin/sh", + "-c", + "spamassassin --version" + }; + + if (pipe_to_sa (NULL, NULL, 3, args)) { + em_junk_sa_available = FALSE; + return; + } else + em_junk_sa_available = TRUE; em_junk_sa_use_spamc = FALSE; @@ -231,6 +245,17 @@ em_junk_sa_test_spamd () em_junk_sa_spamd_tested = TRUE; } +static gboolean +em_junk_sa_is_available () +{ + LOCK (em_junk_sa_test_lock); + if (!em_junk_sa_spamd_tested) + em_junk_sa_test_spamd (); + UNLOCK (em_junk_sa_test_lock); + + return em_junk_sa_available; +} + static gboolean em_junk_sa_check_junk (CamelMimeMessage *msg) { @@ -243,10 +268,8 @@ em_junk_sa_check_junk (CamelMimeMessage *msg) d(fprintf (stderr, "em_junk_sa_check_junk\n")); - LOCK (em_junk_sa_test_lock); - if (!em_junk_sa_spamd_tested) - em_junk_sa_test_spamd (); - UNLOCK (em_junk_sa_test_lock); + if (!em_junk_sa_is_available ()) + return FALSE; args [2] = em_junk_sa_use_spamc ? (em_junk_sa_spamd_port == -1 @@ -281,9 +304,10 @@ em_junk_sa_report_junk (CamelMimeMessage *msg) " --local" /* local only */ }; - d(fprintf (stderr, "em_junk_sa_report_junk\n");) + d(fprintf (stderr, "em_junk_sa_report_junk\n")); - pipe_to_sa (msg, NULL, 3, args) > 0; + if (em_junk_sa_is_available ()) + pipe_to_sa (msg, NULL, 3, args); } static void @@ -299,9 +323,10 @@ em_junk_sa_report_notjunk (CamelMimeMessage *msg) " --local" /* local only */ }; - d(fprintf (stderr, "em_junk_sa_report_notjunk\n");) + d(fprintf (stderr, "em_junk_sa_report_notjunk\n")); - pipe_to_sa (msg, NULL, 3, args) > 0; + if (em_junk_sa_is_available ()) + pipe_to_sa (msg, NULL, 3, args); } static void @@ -317,7 +342,8 @@ em_junk_sa_commit_reports (void) d(fprintf (stderr, "em_junk_sa_commit_reports\n");) - pipe_to_sa (NULL, NULL, 3, args) > 0; + if (em_junk_sa_is_available ()) + pipe_to_sa (NULL, NULL, 3, args); } const EMJunkPlugin * -- cgit