From e8eb5e90bb25e0daed531db22ea0d242af9037a9 Mon Sep 17 00:00:00 2001 From: Vsevolod Stakhov Date: Tue, 31 May 2016 15:10:19 +0100 Subject: [PATCH] [Feature] Add lua utility to decode URL encoding --- src/lua/lua_util.c | 54 +++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 49 insertions(+), 5 deletions(-) diff --git a/src/lua/lua_util.c b/src/lua/lua_util.c index 05a9a4452..a5b5eac84 100644 --- a/src/lua/lua_util.c +++ b/src/lua/lua_util.c @@ -79,6 +79,14 @@ LUA_FUNCTION_DEF (util, encode_base32); */ LUA_FUNCTION_DEF (util, decode_base32); +/*** + * @function util.decode_url(input) + * Decodes data from url encoding + * @param {text or string} input data to decode + * @return {rspamd_text} decoded data chunk + */ +LUA_FUNCTION_DEF (util, decode_url); + /*** * @function util.tokenize_text(input[, exceptions]) * Create tokens from a text using optional exceptions list @@ -325,6 +333,7 @@ static const struct luaL_reg utillib_f[] = { LUA_INTERFACE_DEF (util, decode_base64), LUA_INTERFACE_DEF (util, encode_base32), LUA_INTERFACE_DEF (util, decode_base32), + LUA_INTERFACE_DEF (util, decode_url), LUA_INTERFACE_DEF (util, tokenize_text), LUA_INTERFACE_DEF (util, tanh), LUA_INTERFACE_DEF (util, parse_html), @@ -659,11 +668,45 @@ lua_util_decode_base32 (lua_State *L) } if (s != NULL) { - t = lua_newuserdata (L, sizeof (*t)); - rspamd_lua_setclass (L, "rspamd{text}", -1); - t->start = rspamd_decode_base32 (s, inlen, &outlen); - t->len = outlen; - t->own = TRUE; + t = lua_newuserdata (L, sizeof (*t)); + rspamd_lua_setclass (L, "rspamd{text}", -1); + t->start = rspamd_decode_base32 (s, inlen, &outlen); + t->len = outlen; + t->own = TRUE; + } + else { + lua_pushnil (L); + } + + return 1; +} + +static gint +lua_util_decode_url (lua_State *L) +{ + struct rspamd_lua_text *t; + const gchar *s = NULL; + gsize inlen; + + if (lua_type (L, 1) == LUA_TSTRING) { + s = luaL_checklstring (L, 1, &inlen); + } + else if (lua_type (L, 1) == LUA_TUSERDATA) { + t = lua_check_text (L, 1); + + if (t != NULL) { + s = t->start; + inlen = t->len; + } + } + + if (s != NULL) { + t = lua_newuserdata (L, sizeof (*t)); + rspamd_lua_setclass (L, "rspamd{text}", -1); + t->start = g_malloc (inlen); + memcpy ((char *)t->start, s, inlen); + t->len = rspamd_decode_url ((char *)t->start, s, inlen); + t->own = TRUE; } else { lua_pushnil (L); @@ -672,6 +715,7 @@ lua_util_decode_base32 (lua_State *L) return 1; } + static gint lua_util_tokenize_text (lua_State *L) { -- 2.39.5