diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-04-17 15:28:48 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-04-17 15:28:48 +0100 |
commit | cb17589a11f00d0c9efc2aa77cee0e4a50e9ddde (patch) | |
tree | ec5d3ff5e4692b125f295cfead06e79374534478 /src/libserver | |
parent | 3cb21a049f62dff157a1f33e7bbd928d181b9ce0 (diff) | |
download | rspamd-cb17589a11f00d0c9efc2aa77cee0e4a50e9ddde.tar.gz rspamd-cb17589a11f00d0c9efc2aa77cee0e4a50e9ddde.zip |
Move more initialization to the common routines.
Diffstat (limited to 'src/libserver')
-rw-r--r-- | src/libserver/cfg_file.h | 7 | ||||
-rw-r--r-- | src/libserver/cfg_rcl.c | 10 | ||||
-rw-r--r-- | src/libserver/cfg_utils.c | 25 |
3 files changed, 35 insertions, 7 deletions
diff --git a/src/libserver/cfg_file.h b/src/libserver/cfg_file.h index 25f19d216..e2543fea8 100644 --- a/src/libserver/cfg_file.h +++ b/src/libserver/cfg_file.h @@ -395,6 +395,13 @@ void rspamd_ucl_add_conf_variables (struct ucl_parser *parser); */ gboolean rspamd_init_filters (struct rspamd_config *cfg, bool reconfig); +/** + * Init configuration file structure + * @param cfg + * @param init_lua + */ +void rspamd_init_cfg (struct rspamd_config *cfg, gboolean init_lua); + #endif /* ifdef CFG_FILE_H */ /* * vi:ts=4 diff --git a/src/libserver/cfg_rcl.c b/src/libserver/cfg_rcl.c index 19b920c69..ad0ed8bc3 100644 --- a/src/libserver/cfg_rcl.c +++ b/src/libserver/cfg_rcl.c @@ -2256,10 +2256,12 @@ rspamd_config_read (struct rspamd_config *cfg, const gchar *filename, top = rspamd_rcl_config_init (); err = NULL; - HASH_FIND_STR (top, "logging", logger); - if (logger != NULL) { - logger->fin = logger_fin; - logger->fin_ud = logger_ud; + if (logger_fin != NULL) { + HASH_FIND_STR (top, "logging", logger); + if (logger != NULL) { + logger->fin = logger_fin; + logger->fin_ud = logger_ud; + } } if (!rspamd_rcl_parse (top, cfg, cfg->cfg_pool, cfg->rcl_obj, &err)) { diff --git a/src/libserver/cfg_utils.c b/src/libserver/cfg_utils.c index 28310da57..444ad9a11 100644 --- a/src/libserver/cfg_utils.c +++ b/src/libserver/cfg_utils.c @@ -871,6 +871,25 @@ rspamd_init_filters (struct rspamd_config *cfg, bool reconfig) return rspamd_init_lua_filters (cfg); } -/* - * vi:ts=4 - */ +void +rspamd_init_cfg (struct rspamd_config *cfg, gboolean init_lua) +{ + cfg->cfg_pool = rspamd_mempool_new ( + rspamd_mempool_suggest_size ()); + rspamd_config_defaults (cfg); + + if (init_lua) { + cfg->lua_state = rspamd_lua_init (cfg); + rspamd_mempool_add_destructor (cfg->cfg_pool, + (rspamd_mempool_destruct_t)lua_close, cfg->lua_state); + } + + /* Pre-init of cache */ + cfg->cache = g_new0 (struct symbols_cache, 1); + cfg->cache->static_pool = rspamd_mempool_new ( + rspamd_mempool_suggest_size ()); + cfg->cache->cfg = cfg; + cfg->cache->items_by_symbol = g_hash_table_new ( + rspamd_str_hash, + rspamd_str_equal); +} |