bool *new_sym)
{
struct rspamd_symbol_result *symbol_result = NULL;
- double final_score, *gr_score = NULL, next_gf = 1.0, diff;
+ double final_score, *gr_score = NULL, diff;
struct rspamd_symbol *sdef;
struct rspamd_symbols_group *gr = NULL;
const ucl_object_t *mobj, *sobj;
}
if (diff) {
- /* Handle grow factor */
- if (metric_res->grow_factor && diff > 0) {
- diff *= metric_res->grow_factor;
- next_gf *= task->cfg->grow_factor;
- }
- else if (diff > 0) {
- next_gf = task->cfg->grow_factor;
- }
-
- msg_debug_metric("adjust grow factor to %.2f for symbol %s (%.2f final)",
- next_gf, symbol, diff);
if (sdef) {
PTR_ARRAY_FOREACH(sdef->groups, i, gr)
}
if (!isnan(diff)) {
- metric_res->score += diff;
- metric_res->grow_factor = next_gf;
if (single) {
msg_debug_metric("final score for single symbol %s = %.2f; %.2f diff",
symbol_result = rspamd_mempool_alloc0(task->task_pool, sizeof(*symbol_result));
kh_value(metric_res->symbols, k) = symbol_result;
- /* Handle grow factor */
- if (metric_res->grow_factor && final_score > 0) {
- final_score *= metric_res->grow_factor;
- next_gf *= task->cfg->grow_factor;
- }
- else if (final_score > 0) {
- next_gf = task->cfg->grow_factor;
- }
-
- msg_debug_metric("adjust grow factor to %.2f for symbol %s (%.2f final)",
- next_gf, symbol, final_score);
-
symbol_result->name = sym_cpy;
symbol_result->sym = sdef;
symbol_result->nshots = 1;
const double epsilon = DBL_EPSILON;
metric_res->score += final_score;
- metric_res->grow_factor = next_gf;
symbol_result->score = final_score;
if (final_score > epsilon) {
/*
- * Copyright 2023 Vsevolod Stakhov
+ * Copyright 2024 Vsevolod Stakhov
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
struct rspamd_scan_result {
- double score; /**< total score */
- double grow_factor; /**< current grow factor */
+ double score; /**< total score */
struct rspamd_passthrough_result *passthrough_result;
double positive_score;
double negative_score;
gpointer ud);
/**
- * Default consolidation function for metric, it get all symbols and multiply symbol
- * weight by some factor that is specified in config. Default factor is 1.
- * @param task worker's task that present message from user
- * @param metric_name name of metric
- * @return result metric weight
+ * Adjust symbol results to the grow factor for a specific task; should be called after postfilters
*/
-double rspamd_factor_consolidation_func(struct rspamd_task *task,
- const char *metric_name,
- const char *unused);
-
+void rspamd_task_result_adjust_grow_factor(struct rspamd_task *task,
+ struct rspamd_scan_result *result,
+ double grow_factor);
/**
* Check thresholds and return action for a task
sobj = rspamd_metric_symbol_ucl(task, sym);
ucl_object_insert_key(obj, sobj, sym->name, 0, false);
}
- })
+ });
- if (task->cmd != CMD_CHECK)
- {
+ if (task->cmd != CMD_CHECK) {
/* For checkv2 we insert symbols as a separate object */
ucl_object_insert_key(top, obj, "symbols", 0, false);
}
- else
- {
+ else {
/* For legacy check we just insert it as "default" all together */
ucl_object_insert_key(top, obj, DEFAULT_METRIC, 0, false);
}