diff options
author | Kim Alvefur <zash@zash.se> | 2017-10-23 15:23:03 +0200 |
---|---|---|
committer | Kim Alvefur <zash@zash.se> | 2017-10-23 15:23:03 +0200 |
commit | 695e80fad2270d317dd3b45b0d2ef2c9aec7062d (patch) | |
tree | 69f5dba453329641546409679b2402f96e7aba32 /plugins | |
parent | 42f6c1a8c852faa888a999128c47a0839831b1bc (diff) | |
download | prosody-695e80fad2270d317dd3b45b0d2ef2c9aec7062d.tar.gz prosody-695e80fad2270d317dd3b45b0d2ef2c9aec7062d.zip |
mod_stanza_debug: Logs full stanzas sent and received for debugging purposes
Diffstat (limited to 'plugins')
-rw-r--r-- | plugins/mod_stanza_debug.lua | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/plugins/mod_stanza_debug.lua b/plugins/mod_stanza_debug.lua new file mode 100644 index 00000000..6dedb6f7 --- /dev/null +++ b/plugins/mod_stanza_debug.lua @@ -0,0 +1,29 @@ +module:set_global(); + +local tostring = tostring; +local filters = require "util.filters"; + +local function log_send(t, session) + if t and t ~= "" and t ~= " " then + session.log("debug", "SEND: %s", tostring(t)); + end + return t; +end + +local function log_recv(t, session) + if t and t ~= "" and t ~= " " then + session.log("debug", "RECV: %s", tostring(t)); + end + return t; +end + +local function init_raw_logging(session) + filters.add_filter(session, "stanzas/in", log_recv, -10000); + filters.add_filter(session, "stanzas/out", log_send, 10000); +end + +filters.add_filter_hook(init_raw_logging); + +function module.unload() + filters.remove_filter_hook(init_raw_logging); +end |