Mercurial > prosody-modules
view mod_measure_message_e2ee/mod_measure_message_e2ee.lua @ 3611:235d986ac20f
misc/munin/prosody_: Add a total_s2s counter to work with mod_statistics_statsman
mod_s2s doesn't currently count s2sin and s2sout separately, so this is
a compromise for now.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Tue, 28 May 2019 21:32:50 +0200 |
parents | c414a7e884b3 |
children | 70e5bab388d8 |
line wrap: on
line source
module:set_global(); local count_message = module:measure("message", "rate"); local count_plain = module:measure("plain", "rate"); local count_openpgp = module:measure("openpgp", "rate"); local count_otr = module:measure("otr", "rate"); local count_ox = module:measure("ox", "rate"); local count_omemo = module:measure("omemo", "rate"); local count_encrypted = module:measure("encrypted", "rate"); local function message_handler(event) local origin, stanza = event.origin, event.stanza; -- This counts every message, even those with no body-like content. count_message(); -- Annotates that a message is encrypted, using any of the following methods. if stanza:get_child("encryption", "urn:xmpp:eme:0") then count_encrypted(); end if stanza:get_child("openpgp", "urn:xmpp:openpgp:0") then count_ox(); return; end if stanza:get_child("encrypted", "eu.siacs.conversations.axolotl") then count_omemo(); return; end if stanza:get_child("x", "jabber:x:encrypted") then count_openpgp(); return; end local body = stanza:get_child_text("body"); if body then if body:sub(1,4) == "?OTR" then count_otr(); return; end count_plain(); end end function module.add_host(host_module) module:log("debug", "Loaded on host %s", host_module); host_module:hook("pre-message/host", message_handler, 2); host_module:hook("pre-message/bare", message_handler, 2); host_module:hook("pre-message/full", message_handler, 2); end