Software /
code /
prosody-modules
File
mod_track_muc_joins/mod_track_muc_joins.lua @ 2093:7b9520479e99
mod_firewall: README: Document LOG's ability to take meta expressions
author | Matthew Wild <mwild1@gmail.com> |
---|---|
date | Wed, 16 Mar 2016 11:46:47 +0000 |
parent | 2085:8cb8004091f8 |
child | 2156:3fcac143fe0b |
line wrap: on
line source
local jid_bare = require "util.jid".bare; local sessions = prosody.full_sessions; module:hook("presence/full", function (event) local stanza = event.stanza; local session = sessions[stanza.attr.to]; if not session then return end; local log = session.log or module._log; local muc_x = stanza:get_child("x", "http://jabber.org/protocol/muc#user"); if not muc_x then return end -- Not MUC related local room = jid_bare(stanza.attr.from); local joined = stanza.attr.type; if joined == nil then joined = true; elseif joined == "unavailable" then joined = nil; else -- Ignore errors and whatever return; end -- Check for status code 100, meaning it's their own reflected presence for status in muc_x:childtags("status") do log("debug", "Status code %d", status.attr.code); if status.attr.code == "110" then log("debug", "%s room %s", joined and "Joined" or "Left", room); local rooms = session.rooms_joined; if not rooms then session.rooms_joined = { [room] = joined }; else rooms[room] = joined; end return; end end end); -- TODO Check session.directed for outgoing presence?