Software /
code /
prosody-modules
File
mod_measure_message_length/mod_measure_message_length.lua @ 4538:591c643d55b2
mod_storage_xmlarchive: Insert micropauses in long-running queries
Allows other processing to be interleaved with long-running queries.
Drops 0.9 support since it requires util.async, but 0.9 really should be
EOL by now.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Sat, 10 Apr 2021 01:16:02 +0200 |
parent | 3430:6e70d354b7d8 |
line wrap: on
line source
local bytes = module:measure("bytes", "sizes"); local lines = module:measure("lines", "distribution"); local words = module:measure("words", "distribution"); local function measure_length(event) local body = event.stanza:get_child_text("body"); if body then bytes(#body); lines(select(2, body:gsub("[^\n]+",""))); words(select(2, body:gsub("%S+",""))); end end module:hook("message/full", measure_length); module:hook("message/bare", measure_length); module:hook("message/host", measure_length); module:hook("pre-message/full", measure_length); module:hook("pre-message/bare", measure_length); module:hook("pre-message/host", measure_length);