diff options
author | Johannes Berg <johannes@sipsolutions.net> | 2008-03-20 13:44:38 +0100 |
---|---|---|
committer | Johannes Berg <johannes@sipsolutions.net> | 2008-03-20 13:44:38 +0100 |
commit | a5941271d9ba14dd198df01a13400af557ecf6ed (patch) | |
tree | 26c7d9ebb2717fa4c245aeb1112d93f2ef877e19 /antispam-plugin.c | |
parent | 0baa4bfc6eb3dc5ebf99d93260fbff8455208074 (diff) | |
download | dovecot-antispam-a5941271d9ba14dd198df01a13400af557ecf6ed.tar.gz dovecot-antispam-a5941271d9ba14dd198df01a13400af557ecf6ed.tar.xz dovecot-antispam-a5941271d9ba14dd198df01a13400af557ecf6ed.zip |
add keyword hook, work in progress
Diffstat (limited to '')
-rw-r--r-- | antispam-plugin.c | 51 |
1 files changed, 45 insertions, 6 deletions
diff --git a/antispam-plugin.c b/antispam-plugin.c index 407b909..5dd9a02 100644 --- a/antispam-plugin.c +++ b/antispam-plugin.c @@ -49,6 +49,11 @@ static char *default_spam_folders[] = { static char **spam_folders = default_spam_folders; static char **unsure_folders = NULL; bool antispam_can_append_to_spam = FALSE; +static char **spam_keywords = NULL; + +bool need_keyword_hook; +bool need_folder_hook; + static bool mailbox_in_list(struct mailbox *box, char **list) { @@ -79,6 +84,22 @@ bool mailbox_is_unsure(struct mailbox *box) return mailbox_in_list(box, unsure_folders); } +bool keyword_is_spam(const char *keyword) +{ + char **k = spam_keywords; + + if (!spam_keywords) + return FALSE; + + while (*k) { + if (strcmp(*k, keyword) == 0) + return TRUE; + k++; + } + + return FALSE; +} + const char *get_setting(const char *name) { const char *env; @@ -105,6 +126,7 @@ void PLUGIN_FUNCTION(init)(void) { const char *tmp; char * const *iter; + int spam_folder_count = 0; debug("plugin initialising\n"); @@ -127,17 +149,12 @@ void PLUGIN_FUNCTION(init)(void) if (tmp) spam_folders = p_strsplit(global_pool, tmp, ";"); - tmp = get_setting("ALLOW_APPEND_TO_SPAM"); - if (tmp && strcasecmp(tmp, "yes") == 0) { - antispam_can_append_to_spam = TRUE; - debug("allowing APPEND to spam folders"); - } - if (spam_folders) { iter = spam_folders; while (*iter) { debug("\"%s\" is spam folder\n", *iter); iter++; + spam_folder_count++; } } else debug("no spam folders\n"); @@ -155,6 +172,28 @@ void PLUGIN_FUNCTION(init)(void) } else debug("no unsure folders\n"); + tmp = get_setting("ALLOW_APPEND_TO_SPAM"); + if (tmp && strcasecmp(tmp, "yes") == 0) { + antispam_can_append_to_spam = TRUE; + debug("allowing APPEND to spam folders"); + } + + tmp = get_setting("SPAM_KEYWORDS"); + if (tmp) + spam_keywords = p_strsplit(global_pool, tmp, ";"); + + if (spam_keywords) { + iter = spam_keywords; + while (*iter) { + debug("\"%s\" is spam keyword\n", *iter); + iter++; + } + } + + /* set spam_folders to empty to only allow keywords */ + need_folder_hook = !!spam_folder_count; + need_keyword_hook = !!spam_keywords; + backend_init(global_pool); antispam_next_hook_mail_storage_created = hook_mail_storage_created; |