Software /
code /
prosody
Changeset
13025:b7d0c1d75a37
mod_csi: Add metrics, covering changes and totals
Motivation: Investigating clients that seem to forget to set CSI.
Also, of course, MORE GRAPHS!
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Thu, 06 Apr 2023 08:01:55 +0200 |
parents | 13024:7558fd152459 |
children | 13026:a97f4b277221 |
files | plugins/mod_csi.lua |
diffstat | 1 files changed, 12 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- a/plugins/mod_csi.lua Wed Apr 05 15:33:56 2023 +0100 +++ b/plugins/mod_csi.lua Thu Apr 06 08:01:55 2023 +0200 @@ -2,6 +2,17 @@ local xmlns_csi = "urn:xmpp:csi:0"; local csi_feature = st.stanza("csi", { xmlns = xmlns_csi }); +local sum = module:metric("gauge", "sessions_per_state", "sessions", "CSI state per session", { "csi_state" }) +local change = module:metric("counter", "changes", "events", "CSI state changes", {"csi_state"}); + +module:hook_global("stats-update", function () + for _, session in pairs(prosody.full_sessions) do + if session.host == module.host then + sum:with_labels(session.state or "none"):add(1); + end + end +end); + local csi_handler_available = nil; module:hook("stream-features", function (event) if event.origin.username and csi_handler_available then @@ -13,6 +24,7 @@ return function (event) if event.origin.username then event.origin.state = event.stanza.name; + change:with_labels(event.stanza.name):add(1); module:fire_event(name, event); return true; end