diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-04-15 16:36:44 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-04-15 16:36:44 +0100 |
commit | 44e323e47431dc6e64e374f30565a2c292144f52 (patch) | |
tree | bd2ca4de92cd045f803c8d4906559623e9f07c57 /src/lua | |
parent | ac1c58789c0c7a57dfd9019850ae4cbff6e485f6 (diff) | |
download | rspamd-44e323e47431dc6e64e374f30565a2c292144f52.tar.gz rspamd-44e323e47431dc6e64e374f30565a2c292144f52.zip |
Add lua routines to access more url fields.
Diffstat (limited to 'src/lua')
-rw-r--r-- | src/lua/lua_url.c | 90 |
1 files changed, 89 insertions, 1 deletions
diff --git a/src/lua/lua_url.c b/src/lua/lua_url.c index 35486d0da..8c0fbd739 100644 --- a/src/lua/lua_url.c +++ b/src/lua/lua_url.c @@ -29,6 +29,8 @@ LUA_FUNCTION_DEF (url, get_host); LUA_FUNCTION_DEF (url, get_user); LUA_FUNCTION_DEF (url, get_path); LUA_FUNCTION_DEF (url, get_text); +LUA_FUNCTION_DEF (url, get_tld); +LUA_FUNCTION_DEF (url, to_table); LUA_FUNCTION_DEF (url, is_phished); LUA_FUNCTION_DEF (url, get_phished); LUA_FUNCTION_DEF (url, create); @@ -39,6 +41,8 @@ static const struct luaL_reg urllib_m[] = { LUA_INTERFACE_DEF (url, get_user), LUA_INTERFACE_DEF (url, get_path), LUA_INTERFACE_DEF (url, get_text), + LUA_INTERFACE_DEF (url, get_tld), + LUA_INTERFACE_DEF (url, to_table), LUA_INTERFACE_DEF (url, is_phished), LUA_INTERFACE_DEF (url, get_phished), {"__tostring", lua_url_get_text}, @@ -107,7 +111,7 @@ lua_url_get_path (lua_State *L) { struct rspamd_lua_url *url = lua_check_url (L, 1); - if (url != NULL) { + if (url != NULL && url->url->datalen > 0) { lua_pushlstring (L, url->url->data, url->url->datalen); } else { @@ -167,6 +171,90 @@ lua_url_get_phished (lua_State *L) } static gint +lua_url_get_tld (lua_State *L) +{ + struct rspamd_lua_url *url = lua_check_url (L, 1); + + if (url != NULL && url->url->tldlen > 0) { + lua_pushlstring (L, url->url->tld, url->url->tldlen); + } + else { + lua_pushnil (L); + } + + return 1; +} + +static gint +lua_url_to_table (lua_State *L) +{ + struct rspamd_lua_url *url = lua_check_url (L, 1); + struct rspamd_url *u; + + if (url != NULL) { + u = url->url; + lua_newtable (L); + lua_pushstring (L, "url"); + lua_pushlstring (L, u->string, u->urllen); + lua_settable (L, -3); + + if (u->hostlen > 0) { + lua_pushstring (L, "host"); + lua_pushlstring (L, u->host, u->hostlen); + lua_settable (L, -3); + } + + if (u->tldlen > 0) { + lua_pushstring (L, "tld"); + lua_pushlstring (L, u->tld, u->tldlen); + lua_settable (L, -3); + } + + if (u->userlen > 0) { + lua_pushstring (L, "user"); + lua_pushlstring (L, u->user, u->userlen); + lua_settable (L, -3); + } + + if (u->hostlen > 0) { + lua_pushstring (L, "path"); + lua_pushlstring (L, u->data, u->datalen); + lua_settable (L, -3); + } + + lua_pushstring (L, "protocol"); + + switch (u->protocol) { + case PROTOCOL_FILE: + lua_pushstring (L, "file"); + break; + case PROTOCOL_FTP: + lua_pushstring (L, "ftp"); + break; + case PROTOCOL_HTTP: + lua_pushstring (L, "http"); + break; + case PROTOCOL_HTTPS: + lua_pushstring (L, "https"); + break; + case PROTOCOL_MAILTO: + lua_pushstring (L, "mailto"); + break; + case PROTOCOL_UNKNOWN: + default: + lua_pushstring (L, "unknown"); + break; + } + lua_settable (L, -3); + } + else { + lua_pushnil (L); + } + + return 1; +} + +static gint lua_url_create (lua_State *L) { struct rspamd_url *url; |