Software /
code /
prosody-modules
File
mod_statsd/mod_statsd.lua @ 5571:ca3c2d11823c
mod_pubsub_feeds: Track latest timestamp seen in feeds instead of last poll
This should ensure that an entry that has a publish timestmap after the
previously oldest post, but before the time of the last poll check, is
published to the node.
Previously if an entry would be skipped if it was published at 13:00
with a timestamp of 12:30, where the last poll was at 12:45.
For feeds that lack a timestamp, it now looks for the first post that is
not published, assuming that the feed is in reverse chronological order,
then iterates back up from there.
author | Kim Alvefur <zash@zash.se> |
---|---|
date | Sun, 25 Jun 2023 16:27:55 +0200 |
parent | 2875:c3a039972b74 |
line wrap: on
line source
-- Log common stats to statsd -- -- Copyright (C) 2014 Daurnimator -- -- This module is MIT/X11 licensed. local socket = require "socket" local iterators = require "util.iterators" local jid = require "util.jid" local bare_sessions = prosody.bare_sessions; local options = module:get_option("statsd") or {} -- Create UDP socket to statsd server local sock = socket.udp() sock:setpeername(options.hostname or "127.0.0.1", options.port or 8125) -- Metrics are namespaced by ".", and separated by newline function clean(s) return (s:gsub("[%.:\n]", "_")) end -- A 'safer' send function to expose function send(s) return sock:send(s) end -- prefix should end in "." local prefix = (options.prefix or "prosody") .. "." if not options.no_host then prefix = prefix .. clean(module.host) .. "." end -- Track users as they bind/unbind -- count bare sessions every time, as we have no way to tell if it's a new bare session or not module:hook("resource-bind", function(event) send(prefix.."bare_sessions:"..iterators.count(pairs(bare_sessions)).."|g") send(prefix.."full_sessions:+1|g") end, 1) module:hook("resource-unbind", function(event) send(prefix.."bare_sessions:"..iterators.count(pairs(bare_sessions)).."|g") send(prefix.."full_sessions:-1|g") end, 1) -- Track MUC occupants as they join/leave module:hook("muc-occupant-joined", function(event) send(prefix.."n_occupants:+1|g") local room_node = jid.split(event.room.jid) send(prefix..clean(room_node)..".occupants:+1|g") end) module:hook("muc-occupant-left", function(event) send(prefix.."n_occupants:-1|g") local room_node = jid.split(event.room.jid) send(prefix..clean(room_node)..".occupants:-1|g") end) -- Misc other MUC module:hook("muc-broadcast-message", function(event) send(prefix.."broadcast-message:1|c") local room_node = jid.split(event.room.jid) send(prefix..clean(room_node)..".broadcast-message:1|c") end) module:hook("muc-invite", function(event) -- Total count send(prefix.."invite:1|c") local room_node = jid.split(event.room.jid) -- Counts per room send(prefix..clean(room_node)..".invite:1|c") -- Counts per recipient send(prefix..clean(event.stanza.attr.to)..".invited:1|c") end) module:hook("muc-decline", function(event) -- Total count send(prefix.."decline:1|c") local room_node = jid.split(event.room.jid) -- Counts per room send(prefix..clean(room_node)..".decline:1|c") -- Counts per sender send(prefix..clean(event.incoming.attr.from)..".declined:1|c") end)