# HG changeset patch # User Rob Hoelz # Date 1430310247 18000 # Node ID 752d52d61186c04512a0aead7a289690ebbd8ee7 # Parent a9df1f7e273dfe612d206f2c671e81833b52f5e4# Parent 94c4d4899a21ee59f003c30af30c7501f333693d Merge my branch containing proctitle module diff -r 94c4d4899a21 -r 752d52d61186 mod_log_slow_events/mod_log_slow_events.lua --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/mod_log_slow_events/mod_log_slow_events.lua Wed Apr 29 07:24:07 2015 -0500 @@ -0,0 +1,35 @@ +local time = require "socket".gettime; + +local max_seconds = module:get_option_number("log_slow_events_threshold", 0.5); + +module:wrap_event(false, function (handlers, event_name, event_data) + local start = time(); + local ret = handlers(event_name, event_data); + local duration = time()-start; + if duration > max_seconds then + local data = {}; + if event_data then + local function log_data(name, value) + if value then + table.insert(data, ("%s=%q"):format(name, value)); + return true; + end + end + local sess = event_data.origin or event_data.session; + if sess then + log_data("ip", sess.ip); + if not log_data("full_jid", sess.full_jid) then + log_data("username", sess.username); + end + log_data("type", sess.type); + log_data("host", sess.host); + end + local stanza = event_data.stanza; + if stanza then + log_data("stanza", tostring(stanza)); + end + end + module:log("warn", "Slow event '%s' took %0.2f: %s", event_name, duration, next(data) and table.concat(data, ", ") or "no recognised data"); + end + return ret; +end);