aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--lualib/lua_cfg_transform.lua5
-rw-r--r--src/libserver/cfg_file.h1
-rw-r--r--src/libserver/cfg_rcl.cxx12
-rw-r--r--src/libutil/upstream.c23
4 files changed, 33 insertions, 8 deletions
diff --git a/lualib/lua_cfg_transform.lua b/lualib/lua_cfg_transform.lua
index d6243ade1..02d8526e5 100644
--- a/lualib/lua_cfg_transform.lua
+++ b/lualib/lua_cfg_transform.lua
@@ -630,5 +630,10 @@ return function(cfg)
cfg.emails = {}
end
+ -- Common misprint options.upstreams -> options.upstream
+ if type(cfg.options) == 'table' and type(cfg.options.upstreams) == 'table' and not cfg.options.upstream then
+ cfg.options.upstream = cfg.options.upstreams
+ end
+
return ret, cfg
end
diff --git a/src/libserver/cfg_file.h b/src/libserver/cfg_file.h
index a1ede5669..1ba1d84ad 100644
--- a/src/libserver/cfg_file.h
+++ b/src/libserver/cfg_file.h
@@ -450,6 +450,7 @@ struct rspamd_config {
double upstream_error_time; /**< rate of upstream errors */
double upstream_revive_time; /**< revive timeout for upstreams */
double upstream_lazy_resolve_time; /**< lazy resolve time for upstreams */
+ double upstream_resolve_min_interval; /**< minimum interval for resolving attempts (60 seconds by default) */
struct upstream_ctx *ups_ctx; /**< upstream context */
struct rspamd_dns_resolver *dns_resolver; /**< dns resolver if loaded */
diff --git a/src/libserver/cfg_rcl.cxx b/src/libserver/cfg_rcl.cxx
index 4feb55de0..f0c9db64d 100644
--- a/src/libserver/cfg_rcl.cxx
+++ b/src/libserver/cfg_rcl.cxx
@@ -1747,7 +1747,7 @@ rspamd_rcl_config_init(struct rspamd_config *cfg, GHashTable *skip_sections)
FALSE,
TRUE,
cfg->doc_strings,
- "Global rspamd options");
+ "Global Rspamd options");
rspamd_rcl_add_default_handler(sub,
"cache_file",
rspamd_rcl_parse_struct_string,
@@ -2210,7 +2210,7 @@ rspamd_rcl_config_init(struct rspamd_config *cfg, GHashTable *skip_sections)
/* New DNS configuration */
auto *ssub = rspamd_rcl_add_section_doc(&top, sub, "dns", nullptr, nullptr,
UCL_OBJECT, FALSE, TRUE,
- cfg->doc_strings,
+ nullptr,
"Options for DNS resolver");
rspamd_rcl_add_default_handler(ssub,
"nameserver",
@@ -2259,7 +2259,7 @@ rspamd_rcl_config_init(struct rspamd_config *cfg, GHashTable *skip_sections)
/* New upstreams configuration */
ssub = rspamd_rcl_add_section_doc(&top, sub, "upstream", nullptr, nullptr,
UCL_OBJECT, FALSE, TRUE,
- cfg->doc_strings,
+ nullptr,
"Upstreams configuration parameters");
rspamd_rcl_add_default_handler(ssub,
"max_errors",
@@ -2285,6 +2285,12 @@ rspamd_rcl_config_init(struct rspamd_config *cfg, GHashTable *skip_sections)
G_STRUCT_OFFSET(struct rspamd_config, upstream_lazy_resolve_time),
RSPAMD_CL_FLAG_TIME_FLOAT,
"Time to resolve upstreams addresses in lazy mode");
+ rspamd_rcl_add_default_handler(ssub,
+ "resolve_min_interval",
+ rspamd_rcl_parse_struct_time,
+ G_STRUCT_OFFSET(struct rspamd_config, upstream_resolve_min_interval),
+ RSPAMD_CL_FLAG_TIME_FLOAT,
+ "Minumum interval to perform resolving (60 seconds by default)");
}
if (!(skip_sections && g_hash_table_lookup(skip_sections, "actions"))) {
diff --git a/src/libutil/upstream.c b/src/libutil/upstream.c
index 300f907a7..49570dec0 100644
--- a/src/libutil/upstream.c
+++ b/src/libutil/upstream.c
@@ -87,6 +87,7 @@ struct upstream_limits {
double error_time;
double dns_timeout;
double lazy_resolve_time;
+ double resolve_min_interval;
unsigned int max_errors;
unsigned int dns_retransmits;
};
@@ -157,9 +158,10 @@ static const double default_error_time = DEFAULT_ERROR_TIME;
static const double default_dns_timeout = DEFAULT_DNS_TIMEOUT;
#define DEFAULT_DNS_RETRANSMITS 2
static const unsigned int default_dns_retransmits = DEFAULT_DNS_RETRANSMITS;
-/* TODO: make it configurable */
#define DEFAULT_LAZY_RESOLVE_TIME 3600.0
static const double default_lazy_resolve_time = DEFAULT_LAZY_RESOLVE_TIME;
+#define DEFAULT_RESOLVE_MIN_INTERVAL 60.0
+static const double default_resolve_min_interval = DEFAULT_RESOLVE_MIN_INTERVAL;
static const struct upstream_limits default_limits = {
.revive_time = DEFAULT_REVIVE_TIME,
@@ -169,6 +171,7 @@ static const struct upstream_limits default_limits = {
.dns_retransmits = DEFAULT_DNS_RETRANSMITS,
.max_errors = DEFAULT_MAX_ERRORS,
.lazy_resolve_time = DEFAULT_LAZY_RESOLVE_TIME,
+ .resolve_min_interval = DEFAULT_RESOLVE_MIN_INTERVAL,
};
static void rspamd_upstream_lazy_resolve_cb(struct ev_loop *, ev_timer *, int);
@@ -199,6 +202,15 @@ void rspamd_upstreams_library_config(struct rspamd_config *cfg,
if (cfg->dns_timeout) {
ctx->limits.dns_timeout = cfg->dns_timeout;
}
+ if (cfg->upstream_resolve_min_interval) {
+ ctx->limits.resolve_min_interval = cfg->upstream_resolve_min_interval;
+ }
+
+ /* Some sanity checks */
+ if (ctx->limits.resolve_min_interval > ctx->limits.revive_time) {
+ /* We must be able to resolve host during the revive time */
+ ctx->limits.resolve_min_interval = ctx->limits.revive_time;
+ }
ctx->event_loop = event_loop;
ctx->res = resolver;
@@ -641,8 +653,6 @@ static void
rspamd_upstream_resolve_addrs(const struct upstream_list *ls,
struct upstream *upstream)
{
- /* XXX: maybe make it configurable */
- static const double min_resolve_interval = 60.0;
if (upstream->ctx->res != NULL &&
upstream->ctx->configured &&
@@ -651,11 +661,11 @@ rspamd_upstream_resolve_addrs(const struct upstream_list *ls,
double now = ev_now(upstream->ctx->event_loop);
- if (now - upstream->last_resolve < min_resolve_interval) {
+ if (now - upstream->last_resolve < upstream->ctx->limits.resolve_min_interval) {
msg_info_upstream("do not resolve upstream %s as it was checked %.0f "
"seconds ago (%.0f is minimum)",
upstream->name, now - upstream->last_resolve,
- min_resolve_interval);
+ upstream->ctx->limits.resolve_min_interval);
return;
}
@@ -756,6 +766,7 @@ rspamd_upstream_set_inactive(struct upstream_list *ls, struct upstream *upstream
struct upstream *cur;
struct upstream_list_watcher *w;
+ g_assert(upstream != NULL);
RSPAMD_UPSTREAM_LOCK(ls);
g_ptr_array_remove_index(ls->alive, upstream->active_idx);
upstream->active_idx = -1;
@@ -806,6 +817,7 @@ void rspamd_upstream_fail(struct upstream *upstream,
struct upstream_addr_elt *addr_elt;
struct upstream_list_watcher *w;
+ g_assert(upstream != NULL);
msg_debug_upstream("upstream %s failed; reason: %s",
upstream->name,
reason);
@@ -1652,6 +1664,7 @@ void rspamd_upstream_reresolve(struct upstream_ctx *ctx)
while (cur) {
up = cur->data;
+ g_assert(up != NULL);
REF_RETAIN(up);
rspamd_upstream_resolve_addrs(up->ls, up);
REF_RELEASE(up);