aboutsummaryrefslogtreecommitdiffstats
path: root/src/libserver/rspamd_symcache.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2018-12-14 19:47:34 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2018-12-14 19:47:34 +0000
commitdf1377662731d3f071510a7884ff6f8c759404a8 (patch)
tree14854583033d262955fad45b7495a64873cc8404 /src/libserver/rspamd_symcache.c
parente3e85d63f18aaf7fae817704af79b39ddb938706 (diff)
downloadrspamd-df1377662731d3f071510a7884ff6f8c759404a8.tar.gz
rspamd-df1377662731d3f071510a7884ff6f8c759404a8.zip
[Minor] Core: Add methods to enable/disable symbols
Diffstat (limited to 'src/libserver/rspamd_symcache.c')
-rw-r--r--src/libserver/rspamd_symcache.c84
1 files changed, 80 insertions, 4 deletions
diff --git a/src/libserver/rspamd_symcache.c b/src/libserver/rspamd_symcache.c
index 42ec9bc85..2eff43826 100644
--- a/src/libserver/rspamd_symcache.c
+++ b/src/libserver/rspamd_symcache.c
@@ -56,11 +56,15 @@ INIT_LOG_MODULE(symcache)
((dyn_item)->started)
#define SET_START_BIT(checkpoint, dyn_item) \
(dyn_item)->started = 1
+#define CLR_START_BIT(checkpoint, dyn_item) \
+ (dyn_item)->started = 0
#define CHECK_FINISH_BIT(checkpoint, dyn_item) \
((dyn_item)->finished)
#define SET_FINISH_BIT(checkpoint, dyn_item) \
(dyn_item)->finished = 1
+#define CLR_FINISH_BIT(checkpoint, dyn_item) \
+ (dyn_item)->finished = 0
static const guchar rspamd_symcache_magic[8] = {'r', 's', 'c', 2, 0, 0, 0, 0 };
@@ -2413,8 +2417,8 @@ rspamd_symcache_is_checked (struct rspamd_task *task,
}
void
-rspamd_symcache_disable_symbol (struct rspamd_symcache *cache,
- const gchar *symbol)
+rspamd_symcache_disable_symbol_perm (struct rspamd_symcache *cache,
+ const gchar *symbol)
{
struct rspamd_symcache_item *item;
@@ -2429,8 +2433,8 @@ rspamd_symcache_disable_symbol (struct rspamd_symcache *cache,
}
void
-rspamd_symcache_enable_symbol (struct rspamd_symcache *cache,
- const gchar *symbol)
+rspamd_symcache_enable_symbol_perm (struct rspamd_symcache *cache,
+ const gchar *symbol)
{
struct rspamd_symcache_item *item;
@@ -2506,6 +2510,78 @@ rspamd_symcache_is_symbol_enabled (struct rspamd_task *task,
return ret;
}
+
+gboolean
+rspamd_symcache_enable_symbol (struct rspamd_task *task,
+ struct rspamd_symcache *cache,
+ const gchar *symbol)
+{
+ struct cache_savepoint *checkpoint;
+ struct rspamd_symcache_item *item;
+ struct rspamd_symcache_dynamic_item *dyn_item;
+ gboolean ret = FALSE;
+
+ g_assert (cache != NULL);
+ g_assert (symbol != NULL);
+
+ checkpoint = task->checkpoint;
+
+ if (checkpoint) {
+ item = rspamd_symcache_find_filter (cache, symbol);
+
+ if (item) {
+ dyn_item = rspamd_symcache_get_dynamic (checkpoint, item);
+
+ if (CHECK_FINISH_BIT (checkpoint, dyn_item)) {
+ ret = TRUE;
+ CLR_START_BIT (checkpoint, dyn_item);
+ CLR_FINISH_BIT (checkpoint, dyn_item);
+ }
+ else {
+ msg_debug_task ("cannot enable symbol %s: already started", symbol);
+ }
+ }
+ }
+
+ return ret;
+}
+
+
+gboolean
+rspamd_symcache_disable_symbol (struct rspamd_task *task,
+ struct rspamd_symcache *cache,
+ const gchar *symbol)
+{
+ struct cache_savepoint *checkpoint;
+ struct rspamd_symcache_item *item;
+ struct rspamd_symcache_dynamic_item *dyn_item;
+ gboolean ret = FALSE;
+
+ g_assert (cache != NULL);
+ g_assert (symbol != NULL);
+
+ checkpoint = task->checkpoint;
+
+ if (checkpoint) {
+ item = rspamd_symcache_find_filter (cache, symbol);
+
+ if (item) {
+ dyn_item = rspamd_symcache_get_dynamic (checkpoint, item);
+
+ if (CHECK_START_BIT (checkpoint, dyn_item)) {
+ ret = TRUE;
+ SET_START_BIT (checkpoint, dyn_item);
+ SET_FINISH_BIT (checkpoint, dyn_item);
+ }
+ else {
+ msg_warn_task ("cannot disable symbol %s: already started", symbol);
+ }
+ }
+ }
+
+ return ret;
+}
+
void
rspamd_symcache_foreach (struct rspamd_symcache *cache,
void (*func) (gint, const gchar *, gint, gpointer),