aboutsummaryrefslogtreecommitdiffstats
path: root/src/lua/lua_upstream.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/lua/lua_upstream.c')
-rw-r--r--src/lua/lua_upstream.c47
1 files changed, 16 insertions, 31 deletions
diff --git a/src/lua/lua_upstream.c b/src/lua/lua_upstream.c
index 0b2739903..8ceadcc8c 100644
--- a/src/lua/lua_upstream.c
+++ b/src/lua/lua_upstream.c
@@ -168,54 +168,39 @@ lua_check_upstream_list (lua_State * L)
}
/***
- * @function upstream_list.create(def)
+ * @function upstream_list.create(cfg, def, [default_port])
* Create new upstream list from its string definition in form `<upstream>,<upstream>;<upstream>`
+ * @param {rspamd_config} cfg configuration reference
* @param {string} def upstream list definition
+ * @param {number} default_port default port for upstreams
* @return {upstream_list} upstream list structure
*/
static gint
lua_upstream_list_create (lua_State *L)
{
struct upstream_list *new = NULL, **pnew;
+ struct rspamd_config *cfg = lua_check_config (L, 1);
const gchar *def;
- char **tokens, **t;
guint default_port = 0;
- def = luaL_checkstring (L, 1);
+ def = luaL_checkstring (L, 2);
if (def) {
- if (lua_gettop (L) >= 2) {
- default_port = luaL_checknumber (L, 2);
+ if (lua_gettop (L) >= 3) {
+ default_port = luaL_checknumber (L, 3);
}
- tokens = g_strsplit_set (def, ",;", 0);
- if (!tokens || !tokens[0]) {
- goto err;
- }
- t = tokens;
+ new = rspamd_upstreams_create (cfg->ups_ctx);
- new = rspamd_upstreams_create ();
- while (*t != NULL) {
- if (!rspamd_upstreams_add_upstream (new, *t, default_port, NULL)) {
- goto err;
- }
- t ++;
+ if (rspamd_upstreams_parse_line (new, def, default_port, NULL)) {
+ pnew = lua_newuserdata (L, sizeof (struct upstream_list *));
+ rspamd_lua_setclass (L, "rspamd{upstream_list}", -1);
+ *pnew = new;
+ }
+ else {
+ rspamd_upstreams_destroy (new);
+ lua_pushnil (L);
}
- pnew = lua_newuserdata (L, sizeof (struct upstream_list *));
- rspamd_lua_setclass (L, "rspamd{upstream_list}", -1);
-
- g_strfreev (tokens);
- *pnew = new;
- }
-
- return 1;
-err:
- if (tokens) {
- g_strfreev (tokens);
- }
- if (new) {
- rspamd_upstreams_destroy (new);
}
- lua_pushnil (L);
return 1;
}