diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-09-14 22:11:43 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-09-14 22:11:43 +0100 |
commit | 51e0796dcfb90c8431ee39b54448dcc8a591d535 (patch) | |
tree | df63c60c3ef20ac5b514f74ffbe159878dbbc390 | |
parent | 59f56bfbf59492ef987bd702c3ce59cc113f47c0 (diff) | |
download | rspamd-51e0796dcfb90c8431ee39b54448dcc8a591d535.tar.gz rspamd-51e0796dcfb90c8431ee39b54448dcc8a591d535.zip |
Fix parsing of lua tables.
-rw-r--r-- | src/lua/lua_common.c | 11 | ||||
-rw-r--r-- | src/lua/lua_config.c | 8 |
2 files changed, 12 insertions, 7 deletions
diff --git a/src/lua/lua_common.c b/src/lua/lua_common.c index 209e68fb1..bea2f0a58 100644 --- a/src/lua/lua_common.c +++ b/src/lua/lua_common.c @@ -629,10 +629,10 @@ rspamd_lua_parse_table_arguments (lua_State *L, gint pos, state = read_arg; keylen = p - key; } - else if (*p == '*') { + else if (*p == '*' && key == NULL) { required = TRUE; } - else { + else if (key == NULL) { key = p; } p ++; @@ -787,15 +787,16 @@ rspamd_lua_parse_table_arguments (lua_State *L, gint pos, break; case read_semicolon: - if (*p == ':') { + if (*p == ';' || p == end) { state = read_key; key = NULL; keylen = 0; failed = FALSE; } else { - g_set_error (err, lua_error_quark (), 2, "bad format string: %s", - extraction_pattern); + g_set_error (err, lua_error_quark (), 2, "bad format string: %s," + " at char %c, position %d", + extraction_pattern, *p, (int)(p - extraction_pattern)); va_end (ap); return FALSE; diff --git a/src/lua/lua_config.c b/src/lua/lua_config.c index a26b6b4aa..07e10916a 100644 --- a/src/lua/lua_config.c +++ b/src/lua/lua_config.c @@ -1220,7 +1220,7 @@ lua_config_set_metric_symbol (lua_State * L) if (lua_type (L, 2) == LUA_TTABLE) { if (!rspamd_lua_parse_table_arguments (L, 2, &err, - "name=*S;score=N;description=S;" + "*name=S;score=N;description=S;" "group=S;one_shot=B;metric=S", &name, &weight, &description, &group, &one_shot, &metric_name)) { @@ -1248,12 +1248,16 @@ lua_config_set_metric_symbol (lua_State * L) } } + if (metric_name == NULL) { + metric_name = DEFAULT_METRIC; + } + metric = g_hash_table_lookup (cfg->metrics, metric_name); if (metric == NULL) { msg_err_config ("metric named %s is not defined", metric_name); } - else if (name != NULL && weight > 0) { + else if (name != NULL && weight != 0) { rspamd_config_add_metric_symbol (cfg, metric_name, name, weight, description, group, one_shot, FALSE); } |