diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-07-13 19:07:43 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2017-07-13 19:07:43 +0100 |
commit | 67ccec834e9be395a187da73e5db19df7321031e (patch) | |
tree | dc006e13c9333fda9d355cc1d7b58ebabef6ef02 /src | |
parent | 44674eba990be7afc1ea32bc0fcb31d637be34e2 (diff) | |
download | rspamd-67ccec834e9be395a187da73e5db19df7321031e.tar.gz rspamd-67ccec834e9be395a187da73e5db19df7321031e.zip |
[Feature] Add method to get all content-type attributes in Lua
Diffstat (limited to 'src')
-rw-r--r-- | src/lua/lua_mimepart.c | 61 |
1 files changed, 59 insertions, 2 deletions
diff --git a/src/lua/lua_mimepart.c b/src/lua/lua_mimepart.c index 362b43046..8223b9fc5 100644 --- a/src/lua/lua_mimepart.c +++ b/src/lua/lua_mimepart.c @@ -261,6 +261,13 @@ LUA_FUNCTION_DEF (mimepart, get_length); LUA_FUNCTION_DEF (mimepart, get_type); /*** + * @method mime_part:get_type_full() + * Extract content-type string of the mime part with all attributes + * @return {string,string,table} content type in form 'type','subtype', {attrs} + */ +LUA_FUNCTION_DEF (mimepart, get_type_full); + +/*** * @method mime_part:get_cte() * Extract content-transfer-encoding for a part * @return {string} content transfer encoding (e.g. `base64` or `7bit`) @@ -355,6 +362,7 @@ static const struct luaL_reg mimepartlib_m[] = { LUA_INTERFACE_DEF (mimepart, get_content), LUA_INTERFACE_DEF (mimepart, get_length), LUA_INTERFACE_DEF (mimepart, get_type), + LUA_INTERFACE_DEF (mimepart, get_type_full), LUA_INTERFACE_DEF (mimepart, get_cte), LUA_INTERFACE_DEF (mimepart, get_filename), LUA_INTERFACE_DEF (mimepart, get_header), @@ -815,9 +823,12 @@ lua_mimepart_get_length (lua_State * L) } static gint -lua_mimepart_get_type (lua_State * L) +lua_mimepart_get_type_common (lua_State * L, gboolean full) { struct rspamd_mime_part *part = lua_check_mimepart (L); + GHashTableIter it; + gpointer k, v; + rspamd_ftok_t *akey, *avalue; if (part == NULL) { lua_pushnil (L); @@ -828,7 +839,53 @@ lua_mimepart_get_type (lua_State * L) lua_pushlstring (L, part->ct->type.begin, part->ct->type.len); lua_pushlstring (L, part->ct->subtype.begin, part->ct->subtype.len); - return 2; + if (!full) { + return 2; + } + + lua_createtable (L, 0, 2 + (part->ct->attrs ? + g_hash_table_size (part->ct->attrs) : 0)); + + if (part->ct->charset.len > 0) { + lua_pushstring (L, "charset"); + lua_pushlstring (L, part->ct->charset.begin, part->ct->charset.len); + lua_settable (L, -3); + } + + if (part->ct->boundary.len > 0) { + lua_pushstring (L, "charset"); + lua_pushlstring (L, part->ct->boundary.begin, part->ct->boundary.len); + lua_settable (L, -3); + } + + if (part->ct->attrs) { + g_hash_table_iter_init (&it, part->ct->attrs); + + while (g_hash_table_iter_next (&it, &k, &v)) { + akey = k; + avalue = v; + + if (akey->len > 0 && avalue->len > 0) { + lua_pushlstring (L, akey->begin, akey->len); + lua_pushlstring (L, avalue->begin, avalue->len); + lua_settable (L, -3); + } + } + } + + return 3; +} + +static gint +lua_mimepart_get_type (lua_State * L) +{ + return lua_mimepart_get_type_common (L, FALSE); +} + +static gint +lua_mimepart_get_type_full (lua_State * L) +{ + return lua_mimepart_get_type_common (L, TRUE); } static gint |