summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rambler-co.ru>2011-02-14 03:14:09 +0300
committerVsevolod Stakhov <vsevolod@rambler-co.ru>2011-02-14 03:14:09 +0300
commit3c2638e27f6a693318ec9d787885d20c28c41d36 (patch)
tree6dc377e186770998bbec76e63358ca8083c189a8 /src
parentd479b7c8ed1ce247d7c8beebe8870e24a151b357 (diff)
downloadrspamd-3c2638e27f6a693318ec9d787885d20c28c41d36.tar.gz
rspamd-3c2638e27f6a693318ec9d787885d20c28c41d36.zip
* Add ability to setup metric's weights from lua
Diffstat (limited to 'src')
-rw-r--r--src/cfg_xml.c7
-rw-r--r--src/lua/lua_cfg_file.c73
2 files changed, 79 insertions, 1 deletions
diff --git a/src/cfg_xml.c b/src/cfg_xml.c
index b4eaee045..a85b77777 100644
--- a/src/cfg_xml.c
+++ b/src/cfg_xml.c
@@ -893,8 +893,13 @@ handle_lua (struct config_file *cfg, struct rspamd_xml_userdata *ctx, GHashTable
/* Assign global table to set up attributes */
lua_newtable (L);
lua_setglobal (L, "config");
- /* Now config table can be used for configuring rspamd */
}
+ lua_getglobal (L, "metrics");
+ if (lua_isnil (L, -1)) {
+ lua_newtable (L);
+ lua_setglobal (L, "metrics");
+ }
+ /* Now config tables can be used for configuring rspamd */
/* First check "src" attribute */
if (attrs != NULL && (val = g_hash_table_lookup (attrs, "src")) != NULL) {
/* Chdir */
diff --git a/src/lua/lua_cfg_file.c b/src/lua/lua_cfg_file.c
index fca0d0772..6ec48ebef 100644
--- a/src/lua/lua_cfg_file.c
+++ b/src/lua/lua_cfg_file.c
@@ -96,6 +96,64 @@ lua_process_module (lua_State *L, const gchar *param, struct config_file *cfg)
}
}
+/* Process a single item in 'metrics' table */
+static void
+lua_process_metric (lua_State *L, const gchar *name, struct config_file *cfg)
+{
+ GList *metric_list;
+ gchar *symbol;
+ struct metric *metric;
+ gdouble *score;
+
+ /* Get module opt structure */
+ if ((metric = g_hash_table_lookup (cfg->metrics, name)) == NULL) {
+ metric = check_metric_conf (cfg, metric);
+ metric->name = memory_pool_strdup (cfg->cfg_pool, name);
+ }
+
+ /* Now iterate throught module table */
+ for (lua_pushnil(L); lua_next(L, -2); lua_pop(L, 1)) {
+ /* key - -2, value - -1 */
+ symbol = memory_pool_strdup (cfg->cfg_pool, luaL_checkstring (L, -2));
+ if (symbol != NULL) {
+ if (lua_istable (L, -1)) {
+ /* We got a table, so extract individual attributes */
+ lua_pushstring (L, "weight");
+ lua_gettable (L, -1);
+ if (lua_isnumber (L, -1)) {
+ score = memory_pool_alloc (cfg->cfg_pool, sizeof (double));
+ *score = lua_tonumber (L, -1);
+ }
+ else {
+ msg_warn ("cannot get weight of symbol: %s", symbol);
+ continue;
+ }
+ }
+ else if (lua_isnumber (L, -1)) {
+ /* Just got weight */
+ score = memory_pool_alloc (cfg->cfg_pool, sizeof (double));
+ *score = lua_tonumber (L, -1);
+ }
+ else {
+ msg_warn ("cannot get weight of symbol: %s", symbol);
+ continue;
+ }
+ /* Insert symbol */
+ g_hash_table_insert (metric->symbols, symbol, score);
+
+ if ((metric_list = g_hash_table_lookup (cfg->metrics_symbols, symbol)) == NULL) {
+ metric_list = g_list_prepend (NULL, metric);
+ memory_pool_add_destructor (cfg->cfg_pool, (pool_destruct_func)g_list_free, metric_list);
+ g_hash_table_insert (cfg->metrics_symbols, symbol, metric_list);
+ }
+ else {
+ /* Slow but keep start element of list in safe */
+ metric_list = g_list_append (metric_list, metric);
+ }
+ }
+ }
+}
+
/* Process single element */
void
lua_process_element (struct config_file *cfg, const gchar *name, struct module_opt *opt, gint idx)
@@ -195,6 +253,21 @@ lua_post_load_config (struct config_file *cfg)
}
}
+ /* First check all module options that may be overriden in 'config' global */
+ lua_getglobal (L, "metrics");
+
+ if (lua_istable (L, -1)) {
+ /* Iterate */
+ for (lua_pushnil(L); lua_next(L, -2); lua_pop(L, 1)) {
+ /* 'key' is at index -2 and 'value' is at index -1 */
+ /* Key must be a string and value must be a table */
+ name = luaL_checkstring (L, -2);
+ if (name != NULL && lua_istable (L, -1)) {
+ lua_process_metric (L, name, cfg);
+ }
+ }
+ }
+
/* Now parse all lua params */
g_hash_table_foreach (cfg->modules_opts, lua_module_callback, cfg);
}