Mercurial > prosody-modules
view mod_measure_client_presence/mod_measure_client_presence.lua @ 4709:679f1834dbdb
mod_delegation: update to XEP-0355 v0.5
- namespace bump to "urn:xmpp:delegation:2"
- disco remaining infos now uses the XEP defined "urn:xmpp:delegation:2:bare:disco#info:*"
namespace
- complemeted disco remaining infos implementation for requests made on nodes not already
managed by the server
- bare JID disco items now uses the XEP defined
"urn:xmpp:delegation:2:bare:disco#items:*'" namespace
author | Goffi <goffi@goffi.org> |
---|---|
date | Fri, 15 Oct 2021 15:10:36 +0200 |
parents | 37ae0801f925 |
children |
line wrap: on
line source
module:set_global(); local measure = require"core.statsmanager".measure; local valid_shows = { available = true, chat = true, away = true, dnd = true, xa = true, unavailable = true, } local counters = { available = measure("amount", "client_presence.available"), chat = measure("amount", "client_presence.chat"), away = measure("amount", "client_presence.away"), dnd = measure("amount", "client_presence.dnd"), xa = measure("amount", "client_presence.xa"), unavailable = measure("amount", "client_presence.unavailable"), invalid = measure("amount", "client_presence.invalid"); }; module:hook("stats-update", function () local buckets = { available = 0, chat = 0, away = 0, dnd = 0, xa = 0, unavailable = 0, invalid = 0, }; for _, session in pairs(full_sessions) do local status = "unavailable"; if session.presence then status = session.presence:get_child_text("show") or "available"; end if valid_shows[status] ~= nil then buckets[status] = buckets[status] + 1; else buckets.invalid = buckets.invalid + 1; end end for bucket, count in pairs(buckets) do counters[bucket](count) end end)