Mercurial > prosody-modules
view mod_measure_message_length/mod_measure_message_length.lua @ 3955:017f60608fc8
mod_smacks: also count outgoing MAM messages
mod_smacks doesn't count outgoing MAM messages, which causes warnings in Prosody such as:
> The client says it handled 41 new stanzas, but we only sent 2
It seems mod_smacks is in the wrong here and that it's too strict in trying to determine what is a valid stanza to count.
In RFC6120:
> Definition of XML Stanza: An XML stanza is the basic unit of meaning
> in XMPP. A stanza is a first-level element (at depth=1 of the stream)
> whose element name is "message", "presence", or "iq" and whose
> qualifying namespace is 'jabber:client' or 'jabber:server'.
author | JC Brand <jc@opkode.com> |
---|---|
date | Thu, 26 Mar 2020 11:57:02 +0100 |
parents | 6e70d354b7d8 |
children |
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);