aboutsummaryrefslogtreecommitdiffstats
path: root/plugins/mod_presence.lua
diff options
context:
space:
mode:
authorKim Alvefur <zash@zash.se>2016-04-05 12:48:36 +0200
committerKim Alvefur <zash@zash.se>2016-04-05 12:48:36 +0200
commit69f2c9017677ef6a1bbec03793ee219d16d09f81 (patch)
tree95b6245c2b66f0d5696ba3cb2d43e61ea3a37357 /plugins/mod_presence.lua
parentd00290510d93265adb1ca29f17a15a168349c441 (diff)
parentafcc8898695dd49b60998369e55be70d1a266a82 (diff)
downloadprosody-69f2c9017677ef6a1bbec03793ee219d16d09f81.tar.gz
prosody-69f2c9017677ef6a1bbec03793ee219d16d09f81.zip
Merge 0.10->trunk
Diffstat (limited to 'plugins/mod_presence.lua')
-rw-r--r--plugins/mod_presence.lua23
1 files changed, 23 insertions, 0 deletions
diff --git a/plugins/mod_presence.lua b/plugins/mod_presence.lua
index 64d5a47b..d4f2f28d 100644
--- a/plugins/mod_presence.lua
+++ b/plugins/mod_presence.lua
@@ -357,3 +357,26 @@ module:hook("resource-unbind", function(event)
session.directed = nil;
end
end);
+
+module:hook("roster-item-removed", function (event)
+ local username = event.username;
+ local session = event.origin;
+ local roster = event.roster or session and session.roster;
+ local jid = event.jid;
+ local item = event.item;
+
+ 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}));
+ 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}));
+ end
+
+end, -1);
+