File

mod_measure_stanza_counts/mod_measure_stanza_counts.lua @ 5049:e89aad13a52a

mod_sasl2: Further break up success handling, into pre/post stream:features This allows us to enable mod_smacks after sending success, but before sending stream:features. Previously, the features were being calculated before SM was finalized on the session. We can't finalize SM before sending <success> because it may generate stanzas.
author Matthew Wild <mwild1@gmail.com>
date Thu, 22 Sep 2022 18:25:44 +0100
parent 4559:33b1b6ff23d8
line wrap: on
line source

module:set_global()

local filters = require"util.filters";

local stanzas_in = module:metric(
	"counter", "received", "",
	"Stanzas received by Prosody",
	{ "session_type", "stanza_kind" }
)
local stanzas_out = module:metric(
	"counter", "sent", "",
	"Stanzas sent by prosody",
	{ "session_type", "stanza_kind" }
)

local stanza_kinds = { message = true, presence = true, iq = true };

local function rate(metric_family)
	return function (stanza, session)
		if stanza.attr and not stanza.attr.xmlns and stanza_kinds[stanza.name] then
			metric_family:with_labels(session.type, stanza.name):add(1);
		end
		return stanza;
	end
end

local function measure_stanza_counts(session)
	filters.add_filter(session, "stanzas/in",  rate(stanzas_in));
	filters.add_filter(session, "stanzas/out", rate(stanzas_out));
end

filters.add_filter_hook(measure_stanza_counts);