aboutsummaryrefslogtreecommitdiffstats
path: root/src/libserver
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2016-01-18 01:07:11 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2016-01-18 01:07:11 +0000
commitdfbf2f58ee3f5f2481db498f006137eeb1dfdfb5 (patch)
tree732d71eebd5199f995f24614e5bd4e153e933c14 /src/libserver
parentb4f959e150106634c75b4ca95e2f634f5b8946a6 (diff)
downloadrspamd-dfbf2f58ee3f5f2481db498f006137eeb1dfdfb5.tar.gz
rspamd-dfbf2f58ee3f5f2481db498f006137eeb1dfdfb5.zip
Rework hyperscan notifies to reduce noise level
Diffstat (limited to 'src/libserver')
-rw-r--r--src/libserver/re_cache.c48
-rw-r--r--src/libserver/re_cache.h9
-rw-r--r--src/libserver/rspamd_control.c2
-rw-r--r--src/libserver/rspamd_control.h4
4 files changed, 46 insertions, 17 deletions
diff --git a/src/libserver/re_cache.c b/src/libserver/re_cache.c
index 4434576c8..e0de03184 100644
--- a/src/libserver/re_cache.c
+++ b/src/libserver/re_cache.c
@@ -100,6 +100,7 @@ struct rspamd_re_cache {
guint max_re_data;
gchar hash[rspamd_cryptobox_HASHBYTES + 1];
#ifdef WITH_HYPERSCAN
+ gboolean hyperscan_loaded;
gboolean disable_hyperscan;
hs_platform_info_t plt;
#endif
@@ -186,11 +187,26 @@ rspamd_re_cache_new (void)
cache->re_classes = g_hash_table_new (g_int64_hash, g_int64_equal);
cache->nre = 0;
cache->re = g_ptr_array_new_full (256, rspamd_re_cache_elt_dtor);
+#ifdef WITH_HYPERSCAN
+ cache->hyperscan_loaded = FALSE;
+#endif
REF_INIT_RETAIN (cache, rspamd_re_cache_destroy);
return cache;
}
+gboolean
+rspamd_re_cache_is_hs_loaded (struct rspamd_re_cache *cache)
+{
+ g_assert (cache != NULL);
+
+#ifdef WITH_HYPERSCAN
+ return cache->hyperscan_loaded;
+#else
+ return FALSE;
+#endif
+}
+
rspamd_regexp_t *
rspamd_re_cache_add (struct rspamd_re_cache *cache, rspamd_regexp_t *re,
enum rspamd_re_type type, gpointer type_data, gsize datalen)
@@ -1011,7 +1027,7 @@ rspamd_re_cache_is_finite (struct rspamd_re_cache *cache,
gint
rspamd_re_cache_compile_hyperscan (struct rspamd_re_cache *cache,
- const char *cache_dir, gdouble max_time,
+ const char *cache_dir, gdouble max_time, gboolean silent,
GError **err)
{
g_assert (cache != NULL);
@@ -1051,24 +1067,27 @@ rspamd_re_cache_compile_hyperscan (struct rspamd_re_cache *cache,
g_assert (fd != -1);
lseek (fd, RSPAMD_HS_MAGIC_LEN + sizeof (cache->plt), SEEK_SET);
read (fd, &n, sizeof (n));
- total += n;
close (fd);
if (re_class->type_len > 0) {
- msg_info_re_cache (
- "skip already valid class %s(%*s) to cache %6s, %d regexps",
- rspamd_re_cache_type_to_string (re_class->type),
- (gint) re_class->type_len - 1,
- re_class->type_data,
- re_class->hash,
- n);
+ if (!silent) {
+ msg_info_re_cache (
+ "skip already valid class %s(%*s) to cache %6s, %d regexps",
+ rspamd_re_cache_type_to_string (re_class->type),
+ (gint) re_class->type_len - 1,
+ re_class->type_data,
+ re_class->hash,
+ n);
+ }
}
else {
- msg_info_re_cache (
- "skip already valid class %s to cache %6s, %d regexps",
- rspamd_re_cache_type_to_string (re_class->type),
- re_class->hash,
- n);
+ if (!silent) {
+ msg_info_re_cache (
+ "skip already valid class %s to cache %6s, %d regexps",
+ rspamd_re_cache_type_to_string (re_class->type),
+ re_class->hash,
+ n);
+ }
}
continue;
@@ -1491,6 +1510,7 @@ rspamd_re_cache_load_hyperscan (struct rspamd_re_cache *cache,
}
msg_info_re_cache ("hyperscan database of %d regexps has been loaded", total);
+ cache->hyperscan_loaded = TRUE;
return TRUE;
#endif
diff --git a/src/libserver/re_cache.h b/src/libserver/re_cache.h
index ae5cf9019..8358f146e 100644
--- a/src/libserver/re_cache.h
+++ b/src/libserver/re_cache.h
@@ -84,6 +84,13 @@ void rspamd_re_cache_init (struct rspamd_re_cache *cache,
struct rspamd_config *cfg);
/**
+ * Returns true when hyperscan is loaded
+ * @param cache
+ * @return
+ */
+gboolean rspamd_re_cache_is_hs_loaded (struct rspamd_re_cache *cache);
+
+/**
* Get runtime data for a cache
*/
struct rspamd_re_runtime* rspamd_re_cache_runtime_new (struct rspamd_re_cache *cache);
@@ -145,7 +152,7 @@ enum rspamd_re_type rspamd_re_cache_type_from_string (const char *str);
* Compile expressions to the hyperscan tree and store in the `cache_dir`
*/
gint rspamd_re_cache_compile_hyperscan (struct rspamd_re_cache *cache,
- const char *cache_dir, gdouble max_time,
+ const char *cache_dir, gdouble max_time, gboolean silent,
GError **err);
diff --git a/src/libserver/rspamd_control.c b/src/libserver/rspamd_control.c
index 6696cd183..a91431cac 100644
--- a/src/libserver/rspamd_control.c
+++ b/src/libserver/rspamd_control.c
@@ -716,9 +716,9 @@ rspamd_srv_handler (gint fd, short what, gpointer ud)
* workers
*/
wcmd.cmd.hs_loaded.cache_dir = cmd.cmd.hs_loaded.cache_dir;
+ wcmd.cmd.hs_loaded.forced = cmd.cmd.hs_loaded.forced;
rspamd_control_broadcast_cmd (srv, &wcmd,
rspamd_control_hs_io_handler, NULL);
- rdata->rep.reply.hs_loaded.unused = 0;
break;
default:
msg_err ("unknown command type: %d", cmd.type);
diff --git a/src/libserver/rspamd_control.h b/src/libserver/rspamd_control.h
index a15ace0d6..f8113cbb4 100644
--- a/src/libserver/rspamd_control.h
+++ b/src/libserver/rspamd_control.h
@@ -64,6 +64,7 @@ struct rspamd_control_command {
} recompile;
struct {
gpointer cache_dir;
+ gboolean forced;
} hs_loaded;
struct {
guint unused;
@@ -112,6 +113,7 @@ struct rspamd_srv_command {
} spair;
struct {
gpointer cache_dir;
+ gboolean forced;
} hs_loaded;
} cmd;
};
@@ -124,7 +126,7 @@ struct rspamd_srv_reply {
gint code;
} spair;
struct {
- gint unused;
+ gint forced;
} hs_loaded;
} reply;
};