diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-03-28 18:54:04 -0700 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2014-03-28 18:54:04 -0700 |
commit | 78368a4432e66deec609a26197b3176a1510717f (patch) | |
tree | bae7458af165fda8741bdcc229eba17542121d45 /src/lua | |
parent | 3e71c8b6ddaa774907692eb645f30a7df56cec17 (diff) | |
download | rspamd-78368a4432e66deec609a26197b3176a1510717f.tar.gz rspamd-78368a4432e66deec609a26197b3176a1510717f.zip |
Add common resolver function.
Diffstat (limited to 'src/lua')
-rw-r--r-- | src/lua/lua_common.c | 8 | ||||
-rw-r--r-- | src/lua/lua_common.h | 10 | ||||
-rw-r--r-- | src/lua/lua_dns.c | 76 |
3 files changed, 80 insertions, 14 deletions
diff --git a/src/lua/lua_common.c b/src/lua/lua_common.c index 0a3bbe624..0774615e5 100644 --- a/src/lua/lua_common.c +++ b/src/lua/lua_common.c @@ -649,3 +649,11 @@ lua_check_class (lua_State *L, gint index, const gchar *name) } return NULL; } + +int +rspamd_lua_typerror (lua_State *L, int narg, const char *tname) +{ + const char *msg = lua_pushfstring (L, "%s expected, got %s", tname, + luaL_typename(L, narg)); + return luaL_argerror (L, narg, msg); +} diff --git a/src/lua/lua_common.h b/src/lua/lua_common.h index ec5215edf..fc64ccd28 100644 --- a/src/lua/lua_common.h +++ b/src/lua/lua_common.h @@ -19,6 +19,11 @@ #define luaL_reg luaL_Reg #endif +#define LUA_ENUM(L, name, val) \ + lua_pushlstring(L, #name, sizeof(#name)-1); \ + lua_pushnumber(L, val); \ + lua_settable(L, -3); + #if LUA_VERSION_NUM > 501 static inline void luaL_register (lua_State *L, const gchar *name, const struct luaL_reg *methods) @@ -129,6 +134,11 @@ void lua_ip_push (lua_State *L, int af, gpointer data); void lua_ip_push_fromstring (lua_State *L, const gchar *ip_str); /** + * Create type error + */ +int rspamd_lua_typerror (lua_State *L, int narg, const char *tname); + +/** * Lua IP address structure */ struct rspamd_lua_ip { diff --git a/src/lua/lua_dns.c b/src/lua/lua_dns.c index 3f2b26389..dd2520105 100644 --- a/src/lua/lua_dns.c +++ b/src/lua/lua_dns.c @@ -34,6 +34,7 @@ LUA_FUNCTION_DEF (dns_resolver, resolve_a); LUA_FUNCTION_DEF (dns_resolver, resolve_ptr); LUA_FUNCTION_DEF (dns_resolver, resolve_txt); LUA_FUNCTION_DEF (dns_resolver, resolve_mx); +LUA_FUNCTION_DEF (dns_resolver, resolve); static const struct luaL_reg dns_resolverlib_f[] = { LUA_INTERFACE_DEF (dns_resolver, init), @@ -45,6 +46,7 @@ static const struct luaL_reg dns_resolverlib_m[] = { LUA_INTERFACE_DEF (dns_resolver, resolve_ptr), LUA_INTERFACE_DEF (dns_resolver, resolve_txt), LUA_INTERFACE_DEF (dns_resolver, resolve_mx), + LUA_INTERFACE_DEF (dns_resolver, resolve), {"__tostring", lua_class_tostring}, {NULL, NULL} }; @@ -65,6 +67,22 @@ struct lua_dns_cbdata { const gchar *user_str; }; +static int +lua_dns_get_type (lua_State *L, int argno) +{ + int type; + + lua_pushvalue (L, argno); + lua_gettable (L, lua_upvalueindex (1)); + + type = lua_tonumber (L, -1); + lua_pop (L, 1); + if (type == 0) { + rspamd_lua_typerror (L, argno, "dns_request_type"); + } + return type; +} + static void lua_dns_callback (struct rdns_reply *reply, gpointer arg) { @@ -173,7 +191,7 @@ lua_dns_resolver_init (lua_State *L) static int lua_dns_resolver_resolve_common (lua_State *L, struct rspamd_dns_resolver *resolver, - enum rdns_request_type type) + enum rdns_request_type type, int first) { struct rspamd_async_session *session, **psession; memory_pool_t *pool, **ppool; @@ -181,15 +199,15 @@ lua_dns_resolver_resolve_common (lua_State *L, struct rspamd_dns_resolver *resol struct lua_dns_cbdata *cbdata; /* Check arguments */ - psession = luaL_checkudata (L, 2, "rspamd{session}"); - luaL_argcheck (L, psession != NULL, 2, "'session' expected"); + psession = luaL_checkudata (L, first, "rspamd{session}"); + luaL_argcheck (L, psession != NULL, first, "'session' expected"); session = psession ? *(psession) : NULL; - ppool = luaL_checkudata (L, 3, "rspamd{mempool}"); - luaL_argcheck (L, ppool != NULL, 3, "'mempool' expected"); + ppool = luaL_checkudata (L, first + 1, "rspamd{mempool}"); + luaL_argcheck (L, ppool != NULL, first + 1, "'mempool' expected"); pool = ppool ? *(ppool) : NULL; - to_resolve = luaL_checkstring (L, 4); + to_resolve = luaL_checkstring (L, first + 2); - if (pool != NULL && session != NULL && to_resolve != NULL && lua_isfunction (L, 5)) { + if (pool != NULL && session != NULL && to_resolve != NULL && lua_isfunction (L, first + 3)) { cbdata = memory_pool_alloc (pool, sizeof (struct lua_dns_cbdata)); cbdata->L = L; cbdata->resolver = resolver; @@ -207,11 +225,11 @@ lua_dns_resolver_resolve_common (lua_State *L, struct rspamd_dns_resolver *resol cbdata->to_resolve = memory_pool_strdup (pool, ptr_str); free (ptr_str); } - lua_pushvalue (L, 5); + lua_pushvalue (L, first + 3); cbdata->cbref = luaL_ref (L, LUA_REGISTRYINDEX); - if (lua_gettop (L) > 5) { - cbdata->user_str = lua_tostring (L, 6); + if (lua_gettop (L) > first + 3) { + cbdata->user_str = lua_tostring (L, first + 4); } else { cbdata->user_str = NULL; @@ -234,7 +252,7 @@ lua_dns_resolver_resolve_a (lua_State *L) struct rspamd_dns_resolver *dns_resolver = lua_check_dns_resolver (L); if (dns_resolver) { - return lua_dns_resolver_resolve_common (L, dns_resolver, DNS_REQUEST_A); + return lua_dns_resolver_resolve_common (L, dns_resolver, DNS_REQUEST_A, 2); } else { lua_pushnil (L); @@ -249,7 +267,7 @@ lua_dns_resolver_resolve_ptr (lua_State *L) struct rspamd_dns_resolver *dns_resolver = lua_check_dns_resolver (L); if (dns_resolver) { - return lua_dns_resolver_resolve_common (L, dns_resolver, DNS_REQUEST_PTR); + return lua_dns_resolver_resolve_common (L, dns_resolver, DNS_REQUEST_PTR, 2); } else { lua_pushnil (L); @@ -264,7 +282,7 @@ lua_dns_resolver_resolve_txt (lua_State *L) struct rspamd_dns_resolver *dns_resolver = lua_check_dns_resolver (L); if (dns_resolver) { - return lua_dns_resolver_resolve_common (L, dns_resolver, DNS_REQUEST_TXT); + return lua_dns_resolver_resolve_common (L, dns_resolver, DNS_REQUEST_TXT, 2); } else { lua_pushnil (L); @@ -279,7 +297,25 @@ lua_dns_resolver_resolve_mx (lua_State *L) struct rspamd_dns_resolver *dns_resolver = lua_check_dns_resolver (L); if (dns_resolver) { - return lua_dns_resolver_resolve_common (L, dns_resolver, DNS_REQUEST_MX); + return lua_dns_resolver_resolve_common (L, dns_resolver, DNS_REQUEST_MX, 2); + } + else { + lua_pushnil (L); + } + + return 1; +} + +static int +lua_dns_resolver_resolve (lua_State *L) +{ + struct rspamd_dns_resolver *dns_resolver = lua_check_dns_resolver (L); + int type; + + type = lua_dns_get_type (L, 2); + + if (dns_resolver && type != 0) { + return lua_dns_resolver_resolve_common (L, dns_resolver, type, 3); } else { lua_pushnil (L); @@ -291,6 +327,7 @@ lua_dns_resolver_resolve_mx (lua_State *L) gint luaopen_dns_resolver (lua_State * L) { + luaL_newmetatable (L, "rspamd{resolver}"); lua_pushstring (L, "__index"); lua_pushvalue (L, -2); @@ -300,6 +337,17 @@ luaopen_dns_resolver (lua_State * L) lua_pushstring (L, "rspamd{resolver}"); lua_rawset (L, -3); + lua_newtable(L); + { + LUA_ENUM(L, DNS_REQUEST_A, DNS_REQUEST_A); + LUA_ENUM(L, DNS_REQUEST_PTR, DNS_REQUEST_PTR); + LUA_ENUM(L, DNS_REQUEST_MX, DNS_REQUEST_MX); + LUA_ENUM(L, DNS_REQUEST_TXT, DNS_REQUEST_TXT); + LUA_ENUM(L, DNS_REQUEST_SRV, DNS_REQUEST_SRV); + LUA_ENUM(L, DNS_REQUEST_SPF, DNS_REQUEST_SRV); + LUA_ENUM(L, DNS_REQUEST_AAA, DNS_REQUEST_SRV); + } + luaL_register (L, NULL, dns_resolverlib_m); luaL_register (L, "rspamd_resolver", dns_resolverlib_f); |