aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2020-02-05 16:19:41 +0000
committerVsevolod Stakhov <vsevolod@highsecure.ru>2020-02-05 16:19:41 +0000
commite7fbeb63bbe0a9275380910eef9b7dc01db18c5d (patch)
tree0ec1617adb7866c89e9bd0eec2abf599a5cb2c49
parenta66c2ff0de40276f14586b67cc4afa6ff2f4c11f (diff)
downloadrspamd-e7fbeb63bbe0a9275380910eef9b7dc01db18c5d.tar.gz
rspamd-e7fbeb63bbe0a9275380910eef9b7dc01db18c5d.zip
[Minor] Fix hyperscan loaded when invalid files are presented
-rw-r--r--src/libserver/re_cache.c25
1 files changed, 18 insertions, 7 deletions
diff --git a/src/libserver/re_cache.c b/src/libserver/re_cache.c
index 3c6f5f9e5..5414f8baa 100644
--- a/src/libserver/re_cache.c
+++ b/src/libserver/re_cache.c
@@ -2345,6 +2345,7 @@ rspamd_re_cache_load_hyperscan (struct rspamd_re_cache *cache,
struct rspamd_re_class *re_class;
struct rspamd_re_cache_elt *elt;
struct stat st;
+ gboolean has_valid = FALSE;
g_hash_table_iter_init (&it, cache->re_classes);
@@ -2368,7 +2369,7 @@ rspamd_re_cache_load_hyperscan (struct rspamd_re_cache *cache,
if (map == MAP_FAILED) {
msg_err_re_cache ("cannot mmap %s: %s", path, strerror (errno));
close (fd);
- return FALSE;
+ continue;
}
close (fd);
@@ -2384,7 +2385,7 @@ rspamd_re_cache_load_hyperscan (struct rspamd_re_cache *cache,
msg_err_re_cache ("bad number of expressions in %s: %d",
path, n);
munmap (map, st.st_size);
- return FALSE;
+ continue;
}
total += n;
@@ -2422,7 +2423,11 @@ rspamd_re_cache_load_hyperscan (struct rspamd_re_cache *cache,
g_free (hs_ids);
g_free (hs_flags);
- return FALSE;
+ re_class->hs_ids = NULL;
+ re_class->hs_scratch = NULL;
+ re_class->hs_db = NULL;
+
+ continue;
}
munmap (map, st.st_size);
@@ -2449,18 +2454,24 @@ rspamd_re_cache_load_hyperscan (struct rspamd_re_cache *cache,
re_class->hs_ids = hs_ids;
g_free (hs_flags);
re_class->nhs = n;
+ has_valid = TRUE;
}
else {
msg_err_re_cache ("invalid hyperscan hash file '%s'",
path);
- return FALSE;
+ continue;
}
}
- msg_info_re_cache ("hyperscan database of %d regexps has been loaded", total);
- cache->hyperscan_loaded = TRUE;
+ if (has_valid) {
+ msg_info_re_cache ("hyperscan database of %d regexps has been loaded", total);
+ }
+ else {
+ msg_info_re_cache ("hyperscan database has NOT been loaded; no valid expressions");
+ }
+ cache->hyperscan_loaded = has_valid;
- return TRUE;
+ return has_valid;
#endif
}