From ecb98149c9a91e7e14a6e83f6cb2833c395399a9 Mon Sep 17 00:00:00 2001 From: Kim Alvefur Date: Fri, 8 Apr 2016 16:35:23 +0200 Subject: mod_presence: Construct a 'from' JID when roster items are removed outside of a session --- plugins/mod_presence.lua | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) (limited to 'plugins/mod_presence.lua') diff --git a/plugins/mod_presence.lua b/plugins/mod_presence.lua index d4f2f28d..258c5ea4 100644 --- a/plugins/mod_presence.lua +++ b/plugins/mod_presence.lua @@ -364,18 +364,19 @@ module:hook("roster-item-removed", function (event) local roster = event.roster or session and session.roster; local jid = event.jid; local item = event.item; + local from_jid = origin.full_jid or (username .. "@" .. module.host); local subscription = item and item.subscription or "none"; local ask = item and item.ask; local pending = roster and roster[false].pending[jid]; if subscription == "both" or subscription == "from" or pending then - core_post_stanza(session, st.presence({type="unsubscribed", from=session.full_jid, to=jid})); + core_post_stanza(session, st.presence({type="unsubscribed", from=from_jid, to=jid})); end if subscription == "both" or subscription == "to" or ask then send_presence_of_available_resources(username, module.host, jid, session, st.presence({type="unavailable"})); - core_post_stanza(session, st.presence({type="unsubscribe", from=session.full_jid, to=jid})); + core_post_stanza(session, st.presence({type="unsubscribe", from=from_jid, to=jid})); end end, -1); -- cgit v1.2.3 From f009c36365c7db3d8a298b3e00d4fd850b010e9a Mon Sep 17 00:00:00 2001 From: Kim Alvefur Date: Fri, 8 Apr 2016 17:14:58 +0200 Subject: mod_presence: Fix variable name --- plugins/mod_presence.lua | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'plugins/mod_presence.lua') diff --git a/plugins/mod_presence.lua b/plugins/mod_presence.lua index 258c5ea4..5e1eb404 100644 --- a/plugins/mod_presence.lua +++ b/plugins/mod_presence.lua @@ -364,7 +364,7 @@ module:hook("roster-item-removed", function (event) local roster = event.roster or session and session.roster; local jid = event.jid; local item = event.item; - local from_jid = origin.full_jid or (username .. "@" .. module.host); + local from_jid = session.full_jid or (username .. "@" .. module.host); local subscription = item and item.subscription or "none"; local ask = item and item.ask; -- cgit v1.2.3