Software /
code /
prosody-modules
File
mod_report_tracker/mod_report_tracker.lua @ 6120:bd3ff802d883
mod_anti_spam: Fix another traceback for origin sessions without an IP
This is likely to be the case for stanzas originating from local hosts, for
example (so not true s2s). It should be safe to bypass the IP check for those.
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Sat, 28 Dec 2024 21:02:08 +0000 |
parent | 6064:765e0235c202 |
line wrap: on
line source
local um = require "core.usermanager"; local cache = require "util.cache"; local jid = require "util.jid"; local trusted_reporters = module:get_option_inherited_set("trusted_reporters", {}); local reports_received = module:open_store("reports_received"); local xmlns_reporting = "urn:xmpp:reporting:1"; local reported_users = cache.new(256); local function is_trusted_reporter(reporter_jid) return trusted_reporters:contains(reporter_jid); end function handle_report(event) local stanza = event.stanza; local report = stanza:get_child("report", xmlns_reporting); if not report then return; end local reported_jid = report:get_child_text("jid", "urn:xmpp:jid:0") or stanza:find("{urn:xmpp:forward:0}forwarded/{jabber:client}message@from"); if not reported_jid then module:log("debug", "Discarding report with no JID"); return; elseif jid.host(reported_jid) ~= module.host then module:log("debug", "Discarding report about non-local user"); return; end local reporter_jid = stanza.attr.from; if jid.node(reporter_jid) then module:log("debug", "Discarding report from non-server JID"); return; end local reported_user = jid.node(reported_jid); if not um.user_exists(reported_user, module.host) then module:log("debug", "Discarding report about non-existent user"); return; end if is_trusted_reporter(reporter_jid) then local current_reports = reports_received:get(reported_user, reporter_jid); if not current_reports then current_reports = { first = os.time(); last = os.time(); count = 1; }; else current_reports.last = os.time(); current_reports.count = current_reports.count + 1; end reports_received:set(reported_user, reporter_jid, current_reports); reported_users:set(reported_user, true); module:log("info", "Received abuse report about <%s> from <%s>", reported_jid, reporter_jid); module:fire_event(module.name.."/account-reported", { report_from = reporter_jid; reported_user = reported_user; report = report; }); else module:log("warn", "Discarding abuse report about <%s> from untrusted source <%s>", reported_jid, reporter_jid); end -- Message was handled return true; end module:hook("message/host", handle_report); module:add_item("account-trait", { name = "reported-by-trusted-server"; prob_bad_true = 0.80; prob_bad_false = 0.50; }); module:hook("get-account-traits", function (event) local username = event.username; local reported = reported_users:get(username); if reported == nil then -- Check storage, update cache reported = not not reports_received:get(username); reported_users:set(username, reported); end event.traits["reported-by-trusted-server"] = reported; end);