diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-01-16 21:31:50 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2016-01-16 21:31:50 +0000 |
commit | 393f4b56644f27e815af8e1851ff7aafe8e3ffd2 (patch) | |
tree | 729c1bca22e982c555372ccc276a0c937a26ff31 | |
parent | 31c615f03ba2870d0eb0d4542aa0b9ceec360c84 (diff) | |
download | rspamd-393f4b56644f27e815af8e1851ff7aafe8e3ffd2.tar.gz rspamd-393f4b56644f27e815af8e1851ff7aafe8e3ffd2.zip |
Fix redis cache config as well
-rw-r--r-- | src/libstat/learn_cache/redis_cache.c | 45 |
1 files changed, 28 insertions, 17 deletions
diff --git a/src/libstat/learn_cache/redis_cache.c b/src/libstat/learn_cache/redis_cache.c index 24c1722b1..1c2eaebe2 100644 --- a/src/libstat/learn_cache/redis_cache.c +++ b/src/libstat/learn_cache/redis_cache.c @@ -190,40 +190,51 @@ rspamd_stat_cache_redis_init (struct rspamd_stat_ctx *ctx, { struct rspamd_redis_cache_ctx *cache_ctx; struct rspamd_statfile_config *stf = st->stcf; - const ucl_object_t *elt; + const ucl_object_t *elt, *relt; cache_ctx = g_slice_alloc0 (sizeof (*cache_ctx)); - elt = ucl_object_find_key (stf->opts, "read_servers"); + elt = ucl_object_find_any_key (stf->opts, "read_servers", "servers", NULL); if (elt == NULL) { - elt = ucl_object_find_key (stf->opts, "servers"); + + if (st->classifier->cfg->opts) { + elt = ucl_object_find_any_key (st->classifier->cfg->opts, + "read_servers", "servers", NULL); + } + + if (elt == NULL) { + msg_err ("statfile %s has no redis servers needed by cache", stf->symbol); + + return NULL; + } } - if (elt == NULL) { - msg_err ("statfile %s has no redis servers", stf->symbol); + relt = elt; + cache_ctx->read_servers = rspamd_upstreams_create (cfg->ups_ctx); + if (!rspamd_upstreams_from_ucl (cache_ctx->read_servers, elt, + REDIS_DEFAULT_PORT, NULL)) { + msg_err ("statfile %s cannot get read servers configuration for the cache", + stf->symbol); return NULL; } - else { - cache_ctx->read_servers = rspamd_upstreams_create (cfg->ups_ctx); - if (!rspamd_upstreams_from_ucl (cache_ctx->read_servers, elt, + + elt = ucl_object_find_key (stf->opts, "write_servers"); + if (elt == NULL) { + /* Use read servers as write ones */ + g_assert (relt != NULL); + cache_ctx->write_servers = rspamd_upstreams_create (cfg->ups_ctx); + if (!rspamd_upstreams_from_ucl (cache_ctx->read_servers, relt, REDIS_DEFAULT_PORT, NULL)) { - msg_err ("statfile %s cannot read servers configuration", + msg_err ("statfile %s cannot get read servers configuration for the cache", stf->symbol); return NULL; } } - - elt = ucl_object_find_key (stf->opts, "write_servers"); - if (elt == NULL) { - msg_err ("statfile %s has no write redis servers, " - "so learning is impossible", stf->symbol); - cache_ctx->write_servers = NULL; - } else { cache_ctx->write_servers = rspamd_upstreams_create (cfg->ups_ctx); if (!rspamd_upstreams_from_ucl (cache_ctx->write_servers, elt, REDIS_DEFAULT_PORT, NULL)) { - msg_err ("statfile %s cannot write servers configuration", + msg_err ("statfile %s cannot get write servers configuration for the cache", stf->symbol); rspamd_upstreams_destroy (cache_ctx->write_servers); cache_ctx->write_servers = NULL; |