mirror of
https://github.com/bjc/prosody.git
synced 2025-04-04 21:57:45 +03:00
mod_csi_simple: Don't consider presence errors as important
A large share of `<presence type=error>` appears to be noise from large public channels and failed presence probes. The later at least should count as presence updates, which are currently considered unimportant. See also 8cecb85e4bc4 which is partly reverted here. The intent there was probably mostly about message (delivery) errors, which should be considered important.
This commit is contained in:
parent
d146cc6f58
commit
9339ebb8e3
1 changed files with 5 additions and 4 deletions
|
@ -28,18 +28,19 @@ module:hook("csi-is-stanza-important", function (event)
|
|||
local st_name = stanza.name;
|
||||
if not st_name then return false; end
|
||||
local st_type = stanza.attr.type;
|
||||
if st_type == "error" then
|
||||
return true;
|
||||
end
|
||||
if st_name == "presence" then
|
||||
if st_type == nil or st_type == "unavailable" then
|
||||
if st_type == nil or st_type == "unavailable" or st_name == "error" then
|
||||
return false;
|
||||
end
|
||||
-- TODO Some MUC awareness, e.g. check for the 'this relates to you' status code
|
||||
return true;
|
||||
elseif st_name == "message" then
|
||||
if st_type == "headline" then
|
||||
return false;
|
||||
end
|
||||
if st_type == "error" then
|
||||
return true;
|
||||
end
|
||||
if stanza:get_child("sent", "urn:xmpp:carbons:2") then
|
||||
return true;
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue