--- a/core/rostermanager.lua Sat Oct 25 02:29:58 2008 +0500
+++ b/core/rostermanager.lua Sat Oct 25 02:38:24 2008 +0500
@@ -121,4 +121,18 @@
end
end
+function process_inbound_unsubscribe(username, host, jid)
+ local roster = load_roster(username, host);
+ local item = roster[jid];
+ if item and (item.subscription == "from" or item.subscription == "both") then
+ if item.subscription == "from" then
+ item.subscription = "none";
+ else
+ item.subscription = "to";
+ end
+ item.ask = nil;
+ return datamanager.store(username, host, "roster", roster);
+ end
+end
+
return _M;
\ No newline at end of file
--- a/core/stanza_router.lua Sat Oct 25 02:29:58 2008 +0500
+++ b/core/stanza_router.lua Sat Oct 25 02:38:24 2008 +0500
@@ -209,7 +209,9 @@
elseif stanza.attr.type == "subscribe" then
-- TODO
elseif stanza.attr.type == "unsubscribe" then
- -- TODO
+ if rostermanager.process_inbound_unsubscribe(node, host, from_bare) then
+ rostermanager.roster_push(node, host, from_bare);
+ end
elseif stanza.attr.type == "subscribed" then
if rostermanager.process_inbound_subscription_approval(node, host, from_bare) then
rostermanager.roster_push(node, host, from_bare);