diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-08-13 15:04:42 +0100 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2018-08-13 15:04:42 +0100 |
commit | 4ba8e13af571398fbaa8877c999ee77fd39f39ac (patch) | |
tree | fab5ea72b716dd894395601e995b368869f5bedc /src | |
parent | 149a6439a79d45f4ec0fb683385e4a44e3cf2862 (diff) | |
download | rspamd-4ba8e13af571398fbaa8877c999ee77fd39f39ac.tar.gz rspamd-4ba8e13af571398fbaa8877c999ee77fd39f39ac.zip |
[Minor] Fix conditional debugging
Diffstat (limited to 'src')
-rw-r--r-- | src/libutil/logger.c | 11 | ||||
-rw-r--r-- | src/lua/lua_logger.c | 25 |
2 files changed, 32 insertions, 4 deletions
diff --git a/src/libutil/logger.c b/src/libutil/logger.c index c9f14ccb6..0e20ec8e0 100644 --- a/src/libutil/logger.c +++ b/src/libutil/logger.c @@ -655,7 +655,7 @@ rspamd_common_logv (rspamd_logger_t *rspamd_log, gint level_flags, const gchar *fmt, va_list args) { gchar logbuf[RSPAMD_LOGBUF_SIZE], *end; - gint level = level_flags & (RSPAMD_LOG_LEVEL_MASK & G_LOG_LEVEL_MASK); + gint level = level_flags & (RSPAMD_LOG_LEVEL_MASK & G_LOG_LEVEL_MASK), mod_id; if (G_UNLIKELY (rspamd_log == NULL)) { rspamd_log = default_logger; @@ -669,7 +669,14 @@ rspamd_common_logv (rspamd_logger_t *rspamd_log, gint level_flags, } } else { - if (rspamd_logger_need_log (rspamd_log, level, -1)) { + if (level == G_LOG_LEVEL_DEBUG) { + mod_id = rspamd_logger_add_debug_module (module); + } + else { + mod_id = -1; + } + + if (rspamd_logger_need_log (rspamd_log, level_flags, mod_id)) { end = rspamd_vsnprintf (logbuf, sizeof (logbuf), fmt, args); if ((level_flags & RSPAMD_LOG_ENCRYPTED) && rspamd_log->pk) { diff --git a/src/lua/lua_logger.c b/src/lua/lua_logger.c index fe2fe7d28..75c2984c6 100644 --- a/src/lua/lua_logger.c +++ b/src/lua/lua_logger.c @@ -141,7 +141,7 @@ LUA_FUNCTION_DEF (logger, debugm); LUA_FUNCTION_DEF (logger, slog); /*** - * @function logger.logx(level, id, fmt[, args) + * @function logger.logx(level, module, id, fmt[, args) * Extended interface to make a generic log message on any level * @param {number} log level as a number (see GLogLevelFlags enum for values) * @param {task|cfg|pool|string} id id to log @@ -804,8 +804,29 @@ lua_logger_logx (lua_State *L) { LUA_TRACE_POINT; GLogLevelFlags flags = lua_tonumber (L, 1); + const gchar *modname = lua_tostring (L, 2), *uid = NULL; + gchar logbuf[RSPAMD_LOGBUF_SIZE - 128]; + gboolean ret; + + if (lua_type (L, 3) == LUA_TSTRING) { + uid = luaL_checkstring (L, 3); + } + else { + uid = lua_logger_get_id (L, 3, NULL); + } - return lua_logger_do_log (L, flags, FALSE, 2); + if (uid && modname && lua_type (L, 4) == LUA_TSTRING) { + ret = lua_logger_log_format (L, 4, FALSE, logbuf, sizeof (logbuf) - 1); + + if (ret) { + lua_common_log_line (flags, L, logbuf, uid, modname); + } + } + else { + return luaL_error (L, "invalid arguments"); + } + + return 0; } |